



FLOATING POINT  
SYSTEMS, INC.

**Programmers  
Reference  
Manual  
Part One**

**860-7319-000**

1st Edition, January 1978

Publication No. FPS-7319

#### NOTICE

The material in this manual is for information purposes only and is subject to change without notice.

Floating Point Systems, Inc. assumes no responsibility for any errors which may appear in this publication.

Copyright  1978 by Floating Point Systems, Inc.  
Beaverton, Oregon 97005

All rights reserved. No part of this publication may be reproduced in any form or by any means without written permission from the publisher.

Printed in U.S.A.

## CONTENTS

|                                                                           | Page       |
|---------------------------------------------------------------------------|------------|
| <b>CHAPTER 1      INTRODUCTION</b>                                        | <b>1-1</b> |
| 1.1            PURPOSE                                                    | 1-1        |
| 1.2            SCOPE                                                      | 1-2        |
| 1.3            GENERAL DESCRIPTION                                        | 1-3        |
| 1.4            SYSTEM OVERVIEW                                            | 1-4        |
| 1.5            EXAMPLE AP-120B APPLICATION                                | 1-7        |
| 1.6            SOFTWARE                                                   | 1-8        |
| 1.6.1        APEX (A.P. Executive)                                        | 1-8        |
| 1.6.2        APMATH                                                       | 1-8        |
| 1.6.3        Program Development Package                                  | 1-8        |
| 1.6.4        APTEST                                                       | 1-9        |
| <b>CHAPTER 2      FUNCTIONAL OVERVIEW</b>                                 | <b>2-1</b> |
| 2.1            CONTROL UNIT                                               | 2-2        |
| 2.2            S-PAD UNIT                                                 | 1-3        |
| 2.3            FLOATING ADDER UNIT                                        | 2-5        |
| 2.4            FLOATING MULTIPLIER UNIT                                   | 2-7        |
| 2.5            DATA PAD UNIT                                              | 2-9        |
| 2.6            DATA MEMORY UNIT                                           | 2-11       |
| 2.7            TABLE MEMORY UNIT                                          | 2-13       |
| 2.8            INTERNAL FLOATING POINT FORMAT                             | 2-14       |
| <b>CHAPTER 3      FLOATING POINT ARITHMETIC THEORY</b>                    |            |
| 3.1            INTRODUCTION                                               | 3-2        |
| 3.2            GENERAL NUMBERING SYSTEMS                                  | 3-3        |
| 3.2.1        Base                                                         | 3-3        |
| 3.2.2        Radix Point                                                  | 3-3        |
| 3.2.3        Types of Binary Notation Systems                             | 3-4        |
| 3.3            NUMBER FORMATS                                             | 3-11       |
| 3.3.1        Fixed-Point Numbers                                          | 3-11       |
| 3.3.2        Floating-Point Numbers                                       | 3-13       |
| 3.3.3        Normalization                                                | 3-14       |
| 3.4            AP-120B FLOATING-POINT FORMAT (FPN)                        | 3-16       |
| 3.5            AP-120B FLOATING-POINT ARITHMETIC OPERATIONS<br>(OVERVIEW) | 3-20       |
| 3.5.1        Floating-Point Addition, Subtraction and<br>Multiplication   | 3-21       |
| 3.5.2        Rounding                                                     | 3-25       |
| 3.5.3        Overflow and Underflow                                       | 3-29       |

CHAPTER 4 DETAILED DESCRIPTIONS OF THE FUNCTIONAL UNITS

|        |                                                 |       |
|--------|-------------------------------------------------|-------|
| 4.1    | S-PAD                                           | 4-1   |
| 4.1.1  | General Description                             | 4-1   |
| 4.1.2  | S-PAD Operations                                | 4-4   |
| 4.1.3  | S-PAD Source and Destination Registers          | 4-5   |
| 4.1.4  | S-PAD Function                                  | 4-6   |
| 4.1.5  | S-PAD Modifiers "#", "Sh", "&"                  | 4-7   |
| 4.1.6  | S-PAD Associated Test and Branch Operations     | 4-8   |
| 4.1.7  | Bit Reverse                                     | 4-10  |
| 4.1.8  | General Programming Rules                       | 4-15  |
| 4.1.9  | S-PAD Carry Bit Conditions                      | 4-16  |
| 4.1.10 | Programming Example                             | 4-17  |
| 4.2    | SPECIAL OPERATIONS GROUP (SPEC)                 | 4-19  |
| 4.2.1  | Branch Operations                               | 4-20  |
| 4.2.2  | Data Transfer Operations                        | 4-27  |
| 4.2.3  | Program Source Address Modification             | 4-32  |
| 4.2.4  | Branch Group Summary                            | 4-36  |
| 4.2.5  | AP-120B Internal Status Register (APSTATUS)     | 4-39  |
| 4.2.6  | PERR and PENB, Theory of Operation              | 4-43  |
| 4.3    | FLOATING ADDER (FADDR)                          | 4-45  |
| 4.3.1  | General Description, Theory of Operation        | 4-46  |
| 4.3.2  | FADDR Single and Double Operand Operations      | 4-49  |
| 4.3.3  | Floating Point Logical Operations               | 4-50  |
| 4.3.4  | FADDR Operands (via A1, A2 Registers)           | 4-52  |
| 4.3.5  | FADDR Result (FA)                               | 4-53  |
| 4.3.6  | FADDR Test, Branch and Error Condition          | 4-54  |
| 4.3.7  | Floating Point Adder Programming Considerations | 4-55  |
| 4.4    | FLOATING MULTIPLIER (FMULR)                     | 4-58  |
| 4.4.1  | General Description, Theory of Operation        | 4-59  |
| 4.4.2  | The FMULR Operation -- FMUL                     | 4-62  |
| 4.4.3  | FMULR Operands (via M1, M2 Registers)           | 4-63  |
| 4.4.4  | The FMULR Result (FM)                           | 4-64  |
| 4.4.5  | FMULR Test, Branch and Error Conditions         | 4-65  |
| 4.4.6  | FMUL Programming Considerations                 | 4-66  |
| 4.5    | I/O GROUP                                       | 4-71  |
| 4.5.1  | AP-120B I/O Operations                          | 4-72  |
| 4.5.2  | Virtual Front Panel (PANEL)                     | 4-77  |
| 4.5.3  | Programmed I/O                                  | 4-87  |
| 4.5.4  | Programming Example                             | 4-104 |
| 4.6    | DATA PAD SUMMARY                                | 4-110 |
| 4.6.1  | General Description, Theory of Operation        | 4-111 |
| 4.6.2  | Data Pad Operations                             | 4-112 |
| 4.6.3  | Data Pad Addressing                             | 4-116 |
| 4.6.4  | Programming Examples                            | 4-118 |
| 4.7    | MEMORY GROUP                                    | 4-120 |
| 4.7.1  | Main Data Memory (MD)                           | 4-121 |
| 4.7.2  | Table Memory (TMA)                              | 4-131 |

|           |                                                       |      |
|-----------|-------------------------------------------------------|------|
| CHAPTER 5 | HOW TO PROGRAM THE AP-120B                            | 5-1  |
| 5.1       | MEET THE AP....AGAIN                                  | 5-1  |
| 5.1.1     | Introduction                                          | 5-1  |
| 5.1.2     | Basic Overview                                        | 5-2  |
| 5.1.3     | Referencing Memory                                    | 5-5  |
| 5.1.4     | S-PAD Mnemonics                                       | 5-6  |
| 5.1.5     | Other Pseudo-Ops                                      | 5-7  |
| 5.2       | LOOPS                                                 | 5-8  |
| 5.2.1     | A Poor Loop                                           | 5-8  |
| 5.2.2     | Determining Length of a Loop                          | 5-10 |
| 5.2.3     | Writing a Real Memory-Limited Loop                    | 5-11 |
| 5.2.4     | Writing Intros                                        | 5-13 |
| 5.2.5     | Dot Product Program                                   | 5-15 |
| 5.2.6     | Notation                                              | 5-18 |
| 5.2.7     | Dropping Out One Early                                | 5-20 |
| 5.2.8     | Interaction Between Columns                           | 5-23 |
| 5.2.9     | Changing DPA                                          | 5-24 |
| 5.2.10    | Non-Memory-Limited Loops                              | 5-15 |
| 5.2.11    | A One-Cycle Loop                                      | 5-26 |
| 5.3       | CAVEAT PROGRAMMER (LET THE PROGRAMMER BEWARE)         | 5-29 |
| 5.3.1     | Calling Another Sub-Routine                           | 5-19 |
| 5.3.2     | Illegal Instruction Sequences (Not Caught<br>by APAL) | 5-31 |
| 5.3.3     | Other Things to Watch Out For (Caught by APAL)        | 5-31 |

## FIGURES

| Number | Title                                | Page  |
|--------|--------------------------------------|-------|
| 1-1    | AP-120B Arithmetic Paths             | 1-5   |
| 2-1    | Control Unit                         | 2-2   |
| 2-2    | S-Pad Unit                           | 2-4   |
| 2-3    | Floating Adder Unit                  | 2-6   |
| 2-4    | Floating Multiplier                  | 2-8   |
| 2-5    | Data Pad                             | 2-10  |
| 2-6    | Data Memory Unit                     | 2-12  |
| 2-7    | Table Memory                         | 2-13  |
| 3-1    | AP-120B Floating Point Number Format | 3-18  |
| 4-1    | S-PAD Block Diagram                  | 4-3   |
| 4-2    | PS Formats                           | 4-28  |
| 4-3    | Program Source Memory File           | 4-29  |
| 4-4    | Data Pad                             | 4-111 |
| 4-5    | Main Data Block                      | 4-121 |
| 4-6    | Table Memory                         | 4-132 |

## TABLES

| Number | Title                                   | Page  |
|--------|-----------------------------------------|-------|
| 1-1    | Related Publications                    | 1-10  |
| 3-1    | The AP-120B Rounding Decision Table     | 3-26  |
| 3-2    | The AP-120B Truncation Decision Table   | 3-28  |
| 4-1    | S-PAD Timing Examples                   | 4-9   |
| 4-2    | Loading and Executing AP-120B Bootstrap | 4-106 |
| 4-3    | Table Memory CEXP Truth Table           | 4-138 |

## APPENDIX

|   |                                      |     |
|---|--------------------------------------|-----|
| A | Glossary                             | A-1 |
| B | List of Terms and Usage              | B-1 |
| C | List of Functions                    | C-1 |
| D | Instruction Field Layout and Summary | D-1 |
| E | Instruction Descriptions             | E-1 |

## CHAPTER 1

### INTRODUCTION

#### 1.1 PURPOSE

This manual provides the information necessary for the programmer to write programs for the AP-120B Array Processor to be assembled by the AP Assembler (APAL). It is designed for use both as an introduction to programming the AP-120B and as a reference manual.

## 1.2 SCOPE

This manual contains material on how to program the AP-120B including detailed descriptions of the AP's functional units and its instruction set.

Chapter 1 includes a general description of the AP-120B and an example of its application. Chapter 2 introduces the AP-120B's functional units.

A review of floating point arithmetic theory and the format used by the AP-120B are in Chapter 3.

Chapter 4 includes detailed descriptions of the functional units, including programming examples and considerations. How to take advantage of the AP-120B's pipeline processing is discussed in Chapter 5, "How to Program the AP-120B."

The Appendix includes both a brief summary of the instruction set, Appendix D, and a discussion of each instruction, Appendix E. A diagram of the instruction field layout in Appendix D shows at a glance the relationship of the functional units to the instruction word.

For information about the Software Packages supplied with the AP-120B, the AP Math Library or the Program Development Package refer to Table 1-1, Related Publications, in Section 1.6.

### 1.3 GENERAL DESCRIPTION

The AP-120B is a high-speed (167-ns cycle time) peripheral floating-point arithmetic Array Processor, which is intended to work in parallel with a host computer.

Its internal organization is particularly well suited to performing the large numbers of reiterative multiplications and additions required in digital signal processing, matrix arithmetic, statistical analysis, and numerical simulation.

The highly parallel structure of the AP-120B allows the "overhead" of array indexing, loop counting, and data fetching from memory to be performed simultaneously with arithmetic operations on the data. This allows much faster execution than on a typical general-purpose computer, where each of the above operations must occur sequentially.

The AP-120B achieves its high speed through the use of fast commercial integrated circuit elements and an architecture that permits each logical unit of the machine to operate independently and at maximum speed.

Specifically:

1. Programs, constants, and data each reside in separate, independent memories, to eliminate memory accessing conflicts.
2. Independent floating-point multiply and adder units allow both arithmetic operations to be initiated every 167 ns.
3. Two large (32 locations each) blocks of floating-point accumulators are available for temporary storage of intermediate results from the multiplier, adder, or from memory.
4. Address indexing and counting functions are performed by an independent integer arithmetic unit that includes 16 integer accumulators.

In a typical application, such as a Fast Fourier Transform, the above features allow nearly the entire computation to be overlapped with data memory access time.

Effective processing precision is enhanced by 38-bits of internal data width, an internal floating-point format with optimum numerical properties, and a convergent rounding algorithm.

#### 1.4 SYSTEM OVERVIEW

A general block diagram of AP-120B arithmetic paths appears in Figure 1.1.

Connection is made to the host in a manner that permits data transfers to occur under control of either the Host Computer or the AP-120B. For most host computers, this will mean that the AP-120B is interfaced to both the programmed I/O and DMA channels.



Figure 1-1 AP-120B Arithmetic Paths

The system elements are interconnected with multiple parallel paths so that transfers can occur in parallel. All internal floating-point data paths are 38-bits in width (10-bit biased binary exponent and 28-bit 2's complement mantissa).

Data Memory (MD) is organized in 8K-word modules of 38-bit words each, expandable up to 64K words in the main chassis. The effective memory cycle time (interleaved) is 333 ns.

Table Memory (TM) is used for storage of constants (FFT constants), and is tied to a separate data path so as not to interfere with Data Memory. It is bipolar, 167 ns read-only memory, and is organized in 512-word, 38-bit increments.

Data Pad X (DPX) and Data Pad Y (DPY) are two blocks of 32 floating accumulators each. Each is a two-part register block, wherein one register may be read and another written from each block in one instruction cycle.

The Floating Adder (FA) consists of two input registers (A1 and A2) and a two-stage pipe-line which performs the operations, and convergently rounds the normalized result.

The Floating Multiplier (FM) consists of input registers (M1 and M2) and a three-stage pipe-line which performs the multiply operation. Products are normalized and convergently rounded 38-bit numbers.

The S-PAD consists of 16 integer registers and an integer arithmetic unit which is used to form operand addresses and to perform integer arithmetic.

## 1.5 EXAMPLE AP-120B APPLICATION

A simple FFT processing sequence would go as follows:

Initial conditions are that the FFT program is resident in Program Source Memory internal to the AP-120B, the array to be transformed is resident in host memory, and the host CPU has initiated the AP-120B processor with an I/O instruction.

1. The AP-120B requests host DMA cycles to transfer the array from host memory to internal data memory. Data is converted from host floating-point format to internal AP-120B floating-point format "on the fly."
2. The FFT algorithm is performed, with data remaining in internal AP-120B format. This yields the benefit of 38-bit precision and convergent rounding during the critical phases of processing.
3. The frequency domain array is transferred back to host memory by requesting host DMA cycles. Data is converted from internal format to host format "on the fly."
4. The AP-120B proceeds to another process or stops executing, depending on previously established conditions. An interrupt to the host can be issued.

The AP-120B is most efficiently used when a sequence of operations is performed on one or more sets of data which reside in internal data memory. This reduces data-transfer overhead, and retains maximum numerical precision. For example, a reasonable sequence would be to transfer a trace and a filter, FFT both, array multiply, inverse FFT, and transfer the result back to host memory.

The AP-120B Data Memory has DMA capability. That is to say that MD cycles can be stolen from the AP-120B microprocessor by the interface. This capability allows Host Computer DMA to AP-120B DMA data transfers to occur, thereby minimizing both host CPU and AP-120B overhead.

The AP-120B has been designed with enough flexibility built-in so that its power can be harnessed in a variety of ways. Subsequent sections describe its use in detail.

## 1.6 SOFTWARE

Four packages of software are supplied with the AP-120B which assist the user toward the solution of his particular processing task.

### 1.6.1 APEX (A.P. Executive)

APEX is a mechanism for communicating with the AP-120B via a series of FORTRAN or machine language subroutine "calls." The executive driver routine interprets the particular user call and directs the AP-120B to perform the specified action. For example, in Fortran, to load an array A containing N real data points into the AP-120B, and perform a real Fast Fourier Transform upon that data:

```
IA=0  
CALL APPUT (A,IA,N,2)  
CALL RFFT (IA,N,1)
```

Both the Standard Applications Subroutines described below and user developed AP-120B programs may be called from the host computer using APEX.

### 1.6.2 APMATH (A.P. Math Library)

These are subroutines written in AP-120B assembly language which are callable from host computer Fortran or machine language programs using APEX. They are listed in the AP-120B Math Library.

### 1.6.3 Program Development Package

Four Fortran IV programs which are compiled on the host computer during installation aid user program development.

These are:

1. APAL                    A.P. Assembly Language. A cross-assembler which provides a two pass assembly of symbolic coding into an object module. APAL generates detailed error diagnostics.
2. APLINK                A.P. Linker. Links and relocates separate APAL object modules together into a single execution module.
3. APDBUG                A.P. Debugger. An interactive debugging program. The user may selectively set breakpoints, examine and change memory and register contents, and run program segments.
4. APSIM                 A.P. Simulator. Called by APDBUG, APSIM provides a programmed simulation of the various hardware elements of the AP-120B. All timing characteristics of the AP-120B are emulated, and the floating point arithmetic is simulated (including rounding) to the least significant bit. APSIM is a convenient tool in bringing up new AP-120B programs off line without interfering with production runs.

#### 1.6.4 APTEST (A.P. Test Programs)

APTEST is a collection of interactive diagnostic test and verify programs which aid in isolation of hardware faults. These are:

1. APTEST                A.P. Tester. Exercises the Panel, DMA interface, and various internal registers and memories. Tests Main Data Memory with simple patterns and then with random numbers.

- Board level diagnostic  
indicators are provided.
- |           |                                                                                                                                                                                |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2. APPATH | A.P. Path Tester. Tests the various internal data paths and gives board level diagnostics.                                                                                     |
| 3. APARTH | A.P. Arithmetic Test. Tests the floating point adder, multiplier, and S-Pad arithmetic unit with pseudo-random number and operation sequences.                                 |
| 4. FIFFT  | Forward/Inverse FFT Test. Verifies the correct operation of the AP-120B as a complete unit by doing forward/inverse FFT transforms on both spikes and random number sequences. |

Table 1-1 lists Floating Point Systems publications related to AP-120B software.

Table 1-1 Related Publications

| Manual                                                                                                                                         | Number      |
|------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Processor Handbook                                                                                                                             | 7259        |
| Software Development Package Manuals<br>(includes APAL Array Processor Assembly Language Manual, APLINK-Array Processor Linking Loader Manual) | 7292        |
| AP-120B DEBUG-Array Processor DeBugger Manual                                                                                                  | 7364        |
| AP-120B Diagnostic Software Manual<br>(includes APTEST, APPATH, APARTH, FIFFT)                                                                 | 7284        |
| AP-120B Math Library Paarts I & II                                                                                                             | 7288-02, 03 |
| IOP 16/38 Users Manual                                                                                                                         | 7310R       |
| Programmable I/O Processor (PIOP)<br>(scheduled winter quarter 1978)                                                                           | 7350        |

## CHAPTER 2

### FUNCTIONAL OVERVIEW

The hardware of the AP-120B is composed of three types of functional elements.

1. Logical and control elements
  - a. Control unit
  - b. S-Pad unit
2. Floating-Point arithmetic elements
  - a. Floating-point adder
  - b. Floating-point multiplier
3. Memory elements
  - a. Data Pad unit
  - b. Main data memory unit
  - c. Table memory unit

Each of these functional units is INDEPENDENT and thus can independently perform the programmed operations for which it was designed in parallel with the other functional units.

## 2.1 CONTROL UNIT

The Control Unit, as illustrated by Figure 2-1, consists of:

- a. Program Source Memory (PS)
- b. Program Source Address (PSA) Register
- c. Control Buffer (CB) with decoding logic
- d. Subroutine Return Stack (SRS)  
with subroutine return stack pointer (SRA)

The operation of the AP-120B is controlled by the execution of 64-bit instruction words which reside in Program Source (PS) Memory. The program word for the next instruction to be performed is selected by the address in the Program Source Address (PSA) register. At the initiation of the next machine cycle, this program word is transferred to the Control Buffer (CB) where it is decoded and executed. The PSA is incremented by one unless a branch in the current instruction causes the PSA to move to another location in Program Source (PS) memory. Access to Program Source memory and instruction decoding are overlapped so that the AP-120B can operate at a 6 MHz rate (167 ns).

Branching is accomplished in two manners. A short-range branch is provided by adding the 5-bit branch displacement field to the current PSA. This gives a branch range of from -20(octal) to +17(octal). A long-range jump to any location in PS is accomplished by loading the desired target address into PSA.

Subroutine jumps are made by a "JSR" instruction which saves the current PSA in the Subroutine Return Stack (SRS) and sets PSA to the subroutine address. Return is via a "RETURN," which loads the PSA with the last entered return address on the SRS.

SRA (Subroutine Return Address) is the Subroutine Return Stack pointer, which is automatically incremented or decremented as subroutines are called and returns are made from the subroutine.



Figure 2-1 Control Unit

## 2.2 S-PAD UNIT

This unit, illustrated by Figure 2-2, performs the integer address indexing, loop counting and control functions necessary to direct completion of a given algorithm. In form, it is similar to familiar mini-computers such as the PDP-11 or Nova.

The S-Pad contains sixteen 16-bit directly-addressable registers. The contents of these registers pass through a special integer ALU associated with this unit.

The output of the ALU may be directed back to the specified S-Pad destination register, and also to any of the following address memory registers: Memory Address (MA), Table Memory Address (TMA), or Data Pad Address (DPA).

The S-PAD integer ALU functions include:

| FUNCTION               | EFFECT                           |
|------------------------|----------------------------------|
| a. Move                | S → D      S-Source              |
| b. Logical Complement  | $\bar{S} \rightarrow D$ register |
| c. Clear               | 0 → D      D-Destination         |
| d. Increment           | $S+1 \rightarrow D$ register     |
| e. Decrement           | $S-1 \rightarrow D$              |
| f. Add                 | $D+S \rightarrow D$              |
| g. Subtract            | $D-S \rightarrow D$              |
| h. Logical AND         | D AND $S \rightarrow D$          |
| i. Logical OR          | D OR $S \rightarrow D$           |
| j. Logical Equivalence | D EQV $S \rightarrow D$          |

The output of the S-PAD ALU (called S-PAD FUNCTION or SPFN), may be used unmodified, shifted left once, shifted right once, or shifted right twice.

A hardware bit-reverse function included in the S-Pad accomplishes the bit swapping necessary to access data in scrambled order after an FFT.

The S-PAD ALU also sets three condition bits in the AP-120B Status Register depending upon the output of the ALU/shifter:

N: set if result <0; cleared otherwise

Z: set if result =0; cleared otherwise

C: set if a carry occurred; cleared otherwise

These bits may be tested by the next AP instruction, and a branch made depending upon whether the specified condition was true.



Figure 2-2 S-Pad Unit

### 2.3 FLOATING POINT ADDER UNIT

The Floating Point Adder, shown in Figure 2-3, does addition (or subtraction) operations on the contents of the Adder input registers (A1 and A2). The operation is performed in two stages, each of which takes one machine cycle.

In the first stage, the exponents of the two numbers are compared and the fractions are aligned by shifting the fraction of the smaller number right. The fractions are then added (or subtracted). In the second stage the resulting fraction is normalized and convergently rounded.

Since the two stages are independent of each other, a new pair of numbers may be entered into A1 and A2 every AP cycle (167 ns). The result is available for use two cycles later (333 ns).

In effect, the Floating Adder (FA) is a pipeline, where new inputs may be entered into the pipeline stream every cycle. Initiation of an add operation loads the two numbers to be added into the A1 and A2 input registers. The previous Adder input is pushed down the pipeline to the Adder Buffer register. One cycle later the completed result (called FA) from the Buffer is available for storage or use by another unit. Thus a new add may be started every 167 ns, and the result is ready 333 ns later.

A1 may be loaded from Data Pad (DP), from the output of the Floating Multiplier (FM), or from Table Memory (TM). A2 may be loaded from Data Pad (DP), from the output of the Floating Adder (FA), or from Data Memory (MD).

The output of the Floating Adder (FA) may be directed to the Multiplier (M2), to the Adder (A2), to Data Pad (DP), or to Memory Input (MI).

The operations performed by the Floating Adder are:

- a. A1+01A2
- b. A1-A2
- c. A2-A1
- d. A1 EQV A2
- e. A1 AND A2
- f. A1 OR A2
- g. Convert A2 from signed magnitude to 2's complement format
- h. Convert A2 from 2's complement to signed magnitude format
- i. Scale A2
- j. Absolute value of A2
- k. Fix A2

Four condition bits in the AP Status Register are set or cleared by the Floating Adder depending upon the current result:

- FZ - set to one if result is zero, else cleared to zero.
- FN - set to one if result is negative, else cleared to zero.
- FO - set to one if exponent overflow occurred. The result was forced to the signed maximum value.
- FU - set to one if exponent underflow occurred. The result was forced to zero.

The overflow and underflow bits remain set until cleared by the program.

These bits may be tested by the instruction after the Floating Adder result is completed; i.e., three cycles after the Floating Adder operation was initiated.



Figure 2-3 Floating-Point Adder Unit

## 2.4 FLOATING POINT MULTIPLIER UNIT

The Floating Multiplier, Figure 2-4, forms the product of the two multiplier input registers (M1 and M2). The product is formed in three stages, each of which takes one machine cycle.

In the first stage, the 56-bit product of the two 28-bit fractions are partially completed. The second stage completes the product of the fractions. In the third and final stage the exponents are added, and the mantissa product is normalized and convergently rounded.

The Floating Multiplier, like the Floating Adder, is organized as a pipeline. Initiation of a multiply loads the two numbers to be multiplied into the M1 and M2 input registers. The two previous multiplier inputs are pushed down the pipeline to Buffer 2 and Buffer 3 respectively. One cycle later, the result from Buffer 3 is available for storage or use by another unit.

Thus a new product may be started every 167 ns, and the result is ready 500 ns later.

M1 may be loaded from Data Pad (DP), the output of the Floating Multiplier (FM) or from Table Memory (TM). M2 is loaded from Data Pad (DP), the Adder (FA), or from Main Data Memory (MD).

Two error bits in the AP Status Register are affected by the Floating Multiplier:

- FO - set if exponent overflow occurred. The result was forced to the signed maximum value.
- FU - set if exponent underflow occurred. The result was forced to zero.



Figure 2-4 Floating Multiplier

## 2.5 DATA PAD UNIT

Data Pad, illustrated by Figure 2-5, consists of two fast accumulator blocks, each with 32 floating-point locations, called Data Pad X (DPX) and Data Pad Y (DPY). In a single machine cycle the contents of one location from each Data Pad may be read out and used. In addition, data may also be stored into one location in each Data Pad in the same cycle. That is, for example, in a single instruction (167 ns) a multiply may be initiated specifying one argument from DPX and another from DPY; an Adder result (FA) may be stored into a DPX location, and a data element in Main Data stored into a DPY location. On the very next instruction similar multiple Data Pad accessing could be accomplished again.

The two memories are addressed via a combination of the Data Pad Address (DPA) register and four index field values contained in a given instruction word. DPA may be thought of as a base address register or stack pointer. It may be loaded from the S-Pad (SPFN) or its contents may be incremented or decremented by one.

For a given read or write operation, say reading from Data Pad X, an index value contained in the instruction is added to the current contents of DPA to give the effective address for that particular operation. The four index fields (one each for read DPX, read DPY, write DPX, and write DPY) are each 3 bits wide, and have a range from -4 to +3 relative to DPA.

Data from either Data Pad may be used by the Multiplier (M1, M2), Adder (A1, A2), or Memory Input (MI). Data may be stored into Data Pad from the Adder (FA), Multiplier (FM), S-Pad Function output (SPFN), the Command Buffer Value (VALUE), or from Data Pad (DP).



Figure 2-5 Data Pad

## 2.6 DATA MEMORY UNIT

The Data Memory unit, illustrated in Figure 2-6, is the primary data store for the AP-120B. It is available in 38-bit wide 8K modules which have an interleaved cycle time of 333 or 167 ns.

The memory unit contains a Memory Data (MD) buffer and a Memory Input (MI) buffer. Data read from memory is placed by the controller into MD, while data is written into memory from the MI. The Memory Address (MA) register points to the desired memory location.

In referencing memory for read or write operations, the selected operation is initiated by making a change to the Memory Address (MA) register. The MA register may be loaded from the S-Pad (SPFN) or its contents incremented or decremented by one.

A write operation is specified by loading MI with the data to be written during the same instruction in which MA is changed. This data is then written into memory from MI during the next two AP cycles. Data may be loaded into MI from the Floating Adder (FA), Floating Multiplier (FM), Data Pad (DP), Memory (MD), Table Memory (TM), the Input Bus (INBS), S-Pad Function (SPFN), or the Command Buffer Value (VALUE). A memory operation may be initiated every other cycle. The intervening cycle may be used for any other AP-120B function except another memory initiate.

When a memory READ is initiated, the requested memory data is placed by the memory controller into the Memory Data (MD) register 3 cycles after the request was made. Two instructions after the read request, another memory operation may be initiated. Again, the intervening cycle may be used for any non-memory functions. Data in MD may be used by the Floating Adder (A2), Floating Multiplier (M2), or Data Pad (DP).

To optimize the operation of the AP-120B it is necessary for the programmer to "look ahead" and initiate memory reads prior to the actual time that arguments from data memory are to be used in a calculation.

The system provides a "memory lock-out" which serves to insure that erroneous reads and writes of memory do not occur. If a memory initiate occurs while memory is "busy," further program execution is halted until the previous memory cycle is completed.



Figure 2-6 Data Memory Unit

## 2.7 TABLE MEMORY UNIT

The repeated use of standard constants (such as complex roots of unity and transcendental values) in signal processing routines dictate their ready availability to the programmer. A separate Table Memory (TM), shown in Figure 2-7, eliminates memory accessing conflicts by allowing data values and table values (constants) to be placed in separate memory banks.

Values read from Table Memory are placed by the controller into the Table Memory (TM) buffer register. The Table Memory Address (TMA) register serves as a pointer to the desired location. The standard TM is ROM. RAM is available as an option.

A Table Memory read is initiated by changing the contents of TMA, either by loading a value from the S-PAD (SPFN), or by incrementing or decrementing the contents of TMA.

A new table value may be requested every machine cycle. This value is available for use two cycles later. The value may be used by the Floating Adder (A1), Floating Multiplier (M1), or Data Pad (DP).

In FFT mode (i.e., when a FFT is being computed), the address in TMA is interpreted by the hardware to be an angle which points to the appropriate root of unity for a particular step in the algorithm. This allows the full table of roots of unity to be compressed into a single quadrant of cosines.



Figure 2-7 Table Memory

## 2.8 INTERNAL FLOATING POINT FORMAT

Floating-point data internal to the AP-120B is represented as follows:

| Exponent            | Mantissa |                      |
|---------------------|----------|----------------------|
| 2<br>E <sub>Φ</sub> | 11<br>E9 | 12<br>M <sub>Φ</sub> |

Where:

Mantissa      28-bit two's complement fraction  
Exponent      10-bit binary exponent, biased by 512

The value of a floating-point number in this format is defined as:

$$\text{Mantissa} * 2^{(\text{Exponent} - 512)}$$

The dynamic range of this format is from  $0.5 * 2(-512)$  to  $(1-2[-28]) * 2(511)$ ; or, from  $3.7 * 10(-155)$  to  $6.7 * 10(153)$ .

The 28-bit fraction, combined with the convergent rounding algorithm used in the Floating Adder and Multiplier, gives a maximum relative error of  $7.5 * 10(-9)$  per arithmetic operation. This is a precision of 8.1 decimal digits. As a comparison, unrounded IBM 360 format gives only 6.0 decimal digits of arithmetic accuracy.

The convergent rounding hardware rounds up when the magnitude of the remainder is GREATER than 1/2 of the least significant bit of the mantissa. This serves to minimize truncation errors in long series of arithmetic calculations.

Format conversion between Host format and AP-120B format occurs in the Interface and in the Floating Adder unit. The dynamic range of the internal format is large enough to accomodate IBM 360 format and other Host formats. The extended precision of the AP-120B internal format insures that accuracy is maintained during critical stages of data analysis.

## CHAPTER 3

### FLOATING POINT ARITHMETIC THEORY

The subject matter within this summary requires a certain amount of preparatory discussion regarding types of numbering systems and notation as well as explanations of AP-120B FLOATING POINT number format and FLOATING-POINT ARITHMETIC OPERATIONS.

Those familiar with computer numbering systems may wish to bypass the preliminary sections of this summary and begin with the section dealing with the AP-120B FPN (FLOATING-POINT NUMBER) format. If the user understands the AP Floating-Point format in Section 3.4 and the fundamentals of floating-point addition and multiplication he can skip to Chapter 4.

Accordingly, this summary is presented in sections - general to specific - in the following manner:

- 1) INTRODUCTION
- 2) GENERAL NUMBERING SYSTEMS
  - \* BASE
  - \* RADIX
  - \* TYPES OF NOTATION METHODS
- 3) NUMBER FORMATS
  - \* FIXED-POINT
  - \* FLOATING-POINT
  - \* NORMALIZATION
- 4) AP-120B FLOATING-POINT NUMBER FORMAT
- 5) AP-120B FLOATING-POINT ARITHMETIC OPERATIONS (overview)
  - \* FLOATING-POINT ADDITION, SUBTRACTION AND MULTIPLICATION
  - \* ROUNDING/TRUNCATION
  - \* OVERFLOW AND UNDERFLOW

### 3.1 INTRODUCTION

The AP-120B FLOATING-POINT ARITHMETIC section consists of two units: the FLOATING-POINT ADDER (FADDR) and the FLOATING-POINT MULTIPLIER (FMULR). Both FADDR and FMULR operate on numbers represented in the AP-120B FLOATING-POINT NUMBER format (FPN).

The purpose of this summary is to acquaint the reader with a general overview on the most common types of digital computer numbering systems, and then to focus in on the format and characteristics of the particular numbering system used by the AP-120B FLOATING-POINT ARITHMETIC hardware.

## 3.2 GENERAL NUMBERING SYSTEMS

### 3.2.1 Base

The BASE of a numbering system denotes how many different elements are used to represent progressive digits. For example, the decimal numbering system in general use today uses ten different elements to convey value (0, 1, 2, 3, 4, 5, 6, 7, 8, 9). The decimal system, then, is defined as a BASE(10) numbering system.

Digital computers, however, are not designed to efficiently handle a BASE(10) numbering system. Since the basic hardware element of most computers is a flip-flop or latch capable of only two significant states (1 and 0), the most convenient numbering system for digital computers is the two-element BINARY number system (BASE(2)), or numbering systems that are based on some power of two, such as OCTAL, (BASE(8)), or HEXI-DECIMAL (BASE(16)).

### 3.2.2 Radix Point

A RADIX POINT is that reflexive point where all numbers to the left represent integer quantities greater than or equal to 0 and where all numbers to the right represent fractional quantities less than 1.

In BASE(10) systems, the RADIX POINT is specifically termed the DECIMAL POINT. In BASE (2) systems, it is termed the BINARY POINT. Since the AP-120B uses a BASE(2) number system, the term BINARY POINT will be used in this summary.



### 3.2.3 Types of Binary Notation Systems

Once the base of a numbering system has been established, the question remains - what type of notation system will be used to represent a BINARY NUMBER in such a manner as to convey not only magnitude, but also sign.

There are four popular systems of notation used to accomplish this purpose.

- 1) SIGNED-MAGNITUDE notation
- 2) ONES-COMPLEMENT notation
- 3) TWOS-COMPLEMENT notation
- 4) EXCESS or BIAS notation

#### \* Signed-Magnitude

SIGNED-MAGNITUDE notation uses a Sign-Bit to indicate the sign of the quantity being represented. The integer value is in the same format for both negative and positive values - only the Sign-Bit changes to indicate the sign of the quantity represented. Usually the Sign-Bit is positioned to the left of the number and typically a "0" in the Sign-Bit position indicates a positive number, and a "1" indicates a negative number.

Example:

#### SIGNED-MAGNITUDE NOTATION



\* Ones-Complement

ONES-COMPLEMENT notation also uses a Sign-Bit on the left of the number to denote sign. A positive number represented in SIGN-MAGNITUDE or ONES-COMPLEMENT is exactly the same in appearance. Negative numbers, however, are represented differently in that the Sign-Bit not only changes, but the quantity is complemented, as well.

Example:



The major drawback of both SIGN-MAGNITUDE and ONES-COMPLEMENT notation systems is that there are two possible forms in which to represent the value ZERO (0).

\* Twos-Complement

Positive values represented in TWOS-COMPLEMENT format appear the same as in the SIGN MAGNITUDE and ONES-COMPLEMENT formats. The SIGN-BIT is also to the left. However, for negative values, the number is complemented as in ONES-COMPLEMENT, and then a BINARY ONE is added.

Example:

TWOS-COMPLEMENT NOTATION

 indicates  $+101_2$  or  $+5_8$

$$\begin{array}{r} 1 \quad \emptyset \quad 1 \quad \emptyset \\ + \quad \quad \quad 1 \end{array} \quad \text{ONES-COMPLEMENT}$$

plus "one"

$$2^3 \quad 2^2 \quad 2^1 \quad 2^0$$

 indicates  $-101_2$  or  $-5_8$

$$d_0 \quad d_1 \quad d_2 \quad d_3$$

Integers represented in TWOS-COMPLEMENT notation may be expressed by the following equation:

$$TV = [(-d_0 * 2^{N-1}) + (\sum_{i=1}^{N-1} d_i * 2^{N-(i+1)})]$$

where: TV = TRUE VALUE  
d(0) = digit in 0th position (SIGN BIT)  
d(i) = digit in ith position  
N = number of bits in the data word

Given below is a range of values for a 4-bit data word expressed in TWOS-COMPLEMENT notation.

| Sign                          |                                                                                                                                                                              |                                                                                              |                    |       |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------|-------|
| Digit Weight                  | $-2^3$                                                                                                                                                                       | $2^2$                                                                                        | $2^1$              | $2^0$ |
| Bit Position                  | 0                                                                                                                                                                            | 1                                                                                            | 2                  | 3     |
| Range of all possible numbers | 0 1 1 1<br>0 1 1 0<br>0 1 0 1<br>0 1 0 0<br>0 0 1 1<br>0 0 1 0<br>0 0 0 1<br>0 0 0 0<br>1 1 1 1<br>1 1 1 0<br>1 1 0 1<br>1 1 0 0<br>1 0 1 1<br>1 0 1 0<br>1 0 0 1<br>1 0 0 0 | +7<br>+6<br>+5<br>+4<br>+3<br>+2<br>+1<br>0<br>-1<br>-2<br>-3<br>-4<br>-5<br>-6<br>-7<br>-10 | True Value (octal) |       |
|                               |                                                                                                                                                                              |                                                                                              | Positive Numbers   |       |
|                               |                                                                                                                                                                              |                                                                                              | Zero               |       |
|                               |                                                                                                                                                                              |                                                                                              | Negative numbers   |       |

N = number of bits in the data word

TWOS-COMPLEMENT notation has several advantages over SIGNED-MAGNITUDE and ONES-COMPLEMENT notation, in that:

- \* The problem of two possible forms of zero disappears; only one form of zero is possible, and
- \* TWOS-COMPLEMENT numbers may be added and subtracted without concern for the sign of each number if sign-extended by one bit. The result obtained from either operation will be correctly represented in TWOS-COMPLEMENT form.

Note also that the maximum-negative number possible in TWOS-COMPLEMENT is "1" greater (in magnitude) than the maximum-positive number.

### \* Excess (Bias) Notation

Another notation system capable of differentiating negative from positive quantities is the EXCESS or BIAS system. This method simply establishes a mid-point in the range of all possible numbers that can be represented in a given length data word. The mid-point is given a null or zero value and all numbers exceeding the null point are increasingly positive, and all numbers below the null point are increasingly negative.

#### BIAS NOTATION



Integers represented in BIAS notation may be expressed by the following equation:

$$TV = [(\sum_{i=0}^{N-1} d_i * 2^{N-(i+1)}) - (2^N)]$$

where: TV = TRUE VALUE  
d(i) = Digit in ith position  
N = Number of bits in the data word

Given below is the range of values for a 4-bit data word expressed in BIAS notation:



| Bias Bit | True Value (Octal) |
|----------|--------------------|
| 1 1 1 1  | +7                 |
| 1 1 1 0  | +6                 |
| 1 1 0 1  | +5                 |
| 1 1 0 0  | +4                 |
| 1 0 1 1  | +3                 |
| 1 0 1 0  | +2                 |
| 1 0 0 1  | +1                 |
| 1 0 0 0  | 0                  |
| 0 1 1 1  | -1                 |
| 0 1 1 0  | -2                 |
| 0 1 0 1  | -3                 |
| 0 1 0 0  | -4                 |
| 0 0 1 1  | -5                 |
| 0 0 1 0  | -6                 |
| 0 0 0 1  | -7                 |
| 0 0 0 0  | -10                |

Range of all possible numbers {

Positive Numbers } ← Mid Point (zero)

Negative Numbers }

Three things become apparent:

- 1) The BIAS-BIT occupies bit position 0. When BIAS = "1", it indicates that a positive quantity resides in the remaining bits of the data word. When the BIAS = "0", it indicates that a negative quantity resides in the remaining bits.
- 2) The APPARENT VALUE exceeds the TRUE VALUE by the weight of the BIAS BIT. In other words:

$$\text{TRUE VALUE} = \text{APPARENT VALUE} - 2^{N-1}$$

Where: N = the number of bits in the Data Word

- 3) The maximum-negative number possible is "1" greater in magnitude than the maximum-positive number possible.

The AP-120B uses a mixed system of TWOS-COMPLEMENT notation and BIAS notation for the AP-120B FLOATING POINT NUMBER FORMAT.

### 3.3 NUMBER FORMATS

#### 3.3.1 Fixed-Point Numbers

FIXED-POINT formatted numbers are numbers which have a stationary or fixed BINARY-POINT. FIXED-POINT formatted numbers are termed according to the location at which the BINARY-POINT is fixed. In other words, if a given number has a BINARY-POINT fixed to the extreme right of the data word, the number is said to be in the fixed-point INTEGER format, since all non-zero values that the format can represent are integers with magnitude  $\geq 1$ . Conversely, if the BINARY-POINT is fixed to the extreme left of the data-word, the number is said to be in the fixed-point FRACTION format since all values that can be represented are fractions with magnitude  $\leq 1$ . If the BINARY-POINT is fixed at some point between the two extremes, the number is said to be in fixed-point MIXED-NUMBER format.

Examples, assume a 4-bit data-word



### FIXED-POINT MIXED-NUMBER



Since FIXED-POINT INTEGER formats and FIXED-POINT FRACTION formats are elements of the AP-120B FLOATING-POINT format, both are discussed in more detail, below:

#### FIXED-POINT INTEGERS

Unsigned FIXED-POINT INTEGERS may be expressed in the following equation:

$$TV = \left( \sum_{i=0}^{N-1} d_i * 2^{N-(i+1)} \right)$$

However, in order to represent a signed FIXED-POINT INTEGER, a notation system must be used. Given below is the equation for a FIXED-POINT INTEGER expressed in BIAS notation.

#### BIASED FIXED-POINT INTEGER

$$TV = \left[ \left( \sum_{i=0}^{N-1} d_i * 2^{N-(i+1)} \right) - (2^N) \right]$$

The utility of expressing a BIASED FIXED-POINT INTEGER will become apparent as AP-120B FLOATING-POINT NUMBERS are discussed, later in this summary.

#### FIXED-POINT FRACTIONS

Unsigned FIXED-POINT FRACTIONS may be expressed by the following equation:

$$TV = \left( \sum_{i=0}^{N-1} d_i * 2^{-(i+1)} \right)$$

However, in order to represent a signed FIXED-POINT FRACTION, we must express the fraction using a notation system. Given below, is the equation for a FIXED-POINT FRACTION expressed in TWOS-COMPLEMENT notation:

TWOS-COMPLEMENT FIXED-POINT FRACTION

$$TV = [(-d_0 * 2^0) + (\sum_{i=1}^{N-1} d_i * 2^{-i})]$$

Again, the utility of expressing a TWOS-COMPLEMENT FIXED-POINT FRACTION will be seen when the AP-120B FLOATING-POINT format is introduced later in this summary.

### 3.3.2 Floating-Point Numbers

FLOATING-POINT NUMBERS are a product of two FIXED-POINT NUMBERS - the BASE raised to a SIGNED-EXPONENT (expressed as a FIXED-POINT INTEGER) times a SIGNED-FRACTION (MANTISSA) expressed as a FIXED-POINT FRACTION. A general expression for FLOATING-POINT NUMBERS is given below:

$$\text{FLOATING-POINT NUMBER} = \text{BASE}^{\text{exponent}} * \text{MANTISSA}$$

Where      BASE =      BASE of a given number system  
(in many digital computers,  
              BASE = 2)

EXPONENT =      Signed FIXED-POINT INTEGER  
MANTISSA =      Signed FIXED-POINT FRACTION

A FLOATING-POINT NUMBER is so-called because the BINARY-POINT is not fixed but is allowed to float, thereby increasing the range of numbers that may be represented in a fixed-length data word. Due to its logarithmic nature, a FLOATING-POINT NUMBER is able to represent numbers ranging from very small positive or negative fractions to very large positive or negative integers. A typical format for a FLOATING-POINT NUMBER is given on the following page.

### TYPICAL FLOATING POINT NUMBER FORMAT



FLOATING-POINT NUMBERS possess unique manipulative characteristics in that a given number can be represented by various combinations of EXPONENT and MANTISSA values. The value of any given FLOATING-POINT NUMBER is preserved while changing the individual values of its component parts - as long as the EXPONENT is:

- \* Correspondingly incremented by the same number that the MANTISSA is right-shifted or,
- \* Correspondingly decremented by the same number that the MANTISSA is left-shifted

within the constraints imposed by a fixed-length data word.

**Example:**

The value (+.5) may be represented in FLOATING-POINT format as:  

$$[(2^0) * (+.5)]$$

But, (+.5) can just as well be represented as:  

$$[(2^1) * (.25)]$$

or

$$[(2^2) * (.125)]$$

The difference is that only the first representation is NORMALIZED.

#### 3.3.3 Normalization

NORMALIZATION of a TWOS-COMPLEMENT MANTISSA FPN is the process whereby the bits of the MANTISSA are left-shifted or right-shifted and the EXPONENT correspondingly decremented or incremented until the second-most significant bit of the MANTISSA is not equal to the

MANTISSA-SIGN (the most significant bit of the MANTISSA). A FLOATING-POINT NUMBER is said to be NORMALIZED only when the SIGN of the MANTISSA and the second-most significant bit of the MANTISSA are unequal. The major exception to this rule is a mantissa of zero which cannot be normalized. The above normalization rule guarantees that positive non-zero mantissas lie in the range 0.5 to 0.9999 (0.10000000 to 0.111111111 in binary) and negative mantissas in the range -1.0 to -0.4999 (1.00000000 to 1.011111111). Typically the unnormalized mantissa -0.5 (1.10000000) is allowed since it can be handled by the hardware.

Example:



The major importance is that NORMALIZATION preserves the maximum number of significant bits in the MANTISSA while protecting against problems arising from OVERFLOW out of the bits of significance (the NORMALIZATION process CAN involve a right shift).

### 3.4 AP-120B FLOATING-POINT FORMAT (FPN)

The AP-120B uses a 38-bit data word to express FLOATING-POINT NUMBERS internally (See Figure 3-1). The most significant 10 bits of the word are dedicated to expressing the EXPONENT in biased notation and the remaining 28 bits are dedicated to expressing the MANTISSA in TWOS-COMPLEMENT notation.



THE AP-120B FLOATING-POINT NUMBER (FPN) may be expressed in the same manner used earlier to express FLOATING-POINT NUMBERS generally, viz.:

$$FPN = \text{BASE}^{\text{exponent}} * \text{MANTISSA}$$

In the AP-120B FLOATING-POINT format, however, the EXPONENT SIGN is indicated by use of a BIAS-BIT rather than a SIGN-BIT. Specifically, the EXPONENT of the AP-120B FPN is expressed as a BIASED FIXED-POINT INTEGER and the MANTISSA is expressed as a TWOS-COMPLEMENT FIXED-POINT FRACTION. The general equation may be re-expressed as follows:

$$FPN = 2^{[\text{BIASED FIXED-POINT INTEGER}]} * [\text{TWOS-COMPLEMENT FIXED-POINT FRACTION}]$$

Using the equations developed earlier in this summary for BIASED FIXED-POINT INTEGERS and TWOS-COMPLEMENTED FIXED-POINT FRACTIONS, we now have:

$$FPN = 2^{[(\sum_{i=0}^{N_e-1} d_i * 2^{e-(i+1)}) - (2^{e-1})]} * [(-d_0 * 2^0) + (\sum_{i=1}^{N_m-1} d_i * 2^{-i})]$$

Where:  $N(e)$  = number of digits in the EXPONENT  
 $N(m)$  = number of digits in the MANTISSA

Since, in the AP-120B,  $N(e) = 10$  and  $N(m) = 28$ , the FPN may finally be the AP-120B, the AP expressed as follows (the exponent sum has been corrected for the fact that the digits start at number 2)

$$FPN = 2^{[(\sum_{i=2}^{11} d_i * 2^{11-i}) - (512)] * [-d_0 + (\sum_{i=1}^{27} d_i * 2^{-i})]}$$

Expressed in this manner, it can be seen that the effect of the BIAS scheme (with respect to the EXPONENT) is to shift the TRUE VALUE of the EXPONENT by a factor of (-512), the weighted value of the BIAS-BIT ( $2^9$ ). Accordingly, the TRUE VALUE of the AP-120B FPN EXPONENT can be expressed in the following manner:

$$\begin{array}{ccc} \text{TRUE} & & \text{APPARENT} \\ \text{VALUE} & = & \text{VALUE} \\ (\text{EXPONENT}) & & (\text{EXPONENT}) \end{array} - 512$$

Note that the range of the FPN EXPONENT is:  
[+511 to -512].

The range of the MANTISSA (.M) is:  
[+1 > .M > -1]

The dynamic range for the AP-120B FPN is:

$$[(0.5 * 2^{-512}) \text{ to } (1.0 - 2^{-27}) * 2^{511}] \text{ or,} \\ \text{from } 3.7 * 10^{-155} \text{ to } 6.7 * 10^{153}$$

Figure 3-1 AP-120B FLOATING POINT NUMBER FORMAT



EXAMPLES

| DECIMAL VALUE     | EXONENT       |          |                                 | MANTISSA |  | COMMENTS            |
|-------------------|---------------|----------|---------------------------------|----------|--|---------------------|
|                   | BIAS BIT      | SIGN     |                                 |          |  |                     |
| 0.0               | 00 01         | 09 00 01 |                                 |          |  | 27  ZERO (See Note) |
| 1.0               | 1 000 000 001 | 0        | 100 000 000 000 000 000 000 000 |          |  | $(2^1) * (.5)$      |
| -1.0              | 1 000 000 000 | 1        | 000 000 000 000 000 000 000 000 |          |  | $(2^0) * (-1.0)$    |
| .5                | 1 000 000 000 | 0        | 100 000 000 000 000 000 000 000 |          |  | $(2^0) * (.5)$      |
| -.5               | 1 000 000 000 | 1        | 100 000 000 000 000 000 000 000 |          |  | $(2^0) * (-.5)$     |
| $6.7 * 10^{153}$  | 1 111 111 111 | 0        | 111 111 111 111 111 111 111 111 |          |  | APMAX               |
| $-6.7 * 10^{153}$ | 1 111 111 111 | 1        | 000 000 000 000 000 000 000 000 |          |  | APNMAX              |
| $3.7 * 10^{-155}$ | 0 000 000 000 | 0        | 100 000 000 000 000 000 000 000 |          |  | APMIN               |

Although (0.0) and (-.5) examples are not in NORMALIZED form, both FADDR and FMULR can handle these two specific cases correctly.

NOTE

Although the APPARENT VALUE of ZERO EXPONENT = 0,  
the TRUE VALUE of ZERO EXPONENT = -512. (Which  
multiplied with a MANTISSA of .0, still equals  
0.0).

### 3.5 AP-120B FLOATING-POINT ARITHMETIC OPERATIONS (OVERVIEW)

The AP-120B is capable of simultaneous FLOATING-POINT ADDER (FADDR) and FLOATING-POINT MULTIPLIER (FMULR) operation. This section will present a general overview of the arithmetic operations of both units and discuss operations common to both - such as requirements for NORMALIZATION and CONVERGENT-ROUNDING/TRUNCATION.

First, a brief review of the manipulative characteristics of FPN's is in order. As stated in the preceding section, the same-value FPN may be expressed in various combinations of EXPONENT and MANTISSA values. The key requirement for maintaining the value of any given FPN is that the EXPONENT must be correspondingly incremented or decremented by the same number that the MANTISSA is right-shifted or left-shifted, respectively. Example:

The number (+.5) may be represented, in NORMALIZED form, by the following combination of EXPONENT and MANTISSA values - - -

BASE → EXPONENT TRUE VALUE (APPARENT VALUE = 512)  
↓  
 $(2^0)$  \* (+.5) ← MANTISSA TRUE VALUE  
0.1000

However, the same number may be expressed, in UNNORMALIZED form, by the following combinations of EXPONENT and MANTISSA - - -

$(2^1)$  \* (.25)  
0.01000  
or  
 $(2^2)$  \* (+.125)  
0.001000

Note that as the EXPONENT value, in each case, was incremented by 1, the corresponding MANTISSA value was decremented by means of halving - right-shifting the MANTISSA bits 1 position. Had the example decremented the sample EXPONENTS by some number "N", then the corresponding MANTISSA's, in each case, would have been incremented by means of left-shifting the MANTISSA bits "N" positions.

### 3.5.1 Floating-Point Addition, Subtraction and Multiplication

#### \* Addition

In order to ADD two FPN's, the MANTISSA's of both operands must be expressed in terms of the same EXPONENT. This requirement is met, in the AP-120B, by means of a comparison operation which compares the EXPONENTS of the two operands - retaining the larger EXPONENT as the EXPONENT of the result and right-shifting the MANTISSA of the smaller operand the number of positions that reflect the difference between the two EXPONENTS. For example, assume the following ADD operation:

$$4 + 8 = 12$$

In FLOATING POINT format, the operands may be expressed as follows:

$$[(2^3) * (.5)] + [(2^4) * (.5)] = [ ] \\ 0.10000 \quad 0.10000$$

First, the EXPONENTS are compared. The larger EXPONENT becomes the EXPONENT of the result while the MANTISSA of the smaller operand is right-shifted the number of positions that reflect the difference in the two EXPONENTS:

$$[(2^4) * (.25)] + [(2^4) * (.5)] - [(2^4) * ( )] \\ 0.010000 \quad 0.100$$

Then, the MANTISSA's are algebraically added:

$$[(2^4) * (.25)] + [(2^4) * (.5)] = [(2^4) * (.75)] \\ 0.110000$$

Note that the MANTISSA of the result is already NORMALIZED. Had it been UNNORMALIZED, then the FADDR logic would have left-shifted the MANTISSA and correspondingly decremented or incremented the EXPONENT until the second-most significant bit of the MANTISSA was unequal to the most-significant bit (MANTISSA sign).

#### \* Subtraction

SUBTRACTION of two FPN's is achieved by negating the subtrahend and adding the negated subtrahend to the minuend. Negation is achieved by two's complementing the subtrahend. See example below:

|                   |             |           |             |           |
|-------------------|-------------|-----------|-------------|-----------|
| MINUEND           | 0100        | +4        | 1100        | -4        |
| SUBTRAHEND        | 0011        | +3        | 1101        | -3        |
| NEGATE SUBTRAHEND | <u>1101</u> | <u>-3</u> | <u>0011</u> | <u>+3</u> |
| RESULT            | 0001        | +1        | 1111        | -1        |

### Mantissa Overflow

In MANTISSA OVERFLOW situations (when a digit of numerical significance has carried to the left of the radix point), the proper result is achieved by shifting the MANTISSA to the right one digit and incrementing the EXPONENT.



### \* Multiplication

MULTIPLYING two FPN's with different EXPONENTS requires that (1) the EXPONENTS be algebraically added, and (2) the MANTISSA's be multiplied. Except for two specific cases, the operands involved in FLOATING-POINT MULTIPLICATION must be NORMALIZED in order to obtain a correct result. As with the addition example above, detailed discussion of result NORMALIZATION and ROUNDING operations is reserved for later sections of this summary.

01 Assume the following multiplication operation:

$$(12) * (.25) = 3$$

In AP-120B FLOATING=POINT format, the operands would be expressed as:  

$$[(2^4) * (.75) * [(2^{-1}) * (.5)] = [ ]$$

First, the EXPONENTS are algebraically added. The sum of the EXPONENTS becomes the EXPONENT of the preliminary result.

$$[(2^4) * (.75)] * [(2^{-1}) * (.5)] = [(2^3) * (\quad)]$$

Then, the MANTISSA's are multiplied. The product of the MANTISSA's becomes the MANTISSA of the preliminary result.

$$\begin{array}{ll} [(2^4) * (.75)] * [(2^{-1}) * (.5)] & = [(2^3) * (.375)] \\ 0.11000 & \qquad \qquad \qquad 0.1000 \\ & \qquad \qquad \qquad .01100000 \\ & \qquad \qquad \qquad \text{Preliminary} \\ & \qquad \qquad \qquad \text{Result} \end{array}$$

Note, however, that the PRELIMINARY-RESULT is not NORMALIZED. Accordingly, the FMULR logic will left-shift the MANTISSA bits and correspondingly decrement the EXPONENT until the second-most significant bit of the MANTISSA is not equal to the MANTISSA-SIGN. To illustrate this operation, let us portray the PRELIMINARY RESULT, of the example, in its bit configuration:



The FMULR logic will left-shift the MANTISSA bits and correspondingly decrement the EXPONENT until the second-most significant bit of the MANTISSA is not equal to the MANTISSA-SIGN. (In this example, the MANTISSA is left-shifted one position and the EXPONENT is decremented by one).



Unlike the Floating Add Logic, the FMULR logic can only shift the MANTISSA one position left or right since it can be shown for normalized twos- complement mantissas that the worst case normalization required is only one position.

The AP-120B FMULR is capable of operating on the following UNNORMALIZED operands:

| EXONENT    | MANTISSA                                                                                                       |
|------------|----------------------------------------------------------------------------------------------------------------|
| (1) ZERO = | $\overbrace{0000000000}^{\text{EXONENT}} \quad \overbrace{00000000000000000000000000000000}^{\text{MANTISSA}}$ |

and,

(2) Any number with a MANTISSA of (-.5), such as:

Note that ZERO has an exponent with a TRUE-VALUE of -512.

### 3.5.2 Rounding

During a FLOATING-POINT MULTIPLY (FMUL) or most of the FADD group operations (See FADDR Summary, Chapter 4), the preliminary-result obtained is NORMALIZED and then CONVERGENTLY-ROUNDED. NORMALIZATION operations have been discussed earlier in this summary. The purpose of this section is to present the particular ROUNDING method employed by the AP-120B - - - CONVERGENT-ROUNDING.

CONVERGENT-ROUNDING is so-called because the frequency distribution curve for the rounding-decision matrix is slightly skewed toward zero (See Table 3-1).

Both FADDR and FMULR units employ a 3-bit extension of the PRELIMINARY-RESULT MANTISSA in order to store bits of significance generated off the least significant bit of the MANTISSA during a given operation. These bits - - called GUARD-BITS - - reside to the immediate right of MANTISSA bit 27 and have bit weights of  $2^{-28}$ ,  $2^{-29}$ , and  $2^{-30}$ , respectively.

Prior to NORMALIZATION bits 31 to 58 of the FADDR Result (bits 31 to 50 of the FMULR Result) are inclusively OR'ed into bit 30 of the residue. This has the effect of guaranteeing that the rounding occurs only when the magnitude of the residue is strictly greater than  $2^{-28}$  (= one half of the LSB).

Table 3-1  
The AP-120B ROUNDING-DECISION TABLE



The value contained in the GUARD BITS is called the RESIDUE. The magnitude of the RESIDUE and the sign of the PRELIMINARY-RESULT MANTISSA jointly determine the direction in which the PRELIMINARY-RESULT will be rounded (either toward the next-larger-magnitude number or toward zero).

If the rounding operation causes mantissa overflow, the AP-120B hardware takes care of it by shifting the mantissa to the right one digit and incrementing the exponent.

Note that the TRUE VALUE of the RESIDUE may be expressed as:

$$TV_{RESIDUE} = [(-d_0 * 2^{-27}) + (\sum_{i=28}^{30} d_i * 2^{-i})]$$

Where:  $d(0)$  = Digit in 0(th) position  
(MANTISA-SIGN)

$d(i)$  = GUARD-BIT in  $i$ (th)  
position

The ROUNDING-DECISION is based on the following relation:

$$[(-d_0 * 2^{-27}) + (\sum_{i=28}^{30} d_i * 2^{-i})] > [(0.5) * (2^{-27})]$$

Where  $d(27)$  = Least significant bit  
of the preliminary-  
result MANTISSA

Note that if the relation is true and  $l1$  = magnitude, the PRELIMINARY RESULT MANTISSA will be rounded to the next-larger magnitude number.

The floating adder has two operations which truncate--FSCLT and FIXT. When a preliminary result is positive, the FA truncates by ignoring the residue--throwing it away. If the Preliminary result is negative and there is any residue,  $2(-27)$  is added to the mantissa; this makes the result closer to the next smaller magnitude number. Truncation always goes towards zero (See Table 3-2).

Table 3-2  
The AP-120B TRUNCATION-DECISION TABLE



### 3.5.3 Overflow And Underflow

The current result of a FADDR or FMULR operation (FA, FM) is tested as to OVERFLOW (See Note 1) and UNDERFLOW (See Note 2) conditions. If an OVERFLOW condition occurs, the AP-120B hardware will force the maximum signed Floating- Point number possible (APMAX or APNMAX) onto FA or FM and the OVF bit of the APSTATUS register will be set to "1". Similarly, if an UNDERFLOW condition occurs, the AP-120B hardware will force a Floating Point 0.0 (ZERO) onto FA or FM and set the UNF bit of APSTATUS REGISTER to "1".

|         | EXPONENT |             | SIGN | MANTISSA                                            |    |
|---------|----------|-------------|------|-----------------------------------------------------|----|
|         | 00       | 09          | 00   | 01                                                  | 27 |
| AP MAX  | 1        | 111 111 111 | 0    | 111 111 111 111 111 111 111 111 111 111 111 111     |    |
| AP NMAX | 1        | 111 111 111 | 1    | 000 000 000 000 000 000 000 000 000 000 000 000 000 |    |
| ZERO    | 0        | 000 000 000 | 0    | 000 000 000 000 000 000 000 000 000 000 000 000 000 |    |

### NOTES

1. **Overflow.** The EXPONENT of the current FADDR or FMULR Result exceeds an APPARENT VALUE of 1023. (TRUE VALUE = 511). If the sign of the MANTISSA of the offending result is positive, the AP-120B hardware forces the maximum-positive FLOATING-POINT NUMBER (APMAX) into FA or FM, depending on which operation caused the error condition. If the MANTISSA of the offending result is negative, the maximum-negative FLOATING-POINT NUMBER (APNMAX) is forced onto FA or FM.
2. **Underflow.** When a current FADDR or FMULR operation produces an EXPONENT Result less than an APPARENT VALUE of 0 (TRUE VALUE = -512). The AP-120B hardware will force a FLOATING-POINT 0.0 (ZERO) into FA or FM, depending on which operation caused the error condition.

Note that FLOATING-POINT ZERO has an EXPONENT with an apparent value of 0. (TRUE VALUE = -512) and a MANTISSA with a TRUE VALUE of 0.

## CHAPTER 4

### DETAILED DESCRIPTION OF THE FUNCTIONAL UNITS

#### 4.1 S-PAD SUMMARY

##### 4.1.1 General Description

The SCRATCH PAD (S-PAD) illustrated in Figure 4-1 is generally analogous to the arithmetic/logical and control units of most mini-computers. Operations with the S-PAD group of the AP-120 instruction set are primarily used to perform integer addressing and loop counting operations.

S-PAD is a 16-bit wide arithmetic/logical unit which contains sixteen 16-bit directly addressable registers (SP(0-15)). Operands for S-PAD operations are termed S-PAD SOURCE REGISTER (SP(SPS)) and S-PAD DESTINATION REGISTER (SP(SP0)). The particular S-PAD registers selected as operands for a given operation are determined by the values in the SPS and SPD fields of the current instruction word.

The result of a given S-PAD operation, termed the S-PAD FUNCTION (SPFN), becomes available for use during the current instruction cycle and may be applied to the following elements:

- \* MAIN DATA MEMORY ADDRESS REGISTER (MA)
- \* TABLE MEMORY ADDRESS REGISTER (TMA)
- \* DATA PAD ADDRESS REGISTER (DPA)
- \* FLOATING ADDER (FADDR) A1 Input Register
- \* DEVICE ADDRESS REGISTER (DA), and/or
- \* onto the DATA PAD BUS (DB)

Three condition bits of the APSTATUS Register are set or cleared depending on the state of the particular SPFN result. These bits (C, N, Z) may be tested (one cycle after the appropriate SPFN becomes enabled) by appropriate operations within the BRANCH group and/or SPEC group (STEST field), of the AP-120B Instruction Set. These bits remain latched if no S-PAD arithmetic operation is specified.

The S-PAD integer ALU functions include:

| Function               | Effect                                   |
|------------------------|------------------------------------------|
| a. Move                | S $\rightarrow$ D S-Source register      |
| b. Logical complement  | S $\Rightarrow$ D D-Destination register |
| c. Clear               | 0 $\Rightarrow$ D                        |
| d. Increment           | S+1 $\Rightarrow$ D                      |
| e. Decrement           | S-1 $\Rightarrow$ D                      |
| f. Add                 | D+S $\Rightarrow$ D                      |
| g. Subtract            | D-S $\Rightarrow$ D                      |
| h. Logical AND         | D AND S $\Rightarrow$ D                  |
| i. Logical OR          | D OR S $\Rightarrow$ D                   |
| j. Logical Equivalence | D EQV S $\Rightarrow$ D                  |



Figure 4-1 S-PAD Block Diagram

#### 4.1.2 S-Pad Operations

The S-PAD may perform either single-operand or double-operand arithmetic/logical operations. The operations available within the SOP field are double-operand while the operations available within the SOP1 field are single-operand.

##### 4.1.2.1 Single-Operand Operations

S-PAD single-operand operations use the currently specified SP(SPD) as the sole operand. (See SOP1)

##### SINGLE-OPERAND INSTRUCTIONS AND ALLOWABLE S-PAD MODIFIERS

| OPERATION | L,R<br>RR<br>SHIFT | BIT<br>REVERSE | S-PAD<br>NO-LOAD (#) | REGISTER(S)<br>USED |
|-----------|--------------------|----------------|----------------------|---------------------|
| INC       | YES                | NO             | YES                  | SP(SPD)             |
| DEC       | YES                | NO             | YES                  | SP(SPD)             |
| COM       | YES                | NO             | YES                  | SP(SPD)             |
| CLR       | YES                | NO             | YES                  | SP(SPD)             |

##### 4.1.2.2 Double-Operand Operations

S-PAD double-operand operations use both currently specified SP(SPS) AND SP(SPD) as operands for a given operation. (See SOP)

##### DOUBLE-OPERAND INSTRUCTIONS AND ALLOWABLE S-PAD MODIFIERS

| OPERATION | SHIFT | BIT (&)<br>REVERSE | S-PAD<br>NO LOAD (#) | REGISTER(S)<br>USED |
|-----------|-------|--------------------|----------------------|---------------------|
| MOV       | YES   | YES                | YES                  | SP(SPS),SP(SPD)     |
| ADD       | YES   | YES                | YES                  | SP(SPS),SP(SPD)     |
| SUB       | YES   | YES                | YES                  | SP(SPS),SP(SPD)     |
| AND       | YES   | YES                | YES                  | SP(SPS),SP(SPD)     |
| OR        | YES   | YES                | YES                  | SP(SPS),SP(SPD)     |
| EQV       | YES   | YES                | YES                  | SP(SPS),SP(SPD)     |

The result of either single-operand or double-operand operations - SPFN-is normally stored back into the SP(SPD) unless an S-PAD NO-LOAD is specified.

#### 4.1.3 S-Pad Source and Destination Registers (SP(SPS)) (SP(SPD))

As stated before, up to two of the 16 S-PAD Registers may be accessed per instruction. The particular SP(SPS) and/or SP(SPD) to be used in a given operation is specified by the respective SPS and SPD fields in the instruction word.

SP registers may be labeled by name, using the following assembler pseudo-operation:

N \$EQU 0              Meaning: Assign S-PAD Register "0" the name "N"\*

All SP names must be declared in this manner before including them in an instruction. Additionally, it is permissible to specify more than one name for a given SP and it may be useful to do so when using the same SP to perform separate tasks in a program.

##### \* NOTE

Don't confuse the designated number of the SP with its contents. For example:  
N \$EQU 5 specifies that S-P 5 will  
be labeled as "N". But, the contents  
of "N" would not necessarily be equal to  
the value of five.

#### 4.1.4 S-Pad Function (SPFN)

The result of a given S-PAD operation is termed the S-PAD FUNCTION (SPFN). The SPFN is normally loaded "back" into the currently designated SP(SPD) . SPFN is available during the current instruction cycle as an input to any of the three MEMORY ADDRESS REGISTERS: MEMORY ADDRESS REGISTER (MA), TABLE MEMORY ADDRESS REGISTER (TMA), DATA PAD ADDRESS (DPA), and also may be enabled onto the DATA PAD BUS (DB), which may input to the I/O Device Address register (DA).

Example: ADD 5,6; DB=SPFN  
(Result of ADD 5,6 is placed upon DB)>

#### 4.1.5 S-Pad Modifiers "#", "Sh", "&"

Three optional modifiers may be used to alter the effect of an S-PAD operation:

##### S-PAD MODIFIERS

| FIELD | OPERATOR          | EFFECT                                                                                                                                                                                                            |
|-------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "B"   | "&"               | BIT REVERSE SP(SPS) before using as an S-PAD operand for double-operand operations. (See 4.1.7, BIT REVERSE)                                                                                                      |
| "SH"  | "L", "R", or "RR" | SHIFT result of S-PAD operation. The shifted result becomes available as SPFN.                                                                                                                                    |
| COND  | "#"               | OPERATOR MEANING EXAMPLE                                                                                                                                                                                          |
|       |                   | L Left shift once ADDL<br>R Right shift once ADDR<br>RR Right shift twice ADDR                                                                                                                                    |
|       | ADDL# &5, and 6   | S-PAD NO-LOAD inhibit the normal "back" storing of SPFN into the currently specified SP(SPD). S-PAD NO-LOAD disables the remaining operations in the BRANCH GROUP for the current instruction cycle. (See BRANCH) |
|       |                   | Add a bit-reversed SP(SPS) to SP(SPD), shift the result left once, then inhibit "back loading" SP(SPD).                                                                                                           |

##### NOTE

Loading of Condition Bits (C, N, Z) is not inhibited by the "#".

#### 4.1.6 S-Pad Associated Test and Branch Operations

Three Condition Bits (C, N, Z) are set or cleared in APSTATUS, depending on the condition of the current SPFN. These bits become valid and may be tested (and branches made accordingly), as of the next instruction cycle.

##### S-PAD-RELATED BITS IN APSTATUS REGISTER

- |           |                                                                                                                                                                                                                                                                                                                  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Z (bit 5) | Set to "1" one cycle after the current SPFN=0.                                                                                                                                                                                                                                                                   |
| N (bit 6) | Set to "1" one cycle after the current SPFN<0.                                                                                                                                                                                                                                                                   |
| C (bit 7) | S-PAD Carry Bit:<br>*If an S-PAD shift was specified in forming SPFN, then C reflects the last bit shifted off the SP as a result of ANY S-PAD shift operation. (L, R, or RR).<br><br>*If an S-PAD shift was not specified, then C reflects the state of the S-PAD Carry Bit as set by the last S-PAD operation. |

Note that S-PAD-Related APSTATUS Bits set by the current SPFN become valid and may be tested by a conditional branch as of the NEXT instruction. S-PAD, NOP and SPEC group operations DO NOT affect the state of condition bits in APSTATUS.

##### S-PAD RELATED BRANCH OPERATIONS

| INSTRUCTION-WORD GROUP | SUB-GROUP | INSTRUCTION MNEMONIC | BRANCH CONDITION | RELATED BIT(S) IN APSTATUS |
|------------------------|-----------|----------------------|------------------|----------------------------|
| BRANCH                 | COND      | BEQ                  | SPFN=0           | Z                          |
|                        |           | BNE                  | SPFN=0           | Z                          |
|                        |           | BGE                  | SPFN $\geq$ 0    | N                          |
|                        |           | BGT                  | SPFN>0           | Z, N                       |
| SPEC                   | STEST     | BLT                  | SPFN<0           | N                          |
|                        |           | BNC                  | S-PAD CARRY=1    | C                          |
|                        |           | BZC                  | S-PAD CARRY=0    | C                          |

For details on BRANCH TARGET ADDRESS formulation, see SPEC summary, Section 4.2. Some S-PAD timing examples are listed in Table 4-1.

Table 4-1 S-PAD TIMING EXAMPLES

| INSTRUCTION          | SP(2) | SP(3) | (12-27) | DB | APSTATUS |   |   | BRANCH CONDITIONS |     |     |     |
|----------------------|-------|-------|---------|----|----------|---|---|-------------------|-----|-----|-----|
|                      |       |       |         |    | SPFN     | N | Z | C                 | BLT | BEQ | BNC |
| 1. -                 | 3     | -     | -       | -  | -        | - | - | -                 | -   | -   | -   |
| 2. DEC 2             | 3     | -     | -       | 2  | -        | - | - | -                 | -   | -   | -   |
| 3. DEC 2             | 2     | -     | -       | 1  | 0        | 0 | 1 | F                 | F   | T   |     |
| 4. DEC 2             | 1     | -     | -       | 0  | 0        | 0 | 1 | F                 | F   | T   |     |
| 5. NOP               | 0     | -     | -       | -1 | 0        | 1 | 1 | F                 | T   | T   |     |
| 6. NOP               | 0     | -     | -       | -1 | 0        | 1 | 1 | F                 | T   | T   |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| 1. -                 | 5     | 7     | -       | -  | -        | - | - | -                 | -   | -   | -   |
| 2. SUB 2,3           | 5     | 7     | -       | 2  | -        | - | - | -                 | -   | -   | -   |
| 3. NOP               | 5     | 2     | -       | -3 | 0        | 0 | 1 | F                 | F   | T   |     |
| 4. NOP               | 5     | 2     | -       | -3 | 0        | 0 | 1 | F                 | F   | T   |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| 1. -                 | 5     | 7     | -       | -  | -        | - | - | -                 | -   | -   | -   |
| 2. SUB# 2,3          | 5     | 7     | -       | 2  | -        | - | - | -                 | -   | -   | -   |
| 3. NOP               | 5     | 7     | -       | 2  | 0        | 0 | 1 | F                 | F   | T   |     |
| 4. NOP               | 5     | 7     | -       | 2  | 0        | 0 | 1 | F                 | F   | T   |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| .                    |       |       |         |    |          |   |   |                   |     |     |     |
| 1. -                 | 3     | -     | -       | -  | -        | - | - | -                 | -   | -   | -   |
| 2. LDSPI 2;<br>DB=-1 | 3     | -     | -1      | 3  | -        | - | - | -                 | -   | -   | -   |
| 3. NOP               | -1    | -     | -       | -1 | 0        | 0 | 1 | F                 | F   | T   |     |
| 4. NOP               | -1    | -     | -       | -1 | 0        | 0 | 1 | F                 | F   | T   |     |

- means don't know or don't care

F = Branch Condition False

T = Branch Condition True

#### 4.1.7 Bit Reverse

##### 4.1.7.1 General Description

BIT-REVERSE is the process in which the contents of an address-subscript for an array base-address are reflexively transformed. In other words, the contents of the bits of an address-subscript undergo a bit-for-bit exchange about the center or reflex point of the word. Example:

Assume a 3 bit word:



The contents of bit 02 are exchanged with the contents of bit 0. The center bit, bit 01, is unchanged.

The word would be transformed as follows:

| CONTENTS<br>BEFORE<br>BIT-REVERSING | CONTENTS<br>AFTER<br>BIT-REVERSING |
|-------------------------------------|------------------------------------|
| 000                                 | 000                                |
| 001                                 | 100                                |
| 010                                 | 010                                |
| 011                                 | 110                                |
| 100                                 | 001                                |
| 101                                 | 101                                |
| 110                                 | 011                                |
| 111                                 | 111                                |

If the address-subscript is an even numbered word, the contents would be transformed in the following manner:



#### 4.1.7.2 Bit-Reverse General Application

In the course of FAST FOURIER TRANSFORM operations it is sometimes desirable to access a data array in bit-reversed order. For an eight-point data array A:

| NORMAL ORDER | BIT-REVERSED ORDER | SUBSCRIPT IN NORMAL ORDER | SUBSCRIPT IN BIT-REVERSED ORDER |
|--------------|--------------------|---------------------------|---------------------------------|
| A(0)         | A(0)               | 0                         | 0                               |
| A(1)         | A(4)               | 1                         | 4                               |
| A(2)         | A(2)               | 2                         | 2                               |
| A(3)         | A(6)               | 3                         | 6                               |
| A(4)         | A(1)               | 4                         | 1                               |
| A(5)         | A(5)               | 5                         | 5                               |
| A(6)         | A(3)               | 6                         | 3                               |
| A(7)         | A(7)               | 7                         | 7                               |

The array is accessed in normal order by successively incrementing the subscript. Similarly, the array is accessed in bit-reversed order by incrementing the subscript. The bit-reversed value of the subscript, however, is then used each time to access the array in bit-reversed order.

#### 4.1.7.3 AP-120B Bit-Reverse Application

When the S-PAD BIT-REVERSE (&) is specified for an S-PAD operation, the following process occurs:

- 1) A 15-bit wide BIT-REVERSE (&) is performed on bits 0-14 of the SP(SPS). Bit 15 is set to 0.
- 2) The bit-reversed result is right shifted using the APSTATUS BIT-REVERSE FIELD (APSTATUS (Bits 13-15)) as the shift count. Bit 15 is again set to 0.
- 3) The bit-reversed, shifted word is then used as the source-operand for the particular S-PAD operation specified. Note that the S-PAD operation is performed AFTER the bit-reverse operation.

TO ELABORATE:

\* First-

The contents of SP(SPS) are bit-reversed in the following manner: The contents of bit "0" are "swapped" with the contents of bit "14", the contents of bit "01" are "swapped" with the contents of bit "13", and so on. Bit "07" remains unchanged. Since the complex numbers of a data-array consist of a real part and an imaginary part, each address of an

array actually consists of two successive memory locations, the first containing the imaginary part. Therefore, the index of the real part of the number is always "even"; bit "15" of the index (SP(SPS)) is always cleared to "0".

Example:



\* Second-

The result from the 15-bit wide BIT-REVERSE operation is shifted right so as to fit into the actual width of the word being processed. The shift involves Bits 0-14, with zeros filled in on the left and into Bit 15.

The number of shifts that will be done during the alignment shift depends upon the value contained in the Bit-Reverse field (Bits 13-15). The programmer must place the correct value into the BIT-REVERSE field before using a BIT-REVERSE operation.

The value that must be pre-programmed into the APSTATUS REGISTER BIT-REVERSE FIELD depends on the size of the complex data array, and is listed below accordingly. The Shift Count = 15-n, where n = the power of two.

| Array Size | Number of Bits in the Subscript word | Shift Count to be placed in Bit Reverse Field of APSTATUS REGISTER |
|------------|--------------------------------------|--------------------------------------------------------------------|
| 32,768     | 15                                   | 0                                                                  |
| 16,384     | 14                                   | 1                                                                  |
| 8,192      | 13                                   | 2                                                                  |
| 4,096      | 12                                   | 3                                                                  |
| 2,048      | 11                                   | 4                                                                  |
| 1,024      | 10                                   | 5                                                                  |
| 512        | 9                                    | 6                                                                  |
| 256        | 8                                    | 7                                                                  |

Example: To bit-reverse an 8-bit address word

1) Desired bit-reverse:



2) As accomplished by the bit-reverse operator (&) with the Bit-Reversed Shift count set to 7:



\* Third-

The bit-reversed, shifted SP(SPS) is now ready to be used as the source operand in an S-PAD operation. Most commonly, BIT-REVERSE is used in the following manner:

ADD# &subs, base;SETMA

This operation bit-reverses an array subscript and adds it to the base-address of an array. This sum is used to initiate a memory fetch. The NO-LOAD(#) is stipulated so as to prevent the base-address (contained in SP(SPD)) from being overwritten by the SPFN produced from the ADD operation.

BIT-REVERSE (&) clears bit 15 of a subscript-word, and hence is intended to be used to access complex arrays. A subscript to be bit-reversed must always be even, and point to the real part of a complex pair. The bit-reverse shift count must agree with the word width of the subscript, which in turn must agree with the size of the complex array being accessed. That is, an eight-bit subscript, which will address an array of  $2(8)=256$  complex pairs, needs a shift count of  $15-8=7$ .

Since the shift count is limited to a maximum of seven places, 256 points is the smallest complex array that can be directly accessed using the BIT-REVERSE operator.

There is a technique, however, that permits use of the BIT-REVERSE operator for arrays smaller than 256 complex points. This technique is based on the fact that a right shift after bit-reversal is equivalent to a left shift before bit-reversal. Thus, if the index for a small array is placed in the left byte of the 16-bits of an S-PAD Register (a left shift by seven places) and if the increment for that index is correspondingly left shifted so that necessary index alteration operations will take place consistently, then the BIT-REVERSE shifter can be used with a shift count of  $8-n$  where  $n=\text{the power of two}$ .



BIT-REVERSE operator for small arrays

( $N \leq 256$     $n \leq 8$ )

#### 4.1.8 General Programming Rules (S-Pad Group)

- \* Only one S-PAD operation may be specified per instruction cycle.
- \* If a single-operand instruction is specified, then SP(SPD) is the only operand used. The BIT-REVERSE field is disabled.
- \* If a double-operand instruction is specified, then both SP(SPS) and SP(SPD) are used. SP(SPS) may be "bit-reversed" before use.
- \* SUBtract will subtract the first argument (SP(SPS)) specified from the last argument specified (SP(SPD)). Example:

SUB 6,5 will subtract the contents of SP 6  
from the contents of SP 5.

- \* The preliminary result of an S-PAD operation may be shifted before becoming SPFN. The contents of SPFN are stored back into the currently designated SP(SPD) unless an S-PAD NO-LOAD (#) is specified. SPFN reflects the final result of the current S-PAD operation including any S-PAD modification operations stipulated.
- \* The condition of SPFN sets or clears the C, N, and Z bits of the APSTATUS Register - effective as of the NEXT instruction cycle, accordingly:
  - \* Branches which test the condition of SPFN may be made one instruction following the appropriate S-PAD operation.
- \* IMPORTANT NOTE: Although the contents of SP(SPD) will not be changed during a "NOP" instruction following an S-PAD operation, SPFN will change - reflecting the new contents of SP(SPD).

Although the S-Pad related bits in APSTATUS will not be altered by an S-PAD NOP, the programmer should exercise care when executing an RSPFN op-code, (See RDREG, I/O), since the contents of SPFN may be altered from their state during the last S-PAD operation.

#### 4.1.9 S-Pad Carry Bit Conditions

During any of the operations listed below (except OR) the S-PAD CARRY BIT will be set to "1" if the corresponding equation for the current operation specified is true.

Note that when using S-PAD test and branch operations, Bit C of the APSTATUS REGISTER will reflect the state of the S-PAD CARRY BIT for the last preceding S-PAD operation unless a shift modifier was specified for that operation. If an S-PAD shift was specified, "C" will reflect the state of the last bit shifted off the end.

#### S-PAD CARRY-BIT RELATIONS

If true; then S-PAD CARRY BIT is set to "1"

Operation equations

```
SUB      (SP(SP)) + (SP(SPS)) + 1 >2(16)
INC      [(SP(SP)) + 1] >2(16)
DEC      (SP(SP)) + 177777 >2(16)
COM      (SP(SP)) + 177777 >2(16)
CLR      (SP(SP)) + (SP(SP)) >2(16)
ADD      (SP(SP)) + (SP(SPS)) >2(16)
OR       S-PAD CARRY BIT is set to "0"
EQV      (SP(SP)) + (SP(SPS)) >2(16)
AND     [(SP(SP)) AND (SP(SPS))] + (SP(SP)) > 2(16)
MOV     [(SP(SP)) AND (SP(SPS))] + [(SP(SP)) OR (SP(SPS))] >2(1[])
```

#### 4.1.10 Programming Example

Load Data Pad X with an array "A," with N elements starting at Main Data Memory location 3721x. "CTR" is in S-Pad register which will be used as a counter.

- |          |                             |                                                           |
|----------|-----------------------------|-----------------------------------------------------------|
| 1.       | CLR# CTR; SETDPA            | "Set DPA to 0                                             |
| 2.       | LDMA; DB=3721               | "Fetch the first<br>"element                              |
| 3.       | LDSPI CTR; DB=N             | "Initialize "CTR"<br>"to N                                |
| 4. LOOP: | INCMA; DEC CTR              | "Fetch next element,<br>"Ax+1                             |
| 5.       | DPX<MD;<br>INCDPA; BNE LOOP | Store Ax into DPXx,<br>"advance DPA and test<br>"counter. |

Below is a chart of the above loop, for N=3 elements.

| Inst.<br># | Memory |                | Data<br>DPA | Pad            |                |                | S-Pad<br>"CTR" | Test  |
|------------|--------|----------------|-------------|----------------|----------------|----------------|----------------|-------|
|            | MA     | MI             |             | 0              | 1              | 2              |                |       |
| 1.         | ---    | ---            | 0           | --             | --             | --             | ---            | ---   |
| 2.         | 3721   | ---            | 0           | --             | --             | --             | ---            | ---   |
| 3.         | ---    | ---            | 0           | --             | --             | --             | 3              |       |
| 4.         | 3722   | ---            | 0           | --             | --             | --             | 3              |       |
| 5.         | ---    | A <sub>0</sub> | 0           | A <sub>0</sub> | --             | --             | 2              | true  |
| 4.         | 3723   | ---            | 1           | A <sub>0</sub> | --             | --             | 2              |       |
| 5.         | ---    | A <sub>1</sub> | 1           | A <sub>0</sub> | A <sub>1</sub> | --             | 1              | true  |
| 4.         | ---    | ---            | 2           | A <sub>0</sub> | A <sub>1</sub> | --             | 1              |       |
| 5.         | ---    | A <sub>2</sub> | 2           | A <sub>0</sub> | A <sub>1</sub> | A <sub>2</sub> | 0              | false |

A generalization on the above example is to fetch array "A" from every Kth memory location.

The increment is stored in S-Pad register "STEP," and the array pointer is stored in "PTR:"

1. LDSPI STEP; DB=K                    "Initialize  
                      ""STEP" to K
2. CLR# CTR; SET DPA                  "Set DPA to 0
3. LDMA; DB=BASE                      "Fetch the first  
                      element, Ax
4. LDSPI CTR; DB=N                    "Initialize "CTR"  
                      "to N
5. LOOP: ADD STEP, PTR; SETMA  
                      BEQ DONE                "Advance memory  
                      pointer. Fetch  
                      next element,  
                      Ax+x. Test  
                      counter and jump  
                      out if done.
6. DPX<MD; INCDPA  
                      DEC CTR; BR LOOP        "Store Ax into  
                      DPXx, advance  
                      DPA Decrement  
                      ""CTR" and jump  
                      back to LOOP.

#### 4.2 SPECIAL OPERATIONS GROUP SUMMARY (SPEC)

The op-codes available within the SPEC group fall within the following functional groups: Branch and Test Instructions, Jumps, Data Transfer Instructions and Program Control instructions related to PROGRAM SOURCE ADDRESS REGISTER (PSA) and SUBROUTINE RETURN ADDRESS STACK (SRS) modification.

Discussion of the components involved in the SPECIAL OPERATIONS GROUP (SPEC) is presented in the following manner:

1) Test, Branch and Jump logic related to op-codes within this group, including:

- \* Appropriate Control bits of the APSTATUS REGISTER
- \* AP-120B GENERAL FLAGS
- \* Types of branches and Branch Timing Implications

2) Data Transfer Operations, including:

- \* The PROGRAM SOURCE MEMORY (PS) -- theory of operation, addressing, and types of formats available.
- \* The VIRTUAL FRONT PANEL (PANEL) and PANEL registers related to SPEC GROUP transfer operations.

3) PROGRAM ADDRESS and SUBROUTINE ADDRESS modification (JUMPS)

- \* Program Jumps
- \* Jumps to Subroutines (JSRS)

#### 4.2.1 Branch Operations

Branches available within the SPECIAL OPERATIONS GROUP (SPEC) may be used in tandem with other branch instructions available within the CONDITIONAL BRANCH GROUP (see BRANCH). Both groups of branches use the DISP field (instruction word Bits 27-31) to calculate the BRANCH TARGET ADDRESS. If branch op-codes are used from both groups in the same instruction word, the branch operations are OR'ed. Example:

BFLT LOOP; BEQ LOOP      Meaning: (If either FA is < 0, or SPFN is = 0, then the program will branch to the location indicated as LOOP).

##### 4.2.1.1 Test Conditions

One of the following functions is tested to determine the status of a given branch operation decision.

\*Selected bits of the AP-120B INTERNAL STATUS REGISTER (APSTATUS)  
\*AP-120B GENERAL FLAGS  
\*DATA-PAD BUS state

##### \* SPEC-Related Bits in APSTATUS Register

| Bit Name      | Condition                                                                                                                                                                     | Related SPEC Op-Code(s) |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| FN (bit 4)    | Set to "1" when Floating Adder Result (FA) is negative; reset to "0" when FA is zero or positive.                                                                             | BFLT                    |
| N (bit 6)     | Set to "1" when S=PAD FUNCTION (SPFN) is negative; reset to "0" when SPFN is zero or positive.                                                                                | BLT                     |
| C (bit 7)     | Set to "1" when an S-PAD operation produces a carry either by arithmetic generation or as a result of an S-PAD SHIFT operation; reset to "0" when no S-PAD carry is produced. | BNC,BZC                 |
| IFFT (bit 11) | Set to "1" when AP-120B is processing in the IFFT mode. (Set or cleared via programmed instructions).                                                                         | BIFN,BIFZ               |

\* AP-120B General Flags

There are four flags (0,1,2,3) available for general use within the AP-120B. These flags may be set to "1" or cleared to "0" by software instructions (See FLAG, I/O). A list of the general FLAGS and their respective branch operations is given below:

AP-120B GENERAL FLAGS

| AP FLAG | Branch Contingency | Related SPEC Op-code |
|---------|--------------------|----------------------|
| FL0     | Set to "1"         | BFL0                 |
| FL1     | Set to "1"         | BFL1                 |
| FL2     | Set to "1"         | BFL2                 |
| FL3     | Set to "1"         | BFL3                 |

Note that a minimum of one cycle must intervene between a flag modification instruction (e.g., SFL0) and the related test instruction.

\* Data-Pad Bus (DB) Test

Additionally, the data enabled onto the DATA-PAD BUS (DB) may be tested as to state and branches made accordingly:

| STATE (DPBS)            | Related SPEC Branch Op-Code |
|-------------------------|-----------------------------|
| Negative                | BDBN                        |
| Zero or Positive<br>and | BDBZ                        |
| Unnormalized            |                             |

WARNING

These branches will not work correctly following an instruction from the PS field (e.g., RPSF). They will branch as if DB=0.

#### 4.2.1.2 Branch Target Address Formulation

A BRANCH TARGET ADDRESS is formed by summing the current PSA with the biased DISP field in the following manner:

|                                |                                                                                                                                                                            |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (PSA) + (DISP - 20(octal)) PSA | Meaning: The current contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA) are added to the contents of the biased 5-bit DISplacement field (instruction word bits 27-32). |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

The BRANCH TARGET ADDRESS thus formed will be the next program location to be executed if the current branch condition is satisfied.

#### Biased Displacement Field

The DISP field contains a 5-bit BIASED integer. BIAS is the leftmost bit of the field. When Bias = 1, DISP contains a positive value in the remaining four bits of the field. When BIAS = 0, DISP contains a negative value in the remaining bits, in unsigned twos-complement form. The TRUE-VALUE of DISP is always 20(octal) less than its APPARENT-VALUE.

The range of BRANCH TARGET Addresses using DISP is from -20(octal) to +17 (octal) locations relative to the current PROGRAM SOURCE ADDRESS (PSA).

#### 4.2.1.3 Branch Timing

All of the conditions tested within this group of branch instructions relate to the state of the appropriate device (e.g., DB, SPFN, FA, etc.) as of the previous instruction cycle.

For example, a BFLT op-code tests the condition of the FLOATING ADDER OUTPUT (FA) enabled onto the FA Bus during the preceding instruction. Similarly, a BLT op-code tests the state of the S-PAD FUNCTION (SPFN) enabled during the preceding instruction cycle.

All the Status Bits related to branch operations are latched into the APSTATUS register one cycle after the condition that generated them becomes enabled. A Status Bit will remain set or cleared from that time until one cycle after the next operation produces a condition that will change the Status Bit.

If the condition to be tested was set via an LDAPS instruction, then a one cycle delay must be observed before testing it. Note that the LDAPS wins out over the dynamic FA, FM or S-PAD condition in determining the state of APSTATUS.

The following examples provide explicit illustrations of the timing relationships for the different types of branch conditions.

Example: FLOATING ADDER RESULT (FA) TESTED

|    |                     | Result Available | Appropriate Status Bit |                             |
|----|---------------------|------------------|------------------------|-----------------------------|
| t1 | FADD TM,MD          | -                | -                      | Note that the result of the |
| t2 | FADD DPX(-1),DPY(2) | -                | -                      | first FADD (FADD(t1)) be-   |
| t3 | NOP                 | FA(t1)           |                        | comes available as FA at    |
| t4 | BFLT LOOP           | FA(t1)           | FN(t1)                 | t3. The earliest that one   |
| t5 | NOP                 | FA(t1)           | FN(t1)                 | could test it then is at    |
| t6 | NOP                 | FA(t1)           | FN(t1)                 | t4. Note also that FN in    |
| t7 | FADD                | FA(t1)           | FN(t1)                 | APSTATUS will continue to   |
| t8 | NOP                 | FA(t2)           | FN(t1)                 | reflect the state of this   |
| t9 | BFLT LOOP1          | FA(t2)           | FN(t2)                 | particular FADD result      |
|    |                     |                  |                        | until two cycles after the  |
|    |                     |                  |                        | next FADD operation. The    |
|    |                     |                  |                        | result (FA(t2)) of FADD(t2) |
|    |                     |                  |                        | becomes available at t8 and |
|    |                     |                  |                        | the earliest one could test |
|    |                     |                  |                        | it is at t9, as shown.      |

The timing of the preceding example is applicable to all FA and FM related branches (APSTATUS bits FN, FZ, OVF and UNF).

Example: S-PAD FUNCTION (SPFN) TESTED

|    |            | Result Available | Appropriate Status Bit |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----|------------|------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| t1 | ADD3,4     | SPFN(t1)         | ---                    | Note that the result of the first S-PAD OPERATION (ADD 3,4) becomes available during t1. The earliest one could test this result, then, is at t2. But to illustrate the point that the BRANCH CONDITION BITS latch, the example, does not specify the appropriate test-branch op-code until t5. Note also that more than one branch may be made on the same SPFN, even at a different time, as long as the SPFN state for the operation inquiry is still latched in APSTATUS (i.e., BGE (t6). The appropriate APSTATUS bit condition produced from the ADD OPERATION at t1 is not altered until one cycle after the next S-PAD OPERATION (e.g., t8). Note also that WRTEXP is effectively an S-PAD NOP with respect to the condition bits of the APSTATUS REGISTER. The BLT at t8 tests the result of the ADD 4, 5 instruction at t7. |
| t2 | NOP        | *SPFN(t1)        | N(t1)                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| t3 | WRTEXP     | *SPFN(t1)        | N(t1)                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| t4 | NOP        | *SPFN(t1)        | N(t1)                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| t5 | BLT LOOP1  | *SPFN(t1)        | N(t1)                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| t6 | BGE LOOP   | *SPFN(t1)        | N(t1)                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| t7 | ADD 4,5    | SPFN(t7)         | N(t1)                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| t8 | BLT LOOP 3 | *SPFN(t7)        | N(t7)                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

NOTE

\*The value in SPFN will reflect the updated contents of SP(SPDP) during times t2 to t6 and t8 to t9.

Example: DATA PAD BUS (DB) TESTED  
 Result  
 Available on DB

|    |                       |        |                                                                                                                                                                                                                                                  |
|----|-----------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| t1 | DB=MD                 | DB(t1) | Note that DB is not latched as in the above example and is available for testing for only one cycle following the appropriate enabling operation.                                                                                                |
| t2 | BDBN LOOP1            | ZERO   | In order to perform two sequential branch operations on the same DB, one must "hold" it by a duplicate operation (e.g., the branch at t5 will test the DB (t4). But it is necessary to re-enable DB at t5 in order to perform the branch at t6). |
| t3 | NOP                   | ZERO   |                                                                                                                                                                                                                                                  |
| t4 | DB=DPX(2)             | DB(t4) |                                                                                                                                                                                                                                                  |
| t5 | BDBN LOOP1; DB=DPX(2) | DB(t4) |                                                                                                                                                                                                                                                  |
| t6 | BDBZ LOOP2            | ZERO   |                                                                                                                                                                                                                                                  |

...

Example: APSTATUS TEST following LDAPS

|    |                          |                                              |
|----|--------------------------|----------------------------------------------|
| t1 | ADD1, 2; LDAPS; DB=value | (See Note)<br>"Test result of ADD 1, 2 at t1 |
| t2 | BLT LOOP1                | "Test result of LDAPS at t1                  |
| t2 | BEQ LOOP2                |                                              |
| t3 | FADD                     |                                              |
| t4 | FADD                     |                                              |
| t5 | LDAPS; DB=value          | "Test result of FADD at t4                   |
| t6 | BFLT LOOP3               | "Test result of LDAPS at t5                  |
| t7 | BGE LOOP4                |                                              |

#### NOTE

The cycle following the LDAPS is dominated by the most recent dynamic conditions, e.g., ADD 1,2 at t1 determines BRANCH status during t2 and FA result during t5 controls branch during t6. The cycle after that, the LDAPS dominates---thus the branches at t3 and t7. test the result of the preceding LDAPS instruction.

Example: AP-120B FLAG TESTED

```
t1  CFL0  
t2  NOP  
t3  SFL0  
t4  BFLO LOOP1  
t5  BFLO LOOP1; CFL0
```

Note that a set/clear flag operation is effective, with respect to testing, one cycle after being performed. Accordingly, the BFLO at t4 will find the flag clear and will not result in a program branch. The SFL0 at t3 will be effective as of t4 and the BFLO at t5 will produce a program branch.

#### 4.2.2 Data Transfer Operations

The op-codes within the PSEVEN, PSODD, and PS fields of SPEC group deal with program-word transfer operations between PROGRAM SOURCE MEMORY (PS) and the LITES or SWITCH registers, (LITES, SWR) in the AP VIRTUAL FRONT PANEL (PANEL). The transfers are via the PANEL-BUS (PNLBS) and the DB. The PROGRAM SOURCE WORD may be transferred in QUARTER-WORD, HALF-WORD, or FLOATING-POINT LITERAL format. All PS read and load operations are two-cycle instructions. They behave like one-cycle instructions in that they execute on the first cycle, but they require a second cycle to fetch the next instruction. Therefore, they behave like two cycles, as far as MD timing is concerned.

The available PS formats are presented in Figure 4-2.



Figure 4-2 PS Formats

#### 4.2.2.1 Program Source Memory (PS)

The Program Source Memory file (PS) shown in Figure 4-3 contains the 64 bit instruction words by which programs in the AP-120B are executed. The location of the Program Source Word to be executed is pointed to by the PROGRAM SOURCE ADDRESS REGISTER (PSA) and the instruction contained in that location is decoded, and the appropriate control-functions are generated, by the CONTROL BUFFER (CB).



Figure 4-3 Program Source Memory File

Addressing of the PROGRAM SOURCE MEMORY is accomplished by reference to the 12 bit PROGRAM SOURCE ADDRESS REGISTER (PSA). PSA may be sequentially incremented, altered by either branch or jump instruction, or modified by the several SUB-ROUTINE ADDRESS RETURN STACK (SRS) -related instructions.

#### 4.2.2.2 Program Source Transfer Operation Addressing

When transferring data to or from PROGRAM SOURCE MEMORY (PS), addressing of the PS word is accomplished by either of the following methods:

1. ABSOLUTE - The address of the PROGRAM SOURCE WORD to be read/written is ABSOLUTE from either:
  - \* The 12 bit address contained in the VALUE field of the current instruction word,
  - \* the least significant 12 bits of the TABLE MEMORY ADDRESS (TMA), or
  - \* the 12-bit address currently enabled onto the PANEL BUS (PNLBS).
2. RELATIVE - The address of the PROGRAM SOURCE WORD to be transferred is RELATIVE to the current PSA. The address is formed by adding the current contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA) with the 12-bit address contained in the VALUE field of the current instruction word.

#### 4.2.2.3 SPEC-related Virtual Front Panel (PANEL) registers

The LITES REGISTER (LITES) and SWITCH REGISTER (SWR) of the VIRTUAL FRONT PANEL (PANEL) are involved in many SPEC group transfer op-codes. Both are 16-bit wide registers.

The LITES register is used as a destination register of the PNLBS in the appropriate SPEC group transfer operations. The host can read LITES but cannot load it. The AP-120B can load LITES, but cannot read it. The SWITCH REGISTER is used as a source register for the PNLBS. The host can load and read SWR. The AP-120B can only read SWR.

Data transfers between PS and the appropriate PANEL registers are via the PANEL BUS (PNLBS) and require two machine cycles to execute (See Note). (For a complete description of the VIRTUAL FRONT PANEL, see I/O SUMMARY).

NOTE

When executing these instructions, the programmer must not attempt to execute any other operation which uses the PNLBS for addressing or transferring or a PNLBS conflict will occur.

#### 4.2.3 Program Source Address Modification

The op-codes contained in the SETPSA fields are used to modify the program location by means of forcing a specified value into the PROGRAM SOURCE ADDRESS REGISTER (PSA). The op-codes within the SETPSA field fall into two categories:

- \* Program Jumps
- \* Jumps to subroutines

##### 4.2.3.1 Program Jumps

ABSOLUTE or RELATIVE PROGRAM JUMPS available in the SETPSA field replace the contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA) with a specified value. The Jump may be ABSOLUTE, whereby the contents of PSA are replaced by the current contents of a specified register, or the address currently enabled upon a specified Data Bus; or the Jump may be RELATIVE - whereby the data from a specified source is algebraically added to the current contents of PSA.

##### 4.2.3.2 Jumps to Subroutines

The AP-120B uses an address stack, termed the SUB-ROUTINE RETURN ADDRESS STACK (SRS), which is normally used to save the current contents of PSA plus "1" in the execution of a SUB-ROUTINE JUMP OPERATION (JSP). The address thus saved may be retrieved via a RETURN operation (see RETURN, BRANCH) at the completion of a given sub-routine operation thus enabling the program to return to the next program-source location following the JSR.

##### 4.2.3.3 SRS Operation

The SRS is a LAST-IN - FIRST-OUT (LIFO) memory stack with a capacity for sixteen 12-bit addresses. Addressing control for the SRS is performed by an up/down counter termed the SUB-ROUTINE RETURN ADDRESS REGISTER (SRA). The address last stored into SRS during a sub-routine jump will be the address enabled into PSA upon a return operation. Note, however, that the address stored in this "last-in" position of SRS can be changed via use of selected operations in the SETEXIT field.

The SUB-ROUTINE RETURN STACK (SRS) can store up to a maximum of 16 address words at one time, allowing the programmer to specify a maximum of 16 nested sub-routines. Attempting to exceed the maximum number of nested sub-routines will set the SUB-ROUTINE RETURN ADDRESS OVERFLOW (SRAO) in the APSTATUS register, as will a RETURN operation that has not been preceded by a SUB-ROUTINE JUMP OPERATION.

An example of SUB-ROUTINE JUMP and RETURN operations is given below:

| MAIN PROGRAM  | SUB-ROUTINE 1  | SUB-ROUTINE 2 |
|---------------|----------------|---------------|
| N(0) ZZ       | N(15) SUB1:ZZ  | N(30) SUB2:ZZ |
| N(1) ZZ       | N(16) ZZ       | N(31) ZZ      |
| N(2) ZZ       | N(17) JSR SUB2 | N(32) ZZ      |
| N(3) JSR SUB1 | N(18) ZZ       | N(33) ZZ      |
| N(4) HALT     | N(19) RETURN   | N(34) RETURN  |

ZZ= non-related operation

Note that the MAIN PROGRAM will jump to SUB-ROUTINE 1 (N(15)) upon executing the JSR instruction at N(3). During this jump, the SRA is incremented and N(4) (current PSA + 1) will be stored into the "last-in" position of the SUB-ROUTINE RETURN STACK (SRS).

The program will now execute in SUB-ROUTINE 1 until location N(17), at which time a jump will occur to SUB-ROUTINE 2 at location N(30). The SRA is again incremented, and the address N(18) (the now current PSA + 1) becomes the "last-in" address stored into SRS.

This program will now execute in SUB-ROUTINE 2 until location N(34), where a RETURN will be executed. At this time, the "last-in" address N(18) will be written into PSA and the program will jump back to that location. SRA is decremented so that now N(4) again becomes the "last-in" address contained in SRS.

The Program Proceeds: At N(19) a RETURN will again be executed, and the SRS will write the address N(4) into PSA. The program will halt at that location. SRA is decremented and the "last-in" address becomes the address written into SRS one time before address N(4) was initially written into SRS.

#### WARNING

The JSR instruction has a number of hardware timing problems not detected by APAL or APSIM.

NOTE

A JSR must not be followed immediately by a RETURN.

Example:

ILLEGAL

```
N(14)    JSR SUB2  
N(15)    RETURN
```

Also, any two-cycle instruction immediately before a JSR is illegal.

Example:

ILLEGAL

```
N(13)    RPSF  
N(14)    JSR SUB2
```

If the breakpoint of the front panel is used to stop the machine so that PSA is pointing to an instruction before a JSR, it is not possible to continue.

Example:

ILLEGAL

```
Breakpoint at N(4) followed by  
N(5)    ZZ  
N(6)    JSR SUB1
```

A halt followed by a JSR is also illegal.

Example:

ILLEGAL

```
N(13)    HALT  
N(14)    JSR SUB2
```

#### 4.2.3.4 Conditional Branch Op-Code Group

Purpose: UNCONDITIONAL and CONDITIONAL BRANCHES to program locations within a range of +17(octal) to -20(octal) locations relative to the current PROGRAM SOURCE ADDRESS (PSA), the SUBROUTINE RETURN OPERATION, and the S-PAD NO LOAD function.



- COND      CONDITIONAL BRANCH: Four-bit field whose value determines the specific operation to be performed within the BRANCH group.
- DISP      DISPLACEMENT: Five-bit field whose value with the BIAS subtracted is added to the current PSA to form the BRANCH TARGET ADDRESS for the specified branch operations. (BIAS = 20(octal))

#### 4.2.4 Branch Group Summary

The CONDITIONAL BRANCH op-code group consists of two fields: COND (instruction word bits 23-26) and DISP (instruction word bits 27-31). The value contained in the COND field selects the one operation of the BRANCH GROUP to be performed during the current instruction cycle.

The operations available within the COND field are:

- 1) S-PAD NO-LOAD (#),
- 2) UNCONDITIONAL BRANCH
- 3) CONDITIONAL BRANCHES and,
- 4) SUB-ROUTINE RETURN

When an UNCONDITIONAL BRANCH, is specified, or the branch condition of a CONDITIONAL BRANCH is satisfied, the program will branch to the PROGRAM SOURCE location obtained by adding the current contents of PROGRAM SOURCE ADDRESS REGISTER (PSA) with the value (BIAS removed) contained in the DISP field. The BRANCH TARGET ADDRESS thus obtained is limited to a range from -20(octal) to +17(octal) locations relative to the current PSA.

For a detailed discussion of the addressing, timing and programming examples for Branch type operations, refer to SPEC SUMMARY, Part 1 - Test, Branch and Jump Operations. All sections of Part 1 apply equally to Branch operations within this group EXCEPT Part 1a - Test Conditions. Discussion of test conditions appropriate to BRANCH GROUP op-coded is presented below.

##### 4.2.4.1 Test Conditions

The following conditions are tested by op-codes within the BRANCH GROUP to determine whether or not the branch condition for the appropriate operation is satisfied.

1. Selected Bits of the AP INTERNAL STATUS REGISTER (APSTATUS)
2. Selected Input/Output Flags

\* BRANCH Related Bits in APSTATUS REGISTER

| Bit Name     | Condition                                                                                                                                                                | Related BRANCH<br>Op-code(s)      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| OVF (bit 0)  | Set to "1" when the FA or FM available during the preceding cycle has OVERFLOWED. Once set to a 1, OVF remains latched until cleared by the program or host computer.    | BFPE<br>(See note)                |
| UNF (bit 1)  | Set to "1" when the FA or FM available during the preceding cycle has UNDERFLOWED. Once set to a "1", UNF remains latched until cleared by the program or host computer. | BFPE<br>(See Note)                |
| DIVZ (bit 2) | Set to "1" when a divide by zero has been detected by the divide software. Remains latched until set or cleared by the program or host computer.                         | BFPE<br>(See Note)                |
| FZ (bit 3)   | Set to "1" when the FA available during the preceding cycle was zero. Cleared to "0" otherwise.                                                                          | BFEQ, BFNE,<br>BFGT<br>(See Note) |
| FN (bit 4)   | Set to "1" when the FA available during the preceding cycle was negative. Cleared to "0" otherwise.                                                                      | BFGE, BFGT<br>(See Note)          |
| Z (bit 5)    | Set to "1" when SPFN during the most recent preceding S-PAD operation equaled 0. Cleared to 0 otherwise.                                                                 | BEQ, BNE,<br>BGT<br>(See Note)    |
| N (bit 6)    | Set to "1" when SPFN during the most recent preceding S-PAD operation was negative. Cleared to "0" otherwise.                                                            | BGE, BGT<br>(See Note)            |

NOTE

Indicates that the named op-code tests two or more conditions in order to determine status of branch conditions.

\* I/O FLAGS Test by BRANCH GROUP Op-codes

The I/O DATA READY FLAG (IODRDY) and the INTERRUPT REQUEST FLAG (INTRQ) may be tested by appropriate op-codes within this group and branches made accordingly.

BRANCH - Related I/O Flags

| AP I/O Flag | Branch Contingency | Related BRANCH Op-code |
|-------------|--------------------|------------------------|
| IODRDY      | Set to "1"         | BION                   |
|             | Set to "0"         | BIOZ                   |
| INTRQ       | Set to "1"         | BINTRQ                 |

#### 4.2.4.2 BRANCH TARGET ADDRESSING

The BRANCH TARGET ADDRESS is calculated by adding the current contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA) with the value (BIAS removed) contained in the DISPlacement field of the instruction word. The biasing scheme used for calculating BRANCH TARGET ADDRESSES is explained fully in SPEC SUMMARY - Types of Branch Operations.

In assembly format, the BRANCH TARGET ADDRESS is specified in the following manner:

BIFZ                    TARG

Where TARG may be a name or number specifying a target address. The BRANCH TARGET ADDRESS must be within a range from +17(octal) to -20(octal) locations relative to the current PROGRAM SOURCE ADDRESS (PSA). A relative address within the proper range may be specified directly by using the assembler symbol ".", which always has the value of the current location, i.e., BR .-3. (means branch three locations backwards from the current location).

#### NOTE

The following rules apply to ALL conditional branches:

1. Conditional branches test their particular condition as it existed during the previous instruction.
2. The branch determines what instruction will be executed NEXT. It has no effect upon execution of the current instruction.

See a more complete explanation in the SPEC section.

#### 4.2.5 AP-120B Internal Status Register (APSTATUS) Summary

APSTATUS is a 16-bit read/write register containing status bits which may be used to monitor conditions pertinent to Floating-Point Arithmetic results, the S-Pad RESULT (SPFN), S-Pad CARRY, FFT and IFFT addressing functions, SUB-ROUTINE-RETURN-STACK OVERFLOW conditions, and optionally, MEMORY-PARITY.

Changes in APSTATUS bits are generated by either AP-120B hardware functions or programmed instruction, (whether via AP-120B or Host-CPU). APSTATUS is readable to the AP-120B via use of the RAPS instruction (see I/O, RDREG field). It is writable from the AP-120B via use of the LDAPS instruction (see I/O, LDREG field) except for PERR, which is "set-only"; PERR and PENB=0 if parity option is not present. Changes in STATUS-BITS become effective, with respect to subsequent testing operations, one AP cycle after the condition occurred that caused the change.

APSTATUS is cleared via a Panel Reset (To clear the I/O interface the programmer must also use the interface reset). PERR and PENB are also cleared by an interface reset.

Given below is the APSTATUS format and descriptions of the individual STATUS-BITS.

#### APSTATUS FORMAT

| 0   | 1   | 2    | 3  | 4  | 5 | 6 | 7 | 8    | 9    | 10   | 11   | 12  | 13          | 14 | 15 |
|-----|-----|------|----|----|---|---|---|------|------|------|------|-----|-------------|----|----|
| OVF | UNF | DIVZ | FZ | FN | Z | N | C | PERR | PENB | SRAO | IFFT | FFT | Bit Reverse |    |    |

| BIT | MNEMONIC | MEANING                                                                                                                                                                                                       |
|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | OVF      | OVERFLOW: Set one cycle after the current FADDR or FMULR RESULT (FA or FM) has OVERFLOWED. Set by AP-120B hardware. Remains set until cleared by programmed instruction (LDAPS) or panel RESET, (See Note 1). |
| 1   | UNF      | UNDERFLOW: Set when current FADDR or FMULR RESULT (FA or FM) has UNDERFLOWED. Set by AP-120B hardware. Remains set until cleared by programmed instruction (LDAPS) or panel RESET, (See Note 2).              |
| 2   | DIVZ     | A DIVIDE-BY-ZERO has occurred. Set and cleared by programmed instruction (LDAPS)(See Note 3) or panel RESET.                                                                                                  |

|    |      |                                                                                                                                                                                                                                                                                                                                             |
|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3  | FZ   | FA-ZERO: Set to "1" one cycle after the current FADDR-RESULT (FA) equals 0.0. Cleared to "0" when FA does not equal 0.0 (Via AP-120B hardware or programmed instruction or panel RESET.)                                                                                                                                                    |
| 4  | FN   | FA-NEGATIVE: Set to "1" one cycle after the current FADDR-RESULT (FA) < 0.0. Cleared to "0" when FA > 0.0. (Via AP-120B hardware or programmed instruction or panel RESET.)                                                                                                                                                                 |
| 5  | Z    | SPFN-ZERO: Set to "1" one cycle after the current S-Pad function (SPFN) equals 0. Cleared to "0" when SPFN does not equal 0. (Via AP-120B hardware or programmed instruction or panel RESET.)                                                                                                                                               |
| 6  | N    | SPFN-NEGATIVE: Set to "1" one cycle after the current S-PAD function (SPFN) < 0. (Via AP-120B hardware or programmed instruction.)                                                                                                                                                                                                          |
| 7  | C    | S-PAD CARRY: If an S-PAD shift was specified, "C" reflects the last bit shifted off SPFN as a result of the shift operation. If a shift was not specified "C" reflects the state of S-PAD CARRY BIT or panel RESET.                                                                                                                         |
| 8  | PERR | PARITY-ERROR: (Optional). Set when a Main Data Memory (MD) PARITY-ERROR has occurred. Three parity-bits are used, one each for the EXPONENT, HIGH-MANTISSA, and LOW-MANTISSA portions of the memory word (See Note 4). If "PENB" is set, the AP-120B will halt on this error. Cleared only via panel or interface reset. Set only by LDAPS. |
| 9  | PENB | PARITY-HALT-ENABLE: (Optional). Enables halt on MEMORY PARITY ERROR. If set, the AP-120B will halt when a MEMORY-PARITY-ERROR is detected. Set or cleared by LDAPS. Cleared by panel or interface reset.                                                                                                                                    |
| 10 | SRAO | SUB-ROUTINE-RETURN-STACK OVERFLOW. Set to "1" via AP-120B hardware if more than 16 levels nested sub-routine-calls have occurred, or if a "RETURN" is executed without a corresponding "JSR". (Cleared via programmed instruction or panel RESET.)                                                                                          |

|       |             |                                                                                                                                                                                                                                                                                              |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11    | IFFT        | INVERSE-FFT FLAG. (Set via programmed instruction.) When set in conjunction with the FFT FLAG (bit 12), this bit causes ROOTS-OF-UNITY table references to be interpreted as positive angles when set and negative angles when cleared. (Cleared via programmed instruction or panel RESET.) |
| 12    | FFT         | FFT FLAG. Set and cleared via programmed instruction or panel RESET. When set, causes Table Memory Addresses to be interpreted as angles referencing the ROOTS-OF-UNITY table contained in Table Memory.                                                                                     |
| 13-15 | BIT-REVERSE | BIT-REVERSE SHIFT-VALUE. Three-bit field whose value controls the number of shifts accompanying an address BIT- REVERSING operation. See (S-PAD, BIT-REVERSE.) Shift value to be placed in this field is determined by the following equation:                                               |

$$\text{BIT-REVERSE} = 15 - (\log_2 N)$$

Where: N = length of complex-data-array to which BIT-REVERSE operation (&) is being applied.

#### NOTES

1. OVERFLOW occurs when EXPONENT of result is increased above APPARENT-VALUE of 1023 (TRUE-VALUE of 511). APMAX or APNMAX is forced as the result, depending on the sign of the MANTISSA.
2. UNDERFLOW occurs when EXPONENT of result is decreased below APPARENT-VALUE of 0 (TRUE-VALUE of -512.) ZERO (0.0) is forced as the result.
3. Result is set to the value of the dividend when a DIVIDE-BY-ZERO has occurred. (Via programmed instruction.) Used by AP-120B Math Library Divide Routines.
4. EXPONENT, HIGH-MANTISSA and LOW-MANTISSA PARITY-BITS occupy data-word bit positions 00, 01, and 40, respectively.

Selected STATUS-BITS within APSTATUS may be tested and branched upon (if the appropriate condition is satisfied) by the following AP-120B instructions:

| INSTRUCTION<br>WORD GROUP | SUB-<br>GROUP | INSTRUCTION<br>MNEMONIC | BRANCH<br>CONDITION     | RELATED BIT(S)<br>in APSTATUS |
|---------------------------|---------------|-------------------------|-------------------------|-------------------------------|
| BRANCH                    | COND          | BFPE                    | Floating<br>Point Error | UNF, OVF or<br>DIVZ = 1       |
|                           |               | BFEQ                    | FA=0.0                  | FZ=1                          |
|                           |               | BFNE                    | FA $\neq$ 0.0           | FZ=0                          |
|                           |               | BFGE                    | FA $\geq$ 0.0           | FN=0                          |
|                           |               | BFGT                    | FA>0.0                  | FN,FZ=0                       |
|                           |               | BEQ                     | SPFN=0                  | Z=1                           |
|                           |               | BNE                     | SPFN $\neq$ 0           | Z=0                           |
|                           |               | BGE                     | SPFN $\geq$ 0           | N=0                           |
|                           |               | BGT                     | SPFN>0                  | Z,N=0                         |
| SPEC                      | STEST         | BFLT                    | FA<0.0                  | FN=1                          |
|                           |               | BLT                     | SPFN<0                  | N=1                           |
|                           |               | BNC                     | S-PAD-CARRY=1           | C=1                           |
|                           |               | BZC                     | S-PAD-CARRY=0           | C=0                           |
|                           |               | BIFN                    | IFFT Bit=1              | IFFT=1                        |
|                           |               | BIFZ                    | IFFT Bit=0              | IFFT=0                        |

#### 4.2.6 PERR and PENB, Theory of Operation

PERR, the Parity Error bit, will be set to a "one" by the Parity Option Logic any time a parity-error is detected on a read cycle from Main Data memory. The Parity-Option Logic checks parity on all read cycles whether from the AP processor, the Host Interface or other DMA device such as the IOP and the PIOP. When PERR is set to a "one" as a result of a detected parity error, the data word, parity bits, memory address and cycle acknowledge priority level of the failure are recorded in the logging registers. As a check of the Parity Error Registers, PERR can be set from the AP. If PERR is set via an LDAPS the logging registers will record the above information for the memory read cycle just completed.

When PENB and PERR are both set, the AP will halt immediately. In fact, if an attempt is made to start or continue the AP when both of these bits are set, the AP will not go into the running state. Also, because of the overlap fetch/execute, the next instruction will have been set up. This may cause problems when restarting if this is not taken into account.

The immediate halt characteristic may cause lost interrupt problems with certain Host Interface/driver combinations. Thus, the recommended start-up procedure in the presence of DMA transfers overlapped with AP running is to clear PENB via a panel deposit to APSTATUS before starting the AP. Then to have the initializer code in the AP, set PENB when it clears OVF UNF and DIVZ before branching to the user-called routine. The "Set-only" characteristic of PERR protects the Parity Option from losing parity errors.

Note that contrary to common industry practice, the Parity Option generates even-parity. The highly inter-leaved nature of optimized, AP math-library routines requires many of them to read extra locations past the end of the arrays on which they are operating. Thus even-parity was selected so that a read from non-existent memory (all zeros on data and parity bits) would not cause spurious parity errors.

The following parity-error registers can be read via IN instructions at their respective Device Addresses. They reflect the first data-word, address and memory priority level that caused a parity error.

| DA | REGISTER | DESCRIPTION                                                    |
|----|----------|----------------------------------------------------------------|
| 33 | MDLMAN   | Low Mantissa portion of failing location                       |
| 34 | MDHMAN   | High Mantissa portion of failing location                      |
| 35 | MDEXP    | Exponent and parity bits of failing location<br>(Format below) |



|    |      | DESCRIPTION                                                                               |
|----|------|-------------------------------------------------------------------------------------------|
| 36 | PEAD | Parity Error Address<br>Address of Failing Location<br>(least significant 16 bits)        |
| 37 | MDCA | Main Data Cycle<br>Acknowledge priority level<br>and Address Extension.<br>(Format below) |



#### 4.3 FLOATING ADDER SUMMARY (FADDR)

Discussion of the AP-120B FLOATING-POINT ADDER (FADDR) is presented in the following manner:

1. General description and theory of operation
2. FADDR single and double operand operations
3. FADDR Operands -- A1 and A2
4. FADDR Result -- FA
5. FADDR-associated test, branch, and error conditions
6. FADDR programming considerations

#### 4.3.1 General Description, Theory of Operation

The AP-120B FLOATING-POINT ADDER (FADDR) is a two-stage arithmetic, logical, and format-conversion unit that uses 38-bit FLOATING-POINT NUMBERS as its operands.

##### \* The Operands (A1, A2)

The operands (contained in the A1 and A2 registers) are selected by the octal-value contained in the respective A1 and A2 fields of the current instruction word.

The available inputs to the two FADDR REGISTERS are listed in the A1 and A2 summaries. (See Section 4.3.4).

##### \* The Operations

The particular operation selected by the octal value in the FADD, or FADD1 fields is then performed. (See Section 4.3.2).

##### \* The Result (FA)

The result of a specified FADDR operation is enabled onto the FLOATING ADDER OUTPUT BUS (FA) one cycle after the next FADDR operation is initiated. The result is either NORMALIZED and CONVERGENTLY-ROUNDED, or unnormalized and rounded, or unnormalized and TRUNCATED, depending on the operation specified. (See FLOATING POINT SUMMARY, for more details on NORMALIZATION and ROUNDING/TRUNCATION operations.)

Because of the unique configuration of the AP-120B FADDR, after the initial "pipeline" set-up requirements have been satisfied, the FADDR is capable of producing significant FLOATING-POINT ARITHMETIC results every instruction cycle (167 ns). Note that the AP-120B allows simultaneous FLOATING-POINT ADDER (FADDR) and FLOATING-POINT MULTIPLIER (FMULR) operations.

#### \* Theory of Operation

The AP-120B FLOATING-POINT ADDER (FADDR) is essentially a two-stage pipeline which operates in the following manner:

##### Stage One

In the first stage, the EXPONENTS of the A1 and A2 OPERANDS are compared. The larger of the two EXPONENTS becomes the EXPONENT of the result. The MANTISSA of the smaller operand is correspondingly arithmetically right-shifted a number of places that reflects the magnitude of the difference between the two source-operand EXPONENTS.

The "aligned" mantissas then undergo the specified FADDR operation and the result is presented to the second-stage buffer latch.

When a subsequent FADDR operation is initiated, the preliminary result is "pushed" down into Stage Two.

##### Stage Two

In Stage Two, the preliminary result will be NORMALIZED or not and either CONVERGENTLY-ROUNDED or TRUNCATED, depending on the operation specified. (See Section 4.3.2).

This result becomes available onto the FA BUS one instruction cycle later. Appropriate bits of the APSTATUS REGISTER will be set according to the condition of this FADDR result and may be tested for significance one cycle after this result is enabled onto FA (two cycles after the second FADDR operation).

If the difference in exponents exceeds 31 (the number of significant bits in the AP FLOATING-POINT MANTISSA and FADDR GUARD BITS), a SHIFT-INHIBIT will occur, causing the operand with the SMALLER EXPONENT to be interpreted as positive 0.0. The result of the specified operation will reflect this interpretation.

#### NOTE

The APSTATUS bits will remain latched until one cycle after the result of a subsequent FADDR operation becomes available as FA.

As stated before, the result of an initial FADDR operation becomes available as FA only after a subsequent FADDR operation has been specified. In other words, the result of a given FADDR operation must be pushed down the "pipeline" and out onto the FA Bus by a successive FADDR operation -- the result of which, in turn, must be pushed out by yet another successive FADDR operation. Example:

| OPERATION (COMMENTS) |                        | RESULT AVAILABLE AS FA |
|----------------------|------------------------|------------------------|
| t1                   | FADD DPX,DPY           | -----                  |
| t2                   | FADD TM,MD             | -----                  |
| t3                   | NOP                    | (FA = DPX + DPY)       |
| t4                   | NOP                    | (FA = DPX + DPY)       |
| t5                   | FADD (PUSHES PIPELINE) | (FA = DPX + DPY)       |
| t6                   | NOP                    | (FA = TM + MD)         |

#### 4.3.2 FADDR Single and Double Operand Operations

The FLOATING ADDER Performs Floating Point:

- \* Arithmetic
- \* Logical
- \* Format Conversion, and
- \* Scaling Operations (floating to variable-width fixed-point conversion)

Instructions in the FADD field are double-operand operations which use the A1 and A2 fields to specify source-operands. Instructions in the FADD1 field use only a single-operand. When a FADD1 field op-code is specified (i.e. FADD = 0), the input selected as the source operand is determined by the octal-value in the A2 field.

Only one op-code from the following groups may be initiated during a given instruction cycle.

| ARITHMETIC | OPCODE | FIELD USED | OCTAL<br>VALUE | SOURCE OPERAND<br>FIELD(S) USED | OPERATION   |
|------------|--------|------------|----------------|---------------------------------|-------------|
|            | FADD   | FADD       | 3              | <A1, A2>                        | (A1) + (A2) |
|            | FSUB   | FADD       | 2              | <A1, A2>                        | (A1) - (A2) |
|            | FSUBR  | FADD       | 1              | <A1, A2>                        | (A2) - (A1) |

#### 4.3.3 Floating Point Logical Operations

These instructions (FAND, FOR, FEQV) perform logical operations on floating-point numbers. Exponent alignment occurs as for a normal floating-point add. The two mantissas are then combined using the specified logical operations. The result is then normalized and rounded.

| LOGICAL COMPARISON | OPCODE FIELD USED | OCTAL VALUE | SOURCE/OPERAND FIELD(S) USED | OPERATION                                                                |
|--------------------|-------------------|-------------|------------------------------|--------------------------------------------------------------------------|
| FEQV               | FADD              | 4           | <A1, A2>                     | (A1) EQV (A2)                                                            |
| FAND               | FADD              | 5           | <A1, A2>                     | (A1) AND (A2)                                                            |
| FOR                | FADD              | 6           | <A1, A2>                     | (A1) OR (A2)                                                             |
| FORMAT CONVERSION  |                   |             |                              |                                                                          |
| FIX                | FADD1             | 1           | A2                           | Convert (A2) to a 28-bit integer (rounded)                               |
| FIXT               | FADD1             | 2           | A2                           | Convert (A2) to a 28-bit INTEGER; TRUNCATE the RESULT (See Note 1)       |
| FSM2C              | FADD1             | 4           | A2                           | Convert (A2): from SIGNED-MAGNITUDE to TWOS-COMPLEMENT                   |
| F2CSM              | FADD1             | 5           | A2                           | Convert (A2): from TWOS-COMPLEMENT to SIGNED-MAGNITUDE                   |
| FABS               | FADD1             | 7           | A2                           | Convert (A2): to its ABSOLUTE VALUE                                      |
| SCALING<br>FSCALE  | FADD1             | 6           | A2                           | Scale (A2) using SPFN as reference. Result rounded. (See Note 2)         |
| FSCLT              | FADD1             | 3           | A2                           | Scale (A2) using SPFN as reference; RESULT TRUNCATED (See Notes 1 and 2) |

$\langle A_1, A_2 \rangle$  indicates that source operands need not be specified if a FADD "dummy" operation is used to push the result of the preceding FADDR operation down the pipeline.

#### NOTES

1. TRUNCATION - In an FSCLT or FIXT operation, the result will be TRUNCATED rather than CONVERGENTLY ROUNDED. (See FLOATING-POINT SUMMARY - ROUNDING/TRUNCATION.)
2. The current SPFN when the FSCALE operation is initiated. For correct results SPFN must equal maximum-comparison ( $A_1^{\text{exponent}} + 1$ ).

Note that the BIAS BIT of a given EXPONENT is automatically removed when the EXPONENT is transferred to S-PAD via an LDSPE instruction. (See SOP1). Accordingly, the value contained in a given S-PAD register following an LDSPE instruction will be the TRUE-VALUE of the EXPONENT. However, the BIAS BIT for a given EXPONENT is not removed if the transfer is via an LDSPI or LDSPNL instruction.

When the contents of a given S-PAD register are transferred to FADDR  $A_1^{\text{exponent}}$ ,  $A_2^{\text{exponent}}$  or to DB (via DB = SPFN), the BIAS is automatically added, thus producing an APPARENT-VALUE 512 greater than the TRUE-VALUE.

#### 4.3.4 FADDR Operands (via A1, A2 Registers)

The FADDR uses A1 and A2 registers as the input-buffers for the source operand(s) specified for a given operation. The programmer may select one of six available sources to be used as the A1 REGISTER operand and one of eight sources for the A2 REGISTER operand.

The list below shows the sources available for each respective FADDR register.

| A1 REGISTER<br>SOURCE | A1 FIELD VALUE<br>(IN OCTAL) | A2 REGISTER<br>SOURCE | A2 FIELD VALUE<br>(IN OCTAL) |
|-----------------------|------------------------------|-----------------------|------------------------------|
| NC*                   | 0                            | NC*                   | 0                            |
| FM                    | 1                            | FA                    | 1                            |
| DPX(idx)              | 2                            | DPX(idx)              | 2                            |
| DPY(idx)              | 3                            | DPY(idx)              | 3                            |
| TM                    | 4                            | MD                    | 4                            |
| ZERO**                | 5                            | ZERO**                | 5                            |
|                       |                              | MDPX(idx)***          | 6                            |
|                       |                              | EDPX(idx)***          | 7                            |

#### NOTES

- \* NC: NO CHANGE -- The input-buffers remain unchanged. This mnemonic is implied if no FADDR operands are specified.
- \*\* ZERO: Floating Point 0.0
- \*\*\* MDPX: { Indicates split-word source. See A2 for a detailed explanation of these sources.
- \*\*\* EDPX: { explanation of these sources.

Although the appropriate instruction-word fields and octal-values are listed above, the assembler format coding need only specify the desired operation and the operand source(s). Examples:

| ASSEMBLER FORMAT  | COMMENTS                                                                                                                                            |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| FADD              | "Dummy" FADD                                                                                                                                        |
| FADD NC,NC        | "Dummy" FADD                                                                                                                                        |
| FSUB FM,FA        | Subtract (FA) from (FM)                                                                                                                             |
| FSUBR FM,FA       | Subtract (FM) from (FA)                                                                                                                             |
| MOV 5,5;FSCALE TM | Shift (TM) Right arithmetically a number of positions that is one less than the difference between SP(5) and the TRUE-VALUE of the EXPONENT of (TM) |

#### 4.3.5 The FADDR Result (FA)

The NORMALIZED and either CONVERGENTLY-ROUNDED or TRUNCATED RESULT\* becomes available onto the FLOATING ADDER OUTPUT BUS (FA) one instruction cycle after the next FADDR operation is initiated. This FA will remain latched until replaced following the next FADDR operations.

The FLOATING ADDER OUTPUT (FA) may be directed to:

- \* The FLOATING-ADDER A2 REGISTER
- \* The FLOATING-MULTIPLIER M2 REGISTER
- \* DATA PAD X or DATA PAD Y, or
- \* to MAIN DATA MEMORY INPUT REGISTER (MI)

FA sets the appropriate bits of the APSTATUS REGISTER and these bits may be tested for significance on the instruction cycle after FA becomes valid.

\* In case of FA OVERFLOW or UNDERFLOW, a signed-maximum or ZERO number is forced as the result. (See FLOATING-POINT SUMMARY-OVERFLOW/UNDERFLOW.)

#### 4.3.6 FADDR Test, Branch, and Error Condition

The FADDR result (FA) sets or clears appropriate bits of the APSTATUS REGISTER. These bits may be tested and branches made on their condition one instruction cycle after the appropriate FADDR result is enabled onto FA.

##### FADDR RELATED BITS IN APSTATUS

| APSTATUS<br>BIT NAME | CONDITION                                                                                                                             | RELATED BRANCH<br>OPCODE(S) |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| OVF<br>(bit 0)       | Set to "1" when the current FA or FM has OVERFLOWED (See note 2). OVF remains latched until cleared by the microprogram or HOST-CPU.  | BFPE<br>(See note 1)        |
| UNF<br>(bit 01)      | Set to "1" when the current FA or FM has UNDERFLOWED (See note 2). UNF remains latched until cleared by the microprogram or HOST-CPU. | BFPE<br>(See note 1)        |
| FZ<br>(bit 03)       | Set to "1" when the current FA is equal to "0.0"; cleared to "0" when current FA is not equal to "0.0".                               | BFGE<br>BFGT<br>BFNE        |
| FN<br>(bit 04)       | Set to "1" when the current FA is negative; cleared to "0" when current FA is non-negative.                                           | BFLT                        |

##### NOTES

1. Indicates that the named op-code tests two or more conditions in order to determine status of branch condition.
2. See FLOATING POINT SUMMARY-OVERFLOW.

#### 4.3.7 Floating Point Adder Programming Considerations

##### 4.3.7.1 Simple Examples

Any data source listed under A1 may be combined with any data source listed under A2. For example, to add a number from Data Pad X to another from Data Pad Y:

FADD DPX, DPY                  "DPX + DPY

or to subtract a number read out of Data Memory from a constant in Table Memory:

FSUB TM,MD                  "TM - MD

A reverse subtract changes the order of the subtraction, i.e.,

FSUBR TM,MD                  "MD - TM

subtracts a constant from Table Memory from a number in Data Memory.

To negate a number from DPX:

FSUB ZERO, DPX                  "0.0 - DPX = -DPX

To take the absolute value of a number from Data Memory:

FABS MD                  "ABS(MD)

To fix (convert from floating-point to integer) a number from DPY:

FIX DPY                  "FIX (DPY)

##### 4.3.7.2 Pipelining Considerations

The Floating Adder is a two-stage pipeline. A "FADD" instruction loads the designated operands into the A1 and A2 registers. The previous contents of A1 and A2 are pushed down the pipeline to the Buffer register. One AP cycle later the new contents of Buffer have been normalized and rounded, and are then available for use or storage elsewhere.

The following instruction sequence illustrates how the Adder pipeline works, where A,B...G,H are floating-point numbers to be added:

| Time  | Cycle | Instruction | Adder Pipeline: |     | Buf-fer | Adder Result (FA) |
|-------|-------|-------------|-----------------|-----|---------|-------------------|
|       |       |             | A1,             | A2  |         |                   |
| 0     | 1.    | FADD A,B    | A,B             |     | ---     | ---               |
| 167ns | 2.    | FADD C,D    | C,D             | A,B | ---     |                   |
| 333ns | 3.    | FADD E,F    | E,F             | C,D | A+B     |                   |
| 500ns | 4.    | FADD G,H    | G,H             | E,F | C+D     |                   |
| 667ns | 5.    | FADD        | ---             | G,H | E+F     |                   |
| 833ns | 6.    | ---         | ---             | G,H | G+H     |                   |

The "FADD" without arguments in cycle 5 is used only to push the last computation into the Buffer Register, and hence to the end of the pipeline. Thus, it is a dummy add in the sense that we don't care what its arguments are, since we will never use the results. In the above example we completed our floating-point adds in one microsecond. During cycles 2-4, while we kept the pipeline full, adds were being done every 167ns, the maximum rate.

The completed results, as they come out of the Adder pipeline, are referred to by the mnemonic "FA." FA is dynamic, in the sense that it must be used or stored elsewhere before being changed by the next floating-adder instruction. The programmer has, however, complete control over the pipeline. Arguments advance ONLY when pushed through the pipeline by floating-adder instructions.

#### 4.3.7.3 Pipelining Example

A complete computational sequence is to do the vector sum  $Ax = Ax + Bx$ ,  $i=0,1,2,3$ .  $Ax$  is stored in Data Pad X locations 0-3 and  $Bx$  is stored in Data Pad Y location 0-3.

1. FADD DPX( $\emptyset$ ), DPY( $\emptyset$ ) "Do  $A_0 + B_0$
2. FADD DPX(1), DPY(1) "Do  $A_1 + B_1$
3. FADD DPX(2), DPY(2); DPX( $\emptyset$ )<FA "Do  $A_2 + B_2$ ,  $A_0 + B_0$  is now done, save it in  $A_0$
4. FADD DPX(3), DPY(3); DPX(1)<FA "Do  $A_3 + B_3$ ,  $A_1 + B_1$  is now done, save it in  $A_1$
5. FADD DPX(2)<FA "Push Adder; save  $A_2 + B_2$  in
6. DPX(3)<FA "Save  $A_3 + B_3$  in  $A_3$

Below is a chart of this computation, showing the state of the Adder pipeline and Data Pad after each instruction is executed.

| Cycle | Adder Pipeline |                                 |                                 | Adder Result                   | Data Pad X:                    |                                |                                |                                |
|-------|----------------|---------------------------------|---------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|
|       | A1             | A2                              | Buffer                          |                                | 0                              | 1                              | 2                              | 3                              |
| 1.    | A <sub>0</sub> | B <sub>0</sub>                  | ---                             | ---                            | A <sub>0</sub>                 | A <sub>1</sub>                 | A <sub>2</sub>                 | A <sub>3</sub>                 |
| 2.    | A <sub>1</sub> | B <sub>1</sub>                  | A <sub>0</sub> , B <sub>0</sub> | ---                            | A <sub>0</sub>                 | A <sub>1</sub>                 | A <sub>2</sub>                 | A <sub>3</sub>                 |
| 3.    | A <sub>2</sub> | B <sub>2</sub>                  | A <sub>1</sub> , B <sub>1</sub> | A <sub>0</sub> +B <sub>0</sub> | A <sub>0</sub> +B <sub>0</sub> | A <sub>1</sub>                 | A <sub>2</sub>                 | A <sub>3</sub>                 |
| 4.    | A <sub>3</sub> | B <sub>3</sub>                  | A <sub>2</sub> , B <sub>2</sub> | A <sub>1</sub> +B <sub>1</sub> | A <sub>0</sub> +B <sub>0</sub> | A <sub>1</sub> +B <sub>1</sub> | A <sub>2</sub>                 | A <sub>3</sub>                 |
| 5.    | ---            | A <sub>3</sub> , B <sub>3</sub> | ---                             | A <sub>2</sub> +B <sub>2</sub> | A <sub>0</sub> +B <sub>0</sub> | A <sub>1</sub> +B <sub>1</sub> | A <sub>2</sub> +B <sub>2</sub> | A <sub>3</sub>                 |
| 6.    | ---            | A <sub>3</sub> , B <sub>3</sub> | ---                             | A <sub>3</sub> +B <sub>3</sub> | A <sub>0</sub> +B <sub>0</sub> | A <sub>1</sub> +B <sub>1</sub> | A <sub>2</sub> +B <sub>2</sub> | A <sub>3</sub> +B <sub>3</sub> |

#### 4.3.7.4 FADDR Branches Programming Considerations

The FADDR branches test "FA" one instruction cycle after it is ready for use. That is, an Adder result may be tested one cycle after it has come out of the Adder pipeline. An example:

1. FSUB DPX,DPY      "Do a computation
2. FADD                "Push the result out
3. DPX>FA             "Save the result
4. BFEQ LOOP          "Test the result here (branch  
"to location "LOOP" if result  
"was zero

Compound tests may be made also. Test MD to see if it is between a lower limit contained in DPX (1) and an upper limit in DPX (2), i.e., see if DPX(1)<MD<DPX(2):

1. FSUBR DPX(2), MD    "Do MD-DPX(2)
2. FSUB DPX(1), MD    "Do DPY(1)-MD
3. FADD                "Push first test result  
"out
4. BFGT BIG            "Was too big
5. BFGT SMALL          "Was too small
6. . . .                "OK

The branches are made relative to the current Program Source Address (PSA), with a 5-bit displacement value. This means that the conditional branch target address must be within -20(octal) to +17(octal) locations of the current instruction.

#### 4.4 FLOATING MULTIPLIER (FMULR)

Discussion of the AP-120B FLOATING POINT MULTIPLIER (FMULR) is presented in the following manner:

1. General description and theory of operation
2. FMULR operation -- FMUL
3. FMULR operands -- M1 and M2
4. FMULR result -- FM
5. FMULR associated TEST, BRANCH, and ERROR conditions
6. FMUL Programming Considerations

#### 4.4.1 General Description, Theory of Operation

The AP-120B FLOATING POINT MULTIPLIER (FMULR) is a three-stage multiplication unit using 38-bit FLOATING POINT NUMBERS as its operands.

##### 4.4.1.1 The Operands (M1, M2)

The operands (contained in M1 and M2 registers) are selected by the value contained in the respective M1 and M2 fields of the current instruction word.

The available inputs to the two FMULR registers are described in detail in Section 4.4.3 and in M1, M2 of the instruction summary.

FMULR operands must not be unnormalized by more than one bit position or an unnormalized, and thus possibly inaccurate, product will result. With unnormalized operands the result will be incorrect in that it will be unnormalized by the sum of the number of unnormalized bit positions of the two input arguments.

Since the FMULR internally retains only 28 bits of MANTISSA Result (the full 56-bit product is generated in order to produce a clean 28-bit result), use of unnormalized operands can yield results with the loss of many, if not all, of the bits of significance expected for the result.

##### 4.4.1.2 The Result (FM)

The NORMALIZED, CONVERGENTLY-ROUNDED result is enabled onto the FLOATING MULTIPLIER BUS (FM) one cycle after the second subsequent FMULR operation is initiated, (See Section 4.4.4)

After the initial "pipeline" set-up requirements have been satisfied, the FMULR can produce significant FLOATING POINT MULTIPLICATION results every instruction cycle (167 ns). Note that the AP-120B allows simultaneous FLOATING POINT MULTIPLIER (FMULR) and FLOATING POINT ADDER (FADDR) operations.

##### 4.4.1.3 Theory of Operation

The process of multiplying two FLOATING POINT NUMBERS (FPN's) requires that the true EXPONENTS of both operands be added and the MANTISSAS of both operands be multiplied. The sum of the EXPONENTS becomes the

EXPONENT of the result.

The AP-120B FLOATING POINT MULTIPLIER (FMULR) is a THREE-STAGE pipeline which operates in the following manner:

\* Stage One

In the first stage, the FMUL instruction loads the M1 and M2 operands. A partial multiplication is then performed on the two MANTISSAS and the EXPONENT true-values are added.

When a second FMUL is executed, the partial product and EXPONENT sum are "pushed" down into STAGE TWO by being latched in the second-stage buffer.

\* Stage Two

In the second stage, the MANTISSA multiplication operation is completed.

When a third FMUL is executed, the preliminary result is "pushed" down into the STAGE THREE buffer.

\* Stage Three

\*

In the third stage, the result is NORMALIZED and CONVERGENTLY-ROUNDED.

This result becomes available as FM on the next instruction cycle after the third FMUL. The UNDERFLOW or OVERFLOW bit of the APSTATUS REGISTER will be set according to the condition of this result and may be tested for significance one cycle after this result becomes available as FM (two cycles after the third FMUL). These two status bits, once set, remain set until they are cleared via LDAPS (see I/O group) or by a RESET operation from the Host to the panel reset. The interface reset, however, does not affect the APSTATUS register.

Stated again, the result of an initial FMUL becomes available as FM only after two subsequent FMULS have been initiated.

Example:

|     | OPERATION (COMMENTS)           | RESULT AVAILABLE AS FM |
|-----|--------------------------------|------------------------|
| t1  | FMUL DPX,DPY                   | -----                  |
| t2  | FMUL TM,MD                     | -----                  |
| t3  | FMUL DPY(3),DPX(2)             | -----                  |
| t4  | ZZ                             | (FM = DPX * DPY)       |
| t5  | ZZ                             | (FM = DPX * DPY)       |
| t6  | FMUL (pushes pipeline)         | (FM = DPY * DPY)       |
| t7  | ZZ                             | (FM = TM * MD)         |
| t10 | ZZ                             | (FM = TM * MD)         |
|     | ZZ = Any non-FMUL instruction. |                        |

#### NOTE

The result of the FMUL operation initiated at t3 is at t10 still "hanging" in the pipeline, where it will remain until one cycle after another FMUL is initiated.

#### 4.4.2 The FMULR Operation -- FMUL

When the FM field of the instruction word = 1 and VALUE field is not used, a FLOATING MULTIPLY (FMUL) is initiated using the source operands selected by the octal value of the M1 and M2 fields of the instruction word. (M1 \* M2)

#### 4.4.3 FMULR Operands (via M1, M2 registers)

The FMULR uses M1 and M2 registers as the input buffers for the operands selected for the current FMUL operation. The programmer may select one of four available sources to be used as the M1 REGISTER operand and one of four available sources for the M2 REGISTER operand. Source operands must not be UNNORMALIZED by more than one bit position or an incorrect (unnormalized) result will be obtained.

The list below shows the sources available for each respective FMULR register. (See M1, M2 for detailed descriptions.)

| M1 REGISTER<br>SOURCE | M1 FIELD VALUE<br>(IN OCTAL) | M2 REGISTER<br>SOURCE | M2 FIELD VALUE<br>(IN OCTAL) |
|-----------------------|------------------------------|-----------------------|------------------------------|
| FM                    | 0                            | FA                    | 0                            |
| DPX(idx)              | 1                            | DPX(idx)              | 1                            |
| DPY(idx)              | 2                            | DPY(idx)              | 2                            |
| TM                    | 3                            | MD                    | 3                            |

For coding in ASSEMBLER FORMAT, the programmer need only specify FMUL with the desired operand sources. Examples:

| ASSEMBLER<br>FORMAT | COMMENTS                              |
|---------------------|---------------------------------------|
| FMUL                | "dummy" FMUL actually an FMUL FM,FA   |
| FMUL FM, FA         | Multiply: Current (FM) * current (FA) |
| FMUL DPY(-3),DPX    | Multiply: (DPY(DPA-3)) * (DPX(DPA))   |

#### 4.4.4 The FMULR Result (FM)

The FLOATING MULTIPLIER OUTPUT (FM) may be directed to:

1. FMULR M1 REGISTER
2. FADDR A1 REGISTER
3. MAIN DATA MEMORY INPUT REGISTER (MI)
4. DATA PAD Y (DPY), or
5. DATA PAD X (DPX)

FM can set the UNDERFLOW OR OVERFLOW bits of the APSTATUS REGISTER. These bits may be tested for significance one AP cycle later (after FM is valid).

#### NOTE

In the case of FM OVERFLOW or UNDERFLOW, a signed maximum or zero is forced as the result. (See FLOATING POINT SUMMARY, OVERFLOW/UNDERFLOW.)

#### 4.4.5 FMUL Test, Branch, and Error Conditions

The FMUL results (FM) can set UNDERFLOW or OVERFLOW bits of the APSTATUS REGISTER. These bits may be tested and branches made on their condition one instruction cycle after the appropriate FADDR result is enabled onto FA.

| APSTATUS<br>BIT NAME | CONDITION                                                                                                                                    | RELATED BRANCH<br>OPCODE(S) |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| OVF<br>(bit 0)       | Set to "1" when the current FM has overflowed, (See Note 2), OVF remains latched until cleared by the microprogram or host computer.         | BFPE<br>(See Note 1)        |
| UNF<br>(bit 1)       | Set to "1" when the current FM result has underflowed; (See Note 2), UNF remains latched until cleared by the microprogram or host computer. | BFPE<br>(See Note 1)        |

#### NOTES

1. Indicates that the named op-code tests two or more conditions in order to determine status of branch condition.
2. See FLOATING POINT SUMMARY, OVERFLOW/UNDERFLOW.

#### 4.4.6 FMUL Programming Considerations

##### 4.4.6.1 Simple Examples

Any of the data sources listed under M1 may be multiplied by any of the data sources in M2. For example, to multiply a number read from Data Memory by a constant from Table Memory:

FMUL TM,MD      "TM \* MD

or, to multiply a number in Data Pad X by another number in Data Pad Y:

FMUL DPX,DPY      "DPX \* DPY

##### 4.4.6.2 Pipelining Considerations

The Floating Multiplier is a three-stage pipeline. An "FMUL" instruction loads the specified operands into the M1 and M2 registers. The two previous partially completed products are pushed down the pipeline to Buffer 2 and Buffer 3 respectively. One AP cycle later the new contents of Buffer 3 have been normalized and rounded, and are then available for use or storage elsewhere.

The following instruction sequence illustrates how the Multiplier pipeline works, where A,B...G,H are floating-point numbers to be multiplied together.

| Time  | Cycle | Instruction | Multiplier Pipeline |      |            | Result (FM) |
|-------|-------|-------------|---------------------|------|------------|-------------|
|       |       |             | M1, BUF-            | BUF- | Multiplier |             |
| 0     | 1.    | FMUL A,B    | A,B                 | ---  | ---        | ---         |
| 167ns | 2.    | FMUL C,D    | C,D                 | A,B  | ---        | ---         |
| 333ns | 3.    | FMUL E,F    | E,F                 | C,D  | A,B        | ---         |
| 500ns | 4.    | FMUL G,H    | G,H                 | E,F  | C,D        | A*B         |
| 667ns | 5.    | FMUL        | ---                 | G,H  | E,F        | C*D         |
| 833ns | 6.    | FMUL        | ---                 | ---  | G,H        | E*F         |
| 1.0us | 7.    | ---         | ---                 | ---  | G,H        | G*H         |

The "FMUL" in cycles 5 and 6 are dummy multiplies used to push the last two computations to the end of the pipeline. In the above example we completed four floating-point multiplies in 1.0us. During cycles 3-4, while the pipeline was full, products were being done every 167ns, the maximum rate.

The completed products as they come out of the Multiplier pipeline are referred to by the mnemonic "FM." FM is dynamic, in that it must be used or stored before being changed by the next "FMUL" instruction.

#### 4.4.6.3 Pipelining Example

A computational example is to square the elements in a vector:

$A_i = A_i * A_i$ ,  $i=0,1,2,3$ .  $A_i$  is stored in Data Pad X.

- |                                  |                            |
|----------------------------------|----------------------------|
| 1. FMUL DPX(0),DPX(0)            | "Do $A_0^2$                |
| 2. FMUL DPX(1),DPX(1)            | "Do $A_1^2$                |
| 3. FMUL DPX(2),DPX(2)            | "Do $A_2^2$                |
| 4. FMUL DPX(3),DPX(3); DPX(0)<FM | "Do $A_3^2$ , save $A_0^2$ |
| 5. FMUL; DPX(1)<FM               | "Save $A_1^2$              |
| 6. FMUL; DPX(2)<FM               | "Save $A_2^2$              |
| 7. DPX(3)<FM                     | "Save $A_3^2$              |

Below is a chart of this computation, showing the state of the Multiplier pipeline and Data Pad X after each instruction is executed.

| Cycle | Multiplier Pipeline |            |            |         | Multiplier Result (FM) | Data Pad X |         |         |         |
|-------|---------------------|------------|------------|---------|------------------------|------------|---------|---------|---------|
|       | M1,M2               | Buffer 2   | Buffer 3   |         |                        | 0          | 1       | 2       | 3       |
| 1.    | $A_0, A_0$          | ---        | ---        | ---     | ---                    | $A_0$      | $A_1$   | $A_2$   | $A_3$   |
| 2.    | $A_1, A_1$          | $A_0, A_0$ | ---        | ---     | ---                    | $A_0$      | $A_1$   | $A_2$   | $A_3$   |
| 3.    | $A_2, A_2$          | $A_1, A_1$ | $A_0, A_0$ | ---     | ---                    | $A_0$      | $A_1$   | $A_2$   | $A_3$   |
| 4.    | $A_3, A_3$          | $A_2, A_2$ | $A_1, A_1$ | $A_0^2$ | $A_0^2$                | $A_1^2$    | $A_2$   | $A_3$   | $A_0^2$ |
| 5.    | ---                 | $A_3, A_3$ | $A_2, A_2$ | $A_1^2$ | $A_0^2$                | $A_1^2$    | $A_2$   | $A_3$   | $A_1^2$ |
| 6.    | ----                | ----       | $A_3, A_3$ | $A_2^2$ | $A_0^2$                | $A_1^2$    | $A_2^2$ | $A_3$   | $A_2^2$ |
| 7.    | ----                | ----       | $A_3, A_3$ | $A_3^2$ | $A_0^2$                | $A_1^2$    | $A_2^2$ | $A_3^2$ | $A_3^2$ |

#### 4.4.6.4 Multiply-Add Example

The full floating-point computational power of the AP-120B is utilized when we consider a process involving both multiplies and adds. Form the dot product of two eight-element vectors  $Ax \cdot Bx = AxBx$ ,  $i = -4, -3, \dots, 1, 2, 3$  where  $Ax$  is in Data Pad X and  $Bx$  is in Data Pad Y:

- |                               |                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fill the Multiplier Pipeline  | 1. FMUL DPX (-4), DPY (-4)<br>2. FMUL DPX (-3), DPY (-3)<br>3. FMUL DPX (-2), DPY (-2)<br>4. FMUL DPX (-1), DPY (-1)<br>FADD FM, ZERO | "Do A <sub>-4</sub> B <sub>-4</sub><br>"Do A <sub>-3</sub> B <sub>-3</sub><br>"Do A <sub>-2</sub> B <sub>-2</sub><br>"Do A <sub>-1</sub> B <sub>-1</sub> . A <sub>-4</sub> B <sub>-4</sub> is now done, save it in adder.<br>"Do A <sub>0</sub> B <sub>0</sub> . A <sub>-3</sub> B <sub>-3</sub> is now done, save it in the adder.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Fill the Adder Pipeline       | 5. FMUL DPX (0), DPY (0);<br>FADD FM, ZERO<br>6. FMUL DPX (1), DPY (1)<br>FADD FM, FA                                                 | "Do A <sub>1</sub> B <sub>1</sub> . A <sub>-2</sub> B <sub>-2</sub> is now coming out of the multiplier, and A <sub>-4</sub> B <sub>-4</sub> from the adder, add them together.<br>"Do A <sub>2</sub> B <sub>2</sub> . A <sub>-1</sub> B <sub>-1</sub> is now coming out of the multiplier, and A <sub>-3</sub> B <sub>-3</sub> from the adder, add them together.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Both Pipelines full           | 7. FMUL DPX (2), DPY (2);<br>FADD FM, FA<br>8. FMUL DPX (3), DPY (3);<br>FADD FM, FA<br>9. FMUL; FADD FM, FA                          | "Do A <sub>3</sub> B <sub>3</sub> . A <sub>0</sub> B <sub>0</sub> is now coming out of the multiplier, and (A <sub>-4</sub> B <sub>-4</sub> + A <sub>-2</sub> B <sub>-2</sub> ) from the adder, add them together.<br>"A <sub>1</sub> B <sub>1</sub> is coming out of the multiplier, and (A <sub>-3</sub> B <sub>-3</sub> + A <sub>-1</sub> B <sub>-1</sub> ) from the adder, add them together.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Empty the Multiplier Pipeline | 10. FMUL; FADD FM, FA<br>11. FADD FM, FA                                                                                              | "A <sub>2</sub> B <sub>2</sub> is coming out of the multiplier, and (A <sub>-4</sub> B <sub>-4</sub> + A <sub>-2</sub> B <sub>-2</sub> + A <sub>0</sub> B <sub>0</sub> ) from the adder, add them together.<br>"A <sub>3</sub> B <sub>3</sub> is coming out of the multiplier, and (A <sub>-3</sub> B <sub>-3</sub> + A <sub>-1</sub> B <sub>-1</sub> + A <sub>1</sub> B <sub>1</sub> ) from the adder, add them together.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Empty the Adder Pipeline      | 12. FADD; DPX (3)<FA<br>13. FADD DPX (3), FA<br>14. FADD<br>15. DPX (3)<FA                                                            | "(A <sub>-4</sub> B <sub>-4</sub> + A <sub>-2</sub> B <sub>-2</sub> + A <sub>0</sub> B <sub>0</sub> + A <sub>2</sub> B <sub>2</sub> ) is coming out of the adder, save it in DPX (3).<br>"(A <sub>-3</sub> B <sub>-3</sub> + A <sub>-1</sub> B <sub>-1</sub> + A <sub>0</sub> B <sub>0</sub> + A <sub>2</sub> B <sub>2</sub> ) is coming out of the adder, add it to (A <sub>-4</sub> B <sub>-4</sub> + A <sub>-2</sub> B <sub>-2</sub> + A <sub>0</sub> B <sub>0</sub> + A <sub>2</sub> B <sub>2</sub> ) which was saved in DPX (3).<br>"Push result out of Adder<br>"The result: (A <sub>-4</sub> B <sub>-4</sub> + A <sub>-3</sub> B <sub>-3</sub> + A <sub>-2</sub> B <sub>-2</sub> + A <sub>-1</sub> B <sub>-1</sub> + A <sub>0</sub> B <sub>0</sub> + A <sub>1</sub> B <sub>1</sub> + A <sub>2</sub> B <sub>2</sub> + A <sub>3</sub> B <sub>3</sub> ), saved in DPX (3). |

In accumulating the sum-of-products, the even term sum was kept in one half of the adder pipeline and the odd term sum in the other half. During cycles 5-7 when both pipelines were full, floating-point multiply-adds were being computed every 167ns. This is 12 million floating-point computations per second. A longer sum of products calculation, involving more terms, would maintain this maximum computation rate for nearly all of the computation loop. Here, in a short calculation, most of the time was spent filling and emptying pipelines. Even so, the seven adds and eight multiplies took 15 cycles (2.5us) to complete, or an overall rate of 333ns per floating-point multiply-add.

As a further aid in understanding the multiply-add interaction in the above sum-of-products computation, the chart below summarizes the computation:

| Cycle | Multiplier:                       |                                  | Adder:                                                            |                                  | Data Pad:<br>3                   |
|-------|-----------------------------------|----------------------------------|-------------------------------------------------------------------|----------------------------------|----------------------------------|
|       | M1, M2                            | FM                               | A1, A2                                                            | FA                               |                                  |
| 1.    | A <sub>-4</sub> , B <sub>-4</sub> | ---                              | ---                                                               | ---                              | ---                              |
| 2.    | A <sub>-3</sub> , B <sub>-3</sub> | ---                              | ---                                                               | ---                              | ---                              |
| 3.    | A <sub>-2</sub> , B <sub>-2</sub> | ---                              | ---                                                               | ---                              | ---                              |
| 4.    | A <sub>-1</sub> , B <sub>-1</sub> | A <sub>-4</sub> *B <sub>-4</sub> | A <sub>-4</sub> B <sub>-4</sub> , 0.0                             | ---                              | ---                              |
| 5.    | A <sub>0</sub> , B <sub>0</sub>   | A <sub>-3</sub> *B <sub>-3</sub> | A <sub>-3</sub> B <sub>-3</sub> , 0.0                             | ---                              | ---                              |
| 6.    | A <sub>1</sub> , B <sub>1</sub>   | A <sub>-2</sub> *B <sub>-2</sub> | A <sub>-2</sub> B <sub>-2</sub> , A <sub>-4</sub> B <sub>-4</sub> | A <sub>-4</sub> B <sub>-4</sub>  | ---                              |
| 7.    | A <sub>2</sub> , B <sub>2</sub>   | A <sub>-1</sub> *A <sub>-1</sub> | A <sub>-1</sub> B <sub>-1</sub> , A <sub>-3</sub> B <sub>-3</sub> | A <sub>-3</sub> B <sub>-3</sub>  | ---                              |
| 8.    | A <sub>3</sub> , B <sub>3</sub>   | A <sub>0</sub> *A <sub>0</sub>   | A <sub>0</sub> B <sub>0</sub> , ES <sub>2</sub>                   | ES <sub>2</sub>                  | ---                              |
| 9.    | ---                               | A <sub>1</sub> *A <sub>1</sub>   | A <sub>1</sub> B <sub>1</sub> , OS <sub>2</sub>                   | OS <sub>2</sub>                  | ---                              |
| 10.   | ---                               | A <sub>2</sub> *A <sub>2</sub>   | A <sub>2</sub> B <sub>2</sub> , ES <sub>3</sub>                   | ES <sub>3</sub>                  | ---                              |
| 11.   | ---                               | A <sub>3</sub> *A <sub>3</sub>   | A <sub>3</sub> B <sub>3</sub> , OS <sub>3</sub>                   | OS <sub>3</sub>                  | ---                              |
| 12.   | ---                               | ---                              | ---                                                               | ES <sub>4</sub>                  | ES <sub>4</sub>                  |
| 13.   | ---                               | ---                              | OS <sub>4</sub> , ES <sub>4</sub>                                 | OS <sub>4</sub>                  | ES <sub>4</sub>                  |
| 14.   | ---                               | ---                              | ---                                                               | ---                              | ES <sub>4</sub>                  |
| 15.   | ---                               | ---                              | ---                                                               | OS <sub>4</sub> +ES <sub>4</sub> | OS <sub>4</sub> +ES <sub>4</sub> |

ES is n terms of the even term Sum:  $A_i B_i, i = -4, -2, 0, 2$   
 OS is n terms of the odd term Sum:  $A_i B_i, i = -3, -1, 1, 3$

#### 4.5 I/O GROUP

The Op-Codes available within the I/O group of the AP-120B instruction word provide the operations necessary for (1) DATA TRANSFERS between the AP-120B and the HOST COMPUTER INTERFACE (HOST-CPU I/F) or other ADDRESSABLE I/O DEVICES through the programmed I/O Section and (2) AP-120B INTERNAL REGISTER transfers to the PANEL BUS.

This summary is presented in sections related to the functional areas of the AP-120B I/O STRUCTURE: (1) the VIRTUAL FRONT PANEL (PANEL), AND (2) PROGRAMMED I/O OPERATIONS.

An outline of this summary is presented below:

##### I. AP-120B I/O OPERATIONS

- \* General Overview
- \* Panel Operations
- \* Programmed I/O Operations
- \* DEVICE ADDRESSING

##### II. AP-120B VIRTUAL FRONT PANEL (PANEL)

- \* General Description
- \* Panel Operations
- \* General Rules

##### III. PROGRAMMED I/O

###### a. HOST INTERFACE

- \* Control Register
- \* Formatter
- \* Direct Memory Access operations and related transfer and control registers
- \* Programmed Interrupts

###### b. ADDRESSABLE I/O DEVICES

- \* TMRAM
- \* OTHER I/O DEVICES

##### IV. PROGRAMMING EXAMPLE

#### 4.5.1 AP-120B I/O OPERATIONS

##### 4.5.1.1 General Overview

The AP-120B I/O structure consists of two major areas of operation:

- (1) VIRTUAL FRONT PANEL (PANEL) - through which the HOST-CPU may examine /or alter AP-120B INTERNAL REGISTERS and Data Memories.
- (2) PROGRAMMED I/O - through which data transfers are accomplished between the AP-120B and addressable I/O DEVICES. The I/O DEVICES that may be addressed via programmed I/O operations are grouped in the following manner:
  - A. HOST INTERFACE
    - \* CONTROL REGISTER (CTL)
    - \* FORMATTER (FMT)
    - \* DIRECT MEMORY ACCESS REGISTERS:
      - WORD COUNT REGISTER (WC)
      - HOST MEMORY ADDRESS REGISTER (HMA, HHMA)
      - AP-120B MEMORY ADDRESS REGISTER (APMA)
  - B. OTHER ADDRESSABLE I/O DEVICES
    - \* WRITABLE TABLE MEMORY (TMRAM)
    - \* MEMORY BANK SELECT
    - \* OTHER I/O DEVICES

##### 4.5.1.2 Panel Operations

The PANEL is similar in function to the console of a stand-alone computer and consists of three 16-bit registers: LIGHTS (LITES), SWITCHES (SWR), AND FUNCTION (FN).

The PANEL is primarily under the control of the HOST-CPU. Through PANEL operations, the HOST-CPU may examine and modify internal AP-120B registers as well as dictate control functions related to AP-120B program execution. The AP-120B may deposit into the LIGHTS REGISTER (LITES), and read the SWR.

Typically, the PANEL is used for bootstrap operations (loading and starting programs) and for debugging user software by using hardware breakpoints and/or by examining and modifying AP-120B registers and memory. PANEL OPERATIONS are controlled by the condition of control bits in the FUNCTION REGISTER (FN). (See Section 4.5.2 for more details on PANEL operations).

#### 4.5.1.3 Programmed I/O Operations

The operations available through PROGRAMMED I/O will be discussed in detail in Section 4.5.3 of this summary. The purpose of this section is to present a general overview of the components and operations involved in executing basic PROGRAMMED I/O transfers between the AP-120B and ADDRESSABLE I/O DEVICES.

##### \* Theory of Operations

In contrast to the customary use of a DEVICE CODE FIELD within a given I/O instruction word, the AP-120B uses a separate eight-bit register, termed the DEVICE ADDRESS REGISTER (DA), whose current contents designate the particular I/O DEVICE involved in the current AP-120B I/O operation. Because DA is a separate register, the programmer must properly condition the contents of DA at least one instruction before initiating an I/O operation to the desired I/O DEVICE.

Generally, the designated I/O DEVICE communicates its state of availability to the AP-120B (whether or not it is ready to receive or send data) by the current state of its I/O DATA READY FLAG (IODRDY). When IODRDY of the designated I/O DEVICE is equal to 1, then the I/O DEVICE is READY for the current I/O transfer operation.

Certain Op-Codes within the AP-120B instruction set are capable of testing the state of a device's IODRDY FLAG before executing a given I/O Op-Code. When these Op-Codes are used, the AP-120B will execute a SPIN operation (See note) until IODRDY(DA) is equal to 1, at which time the specified I/O transfer will be executed.

The particular DATA PATHS employed in an I/O operation depend on which DATA-TRANSFER MODE is being used. Generally, with the exception of the DIRECT-MEMORY ACCESS MODE (DMA), data to be OUTPUT from the AP-120B must be placed onto the DATA PAD BUS (DB) where it is automatically placed onto the INBS by the AP-120B I/O structure and OUTPUT to the addressed I/O DEVICE. Data input to the AP-120B must be concurrently transferred onto DB (via use of a DATA PAD GROUP OP-CODE) from the I/O BUS (INBUS) where it is placed by the sending I/O DEVICE.

##### NOTE

A "SPIN" will suspend all on-going program operations within the AP-120B until the IODRDY(DA) FLAG = 1. Note, however, that an infinite SPIN loop will occur if the IODRDY(DA) never equals 1. Do not use I/O SPINS during overlapped main data accesses (See Section 4.7).

### \* In/Out Operations

Basically, there are four types of PROGRAM CONTROL INPUT OR OUTPUT instructions. The PROGRAMMER may: (1) unconditionally transfer DATA (via IN, OUT); (2) SPIN until the I/O DEVICE is READY (IODRDY(DA)=1), and then transfer DATA (via SPININ, SPNOUT); (3) transfer DATA then change the contents of DA (INDA, OUTDA); or (4) SPIN until IODRDY(DA)=1, then transfer DATA, and then change the contents of DA (SPINDA, SPOTDA). (See IN/OUT field for more details.)

Examples of typical non-DMA PROGRAMMED I/O operations are given below:

Assume the S-PAD REGISTER 5 equals the desired I/O DEVICE ADDRESS.

TO INPUT DATA INTO AP-120B:

| ASSEMBLER FORMAT                                                                    | (MEANING)                                                                                                                                                                                    |
|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOV 5,5; LDDA;DB=SPFN<br>IN; DPX(-3)<INBS                                           | (Set up DEVICE ADDRESS)<br>(INPUT data onto INBUS and transfer it to DPX(-3) via DB.)                                                                                                        |
| or, TO INPUT BY TESTING IODRDY(DA)<br>MOV 5,5; LDDA;DB=SPFN<br>SPININ; DPX(-3)<INBS | (Set-up DEVICE ADDRESS)<br>(SPIN until IODRDY flag is set, then INPUT onto INBS and transfer it to DPX(-3) via DB.)                                                                          |
| TO OUTPUT DATA AP-120B:<br>MOV 5,5;LDDA;DB=SPFN<br>OUT;DB=TM                        | (Set up DEVICE ADDRESS)<br>(Put DATA WORD onto DB, then OUTPUT. THE I/O LOGIC will place the data word onto INBS where it will be OUTPUT to the I/O DEVICE.)                                 |
| TO OUTPUT BY TESTING IODRDY(DA)<br>MOV 5,5;LDDA;DB=SPFN<br>SPNOUT;DB=TM             | (Set-up DEVICE ADDRESS)<br>(SPIN until I/O DEVICE is ready to accept the DATA WORD. When ready, the I/O logic will place the DATA WORD onto INBS where it will be OUTPUT to the I/O DEVICE.) |
| or, LDDA; DB=DEV<br>OUTDA; MOV 5, 5                                                 | (Set device address)<br>(Output to first device and set DA to SPFN.)                                                                                                                         |

In order to execute an INPUT or OUTPUT operation, the object I/O DEVICE

must be selected by placing its DEVICE ADDRESS into the AP-120B I/O DEVICE ADDRESS REGISTER (DA). DA is an eight-bit register affording a range of 256 different I/O DEVICE ADDRESSES. The lower DEVICE ADDRESSES are dedicated in the following manner:

| I/O DEVICE                                | DEVICE ADDRESS  |
|-------------------------------------------|-----------------|
| HOST INTERFACE                            |                 |
| DMA REGISTERS:                            |                 |
| WORD COUNT REGISTER (WC)                  | 0               |
| HOST MEMORY ADDRESS REGISTER (HMA)        | 1               |
| CONTROL REGISTER (CTL)(See Note 1)        | 2               |
| AP-120B MEMORY ADDRESS REGISTER (APMA)    | 3               |
| FORMATTER (FMT)                           | 4               |
| WRITABLE TABLE MEMORY (TMRAM)(See Note 2) | 5               |
| MEMORY ADDRESS EXTENSION (MAE)            | 30              |
| APMA EXTENSION (APMAE)                    | 31              |
| MASK (including MODE and I/O)             | 32              |
| ADDITIONAL DEVICE ADDRESSES are:          |                 |
| First IOP16                               | 10-14           |
| Second IOP16                              | 20-24           |
| Parity Option                             | 33-37           |
| First PIOP                                | 100,101,110-117 |

#### NOTES

1. CTL register provides control functions for other HOST-INTERFACE functions besides DMA.
2. HHMA uses device address 5 in some systems. However, if both TMRAM and HHMA are needed, then HHMA is moved to another address which depends upon the system's configuration.

#### \* DA Modification Instructions

The current contents of the DEVICE ADDRESS REGISTER (DA) determine which I/O DEVICE will be involved for a current AP-120B I/O operation. DA may be altered, via programmed instruction, by use of one of the following OP-CODES. (Effective as of the next instruction cycle).

| OP-CODE | I/O SUB-FIELD | OCTAL VALUE | OPERATION                                                                                                                                            |
|---------|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDDA    | LDREG         | 7           | (DPBS) $\Rightarrow$ DA                                                                                                                              |
| OUTDA   | INOUT         | 2           | Perform output to current I/O DEVICE(DA) then (SPFN) $\Rightarrow$ DA                                                                                |
| SPOTDA  | INOUT         | 3           | Spin until IODRDY(DA)=1, then OUTPUT DATA, then (SPFN) $\Rightarrow$ DA                                                                              |
| INDA    | INOUT         | 6           | Perform INPUT from I/O DEVICE(DA), then (SPFN) $\Rightarrow$ DA                                                                                      |
| SPINDA  | INOUT         | 7           | Spin until IODRDY(DA)=1, then INPUT DATA, then (SPFN) $\Rightarrow$ DA                                                                               |
| SNSADA  | SENSE         | 2           | Enable CONDITION "A" to IODRDY(DA), then (SPFN) $\Rightarrow$ DA                                                                                     |
| SPNADA  | SENSE         | 3           | Test loop for CONDITION "A": "A" is continually enabled into IODRDY(DA) while the AP-120B SPINS. When (IODRDY(DA)) = 1, then (SPFN) $\Rightarrow$ DA |
| SNSBDA  | SENSE         | 6           | Enable CONDITION "B" to IODRDY(DA), then (SPFN) $\Rightarrow$ DA                                                                                     |
| SPNBDA  | SENSE         | 7           | Test loop for CONDITION "B": "B" is continually enabled into IODRDY while the AP-120B SPINS. When (IODRDY(DA)) = 1, then (SPFN) $\Rightarrow$ DA     |

Additionally, certain OP-CODES within the SENSE field permit either of two condition lines (A,B) to be enabled into the IODRDY FLAG. (See SENSE field) Conditions "A" and "B" are device dependent and have no a priori descriptions.

#### 4.5.2 Virtual Front Panel (PANEL)

##### 4.5.2.1 General Description

The AP-120B I/O STRUCTURE contains a VIRTUAL FRONT PANEL (PANEL) consisting of three 16-bit registers - (1) SWITCHES (SWR), (2) LIGHTS (LITES), AND (3) FUNCTION (FN). The registers are under control of the HOST-CPU via HOST-INTERFACE. The HOST may examine and/or set these registers at any time, irrespective of the state of the AP-120B. The AP-120B, however, may only DEPOSIT into the LITES register and only READ the SWR (See HOSTPNL field of Special Operations group in instruction descriptions). A brief description of the PANEL registers are given below:

| REGISTER                 | DESCRIPTION                                                                                                                        |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| SWITCHES (SWR) (16 Bits) | Used to enter DATA and ADDRESSES into the AP-120B. Can be read or written by HOST-CPU or read by AP-120B programmed instruction.   |
| LIGHTS (LITES) (16 Bits) | Used to display the contents of internal AP-120B registers. Can be read by HOST-CPU and written by AP-120B programmed instruction. |
| FUNCTION (FN) (16 Bits)  | Provides VIRTUAL FRONT PANEL control operations. Can be read or written by HOST-CPU only.                                          |

##### 4.5.2.2 Panel Operations

The control bits of the PANEL FUNCTION REGISTER (FN) determine the current operation(s) of the VIRTUAL FRONT PANEL. The available PANEL operations may be classed into two groups - (1) AP-120B PROGRAM CONTROL, and (2) AP-120B INTERNAL REGISTER EXAMINATION and MODIFICATION.

A detailed explanation of available PANEL operations and related control bits of the FUNCTION REGISTER (FN) is given below. Unless otherwise noted, the active state of the appropriate FN control bit is a "1".

### PANEL FUNCTION REGISTER FORMAT

|           |            |           |           |            |           |          |            |          |   |            |    |    |    |    |                       |
|-----------|------------|-----------|-----------|------------|-----------|----------|------------|----------|---|------------|----|----|----|----|-----------------------|
| Ø<br>STOP | 1<br>START | 2<br>CONT | 3<br>STEP | 4<br>RESET | 5<br>EXAM | 6<br>DEP | 7<br>BREAK | 8<br>INC | 9 | 10<br>WORD | 11 | 12 | 13 | 14 | 15<br>REGISTER SELECT |
|-----------|------------|-----------|-----------|------------|-----------|----------|------------|----------|---|------------|----|----|----|----|-----------------------|

When the AP-120B is running only the STOP and RESET panel functions are valid. The other panel functions can only be exercised after the AP-120B has been halted. BREAK and REGISTER SELECT can be altered and have an effect.

### PANEL OPERATIONS AND RELATED FN CONTROL BITS AP-120B PROGRAM CONTROL

| OPERATION   | RELATED FN<br>REGISTER BIT(s) | EFFECT                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STOP/HALTED | BIT "0"                       | STOP AP-120B program execution upon completion of the current instruction. FN bit "0" reflects the current state of the AP-120B when examined by the HOST. ("1" equals AP-120B HALTED, "0" = AP-120B RUNNING). Setting this bit will stop the AP. Note that if AP-120B is currently executing a "SPIN" condition, the halt will be effective only after the "SPIN" has been completed. |
| START       | BIT "1"                       | START AP-120B program execution at the program location specified by the contents of the SWITCHES (SWR) register. The preferred first instruction should be a NOP to avoid timing sequence.                                                                                                                                                                                            |
| CONT        | BIT "2"                       | CONTINUE AP-120B program execution at the program location pointed to by the current contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA).                                                                                                                                                                                                                                            |
| STEP        | BIT "3"                       | Single STEP. The AP-120B instruction at the program location pointed to by the current contents of PSA will be executed. The PSA will then be advanced to point to the next program location.                                                                                                                                                                                          |

|       |         |                                                                                                                                                                                                                                                                                                                          |
|-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESET | BIT "4" | RESET and HALT the AP-120B immediately. Clear S-PAD Register "0" (SP(0)) and set current SPFN to SP(SPFN); clear APSTATUS Register, reset and clear MAIN DATA MEMORY TIMING. Inoperative if AP-120B caught in an I/O SPIN.                                                                                               |
| BREAK | BIT "7" | BREAKPOINT - valid only if PSA, MA, or TMA is specified in the REGISTER SELECT field (FN bits 12-15). This causes AP-120B program execution to halt when contents of selected register equal the value set into SWR register. The exact timing of a given BREAK operation is dependent on the ADDRESS REGISTER selected. |

| REGISTER<br>SELECT | CORRESPONDING<br>OCTAL VALUE<br>IN REG SEL<br>FIELD |  | EFFECT                                                                                                                                                                                                                                               |
|--------------------|-----------------------------------------------------|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    |                                                     |  |                                                                                                                                                                                                                                                      |
| PSA                | 0                                                   |  | Halt AP-120B program execution on next instruction following the one whose address is contained in SWR. PSA will point to the instruction following it.                                                                                              |
| MA                 | 2                                                   |  | Halt AP-120B program execution after executing the next instruction following the one that referenced the memory location whose address is contained in SWR. PSA will point to the second instruction following the one which caused the breakpoint. |
| TMA                | 3                                                   |  |                                                                                                                                                                                                                                                      |

AP-120B REGISTER EXAMINATION AND MODIFICATION

| OPERATION | RELATED FN<br>REGISTER BIT(s) | EFFECT                                                                                                                                                                                                                                                                                                   |
|-----------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXAM      | BIT "5"                       | EXAMINE the register or memory selected by the octal value contained in the REGISTER SELECT field (FN bits 12-15).. Display to LITES that PORTION of the selected register or memory as determine by the WORD field (FN bits 10-11).                                                                     |
| DEP       | BIT "6"                       | DEPOSIT the contents of the SWITCHES (SWR) into the register register or memory selected by the value contained in the REGISTER SELECT field (FN bits 12-15). The deposit will occur to that portion of the object register or memory selected by the value contained in the WORD FIELD (FN bits 10-11). |
| INC       | BITS 8-9                      | Increment either MA, TMA, or DPA- depending on current value- following completion of the other concurrently specified PANEL operations. This operation allows sequential memory locations to be examined or deposited. Note that MA pre-increments on the concurrent DEPOSIT into MD.                   |
|           | INC OCTAL<br>VALUE            | ADDRESS REGISTER TO BE<br>INCREMENTED                                                                                                                                                                                                                                                                    |
|           | 0                             | NONE                                                                                                                                                                                                                                                                                                     |
|           | 1                             | MA (MAIN DATA MEMORY ADDRESS<br>REGISTER)                                                                                                                                                                                                                                                                |
|           | 2                             | DPA (DATA PAD ADDRESS REGISTER)                                                                                                                                                                                                                                                                          |
|           | 3                             | TMA (TABLE MEMORY ADDRESS<br>REGISTER)                                                                                                                                                                                                                                                                   |
| WORD      | BITS 10-11                    | Selects which portion of a register or memory is deposited or examined. The WORD field is used in conjunction with REGISTER SELECT (FN BITS 12-15). Portions are selected in the following manner.                                                                                                       |

WORD OCTAL

VALUE IS: REGISTER SELECTED BY CURRENT VALUE IN FN BIT 12-15 IS:

|   | 16 BITS<br>OR LESS | 38 BITS                                                                     | 64 BITS (PROGRAM SOURCE)                            |
|---|--------------------|-----------------------------------------------------------------------------|-----------------------------------------------------|
| 0 | ALL                | **                                                                          | PS(QUARTER ZERO)<br>(PS(Q0));<br>(PS(bits 0-15))    |
| 1 | **                 | EXPONENT bits 02-11<br>right justified,<br>zero filled.                     | PS(QUARTER ONE)<br>(PS(Q1));<br>(PS (bits 16-31))   |
| 2 | **                 | HIGH MANTISSA -<br>MANTISSA bits 00-11;<br>right justified,<br>zero filled. | PS(QUARTER TWO)<br>(PS(Q2)); (PS<br>(bits 32-47))   |
| 3 | **                 | LOW MANTISSA -<br>MANTISSA bits 12-27.                                      | PS(QUARTER THREE)<br>(PS(Q3)); (PS (bits<br>48-63)) |

\*\*Not applicable

REGISTER

SELECT      BITS 12-15      Selects which register, memory, or data path will be examined or deposited for the current PANEL OPERATION. Used in conjunction with WORD field, (FN bits 10-11) by OCTAL VALUE, in the following manner:

| REGISTER SELECT<br>OCTAL VALUE | REGISTER (Field bit<br>SELECTED length) | COMMENTS                                                                                  |
|--------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------|
| 0                              | PSA (12)                                | PROGRAM SOURCE ADDRESS<br>REGISTER                                                        |
| 1                              | SPD (4).                                | S-PAD DESTINATION<br>ADDRESS REGISTER                                                     |
| 2                              | MA (16)                                 | MAIN DATA MEMORY<br>ADDRESS REGISTER                                                      |
| 3                              | TMA (16)                                | TABLE MEMORY ADDRESS<br>REGISTER                                                          |
| 4                              | DPA (6)                                 | DATA PAD ADDRESS<br>REGISTER (DPA is 6 bits<br>wide even though DPA<br>has 32 registers.) |

|    |                             |                                                                                                                                                              |
|----|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5  | SPFN(16)<br>(See Note 1)    | S-PAD FUNCTION<br>currently enabled. May<br>be EXAMINED ONLY..                                                                                               |
| 5  | SP(SPD)(16)<br>(See Note 2) | S-PAD DESTINATION<br>REGISTER currently<br>specified by SPD.<br>May be DEPOSITED<br>ONLY.                                                                    |
| 6  | APSTATUS (16)               | AP-120B INTERNAL STATUS<br>REGISTER                                                                                                                          |
| 7  | DA (8)                      | DEVICE ADDRESS REGISTER                                                                                                                                      |
| 10 | PS(TMA) (64)                | PROGRAM SOURCE WORD<br>specified by the AD-<br>DRESS currently<br>contained in TMA.                                                                          |
| 11 | INBS(DA) (38)               | Read input data from<br>I/O device specified by<br>DA register. May be<br>examined only.                                                                     |
| 12 | 0                           | Not applicable                                                                                                                                               |
| 13 | DPX(DPA-4) (38)             | DATA PAD X location<br>specified by the cur-<br>rent contents of DPA<br>minus 4.                                                                             |
| 14 | DPY(DPA-4) (38)             | DATA PAD Y location<br>specified by the current<br>contents of DPA minus 4.                                                                                  |
| 15 | MD(MA) (16)                 | MAIN DATA MEMORY lo-<br>cation specified by the<br>current contents of MA.                                                                                   |
| 16 | 0                           | Not applicable                                                                                                                                               |
| 17 | TM(TMA)                     | TABLE MEMORY location<br>specified by current<br>contents of TMA. May<br>be EXAMINED ONLY. Note<br>one cycle delay in<br>examination after<br>change of TMA. |

## NOTES

1. Valid only during EXAMINATION operation (FN bit 5 = 1).
2. Valid only during DEPOSIT operation (FN bit 6 = 1).

## General Rules - Panel Operations

### \* STARTING the AP-120B (via START or CONT)

The PANEL START function can be used to start the AP-120B program with the following restriction:

The FIRST INSTRUCTION executed by the AP-120B following a START command MUST NOT alter PSA in any manner other than to advance it to the next sequential instruction. The user should not use a BRANCH or JUMP instruction or any instruction within the SPEC or I/O groups of the instruction word. Accordingly, the preferred first instruction is a NOP.

The PANEL CONT function is recommended to start the AP-120B, in the following manner:

1. Set SWR to the starting address and execute a DEP into PSA.
2. Set SWR to a desired breakpoint (See note) and execute a CONT.

### NOTE

This places the necessary breakpoint code into the user's program should he need to debug the program.

### \* STOPPING the AP-120B (via STOP or BREAK)

On all stopping operations except RESET, the AP120B will stop with PSA set to the ADDRESS of the next instruction. Since SPFN is current, it will be set according to the instruction that the PSA is currently pointing to. Otherwise, the instruction pointed to by PSA is not executed and will execute correctly when the user STEPS or CONTINUES (except for MD timing).

\* MAIN DATA TIMING CYCLE

The MD memory timing is designed so as to preserve the current state of the timing sequence when a STOP or BREAK is executed. MD timing will be in its proper sequence when the user STEPS or CONTINUES.

Note that the user must not examine or alter either MD or TM, nor should he permit a DMA transfer while the AP-120B is stopped, if MD timing is suspended. TM will also be upset by any panel operation other than continue if one cycle after SETTMA, INCTMA, DECTMA or LDTMA.

To determine condition of MD memory timing: If PSA is pointing to either the first or second instruction location following a SETMA, INCMA, DECMA, or LDMA, the memory cycle is suspended in mid-operation and the restrictions stipulated in the note above apply.

\* RESETTING the AP-120B (via RESET)

The user may not correctly STEP or CONT following execution of a PANEL RESET. MD memory timing is cleared and APSTATUS is reset. Also SP(0) is cleared and SPFN is set to SP(SPD) with SPD=0. Thus the S-PAD registers can be examined by setting SPD (DEP to SPD) and examining SPFN.

\* STEPPING the AP-120B (via STEP)

The user may alter or examine any register or memory except for restrictions concerning MD MEMORY TIMING and TM timing as already discussed.

\* EXAMINING or DEPOSITING

The user may examine and/or deposit into any available field within the restrictions concerning MD MEMORY and TM TIMING and the conditions listed below:

\* The current contents of TMA are used as a pointer to indicate which PROGRAM SOURCE location is to be examined or deposited.

\* TO EXAMINE SP(SPD) - since SP(SPD) may not be examined directly, the user may execute a PANEL RESET to force an SP(SPD) to SPFN and then examine SPFN (This clears SP(0)). Alternatively, this may be accomplished with the following micro-code sequence:

```
MOV #0,0
RSPFN; LDSPNL 0
HALT
NOP
```

This will set SPFN=SP(SPD) without clearing SP (0).

Note that a PANEL RESET will also clear MD TIMING and APSTATUS.

\*TO EXAMINE OR DEPOSIT INTO MD - a MEMORY READ CYCLE is initiated by the user executing a DEP into MA. A MEMORY WRITE CYCLE is initiated by the user executing a DEP into MD. Therefore to deposit into a given MD location, and then examine that MD location, the following sequence must be performed.

#### PANEL REGISTER CONDITIONS

| OPERATION                                                         | LITES                          | SWR                                                         | FN                                                                       |
|-------------------------------------------------------------------|--------------------------------|-------------------------------------------------------------|--------------------------------------------------------------------------|
| (1) Set MA to location X                                          | ---                            | Set to address X                                            | DEP (BIT 6) = 1<br>REG SEL (bits 12-15) = 2 (MA)                         |
| (2) Examine MD                                                    | Will reflect contents of MD(X) | ---                                                         | Exam FN=1002(8)<br>(bit 5) = 1<br>REG SEL = 15<br>WORD = 1, 2 or 3       |
| (3) Deposit into MD(X) (This writes into MD at previously set MA) | ---                            | Set to value desired to be deposited into WORD (bits 10-11) | DEP (bit 6) = 1<br>REG SEL (bits 12-15) = 15(MD)<br>10-11) = 1, 2 or 3   |
| (4) SET MA to location X                                          | ---                            | Set to address X                                            | DEP (bit 6) = 1<br>REG SEL (bits 12-15) = 2(MA)<br>WORD (bits 10-11) = 0 |

|                |                                          |     |                                                      |
|----------------|------------------------------------------|-----|------------------------------------------------------|
| (5) Examine MD | Will reflect<br>new contents<br>of MD(X) | --- | Exam (bit 5) = 1<br>REG SEL = 15<br>WORD = 1,2, or 3 |
|----------------|------------------------------------------|-----|------------------------------------------------------|

\* TO EXAMINE TM - because the TABLE MEMORY hardware requires two PANEL operations to retrieve a requested TM location, the following sequence must be performed.

#### PANEL REGISTER CONDITIONS

##### OPERATION

|                                                                                  | LITES   | SWR       | FN                                                  |
|----------------------------------------------------------------------------------|---------|-----------|-----------------------------------------------------|
| (1) Set TMA (To<br>initiate exa-<br>mine TM(X))                                  | ---     | Address X | DEP (bit 6) = 1<br>REG SEL (bits<br>12-15) = 3(TMA) |
| (2) Set TMA<br>("Dummy PANEL<br>operation to<br>retrieve con-<br>tents of TM(X)) | ---     | Address X | Same as above                                       |
| (3) Examine TM                                                                   | (TM(X)) | ---       | Exam (bit 5) = 1<br>REG SEL = 3<br>WORD = 1,2 or 3  |

#### NOTE

WRITABLE TABLE MEMORY (TMRAM) may be deposited through PANEL operations. The user must resort to program I/O Op-Codes in order to WRITE into TMRAM.

#### \* USING THE INCREMENT FUNCTION (via INC)

This function is valid only when either Exam, Dep, RESET or START is selected in the FN. The timing of incrementation is dependent on the operation specified.

Assume INC = 1, 2, or 3

| REGISTER<br>SELECTED IN<br>INC FIELD | PANEL<br>OPERATION | EFFECT                                                |
|--------------------------------------|--------------------|-------------------------------------------------------|
| DPA<br>TMA                           | EXAM or<br>DEP     | DEP MD increments after the specified<br>operation.   |
| MA                                   | DEP MD             | Increments before executing current<br>DEP operation. |

#### 4.5.3 PROGRAMMED I/O

ADDRESSABLE I/O DEVICES capable of I/O transfer operations via use of the AP-120B PROGRAMMED I/O may be classed in the following manner:

- A. HOST INTERFACE and related REGISTERS
- B. Other ADDRESSABLE I/O DEVICES

##### 4.5.3.1 HOST-INTERFACE and related REGISTERS

###### \* General Description

The HOST-INTERFACE acts as a buffer between AP-120B and HOST-CPU. The HOST-INTERFACE is capable of both programmed-control I/O (See Note 1) and DIRECT MEMORY ACCESS (DMA) operations. It consists of the following AP-120B ADDRESSABLE REGISTERS:

| DEVICE                                                | AP-120B DEVICE<br>ADDRESS |
|-------------------------------------------------------|---------------------------|
| WORD COUNT REGISTER (WC) (16 bits)                    | 0                         |
| HOST MEMORY ADDRESS REGISTER (HMA) (16 bits)          | 1                         |
| CONTROL REGISTER (CTL) (16 bits)                      | 2                         |
| AP-120B MEMORY ADDRESS REGISTER (APMA) (16 bits)      | 3                         |
| FORMATTER (FMT) (38 bits)                             | 4                         |
| High Host Memory address (HHMA)(2-4 bits)(See Note 2) | 5                         |

###### NOTES

1. PROGRAMMED CONTROL I/O - I/O data transfer operations are accomplished through sequential program instruction execution. Although the DMA control registers may be accessed through PROGRAMMED CONTROL I/O, the actual DMA transfer operation when enabled is autonomous.
2. HHMA is applicable only for those HOST CPU's having more than 16 bits of DMA address.

\* Control Register (CTL)

CTL is a 16-bit I/O ADDRESSABLE REGISTER (DA = 2). CTL contains the condition bits that control most HOST-INTERFACE-related I/O operations. CTL can be read anytime by the executing AP-120B program without regard to HOST-CPU activity. CTL can be written by either the HOST-CPU or AP-120B. However, if both attempt to write CTL at the same time, the HOST-CPU will be given priority.

The operations directed by CTL fall into the following groups:

- 1) Mode and direction of transfer (DMA or PROGRAMMED - CONTROL I/O)
- 2) Type of DATA FORMAT and I/O PATH SELECTION (via FORMATTER)
- 3) Transfer STATUS and ERROR BITS, and
- 4) PROGRAMMED-INTERRUPT enable bits

CONTROL REGISTER FORMAT

| $\emptyset$<br>WC=0 | 1<br>INTR<br>AP | 2<br>IAP<br>WC | 3<br>IH<br>HALT | 4<br>IH<br>WC | 5<br>IH<br>ENB | 6<br>FERR | 7<br>DLATE | 8<br>CC | 9<br>AP<br>DMA | 10<br>WRT<br>HOST | 11<br>DEC<br>APMA | 12<br>DEC<br>HMA | 13<br>FMT | 14 | START |
|---------------------|-----------------|----------------|-----------------|---------------|----------------|-----------|------------|---------|----------------|-------------------|-------------------|------------------|-----------|----|-------|
|---------------------|-----------------|----------------|-----------------|---------------|----------------|-----------|------------|---------|----------------|-------------------|-------------------|------------------|-----------|----|-------|

A description of CTL bit operations is given below. Further details of particular CTL bit functions will be discussed in sections related to the I/O DEVICES which are controlled or monitored by the CTL register. All bits are READ/WRITE except as noted.

- Bit 0 WC=0 Indicates that the Word Count Register is zero. Note that WC is decremented only during DMA transfers to/from Host Memory. Bit 0 is a Read only bit. It should not be used to monitor DMA activity.
- Bit 1 INTRAP Set the INTRQ (Interrupt Request) flag in the AP-120B.
- Bit 2 IAPWC Set INTRQ (Interrupt Request) flag in the AP-120B when the DMA transfer is done.
- Bit 3 IHALT Enable a Host Interrupt when the AP-120B halts.
- Bit 4 IHWC Enable a Host Interrupt when the DMA transfer is done.
- Bit 5 IHENB Interrupt Host Enable. Interrupt Host if AP-120B attempts to set this bit, or if AP-120B executes an "INTEN" instruction (See I/O field). This bit can actually be written only by the Host.

- Bit 6 FERR Format Error. Indicates that EXPONENT UNDERFLOW or OVERFLOW occurred in conversion from AP-120B Format to Host Floating-Point Format. (Read only) Can be set only during transfers with CTL10=1 and FMT=2 or 3. Due to the Pipeline nature of the FORMATTER, the next two words past the end (before the beginning if CTL11=1) of the DATA ARRAY will be loaded into the FORMATTER at the end of the transfer. In order to avoid spurious setting of FERR, the programmer must insure that these two words are either zero or are FPN's within the allowable dynamic range of formats 2 or 3.
- Bit 7 DLATE Data Late. Indicates that the AP-120B did not empty/load the FORMAT BUFFER before the Host attempted to reload/read it. On some Hosts this bit also indicates an attempt to access non-existent Host memory. In the latter case, the DMA transfer is terminated (PDP-11 only). Bit 7 is a read-only bit that is cleared by an interface reset or by setting HDMA START (CTL 15). It is not cleared by a panel Reset.
- Bit 8 CC Consecutive Cycle. Block DMA transfers to/from Host memory will occur without interruption. On typical Hosts, the Host CPU will be locked out but other higher priority DMA devices will still have access to Host memory. Some Host interfaces are equipped with a hardware selectable consecutive cycle counter that limits the number of cycles stolen in a burst.
- Bit 9 APDMA Allows the interface to perform DMA transfers to/from AP-120B memory. Depending on the direction of transfer, a MAIN DATA MEMORY cycle is initiated every time the Host finishes reading or loading the format register, whether via DMA or program control. On the AP-120B side, the format register is loaded from the MAIN DATA BUS instead of the DATA PAD BUS.
- Bit 10 WRTHOST Write to Host. This bit controls the direction of transfer. If set, data is read from the Ap-120B, passed through the FORMAT REGISTER, and written to the Host. If clear, the direction of transfer is reversed.
- Bit 11 DECAPMA Decrement APMA. If set, APMA is decremented during DMA transfers to/from Ap-120B MAIN DATA MEMORY. If clear, APMA is incremented.
- Bit 12 DECHMA Decrement HMA. If set, DMA is decremented during DMA transfers to/from Host memory. If clear, HMA is incremented.

Bits 13  
& 14 FMT Format Register Control. (See FORMATTER, next section).

Bit 15 HDMA Host DMA Start. Initiate DMA transfers to/from Host memory. When read, the state of this bit reflects the status of the Host DMA activity ("1" if active, "0" if inactive). Transfers continue until WC=0. Writing a "0" in this bit with DMA active has no effect on the transfer as long as the state of CTL (bits 8-14) is not changed. The programmer should not, under any circumstances, write a "1" in this bit with the DMA active. This is the bit that should be read in order to monitor DMA activity.

\* Formatter (FMT)

The FORMATTER consists of the following:

- \* The necessary decoding logic to interpret the types of ongoing I/O transfer (via CTL bits 9, 10, 12, 13 and 14)
- \* A 38 bit double-buffered register, and
- \* An I/O DATA READY FLAG for AP-120B operations

FMT has an I/O DEVICE ADDRESS of 4

The FORMATTER is a HOST-INTERFACE transfer buffer which under the direction of selected bits of the CONTROL REGISTER (CTL), performs the following functions in order to coordinate the I/O transfer operations specified (whether via PROGRAMMED I/O or DMA):

- 1) FORMAT CONVERSION
- 2) INPUT BUS SELECTION
- 3) TRANSFER-DIRECTION CONTROL and ORDER of DATA-WORD ASSEMBLY
- 4) I/O TRANSFER TIMING COORDINATION via its IODRDY flag

### (1) FORMAT CONVERSION

The following FORMAT CONVERSION operations may be performed for a given I/O TRANSFER between the AP-120B and the HOST-CPU. Note that the function selected is entirely dependent on the conditions of bits 13 and 14 of the HOST-INTERFACE CONTROL REGISTER (CTL). The programmer must insure that the CTL bits are configured in a manner consistent with the particular I/O transfer being executed.

| VALUE in CTL<br>Bits 13-14 | FORMAT CONVERSION<br>OPERATION                                                                                                                                                                      |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                          | 32-bit integer. No format conversion. Used to transfer integers of half-words.                                                                                                                      |
| 1                          | 16-bit integer. 16-bit integers from the Host are converted to unnormalized 38-bit AP-120B FPN's. Low 16-bits of AP-120B FPN are sent to Host.                                                      |
| 2                          | Conversion of "SIGN-MAGNITUDE MANTISSA with BINARY EXPONENT" format to/from AP-120B Floating Point format. Includes logic to handle "Phantom Bit" and TWO's COMPLEMENT formats (See Notes 1 and 2). |
| 3                          | Conversion of IBM 32-bit format to/from AP-120B format. IBM format can be specified to be either SIGN-MAGNITUDE or TWO's COMPLEMENT (See Notes 1 and 2).                                            |

### NOTES

1. For format types 2 and 3, the FORMATTER has the necessary logic to detect OVERFLOW and UNDERFLOW on conversion from AP-120B format and to force a signed maximum quantity on OVERFLOW or Floating-Point Zero on UNDERFLOW.
2. Operation may vary depending on Host-CPU used. Generally, one of either format 2 or 3, will be adapted to the single precision Floating-Point format of the Host in question.

## (2) INPUT BUS SELECTION

One of the following formatter input busses is selected by FMT depending on the I/O operation being performed (as determined by CTL bits 9 and 10).

| CTL<br>BIT 9 | CTL<br>BIT 10 | INPUT BUS SELECTED BY FMT |
|--------------|---------------|---------------------------|
| 0 OR 1       | 0             | HOST DATA BUS             |
| 0            | 1             | AP-120B I/O BUS (INBUS)   |
| 1            | 1             | AP-120B MAIN DATA OUTPUT  |

## (3) DIRECTION or TRANSFER and ORDER of DATA-WORD ASSEMBLY

Bit 10 of CTL (WRTHOST) determines which direction the FMT will transfer. (When WRTHOST = 1, the transfer is to HOST=CPU; when WRTHOST = 0, then the transfer is to AP-120B).

The FMT may assemble bi-directional 16-bit words from the HOST-CPU before transferring them to the AP-120B, (depending on the format selected via CTL bits 13 and 14). The order in which the half-words are assembled is dependent on the condition of CTL bit 12. (DECHMA). If DECHMA = 1, the HOST-CPU DMA I/F is assumed to be going backwards through host memory and the FMT will expect to receive a LOW WORD followed by a HIGH WORD and will assemble the two words accordingly. If DECHMA = 0, then the order of assembly is reversed (See Note).

### NOTE

FLOATING POINT NUMBER ARRAYS are always expected to be stored in FORWARD ORDER; that is, with the LOW WORD portion of the DATA-WORD stored in the next higher numbered host memory location than the HIGH WORD portion.

## (4) I/O TIMING COORDINATION via IODRDY

FMT will generate an I/O READY response (via IODRDY = 1) to an appropriate AP-120B IN/OUT or SENSE INSTRUCTION (with DA = 4). If IODRDY = 1, then the FMT is ready to either:

- (1) Receive the DATA-WORD from the AP-120B (when CTL bit 10 (WRTHOST) = 1), or
- (2) Send FORMATTED DATA to the AP-120B (when CTL bit 10 (WRTHOST) = 0).

Note that to insure correct execution of a given I/O transfer operation, all functions of FMT must be properly selected. (i.e., all appropriate CTL bits must be correctly conditioned).

\* Direct Memory Access (DMA)

The AP-120B is capable of both STANDARD-DMA and PARTIAL-DMA operations between the AP-120B and HOST-CPU. STANDARD DMA is defined as autonomous (outside of programmed - I/O) block transfers between AP-120B MAIN DATA MEMORY (MD) and HOST-CPU MEMORY, via HOST- INTERFACE FORMATTER (FMT). Partial DMA is a mixed mode of DMA and PROGRAMMED - I/O, available in the following combinations:

- 1) HOST-CPU MEMORY via DMA to FMT, via PROGRAMMED - I/O to AP-120B
- 2) HOST-CPU via PROGRAMMED I/O to FMT, via DMA to AP-120B MAIN DATA MEMORY (MD).
- 3) AP-120B MD via DMA to FMT, via PROGRAMMED I/O to HOST-CPU.
- 4) AP-120B PROGRAMMED I/O to FMT, via DMA to HOST-CPU MEMORY.

The particular mode executed depends on the configuration of bits 8-15 of the CTL register. (See, CONTROL register, this summary).



\* At end of AP-120B-TO-HOST Transfer, AP must transfer two more words than Host.

PARTIAL DMA

FOUR TYPES:



## NOTES

1. First two arguments read by host (32 bits total in Format 1, 64 bits total in Formats 0, 2, 3) must be discarded.
2. AP-120B must transfer two more words than word count at end of transfer.

## DMA - Related Registers

The following AP-120B ADDRESSABLE Registers provide the necessary information and control bits for DMA execution. If the programmer wishes to control or initiate host DMA transfers from within the AP-120B, he must properly condition the applicable bits of these registers.

| DMA-RELATED REGISTER                                                    | DEVICE ADDRESS | DMA-RELATED BITS                                                                                                                                          |
|-------------------------------------------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| CONTROL (CTL)<br>(See CONTROL REGISTER, this summary, for more details) | 2              | Bit 8 (CC)<br>Bit 9 (APDMA)<br>Bit 10 (WRTHOST)<br>Bit 11 (DECAPMA)<br>Bit 12 (DECHMA)<br>Bit 13 & 14 (FMT)<br>Bit 15 (HDMA START/BUSY)                   |
| WORD COUNT (WC)                                                         | 0              | All: Contains the value representing the length of block measured in Host CPU words to be transferred in current DMA operation. (1 to 65,535 Host words). |
| HOST MEMORY ADDRESS (HMA)                                               | 1              | All: Contains the HOST MEMORY ADDRESS at which DMA transfer will begin (applicable only in STANDARD DMA or PARTIAL DMA types "1" and "4")                 |
| AP-120B MEMORY ADDRESS (APMA)                                           | 3              | All: Contains AP-120B MEMORY ADDRESS at which DMA transfer will begin (applicable in STANDARD DMA and PARTIAL DMA types "2" and "3").                     |

The specific operations required for HOST-CPU PROGRAMMED I/O depend entirely on the type of HOST-CPU being used. Programming examples for AP-120B PARTIAL-DMA (1 and 4 above) are presented in the PROGRAMMING EXAMPLE section of this summary. (e.g., BOOTSTRAP example).

## DMA Operations

Generally, DMA operations are executed in the following manner:

- (1) Bits 8-15 of CTL determine the particular mode, format, and direction of DMA operation to be performed.
- (2) The value placed in WC determines the length of block to be transferred (number of words).
- (3) Addresses placed in either HMA or APMA (or both, depending on mode of DMA selected) indicate respective MEMORY ADDRESSES at which the transfer is started.

Once the DMA is initialized (CTL bit 15 = "1"), the AP-120B will raise its DMA REQUEST to the HOST-CPU. Once the DMA REQUEST is granted, the AP-120B will transfer/receive in the following manner;

- a. DMA will transfer one word (See Note), then -
- b. If CC=0 (Bit 08), the AP-120B will drop its request for one HOST-CPU MEMORY cycle, allowing lower priority devices the opportunity to request and receive HOST-CPU channel priority.
- c. One cycle later, the AP-120B will again raise its request to HOST-CPU (locking out all other lower priority devices) and will again transfer one word.
- d. The process will continue until the DMA transfer is completed (WC = 0) or until a programmed RESET prematurely terminates the operation. Additionally, FERR (CTL bit 06) will be set if EXPONENT OVERFLOW or UNDERFLOW occurred during the transfer operation.

### NOTE

- If DMA is the consecutive cycle mode (CTL bit 8 - "1") then DMA will transfer the number of words indicated by the value selected on the DMA "HEX" hardware switch, if applicable, before dropping its request for one cycle.

\* Programmed Interrupts

The AP-120B is capable of generating the following interrupts:

- a. AP-120B INTERNAL INTERRUPTS
  - (1) UNCONDITIONAL
  - (2) DMA INACTIVE
- b. INTERRUPTS TO HOST-CPU
  - (1) AP-120B HALTED
  - (2) DMA INACTIVE
  - (3) CONTROL BIT "5" (CTL05)

\* AP-120B INTERNAL INTERRUPTS

AP-120B INTERNAL INTERRUPTS, when active, set the INTERRUPT REQUEST FLAG (INTRQ) to "1". INTRQ may then be tested and branches made by use of the BINTRQ Op-Code. (See BRANCH).

Both INTERNAL INTERRUPTS initially require an appropriate enabling bit set to "1" in the CONTROL REGISTER (See Note).

- \* The UNCONDITIONAL interrupt requires CTL bit "1" (INTRAP) be set. If INTRAP is set, the AP hardware will unconditionally set the INTRQ flag.
- \* The DMA INACTIVE interrupt requires CTL bit "2" (IAPWC) to be set as an enable. With IAPWC set to "1" when HDMA START=0 (indicating that DMA is inactive), the INTRQ flag will be set.

INTRQ will be true as long as the conditions for either interrupt stay valid.

| INTERRUPT   | CTL<br>ENABLING BIT       | OTHER<br>CONDITIONS  | EFFECT           |
|-------------|---------------------------|----------------------|------------------|
| UNCONDITION | Bit "1" = "1"<br>(INTRAP) | none                 | Set INTRQ to "1" |
| DMA DONE    | Bit "2" = "1"<br>(IAPWC)  | HOST DMA<br>INACTIVE | Set INTRQ to "1" |

NOTE

Additionally, AP-120B INTERNAL INTERRUPTS require PRIORITY GRANTED via the INTPIN enable line. (Applicable only if there are other AP-120B I/O devices in the hardware configuration). The host interface has the lowest interrupt priority.

Example:

To set UNCONDITIONAL INTERRUPT: (effectively using CTL01 as a program flag)

| ASSEMBLER<br>FORMAT | (MEANING)                                            |
|---------------------|------------------------------------------------------|
| LDDA; DB=2          | (Set up DA for CTL)                                  |
| OUT; DB=40000       | (Write CTL bit "1"(See Note)<br>INTRQ is set to "1") |
| o                   |                                                      |
| o                   |                                                      |
| o                   |                                                      |
| o                   |                                                      |
| BINTRQ SVCRT        | (Branch to SVCRT (service routine)<br>if INTRQ = 1)  |

To set DMA INACTIVE INTERRUPT:

|               |                                                                                            |
|---------------|--------------------------------------------------------------------------------------------|
| LDDA; DB=2    | (Set up DA for CTL)                                                                        |
| OUT; DB=20000 | (Write CTL bit "2"(See Note) -<br>when DMA DONE, then INTRQ is<br>set to "1").             |
| o             |                                                                                            |
| o             |                                                                                            |
| o             |                                                                                            |
| o             |                                                                                            |
| BINTRQ SVCRT  | (Branch to SVCRT (service routine)<br>if INTRQ = 1) branch occurs only<br>if DMA inactive. |

#### NOTE

The PROGRAMMER may destroy existing status bits in CTL when writing new bits. To avoid this, he should first examine the bits of CTL and, if needed, rewrite existing bits except for CTL15 back into CTL along with the desired enable bit. This procedure is not advisable if the Host CPU may be writing CTL at the same time.

\* Interrupts To Host-CPU

THE AP-120B is capable of generating three interrupts to HOST-CPU. Like the AP-120B INTERNAL INTERRUPTS, HOST-CPU interrupts require prior conditioning of the appropriate enable bits in the CONTROL REGISTER (CTL) in addition to the particular condition being true.

HOST-CPU INTERRUPTS

| INTERRUPT             | CTL<br>ENABLING BIT    | OTHER<br>CONDITIONS                               | EFFECT (See Note 1)         |
|-----------------------|------------------------|---------------------------------------------------|-----------------------------|
| AP-120B<br>HALTED     | Bit "3" = 1<br>(IHALT) | AP-120B<br>HALTED                                 | Cause HOST-CPU<br>INTERRUPT |
| DMA<br>INACTIVE       | Bit "4" = 1<br>(IHWC)  | DMA INACTIVE                                      | Cause HOST-CPU<br>INTERRUPT |
| CTL05<br>(See Note 2) | Bit "5" = 1<br>(IHENB) | AP attempted<br>to set bit 5<br>or executed IHFNB | Cause HOST-CPU<br>INTERRUPT |

NOTES

1. The specific operation of interrupt generation depends on the particular HOST-CPU and HOST-INTERFACE employed.
2. CTL05 interrupt will generate a HOST-CPU INTERRUPT in the following manner:
  - a. HOST-CPU must have previously set CTL05 to "1".
  - b. The AP-120B attempts to set CTL05 by use of an INTEN Op-Code (See CONTROL) or by writing a 2000(8) into CTL.
  - c. A HOST-CPU interrupt will be generated.

In order to facilitate repeated use of the CTL05 INTERRUPT, the method used to clear the CTL05 interrupt condition is for the host to load the FN register. In most HOST-CPU I/F's, any WRITE to FN automatically clears a CTL05 interrupt condition. The AP-120B can also clear the interrupt condition by trying to WRITE a "0" into CTL05. The state of CTL05 will not be changed by the AP-120B action.

Example:

| CTL05 INTERRUPT APPLICATION          |                                   |                                                                    |
|--------------------------------------|-----------------------------------|--------------------------------------------------------------------|
| HOST-CPU PROGRAM                     | AP-120B PROGRAM                   | (MEANING)                                                          |
| Stipulated Condition<br>(Sets CTL05) | o<br>o<br>o<br>o                  |                                                                    |
|                                      | INTEN                             | (INTEN attempts to set<br>CTL05; generates HOST-<br>CPU INTERRUPT) |
|                                      | o<br>o<br>o                       |                                                                    |
|                                      | or,<br>LDDA, DB=2<br>OUT; DB=2000 | "set up DA<br>"attempt to set CTL05                                |

#### Host-CPU Interrupt Service Routine

Handles interrupt; then clears CTL05 interrupt condition by an I/O output to FN, thus enabling another CTL05 interrupt. The suggested DATA-WORD to be written into FN is zero or one that restores FN bits 7 to 15.

#### Host Interrupt Handler Programming Considerations

In most host interfaces the following protocol will insure that all three AP to host interrupts (HALT, DMA DONE and CTL05) can be serviced without danger of a "lost" interrupt:

- a) Poll the two visible interrupting conditions in a fixed order; e.g., AP halted and Halt interrupt enabled first followed by DMA inactive and DMA interrupt enabled. If the condition and the interrupt enable are both true then perform the required service.
- b) If no service was required by the two visible conditions then the interrupt was due to the AP-120B having set CTL bit with IHENB set and this interrupt should be given its required service. This service should include a reset of the bit 5 condition by writing the FN register.
- c) Clear all three interrupt enables in the CTL register.

- d) Re-enable only those interrupts that were enabled at entry to the routine and were NOT serviced in step a) above. Be careful here not to set the HDMA START bit in the CTL register. Writing a zero into HDMA START will not affect a DMA transfer that is in progress as long as the other DMA control bits (CTL08 to CTL14) are not altered. IHENB can be re-enabled if step b) cleared the condition via a write FN register.

The net result of steps c) and d) is to clear the interrupt request logic thus allowing another interrupt to occur when another condition comes true. This technique will work even if the condition came true while in the service routine.

The routines that initiate DMA and AP-120B processor action will have to enable the appropriate interrupts AFTER starting the DMA or the AP-120B processor. This is now possible since the interrupt enables in the CTL register can now be safely modified while the DMA is running as long as a zero is written into HDMA START. Again, IHENB can be left on if the interrupt service routine uses a write to the FN registers to clear the CTL05 condition. If the service routine does not clear the CTL05 condition then IHENB can be set any time following the first write FN register command. The start routine must be careful to inhibit all AP-120B interrupts (set PDP-11 processor priority at or above level 4) when modifying the CTL register.

#### 4.5.3.2 Addressable I/O Devices

The AP-120B I/O STRUCTURE may perform transfer operations with up to 256 I/O DEVICES addressable through use of the eight bit DEVICE ADDRESS REGISTER (DA). The first 24 addresses are dedicated to HOST- INTERFACE DEVICES (DA 0-4,6) to WRITABLE TABLE MEMORY-TMRAM (DA 5); MEMORY BANK SELECT (30,31), first IOP16, 10 to 14, and second IOP 16, 20 to 24.

\* TMRAM

With respect to writing operations, TMRAM is essentially an I/O DEVICE whose address is 5. To WRITE into TMRAM, one must set DA to 5 at least one cycle before outputting data to TMRAM. For example, in order to WRITE the current FA into TMRAM location 100(8), the following program would be specified:

Assume S-PAD REGISTER 6 equals "100(octal)"

| ASSEMBLER FORMAT                | (Meaning)                                                  |
|---------------------------------|------------------------------------------------------------|
| o                               |                                                            |
| o                               |                                                            |
| DPX(0)<FA                       | Save FA in DPX(0)                                          |
| LDDA; DB=5                      | (Select TMRAM as I/O DEVICE(DA))                           |
| MOV 6,6; SETTMA; DB=DPX(0); OUT | (Set TMA to"100(octal), WRITE DPX(0) into TMRM 100(octal)) |
| o                               |                                                            |
| o                               |                                                            |
| o                               |                                                            |

Because of the TM WRITE operation, two cycles later the out-put of TMREG is undefined. Three cycles later (assuming no change in TMA) the contents written into TMRAM will be available as the TM OUTPUT (TM).

\* Other Addressable I/O Devices

A variety of I/O DEVICES may be added to the AP-120B, depending on user application and HOST-CPU to AP-120B CONFIGURATION.

#### 4.5.4 Programming Example

The example given in this section shows how the AP-120B .BOOTSTRAP program is loaded and used along with the HOST-DMA to store a given program into AP-120B PROGRAM SOURCE MEMORY. The example nicely illustrates the various functions of the AP-120B I/O structure.

#### AP-120B BOOTSTRAP

Essentially, the AP-120B BOOTSTRAP is loaded and executed in the following manner (See Table 4-2):

- (1) The three-word BOOTSTRAP program is loaded into the AP-120B by the HOST-CPU using AP-120B PANEL operations.
- (2) The BOOTSTRAP is started by HOST-CPU --again using the PANEL.
- (3) With the AP-120B BOOTSTRAP running, a HOST-DMA is initiated. The HOST-DMA transfers 16-bit program quarter-words to the FORMATTER (FMT). FMT assembles them into 32-bit half-words and signals the AP-120B when it is ready. The AP-120B BOOTSTRAP then stores the half-word into the appropriate portion of the PROGRAM SOURCE MEMORY.
- (4) The process continues. When the HOST-DMA is finished, the HOST-CPU is interrupted. (If interrupts are not used the HOST-CPU may test the CTL REGISTER-bit 15 to determine when the DMA is done.)
- (5) The AP-120B is then reset (HOST ABORT function). The AP-120-B may then be started again by the HOST-CPU at the starting address of the newly loaded program.

#### BOOT-LOADS INSTRUCTION HALF-WORDS FROM THE HOST DMA INTO PROGRAM MEMORY

| \$LOC 0 |        |       |            |                                         |
|---------|--------|-------|------------|-----------------------------------------|
| 000000  | 000003 | BOOT: | LDDA; DB=4 | "SET TO HOST DMA FORMATTER              |
|         | 107000 |       |            |                                         |
|         | 002000 |       |            |                                         |
|         | 000004 |       |            |                                         |
| 000001  | 011363 | LOOP: | SPININ;    | "SPIN (WAIT) UNTIL A WORD IS READY      |
|         | 145000 |       | DB=INBS;   | "PUT THE WORD ONTO DB                   |
|         | 001000 |       | LPSLT      | "STORE IT INTO THE LEFT HALF OF PS(TMA) |
|         | 000000 |       |            |                                         |

|        |                                          |                                                              |                                                                                   |
|--------|------------------------------------------|--------------------------------------------------------------|-----------------------------------------------------------------------------------|
| 000002 | 011367<br>145117<br>001000               | SPININ;<br>DB=INBS;<br>LPSRT;                                | "WAIT FOR THE DMA<br>"GET IT IN<br>"STORE IT INTO THE<br>RIGHT HALF OF PS(TMA)    |
|        | 000000                                   | INCTMA;                                                      | "INCREMENT THE<br>POINTER (TMA)                                                   |
|        |                                          | BR LOOP                                                      | "BRANCH BACK FOR MORE                                                             |
|        |                                          | "                                                            |                                                                                   |
|        |                                          | "                                                            |                                                                                   |
|        |                                          | "                                                            |                                                                                   |
|        |                                          | "                                                            |                                                                                   |
|        |                                          | "CALLER-CALL AN AP-120B SUBROUTINE FROM THE HOST<br>COMPUTER |                                                                                   |
| 000003 | 000003<br>174000<br>040004<br>000000     | CALLER: DPX<ZERO;<br>REFR                                    | "GET ZERO INTO DPX<br>"MEMORY REFRESH SYNCH                                       |
| 000004 | 000001<br>122000<br>000400<br>012400     | FMUL DPX,DPX;<br>FADD DPX,DPX                                | "CLEAR THE MULTIPLIER<br>"AND THE ADDER                                           |
| 000005 | 000001<br>122000<br>000400<br>012400     | FMUL DPX,DPX;<br>FADD DPX,DPX                                | "PUSH THE PIPELINES                                                               |
| 000006 | 011027<br>106000<br><br>000400<br>012400 | FMUL DPX,DPX;<br>LDAPS;<br><br>DB=ZERO<br>JSRT               | "AND AGAIN FOR FMUL<br>"CLEAR THE STATUS<br>REGISTER<br><br>"GO DO THE SUBROUTINE |
| 000007 | 000003<br><br>170000<br>000000<br>000000 | HALT                                                         | "HALT ON RETURN FROM<br>THE SUBROUTINE                                            |
| 000010 | 000000<br>000000<br>000000<br>000000     | NOP                                                          |                                                                                   |
|        |                                          | \$END                                                        |                                                                                   |

Table 4-2 LOADING AND EXECUTING AP-120B BOOTSTRAP

| OPERATION                                              | HOST-CPU                                                  | COMMENTS                                                                                                                                    |
|--------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Load AP-120B BOOTSTRAP via PANEL (See Note)            | (1) 0 ➤ SWR<br>1003(octal) ➤ FN                           | Deposit 0 into TMA (TMA is the pointer for depositing into PS)                                                                              |
| (BOOTSTRAP is loaded into PS locations 0, 1, and 2)    | (2) (Bootstrap word bits 0-15) ➤ SWR<br>1010(octal) ➤ FN  | (Deposit first quartile of bootstrap word into QUARTER ZERO of PS(TMA))                                                                     |
|                                                        | (3) (Bootstrap word bits 16-31) ➤ SWR<br>1030(octal) ➤ FN | (Deposit second quartile of bootstrap word into QUARTER ONE of PS(TMA))                                                                     |
|                                                        | (4) (Bootstrap word bits 32-47) ➤ SWR<br>1050(octal) ➤ FN | (Deposit third quartile of bootstrap word into QUARTER TWO of PS(TMA))                                                                      |
|                                                        | (5) (Bootstrap word bits 32-47) ➤ SWR<br>1370(octal) ➤ FN | (Deposit fourth quartile of bootstrap word into QUARTER THREE of (PS)TMA. TMA is then incremented by "1" to point to the next PS location.) |
| {Repeat steps 2-5 for }<br>{remaining bootstrap words} |                                                           |                                                                                                                                             |

EXECUTING THE BOOTSTRAP

| OPERATION                                                                                                                                                                                                                                                       | HOST-CPU                                                            | AP-120B                                                                            | COMMENTS                                                                                                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Indicate to AP-120B where to start loading selected program. (Assume 200 is PS address where program is to be loaded)                                                                                                                                           | 200(OCTAL) → SWR<br>1003(octal) → FN                                |                                                                                    | HOST-CPU deposits 200 into TMA (via panel)                                                                                                                                                               |
| Start AP-120B BOOTSTRAP PROGRAM                                                                                                                                                                                                                                 | 0 SWR<br>1000(octal) → FN = Dep PSA<br>20000(octal) → FN = Continue | BOOTSTRAP is started-AP is waiting for first program half-words to be transferred. | Starts program at PS location 0 (BOOTSTRAP) via Panel Continue                                                                                                                                           |
| Start PARTIAL-DMA from HOST MEMORY to HOST-INTERFACE FORMATTER (FMT) (assume program to be transferred to AP-120B is now stored in HOST MEMORY location 1000 and that the program to be loaded is 200(octal) AP program words (1000(octal) 16-bit host words).) | 1000(octal) → HMA<br>1000(octal) → WC<br>4201(octal) → CTL          | AP is waiting                                                                      | Set HOST-DMA address to 1000<br>Set WORD COUNT to 1000 (assume 16-bit HOST-word)<br>(Initialize HOST-DMA to FMT in consecutive cycle mode. When done, send interrupt to HOST-CPU when HOST-DMA is done.) |

EXECUTING THE BOOTSTRAP (CONTINUED)

| OPERATION                                                                                                                                                                                                                                                                                                                                                                                               | HOST-CPU                                                              | AP-120B                                                                                                                                   | COMMENTS                                                                                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>HOST-CPU is transferring 16-bit words to FMT, via DMA. FMT is assembling them into 32-bit words and when ready, signals AP-120B BOOTSTRAP program. BOOTSTRAP then loads formatted word into PS at location TMA in the following manner:</p> <ul style="list-style-type: none"> <li>* First 32-bit word goes into PS - left half,</li> <li>* Second 32-bit word goes into PS - right half.</li> </ul> | <p>HOST-CPU is transferring 16-bit words from HOST-MEMORY to FMT.</p> | <p>AP BOOTSTRAP<br/>LDDA; DB=4</p> <p>LOOP: SPININ,<br/>DB=INBS; LPSLT<br/>SPININ; DB=INBS; PS(LH)TMA.<br/>LPSRT; INCTMA;<br/>BR LOOP</p> | <p>Set DEVICE ADDRESS to (FMT)</p> <p>Spin until first half word is ready, then store it into PS(LH)TMA.</p> <p>Spin until second half word is ready, then store it into PS(RH)TMA; then increment TMA and branch back to LOOP.</p> |

When HOST-DMA is completed, DMA INACTIVE INTERRUPT will be sent to HOST-CPU. HOST-CPU will respond to the interrupt by stopping the AP-120B BOOTSTRAP as follows:

RESET AP-120B

|                                                     |                                                          |
|-----------------------------------------------------|----------------------------------------------------------|
| Set TMA to desired AP-<br>120B starting address     | 200(octal) → SWR<br>1003(octal) → FN                     |
| Start newly loaded<br>program running in<br>AP-120B | 3(octal) → SWR<br>1000 (octal) → FN<br>20000(octal) → FN |

|                                                   |
|---------------------------------------------------|
| Reset AP-120B using I/O reset<br>command          |
| Deposit starting location<br>200 into TMA         |
| Continue at AP-120B<br>PROGRAM SOURCE location 3  |
| 4 using caller to clear<br>pipelines and APSTATUS |

NOTE

The specific OP-CODES used by the HOST-CPU  
depends on the type of HOST-CPU used.

#### **4.6 DATA PAD SUMMARY**

Discussion of the DATA PAD GROUP (DP) will be presented in the following manner:

1. General Description and Theory of Operation
2. DP Group Operations
3. DP Addressing
4. Programming Examples

#### 4.6.1 General Description, Theory of Operation

DATA PAD (DP) is a block consisting of two high-speed accumulator files, termed DATA PAD X (DPX) and Data PAD Y (DPY), respectively (See Figure 4-4).

Each file contains thirty-two, 38-bit accumulators. Both files share a common address pointer, termed the DATA PAD ADDRESS REGISTER (DPA). DPA, along with one of four BIASED index field XR=X Read Index, YR=Y Read, XW=X Write, YW=Y Write, is used to determine the EFFECTIVE ADDRESS (EFA) for any given DP READ or WRITE operation (See Section 4.6.4 for more details on DP addressing).

Data to be stored into DATA PAD may come from the currently available FLOATING ADDER result (FA), the currently available FLOATING MULTIPLIER result (FM), or one of eight possible sources enabled onto the DATA PAD BUS.

Data READ from DATA PAD may go to the FLOATING MULTIPLIER OPERAND REGISTERS (M1, M2), the FLOATING ADDER OPERAND REGISTERS (A1, A2), the MAIN DATA MEMORY INPUT REGISTER (MI), or onto the DATA PAD BUS (DB).

The DATA PAD REGISTERS behave like true accumulators in that the contents of one register can be read out and written into in the same instruction without conflict. The WRITE takes place at the very end of the instruction cycle so that the old contents can be read out for use during the cycle and the updated contents will be available during the immediately succeeding instruction cycle.



Figure 4-4 Data Pad

#### 4.6.2 Data Pad Operations

Operations within the Data PAD GROUP may be classed in the following groups:

- \* DPX or DPY explicit WRITE operations
- \* DPX or DPY implicit READ operations
- \* DPBS source enabling operations

##### 4.6.2.1 DPX or DPY Explicit WRITE Operations

One each DPX and DPY location may be written during a given instruction cycle, using either the DPX or DPY fields and either XW or YW fields of the instruction word.

| MNEMONIC    | INSTRUCTION WORD<br>FIELD(S) USED | OCTAL<br>VALUE | OPERATION                                                   |
|-------------|-----------------------------------|----------------|-------------------------------------------------------------|
| DPX(idx)<DB | DPX<br>XW                         | 1<br>0-7       | Stores current DB<br>into specified DATA<br>PAD X location. |
| DPX(idx)<FA | DPX<br>XW                         | 2<br>0-7       | Stores current FA into<br>specified DATA PAD X<br>location. |
| DPX(idx)<FM | DPX<br>XW                         | 3<br>0-7       | Stores current FM into<br>specified DATA PAD X<br>location. |
| DPY(idx)<DB | DPY<br>YW                         | 1<br>0-7       | Stores current DB<br>into specified DATA<br>PAD Y location. |
| DPY(idx)<FA | DPY<br>YW                         | 2<br>0-7       | Stores current FA into<br>specified DATA PAD Y<br>location. |
| DPY(idx)<FM | DPY<br>YW                         | 3<br>0-7       | Stores current FM into<br>specified DATA PAD Y<br>location. |

##### NOTE

If VALUE field is used in the same disabled.  
The DPY location will be referenced by the  
XW field, instead.

#### 4.6.2.2 DPX,DPY Implicit Read Operations

One each DPX and DPY location may be read during a given instruction cycle. Whenever a DATA PAD X or Y location is referenced as part of an operation in this or another group in the current instruction word, the XR and YR fields of this group are referenced. Example:

```
FADD DPY(1),DPX(2)
```

The appropriate index fields in the DP group will be set when specifying the above operation. The YR field will be set to "5(octal)", and the XR field set to "6(octal)", since the fields are BIASED by four. The index is relative to the current contents of the DATA PAD ADDRESS REGISTER (DPA).

A complete summary of the DATA PAD addressing scheme is given in the following section.

#### 4.6.2.3 DPBS Enabling Operations

One of eight sources may be enabled onto DPBS during a given instruction cycle, using the DPBS field of the current instruction word. Specifying a DPBS source has an immediate effect, that is, the DPBS source enabled during a given instruction will be the data currently used in all DPBS-related operations during the same instruction cycle.

Note that only one source may be enabled onto DPBS during any given instruction and that source will remain as DPBS only during this instruction.

| MNEMONIC  | INSTRUCTION WORD FIELD(S) USED | OCTAL VALUE | OPERATION                                                                                                         |
|-----------|--------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| DB = ZERO | DPBS                           | 0           | Floating Point ZERO (0.0) is enabled as DPBS for the current instruction. This is the default selection for DPBS. |
| DB = INBS | DPBS                           | 1           | The data currently enabled onto INBS is enabled as DPBS for the current instruction.                              |

|                          |               |          |                                                                                                                                                                           |
|--------------------------|---------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DB = value<br>(See Note) | DPBS<br>VALUE | 2        | The contents of the value field are enabled as DPBS for the current instruction. (Partial word transfer, see instruction summary (DB = VALUE) for a detailed explanation. |
| DB = DPX(idx)            | DPBS<br>XR    | 3<br>0-7 | The contents of the currently specified DATA PAD X location is enabled as DPBS for the current instruction.                                                               |
| DB = DPY(idx)            | DPBS<br>YR    | 4<br>0-7 | The contents of the currently specified DATA PAD Y location is enabled as DPBS for the current instruction.                                                               |
| DB = MD                  | DPBS          | 5        | The current contents of the MAIN DATA OUTPUT REGISTER (MDREG) are enabled as DPBS for the current instruction.                                                            |
| DB = SPFN                | DPBS          | 6        | The current SPFN is enabled as DPBS for the current instruction. (Partial-word transfer, see illustration summary (DB = SPFN) for a detailed explanation).                |
| DB = TM                  | DPBS          | 7        | The current contents of the TABLE MEMORY OUTPUT REGISTER (TMREG) are Enabled as DPBS for the current instruction.                                                         |

\*

NOTE

Value is an integer from decimal -32768 to 32767  
or 0 to 177777 in octal or a label (constant).

In addition to the eight sources available in the DPBS field, three other sources (PS Left Half, PS Floating and PNLBS) can be enabled onto DPBS via operations in the SPEC group. These operations (e.g. RPSL, RPSF, SWDB) take precedence over the DPBS field.

#### 4.6.3 Data Pad Addressing

The effective address of a location in DATA PAD to be read or written is determined by the following combination of elements:

- \* The current contents of the DATA PAD ADDRESS REGISTER (DPA), plus
- \* The value contained in the appropriate INDEX field (XW, XR, YW, YR) of the current instruction word, minus
- \* The BIAS (4(octal))

The INDEX field value is contained within the current instruction word.

The DPA contents may be changed by use of the following instructions effective one cycle after the appropriate instruction is executed.

| INSTRUCTION | MEANING                   |
|-------------|---------------------------|
| INCDPA      | Add "1" to DPA            |
| DEC DPA     | Subtract "1" from DPA     |
| SETDPA      | Set current SPFN into DPA |
| LDDPA       | Set current DPBS into DPA |

DPA is circular in that incrementing DPA currently containing the maximum address (37octal) will produce a DPA of 0(octal) as of the next instruction cycle. Accordingly, decrementing a DPA of 0(octal) will produce a DPA of 37 (octal) as of the next instruction cycle. This circular effect applies equally to indexing. Example:

```
if DPA = 37(octal); then:  
    DPX(2) would indicate DPX location 1(octal).  
  
if DPA = 0(octal); then  
    DPX(-2) would indicate DPX location 36(octal).
```

Note that instructions from LDREG field (LDDPA, LDTMA, MA) cause SETDPA, SETTMA, and SETMA to load from DPBS instead of SPFN.

| Examples  | Meaning                                                                                                  |
|-----------|----------------------------------------------------------------------------------------------------------|
| DB<DPX(1) | Place the contents of the DPX location pointed to by the current contents of the DPA plus one onto DPBS. |

When specified in the above fashion, the ASSEMBLER will place a "5(octal)" into the XR field and a "3(octal)" into the DPBS field of the instruction word. The "5" in the XR field indicates that the DPX READ operation is "5" BIAS locations relative to current DPA. BIAS is "4(octal)" for the DATA PAD INDEX FIELDS.

Accordingly, eight locations are available for any given DPX or DPY READ/WRITE operation, from +3 to -4 locations relative to the current DPA.

| APPARENT VALUE<br>(VALUE CONTAINED IN INDEX FIELD) | TRUE VALUE<br>RELATIVE TO DPA | MEANING          |
|----------------------------------------------------|-------------------------------|------------------|
| 7                                                  | +3                            | DPX or Y(DPA) +3 |
| 6                                                  | 2                             | DPX or Y(DPA) +2 |
| 5                                                  | 1                             | DPX or Y(DPA) +1 |
| 4                                                  | 0                             | DPX or Y(DPA)    |
| 3                                                  | -1                            | DPX or Y(DPA) -1 |
| 2                                                  | -2                            | DPX or Y(DPA) -2 |
| 1                                                  | -3                            | DPX or Y(DPA) -3 |
| 0                                                  | -4                            | DPX or Y(DPA) -4 |

Of course, the programmer need only indicate the desired DATA PAD location in the following manner:

|          |          |
|----------|----------|
| DPX (+3) | DPY (+3) |
| DPX (+2) | DPY (+2) |
| DPX (+1) | DPY (+1) |
| DPX (0)  | DPY (0)  |
| DPX (-1) | DPY (-1) |
| DPX (-2) | DPY (-2) |
| DPX (-3) | DPY (-3) |
| DPX (-4) | DPY (-4) |

#### 4.6.4 Programming Examples

Since four separate displacement fields (XW, XR, YW, YR) are provided within the instruction word, four separate locations in DATA PAD may be used in a given instruction. Example:

Assume DPA = 24(octal):

```
FADD DPX(3),MD; FMUL TM,DPY(-2); DPX(-3)<FA; DPY(1)<FM
```

The above operation would:

- \* Use the contents of DPX location 27 in the FADDR operation,
- \* Use the contents of DPY location 22 in the FMULR operation,
- \* Write the currently available FA into DPX location 21, and
- \* Write the currently available FM into DPY location 23.

Note that only one DPX location may be written, only one DPY location may be written, only one DPX location may be read, and only one DPY location may be read during the same instruction cycle.

#### Using the DPBS to Write Into DATA PAD

Again, one may write into DATA PAD from FA, FM or from one of eight possible sources available on the DATA PAD Bus (DB).

Note, that only ONE source may be enabled onto DB for any given instruction. Example:

LEGAL

1. DPX<DB; DPY<DB; DB = MD      Meaning: Write MD into both DPX and DPY via DB.
2. DPX<FA; DPY<DB; DB = TM      Meaning: Write current FA to DPX, write current TM to DPY via DPBS.

ILLEGAL

3. DPX<DB; DB = MD; DPY<DB; DB = TM      Again, only ONE source may be enabled onto DB per instruction.

\* DB Shorthand Notation

The assembler will automatically enable a source onto DB even though the programmer has not explicitly written the instruction. In other words, the above examples may be written as follows:

| Programmer Writes: | Assembler Inserts:                  |
|--------------------|-------------------------------------|
| 1. DPX<MD;DPY<MD   | DB = MD                             |
| 2. DPX<FA; DPY<TM  | DB = TM                             |
| 3. DPX<MD; DPY<TM  | Error: Assembler will flag as such. |

As shown by the above examples, when using the shorthand notation, the programmer must bear in mind that he may only use one source as DPBS in a given instruction cycle.

#### 4.7 MEMORY GROUP

The operations available within the MEMORY GROUP may be classed into the following functional groups:

- \* MAIN DATA MEMORY (MD) accessing operations
  - MAIN DATA MEMORY ADDRESS REGISTER (MA) modification
- \* DATA PAD ADDRESS REGISTER (DPA) modification
- \* TABLE MEMORY (TM) accessing operations
  - TABLE MEMORY ADDRESS (TMA) modification

Accordingly, this summary will be presented in the following manner:

1. MAIN DATA MEMORY (MI and MA fields)
  - \* General description
  - \* Addressing and memory cycle initialization
  - \* MD read and write operations
2. DATA PAD ADDRESS modification (DPA field)
3. TABLE MEMORY (TMA field)
  - \* General description
  - \* Addressing
  - \* Read and write operations

#### 4.7.1 Main Data Memory (MD)

##### 4.7.1.1 General Description

MAIN DATA (MD) is the main storage file, within the AP-120B for 41-bit data words. MD is a monolithic storage file available in 8K, 16K, 32K and 64K modules - 64K per page - up to a million words. MAIN DATA has two speed ranges: 333 or 167 ns if the interleaving capability is utilized and 500 or 333 ns if non-interleaving locations are accessed.

The MAIN DATA BLOCK (Figure 4-5) consists of the following component parts:

MEMORY INPUT REGISTER (MI)  
MAIN DATA STORAGE FIELD (MD)  
MAIN DATA MEMORY OUTPUT REGISTER (MDREG)  
MAIN DATA MEMORY ADDRESS REGISTER (MA)



Figure 4-5 MAIN DATA BLOCK

MAIN DATA may be written from the FADDR output (FA), the FMULR output (FM), or from one of several sources enabled onto the DATA PAD BUS (DB). The MAIN DATA output, termed MD, is available as an input directly to the FADDR A2 operand register (A2), the FMULR M2 operand register (M2), or may be enabled onto the DB.

Additionally, MD may be accessed via DIRECT MEMORY ACCESS (DMA) from the Host and other I/O interfaces.

The format of a typical MD data word is presented below:



#### 4.7.1.2 Addressing and Memory Cycle Initialization

The 16-bit MEMORY ADDRESS REGISTER (MA) is the pointer indicating which MD location is read or written during a given operation. Additionally, an MD memory cycle is initiated each time the contents of MA are altered by use of an INCMA, DECMA, SETMA or LDMA instruction.

| MA MODIFICATION<br>OP-CODES | EFFECT                                                            |
|-----------------------------|-------------------------------------------------------------------|
| INCMA                       | Increment MA by "1"; initiate an MD memory cycle.                 |
| DECMA                       | Decrement MA by "1"; initiate an MD memory cycle.                 |
| SETMA                       | Set MA from current SPFN (See Note); initiate an MD memory cycle. |
| LDMA                        | Set MA from current DB; initiate an MD memory cycle.              |

If an MI Op-Code is concurrently specified with an appropriate MA modification Op-Code, then an MD MEMORY WRITE CYCLE is initiated, using the new contents of MA to indicate the MD location to be written. If an MA modification instruction is specified without a concurrent MI Op-Code, then an MD MEMORY READ CYCLE is initiated using the new contents of MA to indicate the MD location to be read. Use of an MI Op-Code WITHOUT a concurrent MA modification op-code results in a NOP.

#### NOTE

If an Op-Code from the LDREG field (I/O) is used concurrently, then SETMA will set MA from current DB, not SPFN.

#### EXAMPLES:

##### INITIATING AN MD WRITE CYCLE

##### (MEANING)

|                        |                                                                                                     |
|------------------------|-----------------------------------------------------------------------------------------------------|
| MOV 5,5; SETMA; MA<FA  | (Set MA to current SPFN, write current FA into MD location pointed to by the new contents of MA).   |
| LDMA; DB=DPX(0); MI<FM | (Set MA to current DPX(0), write current FM into MD location pointed to by the new contents of MA). |
| INCMA; MI<DB           | (Increment MA by "1", write current DB into MD location pointed to by new contents of MA).          |

##### INITIATING AN MD READ CYCLE

|                |                                                                               |
|----------------|-------------------------------------------------------------------------------|
| MOV 5,5; SETMA | (Set MA to current SPFN, read MD location pointed to by new contents of MA).  |
| DECMA          | (Decrement MA by "1", read MD location pointed to by the new contents of MA). |

Note, again, that an MA modification Op-Code executed WITH a concurrent MI Op-Code generates an MD WRITE CYCLE. An MA modification Op-Code WITHOUT an MI Op-Code generates an MD READ CYCLE.

#### 4.7.1.3 Interleave

STANDARD speed MD MEMORY references the same bank of memory every three AP cycles (500 ns). In order to facilitate faster intervals between successive memory reference instructions, the AP 120B MAIN DATA MEMORY is divided into banks containing 4K or 16K words each. These banks are interleaved in pairs with odd number memory locations contained in one bank of the pair and even memory locations in the other bank of the pair. Memory reference instructions are allowable every other instruction cycle (333 ns) as long as INTERLEAVE (the sequential reference to different MD MEMORY BANKS) is not violated. Any attempt to reference the same bank of memory (NON-INTERLEAVING) before the minimum time constraint will cause the AP-120B hardware to generate a "SPIN" operation - effectively suspending all ongoing AP-120B program execution one cycle at a time until the memory is no longer busy and can execute the memory reference instruction which prompted the "SPIN" condition. This feature allows AP-120B programs to be written without concern for memory interleaving. But for maximum execution speed the interleaving feature should be used. Thus, for optimum coding of memory accesses, the programmer should be aware of the order in which he accesses memory banks.

For FAST MD MEMORY, memory reference may be made to different banks (INTERLEAVED) every AP cycle (167 ns) and to the same bank (NON-INTERLEAVED) every other AP cycle (333 ns.)

Interleave examples: locations 3 and 4 are interleaved by the odd-even interleave. Locations decimal 8190 and 8192 are interleaved because they reference different bank pairs (4-K bank size). For the 16-K bank size, the bank-pair size is 32K. Thus, for example, locations decimal 32766 and 32768 are in different bank pairs.

#### NOTE

For the 32K and 64K memory modules, the bank size is increased to 16K.

**EXAMPLE:**

| MEMORY<br>ADDRESS<br>SEQUENCE<br>(OCTAL) | MEMORY<br>BANK<br>SEQUENCE | STANDARD MEMORY<br>REFERENCE<br>TIMING        | FAST MEMORY<br>REFERENCE<br>TIMING          |
|------------------------------------------|----------------------------|-----------------------------------------------|---------------------------------------------|
| 101                                      | 1                          |                                               |                                             |
| 102                                      | 0                          | Every two<br>AP cycles<br>(Interleaved)       | Every<br>AP cycle<br>(Interleaved)          |
| 103                                      | 1                          |                                               |                                             |
| 104                                      | 0                          |                                               |                                             |
|                                          |                            |                                               |                                             |
| 100                                      | 0                          |                                               |                                             |
| 102                                      | 0                          | Every three<br>AP cycles<br>(Non-interleaved) | Every two<br>AP cycles<br>(Non-interleaved) |
| 104                                      | 0                          |                                               |                                             |
| 106                                      | 0                          |                                               |                                             |
|                                          |                            |                                               |                                             |
| 234                                      | 0                          |                                               |                                             |
| 10374                                    | 2                          | Every two<br>AP cycles<br>(Interleaved)       | Every<br>AP cycle<br>(Interleaved)          |
| 233                                      | 1                          |                                               |                                             |
| 10376                                    | 2                          |                                               |                                             |

#### 4.7.1.4 MD Read and Write Operations

Three AP clock cycles after an MD memory read cycle has been initiated, the data from the selected memory location becomes available as MD to the DB, A2 operand register, and M2 operand register.

| STANDARD MEMORY |                                | FAST MEMORY |                                |
|-----------------|--------------------------------|-------------|--------------------------------|
| AP<br>CODE      | LOCATION<br>AVAILABLE<br>AS MD | AP<br>CODE  | LOCATION<br>AVAILABLE<br>AS MD |
| 1. INCMA        | -----                          | 1. INCMA    | -----                          |
| 2. NOP          | -----                          | 2. INCMA    | -----                          |
| 3. INCMA        | -----                          | 3. INCMA    | -----                          |
| 4. NOP          | MD101                          | 4. NOP      | MD101                          |
| 5. INCMA        | MD101                          | 5. NOP      | MD102                          |
| 6. NOP          | MD102                          | 6. NOP      | MD103                          |
| 7. NOP          | MD102                          | 7. NOP      | MD103                          |
| 8. NOP          | MD103                          | 8. NOP      | MD103                          |

Once an MD MEMORY WRITE CYCLE is initiated, the data specified by the concurrent MI Op-Code is loaded into the MEMORY INPUT REGISTER (MI) and written into MD at the location pointed to by the MA register.

Data may be written INTERLEAVED every other AP cycle and NON-INTERLEAVED every three AP cycles for standard memory and INTERLEAVED every cycle and NON-INTERLEAVED every other cycle for fast MD.

Note that the example for standard memory with NOP's between the INCMA's will execute correctly on Fast Memory; however, the reverse is not true. Both examples will execute correctly with the INCMA's replaced by SETMA's even if the memory accesses are NON-INTERLEAVED. NON-INTERLEAVED accesses merely result in a slowdown of instruction execution; they do not change the timing relationships between instructions. Writing MD leaves the contents of MDREG unchanged. This allows a memory Read cycle to be initiated and the data to be used later irrespective of intervening MD write cycles.

#### 4.7.1.5 AP-120B DMA and Refresh Time Penalties

##### 1. REFRESH



##### FAST MD

- Refresh costs three clocks = 500ns if AP running interleaved cycles (worst case).
- Refresh costs only two clocks if non-interleaved cycles in AP program.

##### STANDARD MD



c) Refresh costs four clocks = 667ns if AP running interleaved cycles (worst case).

d) Refresh costs only three clocks if AP program running non-interleaved cycles.

2. DMA interference (assuming AP running interleaved cycles).

Time to be added to AP execution per DMA memory cycle:

Fast MD              Std MD

a) Host interface DMA interference:  
DMA address in separate bank-pair  
from AP accesses              1 clock              2 clocks  
Same bank-pair              2 clocks              3 clocks

b) Second DMA channel (IOP,PIOP):  
Separate bank-pair              2 clocks              3 clocks  
Same bank-pair              2 1/2 clocks              3 1/2 clocks

Subtract one clock if AP running non-interleaved cycles in one bank. One clock = 167ns

#### 4.7.1.6 Programming Examples

##### \* Read Example

Load a vector  $A_x, i = 0, 2$  stored in Memory Locations 101, 102, 103 into DPX locations 10, 11, 12. We will assume that MA was set to 100 and DPA was set to 10 before we started.

|    |               |                                                                    |
|----|---------------|--------------------------------------------------------------------|
| 1. | INCMA         | "Fetch $A_0$ from Memory                                           |
| 2. | ---           |                                                                    |
| 3. | INCMA         | "Fetch $A_1$ from Memory                                           |
| 4. | DPX<MD; INCDA | "Store $A_0$ into DPX location 10<br>" and bump DPA pointer to 11. |
| 5. | INCMA;        | "Fetch $A_2$ from Memory                                           |
| 6. | DPX<MD; INCDA | "Store $A_1$ into DPX location 11<br>" and bump DPA pointer to 12. |
| 7. | ---           |                                                                    |
| 8. | DPX<MD        | "Store $A_2$ into DPX location 12.                                 |

Below is a chart of the above transfer, showing the state of each component after each instruction.

| Cycle | Memory |                | Data Pad |                   |                   |                   |
|-------|--------|----------------|----------|-------------------|-------------------|-------------------|
|       | MA     | MD             | DPA      | DPX <sub>10</sub> | DPX <sub>11</sub> | DPX <sub>12</sub> |
| 1.    | 101    | ---            | 10       | ---               | ---               | ---               |
| 2.    | 101    | ---            | 10       | ---               | ---               | ---               |
| 3.    | 102    | ---            | 10       | ---               | ---               | ---               |
| 4.    | 102    | A <sub>0</sub> | 10       | A <sub>0</sub>    | ---               | ---               |
| 5.    | 103    | A <sub>0</sub> | 11       | A <sub>0</sub>    | ---               | ---               |
| 6.    | 103    | A <sub>0</sub> | 11       | A <sub>0</sub>    | A <sub>1</sub>    | ---               |
| 7.    | 103    | A <sub>1</sub> | 12       | A <sub>0</sub>    | A <sub>1</sub>    | ---               |
| 8.    | 103    | A <sub>1</sub> | 12       | A <sub>0</sub>    | A <sub>1</sub>    | A <sub>2</sub>    |
|       |        | 2              |          |                   |                   |                   |

#### \* Write Example

Square the elements of a vector Ax, i = 0, 1, 2, in DPX locations 10, 11, 12 and store the results into Data Memory locations 101, 102, 103. We will assume that MA was set to 100 and DPA was set to 10 before we started.

- |                           |                                                                   |
|---------------------------|-------------------------------------------------------------------|
| 1. FMUL DPX, DPX; INC DPA | "Square A <sub>0</sub> , bump DPA pointer<br>" to 11.             |
| 2. FMUL                   | "Push down the multiplier<br>" pipeline.                          |
| 3. FMUL DPX, DPX; INC DPA | "Square A <sub>1</sub> , bump DPA pointer<br>" to 12.             |
| 4. FMUL; MI<FM; INC MA    | "Write A <sub>0</sub> <sup>2</sup> into memory location<br>" 101. |

Below is a chart of this computation:

| Cycle | DPA | Multiplier          |          | Memory |         |
|-------|-----|---------------------|----------|--------|---------|
|       |     | M1,M2<br>$A_0, A_0$ | FM<br>-- | MA     | MI      |
| 1.    | 10  |                     |          | --     | --      |
| 2.    | 11  | ---                 | --       | --     | --      |
| 3.    | 11  | $A_1, A_1$          | --       | --     | --      |
| 4.    | 12  | ---                 | $A_0^2$  | 101    | $A_0^2$ |
| 5.    | 12  | $A_2, A_2$          | --       | 101    | $A_0^2$ |
| 6.    | 12  | ---                 | $A_1^2$  | 102    | $A_1^2$ |
| 7.    | 12  | ---                 | --       | 102    | $A_1^2$ |
| 8.    | 12  | ---                 | $A_2^2$  | 103    | $A_2^2$ |

\* Memory Interleave

Data Memory is divided into 16 banks of 4K words each using MA00-MA02 and MA15 as a memory bank select. (These are the three highest-order bits and the least-significant bit of MA.) Memory references to different banks may be made every 2 AP cycles, while references to the same bank may be made every 3 AP cycles. For some possible memory addressing sequences we have:

| Memory Address Sequence (Octal) | Memory Bank Sequence | Memory Reference Timing |
|---------------------------------|----------------------|-------------------------|
| 101, 102, 103, 104,...          | 1, 0, 1, 0,...       | every 2 AP cycles       |
| 166, 165, 164, 163,...          | 0, 1, 0, 1,...       | every 2 AP cycles       |
| 100, 102, 104, 106,...          | 0, 0, 0, 0,...       | every 3 AP cycles       |
| 233, 10374, 234, 10376,...      | 1, 2, 0, 2,...       | every 2 AP cycles       |

Thus references to successive sequential memory locations may be made every other AP cycle, but references to successive-odd or successive-even locations must be three cycles apart.

## 4.7.2 TABLE MEMORY (TMA)

### 4.7.2.1 General Description

The TABLE MEMORY FILE (TM) is a separate 38-bit wide storage file used to store standard constants and other slowly changing coefficients. Addressing for TM locations is achieved by use of the TABLE MEMORY ADDRESS REGISTER (TMA).

TM is available in two types -- READ ONLY MEMORY (TMROM) and RANDOM ACCESS MEMORY (TMRAM). TMRAM is capable of both being WRITTEN and READ, while TMROM is capable only of being READ. In both types of memory, the contents of the TM location pointed to by the current contents of TMA become available as TM two cycles after an instruction that alters TMA, with one exception; that is--for a TMRAM WRITE operation, the contents of TMREG are undefined two cycles later, and the new contents of the TM location written can become available as TM three cycles later if TMA is not changed.

TABLE MEMORY (Figure 4-6) consists of the following component parts:

1. TABLE MEMORY STORAGE FILE (TM)
2. TABLE MEMORY ADDRESS REGISTER (TMA)
3. TABLE MEMORY OUTPUT REGISTER (TMREG)
4. TABLE MEMORY INPUT REGISTER (TMIREG)



Figure 4-6 Table Memory

Values stored in Table Memory are read by setting the Table Memory Address (TMA) register to the address of the desired Table Memory location. This is done by the instructions:

```
INCTMA    "Increment TMA by 1  
DECTMA    "Decrement TMA by 1  
SETTMA    "Set TMA to the current S-Pad  
#function (SPFN)
```

Each of the above initiates a fetch from the Table Memory Location pointed at by the new contents of TMA. Two AP cycles later the contents of the desired location are available for use. A new location may be fetched every Ap cycle. One instruction must be placed between a TMA address modification instruction and the use of TM contents.

Therefore,

|                 |                                                      |
|-----------------|------------------------------------------------------|
| INCTMA          | "points to TM address X                              |
| INCTMA          | "points to TM address Y                              |
| FMUL TM, MD     | "Multiplies contents of TM address<br>" X with MD    |
| FMUL TM, DPX(0) | Multiplies contents of TM address<br>" Y with DPX(0) |

In TMRAM, data may be written into TM from the DATA PAD BUS (DB), via an I/O instruction. Data may be read from TMRAM or TMROM directly to the FLOATING ADDER A1 OPERAND REGISTER (A1), to the FLOATING MULTIPLIER M1 OPERAND REGISTER (M1), or onto the DATA PAD BUS (DB).

With respect to writing operations, TMRAM is an I/O DEVICE whose address is 5. To write into TMRAM, one must set DA to 5 at least one cycle before outputting data to TMRAM. For example, in order to write the current FA into TMRAM location 100(octal), the following program would be specified:

Assume S-PAD REGISTER 6 equals "100(octal)"

| ASSEMBLER FORMAT            | (Meaning)                                                            |
|-----------------------------|----------------------------------------------------------------------|
| o                           |                                                                      |
| o                           |                                                                      |
| o                           |                                                                      |
| LDDA;DB = 5                 | (Select TMRAM as IODEVICE (DA))                                      |
| MOV 6,6; SETTMA; DB<FA; OUT | (Set TMA to "100(octal)", write<br>current FA into TMRAM 100(Octal)) |
| o                           |                                                                      |
| o                           |                                                                      |
| o                           |                                                                      |

Because the TABLE MEMORY INPUT REGISTER can accept data in 167 ns, it does not have an IORDY flag associated with it. Therefore, the SPNOUT instruction should not be used to load TMRAM. Data placed on DB during the OUT instruction is written into TMRAM at the address contained in TMA following the OUT instruction. Thus, if an OUT instruction also modifies TMA, the data is written at the TMA address specified by that OUT instruction.

**Example:**

| Location Counter | INSTRUCTION            | COMMENTS                                                                                                                      |
|------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 0                | LDDA; DB=5             | " SET DA=5                                                                                                                    |
| 1                | OUT; DB=DPX(0); INCTMA | " Send DPX(0) to TMRAM<br>" at TMA+1                                                                                          |
| 2                | NOP                    | " Other user code<br>" Previous TM output OK<br>" here                                                                        |
| 3                | NOP                    | " TM output invalid<br>" during this instruction                                                                              |
| 4                | FADD TM, DPX(1)        | " Use of TMRAM<br>" Output OK here<br>" User gets value<br>" Written by the OUT<br>" If TMA not changed<br>" At instruction 2 |

It is possible to write TMRAM on every instruction. TMRAM behaves in all other respects exactly as does TABLE MEMORY ROM (TMROM). Different TMRAM locations can be read on every instruction (167 ns cycle) and the output data is available for use during the second following instruction (167 ns access). It is only after TMRAM WRITE that the TMRAM output is invalid during the second following instruction.

#### 4.7.2.2 Addressing

Addressing of appropriate TM locations is achieved by reference to the current contents of the 16-bit TABLE MEMORY ADDRESS (TMA). When used strictly as an address pointer, TMA is capable of addressing 64K of TABLE MEMORY.

However, TMA is alternatively used as both an address pointer and as a quadrant/sine/cosine indicator for constants used in FFT or IFFT operations. This alternate addressing is enabled by the FFT Bit in APSTATUS (Bit 12) and is modified by the IFFT Bit (Bit 11). In this case, certain bits in TMA also perform control functions for referencing and properly preparing the raw constant stored in TM. Given below is a sample FFT-related format of TMA for a 2048 word cosine table (8K max FFT size).



This division of the TMA register into three sections allows the programmer to address a table of real cosine values lying between angles 0 and 90 degrees as if it were a full circle of complex exponential values with the real part in even numbered locations and the imaginary part in odd numbered locations.

TMA quadrant, sine, cosine theory of operation:

The complex exponential function and the sine and cosine functions are related via the following equation;

$$e^{\pm jx} = \cosine(x) \pm j \sin(x)$$

$$\text{EXP}(\pm x) = \cos(x) \pm j \sin(x).$$

Thus, the real part of the complex exponential of plus or minus a positive real number X is the cosine of X and the imaginary part is plus or minus the sine of X. A forward FFT requires complex exponentials of negative arguments  $\text{CEXP}(-X)$ , while an inverse FFT (IFFT) requires complex exponentials of positive arguments,  $\text{CEXP}(X)$ . Thus, the TMA logic is set up so that the normal mode of operation (FFT = "1", IFFT = "0" in APSTATUS) is to produce complex exponentials of minus X. With FFT = "1" and IFFT = "1", the TMA logic produces complex exponentials of plus X. With FFT = "0" and IFFT = "0" or "1", the logic treats TMA as an unmodified 16-bit address.

Complete understanding of the TMA complex exponential addressing requires knowledge of the following trigonometric identities with  $0 \leq x < 90$  degrees.

|                          |                                                                                                   |
|--------------------------|---------------------------------------------------------------------------------------------------|
| $0^{\text{th}}$ quadrant | $\cos(X) = \cos(X)$                                                                               |
|                          | $\sin(X) = \cos(90^{\circ} - X)$                                                                  |
| $1^{\text{st}}$ quadrant | $\cos(X+90^{\circ}) = -\sin(X)$<br>$= -\cos(90^{\circ} - X)$                                      |
|                          | $\sin(X+90^{\circ}) = \cos(X)$                                                                    |
| $2^{\text{nd}}$ quadrant | $\cos(X+180^{\circ}) = -\cos(X)$<br>$\sin(X+180^{\circ}) = -\sin(X)$<br>$= -\cos(90^{\circ} - X)$ |
| $3^{\text{rd}}$ quadrant | $\cos(X+270^{\circ}) = \sin(X)$<br>$= \cos(90^{\circ} - X)$<br>$\sin(X+270^{\circ}) = -\cos(X)$   |

Thus, these eight equations reduce the desired sine and cosine values in any quadrant to cosine values in the 0th quadrant ( $0 \text{ degrees} \leq X < 90 \text{ degrees}$ ) plus the one value  $\cos(90 \text{ degrees}) = 0$  for  $X = 0$  in  $\cos(90 \text{ degrees} - X)$ .

This last value is achieved by inhibiting the output of TM when  $\cos(90 \text{ degrees})$  is desired. Since the equations do require negative values of the cosine and the table contains only positive values, the logic in TMREG contains a two's complement generator that is capable of negating the mantissa of the output of TM, thus producing a negative floating-point result when  $-\cos(X)$  or  $-\cos(90 \text{ degrees} - X)$  is required.

For use with the FFT or IFFT, the table size required is always a power of two since the FFT algorithm works with the power of two number of data points. The FFT requires a full circle of complex exponentials that has the same number of complex values in it as the largest number of data points desired (number of real points for real FFT's, number of complex points for complex FFT's). Since the above equations reduce the full circle of complex exponentials to one quadrant of cosines, we see that the cosine table must contain one-fourth the number of points for the largest desired FFT.

Thus, for the typical case of an 8192-point maximum size FFT, there will be 2048 values of the cosine function in table memory. The values are computed for the angles  $(n \cdot 90^{\circ}) / 2048$  where  $n = 0 \text{ to } 2047$ . Thus each increment in TM address, represents an angle increment of  $90^{\circ} / 2048$ .

Since an angle of 90 degrees corresponds to a table memory address of 2048, the problem of generating the addresses for the angles 90 degrees - X required by the above equations reduces to a question of simply two's complementing the TM address (Bits 04 to 14) portion of the TMA register output and masking the result back to 11 bits.

$$(90^\circ - x) = \frac{2048 - 90^\circ}{2048} - \frac{n \cdot 90^\circ}{2048} = (2048 - n) \cdot \frac{90^\circ}{2048}$$

In 11-bit binary arithmetic,  $(2048 - n)$  is an equivalent definition of the two's complement of  $n$ .

Thus, the hardware logic for the complex exponential generation also provides the ability to steer bits 04 to 14 of the TMA register, onto bits 05 to 15 of the TMA address bus, while placing zeros on bits 00 to 04, and to conditionally two's complement bits 04 to 14 of TMA, when the angle  $(90^\circ - x)$  is required.

Note that the op-code RTMA reads the value on the TMA address bus, while the op-codes in the SPEC OPER field that use TMA (JSRT, JMPT, LPSLT, etc.) use the unaltered 16-bit contents of the TMA register. An FN register breakpoint on TMA also uses the value on the TMA address bus.

Table 4-3 shows the Table Memory CEXP truth table.

Table 4-3 Table Memory CEXP Truth Table

| QUADRANT |   | SIN/COS | FFT | IFFT | TM ADDRESS   | TM OUTPUT |
|----------|---|---------|-----|------|--------------|-----------|
|          |   |         | 0   | 0/1  | Full 16 bits | +         |
| 0        | 0 | 0       | 1   | 0/1  | +n           | +         |
| 0        | 0 | 1       | 1   | 0/1  | -n           | -/+       |
| 0        | 1 | 0       | 1   | 0/1  | -n           | -         |
| 0        | 1 | 1       | 1   | 0/1  | +n           | -/+       |
| 1        | 0 | 0       | 1   | 0/1  | +n           | -         |
| 1        | 0 | 1       | 1   | 0/1  | -n           | +/-       |
| 1        | 1 | 0       | 1   | 0/1  | -n           | +         |
| 1        | 1 | 1       | 1   | 0/1  | +n           | +/-       |

n = bits 04 to 14 of TMA register for a 2048 point cosine table.

Maximum points in FFT = 8192.

quadrant = Bits 02 and 03 of TMA register for a 2048 point cosine table

SIN/COS = Bit 15 of TMA register

FFT = Bit 12 of APSTATUS

IFFT = Bit 11 of APSTATUS

Hardware strap options allow n to be widened and the quadrant bits moved to the left, thus allowing alternative cosine table sizes of 4K (16K FFT) and 8K (32K FFT). Cosine table sizes of 16K and 32K are possible. However, the quadrant determination logic will not work properly and thus special FFT micro-code would be required.

#### 4.7.2.3 Read and Write Operations

In READ OPERATIONS the contents of the TM location pointed to by the current address contained in TMA will become available as TM two instruction cycles later.

In order to change TMA, one may specify an INCTMA, DECTMA, SETTMA op-code from the TMA field of the MEMORY portion of the instruction word, or specify a LDTMA op-code from the LDREG field of the I/O portion of the instruction word. The contents of TMA as altered by these op-codes are available one cycle later for op-codes that use it as an address (JSRT) or data (RDTMA). The available TMA modification op-codes are given below:

| INSTRUCTION<br>WORD FIELD | OCTAL<br>VALUE | OP-CODE | OPERATION                                        |
|---------------------------|----------------|---------|--------------------------------------------------|
| TMA                       | 1              | INCTMA  | Increment current TMA address by "1"             |
| TMA                       | 2              | DECTMA  | Decrement current TMA address by "1"             |
| TMA                       | 3              | SETTMA  | Replace TMA address with current SPFN (See Note) |
| LDREG                     | 3              | LDTMA   | Replace TMA address with current DB              |

#### NOTE

If an Op-Code from LDREG field (I/O) is used concurrently, then SETTMA will replace the TMA address with the current DB, not SPFN.

#### 4.7.2.4 Programming Examples

##### \* Example 1

Do the vector sum  $Ax = B + K$ ,  $i = 0, 1, 2$ , where  $Ax$  is in DPX locations 10-12,  $Bx$  is in DPY 10-13, and  $Kx$  is a series of constants stored in Table Memory location 235-237.  $Ax$  will be stored back into DPX. We will assume that DPA was set to 10 and TMA was set to 234 before we start.

|    |                               |                                                                    |
|----|-------------------------------|--------------------------------------------------------------------|
| 1. | INCTMA                        | "Fetch K <sub>0</sub>                                              |
| 2. | INCTMA                        | "Fetch K <sub>1</sub>                                              |
| 3. | INCTMA; FADD TM, CPY; INC DPA | "Do K <sub>0</sub> + B <sub>0</sub> , bump DPA to 11               |
| 4. | FADD TM, DPY; INC DPA         | "Do K <sub>1</sub> + B <sub>1</sub> , bump DPA to 12               |
| 5. | FADD TM, DPX (0); DPX (-2)<FA | "Do K <sub>2</sub> + B <sub>2</sub> , store A in DPX <sub>10</sub> |
| 6. | FADD: DPX (-1)<FA             | "Store A <sub>1</sub> in DPX <sub>11</sub>                         |
| 7. | DPX (0)<FA                    | "Store A <sub>2</sub> in DPX <sub>12</sub>                         |

The following charts the above computation:

| Cycle | Table | Memory         | Adder                           | FA                             | Data | Pad X          |                |                |
|-------|-------|----------------|---------------------------------|--------------------------------|------|----------------|----------------|----------------|
|       |       |                |                                 |                                |      | DPA            | 10             | 11             |
| 1.    | 235   | ---            | ---                             | ---                            | 10   | ---            | ---            | ---            |
| 2.    | 236   | ---            | ---                             | ---                            | 10   | ---            | ---            | ---            |
| 3.    | 237   | K <sub>0</sub> | K <sub>0</sub> , B <sub>0</sub> | ---                            | 10   | ---            | ---            | ---            |
| 4.    | 237   | K <sub>1</sub> | K <sub>1</sub> , B <sub>1</sub> | ---                            | 11   | ---            | ---            | ---            |
| 5.    | 237   | K <sub>2</sub> | K <sub>2</sub> , B <sub>2</sub> | K <sub>0</sub> +B <sub>0</sub> | 12   | A <sub>0</sub> | ---            | ---            |
| 6.    | 237   | K <sub>2</sub> | ---                             | K <sub>1</sub> +B <sub>1</sub> | 12   | A <sub>0</sub> | A <sub>1</sub> | ---            |
| 7.    | 237   | K <sub>2</sub> | ---                             | K <sub>2</sub> +B <sub>2</sub> | 12   | A <sub>0</sub> | A <sub>1</sub> | A <sub>2</sub> |

##### \* Example 2 - A Complex Multiply

An example using both memories is a complex multiply from the FFT (Fast Fourier Transform) algorithm. The multiply is between a complex signal point held in Data Memory and a complex exponential value (a root of unity, xxx) fetched from Table Memory. The computation is:

$$X_R = C_R * W_R - C_I * W_I$$

$$X_I = C_R * W_I + C_I * W_R$$

Where  $C$  is the data point and  $W$  is the complex exponential "R" and "I" denote real and imaginary parts respectively.  $C$  is in Main Data Memory, and  $W$  is in Table Memory.

|                          |                                                                                               |                                                                                                                              |
|--------------------------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Fetch the<br>4 arguments | 1. INCMA<br>2. INCTMA<br>3. INCMA; INCTMA<br>4. FMUL TM, MD                                   | "Fetch $C_R$ from Data Memory<br>"Fetch $W_R$ from Table Memory<br>"Fetch $C_I$ fetch $W_I$<br>"Do $C_R * W_R$               |
| Do the<br>multiplies     | 5. FMUL TM, MD; DECTMA<br>6. FMUL TM, MD<br>7. FMUL TM, MD; DPX (0)<FM<br>8. FMUL; DPX (1)<FM | "Do $C_R * W_I$ fetch $W_I$<br>"Do $C_I * W_I$<br>"Do $C_I * W_R$ , Save $C_R W_R$ , In DPX<br>"Save $C_R W_I$ in DPX        |
| Do the 2<br>adds.        | 9. FMUL; FSUBR FM, DPX (0)<br>10. FADD FM, DPX (1)<br>11. DPX (0)<FA; FADD<br>12. DPX (1)<FA  | "Do $X_R + C_R W_R - C_I W_I$<br>"Do $X_I = C_R W_I + C_I W_R$<br>$X_R$ is ready, save in DPX<br>$X_I$ is ready, save in DPX |

The total elapsed time is 12 cycles or 2us. In practice, however, we can overlap all but cycles 4-7 with the preceding and following computations. The complex multiply then takes us only 667ns, when mixed in with other computations.

Below is a summary chart of the complex multiply:

| Cycle | Memories       |                | Multiplier                      |                                | Adder                                                         |                | Data Pad                      |                               |
|-------|----------------|----------------|---------------------------------|--------------------------------|---------------------------------------------------------------|----------------|-------------------------------|-------------------------------|
|       | TM             | MD             | M1, M2                          | FM                             | A1, A2                                                        | FA             | 0                             | 1                             |
| 1.    | ---            | ---            | ---                             | ---                            | ---                                                           | ---            | ---                           | ---                           |
| 2.    | ---            | ---            | ---                             | ---                            | ---                                                           | ---            | ---                           | ---                           |
| 3.    | ---            | ---            | ---                             | ---                            | ---                                                           | ---            | ---                           | ---                           |
| 4.    | W <sub>R</sub> | C <sub>R</sub> | W <sub>R</sub> , C <sub>R</sub> | ---                            | ---                                                           | ---            | ---                           | ---                           |
| 5.    | W <sub>I</sub> | C <sub>R</sub> | W <sub>I</sub> , C <sub>R</sub> | ---                            | ---                                                           | ---            | ---                           | ---                           |
| 6.    | W <sub>I</sub> | C <sub>I</sub> | W <sub>I</sub> , C <sub>I</sub> | ---                            | ---                                                           | ---            | ---                           | ---                           |
| 7.    | W <sub>R</sub> | C <sub>I</sub> | W <sub>R</sub> , C <sub>I</sub> | W <sub>R</sub> *C <sub>R</sub> | ---                                                           | ---            | W <sub>R</sub> C <sub>R</sub> | ---                           |
| 8.    | ---            | I              | ---                             | W <sub>R</sub> *C <sub>R</sub> | ---                                                           | ---            | W <sub>R</sub> C <sub>R</sub> | W <sub>I</sub> C <sub>R</sub> |
| 9.    | ---            | ---            | ---                             | W <sub>I</sub> *C <sub>R</sub> | W <sub>I</sub> C <sub>R</sub> , W <sub>R</sub> C <sub>R</sub> | ---            | W <sub>R</sub> C <sub>R</sub> | W <sub>I</sub> C <sub>R</sub> |
| 10.   | ---            | ---            | ---                             | W <sub>I</sub> *C <sub>I</sub> | W <sub>I</sub> C <sub>I</sub> , W <sub>R</sub> C <sub>R</sub> | X <sub>R</sub> | W <sub>R</sub> C <sub>R</sub> | W <sub>I</sub> C <sub>R</sub> |
| 11.   | ---            | ---            | ---                             | W <sub>R</sub> I               | W <sub>R</sub> I, W <sub>I</sub> C <sub>R</sub>               | X <sub>I</sub> | X <sub>R</sub> C <sub>R</sub> | W <sub>I</sub> C <sub>R</sub> |
| 12.   | ---            | ---            | ---                             | ---                            | ---                                                           | ---            | X <sub>R</sub>                | X <sub>I</sub>                |

## CHAPTER 5

### HOW TO PROGRAM THE AP-120B

#### 5.1 MEET THE AP.....AGAIN

##### 5.1.1 Introduction

The purpose of this chapter is to illustrate the way to use the AP most efficiently, i.e., to write good loops. It assumes that the reader has already read the Software Development Package Manual (APAL, Sections 2 and 3) and has at least a passing acquaintance with the AP instruction set.

This chapter presents a short review of the basic elements of the Array Processor from the programmer's point of view, covers methods and techniques of writing loops and suggests some common pitfalls to avoid.

It reviews some of the basic AP instructions; it is not meant to be all-inclusive but to briefly cover the most-often-used things.

This chapter assumes the use of the AP's 333 ns interleaved memory.

### 5.1.2 Basic Overview

#### 5.1.2.1 Arithmetic

Both the Floating Adder and Floating Multiplier need explicit instructions (e.g., FADD and FMUL, respectively) to push their respective answers out of the pipelines. Given these "pushers", the Floating Adder result (FA) will be available two cycles after the original instruction, and the Floating Multiplier result (FM) will be available three cycles after the original instruction:

|                            |                            |
|----------------------------|----------------------------|
| 0. FADD DPX, DPY "add      | 0. FMUL DPX, DPY "multiply |
| 1. FADD "push              | 1. FMUL "push              |
| 2. DPX(1)<FA "store answer | 2. FMUL "push              |

3. DPY(1)<FM "store answer

The empty FADD and FMUL "pushers" can also be read Adder or Multiplier operations, thus producing new answers each cycle.

If the "pushers" do not directly follow the original instructions, FA will come out one cycle after the first FADD pusher, and FM will come out one cycle after the second FMUL pusher. Both FA and FM will remain available for succeeding cycles until a new FA or FM is pushed out.

The arguments for Adder and Multiplier instructions consist of one from column A and one from column B, (in that order):

COLUMN A (A1 or M1)

COLUMN B (A2 or M2)

|     |     |
|-----|-----|
| FM  | FA  |
| TM  | MD  |
| DPX | DPX |
| DPY | DPY |

The Adder has additional arguments of ZERO and NC (no change), which can be used in either or both columns.

#### 5.1.2.2 Main Data Memory

Reading from memory requires one of the following instructions: SETMA, INCMA, DECMA, or LDMA. In practice, it is usually done by the SETMA instruction. The result, MD, comes out three cycles later and is also available for succeeding cycles until a new MD comes out. No "pushers" are needed. Writing into memory requires one of the above instructions plus MI<source, where source is FA, FM or DB. This goes on the same line as SETMA, and gets done in that cycle. Memory can be referenced every two cycles, for either a read or write.

### 5.1.2.3 Table Memory

Table memory is usually referenced by the SETTMA or LDTMA instruction. Two cycles later, TM is available and remains so until two cycles after the next instruction affecting TMA. Such instructions can occur in every cycle, producing a new TM every cycle.

### 5.1.2.4 Data Pad

DPX and DPY each contain 32 registers, eight of which are accessible from any given DPA. That is, one can reference DPX from DPX(DPA-4) to DPX(DPA+3), and similarly for DPY.

The Data Pad Bus is usually used to store data from memory or from one Data Pad register into another, or to utilize a value, e.g., in conjunction with a load operation:

|                       |                                              |
|-----------------------|----------------------------------------------|
| DPX(1)<DB; DB=DPY(-2) | This can be shortened to<br>DPX(1)<DPY(-2).) |
| DPX<DB; DB=MD         | (Or, DPX<MD)                                 |
| LDDPA; DB=3           | (This sets DPA=3)                            |

Storing into Data Pad from FA or FM does not use the Data Pad Bus. This is important, as it leaves DB free for other uses.

### 5.1.2.5 S-Pad

S-Pad registers are usually used as address pointers or counters, and thus to pass parameters to a program. An S-Pad operation must accompany a SETMA (or SETDPA, SETTMA, etc.) instruction. An S-Pad operation must also precede a conditional branch (BGT, BNE, etc.) by one cycle. That is, conditional branches are based on the S-Pad Function (SPFN) of the S-Pad operation in the previous cycle.

The fastest way to get an integer into S-Pad is to use the LDSPI instruction:

LDSPI COUNT; DB=5

This puts 5 into an S-Pad register called COUNT. The value is assumed to be octal unless a decimal point is added. DB=15. (note point) is equivalent to DB=17 (octal), or to DB=0FX (hex). Hexadecimal numbers must start with a numeric digit and end with "X".

Although the Floating Adder operation FSUB A1, A2 will do A1-A2, the S-Pad operation SUB subtracts in the opposite direction, i.e., SUB PIECE, TOTAL will do:

(contents of S-Pad TOTAL) minus (contents of S-Pad PIECE).

### 5.1.3 Referencing Memory

In order to read something out of memory, or write into it, the location in memory where this will occur must be provided. The SETMA instruction gets this necessary information from the S-Pad Function (SPFN) of the same cycle. Therefore, one needs to construct an S-Pad operation which will result in a pointer to the appropriate memory location. Generally, this takes the form of adding increments to pointers. For example, if there was a 4-element vector in memory locations 100, 102, 104, 106, one would need an S-Pad register (say, APTR) containing the base address (100), and another S-Pad register (AINC) containing the increment between elements (2). Then, if one wanted to read the element in location 102, the appropriate instruction would be ADD AINC, APTR; SETMA. Now APTR would contain 102. If one wrote another ADD AINC, APTR; SETMA the contents of memory location 104 would be read.

Consider the following instruction: MOV APTR, APTR. This doesn't seem to accomplish much, but in the light of the above discussion, it can be seen that its SPFN could be useful for a SETMA. This is how one would get the first element of a vector.

All of the above is correspondingly true for writing into memory.

#### 5.1.4 S-Pad Mnemonics

S-Pad names such as APTR, AINC, N are really only temporary names for the 16 S-Pad registers. A statement such as DEC N will not mean anything to the assembler unless the program has equated the mnemonic "N" with a specific S-Pad register, such as S-Pad 0. This is done by the following assembler pseudo-op: N \$EQU 0. All S-Pad names used in a program must be declared in this manner before using them in an instruction. Thus, programs generally begin with lists like:

```
APTR $EQU 0  
AINC $EQU 1  
BPTR $EQU 2  
BINC $EQU 3  
N    $EQU 4
```

•  
•  
•

These S-Pad numbers should not be confused with the contents of the S-Pads. ADD BINC, BPTR would not add 3 to 2 (using the above list), but would add the contents of S-Pad 3 to the contents of S-Pad 2.

There can be more than one name for an S-Pad register. If you had two different vectors, A and B, and wished to use the mnemonics AINC and BINC for their increments, you could use the same S-Pad register if the increment for both is the same in all cases, by declaring:

```
AINC $EQU 1  
BINC $EQU 1
```

### 5.1.5 Other Pseudo-Ops

Besides the \$EQU pseudo-op, the typical program includes \$TITLE and \$ENTRY pseudo-ops at the very beginning, and an \$END at the very end. A basic program with one loop would have the following form:

See the software manual for explanations of these pseudo-ops.

## 5.2 LOOPS

### 5.2.1 A Poor Loop

The loop is where the potential of the AP comes into full bloom. For example, one way (lengthy but workable) to write a dot product program is as follows:

Given: Vectors A and B in Main Data Memory, with elements of each vector in equally spaced locations in memory (e.g., even-numbered locations).

Produce: N  
c= A(m).B(m)  
m=1

Parameters passed in S-Pad:

| S-Pad Name | Contains:                                                                            |
|------------|--------------------------------------------------------------------------------------|
| APTR       | base address of vector A                                                             |
| BPTR       | base address of vector B                                                             |
| XINC       | increment (number of locations from one element to the next) (same for both vectors) |
| N          | number of elements in each vector                                                    |
| CPTR       | address of answer                                                                    |

|          |                                                         |
|----------|---------------------------------------------------------|
| DOTPROD: | SUB XINC, APTR (See Note below)                         |
|          | SUB XINC, BPTR (See Note below)                         |
|          | FADD ZERO, ZERO "initialize FA=0                        |
|          | FADD                                                    |
| LOOP:    | ADD XINC, APTR; SETMA "get mth element of vector A      |
|          | NOP " from memory                                       |
|          | NOP                                                     |
|          | DPX<MD "MD=A(m), store into DPX                         |
|          | ADD XINC< BPTR; SETMA "get mth element of vector B      |
|          | NOP                                                     |
|          | NOP                                                     |
|          | FMUL DPX, MD "MD=B(m), do A(m).B(m)                     |
|          | FMUL                                                    |
|          | FMUL                                                    |
|          | FADD FM, FA "add product to sum of products             |
|          | FADD                                                    |
|          | DEC N "decrement counter                                |
|          | BGT LOOP "branch back if not done yet<br>"(i.e. if N>0) |
| DONE:    | MOV CPTR, CPTR; SETMA; MI<FA "otherwise, store answer   |

NOTE

This is so that the first time through the loop, ADD XINC, APTR and ADD XINC< BPTR will not move the pointer to the second element, passing up the first altogether.

To begin with, this program can certainly be shortened by combining instructions and overlapping memory fetches. Thus:

```
DOTPROD: FADD ZERO, ZERO; SUB XINC, APTR
          FADD; SUB XINC, BPTR
LOOP:   ADD XINC, APTR; SETMA      "get A(m)
        NOP
        ADD XINC, BPTR; SETMA      "get B(m)
        DPX<MD                "store A(m) in DPX
        NOP
        FMUL DPX, MD           ".do A(m).B(m)
        FMUL
        FMUL
        FADD FM, FA; DEC N     "add product to sum of products
                               " and decrement counter
        FADD; BGT LOOP         "test if done. If not, branch
                               " to LOOP
DONE:   MOV CPTR, CPTR; SETMA; MI<FA
          "if so, store answer
```

Note the extra FMUL's and FADD's, described as "pushers". These push the answers through the pipelines, so that FM and FA will contain what they are intended to contain. This is pointed out because the beginning AP programmer is likely to forget to put "pushers" in his code.

Now the loop of the evolving dot product program is ten cycles long. This means that each new pair of elements costs ten more cycles. Although better than the initial example, which had a 14-cycle loop, this can actually be cut down to a mere four cycles!

### 5.2.2 Determining Length of Loop

One might suppose that the length of a program loop depends on what one is trying to do. This is true, but not in the way one would think. The AP programmer decides ahead of time how many cycles his loop should contain, and then fits everything into that framework. How does he pick the magic number? Most commonly, loops are memory-limited. Recall that one can reference memory (to read or to store) every two cycles. If one has two memory references to do (e.g., "get A" and "get B"), then the loop will be at least four cycles long (two per memory reference). And, unless one has more than four different FMUL's, four different FADD's, or four different S-Pad operations to do, the loop should be, at MOST, four cycles. A lot can be done in four cycles when one can do a Floating Multiplier operation, a Floating Adder operation, an S-Pad operation, a branch, a memory reference, a Data Pad Bus transfer, etc., in EACH cycle.

### 5.2.3 Writing A Real Memory-Limited Loop

Before continuing with the transformation of the dot product program, another example will be utilized.

Given: Vectors A and B in Main Data memory, length=N elements

Produce: Vector C (in memory), where  $C(m)=A(m)2+B(m)$  for  $m=1$  to N

Parameters:

| S-Pad Name | Contains                                         |
|------------|--------------------------------------------------|
| APTR       | base address of A                                |
| BPTR       | base address of B                                |
| CPTR       | base address of C                                |
| XINC       | increment (same for all vectors in this example) |
| N          | number of elements                               |

Note that there should be three memory references in the loop: "get A", "get B", and "store C". (Unlike the dot product which accumulated a running sum in the Adder, this program needs to store an answer after each set of computations. For the dot product, storing was not a repeated process, and hence not included in its loop.) Three memory references, one every other cycle, means the loop would be six cycles long. It would start like this:

- 1) ---(nothing here, but count a cycle)
- 2) ADD XINC, APTR; SETMA      get A
- 3) ---
- 4) ADD XINC, BPTR; SETMA      "get B
- 5) DPX<MD                      "store A in DPX
- 6) FMUL DPX, MD                "do A\*A

(The reason for starting on the second line will be explained later.)

Now it has run out of cycles, but there is still more to do, so it starts back up at the first cycle, which is where the end will branch to, when it gets around to testing if it's done.

|       |                             |                                           |                                                                                        |
|-------|-----------------------------|-------------------------------------------|----------------------------------------------------------------------------------------|
| LOOP: | 1) ---                      | FMUL                                      | "B is available<br>here, but<br>"not needed yet                                        |
|       | 2) ADD XINC, APTR;<br>SETMA | FMUL                                      |                                                                                        |
|       | 3) ---                      | FADD FM, MD                               | "add B to A(2)                                                                         |
|       | 4) ADD XINC, BPTR;<br>SETMA | FADD                                      |                                                                                        |
|       | 5) DPX<MD                   | DEC N                                     | "answer is avail-<br>able here<br>"but can't re-<br>ference memory<br>"yet to store it |
|       | 6) FMUL DPX, MD             | ADD XINC, CPTR; SETMA; MI<FA;<br>BGT LOOP | "store answer and<br>"test if done                                                     |

This is the entire loop. In its proper form, taking out lines and adding semicolons, it looks like this:

```

LOOP: FMUL
      ADD XINC, APTR; SETMA; FMUL
      FADD FM, MD
      ADD XINC, BPTR; SETMA; FADD
      DPX<MD; DEC N
      FMUL DPX, MD; ADD XINC, CPTR; SETMA; MI<FA; BGT LOOP

```

#### 5.2.4 Writing Intros

Notice, however, that if the program goes right into this loop, after initial overhead such as  
SUB XINC, APTR  
SUB XINC, BPTR  
SUB XINC, CPTR

it picks up the first element of A and B as it's supposed to, but it also stores something into C before it's ready to, and decrements the counter too early. IT GOES THROUGH BOTH COLUMNS AT THE SAME TIME. What is desired, however, is that computations in the second column continue from the first column. The only way it can do this is to continue from what the first column did in the PREVIOUS time through the loop. And the FIRST time, there was no previous time. Hence the need for additional microcode before getting into the loop.

Exactly what needs to go before the loop? In order for the second column of the loop to be doing what it's supposed to when the program gets to it, the first column must precede it. Essentially, one rewrites the first column as an "intro" to the loop. Thus:

|          |                        |                                                                                     |
|----------|------------------------|-------------------------------------------------------------------------------------|
| PROGRAM: | MOV APTR, APTR; SETMA  | "get first element<br>"of A                                                         |
|          | SUB XINC, CPTR         | "to offset ADD in<br>loop                                                           |
|          | MOV BPTR, BPTR; SETMA  | "get first element<br>"of B                                                         |
|          | DPX<MD                 | "store A(1) in DPX                                                                  |
|          | FMUL DPX, MD           | "do A(1)2                                                                           |
| LOOP:    | FMUL                   |                                                                                     |
|          | ADD XINC, APTR; SETMA; | FMUL<br>"get A(m+1)                                                                 |
|          |                        | FADD FM, MD<br>"do A(m)2+B(m)                                                       |
|          | ADD XINC, BPTR; SETMA; | FADD<br>"get B(m+1)                                                                 |
|          | DPX<MD;                | DEC N<br>"store A(m+1)                                                              |
|          | FMUL DPX, MD;          | ADD XINC, CPTR; SETMA; MI<FA; BGT LOOP<br>"do A(m+1)2, store<br>"C(m), test if done |
| DONE:    | RETURN                 |                                                                                     |

To clear up a loose end regarding the structure of memory-limited loops, one might notice that since the branch must be in the last cycle, the DEC N instruction must be in the second-to-last cycle. DEC is an S-Pad operation and cannot be in the same cycle as another S-Pad operation, such as ADD XINC, XPTR. A memory-limited loop has SETMA's (requiring S-Pad operations) on every other line. Since the DEC N operation will go on an odd-numbered line of the loop, the SETMA's must go on even-numbered lines. This is why the first thing to do, ADD XINC, APTR; SETMA (See section 5.2.3), was put on line 2.

### 5.2.5 Dot Product Program

It is now possible to write the four cycle dot product. Using the technique outlined above, the loop should be constructed as follows:

- 1) ---
  - 2) ADD XINC, APTR; SETMA "get A
  - 3) ---
  - 4) ADD XINC, BPTR; SETMA "get B
- then
- 1) --- DPX<MD "store A
  - 2) ADD XINC, APTR; SETMA ---
  - 3) --- FMUL DPX, MD "do A.B
  - 4) ADD XINC, BPTR; SETMA FMUL
- then
- 1) --- DPX<MD FMUL
  - 2) ADD XINC, APTR; SETMA --- FADD FM,FA "add A.B to sum  
"of products
  - 3) --- FMUL DPX, MD FADD; DEC N"decrement  
counter
  - 4) ADD XINC, BPTR; SETMA FMUL BGT LOOP "test if done

The intro to this three column loop will consist of the first column alone, then the first and second column together. Other overhead, such as initializing FA to 0, can be mixed in with the intro.

To generalize, an  $N$ -column loop would require an intro consisting of column 1 followed by columns 1 and 2 together, followed by columns 1, 2 and 3 together...followed by columns 1, 2,..., $N-1$  together.

```

$TITLE DOTPROD
$ENTRY DOTPROD

APTR $EQU 0
BPTR $EQU 1
CPTR $EQU 2
XINC $EQU 3
N    $EQU 4

DOTPROD: MOV APTR, APTR; SETMA; FADD ZERO, ZERO      "get A(1) and
                                                       "initialize FA=0
          MOV BPTR, BPTR; SETMA; FADD                 "get B(1)
          DPX<MD                                         "store A(1)
          ADD XINC, APTR; SETMA                         "get A(2)
          FMUL DPX, MD                                "do A(1)*B(1)
          ADD XINC, BPTR; SETMA; FMUL                  "get B(2)
          LOOP:   DPX<MD; FMUL                         "store A(m+1)
          ADD XINC, APTR; SETMA; FADD FM, FA           "get A(m+2), add
                                                       "A(m)B(m) to sum
          FMUL DPX, MD; FADD; DEC N                   "do A(m+1)B(m+1)
                                                       "decrement counter
          ADD XINC, BPTR; SETMA; FMUL; BGT LOOP       "get B(m+2), test if
                                                       "done
DONE:    MOV CPTR, CPTR; SETMA; MI<FA; RETURN        "if so, store answer
$END

```

Now each new pair of elements will cost four more cycles, because every four cycles a new pair is being fetched; every four cycles another product is added to the sum. The longer overhead is no disadvantage as it is only done once, and even if the program was called with N containing 1, making the streamlined loop unnecessary, it takes no longer than the unstreamlined program.

Note that there are two SETMA's in a row at the beginning and again at the end of the program. This will not cause any problems except to make memory spin, which is the memory's way of putting in the NOP's the programmer leaves out. The timing is still the same, and this way there are two less locations of Program Source used up.

It might be mentioned that if one were getting Vectors A and B out of Data Pad instead of memory, the dot product could be written with a one-cycle loop! This will be demonstrated later.

### 5.2.6 Notation

A few words about notation are in order. The "----" used when writing loops in column form simply denotes a blank spot, indicating a cycle goes by while awaiting the results of a memory fetch or while looking for a more propitious spot to use the results of the Adder or Multiplier, etc. Normally, something else will eventually go on the same line, in a different column.

Example: This takes vector A, multiplies it by a constant in DPX, and stores it in vector B.

- 1) --- FMUL DPX, MD
- 2) ADD XINC, APTR; SETMA FMUL
- 3) --- FMUL; DEC N
- 4) --- ADD XINC, BPTR; SETMA; MI<FM; BGT LOOP

Since the length of the loop was already decided by the number of SETMA's, these blank spots cause no harm to the speed. It is the number of cycles in the loop, not the number of columns, which determines speed. Extra columns simply mean longer intros, which the program only goes through once anyway unless it's part of a nested loop.

In loops with several Adder or Multiplier operations, it often happens that one such instruction will be a "pusher" for another in another column.

- 1) (code) FMUL DPY, MD (code)
- 2) " FMUL DPX, DPY FMUL "
- 3) " FMUL FMUL "
- 4) " FMUL DPY<FM "
- 5) " DPX(1)<FM "
- 6) " "

In column 2, lines 2 and 3 are illegal, as those lines already contain FMUL's (which will do the pushing for column 2 as well as column 1). However, it may be advantageous to the programmer to note to himself somehow that FMUL's do belong there, in case things in the first column get moved around for some reason. This is the purpose of such notation as (fmul) or (fadd).

Thus:

- 1) (code) FMUL DPY, MD (code)
- 2) " FMUL DPX, DPY (fmul) "
- 3) " FMUL (fmul) "
- 4) " FMUL DPY<FM "
- 5) " DPX(1)<FM "
- 6) " "

Now, if pieces of the first column were moved down a couple of lines for some reason,

```
1) (code)          FMUL DPY, MD (code) DPX(1)<FM
2) "              (fmul)      "
3) "              (fmul)      "
4) "FMUL DPY, DPY    DPY<FM      "
5) "FMUL           "          "
6) "FMUL           "          "
```

the programmer would be reminded to put real FMUL's back on those lines.

When writing loops with a small number of cycles, these reminders can also help one keep track of the columns, as in:

```
---      --- DPY<MD      FMUL      FADD FM, FA; DEC N
ADD XINC, APTR; SETMA --- FMUL, DPY, MD (fmul) FADD; BGT LOOP
```

This gets a vector from memory, squares each element and adds the squares together (sort of a dot product between vector A and itself). The seemingly empty columns, which disappear when the loop is written in proper form (see below), are necessary in order to write the intro properly. If one left out the second column, for example, his intro would start with:

```
MOV APTR, APTR; SETMA
DPY<MD
ADD XINC, APTR; SETMA; FMUL DPY, MD
.
.
.
```

Clearly, the first MD will not be the first element fetched. By the time it gets down to FADD FM, FA in the loop, something which doesn't belong will be added in.

This is what the intro and loop should look like:

```
MOV APTR, APTR; SETMA
FADD ZERO, ZERO      "initialize FA=0
ADD XINC, APTR; SETMA; FADD
DPY<MD
ADD XINC, APTR; SETMA; FMUL DPY, MD
DPY<MD; FMUL
ADD XINC, APTR; SETMA; FMUL DPY, MD

LOOP: DPY<MD; FMUL; FADD FM, FA; DEC N
      ADD XINC; APTR; SETMA; FMUL DPY, MD; FADD; BGT LOOP

      (answer)<FA
```

### 5.2.7 Dropping Out One Early

|                          |                       |                                           |
|--------------------------|-----------------------|-------------------------------------------|
| 1) ---                   | (code)                | (code)                                    |
| 2) ADD XINC, APTR; SETMA | "                     | "                                         |
| 3) (code)                | "                     | "                                         |
| 4) ADD XINC, BPTR; SETMA | "                     | "                                         |
| 5) (code)                | "                     | "                                         |
| 6) "                     | ADD XINC, CPTR; SETMA | "                                         |
| 7) "                     | (code)                | " DEC N                                   |
| 8) "                     | "                     | ADD XINC, DPTR; SETMA<br>MI<DPX; BGT LOOP |

Here, there are two memory reads in the first column, one read in the second column, and a store in the last column. When writing the intro, the pointers should be taken care of as follows:

```
MOV APTR, APTR; SETMA
SUB XINC, DPTR; (code)
MOV BPTR, BPTR; SETMA
(code)

.
.

.
ADD XINC, APTR; SETMA; (code)
(code)
ADD XINC, BPTR; SETMA;   "
(code)
"           MOV CPTR, CPTR; SETMA
"           (code)
"
```

If the memory reference in the second column of the loop was a store instead of a read, the problem would become more complicated. By the time the counter went down to zero and the last result was stored at DPTR, an extra C would have been stored, possibly over a valuable piece of data, such as the beginning of vector D. Or if instead of ADD XINC, CPTR; SETMA; MI<DPY in the second column, we had DPY<FA (where FA is cumulative, as in the dot product) and later stored DPY into CPTR after getting out of the loop, an extra FA would have been computed and DPY would contain an incorrect answer. In this case, it would be wise to drop out of the loop one time early. One would put an extra DEC N somewhere in the intro, so that the loop would be done N-1 times. Then after the loop, write just the last column (not including DEC and the branch, of course), which is all that remains to be done from the loop anyway.

Example: This does a dot product of vectors A and B, and also outputs the square of each updated sum into vector D.

```
---          FMUL DPX, MD  ---
ADD XINC, APTR; SETMA    (fmul)      FMUL DPY, DPY
---          FMUL           (fmul )
ADD XINC, BPTR; SETMA    FADD FM, FA  FMUL
DPX<MD             FADD           DEC N
---          DPY<FA        ADD XINC, DPTR; SETMA; MI<FM;
                           BGT LOOP
```

When it is going through the loop for the last time and storing the very last thing in D (column 3), it is also simultaneously doing extra executions of columns 1 and 2. Normally, that doesn't matter, but in this case, something extra is being added to the cumulative sum of the dot product (column 2), which was completed the previous time through the loop. By dropping out of the loop before its last time around, this error is avoided:

```
MOV APTR, APTR; SETMA
DEC N                      "to cause dropping out early
MOV BPTR, BPTR; SETMA
DPX<MD
SUB XINC, DPTR            "to nullify the first ADD XINC, DPTR

                           FMUL DPX, MD
ADD XINC, APTR; SETMA; FMUL
FMUL
ADD XINC, BPTR; SETMA    FADD FM, FA
DPX<MD             FADD
DPY<FA

LOOP:
ADD XINC, APTR; SETMA          FMUL DPX, MD
                               FMUL DPY, DPY
ADD XINC, BPTR; SETMA; FMUL
DPX<MD             FADD FM, FA  FMUL
FADD;              DEC N
DPY<FA;            ADD XINC, DPTR; SETMA; MI<FM;
                           BGT LOOP

OUT:
                           FMUL DPY, DPY
MOV CPTR, CPTR; SETMA; MI<DPY; FMUL
FMUL
ADD XINC, DPTR; SETMA; MI<FM;
RETURN
```

Notice that the (fmul) in column 2 became a real FMUL in the intro. OUT starts just the last column. The next line stores the completed dot product.

One might wish to come out one early even if one doesn't strictly need to, if the loop is long and there are only a couple of lines in the last column:

```
1) (code)      (code)
2)   " SETMA    "
3)   "       " SETMA; MI<DPX
4)
5)
6)   " SETMA
7)
8)   " SETMA
9)
10)  " SETMA
11)  " DEC N
12)  " SETMA BGT LOOP
```

In this case, coming out of the loop one time early and adding on the last four lines afterward would save going through eight cycles for nothing.

### 5.2.8 Interaction Between Columns

In order to fit things into complicated loops without creating op-code conflicts, the AP programmer takes advantage of results (e.g. MD, FA) which are the same for one or more cycles after first available. Sometimes he will purposely delay the pushing of an answer through a pipeline by leaving out "pushers". But he must be careful of the way the columns interact with each other within the loop.

|                  |           |
|------------------|-----------|
| 1) FMUL DPX, DPY | .         |
| 2)               | .         |
| 3)               | .         |
| 4) FMUL          | .         |
| 5) FMUL          | DPY(1)<FM |
| 6) DPX(1)<FM     | .         |

The FMUL's in column 2 will act as "pushers" for the FMUL DPX, DPY in column 1, whose answer will come out on line 4 instead of line 6 as desired and will disappear forever when replaced by a new FM on line 5. Notice the FMUL on line 4 in column 1 acts as a pusher for column 2, which was planned for.

Another example:

|                          |              |        |
|--------------------------|--------------|--------|
| 1) (code)                | DPX<MD       | (code) |
| 2) ADD XINC, APTR; SETMA | (code)       | DPX<FA |
| 3) (code)                | FADD FM, DPX | (code) |
| 4) "                     | (code)       | "      |

The DPX of column 2, line 3 will not be the same as what was stored into it in column 2, line 1. It will be FA from column 3, line 2.

### 5.2.9 Changing DPA

Because one can access things in Data Pad much faster than things in memory, it makes sense to store things from memory into Data Pad if they will be used again. For example, if one is going to use an N-element vector for several different computations, one could store it in DPX(0), DPX(1),...,DPX(N-1). Because the Data Pad indices can only be accessed from -4 to +3 with a static DPA, it becomes useful to leave the index alone and change DPA.

Storing vector A in DPX is basically the repeated operation of DPX<MD; INCDPA. If DPA is initially set to zero, then the first element will be stored into DPX(0). INCDPA will increase DPA for the NEXT instruction.

Thus: DPX<MD; INCDPA "refers to DPX(0)  
DPX<MD "refers to DPX(1)

The ways to set DPA to zero:

|                           |                      |
|---------------------------|----------------------|
| CLR# (S-Pad name); SETDPA | "uses up S-Pad field |
| or                        |                      |
| DB=ZERO; LDDPA            | "uses up Adder field |

This loop will read a vector from memory into Data Pad X:

|                       |     |                       |
|-----------------------|-----|-----------------------|
| ---                   | --- | DPX<MD; INCDPA; DEC N |
| ADD XINC, APTR; SETMA | --- | BGT LOOP              |

With intro:

|                                 |  |
|---------------------------------|--|
| MOV APTR, APTR; SETMA           |  |
| CLR# APTR; SETDPA               |  |
| ADD XINC, APTR; SETMA           |  |
| LOOP: DPX<MD; INCDPA; DEC N     |  |
| ADD XINC, APTR; SETMA; BGT LOOP |  |

### 5.2.10 Non-Memory-Limited Loops

A non-memory-limited loop is a loop in which two times the number of memory references is less than the number of same-op-code-field operations required. For example, if there are five Floating Adder operations to be done (FADD, FSUB, FSUBR, etc.) but only two memory references (a fetch and a store), the five Adder operations cannot fit into four cycles.

Incidentally, "pushers" don't count in figuring out how many cycles are needed. In a five-cycle loop with five different Adder operations, the Adder instructions become each other's pushers.

Recall that in memory-limited loops, the first instruction in column 1 usually starts on line 2, to avoid S-Pad conflicts on the next-to-last line. (See last paragraph of Section 5.2.4). This is not necessary in non-memory-limited loops.

The following loop will test whether each element of a vector in DPY is within the range between a maximum limit and minimum limit. If so, the element is added to a cumulative sum. The maximum limit is conveniently located in MD, and the minimum limit in FM, by the grace of whatever program uses this loop. Neither FM nor MD change during this loop's execution.

|                |                   |               |
|----------------|-------------------|---------------|
| FSUB DPY, MD   | BFGT BIGGER       | (fadd)        |
| FSUB FM, DPY   | BFGT SMALL        | DPX<FA; DEC N |
| (fadd) INC DPA | FADD DPY(-1), DPX | BGT LOOP      |

Note that the BFGT instruction tests FA of the previous cycle.

### 5.2.11 A One-Cycle Loop

For the one-cycle dot product, it is assumed that the vectors are already in Data Pad, starting at DPX(0) and DPY(0) (where DPA=0). Obviously, vectors longer than 32 elements cannot be handled this way (or can only be handled in segments of 32 or less).

This is what the loop really looks like:

```
FMUL DPX, DPY; INCDPA (fmul) (fmul) FADD FM, FA; DEC N (fadd) BGT
LOOP
```

The FMUL and FADD instructions become their own "pushers".

```
$TITLE DOTPROD
$ENTRY DOTPROD

N $EQU 0      "number of elements in each vector
CPTR $EQU 1   "where to store answer

DPTPROD: CLR# N; SETDPA          "DPA=0
          FMUL DPX, DPY;        "do A(1)*B(1)
          INCDPA;              "DPA to 1
          DEC N                "set drop out early
          FMUL DPX, DPY;        "do A(2)*B(2)
          INCDPA;              "DPA to 2
          FMUL DPX, DPY;        "do A(3)*B(3)
          INCDPA;              "DPA to 3
          FADD ZERO, ZERO      "init. FA=0
          FMUL DPX, DPY;        "do A(4)*B(4)
          INCDPA;              "DPA to 4
          FADD FM, ZERO;       "A(1)B(1) in Adder
          DEC N                "decrement counter
LOOP:     FMUL DPX< DPY;        "do A(m)*B(m)
          INCDPA;              "DPA to DPA+1
          FADD FM, FA;         "add A(m-3)B(m-3) to sum
          DEC N;               "decrement counter
          BGT LOOP             "test if done

OUT:      DPX<FA; FADD          "store cumulative FA
          FADD DPX, FA          "add it to other cumulative FA
          FADD
          MOV CPTR, CPTR; SETMA; MI<FA; "store answer
          RETURN

$END
```

This particular sort of loop has a problem with the Floating Adder, in that a cumulative FA needs at least two cycles to accumulate each new addition. Hence, the one-cycle loop is actually operating with two mutually exclusive cumulative FA's, interwoven with each other:

```
FADD FM, FA  
FADD FM, FA  
FADD FM, FA  
FADD FM, FA  
FADD FM, FA
```

At the end of all this, they (the two strings of sums) need to be added to each other. (see OUT, the label after LOOP).

This also illustrates the practice of dropping out of the loop one time early. If it didn't drop out early, the last (unneeded) FADD FM, FA of the loop would push out one of the two cumulative FA's. By the next cycle it would be gone forever. By dropping out early, DPX<FA can be done before it's too late.

This line of reasoning can eventually lead one to the idea that the last column of the loop (see beginning of Section 4.2.16) is unnecessary, since there is no way for the Adder result to come out in time for the next FADD FM, FA. The FADD FM, FA of each of the two strings of cumulative FA's will push out the other string. So the loop need only be of the form:

```
FMUL DPX, DPY; INC DPA (fmul) (fmul) DEC N FADD FM, FA; BGT LOOP
```

This is one column less than before, which means that there will be one column's worth (in this case, one line) less to put in the intro. It will also not be necessary to come out of the loop one time early, as there is no extra FADD FM, FA to push away something needed. It is still necessary to add the two cumulative FA's together at the end.

```

$TITLE DOTPROD
$ENTRY DOTPROD

N      $SEQU 0
CPTR $SEQU 1

DOTPROD: CLR# N; SETDPA          "DPA=0
          FMUL DPX, DPY;        "A(1) * B(1)
          INC DPA;             "    DPA to 1
          FADD. ZERO, ZERO    initialize cum. FA=0
          FMUL DPX, DPY;        "A(2) *B(2)
          INC DPA;             "    DPA to 2
          FADD ZERO, ZERO     initialize other cum. FA=0
          FMUL DPX, DPY;        "A(3) * B(3)
          INC DPA;             "    DPA to 3
          DEC N
LOOP:   FMUL DPX, DPY;          "A(m) * B(m)
          INC DPA;             "    DPA to DPA+1
          DEC N;               "    decrement counter
          FADD FM, FA;          "    add A(m-3)B(m-3) to cum. FA
          BGT LOOP              "    test if done
OUT:    DPX<FA; FADD            "store first cumulative FA
          FADD DPX, FA           "add it to other cumulative FA
          FADD
          MOV CPTR, CPTR; SETMA; MI<FA;"store answer
          RETURN

$END

```

## 5.3 CAVEAT PROGRAMMER (LET THE PROGRAMMER BEWARE)

### 5.3.1 Calling Another Sub-Routine

The JSR instruction allows one program to utilize another program, for example the divide sub-routine (DIV). In order to do this, one must declare DIV external (\$EXT DIV) so that the assembler and linker will know what to do with the otherwise undefined symbol. One must also save everything he will need when program execution gets back to his main program. Depending upon what was used in the called sub-routine, some things may remain untouched. Commonly one should not count on being able to leave things in the Adder or Multiplier. Parts of Data Pad may also be changed, or DPA may change. S-Pad will probably not remain inviolate. (Remember, it's the S-Pad register number, not name, which is important.) These things need to be checked before doing a JSR.

### 5.3.2 Illegal Instruction Sequences (not caught by APAL)

The following sequences of instructions have been found to work improperly. They are not flagged as errors by APAL and thus the programmer must be very careful to avoid them.

| SEQUENCE                                                                               | CODE<br>EXAMPLE | PROBLEM                                                                |
|----------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------|
| 1) Two consecutive RETURN instructions.                                                | JSR<br>RETURN   | Stack pointer out of step.                                             |
| 2) A two-cycle instruction (PS, PSODD, or PSEVEN field) followed by a JSR instruction. | RPSF<br>JSR     | Stack pointer out of step.                                             |
| 3) An instruction from the PS field followed by a BDBN or BDBZ instruction.            | LPSL<br>BDBN    | The branch occurs based on DB=0.                                       |
| 4) HALT followed by JSR.                                                               | HALT<br>JSR     | Causes stack pointer overflow if repeated (stack pointer out of step). |
| 5) Panel breakpoint before a JSR.                                                      |                 | Stack pointer out of step.                                             |
| 6) Set flag<br>Branch flag                                                             | SFL0<br>BFL0    | Wait one instruction after setting before branch.                      |
| 7) LDAPS<br>BR APSTATUS                                                                | LDAPS<br>BEQ    | Wait one instruction after setting before branch.                      |

### 5.3.3 Other Things To Watch Out For (caught by APAL)

The rest of this section consists of various short examples, cautions, and reminders.

DPX<MD; DPY<DPX(1)

Illegal. Data Bus is assigned twice. (The above is really  
DPX<DB; DB=MD; DPY<DB; DB=DPX(1).)

DPX<MD; DPY<MD is legal. (DB=MD; DPX<DB; DPY<DB)

DPX<FA; DPY<FM

Legal. FA and FM don't use the Data Bus.

DPX<FA; DPY<FM; DPX(1)<MD

Illegal. Data Pad X is being written into twice (different indices). Within each cycle, there should be no more than one of each of the following:

write into DPX

write into DPY

read from DPX

read from DPY

The exception is when reading out of Data Pad more than once but using the same index:

FADD DPX, FA; FMUL DPX, FA; DPY(1)<DPX is legal.

FADD DPY, DPY; FMUL DPY, DPY is legal.

FADD DPX, FA; FMUL DPX(1), FA is not legal.

FADD DPX, DPY; DPY<MD

The old value of DPY, before MD replaces it, is used in the sum.

DB=4; LDSPI XINC; LDDPA; DPX(2)<FM

Both DPA and the contents of XINC will become 4, but the previous DPA is used in referencing DPX(2).

SUB# XINC, APTR; BGT OUT

Illegal. The # uses the condition field (branch).

## APPENDIX A

## GLOSSARY

|          |                                                                    |
|----------|--------------------------------------------------------------------|
| A        | I.O Device Condition "A" Flag                                      |
| A1       | Floating Adder Input Register #1                                   |
| A2       | Floating Adder Input Register #2                                   |
| ALU      | Arithmetic - Logic Unit                                            |
| APAL     | A.P. Assembly Language (S/W package)                               |
| APARTH   | A.P. Arithmetic Test (S/W package)                                 |
| APBUG    | A.P. Debugger (S/W package)                                        |
| APEX     | A.P. Executive (S/W package)                                       |
| APLINK   | A.P. Linker (S/W package)                                          |
| APMA     | AP-120B Memory Address Register                                    |
| APMATH   | A.P. Math Library (S/W package)                                    |
| APMAX    | Maximum-Positive Floating-Point Number                             |
| APNMAX   | Maximum-Negative Floating-Point Number                             |
| APPATH   | A.P. Path Tester (S/W package)                                     |
| APSIM    | A.P. Simulator (S/W package)                                       |
| APSTATUS | A.P. Status Register                                               |
| APTEST   | A.P. Tester (S/W package)                                          |
| B        | I/O Device Condition "B" Flag                                      |
| CB       | Control Buffer (command)                                           |
| CTL      | Control Register                                                   |
| DA       | I/O Device Address                                                 |
| DB       | Data Pad Bus                                                       |
| DMA      | Direct Memory Access                                               |
| DP       | Data Pad Group                                                     |
| DPA      | Data Pad Address Register                                          |
| DPBS     | Data Pad Bus Field,<br>Data Pad Bus                                |
| DPX      | Data Pad X Registers                                               |
| DPY      | Data Pad Y Registers                                               |
| DST      | Destination Register                                               |
| EFA      | Effective Address                                                  |
| FA       | Floating Adder Output Register,<br>Floating Adder Result           |
| FADDR    | Floating Adder                                                     |
| FM       | Floating Multiplier Output Register,<br>Floating Multiplier Output |
| FFT      | Fast Fourier Transform                                             |
| FMT      | Formatter                                                          |
| FMULR    | Floating Multiplier                                                |

|         |                                          |
|---------|------------------------------------------|
| FN      | Function Register                        |
| FPN     | Floating Point Number                    |
| HHMA    | High Host Memory Address                 |
| HMA     | Host Memory Address Register             |
| IFFT    | Inverse Fast Fourier Transform           |
| INBS    | I/O Input Bus                            |
| INTRQ   | Interrupt Request Flag                   |
| IODRDY  | I/O Data Ready Flag                      |
| JSRS    | Jumps To Subroutines                     |
| LIFO    | Last-In--First-Out                       |
| LITES   | Lights Register                          |
| LSB     | Least Significant Bit                    |
| M1      | Floating Multiplier Input Register #1    |
| M2      | Floating Multiplier Input Register #2    |
| MA      | Memory Address Register                  |
| MAE     | Memory Address Extension                 |
| MD      | Data Memory                              |
| MI      | Memory Input                             |
| MSB     | Most Significant Bit                     |
| PANEL   | AP Virtual Front Panel                   |
| PNLBS   | Panel Bus                                |
| PS      | Program Source Memory                    |
| PSA     | Program Source Address Register          |
| SP      | Scratch Pad Register                     |
| SP(SPD) | S-Pad Destination                        |
| SP(SPS) | S-Pad Source                             |
| S-PAD   | Scratch Pad (See also SP)                |
| SPD     | Scratch Pad Destination Address Register |
| SPFN    | S-Pad Function                           |
| SRA     | Subroutine Return Address                |
| SRAO    | Subroutine Return Address Overflow       |
| SRC     | Source Register                          |
| SRS     | Subroutine Return Stack                  |
| SVCRT   | Service Routine                          |
| SWR     | Panel Switch Register                    |
| TM      | Table Memory                             |
| TMA     | Table Memory Address Register            |
| TMRAM   | Writable Table Memory (Random Access)    |
| VALUE   | Command Buffer Value                     |
| WC      | Word Count Register                      |

APPENDIX B  
LIST OF TERMS AND USAGE

The following terms and abbreviations are used throughout Part III to facilitate instruction descriptions.

| <u>TERM/ABBREVIATION</u> | <u>MEANING</u>                | <u>USAGE</u>                                                                                                                                     |
|--------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| <>                       | Optional Instruction Mnemonic | Elements or operands contained within are optional.<br>e.g.<br>ADD < sh >< # > < & > 5,6<br>If no <>, then listed operands are mandatory.        |
| &                        | BIT-REVERSE Operator          | When specified, this symbol immediately precedes the SP <sub>SPS</sub> operand.<br>e.g.<br>ADD &sub, base<br>(See S-PAD SUMMARY, SPFN MODIFIERS) |
| sh                       | S-PAD Shift Operator          | Indicates one of 4 S-PAD shift options:<br>e.g.<br>SUB< sh > 5,6<br>(See S-PAD SUMMARY, SPFN MODIFIERS)                                          |
| #                        | S-PAD NO-LOAD Operator        | Indicates that normal (SPFN) → SP <sub>SPD</sub> operation is inhibited.<br>e.g.<br>MOV# 5,5                                                     |
| sps                      | S-PAD Source Register         | Indicates currently designated S-PAD DESTINATION REGISTER.<br>e.g.<br>ADD sps, spd<br>(See S-PAD SUMMARY, S-PAD OPERANDS)                        |

|      |                       |                                                                                                                                                                                                                                                                                        |
|------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| targ | BRANCH TARGET ADDRESS | An address contained in the DISP field of the instruction word within a range of -20 <sub>8</sub> to +17 <sub>8</sub> locations relative to the current program location; by name, number, or expression.<br>e.g.<br>BR targ<br>(See SPEC SUMMARY, Test, Branch, and Jump Operations). |
| adr  | ADDRESS               | Address contained in Value field of instruction word. May be used for both absolute and relative addressing operations.<br>(See SPEC SUMMARY, Test, Branch, and Jump Operations).<br>e.g.<br>JMP adr                                                                                   |
| idx  | DATA-PAD Index        | DATA-PAD location specifier; by name, number, or expression, within -4 to +3 locations relative to current DPA.<br>e.g.<br>DPY(idx) < FA                                                                                                                                               |
| val  | value                 | Numeric value contained in the VALUE field of the current instruction word.                                                                                                                                                                                                            |
| a1   | A1 source operand     | Indicates currently selected A1 REGISTER source operand.                                                                                                                                                                                                                               |
| a2   | A2 source operand     | Indicates currently selected A2 REGISTER source operand.<br>e.g.<br>FADD a1, a2                                                                                                                                                                                                        |

|    |                   |                                                                               |
|----|-------------------|-------------------------------------------------------------------------------|
| m1 | M1 source-operand | Indicates currently selected M1 register source-operand.                      |
| m2 | M2 source-operand | Indicates currently selected M2 register source-operand<br>e.g.<br>FMUL m1,m2 |

## APPENDIX C

### LIST OF FUNCTIONS

| FUNCTION OPERATOR | FUNCTION                                                     | MEANING                                                                                                                                                                                                                                                                                   |
|-------------------|--------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| +                 | PLUS                                                         | Additive; A plus B                                                                                                                                                                                                                                                                        |
| -                 | MINUS                                                        | Subtractive; A plus B                                                                                                                                                                                                                                                                     |
| EQV               | EQUIVALENCE<br>(NOT Exclusive OR)                            | If A=B, then C=1;<br>if A=B, then C=0.                                                                                                                                                                                                                                                    |
| AND               | AND                                                          | Indicates that both elements must be present to satisfy the test condition.                                                                                                                                                                                                               |
| OR                | OR                                                           | Indicates that any one or both element(s) present satisfies the test condition.                                                                                                                                                                                                           |
| ( )               | Contents of a Register or Data currently enabled onto a bus. | Used to describe Register Transfers in the following manner:<br><br>(A2) DPX(idx)<br>Meaning: The contents of A2 register replace the contents of DPX(idx).                                                                                                                               |
| superscripts      | indicates portion of larger elements.                        | Example:<br><br>Q1<br>PS<br>Meaning: Quarter-one (bits 16-31) of the PROGRAM-SOURCE word.<br>Note: To avoid double-superscripting, the following convention is observed:<br><br>Q1<br>PS bits 23-27<br>Meaning: Bits 23 through 27 of the QUARTER-ONE portion of the PROGRAM-SOURCE word. |

|                   |                                         |                                                                                                                                                                                                                                                      |
|-------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| arg<br>subscripts | logical complement<br>"as addressed by" | e.g., SP(SPS)<br>Example:<br>PS<br>TMA<br>Meaning: PROGRAM-SOURCE<br>word at the location<br>pointed to by the current<br>contents of TABLE MEMORY<br>ADDRESS REGISTER (TMA).<br>Note: For addressing<br>subscripts, the ( )<br>operator is implied. |
|-------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## APPENDIX D

### INSTRUCTION FIELD LAYOUT AND SUMMARY

#### AP-120B INSTRUCTIONS

##### Unconditional Fields

Each of the following fields may be used in any given instruction word.

| Octal Code | Field Name |        |        |        |        |        |       |        |      |      | Octal Code |
|------------|------------|--------|--------|--------|--------|--------|-------|--------|------|------|------------|
|            | B          | SOP    | SOP1   | SH     | SPS    | SPD    | FADD  | FADD1  | A1   | A2   |            |
| 0          | NOP        | SOP1   | NOP    | NOP    | (S-Pad | (S-Pad | FADD1 | NOP    | NC   | NC   | 0          |
| 1          | &          | SPEC   | WRTEXP | L      | Source | Dest.  | FSUBR | FIX    | FM   | FA   | 1          |
| 2          | ADD        | WRTHMN | RR     | Reg.)  | Reg.)  |        | FSUB  | FIXT   | DPX  | DPX  | 2          |
| 3          | SUB        | WRTLMN | R      |        |        |        | FADD  | FSCLT  | DPY  | DPY  | 3          |
| 4          | MOV        | NOP    |        | (0-17) | (0-17) |        | FEQV  | FSM2C  | TM   | MD   | 4          |
| 5          | AND        | NOP    |        |        |        |        | FAND  | F2CSM  | ZERO | ZERO | 5          |
| 6          | OR         | NOP    |        |        |        |        | FOR   | FSCALE | ZERO | MDPX | 6          |
| 7          | EQV        | NOP    |        |        |        |        | IO    | FABS   | ZERO | EDPX | 7          |
| 10         |            | CLR    |        |        |        |        |       |        |      |      | 10         |
| 11         |            | INC    |        |        |        |        |       |        |      |      | 11         |
| 12         |            | DEC    |        |        |        |        |       |        |      |      | 12         |
| 13         |            | COM    |        |        |        |        |       |        |      |      | 13         |
| 14         |            | LDSPNL |        |        |        |        |       |        |      |      | 14         |
| 15         |            | LDSPE  |        |        |        |        |       |        |      |      | 15         |
| 16         |            | LDSPPI |        |        |        |        |       |        |      |      | 16         |
| 17         |            | LDSPT  |        |        |        |        |       |        |      |      | 17         |

| Octal Code | Field Name |         |     |     |        |        |        |        |        |      | Octal Code |
|------------|------------|---------|-----|-----|--------|--------|--------|--------|--------|------|------------|
|            | COND       | DISP    | DPX | DPY | DPBS   | XR     | YR     | XW     | YW     | FM   |            |
| 0          | NOP        | (Branch | NOP | NOP | ZERO   | (DPX   | (DPY   | (DPX   | (DPY   | NOP  | 0          |
| 1          | #          | Displa- | DB  | DB  | INBS   | Read   | Read   | Write  | Write  | FMUL | 1          |
| 2          | BR         | cement) | FA  | FA  | VALUE* | Index) | Index) | Index) | Index) |      | 2          |
| 3          | BINTRQ     | (0-37)  | FM  | FM  | DPX    |        |        |        |        |      | 3          |
| 4          | BION       |         |     |     | DPY    | (0-7)  | (0-7)  | (0-7)  | (0-7)  |      | 4          |
| 5          | BIOZ       |         |     |     | MD     |        |        |        |        |      | 5          |
| 6          | BFPE       |         |     |     | SPFN   |        |        |        |        |      | 6          |
| 7          | RETURN     |         |     |     | TM     |        |        |        |        |      | 7          |
| 10         | BFEQ       |         |     |     |        |        |        |        |        |      | 10         |
| 11         | BFNE       |         |     |     |        |        |        |        |        |      | 11         |
| 12         | BFGE       |         |     |     |        |        |        |        |        |      | 12         |
| 13         | BFGT       |         |     |     |        |        |        |        |        |      | 13         |
| 14         | BEQ        |         |     |     |        |        |        |        |        |      | 14         |
| 15         | BNE        |         |     |     |        |        |        |        |        |      | 15         |
| 16         | BGE        |         |     |     |        |        |        |        |        |      | 16         |
| 17         | BGT        |         |     |     |        |        |        |        |        |      | 17         |

| Octal Code | Field Name |     |     |       |        |        | Octal Code |
|------------|------------|-----|-----|-------|--------|--------|------------|
|            | M1         | M2  | MI  | MA    | DPA    | TMA    |            |
| 0          | FM         | FA  | NOP | NOP   | NOP    | NOP    | 0          |
| 1          | DPX        | DPX | FA  | INCMA | INCDPA | INCTMA | 1          |
| 2          | DPY        | DPY | FM  | DECMA | DECDPA | DECTMA | 2          |
| 3          | TM         | MD  | DB  | SETMA | SETDPA | SETTMA | 3          |

\* This instruction uses a 16-bit immediate VALUE as a constant or address (in bits 48-63 of this instruction). The YW, FM, M1, M2, MI, TMA and DPA fields are then disabled for this instruction word.

### SPEC Fields

One of the SPEC Fields may be used per instruction word. The S-PAD Fields (B, SOP, SOP1, SH, SPS, and SPD) are then disabled for this instruction.

| Octal<br>Code | Field Name |       |         |        |        |        |        | Octal<br>Code |
|---------------|------------|-------|---------|--------|--------|--------|--------|---------------|
|               | SPEC       | STEST | HOSTPNL | SETPSA | PSEVEN | PSODD  | PS     | SETEXIT       |
| 0             | STEST      | BFLT  | PNLLIT  | JMPA*  | RPS0A* | RPS1A* | RPSLA* | NOP           |
| 1             | HOSTPNL    | BLT   | DBELIT  | JSRA*  | RPS2A* | RPS3A* | RPSFA* | SETEXA*       |
| 2             | SPMDA      | BNC   | DBHLIT  | JMP*   | RPS0*  | RPS1*  | RPSL*  | NOP           |
| 3             | NOP        | BZC   | DBLLIT  | JSR*   | RPS2*  | RPS3*  | RPSF*  | SETEX*        |
| 4             | NOP        | BDBN  | NOP     | JMPT   | RPS0T  | RPS1T  | RPSLT  | NOP           |
| 5             | NOP        | BDBZ  | NOP     | JSRT   | RPS2T  | RPS3T  | RPSFT  | SETEXT        |
| 6             | NOP        | BIFN  | NOP     | JMPP   | NOP    | NOP    | RPSLP  | NOP           |
| 7             | NOP        | BIFZ  | NOP     | JSRP   | NOP    | NOP    | RPSFP  | SETEXP        |
| 10            | SETPSA     | NOP   | SWDB    | NOP    | WPS0A* | WPS1A* | LPSLA* | NOP           |
| 11            | PSEVEN     | NOP   | SWDBE   | NOP    | WPS2A* | WPS3A* | LPSRA* | NOP           |
| 12            | PSODD      | NOP   | SWDBH   | NOP    | WPS0*  | WPS1*  | LPSL*  | NOP           |
| 13            | PS         | NOP   | SWDBL   | NOP    | WPS2*  | WPS3*  | LPSR*  | NOP           |
| 14            | SETEXIT    | BFL0  | NOP     | NOP    | WPS0T  | WPS1T  | LPSLT  | NOP           |
| 15            | NOP        | BFL1  | NOP     | NOP    | WPS2T  | WPS3T  | LPSRT  | NOP           |
| 16            | NOP        | BFL2  | NOP     | NOP    | NOP    | NOP    | LPSLP  | NOP           |
| 17            | NOP        | BFL3  | NOP     | NOP    | NOP    | NOP    | LPSRP  | NOP           |

### I/O Fields

One of the I/O fields may be used per instruction word. The Floating Adder Fields (FADD, FADD1, A1, and A2) are then disabled for this instruction word.

| Octal<br>Code | Field Names |       |       |        |        |      |         | Octal<br>Code |
|---------------|-------------|-------|-------|--------|--------|------|---------|---------------|
|               | IO          | LDREG | RDREG | INOUT  | SENSE  | FLAG | CONTROL |               |
| 0             | LDREG       | NOP   | RPSA  | OUT    | SNSA   | SFL0 | HALT    |               |
| 1             | RDREG       | LDSPD | RSPD  | SPNOUT | SPINA  | SFL1 | IORST   | 1             |
| 2             | SPMDAV      | LDMA  | RMA   | OUTDA  | SNSADA | SFL2 | INTEN   | 2             |
| 3             | REXIT       | LDTMA | RTMA  | SPOTDA | SPNADA | SFL3 | INTA    | 3             |
| 4             | INOUT       | LDPPA | RDPA  | IN     | SNSB   | CFL0 | REFR    | 4             |
| 5             | SENSE       | LDSP  | RSPFN | SPININ | SPINB  | CFL1 | WRTEX   | 5             |
| 6             | FLAG        | LDAPS | RAPS  | INDA   | SNSBDA | CFL2 | WRTMAN  | 6             |
| 7             | CONTROL     | LDDA  | RDA   | SPINDA | SPNDBA | CFL3 | NOP     | 7             |

\* This instruction uses a 16-bit integer VALUE (in bits 48-63 of the instruction word). The YW, FM, M1, M2, MI, MA, TMA, and DPA Fields are then disabled for this instruction word.

## AP-120B Instruction Field Layout

三

S-PAD GROUP

|      |     |   |    |   |     |   |     |    |
|------|-----|---|----|---|-----|---|-----|----|
| 0    | 1   | 3 | 4  | 5 | 6   | 9 | 10  | 13 |
| B    | SOP |   | SH |   | SPS |   | SPD |    |
| SOP1 |     |   |    |   |     |   |     |    |

| Field | Octal<br>Code     | Mnemonic          | Effect                                                                                   |
|-------|-------------------|-------------------|------------------------------------------------------------------------------------------|
| B     | Ø                 | -                 | No-Op                                                                                    |
|       | 1                 | &                 | Use SP <sub>SPS</sub> (bit-reversed)                                                     |
| SOP   | Ø                 | -                 | See SOP1 field                                                                           |
|       | 1                 | -                 | See Special Operations Group                                                             |
|       | 2                 | ADD               | (SP <sub>SPD</sub> ) + (SP <sub>SPS</sub> ) → SPFN                                       |
|       | 3                 | SUB               | (SP <sub>SPD</sub> ) - (SP <sub>SPS</sub> ) → SPFN                                       |
|       | 4                 | MOV               | (SP <sub>SPS</sub> ) → SPFN                                                              |
|       | 5                 | AND               | (SP <sub>SPD</sub> ) AND (SP <sub>SPS</sub> ) → SPFN                                     |
|       | 6                 | OR                | (SP <sub>SPD</sub> ) OR (SP <sub>SPS</sub> ) → SPFN                                      |
|       | 7                 | EQV               | (SP <sub>SPD</sub> ) XOR (SP <sub>SPS</sub> ) → SPFN                                     |
| * SH  | Ø                 | -                 | No-Op                                                                                    |
|       | 1                 | L                 | SPFN * 2 → SPFN (left shift)                                                             |
|       | 2                 | RR                | SPFN ÷ 4 → SPFN (double right shift)                                                     |
|       | 3                 | R                 | SPFN ÷ 2 → SPFN (right shift)                                                            |
| SPS   | 0-17 <sub>8</sub> | 0-17 <sub>8</sub> | S-Pad Source Operand Address                                                             |
| SPD   | 0-17 <sub>8</sub> | 0-17 <sub>8</sub> | S-Pad Destination Address, SPFN → <sup>SP</sup> SPD unless inhibited by No Load (COND=1) |

\*Note: These are logical shifts:



| Field | Octal Code | Mnemonic | Effect                                                                  |
|-------|------------|----------|-------------------------------------------------------------------------|
| SOP1  | 0          | -        | No-Op                                                                   |
|       | 1          | WRTEXP   | Restricts DPX, DPY & MI fields to Write Exponent Only                   |
|       | 2          | WRTHMN   | Restricts DPX, DPY & MI fields to Write High Mantissa Only (Bits 00-11) |
|       | 3          | WRTLTMN  | Restricts DPX, DPY & MI fields to Write Low Mantissa Only (Bits 12-27)  |
|       | 4          | -        | -                                                                       |
|       | 5          | -        | -                                                                       |
|       | 6          | -        | -                                                                       |
|       | 7          | -        | -                                                                       |
|       | 10         | CLR      | $\emptyset \rightarrow SPFN$                                            |
|       | 11         | INC      | $(SP_{SPD}) + 1 \rightarrow SPFN$                                       |
|       | 12         | DEC      | $(SP_{SPD}) - 1 \rightarrow SPFN$                                       |
|       | 13         | COM      | $\overline{(SP_{SPD})} \rightarrow SPFN$                                |
|       | 14         | LDSPNL   | $SP_{SPD} \rightarrow SPFN, PNLBS \leftrightarrow SP_{SPD}$             |
|       | 15         | LDSPE    | $SP_{SPD} \rightarrow SPFN, DPBS^E - 512 \rightarrow SP_{SPD}$          |
|       | 16         | LDSPI    | $SP_{SPD} \rightarrow SPFN, DPBS^{ML} \rightarrow SP_{SPD}$             |
|       | 17         | LDSPT    | $SP_{SPD} \rightarrow SPFN, DPBS^{MT} \rightarrow SP_{SPD}$             |

MH=Mantissa High=Mantissa bits 00-11

ML=Mantissa Low=Mantissa bits 12-27

MT=Mantissa bits for table lookups=Mantissa bits 02-08

E=Exponent

SPECIAL OPERATIONS GROUP

| 1 | 3 | 6 | 9    | 10      | 13 |
|---|---|---|------|---------|----|
| Ø | Ø | 1 | SPEC | STEST   |    |
|   |   |   |      | HOSTPNL |    |
|   |   |   |      | SETPSA  |    |
|   |   |   |      | PSEVEN  |    |
|   |   |   |      | PSODD   |    |
|   |   |   |      | PS      |    |
|   |   |   |      | SETEXIT |    |

| Field | Octal<br>Code | Mnemonic | Effect                                              |
|-------|---------------|----------|-----------------------------------------------------|
| SPEC  | Ø             | -        | See STEST Field (B-6)                               |
| 1     | -             | -        | See HOSTPNL Field (B-7)                             |
| 2     | SPMDA         | -        | Spin until MD available                             |
| 3     | -             | -        |                                                     |
| 4     | -             | -        |                                                     |
| 5     | -             | -        |                                                     |
| 6     | -             | -        |                                                     |
| 7     | -             | -        |                                                     |
| 10    | -             | -        | See SETPSA Field, inhibit TEST except No Load (B-8) |
| 11    | -             | -        | See PSEVEN Field (B-9)                              |
| 12    | -             | -        | See PSODD Field (B-10)                              |
| 13    | -             | -        | See PS Field (B-11)                                 |
| 14    | -             | -        | See SETEXIT Field (E-12)                            |
| 15    | -             | -        |                                                     |
| 16    | -             | -        |                                                     |
| 17    | -             | -        |                                                     |

| Field | Octal<br>Code | Mnemonic | Effect                                   |
|-------|---------------|----------|------------------------------------------|
| STEST | 0             | BFLT     | Branch if FA<0.0                         |
|       | 1             | BLT      | Branch if SPFN<0                         |
|       | 2             | BNC      | Branch if S-Pad carry bit=1              |
|       | 3             | BZC      | Branch if S-Pad carry bit=0              |
|       | 4             | BDBN     | Branch if DPBS<0.0                       |
|       | 5             | BDBZ     | Branch if DPBS positive and unnormalized |
|       | 6             | BIFN     | Branch if Inverse FFT flag=1             |
|       | 7             | BIFZ     | Branch if Inverse FFT flag=0             |
|       | 10            | --       | --                                       |
|       | 11            | --       | --                                       |
|       | 12            | --       | --                                       |
|       | 13            | --       | --                                       |
|       | 14            | BFL0     | Branch if Flag 0=1                       |
|       | 15            | BFL1     | Branch if Flag 1=1                       |
|       | 16            | BFL2     | Branch if Flag 2=1                       |
|       | 17            | BFL3     | Branch if Flag 3=1                       |

If the above specified condition is true OR the condition specified in the COND field is true, a branch occurs to (PSA)+DISP-20

| <u>Field</u> | <u>Octal<br/>Code</u> | <u>Mnemonic</u> | <u>Effect</u>                                   |
|--------------|-----------------------|-----------------|-------------------------------------------------|
| HOSTPNL      | 0                     | PNLLIT          | PNLBS → LITES                                   |
|              | 1                     | DBELIT          | DPBS <sup>E</sup> → PNLBS → LITES               |
|              | 2                     | DBHLIT          | DPBS <sup>MH</sup> → PNLBS → LITES              |
|              | 3                     | DBLLIT          | DPBS <sup>ML</sup> → PNLBS → LITES              |
|              | 4                     | -               | -                                               |
|              | 5                     | -               | -                                               |
|              | 6                     | -               | -                                               |
|              | 7                     | -               | -                                               |
|              | 10                    | SWDB            | (SWR) → PNLBS → DPBS                            |
|              | 11                    | SWDBE           | (SWR) → PNLBS → DPBS <sup>E</sup> and WRTEXP*   |
|              | 12                    | SWDBH           | (SWR) → PNLBS → DPBS <sup>MH</sup> and WRTHMN * |
|              | 13                    | SWDBL           | (SWR) → PNLBS → DPBS <sup>ML</sup> and WRTLBN * |
|              | 14                    | -               | -                                               |
|              | 15                    | -               | -                                               |
|              | 16                    | -               | -                                               |
|              | 17                    | -               | -                                               |

\*Restrict DPS, DPY and MI to:

WRTEXP: Write Exponent only

WRTHMN : Write High Mantissa  
only (bits 00-11)

WRTLBN : Write Low Mantissa  
only (bits 12-27)

MH=Mantissa High=Mantissa bits 00-11

ML=Mantissa Low =Mantissa bits 12-27

E=Exponent

| Field  | Octal<br>Code | Mnemonic | Effect                                                                                                |
|--------|---------------|----------|-------------------------------------------------------------------------------------------------------|
| SETPSA | 0             | JMPA     | VALUE $\rightarrow$ PSA                                                                               |
|        | 1             | JSRA     | (SRA)+1 $\rightarrow$ SRA, (PSA)+1 $\rightarrow$ SRS SRA, VALUE $\rightarrow$ PSA                     |
|        | 2             | JMP      | VALUE+(PSA) $\rightarrow$ PSA                                                                         |
|        | 3             | JSR      | (SRA)+1 $\rightarrow$ SRA, (PSA)+1 $\rightarrow$ SRS SRA, VALUE+(PSA) $\rightarrow$ PSA               |
|        | 4             | JMPT     | (TMA) $\rightarrow$ PSA                                                                               |
|        | 5             | JSRT     | (SRA)+1 $\rightarrow$ SRA, (PSA)+1 $\rightarrow$ SRS SRA, (TMA) $\rightarrow$ PSA                     |
|        | 6             | JMPP     | (SWR) $\rightarrow$ PNLBS $\rightarrow$ PSA                                                           |
|        | 7             | JSRP     | (SRA)+1 $\rightarrow$ SRA, (PSA)+1 $\rightarrow$ SRS SRA, (SWR) $\rightarrow$ PNLBS $\rightarrow$ PSA |

VALUE=Bits 48-63 of this instruction (CB48-CB63)

| Field  | Octal<br>Code | Mnemonic | Effect                                                  |
|--------|---------------|----------|---------------------------------------------------------|
| PSEVEN | 0             | RPSØA    | (PS <sup>QØ</sup> <sub>VALUE</sub> ) → PNLBS+ LITES     |
|        | 1             | RPS2A    | (PS <sup>Q2</sup> <sub>VALUE</sub> ) → PNLBS+ LITES     |
|        | 2             | RPSØ     | (PS <sup>QØ</sup> <sub>VALUE+PSA</sub> ) → PNLBS+ LITES |
|        | 3             | RPS2     | (PS <sup>Q2</sup> <sub>VALUE+PSA</sub> ) → PNLBS+ LITES |
|        | 4             | RPSØT    | (PS <sup>QØ</sup> <sub>TMA</sub> ) → PNLBS+ LITES       |
|        | 5             | RPS2T    | (PS <sup>Q2</sup> <sub>TMA</sub> ) → PNLBS+ LITES       |
|        | 6             | -        | -                                                       |
|        | 7             | -        | -                                                       |
|        | 10            | WPSØA    | (SWR) → PNLBS+ PS <sup>QØ</sup> <sub>VALUE</sub>        |
|        | 11            | WPS2A    | (SWR) → PNLBS+ PS <sup>Q2</sup> <sub>VALUE</sub>        |
|        | 12            | WPSØ     | (SWR) → PNLBS+ PS <sup>QØ</sup> <sub>VALUE+PSA</sub>    |
|        | 13            | WPS2     | (SWR) → PNLBS+ PS <sup>Q2</sup> <sub>VALUE+PSA</sub>    |
|        | 14            | WPSØT    | (SWR) → PNLBS+ PS <sup>QØ</sup> <sub>TMA</sub>          |
|        | 15            | WPS2T    | (SWR) → PNLBS+ PS <sup>Q2</sup> <sub>TMA</sub>          |
|        | 16            | -        | -                                                       |
|        | 17            | -        | -                                                       |

This field requires 2 cycles to execute

VALUE = Bits 48-63 of this instruction (CB48-CB63)

QØ = Quarter zero of Program Source Word (PSØØ-PS15)

Q2 = Quarter two of Program Source Word (PS31-PS47)

| Field | Octal<br>Code | Mnemonic | Effect                                                |
|-------|---------------|----------|-------------------------------------------------------|
| PSODD | 0             | RPS1A    | (PS <sup>Q1</sup> <sub>VALUE</sub> )→PNLBS→ LITES     |
|       | 1             | RPS3A    | (PS <sup>Q3</sup> <sub>VALUE</sub> )→PNLBS→ LITES     |
|       | 2             | RPS1     | (PS <sup>Q1</sup> <sub>VALUE+PSA</sub> )→PNLBS→ LITES |
|       | 3             | RPS3     | (PS <sup>Q3</sup> <sub>VALUE+PSA</sub> )→PNLBS→ LITES |
|       | 4             | RPS1T    | (PS <sup>Q1</sup> <sub>TMA</sub> )→PNLBS→ LITES       |
|       | 5             | RPS3T    | (PS <sup>Q3</sup> <sub>TMA</sub> )→PNLBS→ LITES       |
|       | 6             | -        | -                                                     |
|       | 7             | -        | -                                                     |
|       | 10            | WPS1A    | (SWR) →PNLBS→PS <sup>Q1</sup> <sub>VALUE</sub>        |
|       | 11            | WPS3A    | (SWR) →PNLBS→PS <sup>Q3</sup> <sub>VALUE</sub>        |
|       | 12            | WPS1     | (SWR) →PNLBS→PS <sup>Q1</sup> <sub>VALUE+PSA</sub>    |
|       | 13            | WPS3     | (SWR) →PNLBS→PS <sup>Q3</sup> <sub>VALUE+PSA</sub>    |
|       | 14            | WPS1T    | (SWR) →PNLBS→PS <sup>Q1</sup> <sub>TMA</sub>          |
|       | 15            | WPS3T    | (SWR) →PNLBS→PS <sup>Q3</sup> <sub>TMA</sub>          |
|       | 16            | -        | -                                                     |
|       | 17            | -        | -                                                     |

This field requires 2 cycles to execute.

VALUE=Bits 48-63 of this instruction (CB48-CB63)

Q1=Quarter one of Program Source Word (PS16-PS31)

Q3=Quarter three of Program Source Word (PS48-PS63)

| Field | Octal Code | Mnemonic | Effect                                          |
|-------|------------|----------|-------------------------------------------------|
| PS    | 0          | RPSLA    | (PS <sup>LH</sup> <sub>VALUE</sub> ) → DPBS     |
|       | 1          | RPSFA    | (PS <sup>FP</sup> <sub>VALUE</sub> ) → DPBS     |
|       | 2          | RPSL     | (PS <sup>LH</sup> <sub>VALUE+PSA</sub> ) → DPBS |
|       | 3          | RPSF     | (PS <sup>FP</sup> <sub>VALUE+PSA</sub> ) → DPBS |
|       | 4          | RPSLT    | (PS <sup>LH</sup> <sub>TMA</sub> ) → DPBS       |
|       | 5          | RPSFT    | (PS <sup>FP</sup> <sub>TMA</sub> ) → DPBS       |
|       | 6          | RPSLP    | (PS <sup>LH</sup> <sub>PNLBS</sub> ) → DPBS     |
|       | 7          | RPSFP    | (PS <sup>FP</sup> <sub>PNLBS</sub> ) → DPBS     |
|       | 10         | LPSLA    | DPBS → PS <sup>LH</sup> <sub>VALUE</sub>        |
|       | 11         | LPSRA    | DPBS → PS <sup>RH</sup> <sub>VALUE</sub>        |
|       | 12         | LPSL     | DPBS → PS <sup>LH</sup> <sub>VALUE+PSA</sub>    |
|       | 13         | LPSR     | DPBS → PS <sup>RH</sup> <sub>VALUE+BA</sub>     |
|       | 14         | LPSLT    | DPBS → PS <sup>LH</sup> <sub>TMA</sub>          |
|       | 15         | LPSRT    | DPBS → PS <sup>RH</sup> <sub>TMA</sub>          |
|       | 16         | LPSLP    | DPBS → PS <sup>LH</sup> <sub>PNLBS</sub>        |
|       | 17         | LPSRP    | DPBS → PS <sup>RH</sup> <sub>PNLBS</sub>        |

This field requires 2 cycles to execute.

VALUE=Bits 48-63 of this instruction (CB48-CB63)

LH=Left half of Program Source Word (Bits 00-31)

RH=Right half of Program Source Word (Bits 32-63)

FP=Program Source bits 26-63, used for floating-point literals

| Field   | Octal<br>Code | Mnemonic | Effect                                       |
|---------|---------------|----------|----------------------------------------------|
| SETEXIT | 0             | -        | -                                            |
|         | 1             | SETEXA   | VALUE $\rightarrow$ SRS <sub>SRA</sub>       |
|         | 2             | -        | -                                            |
|         | 3             | SETEX    | VALUE+(PSA) $\rightarrow$ SRS <sub>SRA</sub> |
|         | 4             | -        | -                                            |
|         | 5             | SETEXT   | TMA $\rightarrow$ SRS <sub>SRA</sub>         |
|         | 6             | -        | -                                            |
|         | 7             | SETEXP   | PSA+1 $\rightarrow$ SRS <sub>SRA</sub>       |

Sets the current subroutine return address as indicated above.

SRA does not change.

VALUE=Bits 48-63 of this instruction.

### FLOATING ADDER GROUP

|      |    |       |    |    |    |
|------|----|-------|----|----|----|
| 14   | 16 | 17    | 19 | 20 | 22 |
| FADD |    | A1    |    | A2 |    |
|      |    | FADD1 |    |    |    |

| Field | Octal Code | Mnemonic | Effect                                        |
|-------|------------|----------|-----------------------------------------------|
| FADD  | Ø          | -        | See FADD1 field                               |
|       | 1          | FSUBR    | Subtract: (A2) - (A1)                         |
|       | 2          | FSUB     | Subtract: (A1) - (A2)                         |
|       | 3          | FADD     | Add: (A1) + (A2)                              |
|       | 4          | FEQV     | Logical Equivalence: (A1) <del>XOR</del> (A2) |
|       | 5          | FAND     | Logical and: (A1) AND (A2)                    |
|       | 6          | FOR      | Logical or: (A1) OR (A2)                      |
|       | 7          | -        | See I/O Group                                 |
| A1    | Ø          | NC       | (A1) → A1                                     |
|       | 1          | FM       | FM → A1                                       |
|       | 2          | DPX(1DX) | (DPX <sub>DPA+1DX</sub> ) → A1 Where XR=1DX+4 |
|       | 3          | DPY(1DX) | (DPY <sub>DPA+1DX</sub> ) → A1 Where YR=1DX+4 |
|       | 4          | TM       | (TM) → A1                                     |
|       | 5          | ZERO     | Ø Ø → A1                                      |
|       | 6          | -        | -                                             |
|       | 7          | -        | -                                             |

Note: All floating adder op-codes:

1. Align exponents
2. Perform the specified arithmetic, logical, or shift operation
3. Normalize
4. Convergently round

| Field | Octal Code | Mnemonic   | Effect                                                                                                              |
|-------|------------|------------|---------------------------------------------------------------------------------------------------------------------|
| A2    | 0          | NC         | (A2)→A2                                                                                                             |
|       | 1          | FA         | FA→A2                                                                                                               |
|       | 2          | DPX (1DX)  | (DPX <sub>DPA+1DX</sub> )→A2, Where XR=1DX+4                                                                        |
|       | 3          | DPY (1DX)  | (DPY <sub>DPA+1DX</sub> )→A2, Where YR=1DX+4                                                                        |
|       | 4          | MD         | (MD)→A2                                                                                                             |
|       | 5          | ZERO       | 0.0→A2                                                                                                              |
|       | 6          | MDPX (1DX) | SPFN+512+A2 <sup>E</sup> , (DPX <sup>M</sup> <sub>DPA+1DX</sub> )→A2 <sup>M</sup>                                   |
|       | 7          | EDPX (1DX) | (DPX <sup>E</sup> <sub>DPA+1DX</sub> )→A2 <sup>E</sup> , SPFN→A2 <sup>M</sup> (00-01),<br>0→A2 <sup>M</sup> (02-27) |
| ADD1  | 0          | -          | No-Op                                                                                                               |
|       | 1          | FIX        | Convert (A2) to an integer                                                                                          |
|       | 2          | FIXT       | Convert (A2) to an integer (result truncated)                                                                       |
|       | 3          | FSCLT      | Shift (A2) right and increment A2 <sup>E</sup> until A2 <sup>E</sup> =(SPFN+511) (result truncated).                |
|       | 4          | FSM2C      | Convert (A2), from signed Magnitude to 2's complement.                                                              |
|       | 5          | F2CSM      | Convert (A2) from 2's complement to signed magnitude.                                                               |
|       | 6          | FSCALE     | Shift (A2) right and increment A2 <sup>E</sup> until A2 <sup>E</sup> =SPFN+511.                                     |
|       | 7          | FABS       | Take the absolute value of (A2).                                                                                    |

## I/O GROUP

| 14 | 16 | 17 | 19  | 20      | 22 |
|----|----|----|-----|---------|----|
| 1  | 1  | 1  | I/O | LDREG   |    |
|    |    |    |     | RDREG   |    |
|    |    |    |     | INOUT   |    |
|    |    |    |     | SENSE   |    |
|    |    |    |     | FLAG    |    |
|    |    |    |     | CONTROL |    |

| Field | Octal<br>Code | Mnemonic | Effect                                          |
|-------|---------------|----------|-------------------------------------------------|
| I/O   | Ø             | -        | See LDREG field                                 |
|       | 1             | -        | See RDREG field                                 |
|       | 2             | SPMDAV   | Spin until MD available                         |
|       | 3             | REXIT    | SRS (SRA) → PNLBS (See Note)                    |
|       | 4             | -        | See INOUT field                                 |
|       | 5             | -        | See SENSE field                                 |
|       | 6             | -        | See FLAG field                                  |
|       | 7             | -        | See CONTROL field                               |
| LDREG | Ø             | -        | No-Op                                           |
|       | 1             | LDSPD    | DPBS→SPD                                        |
|       | 2             | LDMA     | DPBS→MA                                         |
|       | 3             | LDTMA    | DPBS→TMA                                        |
|       | 4             | LDDPA    | DPBS→DPA                                        |
|       | 5             | EDSP     | SP <sub>SPD</sub> →SPFN, DPBS→SP <sub>SPD</sub> |
|       | 6             | LDAPS    | DPBS→APSTATUS                                   |
|       | 7             | LDDA     | DPBS→DA                                         |

Note: This is generally used with a LDSPNL to load SRS into S-Pad register. It doesn't affect SRA.

| Field | Octal<br>Code | Mnemonic | Effect                                                                     |
|-------|---------------|----------|----------------------------------------------------------------------------|
| RDREG | Ø             | RPSA     | (PSA)→PNLBS                                                                |
|       | 1             | RSPD     | (SPD)→PNLBS                                                                |
|       | 2             | RMA      | (MA)→PNLBS                                                                 |
|       | 3             | RTMA     | (TMA)→PNLBS                                                                |
|       | 4             | RDPA     | (DPA)→PNLBS                                                                |
|       | 5             | RSPFN    | SPFN→PNLBS                                                                 |
|       | 6             | RAPS     | (APSTATUS)→PNLBS                                                           |
|       | 7             | RDA      | (DA)→PNLBS                                                                 |
| INOUT | Ø             | OUT      | DPBS→IODEVICE <sub>DA</sub>                                                |
|       | 1             | SPNOUT   | SPIN if IODRDY <sub>DA</sub> =Ø<br>DPBS→IODEVICE <sub>DA</sub>             |
|       | 2             | OUTDA    | DPBS→IODEVICE <sub>DA</sub> , SPFN→DA                                      |
|       | 3             | SPOTDA   | SPIN if IODRDY <sub>DA</sub> =Ø, SPFN→DA<br>DPBS→IODEVICE <sub>DA</sub>    |
|       | 4             | IN       | (IODEVICE <sub>DA</sub> )→INBS                                             |
|       | 5             | SPININ   | SPIN if IODRDY <sub>DA</sub> =Ø<br>(IODEVICE <sub>DA</sub> )→INBS          |
|       | 6             | INDA     | (IODEVICE <sub>DA</sub> )→INBS, SPFN→DA                                    |
|       | 7             | SPINDA   | SPIN if IODRDY <sub>DA</sub> =Ø, SPFN→DA<br>(IODEVICE <sub>DA</sub> )→INBS |

| Field | Octal<br>Code | Mnemonic | Effect                                             |
|-------|---------------|----------|----------------------------------------------------|
| SENSE | 0             | SNSA     | A <sub>DA</sub> →IODRDY Flag                       |
|       | 1             | SPINA    | A <sub>DA</sub> →IODRDY, SPIN if IODRDY=0          |
|       | 2             | SNSADA   | A <sub>DA</sub> →IODRDY, SPFN→DA                   |
|       | 3             | SPNADA   | A <sub>DA</sub> →IODRDY, SPIN if IODRDY=0, SPFN→DA |
|       | 4             | SNSB     | B <sub>DA</sub> →IODRDY Flag                       |
|       | 5             | SPINB    | B <sub>DA</sub> →IODRDY, SPIN if IODRDY=0          |
|       | 6             | SNSBDA   | B <sub>DA</sub> →IODRDY, SPFN→DA                   |
|       | 7             | SPNBDA   | B <sub>DA</sub> →IODRDY, SPIN if IODRDY=0, SPFN→DA |

A and B are I/O device dependent conditions, either 1 or 0

|      |   |      |                     |
|------|---|------|---------------------|
| FLAG | 0 | SFL0 | 1→FLAG <sub>0</sub> |
|      | 1 | SFL1 | 1→FLAG <sub>1</sub> |
|      | 2 | SFL2 | 1→FLAG <sub>2</sub> |
|      | 3 | SFL3 | 1→FLAG <sub>3</sub> |
|      | 4 | CFL0 | 0→FLAG <sub>0</sub> |
|      | 5 | CFL1 | 0→FLAG <sub>1</sub> |
|      | 6 | CFL2 | 0→FLAG <sub>2</sub> |
|      | 7 | CFL3 | 0→FLAG <sub>3</sub> |

| Field   | Octal<br>Code | Mnemonic | Effect                                                                      |
|---------|---------------|----------|-----------------------------------------------------------------------------|
| CONTROL | 0             | HALT     | Halt                                                                        |
|         | 1             | IORST    | I/O reset (See note)                                                        |
|         | 2             | INTEN    | Interrupt enable - generates CTL05 Interrupt to Host                        |
|         | 3             | INTA     | Interrupt acknowledge. Device Address of interrupting device put into DPBS. |
|         | 4             | REFR     | Memory refresh sync                                                         |
|         | 5             | WRTEX    | Restricts DPX, DPY & MI to Write exponent only                              |
|         | 6             | WRTMAN   | Restricts DPX, DPY & MI to Write Mantissa Only (Bits 0-27)                  |
|         | 7             | Not Used | ---                                                                         |

Note: This also clears flags.

BRANCH GROUP

|      |      |    |  |    |
|------|------|----|--|----|
| 23   | 26   | 27 |  | 31 |
| COND | DISP |    |  |    |

| Field | Octal<br>Code | Mnemonic | Effect                                                                                       |
|-------|---------------|----------|----------------------------------------------------------------------------------------------|
| COND  | 0             | -        | No-Op                                                                                        |
|       | 1             | #        | Inhibit load of SPFN $\rightarrow$ SP <sub>SPD</sub>                                         |
|       | 2             | BR       | Branch always                                                                                |
|       | 3             | BINTRQ   | Branch if INTRQ (Interrupt Request) flag=1                                                   |
|       | 4             | BION     | Branch if IODRDY <sub>DA</sub> flag=1                                                        |
|       | 5             | BIOZ     | Branch if IODRDY <sub>DA</sub> flag=0                                                        |
|       | 6             | BFPE     | Branch on floating-point arithmetic error (overflow, underflow, or divide by zero)           |
|       | 7             | RETURN   | (SRS <sub>SRA</sub> ) $\rightarrow$ PSA, (SRA)-1 $\rightarrow$ SRA (Subroutine return jump.) |

NOTE: "RETURNS" may not be made in two successive instructions.

|    |      |                                               |
|----|------|-----------------------------------------------|
| 10 | BFEQ | Branch if FA- $\emptyset$ . $\emptyset$       |
| 11 | BFNE | Branch if FA $\neq$ $\emptyset$ . $\emptyset$ |
| 12 | BFGE | Branch if FA $\geq$ $\emptyset$ . $\emptyset$ |
| 13 | BFGT | Branch if FA $>$ $\emptyset$ . $\emptyset$    |
| 14 | BEQ  | Branch if SPFN= $\emptyset$                   |
| 15 | BNE  | Branch if SPFN $\neq$ $\emptyset$             |
| 16 | BGE  | Branch if SPFN $\geq$ $\emptyset$             |
| 17 | BGT  | Branch if SPFN $>$ $\emptyset$                |

Note: FA and SPFN are tested as to their state for the previous instruction.

---

|      |                   |                                                                  |
|------|-------------------|------------------------------------------------------------------|
| DISP | $\emptyset$ to 37 | If branch condition is true, (PSA)<br>$+DISP-20 \rightarrow PSA$ |
|------|-------------------|------------------------------------------------------------------|

Thus the effective Branch Range is -20 to +17 relative to the current instruction.

DATA PAD GROUP

|     |     |      |    |    |    |    |    |    |    |    |    |    |    |
|-----|-----|------|----|----|----|----|----|----|----|----|----|----|----|
| 32  | 33  | 34   | 35 | 36 | 38 | 39 | 41 | 42 | 44 | 45 | 47 | 48 | 50 |
| DPX | DPY | DPBS |    | XR |    | YR |    | XW |    | YW |    |    |    |

| Field | Octal<br>Code | Mnemonic    | Effect                                        |
|-------|---------------|-------------|-----------------------------------------------|
| DPX   | Ø             | -           | No-Op                                         |
|       | 1             | DPX(1DX)<DB | DPBS→*DPX <sub>DPA+1DX</sub> , Where XW=1DX+4 |
|       | 2             | DPX(1DX)<FA | FA→*DPX <sub>DPA+1DX</sub> , Where XW=1DX+4   |
|       | 3             | DPX(1DX)<FM | FM→*DPX <sub>DPX+1DX</sub> , Where XW=1DX+4   |
| DPY   | Ø             | -           | No-Op                                         |
|       | 1             | DPY(1DX)<DB | DPBS→*DPY <sub>DPA+1DX</sub> Where YW=1DX+4   |
|       | 2             | DPY(1DX)<FA | FA→*DPY <sub>DPA+1DX</sub> Where YW=1DX+4     |
|       | 3             | DPY(1DX)<FM | FM→*DPY <sub>DPA+1DX</sub> Where YW=1DX+4     |

\*All bits written unless WRTEXP, WRTHMAN or WRTLMLAN set. See SOP1  
nd HOSTPNL field.

|      |   |             |                                                                                                   |
|------|---|-------------|---------------------------------------------------------------------------------------------------|
| DPBS | Ø | DB=ZERO     | Ø. Ø→DPBS                                                                                         |
|      | 1 | DB=INBS     | INBS→DPBS                                                                                         |
|      | 2 | DB=VALUE    | VALUE→DPBS <sup>E</sup> , VALUE→DPBS <sup>ML</sup> ,<br>sign extended into DPBS <sub>MH</sub>     |
|      | 3 | DB=DPX(1DX) | (DPX <sub>DPA + 1DX</sub> ) →DPBS, Where XR=1DX+4                                                 |
|      | 4 | DB=DPY(1DX) | (DPY <sub>DPA + 1DX</sub> ) →DPBS, Where YR=1DX+4                                                 |
|      | 5 | DB=MD       | (MD) DPBS                                                                                         |
|      | 6 | DB=SPFN     | SPFN + 512→DPBS <sup>E</sup> , SPFN→DPBS <sup>ML</sup> ,<br>sign extended into DPBS <sub>MH</sub> |
|      | 7 | DB=TM       | (TM)→DPBS                                                                                         |

DPBS forced to Ø if HOSTPNL field=10 to 13

ML=Mantissa Low (Mantissa Bits 12-27)

MH=Mantissa High (Mantissa Bits 00-11)

E=Exponent

VALUE is a 16-bit 2's complement number, contained in bits 48-63 of the instruction word.

| Field | Octal<br>Code | Mnemonic | Effect                                                                     |
|-------|---------------|----------|----------------------------------------------------------------------------|
| XR    | Ø to 7        |          | DPX Read EFA is (DPA)+XR-4                                                 |
| YR    | Ø to 7        |          | DPY Read EFA is (DPA)+YR-4                                                 |
| XW    | Ø to 7        |          | DPX Write EFA is (DPA)+XW-4                                                |
| YW    | Ø to 7        |          | DPY Write EFA is (DPA)+YW-4,<br>YW=XW if VALUE is used in<br>another field |

## FLOATING MULTIPLIER GROUP

|    |    |    |    |    |
|----|----|----|----|----|
| 51 | 52 | 53 | 54 | 55 |
| FM | M1 |    | M2 |    |

| Field | Octal Code | Mnemonic  | Effect                                        |
|-------|------------|-----------|-----------------------------------------------|
| FM    | 0          | -         | No-Op                                         |
|       | 1          | FMUL      | Multiply: (M1)*(M2)                           |
| M1    | 0          | FM        | FM→M1                                         |
|       | 1          | DPX (1DX) | (DPX <sub>DPA+ 1DX</sub> )→M1, Where XR=1DX+4 |
|       | 2          | DPY (1DX) | (DPY <sub>DPA+ 1DX</sub> )→M1, Where YR=1DX+4 |
|       | 3          | TM        | (TM)→M1                                       |
| M2    | 0          | FA        | FA→M2                                         |
|       | 1          | DPX (1DX) | (DPX <sub>DPA+ 1DX</sub> )→M2, Where XR=1DX+4 |
|       | 2          | DPY (1DX) | (DPY <sub>DPA+ 1DX</sub> )→M2, Where YR=1DX+4 |
|       | 3          | MD        | (MD)→M2                                       |

Note: These fields are not in effect if VALUE is used in another field.

Arguments that are unnormalized by more than one position will produce incorrect results.

## MEMORY GROUP

|    |    |     |    |     |    |    |    |
|----|----|-----|----|-----|----|----|----|
| 56 | 57 | 58  | 59 | 60  | 61 | 62 | 63 |
| MI | MA | DPA |    | TMA |    |    |    |

| Field | Octal<br>Code | Mnemonic | Effect                               |
|-------|---------------|----------|--------------------------------------|
| MI    | Ø             | -        | No-Op                                |
|       | 1             | MI<FA    | FA→MI, write MI into Data Memory**   |
|       | 2             | MI<FM    | FM→MI, write MI into Data Memory**   |
|       | 3             | MI<DB    | DPBS→MI, write MI into Data Memory** |

\*\*All bits written unless WRTEXP, WRTHMAN or WRTLMLAN is set.  
See SOP1 and HOSTPNL fields.

|    |   |       |                                                                                                         |
|----|---|-------|---------------------------------------------------------------------------------------------------------|
| MA | Ø | -     | No-Op                                                                                                   |
|    | 1 | INCMA | (MA)+1→MA, initiate a Data Memory cycle                                                                 |
|    | 2 | DECMA | (MA)-1→MA, initiate a Data Memory cycle                                                                 |
|    | 3 | SETMA | *SPFN→MA, initiate a Data Memory cycle<br><i>*DPBS is used in place of SPFN if LDREG field is used.</i> |

|     |   |         |             |
|-----|---|---------|-------------|
| DPA | Ø | -       | No-Op       |
|     | 1 | INCDPA  | (DPA)+1→DPA |
|     | 2 | DECDDPA | (DPA)-1→DPA |
|     | 3 | SETDPA  | *SPFN→DPA   |

*\*DPBS is used in place of SPFN if LDREG field is used.*

Note: These fields are not in effect if a value is used by another field. Changes made in MA, TMA, or DPA do not affect the values of these registers used by other fields during the current instruction.

| Field | Octal<br>Code | Mnemonic | Effect                                         |
|-------|---------------|----------|------------------------------------------------|
| TMA   | 0             | -        | No-Op                                          |
|       | 1             | INCTMA   | (TMA)+1→TMA, initiate a read from Table Memory |
|       | 2             | DECTMA   | (TMA)+1→TMA, initiate a read from Table Memory |
|       | 3             | SETTMA   | *SPFN→TMA, initiate a read from Table Memory   |

\*DPBS is used in place of SPFN if LDREG field is used.

Note: These fields are not in effect if a VALUE is used by another field. Changes made in MA, TMA, or DPA do not affect the values of these registers used by other fields during the current instruction.

|    |     |                                          |
|----|-----|------------------------------------------|
| 0  | NOP | Assembler recognizes this mnemonic       |
| to |     | and will insert an all zeros instruction |
| 63 |     | which is a NOP.                          |

INDEX

|              |                           |
|--------------|---------------------------|
| &.....       | D-4                       |
| A1.....      | D-14                      |
| A2.....      | D-15                      |
| ADD.....     | D-4                       |
| AND.....     | D-4                       |
| B.....       | D-4                       |
| BDBN.....    | D-7                       |
| BDBZ.....    | D-7                       |
| BEQ.....     | D-20                      |
| BFEQ.....    | D-20                      |
| BFGE.....    | D-20                      |
| BFGT.....    | D-20                      |
| BFL0.....    | D-7                       |
| BFL1.....    | D-7                       |
| BFL2.....    | D-7                       |
| BFL3.....    | D-7                       |
| BFLT.....    | D-7                       |
| BFNE.....    | D-20                      |
| BFPE.....    | D-20                      |
| BGE.....     | D-20                      |
| BGT.....     | D-20                      |
| BIFN.....    | D-7                       |
| BIFZ.....    | D-7                       |
| BINTRQ.....  | D-20                      |
| BION.....    | D-20                      |
| BIOZ.....    | D-20                      |
| BLT.....     | D-7                       |
| BNC.....     | D-7                       |
| BNE.....     | D-20                      |
| BR.....      | D-20                      |
| BZC.....     | D-7                       |
| CFL0.....    | D-18                      |
| CFL1.....    | D-18                      |
| CFL2.....    | D-18                      |
| CFL3.....    | D-18                      |
| CLR.....     | D-5                       |
| COM.....     | D-5                       |
| COND.....    | D-20                      |
| CONTROL..... | D-19                      |
| DB.....      | D-21                      |
| DBELIT.....  | D-8                       |
| DBHLIT.....  | D-8                       |
| DBLLIT.....  | D-8                       |
| DEC.....     | D-5                       |
| DECDPA.....  | D-24                      |
| DECMA.....   | D-24                      |
| DECTMA.....  | D-25                      |
| DISP.....    | D-20                      |
| DPA.....     | D-24                      |
| DPBS.....    | D-21                      |
| DPX.....     | D-14, D-15,<br>D-21, D-23 |
| DPY.....     | D-14, D-15,<br>D-21, D-23 |
| EDPX.....    | D-15                      |
| EQV.....     | D-4                       |
| F2CSM.....   | D-15                      |
| FA.....      | D-15, D-24                |
| FABS.....    | D-15                      |
| FADD.....    | D-14                      |
| FADD1.....   | D-15                      |
| FAND.....    | D-14                      |
| FEQV.....    | D-14                      |
| FIX.....     | D-15                      |
| FIXT.....    | D-15                      |
| FLAG.....    | D-18                      |
| FM.....      | D-14, D-23,<br>D-24       |
| FMUL.....    | D-23                      |
| FOR.....     | D-14                      |
| FSCALE.....  | D-15                      |
| FSCLT.....   | D-15                      |
| FSM2C.....   | D-15                      |
| FSUB.....    | D-14                      |
| FSUBR.....   | D-14                      |
| HALT.....    | D-19                      |
| HOSTPNL..... | D-8                       |
| IN.....      | D-17                      |
| INBS.....    | D-21                      |
| INC.....     | D-5                       |
| INCDPA.....  | D-24                      |
| INCMA.....   | D-24                      |
| INCTMA.....  | D-25                      |
| INDA.....    | D-17                      |
| INOUT.....   | D-17                      |
| INTA.....    | D-19                      |
| INTEN.....   | D-19                      |
| IO.....      | D-16                      |
| IORST.....   | D-19                      |
| JMP.....     | D-9                       |

|             |                     |              |      |
|-------------|---------------------|--------------|------|
| JMPA.....   | D-9                 | RDPA.....    | D-17 |
| JMPP.....   | D-9                 | RDREG.....   | D-17 |
| JMPT.....   | D-9                 | REFR.....    | D-19 |
| JSR.....    | D-9                 | RETURN.....  | D-20 |
| JSRA.....   | D-9                 | REXIT.....   | D-16 |
| JSRP.....   | D-9                 | RMA.....     | D-17 |
| JSRT.....   | D-9                 | RPSO.....    | D-10 |
| L.....      | D-4                 | RPSOA.....   | D-10 |
| LDAPS.....  | D-16                | RPSOT.....   | D-10 |
| LDDA.....   | D-16                | RPS1.....    | D-11 |
| LDDPA.....  | D-16                | RPS1A.....   | D-11 |
| LDMA.....   | D-16                | RPS1T.....   | D-11 |
| LDREG.....  | D-16                | RPS2.....    | D-10 |
| LDSP.....   | D-16                | RPS2A.....   | D-10 |
| LDSPD.....  | D-16                | RPS2T.....   | D-10 |
| LDSPE.....  | D-5                 | RPS3.....    | D-11 |
| LDSPI.....  | D-5                 | RPS3A.....   | D-11 |
| LDSPNL..... | D-5                 | RPS3T.....   | D-11 |
| LDSPT.....  | D-5                 | RPSA.....    | D-17 |
| LDTMA.....  | D-16                | RPSF.....    | D-12 |
| LPSL.....   | D-12                | RPSFA.....   | D-12 |
| LPSLA.....  | D-12                | RPSFP.....   | D-12 |
| LPSLP.....  | D-12                | RPSFT.....   | D-12 |
| LPSLT.....  | D-12                | RPSL.....    | D-12 |
| LPSR.....   | D-12                | RPSLA.....   | D-12 |
| LPSRA.....  | D-12                | RPSLP.....   | D-12 |
| LPSRP.....  | D-12                | RPSLT.....   | D-12 |
| LPSRT.....  | D-12                | RR.....      | D-4  |
| M1.....     | D-23                | RSPD.....    | D-17 |
| M2.....     | D-23                | RSPFN.....   | D-17 |
| MA.....     | D-24                | RTMA.....    | D-17 |
| MD.....     | D-15, D-21,<br>D-23 | SENSE.....   | D-18 |
| MDPX.....   | D-15                | SETDPA.....  | D-24 |
| MI.....     | D-24                | SETEX.....   | D-13 |
| MOV.....    | D-4                 | SETEXA.....  | D-13 |
| NC.....     | D-14, D-15          | SETEXIT..... | D-13 |
| NOP.....    | D-25                | SETEXP.....  | D-13 |
| OR.....     | D-4                 | SETEXT.....  | D-13 |
| OUT.....    | D-17                | SETMA.....   | D-24 |
| OUTDA.....  | D-17                | SETSPA.....  | D-9  |
| PNLLIT..... | D-8                 | SETTMA.....  | D-25 |
| PS.....     | D-12                | SFL0.....    | D-18 |
| PSEVEN..... | D-10                | SFL1.....    | D-18 |
| PSODD.....  | D-11                | SFL2.....    | D-18 |
| R.....      | D-4                 | SFL3.....    | D-18 |
| RAPS.....   | D-17                | SH.....      | D-4  |
| RDA.....    | D-17                | SNSA.....    | D-18 |
|             |                     | SNSADA.....  | D-18 |

|             |                     |           |                     |
|-------------|---------------------|-----------|---------------------|
| SNSB.....   | D-18                | YR.....   | D-22                |
| SNSBDA..... | D-18                | YW.....   | D-22                |
| SOP.....    | D-4                 | ZERO..... | D-14, D-15,<br>D-21 |
| SOP1.....   | D-5                 | #.....    | D-20                |
| SPD.....    | D-4                 |           |                     |
| SPEC.....   | D-6                 |           |                     |
| SPFN.....   | D-21                |           |                     |
| SPINA.....  | D-17                |           |                     |
| SPINB.....  | D-18                |           |                     |
| SPINDA..... | D-17                |           |                     |
| SPININ..... | D-17                |           |                     |
| SPMDA.....  | D-6                 |           |                     |
| SPMDAV..... | D-16                |           |                     |
| SPNADA..... | D-18                |           |                     |
| SPNBDA..... | D-18                |           |                     |
| SPNOUT..... | D-17                |           |                     |
| SPOTDA..... | D-17                |           |                     |
| SPS.....    | D-4                 |           |                     |
| STEST.....  | D-7                 |           |                     |
| SUB.....    | D-4                 |           |                     |
| SWDB.....   | D-8                 |           |                     |
| SWDBE.....  | D-8                 |           |                     |
| SWDBH.....  | D-8                 |           |                     |
| SWDBL.....  | D-8                 |           |                     |
| TM.....     | D-14, D-21,<br>D-23 |           |                     |
| TMA.....    | D-25                |           |                     |
| VALUE.....  | D-21                |           |                     |
| WPS0.....   | D-10                |           |                     |
| WPSOA.....  | D-10                |           |                     |
| WPSOT.....  | D-10                |           |                     |
| WPS1.....   | D-11                |           |                     |
| WPS1A.....  | D-11                |           |                     |
| WPS1T.....  | D-11                |           |                     |
| WPS2.....   | D-10                |           |                     |
| WPS2A.....  | D-10                |           |                     |
| WPS2T.....  | D-10                |           |                     |
| WPS3.....   | D-11                |           |                     |
| WPS3A.....  | D-11                |           |                     |
| WPS3T.....  | D-11                |           |                     |
| WRTEX.....  | D-19                |           |                     |
| WRTEXP..... | D-5                 |           |                     |
| WRTHMN..... | D-5                 |           |                     |
| WRTLBN..... | D-5                 |           |                     |
| WRTMAN..... | D-19                |           |                     |
| XR.....     | D-22                |           |                     |
| XW.....     | D-22                |           |                     |



FLOATING POINT  
SYSTEMS, INC.

CALL TOLL FREE 800-547-1445  
P.O. Box 23489, Portland, OR 97223  
(503) 641-3151, TLX: 360470 FLOATPOINT PTL



FLOATING POINT  
SYSTEMS, INC.

**Programmers  
Reference  
Manual  
Part Two**  
**860-7319-000**

1st Edition, January 1978

Publication No. FPS-7319

NOTICE

The material in this manual is for information purposes only and is subject to change without notice.

Floating Point Systems, Inc. assumes no responsibility for any errors which may appear in this publication.

Copyright  1978 by Floating Point Systems, Inc.  
Beaverton, Oregon 97005

All rights reserved. No part of this publication may be reproduced in any form or by any means without written permission from the publisher.

Printed in U.S.A.

**Table of Contents**  
AP-120B Instructions

**Unconditional Fields**

Each of the following fields may be used in any given instruction word.

| Field Name | B                | SOP                 | SOP1                  | SH                |
|------------|------------------|---------------------|-----------------------|-------------------|
| Octal Code |                  |                     |                       |                   |
| 0          | NOP              | SOP1 . . . . . E-23 | NOP                   | NOP               |
| 1          | & . . . . . E-13 | SPEC                | WRTEXP . . . . . E-23 | L . . . . . E-14  |
| 2          |                  | ADD . . . . . E-17  | WRTHMN . . . . . E-24 | RR . . . . . E-16 |
| 3          |                  | SUB . . . . . E-18  | WRTLBN . . . . . E-24 | R . . . . . E-15  |
| 4          |                  | MOV . . . . . E-19  | NOP                   |                   |
| 5          |                  | AND . . . . . E-20  | NOP                   |                   |
| 6          |                  | OR . . . . . E-21   | NOP                   |                   |
| 7          |                  | EQV . . . . . E-22  | NOP                   |                   |
| 10         |                  |                     | CLR . . . . . E-25    |                   |
| 11         |                  |                     | INC . . . . . E-25    |                   |
| 12         |                  |                     | DEC . . . . . E-26    |                   |
| 13         |                  |                     | COM . . . . . E-26    |                   |
| 14         |                  |                     | LDSPNL . . . . . E-27 |                   |
| 15         |                  |                     | LDSPPE . . . . . E-28 |                   |
| 16         |                  |                     | LDSPPI . . . . . E-29 |                   |
| 17         |                  |                     | LDSPPT . . . . . E-30 |                   |

| Field Name    | SPS (S-Pad Source Reg.) | SPD (S-Pad Dest. Reg.) |
|---------------|-------------------------|------------------------|
| Octal Code    |                         |                        |
| 0<br>to<br>17 | (0-17)                  | (0-17)                 |

S-Pad Timing Rules . . . . E-12

| Field Name | FADD                 | FADD1                 | A1                  | A2                  |
|------------|----------------------|-----------------------|---------------------|---------------------|
| Octal Code |                      |                       |                     |                     |
| 0          | FADD1 . . . . . E-86 | NOP                   | NC . . . . . E-93   | NC . . . . . E-95   |
| 1          | FSUBR . . . . . E-81 | FIX . . . . . E-86    | FM . . . . . E-93   | FA . . . . . E-95   |
| 2          | FSUB . . . . . E-81  | FIYT . . . . . E-87   | DPX . . . . . E-93  | DPX . . . . . E-95  |
| 3          | FADD . . . . . E-82  | FSCLT . . . . . E-88  | DPY . . . . . E-93  | DPY . . . . . E-95  |
| 4          | FEQV . . . . . E-83  | FSM2C . . . . . E-89  | TM . . . . . E-94   | MD . . . . . E-96   |
| 5          | FAND . . . . . E-84  | F2CSM . . . . . E-90  | ZERO . . . . . E-94 | ZERO . . . . . E-96 |
| 6          | FOR . . . . . E-85   | FSCALE . . . . . E-91 | ZERO                | MDPX . . . . . E-96 |
| 7          | IO . . . . . E-101   | FABS . . . . . E-92   | ZERO                | EDPX . . . . . E-96 |

**Unconditional Fields**

Each of the following fields may be used in any given instruction word.

| Field Name | COND                  | DISP (Branch Displacement) | DPX                | DPY                |
|------------|-----------------------|----------------------------|--------------------|--------------------|
| Octal Code |                       |                            |                    |                    |
| 0          | NOP                   | (0-37)                     | NOP                | NOP                |
| 1          | # . . . . . E-68      |                            | DB . . . . . E-123 | DB . . . . . E-126 |
| 2          | BR . . . . . E-69     |                            | FA . . . . . E-124 | FA . . . . . E-127 |
| 3          | BINTRQ . . . . . E-70 |                            | FM . . . . . E-125 | FM . . . . . E-128 |
| 4          | BION . . . . . E-70   |                            |                    |                    |
| 5          | BIOZ . . . . . E-71   |                            |                    |                    |
| 6          | BFPE . . . . . E-71   |                            |                    |                    |
| 7          | RETURN . . . . . E-72 |                            |                    |                    |
| 10         | BFEQ . . . . . E-73   |                            |                    |                    |
| 11         | BFNE . . . . . E-74   |                            |                    |                    |
| 12         | BFGE . . . . . E-75   |                            |                    |                    |
| 13         | BFGT . . . . . E-76   |                            |                    |                    |
| 14         | BEQ . . . . . E-77    |                            |                    |                    |
| 15         | BNE . . . . . E-78    |                            |                    |                    |
| 16         | BGE . . . . . E-79    |                            |                    |                    |
| 17         | BGT . . . . . E-80    |                            |                    |                    |

| Field Name | DPBS               | XR (DPX Read Index) | YR (DPY Read Index) | XW (DPX Write Index) | YW (DPY Write Index) | FM   |
|------------|--------------------|---------------------|---------------------|----------------------|----------------------|------|
| Octal Code |                    |                     |                     |                      |                      |      |
| 0          | ZERO . . . E-129   | (0-7)               | (0-7)               | (0-7)                | (0-7)                | NOP  |
| 1          | INBS . . . E-130   |                     |                     |                      |                      | FMUL |
| 2          | VALUE* . . . E-131 |                     |                     |                      |                      |      |
| 3          | DPX . . . E-132    |                     |                     |                      |                      |      |
| 4          | DPY . . . E-133    |                     |                     |                      |                      |      |
| 5          | MD . . . . E-134   |                     |                     |                      |                      |      |
| 6          | SPFN . . . E-135   |                     |                     |                      |                      |      |
| 7          | TM . . . . E-136   |                     |                     |                      |                      |      |

| Field Name | M1               | M2                | MI               | MA              | DPA              | TMA              |
|------------|------------------|-------------------|------------------|-----------------|------------------|------------------|
| Octal Code |                  |                   |                  |                 |                  |                  |
| 0          | FM . . . . E-99  | FA . . . . E-100  | NOP              | NOP             | NOP              | NOP              |
| 1          | DPX . . . . E-99 | DPX . . . . E-100 | FA . . . . E-137 | INCMA . . E-140 | INCDPA . . E-143 | INCTMA . . E-146 |
| 2          | DPY . . . . E-99 | DPY . . . . E-100 | FM . . . . E-138 | DECMA . . E-141 | DECDA . . E-144  | DECTMA . . E-147 |
| 3          | TM . . . . E-99  | MD . . . . E-100  | DB . . . . E-139 | SETMA . . E-142 | SETDPA . . E-145 | SETTMA . . E-148 |

\*This instruction uses a 16-bit immediate VALUE as a constant or address (in bits 48-63 of this instruction). The YW, FM, M1, M2, MI, TMA, and DPA fields are then disabled for this instruction word.

**SPEC Fields**

One of the SPEC Fields may be used per instruction word. The S-Pad Fields (B, SOP, SOP1, SH, SPS, and SPD) are then disabled for this instruction.

| Field Name | SPEC                 | STEST             | HOSTPNL             | SETPSA             |
|------------|----------------------|-------------------|---------------------|--------------------|
| Octal Code |                      |                   |                     |                    |
| 0          | STEST . . . . E-31   | BFLT . . . . E-31 | PNLIT . . . . E-39  | JMPA* . . . . E-45 |
| 1          | HOSTPNL . . . . E-39 | BLT . . . . E-32  | OBELIT . . . . E-39 | JSRA* . . . . E-46 |
| 2          | SPMDA . . . . E-6    | BNC . . . . E-33  | DBHLIT . . . . E-40 | JMP* . . . . E-47  |
| 3          | NOP                  | BZC . . . . E-34  | DBLLIT . . . . E-40 | JSR* . . . . E-47  |
| 4          | NOP                  | BOBN . . . . E-35 | NOP                 | JMPT . . . . E-48  |
| 5          | NOP                  | BOBZ . . . . E-36 | NOP                 | JSRT . . . . E-48  |
| 6          | NOP                  | BIFN . . . . E-37 | NOP                 | JMPP . . . . E-49  |
| 7          | NOP                  | BIFZ . . . . E-37 | NOP                 | JSRP . . . . E-50  |
| 10         | SETPSA . . . . E-45  | NOP               | SWDB . . . . E-41   | NOP                |
| 11         | PSEVEN . . . . E-52  | NOP               | SWDBE . . . . E-42  | NOP                |
| 12         | PSOOD . . . . E-55   | NOP               | SWDBH . . . . E-43  | NOP                |
| 13         | PS . . . . E-58      | NOP               | SWDBL . . . . E-44  | NOP                |
| 14         | SETEXIT . . . . E-66 | BFLO . . . . E-38 | NOP                 | NOP                |
| 15         | NOP                  | BFL1 . . . . E-38 | NOP                 | NOP                |
| 16         | NOP                  | BFL2 . . . . E-38 | NOP                 | NOP                |
| 17         | NOP                  | BFL3 . . . . E-38 | NOP                 | NOP                |

| Field Name | PSEVEN              | PSOOD               | PS                  | SETEXIT              |
|------------|---------------------|---------------------|---------------------|----------------------|
| Octal Code |                     |                     |                     |                      |
| 0          | RPSOA* . . . . E-52 | RPS1A* . . . . E-55 | RPSLA* . . . . E-58 | NOP                  |
| 1          | RPS2A* . . . . E-52 | RPS3A* . . . . E-55 | RPSFA* . . . . E-59 | SETEXA* . . . . E-66 |
| 2          | RPSO* . . . . E-52  | RPS1* . . . . E-55  | RPSL* . . . . E-60  | NOP                  |
| 3          | RPS2* . . . . E-52  | RPS3* . . . . E-55  | RPSF* . . . . E-60  | SETEX* . . . . E-66  |
| 4          | RPSOT . . . . E-52  | RPS1T . . . . E-56  | RPSLT . . . . E-60  | NOP                  |
| 5          | RPS2T . . . . E-53  | RPS3T . . . . E-56  | RPSFT . . . . E-61  | SETEXT . . . . E-67  |
| 6          | NOP                 | NOP                 | RPSLP . . . . E-61  | NOP                  |
| 7          | NOP                 | NOP                 | RPSFP . . . . E-61  | SETEXP . . . . E-67  |
| 10         | WPSOA* . . . . E-53 | WPS1A* . . . . E-56 | LPSLA* . . . . E-62 | NOP                  |
| 11         | WPS2A* . . . . E-53 | WPS3A* . . . . E-56 | LPSRA* . . . . E-63 | NOP                  |
| 12         | WPSO* . . . . E-54  | WPS1* . . . . E-57  | LPSL* . . . . E-64  | NOP                  |
| 13         | WPS2* . . . . E-54  | WPS3* . . . . E-57  | LPSR* . . . . E-64  | NOP                  |
| 14         | WPSOT . . . . E-54  | WPS1T . . . . E-57  | LPSLT . . . . E-64  | NOP                  |
| 15         | WPS2T . . . . E-54  | WPS3T . . . . E-57  | LPSRT . . . . E-65  | NOP                  |
| 16         | NOP                 | NOP                 | LPSLP . . . . E-65  | NOP                  |
| 17         | NOP                 | NOP                 | LPSRP . . . . E-65  | NOP                  |

Formats for partial words (PSEVEN, PSOOD, PS Fields) . . . . E-51

\*This instruction uses a 16-bit integer VALUE (in bits 48-63 of the instruction word). The YW, FM, M1, M3, MI, MA, TMA, and DPA Fields are then disabled for this instruction word.

I/O Fields

One of the I/O Fields may be used per instruction word. The Floating Adder Fields (FADD, FADD1, A1, and A2) are then disabled for this instruction word.

| Field Name | I/O                 | LDREG                 | RDREG                 | INOUT                  |
|------------|---------------------|-----------------------|-----------------------|------------------------|
| Octal Code |                     |                       |                       |                        |
| 0          | LDREG . . . . E-101 | NOP . . . . .         | RPSA . . . . . E-105  | OUT . . . . . E-107    |
| 1          | RDREG . . . . E-105 | LDSPD . . . . . E-101 | RSPD . . . . . E-105  | SPNOUT . . . . . E-109 |
| 2          | SPMDAV . . . . E-7  | LDMA . . . . . E-101  | RMA . . . . . E-106   | CUTDA . . . . . E-110  |
| 3          | REXIT . . . . E-7   | LDTMA . . . . . E-102 | RTMA . . . . . E-106  | SPOTDA . . . . . E-111 |
| 4          | INOUT . . . . E-109 | LDDPA . . . . . E-102 | RDPA . . . . . E-107  | IN . . . . . E-112     |
| 5          | SENSE . . . . E-115 | LDSP . . . . . E-103  | RSPFN . . . . . E-107 | SPININ . . . . E-112   |
| 6          | FLAG . . . . E-121  | LDAPS . . . . . E-103 | RAPS . . . . . E-108  | INDA . . . . . E-113   |
| 7          | CONTROL . . . . E-8 | LDDA . . . . . E-103  | RDA . . . . . E-108   | SPIHDA . . . . . E-114 |

| Field Name | SENSE                | FLAG                 | CONTROL               |
|------------|----------------------|----------------------|-----------------------|
| Octal Code |                      |                      |                       |
| 0          | SNSA . . . . E-115   | SFL0 . . . . . E-121 | HALT . . . . . E-8    |
| 1          | SPINA . . . . E-115  | SFL1 . . . . . E-121 | IORST . . . . . E-9   |
| 2          | SNSADA . . . . E-115 | SFL2 . . . . . E-121 | INTEN . . . . . E-9   |
| 3          | SPNADA . . . . E-115 | SFL3 . . . . . E-121 | INTA . . . . . E-10   |
| 4          | SNSB . . . . E-118   | CFL0 . . . . . E-122 | REFR . . . . . E-10   |
| 5          | SPINB . . . . E-118  | CFL1 . . . . . E-122 | WRTEX . . . . . E-11  |
| 6          | SNSBDA . . . . E-119 | CFL2 . . . . . E-122 | WRTMAN . . . . . E-11 |
| 7          | SPNBDA . . . . E-120 | CFL3 . . . . . E-122 | NOP                   |

NOP . . . . . E-5

AP-120B Instruction Field Layout



|                |     |      |    |    |    |    |    |    |    |    |    |                |    |              |    |     |     |    |    |    |    |    |    |    |    |       |    |    |    |    |    |
|----------------|-----|------|----|----|----|----|----|----|----|----|----|----------------|----|--------------|----|-----|-----|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|
| 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 |
| DPX            | DPY | DPBS |    | XR |    | YR | XW |    | YW |    | FM | M1             | M2 | MI           | MA | DPA | TMA |    |    |    |    |    |    |    |    |       |    |    |    |    |    |
| Data Pad Group |     |      |    |    |    |    |    |    |    |    |    | Multiply Group |    | Memory Group |    |     |     |    |    |    |    |    |    |    |    | VALUE |    |    |    |    |    |
|                |     |      |    |    |    |    |    |    |    |    |    |                |    |              |    |     |     |    |    |    |    |    |    |    |    |       |    |    |    |    |    |

0

63



MANDATORY FIELDS  
OPTIONAL FIELDS  
DISABLED FIELDS

value

all  
zeros

No-operation

Assembler format: NOP

Effect: No operation is performed

Description: The assembler recognizes this mnemonic and will insert an all zeros instruction which is a NOP.

CONTROL (from SPEC )



VALUE

|   |       |                           |
|---|-------|---------------------------|
| 2 | SPMDA | SPIN WHILE MAIN DATA BUSY |
|---|-------|---------------------------|

Assembler

Format: SPMDA

Effect: "SPIN" while MAIN DATA BUSY

Description: When specified, SPMDA causes the AP-120B to suspend program execution until MAIN DATA MEMORY (MD) completes its READ or WRITE cycle and becomes available for the next READ/WRITE operation. Using this op-code in an instruction immediately following one that initiates an MD READ operation, results in the data from that operation being available for use during the present instruction. It has no effect on a MD READ/WRITE operation in the same instruction.

Thus: LDMA; DB=100  
SPMDA; DPX(0)<MD

results in the contents of MD(100) being loaded into DPX(0).

CONTROL (from I/O )



VALUE

2      SPMDAV      SPIN WHILE MAIN DATA BUSY

Assembler  
Format:      SPMDAV

Effect:      "SPIN" while MAIN DATA BUSY

Description: When specified, SPMDA causes the AP-120B to suspend program execution until MAIN DATA MEMORY (MD) completes its READ or WRITE cycle and becomes available for the next READ/WRITE operation. Using this op-code in an instruction immediately following one that initiates an MD READ operation, results in the data from that operation being available for use during the present instruction. It has no effect on a MD READ/WRITE operation in the same instruction.

Thus:      LDMA; DB=100  
SPMDA; DPX(0)<MD

results in the contents of MD(100) being loaded into DPX(0).

3      REXIT      READ EXIT

Assembler  
Format:      REXIT

Effect:      SRS (SRA)→PNLBS

Description: This instruction is similar to SETEXIT, but allows reading instead. The SRA is NOT changed by this instruction. This is generally used with a LDSPNL to load into S-PAD register.

CONTROL FIELD (CONTROL)



Ø      HALT      HALT AP-120

Assembler  
Format:      HALT  
example:    INCMA; MI<FA; HALT

Effect:      l → FN<sub>bit Ø</sub>; clear RUN INDICATOR

Description: The AP-120B program execution will be halted after completion of the current instruction word. (See note.) AP-120B RUN INDICATOR (RUN) cleared and PANEL FUNCTION REGISTER(bit 0) set. When halted, PSA will point to the next instruction to be executed and it will have been entered into the instruction register. SPFN will reflect the operation in that instruction.

NOTE: if the current instruction "SPINS" while waiting for I/O or MEMORY, HALT will not be effective until the "SPIN" cycle is finished and the instruction completed (as in the above example).

WARNING: Due to timing problems in the JSR instruction, it should not follow a HALT. Thus, the recommended programming practice is to place a NOP (no operation, all zeros instruction) after every HALT instruction.

## CONTROL FIELD (CONTROL)



### VALUE

|                      |                                                                             |                               |
|----------------------|-----------------------------------------------------------------------------|-------------------------------|
| 1                    | <b>IORST</b>                                                                | RESET I/O DEVICES IMMEDIATELY |
| Assembler<br>Format: | IORST                                                                       |                               |
| Effect:              | Clear I/O device logic and timing and all four of the general FLAGS.        |                               |
| Description:         | Effects are device dependent. No effect on Host interface, TMRAM, or IOP16. |                               |

|                      |                                                                                                    |                  |
|----------------------|----------------------------------------------------------------------------------------------------|------------------|
| !                    | <b>INTEN</b>                                                                                       | INTERRUPT ENABLE |
| Assembler<br>Format: | INTEN                                                                                              |                  |
| Effect:              | If CTL <sup>Bit 05</sup> is already set to "1", generate interrupt to HOST-CPU. If not, no effect. |                  |

Description: This is used in conjunction with the CTL05 interrupt.  
(See I/O, PROGRAMMED INTERRUPTS.)

When an INTEN is executed, the AP-120B will attempt to set CTL05 interrupt. If CTL(Bit 05) is already set, then the AP-120B will generate an interrupt to HOST-CPU. The state of CTL(Bit 05) is not altered by this instruction.

CONTROL FIELD (CONTROL)



VALUE

|   |                                                                  |                       |
|---|------------------------------------------------------------------|-----------------------|
| 3 | <span style="border: 1px solid black; padding: 2px;">INTA</span> | INTERRUPT ACKNOWLEDGE |
|---|------------------------------------------------------------------|-----------------------|

Assembler  
Format: INTA

Effect: (DA interrupting IODEVICE) → INBS

Description: The interrupting I/O DEVICE enables its Device Address onto the INBS MANTISSA (Bits 20 to 27) for the current instruction cycle. Used to identify the interrupting I/O device after an interrupt is detected via the BINTRQ instruction.

|   |                                                                  |                        |
|---|------------------------------------------------------------------|------------------------|
| 4 | <span style="border: 1px solid black; padding: 2px;">REFR</span> | MEMORY REFRESH REQUEST |
|---|------------------------------------------------------------------|------------------------|

Assembler  
Format: REFR

Effect: REFRESH MD; reset REFR CTR

Description: REFR initiates a REFRESH cycle to MAIN DATA MEMORY (MD). The REFRESH COUNTER (REFR CTR) is reset to zero. This has the effect of synchronizing the REFRESH timing with a running AP-120B program. It can be used either to eliminate REFRESH interference with programmed memory accesses or simply to stabilize the REFRESH timing in order to facilitate hardware fault tracing with an oscilloscope. Floating Point Systems supplied APEX drivers always generate a REFR before starting the user called micro-code.

NOTE: NON-PROGRAMMED REFRESH cycles occur every 31usec for 8K bank-pair MD memory and every 15.5usec for 32K bank-pair MD memory.

CONTROL FIELD (CONTROL)



VALUE

5           WRITE EXPONENT ONLY

Assembler  
Format:

WRTEX

example: DPX (2)< TM; WRTEX

Effect:      Restricts DPX, DPY, or MI fields to write exponent bits only.

Description: When specified with a concurrent WRITE DPX, DPY, or MI operation, WRTEX restricts the writing to EXPONENT(Bits 02-11) only. (See S-PAD group, WRTEXP for further description of effect.)

6           WRITE MANTISSA ONLY

Assembler  
Format:

WRTMAN

Example: MOV 5,5; SETMA; MI<FA; WRTMAN

Effect:      Restricts DPX, DPY, or MI fields to WRITE MANTISSA bits only.

Description: When specified with a concurrent WRITE DPX, DPY or MI operation, WRTMAN restricts the writing to MANTISSA(Bits 00-27) only. (See S-PAD group for further discussion.)

CONTROL FIELD (CONTROL)  
continued...

7

IOINTA

I/O INTERRUPT ACKNOWLEDGE

Assembler

Format: IOINTA

Effect: (DA interrupting IODEVICE) INBUS

Description: The interrupting I/O Device enables its Device Address onto the INBS Mantissa (Bits 20 to 27) for the current instruction cycle.

#### S-PAD TIMING RULES

1. SPFN for an instruction with an S-PAD operation is the result of that operation.
2. SPFN is stored back into SP(SPD) only once - at the end of the instruction in which the S-PAD operation took place (not stored at all if No-Load specified). Similarly, the N, Z, and C S-PAD condition bits are set only once for each S-PAD operation.
3. SPFN for an instruction without an S-PAD operation is the result of performing the last previous S-PAD instruction over again, using the current value of SP(SPD) as possibly modified by the original S-PAD operation. SP(SPD) is not altered if no S-PAD operation is specified. This modified SPFN value would be apparent if an SPFN utilizing instruction were executed (e.g., RSPFN, SETMA, etc.).

## BIT REVERSE FIELD



### VALUE

**0** No Operation

**1**  BIT REVERSE the contents of S-PAD SOURCE REGISTER before using

### Assembler

Format: < & > (Brackets indicate optional use with S-PAD operations.)

Effect: Example: ADD & 6,5

Effect: BIT-REVERSE(SP<sub>SPS</sub>) → SOURCE INPUT FOR CURRENT S-PAD OPERATION

Description: The contents of the S-PAD SOURCE REGISTER (SP[SPS]) are BIT-REVERSED and shifted before being used as the SOURCE OPERAND in the current S-PAD operation.

The number of shifts performed depends on the size of the complex data array being processed. The programmer must load the applicable shift value into the BIT-REVERSE field of the APSTATUS Register before specifying the BIT-REVERSE operation. (See S-PAD SUMMARY BIT-REVERSE FIELD for more details.) (See also APSTATUS SUMMARY.)

## SHIFT FIELD



### VALUE

$\emptyset$  No Operation

1 LEFT SHIFT S-PAD OUTPUT (SPFN) ONCE. ZERO FILL.

### Assembler

Format: <L> (Brackets indicate optional use with S-PAD operations)

Example: SUBL 5,6

Effect: SPFN → LEFT SHIFTED ONCE → SPFN

Description: The S-PAD RESULT (SPFN) is logically shifted left one place. The right-most bit is set to zero. The bit shifted off the left end is stored in the S-PAD CARRY BIT, (C) - overriding any carry that resulted from the specified arithmetic operation.

Excepting possible OVERFLOW, the shift has the effect of a multiplication by two. The carry bit (C), bit 7 of the AP INTERNAL STATUS REGISTER (APSTATUS), may be tested during the next instruction cycle.



## SHIFT FIELD (SH)



MANDATORY FIELDS

OPTIONAL FIELDS

DISABLED FIELDS

\* MAY BE USED WITH EITHER  
SOP OR SOP1 FIELDS

VALUE

2



RIGHT SHIFT S-PAD FUNCTION (SPFN) ONCE. ZERO FILL.

Assembler

Format: <R> (Brackets indicate optional use with S-PAD operations)

Example: SUBR 5,6

Effect: SPFN right-shifted once+ SPFN

Description: The S-PAD RESULT (SPFN) is logically shifted right one place. A zero is shifted into the left-most bit. The bit shifted off the right end is set into the S-PAD CARRY BIT.

The instruction has the effect for unsigned numbers, of a division by two. Bit C of the AP INTERNAL STATUS REGISTER (bit 7, APSTATUS) reflects the condition of S-PAD CARRY and may be tested during the next instruction cycle.



## SHIFT FIELD



\* MAY BE USED WITH EITHER  
SOP OR SOP1 FIELDS

## VALUE

|    |                                                |    |                                                     |
|----|------------------------------------------------|----|-----------------------------------------------------|
| 3  | <table border="1"><tr><td>RR</td></tr></table> | RR | RIGHT SHIFT S-PAD FUNCTION (SPFN) twice. Zero fill. |
| RR |                                                |    |                                                     |

Assembler  
Format:

<RR> (Brackets indicate optional use with S-PAD  
operations)

Example: SUBRR 5,6

Effect: SPFN  $\rightarrow$  right shifted twice  $\rightarrow$  SPFN

Description: The contents of the S-PAD ALU RESULT are logically shifted right two times before being enabled onto the SPFN data path. Zeros are filled into the left-most two bits. The second bit shifted off the end is set into the S-PAD ALU CARRY BIT.

The instruction has the effect for unsigned numbers of a division by four. Bit C (bit 7) of the AP INTERNAL STATUS REGISTER (APSTATUS) reflects the condition of the S-PAD CARRY BIT and may be tested during the next instruction cycle.



## S-PAD OPERATIONS FIELD



### VALUE

|   |                                                                                                                                               |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | See, S-PAD OPERATIONS 1                                                                                                                       |
| 1 | See, SPECIAL OPERATIONS                                                                                                                       |
| 2 | <div style="border: 1px solid black; padding: 2px; display: inline-block;">ADD</div> ADD S-PAD SOURCE REGISTER AND S-PAD DESTINATION REGISTER |

### Assembler

Format:  $\text{ADD } \langle \# \rangle \text{ } \langle & \rangle \text{ } \text{SPS}, \text{SPD}$

Effect:  $(\text{SP}_{\text{SPS}})^{\dagger} \text{ plus } (\text{SP}_{\text{SPD}})^{\ddagger} \text{ SPFN}^{\dagger\dagger};$

$\text{SPFN}^{\dagger\dagger} (\text{SP}_{\text{SPD}})$  unless S-PAD NO-LOAD (#) is specified

Description: The contents of S-PAD SOURCE REGISTER ( $\text{SP}_{\text{SPS}}$ ) are added with the contents of S-PAD DESTINATION REGISTER ( $\text{SP}_{\text{SPD}}$ ). The result of the operation, ( $\text{SPFN}$ ) is stored back into the specified S-PAD DESTINATION REGISTER unless an S-PAD NO-LOAD (#) is specified.

Appropriate bits are set in the AP INTERNAL STATUS REGISTER (APSTATUS) and may be tested during the next instruction cycle.

CARRY BIT EQUATION: If  $(\text{SP}_{\text{SPD}}) + (\text{SP}_{\text{SPS}}) > 2^{16}$  then carry=1

$\dagger$   $(\text{SP}_{\text{SPS}})$  may be optionally BIT-REVERSED, (see BIT-REVERSE FIELD)

$\dagger\dagger$   $\text{SPFN}$  from the ADD may be optionally shifted, (see SHIFT FIELD)

## S-PAD OPERATIONS FIELD



VALUE

3

SUB

SUBtract S-PAD SOURCE REGISTER from S-PAD  
DESTINATION REGISTER

Assembler

Format: SUB< sh >< # > < & > sps,spd

Effect:  $(SP_{SPD}) - (SP_{SPS})^{+} \rightarrow SPFN^{++};$

$SPFN \leftarrow (SP_{SPD})$  unless S-PAD NO-LOAD (#) is specified

Description: The contents of the S-PAD SOURCE REGISTER are subtracted from the contents of the S-PAD DESTINATION REGISTER. The result of the operation is stored back into the S-PAD DESTINATION REGISTER unless a S-PAD NO-LOAD (#) is specified.

Appropriate bits (N,Z,C) are set in the AP INTERNAL STATUS REGISTER (APSTATUS) and may be tested during the next instruction cycle.

CARRY BIT EQUATION: If  $(SP[SPD]) + (\overline{SP[SPS]}) + 1 \geq 2^{16}$  then C=1 else 0. If a shift is specified, then C is set to the carry from that shift.

$^{+}(SP[SPS])$  may be optionally BIT-REVERSED. See BIT-REVERSE FIELD.  
 $^{++}SPFN$  from the SUB may be optionally shifted. See SHIFT FIELD.

## S-PAD OPERATIONS FIELD



VALUE

4      MOVE S-PAD SOURCE REGISTER TO  
S-PAD DESTINATION REGISTER

Assembler Format:  $MOV < sh > < \# > < \& > sps, spd$

Effect:  $(SP_{SPS})^{\dagger} \rightarrow SPFN^{\ddagger}; SPFN \rightarrow (SP_{SPD})$  unless S-PAD NO-LOAD is specified.

Description: SPFN is set to the contents of the S-PAD SOURCE REGISTER ( $SP[SPS]$ ); SPFN is stored into the S-PAD DESTINATION REGISTER unless an S-PAD NO-LOAD (#) is specified.

Appropriate bits are set in the AP INTERNAL STATUS REGISTER (APSTATUS) and may be tested during the next instruction cycle.

CARRY BIT EQUATION: If  $[(SP[SPD]) \text{ AND } (SP[SPS])] + [(SP[SPD]) \text{ OR } (SP[SPS])] \geq 2^{16}$   
then, C=1 else 0

$^{\dagger}(SP[SPS])$  may be optionally BIT-REVERSED. See BIT-REVERSE FIELD.  
 $^{\ddagger}SPFN$  from the MOV may be optionally shifted. See SHIFT FIELD.

## S-PAD OPERATIONS FIELD



VALUE

5 AND AND S-PAD SOURCE REGISTER to S-PAD DESTINATION REGISTER

Assembler

Format: AND <sh> <#> <&> sps,spd

Effect:  $(SP_{SPS})^+ \text{ AND } (SP_{SPD}) \rightarrow SPFN^{++};$

$SPFN \dagger \dagger \text{ unless S-PAD NO-LOAD is specified.}$

Description: The contents of the S-PAD SOURCE REGISTER ( $SP_{SPS}$ ) are logically ANDed with the contents of the S-PAD DESTINATION REGISTER ( $SP_{SPD}$ ). A bit by bit comparison is made between the contents of the two operands and if both respective bits are "1", a "1" is recorded into the corresponding bit of the result ( $SPFN$ ). All other combinations result in "0" being recorded into the respective bit of  $SPFN$ .

The result of the operation ( $SPFN$ ) is stored into  $SP_{SPD}$  unless an S-PAD NO-LOAD (#) is specified.

The appropriate bits are set in the AP INTERNAL STATUS REGISTER (APSTATUS) and may be tested during the next instruction cycle.

CARRY BIT EQUATION: If  $[(SP_{SPD}) \text{ AND } (SP_{SPS})] + (SP_{SPD}) \geq 2^{16}$  then CARRY=1

TRUTH TABLE

| $SP_{SPS}$ | $SP_{SPD}$ | $SPFN$ |
|------------|------------|--------|
| 0          | 0          | 0      |
| 0          | 1          | 0      |
| 1          | 0          | 0      |
| 1          | 1          | 1      |

<sup>†</sup>  $(SP_{SPS})$  may be optionally BIT-REVERSED, See BIT-REVERSE FIELD

<sup>++</sup>  $SPFN$  from the AND may be optionally shifted, See SHIFT FIELD

## S-PAD OPERATIONS FIELD



VALUE

6           OR S-PAD SOURCE REGISTER to S-PAD DESTINATION REGISTER

Assembler

Format:      OR < sh > < # > < & > sps,spd

Effect:       $(SP_{SPS})^{\dagger} \text{ OR } (SP_{SPD})^{\ddagger} \rightarrow SPFN;$

$SPFN \rightarrow (SP_{SPD})$  unless NO-LOAD is specified.

Description: The contents of the S-PAD SOURCE REGISTER ( $SP[SPS]$ ) are logically ORed with the contents of the S-PAD DESTINATION REGISTER ( $SP[SPD]$ ). A bit-by-bit comparison is made between the contents of the two operands and if either one of the respective bits = "1," then a "1" is recorded in the corresponding bit of the result ( $SPFN$ ). All other combinations result in a "0" being recorded into the respective  $SPFN$  bit position. The result of the operation ( $SPFN$ ) is stored into  $SP(SP)$  unless S-PAD NO-LOAD (#) is specified.

Additionally, S-PAD ALU CARRY BIT is set to "0." The appropriate bits of the AP INTERNAL STATUS REGISTER (APSTATUS) are set and may be tested during the next instruction cycle.

TRUTH TABLE

| $SP_{SPS}$ | $SP_{SPD}$ | $SPFN$ |
|------------|------------|--------|
| ∅          | ∅          | ►      |
| ∅          | 1          | ►      |
| 1          | ∅          | ►      |
| 1          | 1          | ►      |

$\dagger (SP[SPS])$  may be optionally BIT-REVERSEd. See BIT-REVERSE FIELD.

$\ddagger SPFN$  from the OR may be optionally shifted. See SHIFT FIELD.

## S-PAD OPERATIONS FIELD



VALUE

7

EQV

EQUIVALENCE S-PAD SOURCE REGISTER to S-PAD  
DESTINATION REGISTER

### Assembler

Format: EQV < sh >< # > < & > sps,spd

Effect:  $(SP_{SPS})^{\dagger} \overline{XOR} (SP_{SPD}) \rightarrow SPFN^{\ddagger};$

$SPFN \rightarrow (SP_{SPD})$  unless NO-LOAD is specified.

Description: The contents of the S-PAD SOURCE REGISTER ( $SP[SPS]$ ) and the S-PAD DESTINATION REGISTER ( $SP[SPD]$ ) are compared on a corresponding bit position basis for equal value. If the corresponding bits both equal "0," or both equal "1," then the respective bit of the result ( $SPFN$ ) is set to "1." All other combinations result in a "0" being set into the corresponding bit of  $SPFN$ . The result of the operation ( $SPFN$ ) is then written into ( $SP[SPD]$ ) unless S-PAD NO-LOAD (#) is specified.

The appropriate bits are set in the AP INTERNAL STATUS REGISTER (APSTATUS) and may be tested during the next instruction cycle.

CARRY BIT EQUATION: If  $(SP[SPD]) + (SP[SPS]) \geq 2^{16}$  then CARRY=1

TRUTH TABLE

| SP <sub>SPS</sub> | SP <sub>SPD</sub> | SPFN |
|-------------------|-------------------|------|
| Ø                 | Ø                 | ► 1  |
| Ø                 | 1                 | ► Ø  |
| 1                 | Ø                 | ► Ø  |
| 1                 | 1                 | ► 1  |

<sup>†</sup>( $SP[SPS]$ ) may be optionally BIT-REVERSED. See BIT-REVERSE FIELD.  
<sup>‡</sup>SPFN from the EQV may be optionally shifted. See SHIFT FIELD.

## S-PAD OPERATION 1 FIELD




  
 MANDATORY FIELDS

OPTIONAL FIELDS

DISABLED FIELDS

### VALUE

|   |                                                                                   |                                                     |
|---|-----------------------------------------------------------------------------------|-----------------------------------------------------|
| 1 |  | RESTRICT WRITE TO EXPONENT only into DPX, DPY or MI |
|---|-----------------------------------------------------------------------------------|-----------------------------------------------------|

### Assembler

Format: WRTEXP

Example: DPX (-2) FA; WRTEXP

Effect: Restricts DPX,DPY or MI field to write EXPONENT bits only.

Description: WRTEXP restricts writing of the pertinent MEMORY INPUT REGISTER into EXPONENT bits 02-11 only. WRTEXP used in conjunction with a DPX, DPY or MI WRITE operation.

When used in conjunction with a WRITE DPX or WRITE DPY operation, this operation has the effect of concatenating a portion of the input data with the value most recently written into DPX or DPY irrespective of XW or YW. Thus, if the last WRITE into DPX placed a floating point 1.0 into DPX(-2) and in this instruction we WRITE DPX(0) in conjunction with the WRTEXP Op-Code, the net effect is to concatenate the EXPONENT portion of the current input with the MANTISSA from the 1.0 of the preceding DPX WRITE operation and place the result in DPX(0). WRTLMN, WRTEX and WRTMAN from the I/O group also work in a similar manner.

## S-PAD OPERATIONS 1 FIELD



## VALUE

2 WRTHMN RESTRICT WRITE TO HIGH MANTISSA only into DPX,  
DPY or MI

## Assembler

**Format:** WRTHMN

Example: WRTHMN ; DPY < FM

**Effect:** Restricts DPX, DPY or MI fields to WRITE HIGH MANTISSA bits only (MANTISSA bits Ø-11).

Description: WRTHMN restricts the writing to the HIGH MANTISSA only, (MANTISSA BITS 00-11) of the pertinent MEMORY INPUT REGISTER. WRTHMN is used in conjunction with a DPX, DPY or MI WRITE operation. (See example above).

*NOTE: See WRTEXP for a description of the effect of this operation on DPX or DPY.*

3 WRTLMN RESTRICT WRITE to LOW MANTISSA only into DPX,  
DPY or MI FIELDS

## Assembler

Format: WBTLMN

Example: WRTI,MN : SETMA: MT < MD

**Effect:** Restricts DPX, DPY or MI fields to WRITE LOW MANTISSA bits 12-27 only (MANTISSA).

Description: WRTLMN restricts writing to the LOW MANTISSA only (MANTISSA[bits 12-27]) of the pertinent MEMORY INPUT REGISTER. WRTLMN is used in conjunction with a DPX, DPY or MI WRITE operation. (See example above.)

NOTE: See WRTEXP for a description of the effect of this operation on DPX or DPY.

## S-PAD OPERATIONS 1 FIELD



### VALUE

4 through 7                    No Operation

10                                                        CLEAR S-PAD DESTINATION REGISTER

#### Assembler

Format:                    CLR < sh><#> spd

Effect:                     $\emptyset \rightarrow SPFN$ ;  $\emptyset \rightarrow SP_{SPD}$  unless NO-LOAD (#) is specified.

Description: The S-PAD OUTPUT (SPFN) is forced to all zeros and bit "Z" of the AP INTERNAL STATUS REGISTER is set to "1" (bit 5, APSTATUS).

SP(SPD) is cleared unless S-PAD NO-LOAD (#) is specified.

CARRY BIT EQUATION: If SP(SPD) is negative then CARRY=1..

11                                                        INCREMENT S-PAD DESTINATION REGISTER

#### Assembler

Format:                    INC< sh >< # >spd

Effect:                     $(SP_{SPD}) + 1 \rightarrow SPFN$ ; and, unless NO-LOAD is specified,  
 $SPFN \rightarrow (SP_{SPD})$ .

Description: The contents of the S-PAD DESTINATION REGISTER (SP[SPD]), plus ONE are enabled onto the S-PAD FUNCTION (SPFN). SPFN is stored into the S-PAD DESTINATION REGISTER unless S-PAD NO-LOAD is specified.

The appropriate bits of the APSTATUS Register are set and may be tested during the next instruction cycle.

CARRY BIT EQUATION: If (SP[SPD]) was -1, then CARRY=1 else 0.

## S-PAD OPERATIONS 1 FIELD



VALUE

12      DEC      DECREMENT S-PAD DESTINATION REGISTER

Assembler

Format: DEC < sh> < #> spd

Effect:  $(SP_{SPD}) - 1 \rightarrow SPFN$ ; and, unless NO-LOAD is specified,  
 $(SPFN) \rightarrow SP_{SPD}$

Description: The contents of the S-PAD DESTINATION REGISTER minus ONE is set to the S-PAD Function (SPFN). The result (SPFN) is stored into the S-PAD DESTINATION REGISTER unless S-PAD NO-LOAD (#) is specified.

The appropriate bits of the AP INTERNAL STATUS REGISTER (APSTATUS) will be set and may be tested during the next instruction cycle.

CARRY BIT EQUATION: Unless  $SP_{SPD}$  was  $\emptyset$ , CARRY=1.

13      COM      COMPLEMENT S-PAD DESTINATION REGISTER

Assembler

Format: COM < sh > < # > spd

Effect:  $(\overline{SP_{SPD}}) \rightarrow SPFN$ ; unless NO-LOAD is specified,  
 $SPFN \rightarrow (SP_{SPD})$

Description: The ONE's COMPLEMENT of the contents of S-PAD DESTINATION REGISTER are enabled onto the S-PAD Function. The result (SPFN) is stored into  $SP_{SPD}$  unless S-PAD NO-LOAD (#) is specified in the instruction.

The appropriate bits of the AP INTERNAL STATUS REGISTER (APSTATUS) will be set and may be tested during the next instruction cycle.

CARRY BIT EQUATION: Unless  $SP_{SPD}$  was  $\emptyset$ , CARRY=1.

## S-PAD OPERATIONS 1 FIELD



VALUE

14      **LDSPNL**      LOAD S-PAD DESTINATION REGISTER from the PANEL BUS

Assembler

Format: LDSPNL spd

Effect:  $(SP_{SPD}) \rightarrow SPFN; PNLBS \rightarrow SP_{SPD}$

Description: First, the S-PAD Function is set to the old contents of the S-PAD DESTINATION REGISTER. Then, whatever is enabled onto the PANEL BUS is loaded into the S-PAD DESTINATION REGISTER.

The appropriate bits of the AP INTERNAL STATUS REGISTER (APSTATUS) are set as determined by the previous contents of  $SP_{SPD}$  and may be tested during the next instruction. S-PAD CARRY is set to one. If no S-PAD operation is done in the next instruction, then SPFN for that instruction will be the new contents of  $SP_{SPD}$  as loaded by this instruction cycle

FIRST:



THEN:



S-PAD OPERATIONS 1 FIELD



VALUE

15      **LDSPE**      Load S-PAD DESTINATION REGISTER from  
                  DATA PAD BUS - EXPONENT

Assembler  
Format:      LDSPE spd<sup>†</sup>

Effect:      (SP<sub>SPD</sub>)  $\rightarrow$  SPFN; then, (DPBS<sup>EXP</sup>)  $-512 \rightarrow$  SP<sub>SPD</sub>

Description: First, the SPFN is set to the old contents of the S-PAD DESTINATION REGISTER. Then the EXPONENT portion of the DATA PAD BUS (bits 02-11), BIAS inverted, is loaded into the S-PAD DESTINATION REGISTER (bits 06-15). The inverted EXPONENT BIAS BIT is extended into the remaining portion of SP(SPD) (bits 00-05).

The appropriate bits of the AP INTERNAL STATUS REGISTER (APSTATUS) are set as determined by the previous contents of SP(SPD) and may be tested during the next instruction. S-PAD CARRY is set to one. If no S-PAD operation is done in the next instruction, then SPFN for that instruction will be the new contents of SP(SPD) as loaded by this instruction.

<sup>†</sup>This transformation converts a BIASED EXPONENT from a Floating Point word into its TWO's COMPLEMENT equivalent.

S-PAD OPERATIONS 1 FIELD



VALUE

16      Load S-PAD DESTINATION REGISTER from DATA PAD BUS - INTEGER

Assembler Format:      LDSPI spd

Effect:       $(SP_{SPD}) \rightarrow SPFN$ , then  $(DPBS_{LOW\ MANTISSA}) \rightarrow SP_{SPD}$

Description: First, SPFN is set to the old contents of the S-PAD DESTINATION REGISTER. Then the contents of the DATA PAD BUS - LOW MANTISSA, a 16-bit integer, are loaded into the S-PAD DESTINATION REGISTER.

The appropriate bits of the AP INTERNAL STATUS REGISTER (APSTATUS) are set as determined by the previous contents of  $SP_{SPD}$  and may be tested during the next instruction. S-PAD CARRY is set to one. If no S-PAD operation is done in the next instruction, the SPFN for that instruction will be the new contents of  $SP_{SPD}$  as loaded by this instruction.

S-PAD OPERATIONS 1 FIELD



VALUE

17

LDSPT

Load S-PAD DESTINATION REGISTER from DATA PAD BUS -  
TABLE LOOK UP BITS

Assembler

Format: LDSPT spd

Effect:  $(SP_{SPD}) \rightarrow SPFN; \text{ then } (DPBS MANTISSA}_{\text{Bits } 02-08} \rightarrow SP_{SPD}$

Description: First, the SPFN is set to the old contents of S-PAD DESTINATION REGISTER. Then the DATA PAD BUS - TABLE LOOK UP bits (MANTISSA [bits 02-08]) are loaded into bits 09-15 of the S-PAD DESTINATION REGISTER. SP(SPD) bits 00-08 are cleared to zero.

LDSPT may be used to calculate memory addresses for use with a look up table. It extracts the seven most significant unknown bits from a positive, normalized, non-zero Floating Point number.

The appropriate bits of the AP INTERNAL STATUS REGISTER (APSTATUS) are set as determined by the previous contents of SP(SPD) and may be tested during the next instruction. S-PAD CARRY is set to one. If no S-PAD operation is done in the next instruction, then SPFN for that instruction will be the new contents of SP(SPD) as loaded by this instruction.

SPECIAL TEST FIELD (STEST)



VALUE

$\emptyset$       **BFLT**      BRANCH on FLOATING ADDER LESS THAN ZERO

Assembler

Format:      BFLT targ

Effect:      If FA < 0; then (PSA) + (DISP<sup>†</sup> - BIAS) → PSA (where  
BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH. BFLT will cause a program branch if the FADDR Result (FA) available during the previous instruction was less than zero.

This instruction tests the FA-NEGATIVE Bit (FN) of the APSTATUS Register. If FN is equal to "1" (indicating that FA was negative during the previous instruction) a program branch will occur to the BRANCH TARGET ADDRESS (targ) formed by adding the current contents of PSA with Biased contents of the DISP field of the current instruction word. If FN is equal to "0," this instruction will have no effect.

The BRANCH TARGET ADDRESS must lie within -20(8) to +17(8) locations relative to the current PROGRAM SOURCE ADDRESS.

DISP=Instruction Word (BITS 27-31) is computed as follows: DISP = targ - (PSA) + BIAS. Note that if FN was altered via a LDAPS instruction, at least one cycle must intervene before testing it with this instruction. This restriction applies to all BRANCH instructions that test conditions appearing in APSTATUS.

SPECIAL TEST FIELD (STEST)



VALUE

- 1      **BLT**      BRANCH if S-PAD FUNCTION is LESS THAN ZERO

**Assembler**

**Format:**      BLT targ

**Effect:**      If  $\text{SPFN} < 0$ ; then  $(\text{PSA}) + (\text{DISP}^+ - \text{BIAS}) \rightarrow \text{PSA}$  (Where  
 $\text{BIAS} = 20_8$ ).

**Description:** CONDITIONAL RELATIVE BRANCH. BLT will cause a program branch if the result of the last S-PAD operation (SPFN) was less than zero.

This instruction tests the condition of the SPFN-NEGATIVE Bit (N) of the APSTATUS Register. If "N" is equal to "1" (indicating that SPFN of the last previous instruction was negative), a program branch will occur to the BRANCH TARGET ADDRESS (targ) formed by adding the current contents of PSA with the BIASED contents of the DISP field of the current instruction word. If "N" is equal to "0," this instruction will have no effect.

SPECIAL TEST FIELD (STEST)



VALUE

- 2      BNC      BRANCH if S-PAD CARRY is equal to "1"

Assembler

Format:      BNC targ

Effect:      If S-PAD CARRY = 1; then  $(PSA) + (DISP^{\dagger} - BIAS) \rightarrow PSA$   
                  (Where BIAS =  $20_8$ ).

Description:    CONDITIONAL RELATIVE BRANCH. BNC will cause a program branch if the S-PAD CARRY Bit (C) of the APSTATUS Register is equal to "1."

Bit "C" will be equal to "1" if either:

\*the S-PAD CARRY Bit was set to "1" as a result of the last S-PAD operation and no S-PAD SHIFT was specified, or

\*a shift occurred during the last S-PAD operation and the last bit shifted "off the end" of the S-PAD Result was equal to "1."

SPECIAL TEST FIELD (STEST)



VALUE

- 3      BZC      BRANCH on S-PAD CARRY equal to ZERO

Assembler

Format:      BZC targ

Effect:      If S-PAD CARRY =  $\emptyset$ ; then  $(PSA) + (DISP^+ - BIAS) \rightarrow PSA$   
                  (Where  $BIAS = 20_8$ ).

Description:    CONDITIONAL RELATIVE BRANCH. BZC will cause a program branch if the S-PAD CARRY Bit (C) of the APSTATUS Register is equal to zero.

SPECIAL TEST FIELD (STEST)



VALUE

4      **BDBN**      BRANCH if DATA PAD BUS is NEGATIVE

Assembler

Format:      BDBN targ

Effect:      If  $(DB) < 0.0$ ; then  $(PSA) + (DISP^+ - BIAS) \rightarrow PSA$   
 $(\text{Where } BIAS = 20_8)$ .

Description: CONDITIONAL RELATIVE BRANCH. The sign of the DATA PAD BUS (MANTISSA) (DB[MANT]bit 00) is tested as to its state during the preceding instruction. If DB(MANT)Bit 00 was negative, (e.g., =1), a program branch will occur to the BRANCH TARGET ADDRESS (targ) formed by adding the current contents of PSA with the BIASED contents of the DISP field of the current instruction word. If DB(MANT)Bit 00 was "0," this instruction will have no effect.

NOTE: Since any data enabled onto DB is not latched, the programmer must re-enable the particular data onto DB one instruction cycle before attempting to test it with this instruction.

Note that instructions in the PS field (RPSF, LPSL, etc.) cannot be used to enable data onto Data Pad Bus for testing with this instruction.

SPECIAL TEST FIELD (STEST)



VALUE

5      BDBZ      BRANCH if DATA PAD BUS is POSITIVE and UNNORMALIZED

Assembler

Format:      BDBZ targ

Effect:      If DB<sup>MANT</sup> Bits 00,01 = "0", then (PSA) + (DISP<sup>+</sup> - BIAS) → PSA  
 (Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH. BDBZ will cause a program branch to occur to the BRANCH TARGET ADDRESS (targ), formed by adding the current contents of PSA with the BIASED contents of the DISP field of the current instruction word, if the sign of the DATA PAD BUS(MANTISSA)(DB[MANT]Bit 00), enabled during the preceding instruction, was positive (e.g.,=0) and DB(MANT)Bit 01 was also equal to "0," (indicating an UNNORMALIZED MANTISSA). If either or both Bits equal(s) "1," this instruction will have no effect.

NOTE: Since any data enabled onto DB is not latched, the programmer must re-enable the particular data onto DB one cycle before attempting to test it by this instruction.

SPECIAL TEST FIELD (STEST)



VALUE

6      **BIFN**      BRANCH if INVERSE FFT FLAG = 1

Assembler

Format:      BIFN targ

Effect:      If IFFT (APSTATUS Bit 11) = 1; then (PSA) + (DISP<sup>+</sup> - BIAS) + PSA  
                  (Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH. BIFN will cause a program branch if the Inverse FFT Flag (IFFT) of the APSTATUS Register is set to "1."

IFFT is APSTATUS(bit 11) and can be set by an LDAPS instruction. (See LDREG, I/O.) It is normally set to "1," along with APSTATUS(bit 12) (FFT), only during an INVERSE FAST FOURIER TRANSFORM.

7      **BIFZ**      BRANCH if IFFT FLAG = 0

Assembler

Format:      BIFZ targ

Effect:      If IFFT (APSTATUS Bit 12) = Ø; then (PSA) = (DISP<sup>+</sup> - BIAS) + PSA  
                  (Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH. BIFZ will cause a program branch if the INVERSE FFT Flag (IFFT) of the APSTATUS Register is cleared to zero.

SPECIAL TEST FIELD (STEST)



VALUE

10 through 13                  No Operation

|    |      |                               |
|----|------|-------------------------------|
| 14 | BFL0 | BRANCH if GENERAL FLAG #0 = 1 |
| 15 | BFL1 | BRANCH if GENERAL FLAG #1 = 1 |
| 16 | BFL2 | BRANCH if GENERAL FLAG #2 = 1 |
| 17 | BFL3 | BRANCH if GENERAL FLAG #3 = 1 |

Assembler

Format:                  BFLn targ

Effect:                  If FLAG n=1; then (PSA) + (DISP<sup>†</sup> - BIAS) → PSA  
                           (Where BIAS = 20<sub>8</sub>).

Description: A branch will occur to program location "targ" (assembler format) if flag "n" is set to "1." Flag "n" must have been set or cleared two cycles before the current instruction cycle in order to be tested, i.e., at least one cycle must intervene between a set or clear flag instruction and a branch flag instruction.

Note: The CONDITIONAL RELATIVE BRANCH instructions test the condition of either of four GENERAL FLAGS (0,1,2,3) available for use in the AP. These flags may be "set" or "cleared" by software instructions. (See FLAG, I/O.)

HOST/PANEL FIELD (HOSTPNL)



VALUE

0

**PNLLIT**

TRANSFER PANEL BUS to the LITES REGISTER

Assembler  
Format:

PNLLIT

Effect: (PNLBS) → LITES

Description: The current data enabled onto the 16-bit PANEL BUS are loaded into the 16-bit LITES REGISTER.

1

**DBELIT**

TRANSFER DATA PAD BUS<sup>EXPONENT</sup> to the LITES REGISTER,  
via PANEL BUS

Assembler  
Format:

DBELIT

Effect: (DB<sup>EXP</sup>) PNLBS → LITES; right justified.

Description: The current data enabled onto the 10-bit DATA PAD BUS<sup>EXPONENT</sup> are loaded into the 16-bit LITES REGISTER - right justified. The transfer is via the PANEL BUS.

HOST/PANEL FIELD (HOSTPNL)



VALUE

2



TRANSFER DATA PAD BUS - HIGH MANTISSA to the LITES REGISTER, via PANEL BUS

Assembler

Format: DBHLIT

Effect: (DB<sup>HMANT</sup>) → PNLBS → LITES; right justified

Description: The current data enabled onto the DATA PAD BUS (MANTISSA Bits 00-11) are loaded into the 12 right-most bits of the LITES REGISTER. The transfer is via PANEL BUS.

3



TRANSFER DATA PAD BUS <sup>LOW MANTISSA</sup> to the LITES REGISTER, via PANEL BUS

Assembler

Format: DBLLIT

Effect: (DB<sup>LMANT</sup>) → PNLBS → LITES

Description: The current data enabled onto the DATA PAD BUS (MANTISSA Bits 12-27) is loaded into the LITES REGISTER, via the PANEL BUS.

HOST/PANEL FIELD (HOSTPNL)



VALUE

4 through 7      **NOP**      No Operation

10      **SWDB**      TRANSFER SWITCHES to the DATA PAD BUS, via PANEL BUS

Assembler Format:

Example: DPX(1)< DB; SWDB

Effect:      (SWR<sup>Bits 06-15</sup>) → DB<sup>EXP</sup> Bits 02-11,  
                 (SWR<sup>Bits 04-15</sup>) → DB<sup>MANT</sup> Bits 00-11,  
                 (SWR) → DB<sup>MANT</sup> Bits 12-27.      } via PNLBS

Description: The current contents of the 16-bit SWITCH Register (SWR) are enabled onto the DATA PAD BUS (DB) in the following manner:

SWR(bits 06-15) are enabled onto the DATA PAD BUS(EXPONENT),

SWR(bits 04-15) are enabled onto the DATA PAD BUS(HIGH MANTISSA), and

SWR(bits 00-15) are enabled onto the DATA PAD BUS(LOW MANTISSA).

The transfer is via PNLBS.

This instruction is used concurrently with a write from DATA PAD BUS operation to transfer the contents of SWR into a designated memory location or Register. Use of this instruction disables any current DB or PNLBS source-enabling operation.

**HOST/PANEL FIELD (HOSTPNL)**



### VALUE

11 SWDBE TRANSFER SWITCHES to the DATA PAD BUS<sup>EXONENT</sup>  
via PANEL BUS

## Assembler Format:

Example: DPY (-2) < DB; SWDBE

Description: The current contents of the 16-bit SWITCH Register (SWR) are enabled onto the DATA PAD BUS (DB) and a WRTEXP is forced.

A WRTEXP is forced as part of this instruction, restricting the writing to the EXPONENT portion of the designated memory location.

<sup>†</sup> see, SOPI for a detailed description of WRTEXP

**HOST/PANEL FIELD (HOSTPNL)**



## VALUE

12 SWDBH TRANSFER SWITCHES to DATA PAD BUS HIGH MANTISSA

## Assembler Format:

TRANSFER SWITCHES to DATA PAD BUS HIGH MANTISSA

**Assembler  
Format:** SWDBH

Example: SETMA; MI < DB; SWDBH

Effect:      (SWR<sup>Bits Ø6-15</sup>) → DB<sup>EXP</sup> Bits Ø2-11, } via PNLBS;WRTHMN<sup>+</sup>  
                 (SWR<sup>Bits Ø4-15</sup>) → DB<sup>MANT</sup> Bits ØØ-11, } is forced  
                 (SWR) → DB<sup>MANT</sup> Bits 12-27. }

Description: The current contents of the 16-bit SWITCH Register (SWR) are enabled onto the DATA PAD BUS (DB) in the following manner:

The transfer is via PNLBS.

A WRTHMN is forced as part of this instruction, restricting the writing to the HIGH-MANTISSA portion (MANTISSA[bits 00-11]) of the designated memory location, only.

<sup>†</sup> See SOP1 for a detailed description of WRTHMN

HOST/PANEL FIELD (HOSTPNL)



VALUE

|                      |                                                                                                                                                         |                                                               |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
| 14<br>through<br>17  | NOP                                                                                                                                                     | No Operation                                                  |
| 13                   | SWDBL                                                                                                                                                   | TRANSFER SWITCHES to DATA PAD BUS <small>LOW MANTISSA</small> |
| Assembler<br>Format: | SWDBL                                                                                                                                                   |                                                               |
| Effect:              | Example: SWDBL; DPY(1) < DB                                                                                                                             |                                                               |
|                      | (SWR Bits Ø6-15) —> DB <sup>EXP</sup> Bits Ø2-11,<br>(SWR Bits Ø4-15) —> DB <sup>MANT</sup> Bits ØØ-11,<br>(SWR) ——————> DB <sup>MANT</sup> Bits 12-27. | via PNLBS; WRTLMN <sup>†</sup><br>is forced                   |

Description: The current contents of the 16-bit SWITCH Register (SWR) are enabled onto the DATA PAD BUS (DB) in the following manner:

The transfer is via PNLBS.

A WRTLMN is forced as part of this instruction, restricting the writing to the LOW-MANTISSA portion (MANTISSA[bits 12-27]) of the designated memory location only.

<sup>†</sup> See SOP1 for a detailed description of WRTLMN

SET PROGRAM SOURCE ADDRESS (SETPSA)



VALUE

Ø      JMPA      JUMP (ABSOLUTE)

Assembler

Format:      JMPA adr

Effect:      (VALUE) → PSA

Description: JMPA forces the address contained in the least-significant 12 bits of the VALUE field (Instruction Word<sup>Bits 48-63</sup>) into the 12-bit PROGRAM SOURCE ADDRESS REGISTER (PSA). The effect is an ABSOLUTE JUMP to the location in program memory contained in the VALUE field.

SET PROGRAM SOURCE ADDRESS (SETPSA)



VALUE

|   |      |                                |
|---|------|--------------------------------|
| 1 | JSRA | JUMP to SUB ROUTINE (ABSOLUTE) |
|---|------|--------------------------------|

Assembler

Format: JSRA adr

Effect:  $(SRA) + 1 \rightarrow SRA; (PSA) + 1 \rightarrow SRS_{SRA}; (VALUE) \rightarrow PSA$

Description: SUB-ROUTINE JUMP. First, the contents of the current PROGRAM SOURCE ADDRESS (PSA), plus "1," are saved by incrementing the SUB-ROUTINE STACK ADDRESS REGISTER (SRA) and storing the current  $[(PSA) + 1]$  into the "last-in" location of the SUB-ROUTINE RETURN STACK (SRS).

The least-significant 12 bits of the VALUE field (Instruction Word[bits 48-63]) are then loaded into the 12-bit PROGRAM SOURCE ADDRESS REGISTER (PSA). The program then jumps to that location. (See also RETURN, BRANCH.)

WARNINGS: The JSR instructions have a timing problem that causes certain instruction sequences to execute improperly. The following sequences should be avoided by the programmer:

- 1) Instruction from PS, PSEVEN or PSODD followed by a JSR.

example: LDPSL  
JSRA

- 2) HALT instruction or a Panel Breakpoint before a JSR.

example: HALT  
JSRT

- 3) Execution of consecutive RETURN instructions. This appears in the coding as a JSR followed by a RETURN.

example: JSR  
RETURN

These cases all result in a mismatch between the subroutine Return address pointers (SRA) and program execution, and thus will cause severe debugging problems if extreme caution is not taken to avoid them.

### SET PROGRAM SOURCE ADDRESS (SETPSA)



VALUE

2           JUMP (RELATIVE)

Assembler

Format:            JMP adr

Effect:            (VALUE) + (PSA) → PSA

Description: UNCONDITIONAL RELATIVE JUMP. The address contained on the least-significant 12 bits of the VALUE field (Instruction Words Bits 48-63) is added to the current contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA). The address thus formed is loaded into PSA and the program jumps to that location.

3           JUMP TO SUB ROUTINE (RELATIVE)

Assembler

Format:            JSR adr

Effect:            (SRA) + 1 → SRA; (PSA) + 1 → SRS<sub>SRA</sub>;  
                      (VALUE) + (PSA) → PSA

Description: RELATIVE SUB-ROUTINE JUMP. First, the current contents of the PROGRAM SOURCE ADDRESS (PSA) plus "1" are saved by incrementing the SUB-ROUTINE ADDRESS REGISTER (SRA) and storing [(PSA) + 1] into the "last-in" position of the SUB-ROUTINE RETURN STACK (SRS<sub>SRA</sub>). The address contained in the least-significant 12 bits of the VALUE field (Instruction Word Bits 48-63) is added to the current contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA). The address thus formed is loaded into PSA and the program jumps to that location, (see also, RETURN, BRANCH ).

SET PROGRAM SOURCE ADDRESS (SETPSA)



VALUE

- 4      JMPT      JUMP to location specified by TABLE MEMORY ADDRESS (ABSOLUTE)

Assembler

Format:      JMPT

Example:      ADD 1,2; SETTMA

Effect:      (TMA)  $\rightarrow$  PSA

Description: UNCONDITIONAL ABSOLUTE JUMP. The contents of the PROGRAM SOURCE REGISTER (PSA) are replaced by the least-significant 12 bits of the current contents of the TABLE MEMORY ADDRESS REGISTER (TMA).

- 5      JSRT      JUMP to SUB-ROUTINE at location specified by TABLE MEMORY ADDRESS (ABSOLUTE)

Assembler

Format:      JSRT

Example:      ADD 1,2; SETTMA

JSRT

Effect:      (SRA) + 1  $\rightarrow$  SRA; (PSA) + 1  $\rightarrow$  SRS<sub>SRA</sub>; (TMA Bits 04-15)  $\rightarrow$  PSA

Description: UNCONDITIONAL ABSOLUTE SUB-ROUTINE JUMP. First, the current PROGRAM SOURCE ADDRESS plus "1" is saved by incrementing the SUB-ROUTINE ADDRESS POINTER (SRA) and storing [(PSA) + 1] into the "last-in" position of the SUB-ROUTINE RETURN STACK (SRS<sub>SRA</sub>).

The contents of PSA are then replaced by the least-significant 12 bits of the current contents of the TABLE MEMORY ADDRESS REGISTER (TMA). The program then jumps to the new PROGRAM SOURCE location. (See also, RETURN, BRANCH ).

SET PROGRAM SOURCE ADDRESS (SETPSA)



VALUE

6

JMPP

JUMP to location indicated by SWITCH REGISTER,  
via PANEL BUS (ABSOLUTE)

Assembler

Format:

JMPP

Effect:

(SRW<sup>Bits Ø4-15</sup>) → PNLBS → PSA

Description: UNCONDITIONAL ABSOLUTE JUMP. The current contents of the least-significant 12 bits of the SWITCH REGISTER (SWR) are loaded into the PROGRAM SOURCE ADDRESS REGISTER (PSA) via the PANEL BUS (PNLBS).

The program then jumps to the new PROGRAM SOURCE location.

WARNING: Propagation delays inherent when executing JMPP may disallow proper decoding of certain target instructions. The preferred alternative sequence is as follows:

$t_n$  SWDB; LDTMA  
 $t_{n+1}$  JMPT

SET PROGRAM SOURCE ADDRESS (SETPSA)



VALUE

- 7      **JSRP**      JUMP to SUB-ROUTINE pointed by the SWITCH REGISTER

Assembler  
Format:

JSRP

Effect:       $(SRA) + 1 \rightarrow SRA; (PSA) + 1 \rightarrow SRS_{SRA};$   
 $(SWR \text{ bits } \emptyset 4-15) \rightarrow PNLBS \rightarrow PSA$

Description: UNCONDITIONAL ABSOLUTE SUB-ROUTINE JUMP. First, the current PROGRAM SOURCE ADDRESS (PSA) plus "1" is "saved" by incrementing the SUB-ROUTINE ADDRESS POINTER (SRA) by "1" and storing  $[(PSA) + 1]$  into the "last-in" position of the SUB-ROUTINE RETURN STACK ( $SRS_{SRA}$ ).

Then the contents of the PROGRAM SOURCE ADDRESS REGISTER are replaced by the current contents of the least significant 12 bits of the SWITCH REGISTER (via the PANEL BUS). The program then jumps to the new PROGRAM SOURCE location. (See also, RETURN, BRANCH ).

WARNING: Propagation delays inherent when executing JSRP may disallow proper decoding of certain target instructions. The preferred alternative sequence is as follows:

$t_n$       SWDB; LDTMA  
 $t_{n+1}$       JSRT

## PSEVEN, PSODD AND PS FIELDS

The following instructions available in the PSEVEN and PSODD fields involve PROGRAM SOURCE partial-word transfers via the PANEL BUS. Addressing for a given instruction may be RELATIVE or ABSOLUTE. (See SPEC SUMMARY.) All instructions within these fields require two cycles to execute and instructions from other fields which reference PNLBS for addressing or use PNLBS as a transfer-conduit should not be concurrently specified.

Formats for the various PS partial-words is given below:

Please note the warnings in the HALT, BDBN, BDBZ and JSRA descriptions for WRT the PS, PSEVEN and PSODD instructions.

### NOTES

- 1) When VALUE or TMA is used as an addressing subscript, the least-significant 12 bits are used.

Example:

```
PS(Q0)(VALUE)=PS(Q0)(VALUE)(bits 52-63)  
PS(Q0)(TMA)=PS(Q0)(TMA)(bits 04-15)
```

TMA is TMA Register, not the Table Memory Address which may be modified by the FFT bit APSTATUS.

- 2) PS Quarter 0 is Bits 00 to 15 = PS(Q0)  
1           16 to 31 = PS(Q1)  
2           32 to 47 = PS(Q2)  
3           48 to 64 = PS(Q3)

PROGRAM SOURCE - EVEN FIELD (PSEVEN)



VALUE

- |                                                                                                                  |                                                                                                         |
|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| <b>0</b><br>                                                                                                     | READ PROGRAM SOURCE QUARTER $\emptyset$ to LITES (ABSOLUTE)                                             |
| Assembler Format: RPS0A adr<br>Effect: $(PS^{\emptyset} \text{ VALUE}) \rightarrow PNLBS \rightarrow LITES$      |                                                                                                         |
| <b>1</b><br>                                                                                                     | READ PROGRAM SOURCE QUARTER 2 from LITES (ABSOLUTE)                                                     |
| Assembler Format: RPS2A adr<br>Effect: $(PS^2 \text{ VALUE}) \rightarrow PNLBS \rightarrow LITES$                |                                                                                                         |
| <b>2</b><br>                                                                                                     | READ PROGRAM SOURCE QUARTER $\emptyset$ to LITES (RELATIVE)                                             |
| Assembler Format: RPS0 adr<br>Effect: $(PS^{\emptyset} \text{ VALUE} + PSA) \rightarrow PNLBS \rightarrow LITES$ |                                                                                                         |
| <b>3</b><br>                                                                                                     | READ PROGRAM SOURCE QUARTER 2 to LITES (RELATIVE)                                                       |
| Assembler Format: RPS2 adr<br>Effect: $(PS^2 \text{ VALUE} + PSA) \rightarrow PNLBS \rightarrow LITES$           |                                                                                                         |
| <b>4</b><br>                                                                                                     | READ PROGRAM SOURCE QUARTER $\emptyset$ to LITES<br>from the location specified by TABLE MEMORY ADDRESS |
| Assembler Format: RPS0T<br>Effect: $(PS^{\emptyset} \text{ TMA}) \rightarrow PNLBS \rightarrow LITES$            |                                                                                                         |

PROGRAM SOURCE - EVEN FIELD (PSEVEN)



VALUE

- 5      **RPS2T**      READ PROGRAM SOURCE QUARTER 2 to LITES  
from the location specified by TABLE MEMORY ADDRESS
- Assembler Format: RPS2T  
Effect: (PS<sup>Q2</sup><sub>TMA</sub>) → PNLBS → LITES
- 6 and 7      **NOP**      No Operation
- 10     **WPSØA**      WRITE PROGRAM SOURCE QUARTER Ø from the  
SWITCHES (ABSOLUTE)
- Assembler Format: WPSØA adr  
Effect: (SWR) → PNLBS → PS<sup>ØØ</sup><sub>VALUE</sub>
- 11     **WPS2A**      WRITE PROGRAM SOURCE QUARTER 2 from the  
SWITCHES (ABSOLUTE)
- Assembler Format: WPS2A adr  
Effect: (SWR) → PNLBS → PS<sup>Q2</sup><sub>VALUE</sub>

PROGRAM SOURCE - EVEN FIELD (PSEVEN)



VALUE

12      WRITE PROGRAM SOURCE QUARTER 0 from the SWITCHES (RELATIVE)

Assembler  
Format:

WPS0 adr

Effect:

(SWR) → PNLBS → PS<sup>Q0</sup>  
VALUE + PSA

13      WRITE PROGRAM SOURCE QUARTER 2 from the SWITCHES (RELATIVE)

Assembler  
Format:

WPS2 adr

Effect:

(SWR) → PNLBS → PS<sup>Q2</sup>  
VALUE + PSA

14      WRITE PROGRAM SOURCE QUARTER 0 from the SWITCHES at the location specified by TABLE MEMORY ADDRESS

Assembler  
Format:

WPS0T

Effect:

(SWR) → PNLBS → PS<sup>Q2</sup>  
TMA

15      WRITE PROGRAM SOURCE QUARTER 2 from the SWITCHES at the location specified by TABLE MEMORY ADDRESS

Assembler  
Format:

WPS2T

Effect:

(SWR) → PNLBS → PS<sup>Q2</sup>  
TMA

PROGRAM SOURCE - ODD FIELD (PSODD)



VALUE

g RPS1A READ PROGRAM SOURCE QUARTER 1 to LITES (ABSOLUTE)

Assembler  
Format:  
Effect: RPS1A adr  
(PS<sup>Q1</sup> VALUE) → PNLBS → LITES

1 RPS3A READ PROGRAM SOURCE QUARTER 3 from LITES (ABSOLUTE)

Assembler  
Format:  
Effect: RPS3A adr  
(PS<sup>Q3</sup> VALUE) → PNLBS → LITES

2 RPS1 READ PROGRAM SOURCE QUARTER 1 to LITES (RELATIVE)

Assembler  
Format:  
Effect: RPS1 adr  
(PS<sup>Q1</sup> VALUE + PSA) → PNLBS → LITES

3 RPS3 READ PROGRAM SOURCE QUARTER 3 to LITES (RELATIVE)

Assembler  
Format:  
Effect: RPS3 adr  
(PS<sup>Q3</sup> VALUE + PSA) → PNLBS → LITES

PROGRAM SOURCE - ODD FIELD (PSODD)



VALUE

4      **RPS1T**      READ PROGRAM SOURCE QUARTER 1 to LITES from the location specified by TABLE MEMORY ADDRESS

Assembler Format: RPS1T  
Effect: (PS<sup>Q1</sup><sub>TMA</sub>) → PNLBS → LITES

5      **RPS3T**      READ PROGRAM SOURCE QUARTER 3 to LITES from the location specified by TABLE MEMORY ADDRESS

Assembler Format: RPS3T  
Effect: (PS<sup>Q3</sup><sub>TMA</sub>) → PNLBS → LITES

6 and 7      **NOP**      No Operation

10      **WPS1A**      WRITE PROGRAM SOURCE QUARTER 1 from the SWITCHES (ABSOLUTE)

Assembler Format: WPS1A adr  
Effect: (SWR) → PNLBS → PS<sup>Q1</sup><sub>VALUE</sub>

11      **WPS3A**      WRITE PROGRAM SOURCE QUARTER 3 from the SWITCHES (ABSOLUTE)

Assembler Format: WPS3A adr  
Effect: (SWR) → PNLBS → PS<sup>Q3</sup><sub>VALUE</sub>

PROGRAM SOURCE - ODD FIELD (PSODD)



VALUE

12      **WPS1**      WRITE PROGRAM SOURCE<sup>QUARTER 1</sup> from the SWITCHES (RELATIVE)

Assembler  
Format:

WPS1 adr

Effect:

(SWR) → PNLBS → PS<sup>Q1</sup>  
                          VALUE + PSA

13      **WPS3**      WRITE PROGRAM SOURCE<sup>QUARTER 3</sup> from the SWITCHES (RELATIVE)

Assembler  
Format:

WPS3 adr

Effect:

(SWR) → PNLBS → PS<sup>Q3</sup>  
                          VALUE + PSA

14      **WPSLT**     WRITE PROGRAM SOURCE<sup>QUARTER 1</sup> from the SWITCHES  
                         at the location specified by TABLE MEMORY ADDRESS

Assembler  
Format:

WPSLT

Effect:

(SWR) → PNLBS → PS<sup>Q1</sup>  
                          TMA

15      **WPS3T**     WRITE PROGRAM SOURCE<sup>QUARTER 3</sup> from the SWITCHES  
                         at the location specified by TABLE MEMORY ADDRESS

Assembler  
Format:

WPS3T

Effect:

(SWR) → PNLBS → PS<sup>Q3</sup>  
                          TMA

PROGRAM SOURCE FIELD (PS)



VALUE



Assembler

Format: RPSLA adr

Effect:  $(PS^{LH})_{VALUE} \rightarrow DB$

Description: PROGRAM SOURCE(LEFT HALF) ( $PS_{LH}$ )=PS bits 00-31], as addressed by the least-significant 12 bits contained in the VALUE field (Instruction Word bits 48-63]), is enabled onto DATA PAD BUS (DB).

The transfer is executed in the following manner:

- \* ZEROS  $\longrightarrow$  DB(EXP)Bits 02-07
- \* PS(Bits 00-03)  $\longrightarrow$  DB(EXP)Bits 08-11
- \* PS(Bits 04-31)  $\longrightarrow$  DB(MANT)Bits 00-27

This instruction requires two cycles to execute.

PROGRAM SOURCE FIELD (PS)



VALUE

1      **RPSFA**      READ PROGRAM SOURCE <sup>FLOATING-POINT LITERAL</sup> to  
                          DATA PAD BUS (ABSOLUTE)

Assembler  
Format:      RPSFA adr  
Effect:      (PS<sup>FPL</sup>  
                  VALUE) → DB

Description: PROGRAM SOURCE(FLOATING-POINT LITERAL) (PS[FPL]=PS bits [26-63]), as addressed by the least-significant 12 bits contained in the VALUE field (Instruction Word bits 48-63]), is enabled onto DATA PAD BUS (DB).

The transfer is executed in the following manner:

|                  |                    |
|------------------|--------------------|
| * PS(Bits 26-35) | DB(EXP)Bits 02-11  |
| * PS(Bits 36-63) | DB(MANT)Bits 00-27 |

This instruction requires two cycles to execute.

PROGRAM SOURCE FIELD (PS)



VALUE

2 RPSL READ PROGRAM SOURCE <sup>LEFT HALF</sup> to DATA PAD BUS (RELATIVE)

Assembler  
Format: RPSL adr  
Effect:  $(PS^{LH} \text{ VALUE} + PSA) \rightarrow DB$

3 RPSF READ PROGRAM SOURCE <sup>FLOATING-POINT LITERAL</sup> to  
DATA PAD BUS (RELATIVE)

Assembler  
Format: RPSF adr  
Effect:  $(PS^{FPL} \text{ VALUE} + PSA) \rightarrow DB$

This instruction requires two cycles to execute.

4 RPSLT READ PROGRAM SOURCE <sup>LEFT HALF</sup> to DATA PAD BUS from the  
location specified by TABLE MEMORY ADDRESS (ABSOLUTE)

Assembler  
Format: RPSLT  
Effect:  $(PS^{LH}_{TMA}) \rightarrow DB$

This instruction requires two cycles to execute.

PROGRAM SOURCE FIELD (PS)



VALUE

5



READ PROGRAM SOURCE <sup>FLOATING-POINT LITERAL</sup> to DATA PAD BUS  
from the location specified by TABLE MEMORY ADDRESS (ABSOLUTE)

Assembler  
Format:

RPSFT

Effect:

(PS <sup>FPL</sup><sub>TMA</sub>) → DB

This instruction requires two cycles to execute.

6



READ PROGRAM SOURCE <sup>LEFT HALF</sup> to DATA PAD BUS from  
the address contained on PANEL BUS (ABSOLUTE)

Assembler  
Format:

RPSLP

Effect:

(PS <sup>LH</sup><sub>PNLBS</sub>) → DB

This instruction requires two cycles to execute.

7



READ PROGRAM SOURCE <sup>FLOATING-POINT LITERAL</sup> to DATA PAD BUS  
from the address contained on PANEL BUS (ABSOLUTE)

Assembler  
Format:

RPSFP

Effect:

(PS <sup>FPL</sup><sub>PNLBS</sub>) → DB

This instruction requires two cycles to execute.

PROGRAM SOURCE FIELD (PS)



VALUE

10 LPSLA LOAD PROGRAM SOURCE <sup>LEFT HALF</sup> from DATA PAD BUS (ABSOLUTE)

Assembler

Format: LPSLA adr

Effect: (DB) → PS <sup>LH</sup>  
VALUE

Description: The right-most 32 bits of the DATA currently enabled onto DATA PAD BUS (DB) are loaded into the PROGRAM SOURCE(LEFT HALF) (PS LH]=PS bits 00-31]).

The transfer is executed in the following manner:

- \* DB(EXP) Bits 08-11 → PS(Bits 00-03)
- \* DB(MANT) Bits 00-27 → PS(Bits 04-31)

This instruction requires two cycles to execute.

**PROGRAM SOURCE FIELD (PS)**



### VALUE

11 LPSRA LOAD PROGRAM SOURCE from DATA PAD BUS (ABSOLUTE)

## Assembler

### **Format:**

Effect: (DB)  $\rightarrow$  PS<sup>RH</sup>  
VALUE

Description: The right-most 32 bits of data currently enabled onto the DATA PAD BUS (DB) are loaded into the PROGRAM SOURCE(RIGHT HALF) (PS [RH]=PS bits [48-63]) as addressed by the least-significant 12 bits of the VALUE field (Instruction Word bits 48-63]).

The transfer is executed in the following manner:

- \* DB(EXP) Bits 08-11 → PS(Bits 32-35)  
\* DB(MANT) Bits 00-27 → PS(Bits 36-63)

This instruction requires two cycles to execute.

PROGRAM SOURCE FIELD (PS)



VALUE

12      LOAD PROGRAM SOURCE <sup>LEFT HALF</sup> from DATA PAD BUS (RELATIVE)

Assembler  
Format: LPSL adr  
Effect: (DB)  $\rightarrow$  PS<sup>LH</sup> VALUE + PSA

This instruction requires two cycles to execute.

13      LOAD PROGRAM SOURCE <sup>RIGHT HALF</sup> from DATA PAD BUS (RELATIVE)

Assembler  
Format: LPSR adr  
Effect: (DB)  $\rightarrow$  PS<sup>RH</sup> VALUE + PSA

This instruction requires two cycles to execute.

14      LOAD PROGRAM SOURCE <sup>LEFT HALF</sup> from DATA PAD BUS as addressed by TABLE MEMORY ADDRESS (ABSOLUTE)

Assembler  
Format: LPSLT  
Effect: (DB)  $\rightarrow$  PS<sup>LH</sup> TMA

This instruction requires two cycles to execute.

PROGRAM SOURCE FIELD (PS)



VALUE

- 15 LOAD PROGRAM SOURCE <sup>RIGHT HALF</sup> from DATA PAD BUS as addressed by TABLE MEMORY ADDRESS (ABSOLUTE)

Assembler Format: LPSRT  
Effect: (DB) → PS <sup>RH</sup> TMA

This instruction requires two cycles to execute.

- 16 LOAD PROGRAM SOURCE <sup>LEFT HALF</sup> from DATA PAD BUS at the address contained on PANEL BUS (ABSOLUTE)

Assembler Format: LPSLP  
Effect: (DB) → PS <sup>LH</sup> PNLBS

This instruction requires two cycles to execute.

- 17 LOAD PROGRAM SOURCE <sup>RIGHT HALF</sup> from DATA PAD BUS at the address contained on PANEL BUS (ABSOLUTE)

Assembler Format: LPSRP  
Effect: (DB) → PS <sup>RH</sup> PNLBS

This instruction requires two cycles to execute.

SET EXIT FIELD (SETEXIT)



VALUE

|   |        |                             |
|---|--------|-----------------------------|
| Ø | NOP    | No Operation                |
| 1 | SETEXA | SET EXIT ADDRESS (ABSOLUTE) |

Assembler  
Format: SETEXA  
Effect: (VALUE) → SRS<sub>SRA</sub>

Description: The contents of the current SUB-ROUTINE RETURN ADDRESS (SRS[SRA]), the "last-in" address, are replaced by the least-significant 12 bits of the VALUE field (Instruction Word[bits 48-63]). SRA not affected.

|   |       |                             |
|---|-------|-----------------------------|
| 2 | NOP   | No Operation                |
| 3 | SETEX | SET EXIT ADDRESS (RELATIVE) |

Assembler  
Format: SETEX adr  
Effect: (VALUE = PSA) → SRS<sub>SRA</sub>

Description: The contents of the current SUB-ROUTINE RETURN ADDRESS (SRS<sub>SRA</sub>), the "last-in" address, are replaced with the address formed by adding the current contents of the PROGRAM SOURCE ADDRESS (PSA) to the least-significant 12 bits contained on the VALUE field.

SET EXIT FIELD (SETEXIT)



VALUE

4      **NOP**      No Operation

5      **SETEXT**      SET EXIT ADDRESS from TABLE MEMORY ADDRESS (ABSOLUTE)

Assembler

Format:      SETEXT

Effect:      (TMA) → SRS<sub>SRA</sub>

Description: The contents of the current SUB-ROUTINE RETURN ADDRESS (SRS<sub>SRA</sub>), the "last-in" address, are replaced by the least-significant 12 bits of the current contents of the TABLE MEMORY ADDRESS REGISTER (TMA).

6      **NOP**      No Operation

7      **SETEXP**      SET EXIT ADDRESS from PROGRAM SOURCE ADDRESS plus ONE (ABSOLUTE)

Assembler

Format:      SETEXP

Effect:      (PSA + 1) → SRS<sub>SRA</sub>

Description: The contents of the current SUB-ROUTINE RETURN ADDRESS (SRS<sub>SRA</sub>), the "last-in" address, are replaced by the current contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA) plus "1".

BRANCH GROUP (BRANCH)



VALUE

Ø No Operation

1  S-PAD DESTINATION REGISTER NO-LOAD

Assembler  
Format: < # >

(Example: ADDL# 4,5)

Effect: (SPFN) → SP<sub>SPD</sub> is inhibited.

Description: This instruction inhibits the normal loading of the current S-PAD OPERATION result (SPFN) back into the S-PAD DESTINATION REGISTER (SP<sub>SPD</sub>) specified during the S-PAD Operation. (See S-PAD summary)

NOTE: Brackets indicate optional use with S-PAD operations.

BRANCH GROUP (BRANCH)



VALUE

2



UNCONDITIONAL BRANCH (RELATIVE)

Assembler

Format:

BR disp

(Examples: BR LOOP)

Effect:

$(PSA) + (DISP^+ - BIAS) \rightarrow PSA$

(Where BIAS = 20<sub>8</sub>).

Description: UNCONDITIONAL RELATIVE BRANCH

The program will branch to the target location "disp" (Assembler Format) by adding the current PSA to the BIASED value contained in the DISplacement field of the instruction word.

NOTE: The BRANCH TARGET ADDRESS must be within a range of -20(8) to +17(8) locations relative to the current PROGRAM SOURCE ADDRESS (PSA).

DISP = bits 27-31 of the current instruction word and is completed as follows:

$\dagger$  DISP = disp - PSA + BIAS.

BRANCH GROUP (BRANCH)



↓

VALUE

3



BRANCH ON INTERRUPT REQUEST FLAG NON-ZERO

Assembler

Format:           BINTRQ    disp

Effect:           If INTRQ = 1, then (PSA) + (DISP - BIAS) → PSA  
(Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH if Interrupt Request.

If the INTERRUPT REQUEST FLAG (INTRQ) equals "1," then the program will branch to the target location "disp."

This instruction can be used in conjunction with a succeeding INTA instruction (see I/O group) to identify the interrupting I/O device.

4



BRANCH ON I/O DATA READY FLAG NON-ZERO

Assembler

Format:           BION      disp

Effect:           If IODRDY (DA) = 1, then (PSA) + (DISP - BIAS) → PSA  
(Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH is I/O Device Ready.

If the I/O DATA READY FLAG (IODRDY) of the I/O device specified by the I/O DEVICE ADDRESS REGISTER (DA) is "1," then the program will branch to the target location "disp."

BRANCH GROUP (BRANCH)



VALUE

- 5      **BIOZ**      BRANCH ON I/O DATA READY FLAG ZERO

Assembler

Format:      BIOZ    disp

Effect:      If  $(IODRDY_{DA}) = \emptyset$ , then  $(PSA) + (DISP - BIAS) \rightarrow PSA$   
(Where  $BIAS = 20_8$ ).

Description: CONDITIONAL RELATIVE BRANCH if I/O Device not ready.

If the I/O DATA READY FLAG (IODRDY) of the I/O DEVICE specified by the I/O DEVICE ADDRESS REGISTER (DA) equals "0," then the program will branch to the target location "disp."

- 6      **BFPE**      BRANCH ON FLOATING POINT ERROR

Assembler

Format:      BFPE    disp

Effect:      If OVF, UNF, or DIVZ = "1", then  $(PSA) + (DISP - BIAS) \rightarrow PSA$   
(Where  $BIAS = 20_8$ ).

Description: CONDITIONAL RELATIVE BRANCH if Floating Point Error.

The OVERFLOW (OVF), UNDERFLOW (UNF), and DIVIDE BY ZERO (DIVZ), FLAGS (bits 0, 1, 2 of the APSTATUS REGISTER) are tested. If any of the three flags = "1," then a branch will occur to the target location "disp."

BRANCH GROUP (BRANCH)



VALUE

7           RETURN FROM SUB-ROUTINE

Assembler  
Format:      RETURN

Effect:       $(SRS_{SRA}) \rightarrow PSA; (SRA) -1 \rightarrow SRA$

Description: UNCONDITIONAL RETURN JUMP.

The address contained in the "last-in" position of the SUB-ROUTINE RETURN STACK (SRS) is forced into the PROGRAM SOURCE ADDRESS REGISTER (PSA) and the program branches to that program location.

The SUB-ROUTINE ADDRESS POINTER REGISTER (SRA) is then decremented by "1," and will point to the next "last-in" SUB-ROUTINE ADDRESS in event of another RETURN instruction. RETURN effects a "RETURN" from the last SUB-ROUTINE call.

NOTE: Two or more RETURNS may not be executed in time sequential instructions. There must be at least one instruction cycle between the last RETURN instruction and the next one, e.g., the following coding example is illegal in that it results in having the visible RETURN instruction execute immediately after the RETURN instruction in "sub" that brings the processor back to this level.

illegal code:      JSR sub  
                      RETURN

BRANCH GROUP (BRANCH)



VALUE

10       BRANCH on FLOATING ADDER EQUAL ZERO

Assembler

Format:      BFEQ    disp

Example:    BFEQ .-3

Effect:      If FA = 0.0, then (PSA) + (DISP - BIAS)  $\rightarrow$  PSA  
(Where BIAS =  $20_8$ ).

Description: CONDITIONAL RELATIVE BRANCH if FA equal to zero.

BFEQ will cause a PROGRAM BRANCH if the FLOATING ADDER Result (FA) available during the previous instruction was equal to 0.0. This instruction tests the FZ FLAG (bit 3 of APSTATUS) as set by the previous instruction. If FZ is equal to "1," (i.e., FA during the last instruction was equal to 0.0), then the program will branch to the target location "disp."

BRANCH GROUP (BRANCH)



VALUE

11

BFNE

BRANCH on FLOATING ADDER NOT EQUAL to ZERO

Assembler

Format:

BFNE disp

Example: BFNE HELP+6

Effect:

If FA  $\neq$  0.0, then (PSA) + (DISP - BIAS)  $\rightarrow$  PSA  
(Where BIAS =  $20_8$ ).

Description: CONDITIONAL RELATIVE BRANCH if FA not equal to zero.

BFNE will cause a PROGRAM BRANCH if the FLOATING ADDER Result for the previous instruction was not equal to 0.0. This instruction tests the FZ flag (bit 3 of APSTATUS) as set by the previous instruction. If FZ equals "0" (i.e., FA for the last instruction was not equal to 0.0), the branch will occur to the target location "disp."

BRANCH GROUP (BRANCH)



VALUE

12           BFGE           BRANCH on FLOATING ADDER GREATER or EQUAL to ZERO

Assembler  
Format:       BFGE    disp

Effect:       If FA> 0.0, then (PSA) + (DISP - BIAS)+ PSA  
(Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH if FA greater than or equal to zero.

BFGE will cause a PROGRAM BRANCH if the FLOATING ADDER Result (FA) for the previous instruction was greater than or equal to 0.0.

This instruction tests the condition of the FLOATING ADDER NEGATIVE (FN) FLAG (bit 4 of APSTATUS) as set by the previous instruction.

If FN equals "0," (indicating that FA was not negative, i.e., greater than or equal to zero, during the last instruction cycle), a branch will occur to the TARGET ADDRESS "disp."

BRANCH GROUP (BRANCH)



VALUE

13

BFGT

BRANCH on FLOATING ADDER GREATER THAN ZERO

Assembler

Format:           BFGT     disp

Effect:           If FA > 0.0, then (PSA) + (DISP - BIAS)\* PSA  
(Where BIAS = 20<sub>8</sub>)

Description: CONDITIONAL RELATIVE BRANCH if FA greater than zero.

BFGT will cause a PROGRAM BRANCH to occur if the last FLOATING ADDER RESULT (FA) for the previous instruction was greater than 0.0.

The instruction tests the FLOATING ADDER ZERO (FZ) and FLOATING ADDER NEGATIVE (FN) flags (bits 3 and 4 of APSTATUS) as set by the previous instruction.

If both flags equal "0" (indicating that FA during the last instruction was greater than zero), then the program will branch to the target location "disp."

BRANCH GROUP (BRANCH)



↓  
VALUE

14      BEQ      BRANCH on S-PAD RESULT EQUALS ZERO

Assembler  
Format:      BEQ    disp

Effect:      If SPFN =  $\emptyset$ , then (PSA) + (DISP - BIAS)  $\rightarrow$  PSA  
(Where BIAS =  $20_8$ ).

Description: CONDITIONAL RELATIVE BRANCH if SPFN equals zero.

BEQ will cause a PROGRAM BRANCH if the result of the last S-PAD operation (SPFN) was equal to zero.

This instruction tests the S-PAD ZERO FLAG (Z) (bit 5 of APSTATUS) as set by the previous instruction. If Z equals "1" (indicating that SPFN of the last S-PAD operation was equal to zero), then a branch will occur to the target location "disp."

BRANCH GROUP (BRANCH)



VALUE

15



BRANCH on S-PAD RESULT NON-ZERO

Assembler

Format:

BNE disp

Effect:

If SPFN  $\neq \emptyset$ , then (PSA) + (DISP + BIAS)  $\rightarrow$  PSA  
(Where BIAS =  $20_8$ ).

Description: CONDITIONAL RELATIVE BRANCH if SPFN not equal to zero.

BNE will cause a PROGRAM RELATIVE BRANCH if the result of the last previous S-PAD operation (SPFN) was not equal to 0.

The instruction tests the S-PAD ZERO FLAG (Z) (bit 5 of APSTATUS) as set by the previous instruction. If Z equals "0" (indicating that SPFN of the last S-PAD operation was not equal to zero), then a branch will occur to the target location "disp."

BRANCH GROUP (BRANCH)

|      |    |    |    |    |      |    |    |    |
|------|----|----|----|----|------|----|----|----|
| 23   | 24 | 25 | 26 | 27 | 28   | 29 | 30 | 31 |
| COND |    |    |    |    | DISP |    |    |    |



VALUE

16



BRANCH on S-PAD RESULT GREATER or EQUAL to ZERO

Assembler

Format: BGE disp

Effect: If SPFN > 0, then (PSA) + (DISP - BIAS) → PSA  
(Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH if SPFN greater than or equal to zero.

BGE will cause a PROGRAM BRANCH if the result of the last S-PAD operation (SPFN) was greater than or equal to zero.

The instruction tests the S-PAD NEGATIVE FLAG (N) (bit 6 of APSTATUS) as set by the previous instruction. If N is equal to "0" (indicating SPFN of the last operation was zero or greater), a branch will occur to the target location "disp."

BRANCH GROUP (BRANCH)

|      |    |    |    |    |      |    |    |    |
|------|----|----|----|----|------|----|----|----|
| 23   | 24 | 25 | 26 | 27 | 28   | 29 | 30 | 31 |
| COND |    |    |    |    | DISP |    |    |    |

↓  
VALUE

17       BRANCH on S-PAD RESULT GREATER THAN ZERO

Assembler

Format:            BGT     disp

Effect:            If SPFN > 0, then (PSA) + (DISP - BIAS) → PSA  
(Where BIAS = 20<sub>8</sub>).

Description: CONDITIONAL RELATIVE BRANCH if SPFN greater than zero.

BGT will cause a PROGRAM BRANCH if the result of the last S-PAD operation (SPFN) was greater than zero.

The instruction tests the S-PAD ZERO (Z) and S-PAD NEGATIVE (N) flags (bits 5, 6 or APSTATUS) as set by the previous instruction. If both flags equal "0" (indicating SPFN of last S-PAD operation was greater than zero), then a branch will occur to the target location "disp."

## FLOATING ADDER GROUP (FADD)



ALUE

0 See FADD1 field.

1 FSUBR FLOATING-POINT SUBTRACT REVERSE;  
A2 minus A1.

Assembler  
Format: FSUBR < A1, A2 > (< > indicates optional fields)

Effect: (A2) - (A1)  
FSUBR TM,MD

Description: FSUBR reverses the order of operands in a FLOATING-POINT SUBTRACTION. The contents of A1 REGISTER (A1) undergo a FLOATING-POINT SUBTRACTION from the contents of A2 REGISTER (A2).

The NORMALIZED, CONVERGENTLY-ROUNDED RESULT is available as the FLOATING-ADDER OUTPUT (FA) one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

2 FSUB FLOATING-POINT SUBTRACT; A1 minus A2.

Assembler  
Format: FSUB < A1, A2 >

Effect: (A1) - (A2)

Description: The contents of A2 REGISTER (A2) undergo a FLOATING-POINT SUBTRACTION from the contents of A1 REGISTER (A1).

The NORMALIZED, CONVERGENTLY-ROUNDED RESULT becomes available as the FLOATING ADDER OUTPUT (FA) one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

## FLOATING ADDER GROUP (FADD)



ALUE

3      FADD      FLOATING-POINT ADD; A1 plus A2.

Assembler  
Format:      FADD < A1, A2 >

Effect:      (A1) + (A2)

Description: The contents of A1 REGISTER undergo a FLOATING-POINT ADDITION with the contents of A2 REGISTER.

The NORMALIZED, CONVERGENTLY-ROUNDED RESULT becomes available as the FLOATING ADDER OUTPUT (FA) one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

## FLOATING ADDER GROUP (FADD)



VALUE

4

FEQV

FLOATING-POINT LOGICAL EQUIVALENCE;  
A1 with A2.

Assembler  
Format:            FEQV < A1, A2 >

Effect:            (A1)  $\overline{\text{XOR}}$  (A2)

Description: The MANTISSAS of A1 and A2 are compared for EQUIVALENCE in the following manner:

Following the arithmetic right-shift of the MANTISSA corresponding to the smaller EXPONENT, the MANTISSAS of A1 and A2, including the three bits of residue, undergo a "bit by bit" comparison. When corresponding bits of A1 and A2 are equal; (i.e., both "0"s or both "1"s), a "1" is written into the corresponding bit of the RESULT. All other combinations result in a "0" being written.

The NORMALIZED, CONVERGENTLY-ROUNDED RESULT of this logical operation becomes available as the FLOATING ADDER OUTPUT (FA) one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

## FLOATING ADDER GROUP (FADD)



ALUE

5            FAND            FLOATING-POINT AND; A1, A2.

Assembler  
Format:            FAND < A1, A2 >

Effect:            (A1) and (A2)

Description: The MANTISSAS of A1 and A2 are logically ANDED in the following manner:

Following the arithmetic right-shift of the MANTISSA corresponding to the smaller EXPONENT, the MANTISSAS of A1 and A2 undergo a "bit by bit" comparison. When corresponding bits of A1 and A2 both equal "1," then a "1" is written into the corresponding bit position of the RESULT. All other combinations result in a "0" being written.

The NORMALIZED, CONVERGENTLY-ROUNDED RESULT of this logical operation becomes available as the FLOATING ADDER OUTPUT (FA) one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

## FLOATING ADDER GROUP (FADD)



:LUE

6 FOR FLOATING-POINT OR; A1 or A2.

Assembler Format: FOR < A1, A2 >

Effect: (A1) OR (A2)

Description: The contents of A1 and A2 are ORed in the following manner:

Following the arithmetic right-shift of the MANTISSA corresponding to the smaller EXPONENT, the MANTISSAS of A1 and A2, including the three bits of residue, undergo a "bit by bit" comparison. When either or both corresponding bits of A1 and A2 equal "1," a "1" is written into the corresponding bit position of the RESULT. When neither corresponding bit is equal to "1," a "0" is written.

The NORMALIZED and CONVERGENTLY-ROUNDED RESULT of this logical operation becomes available as the FLOATING ADDER OUTPUT (FA) one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

## FLOATING ADDER GROUP (FADD)



**VALUE**

- ) No-operation.



## Assembler

**Format:** FIX <A2> (< > indicates optional field)

**Effect:** Convert (A2) to a 28-Bit Two's Complement integer.  
**Example:** FIX MD

Description: The contents of A2 are FIXED to an integer in the following manner:

1) An exponent of 28 (apparent value = 1034 [octal]) is forced into A

- 1) An exponent of 28 (apparent value = 1034 [octal]) is forced into A1(EXPONENT). A1(MANTISSA) = 0. A2 contains the selected argument to be FIXED.<sup>†</sup>
  - 2) The EXPONENTS of the operands are compared and the MANTISSA corresponding to the smaller EXPONENT is arithmetically right-shifted the number of positions that reflect the difference in the two EXPONENTS. The aligned MANTISSAS are then algebraically added producing a PRELIMINARY-RESULT along with the larger of the two input exponents.
  - 3) The PRELIMINARY-RESULT(EXPONENT) is decremented by "1" and the PRELIMINARY-RESULT(MANTISSA) is correspondingly left-shifted one position while preserving the MANTISSA-SIGN.
  - 4) The PRELIMINARY-RESULT is then CONVERGENTLY-ROUNDED and becomes available as FA one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

If the TRUE-VALUE of A2(EXPONENT) was in a range of 1 to 27, then the TRUE-VALUE of the RESULT(EXPONENT) will be 27 (APPARENT-VALUE=1033 [octal] or 539). If RESULT(MANTISSA) is  $\leq$  2 (-28), then a FLOATING-POINT ZERO is forced as the result.

<sup>†</sup>The TRUE-VALUE of A2(EXPONENT) must not exceed +27.  
(APPARENT-VALUE $\leq$ 1033(octal). If the TRUE-VALUE of A2(EXPONENT) $\geq$ 28, the following RESULT will be obtained:

RESULT(EXPONENT)=A2(EXPONENT)minus "1;"      RESULT(MANTISSA-SIGN)=A2(MANTISSA-SIGN).

RESULT(MANTISSA Bits 01-26)=A2(MANTISSA Bits 02-27);RESULT (MANTISSA Bit 27)=0.

## FLOATING ADDER GROUP (FADD)



↓  
VALUE

2      FIXT      FIX and TRUNCATE A2 to an INTEGER

Assembler

Format:      FIXT <A2>

Effect:      Convert (A2) to a 28-Bit Two's Complement INTEGER; TRUNCATE  
(sign magnitude)

Example:      FIXT DPX(3)

Description: The contents of A2(MANTISSA) are FIXED to an integer and the RESULT is TRUNCATED in the following manner:

- 1) Current SPFN(Bits 06-15) plus BIAS are forced into A1(EXPONENT).  
A1(MANTISSA)=0 . A2 contains the selected argument to be  
FIXED.†
- 2) The EXPONENTS of the operands are compared and the MANTISSA  
corresponding to the smaller EXPONENT is arithmetically right-  
shifted the number of positions that reflect the difference in  
the two EXPONENTS. The aligned MANTISSAS are then algebraical-  
ly added producing a PRELIMINARY-RESULT.
- 3) The PRELIMINARY-RESULT(EXPONENT) is decremented by "1" and  
the PRELIMINARY-RESULT(MANTISSA) is correspondingly left-  
shifted. (This operation preserves the MANTISSA-SIGN fol-  
lowing an internal sign-extension operation).
- 4) The Truncation truth table logic is enabled for this  
operation (see Floating Point Arithmetic theory) and a  
TRUNCATED RESULT becomes available as FA one cycle after  
the next FADDR group instruction is initiated. (See  
FADDR SUMMARY.)

If the TRUE-VALUE of A2(EXPONENT) was in a range of 1 to 27, then the  
TRUE-VALUE of the RESULT(EXPONENT) will be 27  
(APPARENT-VALUE=1033[octal] or 539). If RESULT(MANTISSA) is <2(-27),  
then a FLOATING-POINT ZERO is forced as the result.

†TRUE-VALUE of A2(EXPONENT) must not exceed +27. (APPARENT-VALUE 539).

If TRUE-VALUE of A2(EXPONENT) 28, the following RESULT will be  
obtained:

RESULT(EXPONENT)=A2(EXPONENT)minus "1";      RESULT(MANTISSA-SIGN)=A2(MANTISSA-SIGN),  
RESULT(MANTISSA Bits 01-26)=A2(MANTISSA Bits 02-27);RESULT(MANTISSA Bit 27)=0.

## FLOATING ADDER GROUP (FADD)



Assembler Format: FSCLT A2

Effect: Shift A2<sup>MANTISSA</sup> right and increment  
 $(A2^{EXONENT})$  until  $A2_E = (SPFN + BIAS) - 1$ ;  
 result TRUNCATED. Converts an FPN to a 28-Bit Two's  
 Complement integer within a dynamic range of  $2^{27}$ .

Description: The contents of A2(MANTISSA) are SCALED in the following manner:

- 1) Current SPFN(Bits 06-15) plus BIAS(=512) are forced into A1(EXPONENT). A1(MANTISSA)=0†. A2 contains the selected argument to be SCALED.††
- 2) The EXPONENTS of the operands are compared and the MANTISSA corresponding to the smaller EXPONENT is arithmetically right-shifted the number of positions that reflect the difference in the two EXPONENTS. The aligned MANTISSAS are then algebraically added producing a PRELIMINARY-RESULT.
- 3) The PRELIMINARY-RESULT(EXPONENT) is decremented by "1" and the PRELIMINARY-RESULT(MANTISSA) is correspondingly left-shifted. (This operation preserves the MANTISSA-SIGN following an internal sign-extension operation).
- 4) The CONVERGENT-ROUNDING logic is inhibited for this operation and a TRUNCATED RESULT becomes available as FA one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY).

If the TRUE-VALUE OF A2(EXPONENT) was in a range of 1 to 27, then the TRUE-VALUE of the RESULT(EXPONENT) will be 27 (APPARENT-VALUE=1033[octal] or 539). If RESULT(MANTISSA) is < 2(-28), then a FLOATING-POINT ZERO is forced as the result.

†Current SPFN(Bits 06-15) must equal maximum A2 Exponent plus "1" in order to obtain a correct result from this operation.

††TRUE-VALUE of A2(EXPONENT) must not exceed the value of current SPFN minus "1." If it does, the result obtained will be the same as in the case of FIX or FIXT when A2(EXP) ≥ 28.

## FLOATING ADDER 1 FIELD (FADD)



VALUE

4                    **FSM2C**                    FORMAT-CONVERSION; A2 from SIGNED-MAGNITUDE to TWO'S COMPLEMENT<sup>†</sup>

### Assembler

Format:              **FSM2C        A2**

Effect:              Converts (A2) from SIGNED-MAGNITUDE to TWO'S-COMPLEMENT.

Description: The contents of A2 REGISTER are converted from SIGNED-MAGNITUDE to TWO'S-COMPLEMENT format in the following manner:

- 1) If A2(MANTISSA) is negative, then A2(MANTISSA bit 00) (MANTISSA-SIGN) remains unchanged while A2(MANTISSA Bits 01-27) undergo a TWO'S-COMPLEMENT conversion.
- 2) If A2(MANTISSA) is positive, A2(MANTISSA) is unchanged.

The normalized RESULT becomes available as the FLOATING ADDER OUTPUT (FA) one cycle after the next FADDR group operation. This operation can result in Floating Point underflow if the exponent is large and negative and the mantissa unnormalized. (See FADDR SUMMARY).

<sup>†</sup>See FLOATING-POINT THEORY, Types of notation.

This operation can result in FLOATING-POINT underflow if the exponent is large and negative and the mantissa unnormalized.

## FLOATING ADDER 1 FIELD (FADD)



VALUE

5

F2CSM

FORMAT CONVERSION; A2 from TWOS-COMPLEMENT to SIGNED-MAGNITUDE.<sup>†</sup>

Assembler

Format: F2CSM A2

Effect: Convert (A2) from TWOS-COMPLEMENT to SIGNED-MAGNITUDE.

Description: The contents of A2 REGISTER are converted to SIGN-MAGNITUDE format in the following manner:

- 1) If A2(MANTISSA) is positive, A2(MANTISSA) is unchanged.
- 2) If A2(MANTISSA) is negative, then A2(MANTISSA Bit 00) (MANTISSA-SIGN) remains unchanged while A2(MANTISSA Bits 01-27) undergo a TWOS-COMPLEMENT conversion.

The normalized and convergently rounded RESULT becomes available as the FLOATING ADDER OUTPUT (FA) one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY). Both underflow and overflow are possible as a result of this operation.

<sup>†</sup> See FLOATING-POINT SUMMARY, Types of Notation

## FLOATING ADDER 1 FIELD (FADD)



VALUE

6      **FSCALE**      FLOATING-POINT SCALE of A2 (rounded result)

Assembler  
Format:  
Shift ( $A_2^{MANTISSA}$ ) right and increment  
 $(A_2^{EXONENT})$  until  $(A_2^{EXONENT}) = (\text{SPFN})$   
+ BIAS -1

Description: The contents of A2 are SCALED in the following manner:

- 1) Current SPFN(Bits 06-15)plus BIAS(=512)are forced into A1(EXPONENT). A1(MANTISSA)=0†. A2 contains the selected argument to be SCALED. ††
- 2) The EXPONENTS of the operands are compared and the MANTISSA corresponding to the smaller EXPONENT is arithmetically right-shifted the number of positions that reflect the difference in the two EXPONENTS. The aligned MANTISSAS are then algebraically added producing a PRELIMINARY-RESULT.
- 3) The PRELIMINARY-RESULT(EXPONENT)is decremented by "1" and the PRELIMINARY-RESULT(MANTISSA)is correspondingly left-shifted. (This operation preserves the MANTISSA-SIGN following an internal sign-extension operation).
- 4) The PRELIMINARY-RESULT is then CONVERGENTLY-ROUNDED and becomes available as FA one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY.)

If RESULT(MANTISSA)is  $\leq 2(-28)$ , then a FLOATING-POINT ZERO is forced as the result.

† Current SPFN(Bits 06-15)must equal maximum plus "1" in order to obtain a correct result from this operation.

†† TRUE-VALUE OF A2(EXPONENT)must not exceed the value of current SPFN minus "1."

## FLOATING ADDER 1 FIELD (FADD)



VALUE

7

FABS

FORMAT CONVERSION; A2 to ABSOLUTE VALUE.

### Assembler

Format: FABS A2

Effect: (A2) → ABSOLUTE VALUE

Description: The contents of A2 are converted to ABSOLUTE VALUE format in the following manner:

- 1) If A2(MANTISSA) is positive, A2(MANTISSA) is unchanged.  
A2 becomes the PRELIMINARY RESULT.
- 2) If A2(MANTISSA) is negative, then A2(MANTISSA Bits 00-27) undergo a TWOS-COMPLEMENT conversion. (See FLOATING-POINT SUMMARY -- Types of Notation).

The PRELIMINARY RESULT is then normalized and CONVERGENTLY-ROUNDED and becomes available as FA one cycle after the next FADDR group instruction is initiated. (See FADDR SUMMARY). Both overflow and underflow are possible as a result of this operation.

## FLOATING-ADDER GROUP (A1)



### FLOATING ADDER REGISTER INPUT SUMMARY

A1

#### VALUE

|           |                                                       |                                                                                     |                                                                                                    |
|-----------|-------------------------------------------------------|-------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| Ø         | <table border="1"><tr><td>NC</td></tr></table>        | NC                                                                                  | NO CHANGE: The contents of A1 during the last FADDR operation are used as the A1 REGISTER OPERAND. |
| NC        |                                                       |                                                                                     |                                                                                                    |
|           |                                                       | Assembler Format: FADD NC, <A2> Note: If no A1 operand is specified, NC is implied. |                                                                                                    |
|           |                                                       | Effect: A1 is unaltered from previous operation.                                    |                                                                                                    |
| 1         | <table border="1"><tr><td>FM</td></tr></table>        | FM                                                                                  | The current FLOATING-MULTIPLIER OUTPUT (FM) is the A1 REGISTER OPERAND.                            |
| FM        |                                                       |                                                                                     |                                                                                                    |
|           |                                                       | Assembler Format: FSUB FM, <A2>                                                     |                                                                                                    |
|           |                                                       | Effect: (FM) → A1                                                                   |                                                                                                    |
| 2         | <table border="1"><tr><td>DPX (idx)</td></tr></table> | DPX (idx)                                                                           | DATA PAD X (DPA + XR -4) is the A1 REGISTER OPERAND.                                               |
| DPX (idx) |                                                       |                                                                                     |                                                                                                    |
|           |                                                       | Assembler Format: FSUBR DPX (idx), <A2>                                             |                                                                                                    |
|           |                                                       | Effect: [DPX (DPA + XR -4)] → A1                                                    |                                                                                                    |
| 3         | <table border="1"><tr><td>DPY (idx)</td></tr></table> | DPY (idx)                                                                           | DATA PAD Y (DPA + YR -4) is A1 REGISTER OPERAND.                                                   |
| DPY (idx) |                                                       |                                                                                     |                                                                                                    |
|           |                                                       | Assembler Format: FOR DPY (idx), <A2>                                               |                                                                                                    |
|           |                                                       | Effect: [DPY (DPA + YR -4)] → A1                                                    |                                                                                                    |

4



The current contents of the TABLE MEMORY REGISTER  
(TMREG) is the A1 REGISTER OPERAND (See MEMORY  
GROUP SUMMARY - TM)

Assembler  
Format:

FAND TM, <A2>

Effect:

(TMREG) → A1

5, 6  
and  
7



FLOATING-POINT ZERO (0.0) is the A1 REGISTER  
OPERAND.

Assembler  
Format:

FEQV ZERO, <A2>

Effect:

0.0 → A1

## FLOATING ADDER GROUP



### FLOATING ADDER REGISTER INPUT SUMMARY

A2

OCTAL  
VALUE

Ø



The contents of A2 during the last FADDR operation are used as the A2 REGISTER operand.

Assembler  
Format:

FADD <A1>, NC

Effect:

(A2) is unaltered from previous operation.

1



The current FLOATING ADDER OUTPUT (FA) is the A2 REGISTER operand.

Assembler  
Format:

FIX FA

Effect:

(FA) → A2

2



DATA PAD X (DPA + XR -4) is the A2 REGISTER operand.

Assembler  
Format:

FSCLT DPX(idx)

Effect:

[DPX(DPA + XR -4)] → A2

3



DATA PAD Y (DPA + YR -4) is the A2 REGISTER operand.

Assembler  
Format:

FABS DPY(idx)

Effect:

[DPX(DPA + YR -4)] → A2

|   |                   |                                                                                                                                                                         |
|---|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                   | The current contents of the MAIN DATA MEMORY OUTPUT REGISTER (MDREG) are used as the A2 REGISTER operand. (See MEMORY GROUP SUMMARY - MD).                              |
| 4 | MD                |                                                                                                                                                                         |
|   | Assembler Format: | F2CSM MD                                                                                                                                                                |
|   | Effect:           | (MDREG) $\rightarrow$ A2                                                                                                                                                |
| 5 | ZERO              | FLOATING POINT ZERO (0.0) is the A2 REGISTER operand.                                                                                                                   |
|   | Assembler Format: | FADD <A1>, ZERO                                                                                                                                                         |
|   | Effect:           | 0.0 $\rightarrow$ A2                                                                                                                                                    |
| 6 | MDPX (idx)        | "Split-word" transfer to A2. (mantissa of DPX)                                                                                                                          |
|   |                   | (1) The SPAD FUNCTION (SPFN) plus the BIAS-VALUE (512) forms the EXPONENT portion of the A2 OPERAND.                                                                    |
|   |                   | (2) The MANTISSA portion of DATA PAD X <sub>(DPA + XR - 4)</sub> forms the MANTISSA portion of the A2 OPERAND.                                                          |
|   | Assembler Format: | FSUB <A1>, MDPX (idx)                                                                                                                                                   |
|   | Effect:           | (SPFN) + 512 $\rightarrow$ A2 <sup>EXPONENT</sup> ;<br>[DPX <sub>(DPA + XR - 4)</sub> ] $\rightarrow$ A2 <sup>MANTISSA</sup>                                            |
| 7 | EDPX (idx)        | " Split-word" transfer to A2. (exponent of DPX)                                                                                                                         |
|   |                   | (1) The EXPONENT of DATA PAD X <sub>(DPA + XR - 4)</sub> forms the EXPONENT portion of the A2 OPERAND.                                                                  |
|   |                   | (2) The 2 least-significant bits of SPAD FUNCTION (SPFN bits 14,15) are put into A2 <sup>MANTISSA</sup> bits 00, 01. The remainder of A2 <sup>MANTISSA</sup> is zeroed. |

EDPX (idx) is used to generate either a  
+1 or -1 MANTISSA value.

Assembler  
Format:

FSUBR <Al>, EDPX (idx)

Effect:

[DPX (DPA + XR -4)] → A2<sup>EXPONENT</sup>;  
(SPFN Bits 14, 15) → A2<sup>MANTISSA</sup> bits 00, 01;  
0s → A2<sup>MANTISSA</sup> bits 01-27.

## FLOATING MULTIPLIER GROUP



### VALUE

$\emptyset$  No Operation

1      **FMUL**      FLOATING POINT MULTIPLY

Assembler  
Format:      FMUL <M1,M2><sup>†</sup>

Effect:      (M1) \* (M2)

Description: A FLOATING POINT MULTIPLY (FMUL) is initiated using the operands selected by the M1 and M2 fields.

The CONVERGENTLY-ROUNDED result becomes available as FM 1 cycle after it has been "pushed" through the 3 stage pipeline by two subsequent FMUL operations. (See, FMULR SUMMARY).

<sup>†</sup> M1 and M2 operands need not be specified if a "dummy" is desired.

## M1 REGISTER SUMMARY



VALUE

- |                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>0      </p> <p>Assembler Format:      FMUL      FM,&lt;M2&gt;</p> <p>Effect:      (FM) → M1</p><br><p>1      </p> <p>Assembler Format:      FMUL DPX(idx),&lt;M2&gt;</p> <p>Effect:      (DPX(DPA + idx)) → M1</p><br><p>2      </p> <p>Assembler Format:      FMUL DPY(idx),&lt;M2&gt;</p> <p>Effect:      (DPY(DPA + idx)) → M1</p><br><p>3      </p> <p>Assembler Format:      FMUL TM,&lt;M2&gt;</p> <p>Effect:      (TMREG) → M1</p> | <p>FLOATING MULTIPLIER OUTPUT is the M1 REGISTER OPERAND</p><br><p>DATA PAD X is the M1 REGISTER OPERAND</p><br><p>DATA PAD Y is the M1 REGISTER OPERAND</p><br><p>TABLE MEMORY OUTPUT REGISTER is the M1 REGISTER OPERAND</p> |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## M2 REGISTER SUMMARY



↓  
VALUE

0 FA FLOATING ADDER OUTPUT is the M2 REGISTER INPUT

Assembler Format: FMUL<M1>, FA

Effect: (FA) → M2

1 DPX(idx) DATA PAD X as M2 REGISTER INPUT

Assembler Format: FMUL<M1>, DPX(idx)

Effect: (DPX(DPA + idx)) → M2

2 DPY(idx) DATA PAD Y is the M2 REGISTER INPUT

Assembler Format: FMUL <M1>, DPY(idx)

Effect: (DPY(DPA + idx)) → M2

3 MD MAIN DATA MEMORY REGISTER is the M2 REGISTER INPUT

Assembler Format: FMUL<M1>, MD

Effect: (MDREG) → M2

## LOAD REGISTER FIELD (LDREG)



### VALUE

$\emptyset$  No Operation

1  LOAD S-PAD DESTINATION ADDRESS

#### Assembler Format:

LDSPD

Example: LDSPD;DB=DPX(-3)

Effect: (DPBS<sup>MANTISSA</sup> bits 24-27)  $\rightarrow$  SPD

Description: DPBS(MANTISSA)bits 24-27 replace the contents of the four-bit S-PAD DESTINATION ADDRESS REGISTER (SPD) as of the next instruction cycle.

NOTE: A current S-PAD operation is unaffected by this instruction. However, if an S-PAD operation is executed on the next instruction cycle, the assembled S-PAD DESTINATION ADDRESS (SPD) to be used in the S-PAD operation will be replaced with the contents of SPD produced as a result of this instruction.

2  LOAD MEMORY ADDRESS from the DATA PAD BUS;  
INITIATE A MEMORY CYCLE

#### Assembler Format:

LDMA

Example: LDMA;DB=DPX(-1)

Effect: (DPBS<sup>MANTISSA</sup> bits 12-27)  $\rightarrow$  MA

Description: DPBS(LOW MANTISSA) bits 12-27 are loaded into the MAIN DATA MEMORY ADDRESS REGISTER (MA) effective as of the next instruction cycle. A MAIN DATA (MD) MEMORY cycle is initiated using the new contents of MA. (See MEMORY GROUP SUMMARY.)

NOTE: This op-code supersedes INCMA and DECMA in the same instruction. It makes SETMA redundant since it would now load from DB instead of SPFN due to the use of the LDREG field.

LOAD REGISTER FIELD (LDREG)



VALUE

- 3      **LDIMA**      LOAD TABLE MEMORY ADDRESS from DATA PAD BUS

Assembler

Format:

LDTMA

Example: LDTMA;DB=DPY(-4)

Effect:                  MANTISSA (DPBS bits 12-27) → TMA

Description: The DATA PAD BUS (LOW MANTISSA) (DPBS [MANTISSA] bits 12-27) is loaded into the TABLE MEMORY ADDRESS REGISTER (TMA) effective as of the next instruction cycle.

Two cycles later the contents of the TABLE MEMORY location specified by the two new contents of TMA will become available as the contents of TABLE MEMORY OUTPUT REGISTER (TMREG).

NOTE: This op-code supersedes INCTMA and DECTMA in the same instruction. It makes SETTMA redundant.

- 4      **LDDPA**      LOAD DATA PAD ADDRESS from DATA PAD BUS

Assembler

Format:

LDDPA

Example: LDDPA;DB=DPX(3)

Effect:                  MANTISSA (DPBS bits 21-27) → DPA

Description: The contents enabled onto the DATA PAD BUS (MANTISSA) bits 12-27 are loaded into the DATA PAD ADDRESS REGISTER (DPA). The change in DPA is effective as of the next instruction cycle.

NOTE: LDDPA supersedes INC DPA and DEC DPA. It makes SET DPA redundant.

### LOAD REGISTER FIELD (LDREG)



VALUE

- 5      **LDSP**      LOAD S-PAD DESTINATION REGISTER from DATA PAD BUS

Assembler

Format:

Example: LDSP;DB=VALUE

Effect: (DPBS<sup>MANTISSA</sup> bits 12-27) → SP<sub>SPD</sub>

Description: The data currently enabled onto the DATA PAD BUS(MANTISSA)bits 12-27 are loaded into SP(SPD).

SPD is selected either via current S-PAD operation or a preceding LDSPD.

NOTE: LDSP supersedes LDSPNL, LDSPE and LDSPT. It makes LDSPI redundant. However, one of these op-codes could be used to select SPD if the immediately preceding instruction was not an LDSPD.

When combined with an S-PAD operation, LDSP results in the inclusive OR of SPFN and DPBS[MANTISSA](12-27) being written into SP(SPD).

- 6      **LDAPS**      LOAD APSTATUS REGISTER from DATA PAD BUS

Assembler

Format:

Example: LDAPS;DB=DPY(2)

Effect: (DPBS<sup>MANTISSA</sup> bits 12-27) -- APSTATUS

Description: The data currently enabled onto the DATA PAD BUS(MANTISSA) bits 12-27 are loaded into the APSTATUS REGISTER (APSTATUS). The new contents of APSTATUS may be tested. Two cycles later, i.e., at least one cycle must intervene between the LDAPS and a related test. Refer to the I/O Group Summary for a complete description of the effects of LDAPS.

LOAD REGISTER FIELD (LDREG)



OCTAL  
VALUE

7      **LDDA**      LOAD DEVICE ADDRESS from DATA PAD BUS.

Assembler

Format:      LDDA

Example:    LDDA;DB=VALUE

Effect:      The least significant 8 bits of the data currently enabled onto the DATA PAD BUS (DPBS) (DATA PAD BUS <sup>MANTISSA</sup> bits 20-27) are loaded into the 8 bit DEVICE ADDRESS REGISTER (DA); effective as of the next instruction cycle.

## READ REGISTER FIELD (RDREG)



VALUE

0 RPSA READ PROGRAM SOURCE ADDRESS onto the PANEL BUS.

Assembler  
Format: RPSA

Effect: (PSA) → PNLBS

Description: The contents of the PROGRAM SOURCE ADDRESS REGISTER (PSA) are enabled onto the PANEL BUS (bits 04-15). The value of PSA READ is the absolute address of this instruction.

1 RSPD READ SPAD DESTINATION ADDRESS REGISTER onto the PANEL BUS.

Assembler  
Format: RSPD

Effect: (SPD) → PNLBS

Description: The contents of the currently designated S-PAD DESTINATION ADDRESS (SPD) are enabled onto the PANEL BUS (PNLBS) (bits 12-15).

READ REGISTER FIELD (RDREG)



VALUE

- 2      RMA      READ MEMORY ADDRESS REGISTER onto the PANEL BUS

Assembler  
Format:      RMA

Effect:      (MA) → PNLBS

Description: The contents of the 16-bit MEMORY ADDRESS REGISTER (MA) are enabled onto the PANEL BUS (PNLBS) (bits 00-15).

- 3      RTMA      READ TABLE MEMORY ADDRESS onto the PANEL BUS

Assembler  
Format:      RTMA

Effect:      (TMA) → PNLBS

Description: The contents of the 16-bit TABLE MEMORY ADDRESS (TMA) are enabled onto the PANEL BUS (PNLBS) (bits 00-15).

The value read by this instruction is the contents of TMA as modified by the FFT and IFFT Bits in the APSTATUS Register (APSTATUS Bits 11 and 12). If APSTATUS Bit 12 is a "0," then this instruction reads the unmodified contents of TMA. Thus, this instruction always reads the actual address being presented to TABLE MEMORY. This is distinct from the JMPT, JSRT, LPSLT, LPSRT, etc. op-codes in the SPEC group that always use the unmodified contents of TMA Register.

READ REGISTER FIELD (RDREG)



VALUE

- 4      **RDPA**      READ DATA PAD REGISTER onto the PANEL BUS

Assembler  
Format: RDPA

Effect: (DPA) → PNLBS

Description: The contents of the six-bit DATA PAD ADDRESS REGISTER (DPA) are enabled onto the PANEL BUS (PNLBS) (bits 10-15).

NOTE: DPA appears to be six bits wide for the purposes of LDDPA, SETDPA, INC DPA, DEC DPA and RDPA. Only the least significant five bits, however, are effective in addressing DATA PAD.

- 5      **RSPFN**      READ S-PAD FUNCTION onto the PANEL BUS

Assembler  
Format: RSPFN

Effect: (SPFN) → PNLBS

Description: The result of the current S-PAD operation (SPFN) is enabled onto the PANEL BUS (bits 00-15) for this instruction cycle.

READ REGISTER FIELD (RDREG)



VALUE

6

RAPS

READ APSTATUS REGISTER onto the PANEL BUS

Assembler  
Format:

RAPS

Effect:  $(APSTATUS) \rightarrow PNLBS$

Description: The contents of the 16-bit APSTATUS REGISTER (APSTATUS) are enabled onto the PANEL BUS (PNLBS) (bits 00-15) during the current instruction cycle.

7

RDA

READ DEVICE ADDRESS onto the PANEL BUS

Assembler  
Format:

RDA

Effect:  $(DA) \rightarrow PNLBS$  bits 08-15; 0's  $\rightarrow PNLBS$  bits 00-07

Description: The current contents of the eight-bit DEVICE ADDRESS REGISTER (DA) are enabled onto the PANEL BUS (PNLBS), bits 08-15. Zeros are enabled onto the remaining left-most bits of PNLBS, bits 00-07.

INPUT/OUTPUT FIELD (IN/OUT)



VALUE



Assembler  
Format:

OUT

Example: DB=DPX;OUT

Effect: (DPBS)  $\rightarrow$  INBS  $\rightarrow$  I/O DEVICE (DA)

Description: The data enabled onto the DATA PAD BUS (DPBS) during this instruction is enabled onto the INPUT/OUTPUT BUS (INBS) where it becomes available for output to the I/O DEVICE specified by the DEVICE ADDRESS REGISTER (DA).



Assembler  
Format:

SPNOUT

Example: DA=DPY(3);SPNOUT

Effect: SPIN UNTIL IODRDY<sub>(DA)</sub> = 1; then, (DPBS)  $\rightarrow$  INBS  $\rightarrow$  I/O DEVICE<sub>(DA)</sub>

Description: First, the condition of the I/O DATA READY FLAG (IODRDY) is tested. If IODRDY = 0, then a SPIN will occur. When IODRDY = 1, the data currently enabled onto the DATA PAD BUS (DPBS) is enabled onto the INPUT/OUTPUT BUS (INBS) where it becomes available for output to the I/O DEVICE specified by the I/O DEVICE ADDRESS REGISTER (DA).

NOTE: If IODRDY(DA) never equals "1", an infinite SPIN condition will occur. This can only be cleared by an Interface Reset.

INPUT/OUTPUT FIELD (IN/CUT)



VALUE

2      **OUTDA**      OUTPUT DATA; then SET DEVICE ADDRESS from SPFN

Assembler

Format:                  OUTDA

Example:    MOV 5,5;DB=DPX(-2);OUTDA

Effect:                  (DPBS)  $\rightarrow$  INBS  $\rightarrow$  IODEVICE<sub>(DA)</sub>; then, (SPFN)  $\rightarrow$  DA

Description: First, the data currently enabled onto the DATA PAD BUS (DPBS) is enabled onto the INPUT/OUTPUT BUS (INBS), where it becomes available for output to the I/O DEVICE specified by the current contents of the I/O DEVICE ADDRESS REGISTER (DA).

Then, bits Ø8-15 of the current SPAD operation result (SPFN) are loaded into the 8 bit I/O DEVICE ADDRESS REGISTER; effective as of the next instruction cycle.

INPUT/OUTPUT FIELD (IN/OUT)



VALUE

- 3 SPOTDA SPIN until I/O DEVICE is READY; then OUTPUT DATA; then SET DEVICE ADDRESS from SPFN.

Assembler Format:

SPOTDA

Example: MOV 3,3;DB=MD;SPOTDA

Effect:

SPIN until IODRDY (DA)=1; then (DPBS)  $\rightarrow$  INBS  $\rightarrow$  I/O DEVICE (DA); then (SPFN)  $\rightarrow$  DA

Description: First, the condition of the I/O DATA READY FLAG (IODRDY[DA]) is tested. If IODRDY(DA)=0, then a SPIN will occur until IODRDY(DA)=1. When IODRDY(DA)=1, the data currently enabled onto the DATA PAD BUS (DPBS) is enabled onto the INPUT/OUTPUT BUS (INBS) for output to the I/O DEVICE specified by the current contents of the I/O DEVICE ADDRESS REGISTER (DA).

Then, the eight right-most bits (bits 08-15) of the current S-PAD operation result (SPFN) are loaded into the I/O DEVICE ADDRESS REGISTER (DA); effective as of the next instruction cycle.

NOTE: If IODRDY(DA) never equals "1", then an infinite SPIN will occur.

INPUT/OUTPUT FIELD (IN/OUT)



VALUE

4            INPUT DATA from I/O DEVICE (DA)

Assembler  
Format:

IN

Example: IN;DPX(2)<DB; DB = INBS

Effect:      I/O DEVICE (DA) → INBS

Description: The data input from the I/O DEVICE specified by the I/O DEVICE ADDRESS REGISTER (DA) is enabled onto the INPUT/OUTPUT BUS (INBS).

NOTE: In order to be used internally by the AP-120B, the data input onto the INBS must be enabled onto the DPBS. This is achieved by a concurrent software instruction to that effect, such as in the assembler format example above. (Note that the assembler would equate the form DPX(2)<INBS to the two instructions shown above).

5            SPIN UNTIL I/O DEVICE is READY; then INPUT DATA.

Assembler  
Format:

SPININ

Example: SPININ;DPX<INBS

Effect:      SPIN until IODRDY (DA)=1; then (I/O DEVICE (DA)) → INBS

Description: First, a SPIN is executed until the I/O DATA READY FLAG (IODRDY), for the I/O DEVICE SPECIFIED by the I/O DEVICE ADDRESS REGISTER (DA), is equal to "1."

Then, (when IODRDY (DA)=1), the data from the I/O DEVICE (DA) is enabled onto the INPUT/OUTPUT BUS (INBS).

NOTE: If IODRDY (DA) never equals "1," an infinite SPIN loop will occur.

INPUT/OUTPUT FIELD (IN/OUT)



VALUE

6



INPUT DATA; then SET DEVICE ADDRESS from SPFN

Assembler  
Format:

INDA

Example: MOV 5,5;INDA;DPY < INBS

Effect:

(I/O DEVICE<sub>(DA)</sub>) → INBS; then (SPFN) → DA .

Description: First, the data input from the I/O DEVICE specified by the current contents of the I/O DEVICE REGISTER (DA), is enabled onto the INPUT/OUTPUT BUS (INBS).

Then, bits 08-15 of the current S-PAD operation result (SPFN) is set into the I/O DEVICE ADDRESS REGISTER (DA); effective as of the next instruction cycle.

INPUT/OUTPUT FIELD (IN/OUT)



VALUE

7      **SPINDA**      SPIN UNTIL I/O DEVICE READY; then INPUT DATA;  
then SET DEVICE ADDRESS from SPFN.

Assembler

Format:

Example: MOV 6,6;SPINDA;DB=INBS

Effect:      SPIN until IODRDY=1, then (I/O DEVICE<sub>(DA)</sub>) → INBS;  
then (SPFN) → DA

Description: First, a SPIN is executed until the I/O DATA READY FLAG(IODRDY) of the I/O DEVICE specified by the contents of the I/O DEVICE ADDRESS REGISTER (DA) is equal to "1."

When IODRDY(DA)=1, the data from the I/O DEVICE(DA) is input onto the INPUT/OUTPUT BUS (INBS).

Then the right-most bits of the current S-PAD operation result (SPFN) are loaded into the I/O DEVICE ADDRESS REGISTER (DA); effective as of the next instruction cycle.

If IODRDY (DA) never equals "1," an infinite SPIN loop will be incurred.

## I/O SENSE FIELD (SENSE)



VALUE



Assembler  
Format: SNSA

Effect:  $(A_{(DA)}) \rightarrow IODRDY_{(DA)}$

Description: CONDITION "A" of the I/O DEVICE specified by the DEVICE ADDRESS REGISTER (DA) will be "sensed" and the I/O DATA READY FLAG (IODRDY[DA]) will be set to reflect the state of "A" (either "1" or "0"). These conditions are device dependent and may not necessarily be implemented for all I/O devices. Refer to the appropriate device manual for further information. Note that some devices (e.g., PIOP) use the SNSA instruction to perform control functions.



Assembler  
Format: SPINA

Effect:  $(A_{(DA)}) \rightarrow IODRDY_{(DA)}; \text{ if } IODRDY_{(DA)} = 0 \text{ SPIN UNTIL } IODRDY_{(DA)} = 1$

Description: First, CONDITION "A" of I/O DEVICE(DA) is sensed and the I/O DATA READY FLAG (IODRDY) is set accordingly (to either "1" or "0").

If IODRDY(DA) equals "0," a SPIN condition will occur and will continue until condition "A" is equal to "1."

NOTE: If "A" never equals "1," an infinite SPIN will occur.

I/O SENSE FIELD (SENSE)



VALUE

- 2      SNSADA
- SENSE "A" SET to I/O READY FLAG; then set DEVICE ADDRESS from SPFN.

Assembler

Format:            SNSADA

Example:    MOV 5,5;SNSADA

Effect:             $(A_{(DA)}) \rightarrow IODRDY_{(DA)}$ ; then  $(SPFN) \rightarrow DA$

Description: First, CONDITION (A) for the I/O DEVICE specified by the I/O DEVICE ADDRESS REGISTER (DA) is sensed and its content (either "1" or "0") is set into the I/O DEVICE DATA READY FLAG ( $IODRDY_{(DA)}$ ).

Then, the right-most bits (bits 08-15) of the current S-PAD operation result (SPFN) are loaded into the I/O DEVICE ADDRESS REGISTER (DA); effective as of the next instruction cycle.

I/O SENSE FIELD (SENSE)



VALUE

- 3           SPIN UNTIL "A" NON-ZERO; then SET DEVICE ADDRESS from SPFN

Assembler  
Format:

SPNADA

Effect:       $(A_{(DA)}) \rightarrow IODRDY_{(DA)}$ ; if  $IODRDY_{(DA)} = \emptyset$   
                   SPIN until  $IODRDY_{(DA)} = 1$ ; then  $(SPFN) \rightarrow DA$

Description: First, CONDITION "A" of I/O DEVICE<sub>(DA)</sub> is sensed and set into the I/O DATA READY FLAG (IODRDY<sub>(DA)</sub>). If IODRDY then equals " $\emptyset$ ", a SPIN condition will occur until IODRDY<sub>(DA)</sub> = 1. At that time, the 8 right-most bits (bits 08-15) of the current S-PAD operation result (SPFN) are loaded into the I/O DEVICE ADDRESS REGISTER (DA); effective next instruction cycle.

NOTE: An infinite "SPIN" will occur if "A" never equals "1".

I/O SENSE FIELD (SENSE)



VALUE

4  SENSE I/O DEVICE CONDITION "B", SET IODRDY<sub>(DA)</sub> from "B"

Assembler  
Format: SNSB

Effect:  $(B_{(DA)}) \rightarrow IODRDY_{(DA)}$

Description: CONDITION "B" (B) of the I/O DEVICE specified by the DEVICE ADDRESS REGISTER (DA) will be "sensed" and the I/O DATA READY FLAG (IODRDY) for that I/O DEVICE will be set to reflect the contents of "B" (either "1" or " $\emptyset$ ").

5  SPIN UNTIL "B" is NON-ZERO

Assembler  
Format: SPINB

Effect:  $(B_{(DA)}) \rightarrow IODRDY_{(DA)}$ ; if  $IODRDY_{(DA)} = \emptyset$  SPIN until  $IODRDY_{(DA)} = 1$ .

Description: First, CONDITION "B" of I/O DEVICE<sub>(DA)</sub> is sensed and the I/O DATA READY FLAG (IODRDY) is set accordingly, (to either "1" or " $\emptyset$ ").

If  $IODRDY_{(DA)}$  then equals " $\emptyset$ ", a SPIN condition will occur until "B" equals "1", at which time the  $IODRDY_{(DA)}$  is set accordingly.

NOTE: If "B" never equals "1", an infinite SPIN condition will occur.

I/O SENSE FIELD (SENSE)



VALUE

- 6      SNSBDA      SENSE "B" set to I/O DATA READY FLAG, then SET DEVICE ADDRESS from SPFN.

Assembler  
Format:

Effect:       $(B_{(DA)}) \rightarrow IODRDY_{(DA)}$ ; then  $(SPFN) \rightarrow DA$

Description: First, condition "B" of the I/O DEVICE specified by the I/O DEVICE ADDRESS REGISTER  $(DA)$  is sensed and its content (either "1" or " $\emptyset$ ") set into the I/O DEVICE DATA READY FLAG  $(IODRDY_{(DA)})$ .

Then, the right-most bits (bits  $\emptyset 8-15$ ) of the current S-PAD operation result (SPFN) are loaded into the I/O DEVICE ADDRESS REGISTER  $(DA)$ ; effective next instruction cycle.

I/O SENSE FIELD (SENSE)



VALUE

|   |        |                                                          |
|---|--------|----------------------------------------------------------|
| 7 | SPNBDA | SPIN UNTIL "B" is NON-ZERO; SET DEVICE ADDRESS from SPFN |
|---|--------|----------------------------------------------------------|

Assembler

Format: SPNBDA

Effect:  $(B_{(DA)}) \rightarrow IODRDY_{(DA)}$ ; if  $IODRDY_{(DA)} = \emptyset$ , SPIN until  
 $IODRDY=1$ ; then  $(SPFN) \rightarrow DA$

Description: First, CONDITION "B" of I/O DEVICE  $_{(DA)}$  is sensed and set into the I/O DATA READY FLAG  $(IODRDY_{(DA)})$ . If  $IODRDY_{(DA)}$  then equals " $\emptyset$ ", a SPIN condition will occur until "B" equals "1", at which time the  $IODRDY_{(DA)}$  is set accordingly.

Then the 8 right-most bits (bits 08-15) of the current S-PAD operation result (SPFN) are loaded into the I/O DEVICE ADDRESS REGISTER (DA); effective next instruction cycle.

NOTE: If "B" never equals "1", an infinite SPIN condition will occur.

## SET/CLEAR FLAG FIELD (FLAG)



VALUE

The following instructions set one of four GENERAL FLAGS (0,1,2,3) to a "1". These flags may be tested and branched upon accordingly by software instructions (see STEST SPEC).

|   |      |                           |
|---|------|---------------------------|
| Ø | SFLØ | Set GENERAL FLAG Ø to "1" |
| 1 | SFL1 | Set GENERAL FLAG 1 to "1" |
| 2 | SFL2 | Set GENERAL FLAG 2 to "1" |
| 3 | SFL3 | Set GENERAL FLAG 3 to "1" |

Assembler  
Format:           SFLn  
  
Effect:           l → FLAG<sub>n</sub>

NOTE: Effective two instruction cycles later. At least one cycle must intervene between an SFLn and a Related Branch instruction.

### SET/CLEAR FLAG FIELD (FLAG)



VALUE

The following instructions clear to "0" one of the four GENERAL FLAGS (0,1,2,3) available for use in the AP. These flags may be tested and branched upon by software instructions (see STEST SPEC).

|   |      |                             |
|---|------|-----------------------------|
| 4 | CLFØ | Clear GENERAL FLAG Ø to "Ø" |
| 5 | CLF1 | Clear GENERAL FLAG 1 to "Ø" |
| 6 | CLF2 | Clear GENERAL FLAG 2 to "Ø" |
| 7 | CLF3 | Clear GENERAL FLAG 3 to "Ø" |

Assembler  
Format:

CLFn

Effect:

$\emptyset \rightarrow \text{FLAG}_n$

NOTE: Effective two instruction cycles later.

**DATA PAD X (DPX)**



## VALUE

$\emptyset$  No Operation

1 DPX(idx)<sup>†</sup> < DB STORE DATA PAD BUS into DATA PAD X

## Assembler

Format: DPX(idx) → DB

Example: DPX (-3) < DB; DB=MD

Effect:  $(DPBS) \rightarrow DPX_{(DPA)} + \text{idx}$

Description: The data currently enabled onto the DATA PAD BUS (DB) is written into DATA PAD X (DPX) at the location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPA), plus the contents of the XWRITE FIELD (XW) minus 4 (the BIAS value).

Normally, a DPBS enable instruction is used concurrently with this instruction. If so, the two instructions can be expressed in shorthand notation (e.g., the example above can be expressed as follows: DPX[-3]<MD).

Note: All bits are written unless WRTEXP, WRTHMN , or WRTLMM is set.

$\dagger$  idx: An integer in a range from -4 to +3.  
 $xw = \text{idx} + 4$

DATA PAD X (DPX)



VALUE

2      DPX(idx) < FA      STORE FLOATING ADDER OUTPUT into DATA PAD X

Assembler

Format:      DPX(idx) < FA

Effect:

(FA)  $\rightarrow$  DPX(DPA) + idx - 4

Description: The current FLOATING ADDER result (FA) is written into DATA PAD X (DPX) at the location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPA), plus idx.

DATA PAD X (DPX)



VALUE

3      **DPX(idx) < FM**      STORE FLOATING MULTIPLIER OUTPUT into DATA PAD X

Assembler

Format:      DPX(idx)< FM

Effect:      (FM) → DPX<sub>(DPA) + idx</sub>

Description: The current FLOATING MULTIPLIER OUTPUT (FM) is written into DATA PAD X (DPX) at the location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPA), plus idx.

DATA PAD Y (DPY)



VALUE

1      **DPY(idx)<sup>†</sup> < DB**      STORE DATA PAD BUS into DATA PAD Y

Assembler

Format:

DPX(idx) < DB

Example: DPY(+3) < DB; DB=MD

Effect: (DB) → DPY (DPA) + idx

Description: The data currently enabled onto the DATA PAD BUS (DB) is written into DATA PAD Y (DPY) at the location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPA), plus the contents of the Y WRITE FIELD (YW)<sup>††</sup> minus 4 (the BIAS value).

Normally, a DPBS enable instruction is used concurrently with this instruction. If so, the two instructions can be expressed in shorthand notation (e.g., the example above can be expressed as follows: DPY[+3]<MD).

Note: All bits written unless WRTEXP, WRTHMN, or WRTLMN is set.

<sup>†</sup>idx: An integer in a range from -4 to +3.  
<sup>††</sup>YW = idx+4.

<sup>††</sup>If VALUE field is used during this instruction, the XW field is referenced instead. And if a DPX (idx) write instruction is used concurrently, the indices specified by the programmer must be equal. Errors in this regard are flagged by the assembler.

DATA PAD Y (DPY)



VALUE

2      **DPY(idx) < FA**      STORE FLOATING ADDER OUTPUT into DATA PAD Y

Assembler  
Format:

DPY(idx)< FA

Effect:       $(FA) + DPY$   
                  (DPA) + idx

Description: The current FLOATING ADDER OUTPUT (FA) is written into DATA PAD Y at the location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPA), plus idx.

DATA PAD Y (DPY)



VALUE

3      DPY(idx) < FM      STORE FLOATING MULTIPLIER OUTPUT into DATA PAD Y

Assembler  
Format:

DPY(idx) < FM

Effect:       $(FM) \rightarrow DPY(DPA) + idx$

Description: The current contents of the FLOATING MULTIPLIER OUTPUT (FM) are written into DATA PAD Y (DPY) at the location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPA), plus idx.

DATA PAD BUS (DPBS)



VALUE

**0 DB = ZERO** ENABLE FLOATING POINT ZERO onto the DATA PAD BUS

Assembler

Format: DB = ZERO (see Data Pad summary)

Effect: 0.0 → DPBS

Description: FLOATING POINT ZERO (0.0) is enabled onto the DATA PAD BUS (DPBS) during the current instruction cycle.

Note that this is the default condition for the DPBS field. Thus, if DPBS is not specified via a "DB = " mnemonic, and no other DATA PAD BUS enable field (e.g. RPSF, see SPEC) is utilized, then there will be a zero on the DATA PAD BUS.

### DATA PAD BUS (DPBS)



### **VALUE**

1 DB = INBS ENABLE INBUS onto the DATA PAD BUS

## Assembler Format:

ENABLE INBUS onto the DATA PAD BUS

DB = INBS (see Data Pad summary)

**Example:** IN: DPX(-3) DB; DB=INBS

### **Effect:**

(INBS) → DPBS

Description: The contents of the 38-bit INPUT/OUTPUT BUS (INBS) are enabled onto the DATA PAD BUS (DPBS) for the current instruction cycle.

This instruction is used to transfer data from INBS to DPBS during a current input operation (See example, above).

It must be accompanied by an I/O group INPUT instruction (IN, SPININ, INDA or SPINDA).

DATA PAD BUS (DPBS)



VALUE

2       $DB = VALUE^{\dagger}$       ENABLE VALUE onto the DATA PAD BUS

Assembler

Format:

$DB = val$  (where  $val$  is 16 bit value contained in Value field).

Example:  $DB = 25$   
 $DB = -1$

Effect:

(VALUE bits 54-63)  $\rightarrow$  DPBS EXPONENT  
 (VALUE bits 49-63)  $\rightarrow$  DPBS MANTISSA bits 13-27  
 (VALUE bit 48 (sign)  $\rightarrow$  DPBS MANTISSA bits 00-12

Description: The 16-bit value contained in the VALUE field of the instruction word is enabled onto the DATA PAD BUS (DPBS) during the current instruction cycle, in the following manner:

- 1) The right-most 15 bits of the VALUE field are enabled onto DPBS (MANTISSA) bits 13-27. The left-most remaining bit (the sign bit) is extended and enabled onto DPBS (MANTISSA) bits 00-12.
- 2) The right-most 10 bits of the VALUE field are enabled onto the DPBS (EXPONENT) bits 02-11.

<sup>†</sup> YW field is disabled for the current instruction cycle.

DATA PAD BUS (DPBS)



VALUE

3      DB = DPX(idx)<sup>†</sup>      ENABLE DATA PAD X onto the DATA PAD BUS

Assembler  
Format:

DB = DPX(idx)

Effect:       $(DPX \quad ) \rightarrow DPBS$   
 $(DPA) + idx$

Description: The contents of the DATA PAD X (DPX) location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPS), plus the contents of the X READ FIELD (XR) minus 4, are enabled onto the DATA PAD BUS (DPBS) for the current instruction cycle.

<sup>†</sup> idx: An integer in a range from -4 to +3.  
 $XR = idx + 4$

DATA PAD BUS (DPBS)



VALUE

4

$DB = DPY(idx)$

ENABLE DATA PAD Y onto the DATA PAD BUS

Assembler  
Format:

$DB = DPY(idx)$

Effect:

$(DPY(DPA) + idx) \rightarrow DPBS$

Description: The contents of the DATA PAD Y (DPY) location specified by the current contents of the DATA PAD ADDRESS REGISTER (DPA), plus the contents of the Y READ FIELD (YR) minus 4, are enabled onto the DATA PAD BUS (DPBS) for the current instruction cycle.

<sup>+</sup> idx: An integer in a range from -4 to +3.  
 $YR = idx + 4$

DATA PAD BUS (DPBS)



VALUE

5      DB = MD      ENABLE MAIN DATA MEMORY onto the DATA PAD BUS

Assembler  
Format:

DB=MD

Effect:      (MDREG) → DPBS

Description: The contents of the MAIN DATA MEMORY (MD) location entered into the MEMORY OUTPUT REGISTER (MDREG) during this instruction cycle are enabled onto the DATA PAD BUS for the current instruction cycle. (See MEMORY GROUP SUMMARY for the set-up requirements for a MAIN DATA MEMORY (MD) READ operation.)

DATA PAD BUS (DPBS)



VALUE

6

DB = SPFN

ENABLE SPAD FUNCTION onto the DATA PAD BUS

Assembler

Format:

DB = SPFN

Effect:

(SPFN<sub>bits 7-15</sub>) → DPBS<sup>EXPONENT</sup> bits Ø3-11

(SPFN<sub>bit 6</sub>) INVERTED<sup>†</sup> → DPBS<sup>EXPONENT</sup> bit Ø2

(SPFN<sub>bits Ø1-15</sub>) → DPBS<sup>MANTISSA</sup> bits 13-27

(SPFN<sub>bit Ø (sign)</sub>) → DPBS<sup>MANTISSA</sup> bits 00-12

Description: The 10 right-most bits of the S-PAD FUNCTION (SPFN bits [6-15]) plus BIAS, are enabled onto the DATA PAD BUS (EXPONENT) (DPBS [EXP] bits 02-11). The 15 right-most bits of SPFN (bits 01-15) are concurrently enabled onto the DPBS (MANTISSA bits) 13-27 and the left-most remaining bit (SPFN [bit 0]) is extended and enabled onto the left-most remaining bits of the DPBS (MANTISSA) (bits 00-12). SPFN is enabled onto DPBS during the current instruction only.

<sup>†</sup> BIAS: For this operation, a BIAS of 512(10) is added by inverting SPFN(bit)06.

DATA PAD BUS (DPBS)



VALUE

7      DB = TM      ENABLE TABLE MEMORY onto the DATA PAD BUS

Assembler  
Format:            DB=TM

Effect:            (TMREG) → DPBS

Description: The contents of the TABLE MEMORY (TM) location currently entered into the TABLE MEMORY REGISTER (TM REG) is enabled onto the DATA PAD BUS (DPBS) for the current instruction cycle. (See MEMORY GROUP SUMMARY-TM for the set-up requirements for a TABLE MEMORY [TM] READ operation).

MEMORY INPUT GROUP (MI)



VALUE

Ø No Operation

1 WRITE FLOATING ADDER RESULT to MAIN DATA MEMORY; VIA MEMORY INPUT REGISTER

Assembler Format:

Example: MOV 5,5; SETMA; MI< FA

Effect: (FA) → MI → MD (MA)

Description: The FLOATING ADDER RESULT (FA) currently available is loaded into the MEMORY INPUT REGISTER (MI) and written into the MAIN DATA MEMORY (MD) location specified by the current contents of the MEMORY ADDRESS REGISTER (MA). (See: MEMORY GROUP SUMMARY - MD for the necessary timing implications).

NOTE: The contents of the MEMORY ADDRESS REGISTER (MA), which specifies the MD location to be written, are determined by the mandatory and simultaneous SETMA, INCMA, DECMA or LDMA instruction being processed.

MEMORY INPUT GROUP (MI)



VALUE

- 2      **MI < FM**      WRITE FLOATING MULTIPLY RESULT to MAIN DATA MEMORY; VIA MEMORY INPUT REGISTER

Assembler

Format:      MI < FM

Example:    INCMA; MI < FM

Effect:      (FM) → MI + MD (MA)

Description: The FLOATING MULTIPLIER RESULT (FM) currently available is loaded into the MEMORY INPUT REGISTER (MI) and written into MAIN DATA MEMORY (MD) at the location specified by the current contents of the MEMORY ADDRESS REGISTER (MA).

MEMORY INPUT GROUP (MI)



VALUE

3      **MI < DB**

WRITE DATA PAD BUS to MAIN DATA MEMORY;  
VIA MEMORY INPUT REGISTER

Assembler

Format:            MI < DB

Example: DECMA; MI < DB; DB=ZERO

or: DECMA; MI < ZERO

Effect:            (DPBS) → MI → MD<sub>(MA)</sub>

Description: The current data enabled onto the DATA PAD BUS(DB) is loaded into the MEMORY INPUT REGISTER(MI) and written into MAIN DATA MEMORY (MD) at the location specified by the current contents of the MEMORY ADDRESS REGISTER (MA).

This instruction should be used in conjunction with a DPBS ENABLE instruction unless a zero is desired.

MEMORY ADDRESS GROUP (MA)



VALUE

$\emptyset$  No Operation

1 INCMA INCREMENT MEMORY ADDRESS REGISTER;  
INITIATE MAIN DATA MEMORY

Assembler  
Format:

INCMA

Example: INCMA; MI<FA

Effect:  $(MA) + 1 \rightarrow MA$ ; initiate MD cycle

Description: The contents of the MEMORY ADDRESS REGISTER (MA) are incremented by "1" and a MAIN DATA MEMORY (MD) cycle is initiated.

If used concurrently with an MI group instruction, an MD WRITE is initiated using the incremented value of MA as the MD location specifier.

If used without a concurrent MI group instruction, then an MD READ is initiated using the incremented value of MA as the MD location specifier.

(See MEMORY GROUP SUMMARY - MD, for the necessary memory timing implications involved in the use of this field.)

MANDATORY FIELDS

OPTIONAL FIELDS

DISABLED FIELDS †

MEMORY ADDRESS GROUP (MA)



VALUE

- 2      **DECMA**      DECREMENT MEMORY ADDRESS REGISTER;  
                          INITIATE MAIN DATA MEMORY

Assembler  
Format:

DECMA

Example: DECMA;MI < FM

Effect:      (MA)-1 → MA; initiate MD cycle

Description: The contents of MEMORY ADDRESS REGISTER (MA) are decremented by "1" and a MAIN DATA MEMORY (MD) cycle is initiated.

If used with an MI group instruction, an MD WRITE is initiated using the decremented contents of MA as the MD location specifier.

If used without a concurrent MI group instruction, then an MD READ is initiated using the decremented contents of MA as the MD location specifier.

MEMORY ADDRESS GROUP (MA)



VALUE

3

**SEIMA**

SET MEMORY ADDRESS REGISTER FROM THE S-PAD

FUNCTION: INITIATE MAIN DATA MEMORY

Assembler

Format:

SETMA

Example: MOVE 0,0; SETMA; MI<TM

Effect:

$(SPFN) \rightarrow MA$ ; or, if LDREG field is being used, then  
 $(DPBS) \rightarrow MA$ , instead.

Description: The contents of the MEMORY ADDRESS REGISTER (MA) are replaced by the S-PAD OUTPUT (SPFN) of the current S-PAD operation.

However, if an LDREG field instruction (see I/O) is used during the same instruction, then the contents currently enabled onto the DATA PAD BUS (DPBS), and not SPFN, are loaded into the MEMORY ADDRESS REGISTER (MA).

If used with an MI group instruction, an MD WRITE will be initiated. If used without an MI group instruction, then an MD READ will be initiated. In either case, the newly-formed value of MA will be used as the MD location specifier.

DATA PAD ADDRESS GROUP (DPA)



VALUE

Ø No Operation

1 INCDPA INCREMENT DATA PAD ADDRESS

Assembler:

Format: INCDPA

Effect: (DPA)+1+ DPA

Description: The contents of the DATA PAD ADDRESS REGISTER (DPA) are decremented by "1."

DPA will not be affected during the current instruction cycle but will be available as of the next instruction cycle.

(See DATA PAD GROUP SUMMARY - DPA.)

DATA PAD ADDRESS GROUP (DPA)



VALUE

2      DECDPA      DECREMENT DATA PAD ADDRESS REGISTER

Assembler  
Format:      DECDPA

Effect:      (DPA) -1 → DPA

Description: The contents of the DATA PAD ADDRESS REGISTER (DPA) are incremented by "1."

DPA will not be affected during the current instruction cycle but will be available as of the next instruction cycle.

(See DATA PAD GROUP SUMMARY - DPA.)

TABLE MEMORY ADDRESS GROUP (TMA)



VALUE

2      DECIMA      DECREMENT TABLE MEMORY ADDRESS REGISTER

Assembler  
Format:      DECTMA (See, MEMORY GROUP SUMMARY - TMA)

Effect:      (TMA) -1 → TMA

Description: The contents of the TABLE MEMORY ADDRESS REGISTER (TMA) are decremented by one.

The contents of TM (TMA) are available in TMREG two cycles after execution of this instruction.

TABLE MEMORY ADDRESS GROUP (TMA)



VALUE

3

SETTMA

SET TABLE MEMORY ADDRESS REGISTER from  
S-PAD FUNCTION

Assembler

Format: SETTMA

Effect: (SPFN) → TMA; or, if LDREG field is being used, then  
(DPBS) → TMA, instead.

Description: The contents of the result of the current S-PAD operation (SPFN) are loaded into the TABLE MEMORY ADDRESS REGISTER (TMA). However, if an LDREG field instruction is used concurrently (see I/O), then the data enabled onto the DATA PAD BUS (DPBS), and not SPFN, is loaded into TMA.

The contents of TMA are available as TM two cycles after execution of this instruction.

## INDEX

|              |                                         |              |                                    |
|--------------|-----------------------------------------|--------------|------------------------------------|
| &.....       | E-13                                    | EDPX.....    | E-96                               |
| A1.....      | E-93                                    | EQV.....     | E-22                               |
| A2.....      | E-95                                    | F2CSM.....   | E-90                               |
| ADD.....     | E-17                                    | FA.....      | E-95, E-100, E-124<br>E-127, E-137 |
| AND.....     | E-20                                    | FABS.....    | E-92                               |
| B.....       | E-13                                    | FADD.....    | E-81                               |
| BDBN.....    | E-35                                    | FADD1.....   | E-81                               |
| BDBZ.....    | E-36                                    | FAND.....    | E-84                               |
| BEQ.....     | E-77                                    | FEQV.....    | E-83                               |
| BFEQ.....    | E-73                                    | FIX.....     | E-86                               |
| BFGE.....    | E-75                                    | FIXT.....    | E-87                               |
| BFGT.....    | E-76                                    | FLAG.....    | E-121                              |
| BFL0.....    | E-38                                    | FM.....      | E-93, E-99, E-125<br>E-128, E-138  |
| BFL1.....    | E-38                                    | FMUL.....    | E-98                               |
| BFL2.....    | E-38                                    | FOR.....     | E-85                               |
| BFL3.....    | E-38                                    | FSCALE.....  | E-91                               |
| BFLT.....    | E-31                                    | FSCLT.....   | E-88                               |
| BFNE.....    | E-74                                    | FSM2C.....   | E-89                               |
| BFPE.....    | E-71                                    | FSUB.....    | E-81                               |
| BGE.....     | E-79                                    | FSUBR.....   | E-81                               |
| BGT.....     | E-80                                    | HALT.....    | E-8                                |
| BIFN.....    | E-37                                    | HOSTPNL..... | E-39                               |
| BIFZ.....    | E-37                                    | IN.....      | E-112                              |
| BINTRQ.....  | E-70                                    | INBS.....    | E-130                              |
| BION.....    | E-70                                    | INC.....     | E-25                               |
| BIOZ.....    | E-71                                    | INCDPA.....  | E-143                              |
| BLT.....     | E-32                                    | INCMA.....   | E-140                              |
| BNC.....     | E-33                                    | INCTMA.....  | E-146                              |
| BNE.....     | E-78                                    | INDA.....    | E-113                              |
| BR.....      | E-69                                    | INOUT.....   | E-109                              |
| BZC.....     | E-34                                    | INTA.....    | E-10                               |
| CFL0.....    | E-122                                   | INTEN.....   | E-9                                |
| CFL1.....    | E-122                                   | IO.....      | E-7, E-101                         |
| CFL2.....    | E-122                                   | IORST.....   | E-9                                |
| CFL3.....    | E-122                                   | JMP.....     | E-47                               |
| CLR.....     | E-25                                    | JMPA.....    | E-45                               |
| COM.....     | E-26                                    | JMPP.....    | E-49                               |
| COND.....    | E-68                                    | JMPT.....    | E-48                               |
| CONTROL..... | E-8                                     | JSR.....     | E-47                               |
| DB.....      | E-123, E-129, E-139                     | JSRA.....    | E-46                               |
| DBELIT.....  | E-39                                    | JSRP.....    | E-50                               |
| DBHLIT.....  | E-40                                    | JSRT.....    | E-48                               |
| DBLLIT.....  | E-40                                    | L.....       | E-14                               |
| DEC.....     | E-26                                    | LDAPS.....   | E-103                              |
| DECDDPA..... | E-144                                   | LDDA.....    | E-104                              |
| DECMA.....   | E-141                                   | LDDPA.....   | E-102                              |
| DECTMA.....  | E-147                                   | LDMA.....    | E-101                              |
| DISP.....    | E-31, E-69                              | LDREG.....   | E-101                              |
| DPA.....     | E-143                                   | LDSP.....    | E-103                              |
| DPBS.....    | E-129                                   | LDSPD.....   | E-101                              |
| DPX.....     | E-93, E-95, E-99<br>E-100, E-123, E-132 | LDSPE.....   | E-28                               |
| DPY.....     | E-93, E-95, E-99<br>E-100, E-126, E-133 | LDSPI.....   | E-29                               |

|             |                    |              |                   |
|-------------|--------------------|--------------|-------------------|
| LDSPNL..... | E-27               | SETEXA.....  | E-66              |
| LDSPT.....  | E-30               | SETEXIT..... | E-66              |
| LDTMA.....  | E-102              | SETEXP.....  | E-67              |
| LPSL.....   | E-64               | SETTEXT..... | E-67              |
| LPSLA.....  | E-62               | SETMA.....   | E-142             |
| LPSLP.....  | E-65               | SETSPA.....  | E-45              |
| LPSLT.....  | E-64               | SETTMA.....  | E-148             |
| LPSR.....   | E-64               | SFL0.....    | E-121             |
| LPSRA.....  | E-63               | SFL1.....    | E-121             |
| LPSRP.....  | E-65               | SFL2.....    | E-121             |
| LPSRT.....  | E-65               | SFL3.....    | E-121             |
| M1.....     | E-99               | SH.....      | E-14              |
| M2.....     | E-100              | SNSA.....    | E-115             |
| MA.....     | E-140              | SNSADA.....  | E-116             |
| MD.....     | E-96, E-100, E-134 | SNSB.....    | E-118             |
| MDPX.....   | E-96               | SNSBDA.....  | E-119             |
| MI.....     | E-137              | SOP.....     | E-6               |
| MOV.....    | E-19               | SOP1.....    | E-23              |
| NC.....     | E-95               | SPD.....     | E-17              |
| NOP.....    | E-5                | SPEC.....    | E-6               |
| OR.....     | E-21               | SPFN.....    | E-135             |
| OUT.....    | E-109              | SPINA.....   | E-115             |
| OUTDA.....  | E-110              | SPINB.....   | E-118             |
| PNLLIT..... | E-39               | SPINDA.....  | E-114             |
| PS.....     | E-58               | SPININ.....  | E-112             |
| PSEVEN..... | E-52               | SPMDA.....   | E-6               |
| PSODD.....  | E-55               | SPMDAV.....  | E-7               |
| R.....      | E-15               | SPNADA.....  | E-117             |
| RAPS.....   | E-108              | SPNBDA.....  | E-120             |
| RDA.....    | E-108              | SPNOUT.....  | E-109             |
| RDPA.....   | E-107              | SPOTDA.....  | E-11              |
| RDREG.....  | E-105              | SPS.....     | E-17              |
| REFR.....   | E-10               | STEST.....   | E-31              |
| RETURN..... | E-72               | SUB.....     | E-18              |
| REXIT.....  | E-7                | SWDB.....    | E-41              |
| RMA.....    | E-106              | SWDBE.....   | E-42              |
| RPSO.....   | E-652              | SWDBH.....   | E-43              |
| RPSOA.....  | E-52               | SWDBL.....   | E-44              |
| RPSOT.....  | E-52               | TM.....      | E-94, E-99, E-136 |
| RPS1.....   | E-55               | TMA.....     | E-146             |
| RPS1A.....  | E-55               | VALUE.....   | E-121, E-131      |
| RPS1T.....  | E-56               | WPS0.....    | E-54              |
| RPS2.....   | E-52               | WPS0A.....   | E-53              |
| RPS2A.....  | E-52               | WPS0T.....   | E-54              |
| RPS2T.....  | E-53               | WPS1.....    | E-57              |
| RPS3.....   | E-55               | WPS1A.....   | E-56              |
| RPS3A.....  | E-55               | WPS1T.....   | E-57              |
| RPS3T.....  | E-56               | WPS2.....    | E-54              |
| RPSA.....   | E-105              | WPS2A.....   | E-53              |
| RPSF.....   | E-60               | WPS2T.....   | E-54              |
| RPSFA.....  | E-59               | WPS3.....    | E-57              |
| RPSFP.....  | E-61               | WPS3A.....   | E-56              |
| RPSFT.....  | E-61               | WPS3T.....   | E-57              |
| RPSL.....   | E-60               | WRTEX.....   | E-11              |
| RPSLA.....  | E-58               | WRTEXP.....  | E-23              |
| RPSLP.....  | E-61               | WRTHMN.....  | E-24              |
| RPSLT.....  | E-60               | WRTLBN.....  | E-24              |
| RR.....     | E-16               | WRTMAN.....  | E-11              |
| RSPD.....   | E-105              | XR.....      | E-132             |
| RSPFN.....  | E-107              | XW.....      | E-123             |
| RTMA.....   | E-106              | YR.....      | E-133             |
| SENSE.....  | E-115              | YW.....      | E-126             |
| SETDPA..... | E-145              | ZERO.....    | E-94, E-96, E-129 |
| SETEX.....  | E-66               | #.....       | E-68              |

## Notice to the Reader

- Help us improve the quality and usefulness of this manual.
- Your comments and answers to the following READERS COMMENT form would be appreciated.

=====

To mail: fold the form in three parts so that Floating Point Systems' mailing address is visible; seal.

Thank you

## READERS COMMENT FORM

Your comments will help us improve the quality and usefulness of our publications. To mail: fold the form in three parts so that Floating Point Systems mailing address is visible, then seal.

Title of document \_\_\_\_\_

Name/Title \_\_\_\_\_ Date \_\_\_\_\_

Firm \_\_\_\_\_ Department \_\_\_\_\_

Address \_\_\_\_\_

Telephone \_\_\_\_\_

I used this manual...

I found this material...

|                                                            | Yes                      | No                       |
|------------------------------------------------------------|--------------------------|--------------------------|
| <input type="checkbox"/> as an introduction to the subject |                          |                          |
| <input type="checkbox"/> as an aid for advanced training   | <input type="checkbox"/> | <input type="checkbox"/> |
| <input type="checkbox"/> to instruct a class               | <input type="checkbox"/> | <input type="checkbox"/> |
| <input type="checkbox"/> to learn operating procedures     | <input type="checkbox"/> | <input type="checkbox"/> |
| <input type="checkbox"/> as a reference manual             | <input type="checkbox"/> | <input type="checkbox"/> |
| <input type="checkbox"/> other _____                       | <input type="checkbox"/> | <input type="checkbox"/> |

Please indicate below, listing the pages, any errors you found in the manual. Also indicate if you would have liked more information on a certain subject.

First Class  
Permit No.A-737  
Portland,  
Oregon

**BUSINESS REPLY**

No postage stamp necessary if mailed in the United States

Postage will be paid by:

**FLOATING POINT SYSTEMS, INC.**

**P.O. Box 23489**

**Portland, Oregon 97223**

**Attn: Technical Publications**



FLOATING POINT  
SYSTEMS, INC.

CALL TOLL FREE 800-547-1445  
P.O. Box 23489, Portland, OR 97223  
(503) 641-3151, TLX: 360470 FLOATPOINT PTL