# BBB000 COMPUTER REFERENCE MANUAL

홍철왕왜 문양명(BR달왕왕임정말홍권) 승규는 영영광



# **BBOO COMPUTER REFERENCE MANUAL**



© WANG LABORATORIES, INC., 1970 Tewksbury, Mass. 01876 Telephone (617) 851-7311 TWX 710 343-6769



# TABLE OF CONTENTS

| ١.         | INTRODUCTION                                                          | 1  |
|------------|-----------------------------------------------------------------------|----|
| H.         | GENERAL SPECIFICATIONS                                                | 2  |
| 111.       | CPU REGISTER ORGANIZATION                                             | 3  |
|            | A. Addressable Registers                                              | 4  |
|            | B. Non-Addressable Registers                                          | 5  |
| IV.        | MEMORY ORGANIZATION AND ADDRESSING                                    | 7  |
|            | A. Current Page Addressing                                            | 7  |
|            | B. Absolute Page Addressing                                           | 8  |
|            | C. Indirect Addressing                                                | 8  |
|            | D. Auto-Index Indirect Address Reference                              | 8  |
|            | E. Immediate Reference                                                | 9  |
| <b>V</b> . | INSTRUCTION FORMATS                                                   | 10 |
|            | A. Format 1 – Memory Reference Instruction (Without Auto-Index)       | 10 |
|            | B. Format 2 – Memory Reference Instructions (With Auto-Index)         | 10 |
|            | C. Format 3 – Immediate Reference Instructions                        | 10 |
|            | D. Format 4 – Register Setting and Skip Instructions                  | 10 |
|            | E. Format 5 – Shift/Rotate Instructions (A-Register)                  | 11 |
|            | F. Format 6 – Mini Instructions (Current Page Jump)                   | 11 |
| VI.        | WANG 3300 INSTRUCTION REPERTOIRE                                      | 12 |
|            | A. Memory Reference Group (Without Auto-Index)                        | 12 |
|            | B. Memory Reference Group (With Auto-Index)                           | 13 |
|            | C. Immediate Reference Group                                          | 15 |
|            | D. Shift and Rotate Group                                             | 16 |
|            | E. Conditional Jump Group                                             | 17 |
|            | F. Conditional Skip Group (A-Register, Status Register, I/O Register) | 18 |
|            | G. Register Transfer and Manipulation Group (With Micro Jumps)        | 19 |
|            | H. Input/Output and Interrupt Group                                   | 20 |
| VII.       | Input/Output and Interrupt Organization                               | 22 |
|            | A. Modes of Input/Output Operation                                    | 22 |
|            | B. I/O Bus Structure Organization                                     | 22 |
|            | C. I/O Status Registers                                               | 23 |
|            | D. Interrupt Operations and Instructions                              | 25 |
|            | E. I/O Instructions                                                   | 26 |

# TABLE OF CONTENTS (Concl'd)

| VIII. | 331  | 5 TELETYPE TERMINAL OPERATION                       | 27 |
|-------|------|-----------------------------------------------------|----|
|       | Α.   | Operational Characteristics                         | 27 |
|       | В.   | I/O Status Register Settings                        | 27 |
|       | С.   | Read and Write Programming Procedures               | 29 |
|       | D.   | Program Examples                                    | 30 |
|       | Ε.   | Teletype Device Buffer Addresses                    | 33 |
| IX.   | CON  | TROL CONSOLE OPERATING PROCEDURES                   | 34 |
|       | Α.   | Turn-On Procedures                                  | 34 |
|       | В.   | Display Contents of Single Memory Location          | 34 |
|       | С.   | Read Consecutive Memory Locations                   | 34 |
|       | D.   | Modify the Contents of a Single Memory Location     | 34 |
|       | Ε.   | Modify the Contents of Consecutive Memory Locations | 34 |
|       | F.   | Enter or Modify Data in Registers                   | 34 |
|       | G.   | Single Step Program Execution                       | 35 |
|       | Н.   | Automatic Program Execution                         | 35 |
|       | I.   | Execute Command from Control Panel                  | 35 |
| APPEN | DIXE | S .                                                 |    |
|       | •    |                                                     |    |

| А. |                                    | 39 |
|----|------------------------------------|----|
| В. | Alphabetic List of Instructions    | 43 |
| С. | Table of Instructions by OP Code   | 47 |
| D. | Wang 3300 ASCII Character Code Set | 49 |

Ç

# LIST OF ILLUSTRATIONS

| Figure | 1 | Block Diagram of the Wang 3300 CPU Organization | 3  |
|--------|---|-------------------------------------------------|----|
|        | 2 | Wang 3300 Memory Page Format                    | 7  |
|        | 3 | Typical I/O Bus Station Organization            | 24 |
|        | 4 | Wang 3300 Console                               | 37 |
|        |   |                                                 |    |

# LIST OF TABLES

| Table | 1 | Teletype I/O Status Register Settings During Data Transfer | 28 |
|-------|---|------------------------------------------------------------|----|
|       | 2 | 3300 Computer Console Switches and Indicators              | 36 |

#### I. INTRODUCTION

The Wang 3300 is an integrated circuit general purpose mini computer. Unlike most computers in this class, it was specifically designed to be the central processor for multi-terminal time-sharing applications for higher level language systems. The Wang 3300 design incorporates such features as:

- A powerful repertoire of 68 instructions, including 21 memory reference instructions.
- A flexible and powerful I/O logic design which includes an I/O bus structure to handle up to 128 low and medium speed peripheral devices and Direct Memory Access Channel logic to control high speed devices at transfer rates up to 300,000 cps.
- A highly efficient priority interrupt structure which handles up to 128 priority interrupt levels and incorporates device address interrupt acknowledgement to reduce interrupt processing time.
   Memory expandability up to 65k bytes to accommodate large system applications.
- Nine modes of addressing, including a unique auto-increment/auto-decrement indirect addressing mode throughout all of memory. In this mode the indirect address is decremented before and incremented after single or double byte memory transfers. This produces a true push-pop access mode for handling table and list processing efficiently. In many applications, it provides the flexibility and speed equivalent to an unlimited number of index registers, and also eliminates the time consuming bookkeeping requirements associated with index registers.
- Six arithmetic instructions which operate in both binary and decimal mode. In decimal mode, 4 bit decimal groups are operated on in decimal arithmetic. This feature eliminates the inaccuracies and time inefficiencies associated with decimal to binary conversion and binary arithmetic, and provides a multi-precision capability.

The Wang 3300 is a byte-oriented computer, but it also has a number of double byte operand memory reference commands. This in essence provides the best features of both 8 bit and 16 bit computers. In many areas where the processing involves higher level languages, a single byte or character is commonly referenced. A 16 bit fetch is inefficient and often involves additional masking logic. However, in those instances in which 16 bit transfers are required, Wang 3300 double byte commands accommodate them.

The Wang 3300 is designed specifically to meet the high performance requirements of time-sharing systems. However, a modular design and a flexible and powerful I/O structure and instruction repertoire enable the 3300 to meet a great variety of scientific and commercial applications in the both real-time and batch processing modes.

#### **II. GENERAL SPECIFICATIONS**

- Computer transfer logic 8 bit parallel binary
- Memory Cycle time 1.6 μ sec.
- Word Length 8 bits
- Instruction Length 16 bits
- Addressing Memory is segmented in 256 byte pages.
  - The following addressing modes are available.
    - Direct Absolute page (Page 0 or 1)
    - Direct Current page
    - Indirect Absolute page (Page 0 or 1)
    - Indirect Current page
    - Indirect, Absolute Page, Auto-Increment (Page 0 or 1)
    - Indirect, Absolute Page, Auto-Decrement (Page 0 or 1)
    - Indirect, Current Page, Auto-Increment
    - Indirect, Current Page, Auto-Decrement
    - Immediate
- Memory Type Magnetic core
- Memory Size From 4,096 to 65,536 bytes in increments of 4,096 bytes
- Arithmetic Modes- Binary Mode and Addressing 2's complement
  - Decimal Mode 4 bit BCD Complement Instructions - 1's complement or 9's complement
- Speed
- Add: 8 bit binary 4.8  $\mu$ sec Add: 8 bit decimal - 4.8  $\mu$ sec
  - Add: 16 bit binary 6.4  $\mu$ sec
  - Add: 16 bit decimal 6.4  $\mu$  sec
- Multiply: floating point, (8 digit decimal mantissa) 4 ms
- Input Output
   I/O Bus structure which controls up to 128 devices
  - Multiplex Mode (character Buffers)
    - Direct Memory Access channel Mode
- Interrupt Device Station Groups
  - 128 Priority Levels
- Peripheral Equipment
  - Wang 3310 I/O Writer (Modified IBM Selectric)
    - Keyboard Input
    - Typed Output at 15 cps
  - Wang 3315 33-ASR Teletype, Model TBE
    - Keyboard Input
    - Typed Output at 10 cps
    - Paper Tape Reader 10 cps
    - Punch Tape Punch 10 cps
    - Off-line paper tape preparation, reproduction, listing
    - Remote phone line terminal capability
  - Wang 1103A Acoustic Coupler (with Automatic Answer-Back)
    - To interface the 3300 for remote phone line connection
  - Wang 1104A Acoustic Coupler
    - To interface the 3315 teletypes for remote phone line connection
  - Wang 3320 Magnetic Tape Cassette Drive Pair
    - Tape Read 800 cps
    - Tape Write 800 cps
    - Rewind Speed 1 minute
    - Tape Capacity 300,000 byte (max)

#### III. CPU REGISTER ORGANIZATION

Figure 1, a block diagram of the 3300 CPU organization, illustrates the data storage registers, memory and input/output control logic. The basic storage unit of memory is a byte (8 bits). All registers are 8 bits in length.

The A, Z, S, B, C, and I registers can be addressed or reset by computer instructions. The A and Z registers are general accumulator registers. The S register contains operational status and control bits. The B and C registers are the program instruction counter. The I register contains I/O status information.

The remaining control logic and registers are used in the execution of computer instructions, memory access and input/output. They are not addressable.

All arithmetic operations are performed in the Arithmetic Logic Unit. Arithmetic operations are performed in both binary and decimal mode. Binary arithmetic is performed in 2's complement where one byte assumes a value of from 0 to 255. In decimal mode, a byte containing two 4-bit decimal digits is operated on in decimal arithmetic. In decimal mode, a byte can assume values from 00 to 99.

Information is fetched from memory in a one-byte path via the M register and the L-Bus and M-Bus to various registers. Information is transferred to memory in a one byte path via the Z bus. The memory address is contained in the M and N registers from where it is fetched and decoded.

Information is transferred between input/output device control logic and either the A register or directly to and from memory via the I/O Bus, L-Bus, Z-Bus, and Arithmetic Logic Unit.

The following section contains a detailed description of the CPU registers.



#### FIG. 1. BLOCK DIAGRAM OF THE WANG 3300 CPU ORGANIZATION

#### A. Addressable Registers

The following registers can be addressed or modified by computer instructions:

(1) A-Register

The A-register is an 8 bit general purpose register used primarily as the arithmetic accumulator, and for logical operations, bit manipulation and testing.

#### (2) Z-Register



The Z register is an 8 bit general purpose register. It is independently addressable, but is not generally used in arithmetic, logical, and testing operations like the A-register. It is however treated as a high order extention of the A-register for double byte commands (Double load, Double unload, Double add to Memory, Double shifts, etc.).

| (3) <b>S-Register</b><br>(Status Register) | NOT<br>USED | Ρ | с | z | D | v | s <sub>1</sub> s <sub>0</sub> | ] |
|--------------------------------------------|-------------|---|---|---|---|---|-------------------------------|---|
|                                            | 7           | 6 | 5 | 4 | 3 | 2 | 1 0                           |   |

The Status Register is made up of 7 bits which act and are set independently of one another, but may be addressed as a group with certain status register instructions. Two status bits, P and D, control absolute addressing and arithmetic modes. Others, such as C, Z, and V, are set after the execution of certain instructions to indicate the final results of the instruction operation.

The status register bits are:

The setting of the P bit controls what memory page is referenced by memory reference commands which are set up in an absolute page addressing format. If P is set to 0, page zero is referenced (locations 0 to 255). If P is set to 1, Page 1 is referenced, (locations 256 to 511). P is set and reset by status register instructions only, (ONS, OFS, TSAJ, TASJ).

$$\begin{array}{c} C \\ \hline C \\ \hline S \\ \hline \end{array} \qquad - Carry Bit (S_{S}) \\ \hline C = 1 Carry \\ C = 0 No Carry \\ \hline \end{array}$$

The C status bit (carry bit), is set after the execution of a number of arithmetic and comparison commands. The value of the carry from the high order bit or digit of the last arithmetic operation sets C, (TO 0 or 1). The previous setting of C is added into the lower order bit or digit for arithmetic instructions with carry.

| Z | - Last Value Zero (S <sub>4</sub> ) | Z = 1 Result Zero     |
|---|-------------------------------------|-----------------------|
| 4 |                                     | Z = 0 Result Non-zero |

The Z status bit is set after the execution of most load, register transfer, arithmetic, compare and logical instructions. Z is set to 1 if the final result of the arithmetic, logical or load operation was a zero, (result of both bytes for double commands). If it is set to 0, the result was not zero.

| D | - Decimal Arithmetic Mode Indicator (S <sub>3</sub> ) D = 0 Binary Mode |
|---|-------------------------------------------------------------------------|
| 3 | D = 1 Decimal Mode                                                      |

The setting of the D status bit controls the arithmetic mode for arithmetic instructions. If D is set to 0 binary arithmetic is performed, if it is set to 1 decimal arithmetic is performed. Addressing arithmetic and compare instruction arithmetic will always be done in binary mode, regardless of D. D is set and reset by status register instructions only (ONS, OFS, TSAJ, TASJ).

V = 0 Result valid decimal no. V = 1 Result not valid decimal no.

The V status bit is set after the execution of many load, register transfers, arithmetic and compare instructions. The V status bit is set only when the computer is in decimal arithmetic mode (the D status bit = 1). V is set to 0 if the final result of the instruction was a valid decimal number (each 4 bit groups are 0 to 9), and it is set to 1 if it was not.

$$\begin{bmatrix} \mathbf{S}_1 \\ \mathbf{S}_0 \end{bmatrix} = \mathbf{S}_0 - \mathbf{U}$$
ser Status Bits ( $\mathbf{S}_1, \mathbf{S}_0$ )

The  $S_0$  and  $S_1$  bits of the status register are general purpose bits which can be set at the programmer's discretion for program control functions. They are set by status register instructions and typically tested with status register skip instructions.

#### (4) **Program Counter Registers (B, C)**

| Β |   |     |  |
|---|---|-----|--|
| 7 | 0 | 7 0 |  |

These two registers contain the 16-bit address of the next instruction to be executed. The B register (most significant 8 bits) contains the page address, and the C register (least significant 8 bits) contains the address within page (0 to 255). A full address of from 0 to  $65,535_{10}$  can be expressed. The program counter is set by jump and skip commands.

(5) I/O Register



The I/O control logic for each peripheral device contains the equivalent of this 8 bit register. The I/O Register bits indicate various conditions for that device, (ready, error, power off, etc.). The I/O register bits are always sensed with the address of the device stored in the Z-register. These bits are normally reset by I/O clear or enable operations.

#### B. Non-Addressable Registers

The following registers control and contain information for the execution of program instructions and memory access operations, but are not addressable by computer instructions.

(1) Instruction Register (D)



The 8 bit instruction register holds the instruction code byte of the instruction about to be executed.

(2) Operand Address Registers (M, N)



The M and N registers hold the full 16 bit address of the next byte to be fetched from or stored into memory. When instructions are fetched, M and N are set to the current value of the program counter. When a memory reference instruction is executed, M and N receive the final effective operand address.

(3) L-Register



This 8-bit register acts as an intermediate data transfer unit for memory reference, and register transfer operations.

#### (4) T-Register



This 8-bit temporary register is used as an intermediate data transfer unit for memory reference and register transfer operations.

# (5) M-Register

|   |   | M, | , |          |
|---|---|----|---|----------|
| 7 | - |    |   | <u> </u> |

ž

The M-Register functions as a memory data buffer, for Memory fetches. All data fetched from memory is temporarily stored in the M-register.

# (6) Arithmetic Logic Unit

This unit performs all arithmetic and logical operations and acts of a data transfer unit for register, memory reference and I/O operations.

#### (7) I/O Bus Control Unit

This unit controls the input/output transfer of data passing on the I/O Bus between the CPU and Device Control logic. It contains the G-register (General I/O) information.

#### (8) CHM, CHN

These registers contain the memory address for channel I/O operations.

#### (9) Input/Out Device Control Logic

The units control the operation for one or more I/O devices. The typical control unit also contains device data buffers and the I/O registers (I registers) for each controlled device.

# IV. MEMORY ORGANIZATION AND ADDRESSING

The basic unit of addressable memory is a byte, (8 bits). Memory is logically divided into 256 bytes groups called pages. Figure 2 illustrates the format of 3300 memory in pages. A full 16 bit address can reference byte addresses from 0 to  $65,535_{10}$ . The 16 bit address can also be considered to consist of a high order 8 bits which express the page address and a low order 8 bits which express the byte location within that page:

| <b></b> | 16 Bit Memory Address |                       |  |  |  |  |  |  |  |  |  |
|---------|-----------------------|-----------------------|--|--|--|--|--|--|--|--|--|
|         | Page Address          | Location with Page    |  |  |  |  |  |  |  |  |  |
| LZ      | 0 [7                  | 0                     |  |  |  |  |  |  |  |  |  |
|         | 256 Pages:            | 256 byte addresses    |  |  |  |  |  |  |  |  |  |
|         | Addresses from        | within each page:     |  |  |  |  |  |  |  |  |  |
|         | 0 to 255 Decimal      | From 0 to 255 Decimal |  |  |  |  |  |  |  |  |  |
|         | or                    | or                    |  |  |  |  |  |  |  |  |  |
|         | 00 to FF Hexidecimal  | 00 to FF Hexidecimal  |  |  |  |  |  |  |  |  |  |

#### A. Current Page Addressing

A Wang 3300 instruction is made up of two bytes, (16 bits). For memory reference instructions, the first byte contains the instruction operation code and information defining the mode of addressing. The second byte generally contains an operand address or jump address. Therefore, the second 8-bit byte of the instruction can normally refer to the 256 locations within the current page in which the instruction is located. This is called current page addressing.



#### FIG. 2. WANG 3300 MEMORY PAGE FORMAT

#### B. Absolute Page Addressing

Absolute page addressing is similar in format to current page addressing. However, the 8-bit address portion of the instruction indicates a location within page 0 or page 1 which is being referenced instead of the current page where the instruction is located. Page 0 is referenced if the P status register bit is currently set to 0, page 1 is referenced if P is set to 1. Therefore, an instruction located anywhere in memory can directly reference these two pages.

# 16 Bit instruction with Absolute Page Reference



# C. Indirect Addressing

In the indirect addressing mode, the 8 bit address portion of the instruction specifies the location (within the current page, or page 0 or page 1) where the full 16 bit address of the operand is located. Thus, any location in memory can be referenced indirectly. The indirect address must be located on an even address boundary (at an even address). It acts as a pointer to a second location where the final operand is located.

16 Bit Instruction with Indirect Address Reference



#### D. Auto-Index Indirect Address Reference

A group of Wang 3300 memory reference instructions have in addition to normal indirect addressing capability, a mode whereby the indirect address is incremented or decremented after or before it is referenced indirectly. This permits lists or tables to be processed efficiently without the bookkeeping generally necessary with indexing operations. The following two modes of auto-index indirect addressing are available:

#### (1) Auto Incrementing Indirect Mode

An operand is referenced via an indirect address. After the indirect address is referenced to obtain the operand, it is incremented. For single byte memory reference command the final value of the indirect address is one greater than the original value. For double byte memory reference commands, the final value is two greater. The indirect address must be located on an even boundry. In addition, for double byte memory reference commands the original value of the indirect address must also be even.

#### (2) Auto Decrementing Indirect Mode

An operand is referenced via an indirect address. Before the indirect address is referenced to obtain the operand, it is decremented. For single byte memory reference commands, the final value of the indirect address is one less than the original value. For double byte memory reference commands, the final value of the indirect address is two less than the original value. The indirect address must be located on an even boundry. In addition, for double byte memory reference commands, the original value of the indirect address must also be even.



#### (d) Auto Decrement, double byte operand\*: -2 Before reference

\*Original value of indirect address must be even.

#### E. Immediate Reference

The Wang 3300 has a group of immediate reference commands. In this mode the second byte of the instruction is treated as the operand and is loaded or used in arithmetic, logical, and comparison commands.





#### **V. INSTRUCTION FORMATS**

All Wang 3300 instructions occupy two bytes of memory. They can be classified into the following six formats:

#### A. Format 1 - Memory Reference Instructions (Without Auto-Index)

This format class includes all memory reference instructions which cannot be used with autoindexing. For this format the left six bits of the operation code byte contain the op code, the right two bits specify the addressing mode. The second byte of the instruction contains the 8 bit address of the operand or indirect address within the current or an absolute page, (page 0 or page 1). For absolute page reference, page 0 is selected if the P status register bit is 0, page 1 is selected if the P status register bit is set to 1.

| Γ | 0 | Op. Code XX |   |   |   | X | M (address) |   |   |   |   |   |   |   | FORMAT 1 |  |
|---|---|-------------|---|---|---|---|-------------|---|---|---|---|---|---|---|----------|--|
| 7 | 6 | 5           | 4 | 3 | 2 | 1 | 0           | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |  |

#### Memory Reference Mode

XX = 00 absolute page direct
XX = 01 absolute page indirect
XX = 10 current page direct
XX = 11 current page indirect

M = Address of the operand or indirect address operand within the current page or an absolute page

#### B. Format 2 - Memory Reference Instructions (With Auto-Index)

This format class includes all memory reference instructions that can be used in auto-index addressing mode. In this format, the left 5 bits of the OP Code byte contain the Op Code, the right 3 bits specify the addressing mode. The second byte of the instruction specifies the 8 bit address of either the operand or indirect address within the current or an absolute page.

|                       | Op. Code XXX           | M (address)               |  |  |  |  |  |  |
|-----------------------|------------------------|---------------------------|--|--|--|--|--|--|
| 7 6                   | 6 5 4 3 2 1 0          | 7 6 5 4 3 2 1 0           |  |  |  |  |  |  |
| Memory Reference Mode |                        |                           |  |  |  |  |  |  |
| XXX = 000             | absolute page, direct  | M = Address of Operand or |  |  |  |  |  |  |
| XXX = 001             | absolute page, indired | ct Indirect Address with  |  |  |  |  |  |  |
| XXX = 010             | current page, direct   | the Current or an         |  |  |  |  |  |  |
| XXX = 011             | current page, indirect | t Absolute Page           |  |  |  |  |  |  |
| XXX = 100             | absolute page, indire  | ect with                  |  |  |  |  |  |  |
|                       | auto-increment         |                           |  |  |  |  |  |  |
| XXX = 101             | absolute page, indire  | ct with auto-decrement    |  |  |  |  |  |  |
| XXX = 110             | current page, indirect | t with auto-increment     |  |  |  |  |  |  |
| XXX = 111             | current page, indirec  | t with auto-decrement     |  |  |  |  |  |  |

#### C. Format 3 - Immediate Reference Instructions

In this format class, the second byte of the instruction is used as the operand. It is either loaded into the Z or A registers or used directly in arithmetic, logical, or comparison operations. The entire 8 bits of the operation byte is used for the OP Code.



# D. Format 4 - Register Setting and Skip Instructions

In this class, the second byte of the instruction is generally used as a mask to specify which bits of a particular register will be tested by a skip instruction or set.

|   | Op. Code |   |   |   |   |   |   |   |
|---|----------|---|---|---|---|---|---|---|
| 7 | ,        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

M = Mask to specify what bits in a register are to be set or tested.

# E. Format 5 - Shift/Rotate Instructions (A-Register)

This format class includes A-register shift and rotate instructions. The rightmost two bits of the second instruction byte specify the shift count. The remaining bits in this byte are unused.

|   | Op. Code |   |   |   |   | Γ | Unused |   |     | NN  |    |       |     |      |     |   |      |
|---|----------|---|---|---|---|---|--------|---|-----|-----|----|-------|-----|------|-----|---|------|
| 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0      | 7 | 6   | 5   | 4  | 3     | 2   | 1    | 0   |   |      |
|   |          |   |   |   |   |   |        | N | N : | = ( | Sh | ift ( | Cou | int  |     |   |      |
|   |          |   |   |   |   |   |        |   | N   | N   | =  | 00    | Sł  | nift | t   | 1 | bit  |
|   |          |   |   |   |   |   |        |   | Ν   | N   | =  | 01    | Sł  | hift | t : | 2 | bits |
|   |          |   |   |   |   |   |        |   | N   | N   | =  | 02    | Sł  | hift | t : | 3 | bits |
|   |          |   |   |   |   |   |        |   | N   | N   | =  | 03    | Sł  | nift | t 4 | 4 | bits |

# F. Format 6 - Mini Instructions (Current Page Jump)

In this format class, the instruction generally performs register manipulations or input/output, and does not explicitly require the second instruction byte. It is used in all cases to perform a jump to any other location within the current page of the instruction.

|   | Op. Code |   |   |   |   |   | Γ | M (Jump Address) |   |   |   |   |   |   |   |
|---|----------|---|---|---|---|---|---|------------------|---|---|---|---|---|---|---|
| 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0 | 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

M specifies the current page address of the next instruction to be executed.

#### VI. WANG 3300 INSTRUCTION REPERTOIRE

The Wang 3300 has 68 instructions. Each instruction occupies two bytes of memory. The instruction can be classified into the following functional groups:

- Memory Reference Group (Without Auto-Index)
- Memory Reference Group (With Auto-Index)
- Immediate Reference Group
- Shift and Rotate Group
- Conditional Jump Group
- Conditional Skip Group
- Register Transfer And Manipulation Group
- Input/Output And Interrupt Group

The instructions are described in detail in this section by functional group. Along with the op code and instruction description, the instruction timing and status bits effected are listed. The timing is given in memory cycles. Each memory cycle takes 1.6  $\mu$  sec. In instances where the instruction can use indirect address reference, both the direct and indirect timing are given. All indirect address memory references require two additional memory cycles.

For example, if an instruction lists the following timing:

3, 5 memory cycles

It will take: 3 memory cycles or 3 (1.6) =  $4.8 \mu$  sec. to execute with direct memory reference and 5 memory cycles or 5 (1.6) =  $8.0 \mu$  sec. to execute with indirect memory reference

The status bits effected by the execution of the instruction are listed for each instruction. For example:

Status – C, Z, V

Means that the instruction when executed will set the C (carry), Z (Last Result Zero), and V (Last Result Valid Decimal) Status Register Bits. The status register bits which can be set by instruction execution (other than status register instructions) are:

|                       | C — Carry<br>Z — Last Result Zero<br>V — Last Result Valid                                                                               | Decimal <b>(Se</b> t only i                 | n Decimal Arithmetic Mode)               |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|------------------------------------------|
| A. Memory Reference G | roup (Without Auto-Index)                                                                                                                | Bits 0 and 1<br>of Instruction<br>Code Byte | Assembler<br>Symbolic<br>Representation  |
| Addressing Modes:     | <ul> <li>Absolute Page, Direct</li> <li>Absolute Page, Indirect</li> <li>Current Page, Direct</li> <li>Current Page, Indirect</li> </ul> | XX = 00<br>XX = 01<br>XX = 10<br>XX = 11    | BA TAGO<br>BA* TAGO<br>BA TAG<br>BA* TAG |
| Notes: • The indi     | rect address must be located on a                                                                                                        | n even address bound                        | lary.                                    |

 Memory reference instructions which reference a current page address and require more than two memory cycles for execution will not function properly when located in the last location of a page, (XXFE).

| BA | Boolean And | 010010XX                                     | м              | 3, 5 Memory Cycles                     | Status – Z, V         |
|----|-------------|----------------------------------------------|----------------|----------------------------------------|-----------------------|
|    |             | 7 0 7<br>The contents of<br>of the A-Registe |                | e memory address are and is left in A. | led with the contents |
| BO | Boolean Or  | 010110XX                                     | м              | 3, 5 Memory Cycles                     | Status – Z, V         |
|    |             | 7 0 7                                        | 0              |                                        |                       |
|    |             | The contents of                              | f the effectiv | e memory address are or                | ed with the contents  |

|          |                           |                                                                                                                                                                                                                                                                                                                  | 1                                                                                                                                                                                                      |                                                                                                                                        |                                                                                                                                                                                    |
|----------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BX       | Boolean                   | 010100XX                                                                                                                                                                                                                                                                                                         | м                                                                                                                                                                                                      | 3, 5 Memory Cycles                                                                                                                     | Status – Z, V                                                                                                                                                                      |
|          | exclusive or              | 7 0                                                                                                                                                                                                                                                                                                              | 7                                                                                                                                                                                                      | 0                                                                                                                                      |                                                                                                                                                                                    |
|          |                           | The contents the A-Registe                                                                                                                                                                                                                                                                                       | of the effe<br>er, the result                                                                                                                                                                          | ctive memory address a<br>is left in A.                                                                                                | re exclusive ored with                                                                                                                                                             |
| INC      | Increment                 | 010000XX                                                                                                                                                                                                                                                                                                         | М                                                                                                                                                                                                      | 3, 5 Memory Cycles                                                                                                                     | Status – Z, V                                                                                                                                                                      |
|          | Memory                    | 7 0                                                                                                                                                                                                                                                                                                              | 7                                                                                                                                                                                                      | 0                                                                                                                                      |                                                                                                                                                                                    |
|          |                           | The contents<br>addition is al                                                                                                                                                                                                                                                                                   | of the effe<br>ways binary.                                                                                                                                                                            | ctive memory address is                                                                                                                | incremented by one,                                                                                                                                                                |
| JEI      | Jump and                  | 010101XX                                                                                                                                                                                                                                                                                                         | M                                                                                                                                                                                                      | 2, 4 Memory Cycles                                                                                                                     | Status – None                                                                                                                                                                      |
|          | Enable                    | 7 0                                                                                                                                                                                                                                                                                                              | 7                                                                                                                                                                                                      | 0                                                                                                                                      |                                                                                                                                                                                    |
|          | Interrupt                 | made to the e                                                                                                                                                                                                                                                                                                    | effective men<br>urs or by a D                                                                                                                                                                         | t to zero, (Enable CP Int<br>nory address. (CP Interru<br>SIJ instruction). The CP                                                     | pt is disabled when an                                                                                                                                                             |
| JMP      | Jump                      | 010001XX                                                                                                                                                                                                                                                                                                         | М                                                                                                                                                                                                      | 2, 4 Memory Cycles                                                                                                                     | Status – None                                                                                                                                                                      |
|          |                           | 7 0                                                                                                                                                                                                                                                                                                              | 7                                                                                                                                                                                                      | 0                                                                                                                                      |                                                                                                                                                                                    |
|          |                           | Program Cont                                                                                                                                                                                                                                                                                                     | rol is transfer                                                                                                                                                                                        | red to the effective memo                                                                                                              | ory address.                                                                                                                                                                       |
| JST      | Jump and                  | 010011XX                                                                                                                                                                                                                                                                                                         | М                                                                                                                                                                                                      | 4, 6 Memory Cycles                                                                                                                     | Status – None                                                                                                                                                                      |
|          | Store Location            | 7 0                                                                                                                                                                                                                                                                                                              | 7                                                                                                                                                                                                      | 0                                                                                                                                      |                                                                                                                                                                                    |
| R Memor  |                           | effective mer                                                                                                                                                                                                                                                                                                    | nory addres                                                                                                                                                                                            | e next sequential instruc<br>s and effective memor<br>red to the effective mem                                                         | y address plus one.                                                                                                                                                                |
|          | N Reference Crow          | - /10/inh Auga Im.                                                                                                                                                                                                                                                                                               | <b>\</b>                                                                                                                                                                                               |                                                                                                                                        |                                                                                                                                                                                    |
| D. Memor | y Reference Group         | o (With Auto-Ind                                                                                                                                                                                                                                                                                                 | dex)                                                                                                                                                                                                   | Bits 0, 1, 2<br>of Instruction<br>Code Byte                                                                                            | Assembler<br>Symbolic<br>Representation                                                                                                                                            |
|          | sing Mode: •              | Absolute Page                                                                                                                                                                                                                                                                                                    | , Direct                                                                                                                                                                                               | Bits 0, 1, 2<br>of Instruction                                                                                                         | Assembler<br>Symbolic                                                                                                                                                              |
|          | sing Mode: ●<br>●         | Absolute Page<br>Absolute Page                                                                                                                                                                                                                                                                                   | , Direct<br>, Indirect                                                                                                                                                                                 | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001                                                                  | Assembler<br>Symbolic<br>Representation                                                                                                                                            |
|          | sing Mode: ●<br>●         | Absolute Page<br>Absolute Page<br>Current Page,                                                                                                                                                                                                                                                                  | , Direct<br>, Indirect<br>Direct                                                                                                                                                                       | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010                                                     | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD* TAGO)<br>(ADD TAG)                                                                                                  |
|          | sing Mode: ●<br>●         | Absolute Page<br>Absolute Page<br>Current Page,<br>Current Page,                                                                                                                                                                                                                                                 | , Direct<br>, Indirect<br>Direct<br>Indirect                                                                                                                                                           | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010<br>XXX = 011                                        | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD* TAGO)<br>(ADD TAG)<br>(ADD* TAG)                                                                                    |
|          | sing Mode: ●<br>●         | Absolute Page<br>Absolute Page<br>Current Page,                                                                                                                                                                                                                                                                  | , Direct<br>, Indirect<br>Direct<br>Indirect<br>, Indirect,                                                                                                                                            | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010                                                     | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD* TAGO)<br>(ADD TAG)                                                                                                  |
|          | sing Mode:<br>•<br>•<br>• | Absolute Page<br>Absolute Page<br>Current Page,<br>Current Page,<br>Absolute Page<br>Auto-Incremer<br>Absolute Page<br>Auto-Decreme                                                                                                                                                                              | , Direct<br>, Indirect<br>Direct<br>Indirect<br>, Indirect,<br>nt<br>, Indirect<br>nt                                                                                                                  | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010<br>XXX = 011<br>XXX = 100<br>XXX = 101              | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD* TAGO)<br>(ADD TAG)<br>(ADD* TAG)                                                                                    |
|          | sing Mode:<br>•<br>•<br>• | Absolute Page<br>Absolute Page<br>Current Page,<br>Current Page,<br>Absolute Page<br>Auto-Incremer<br>Absolute Page<br>Auto-Decreme<br>Current Page,                                                                                                                                                             | , Direct<br>, Indirect<br>Direct<br>Indirect<br>, Indirect,<br>nt<br>, Indirect<br>nt<br>Indirect                                                                                                      | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010<br>XXX = 011<br>XXX = 100                           | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD* TAGO)<br>(ADD TAG)<br>(ADD* TAG)<br>(ADD+ TAGO)                                                                     |
|          | sing Mode:<br>•<br>•<br>• | Absolute Page<br>Absolute Page,<br>Current Page,<br>Current Page,<br>Absolute Page<br>Auto-Incremer<br>Absolute Page<br>Auto-Decreme<br>Current Page,<br>Auto-Incremer                                                                                                                                           | , Direct<br>, Indirect<br>Direct<br>Indirect<br>, Indirect,<br>nt<br>, Indirect<br>nt<br>Indirect                                                                                                      | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010<br>XXX = 011<br>XXX = 100<br>XXX = 101<br>XXX = 110 | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD* TAGO)<br>(ADD TAG)<br>(ADD* TAG)<br>(ADD+ TAGO)<br>(ADD- TAGO)<br>(ADD+ TAGO)                                       |
|          | sing Mode:<br>•<br>•<br>• | Absolute Page<br>Absolute Page<br>Current Page,<br>Current Page,<br>Absolute Page<br>Auto-Incremer<br>Absolute Page<br>Auto-Decreme<br>Current Page,                                                                                                                                                             | , Direct<br>, Indirect<br>Direct<br>Indirect<br>, Indirect,<br>, Indirect<br>nt<br>Indirect<br>nt<br>Indirect,                                                                                         | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010<br>XXX = 011<br>XXX = 100<br>XXX = 101              | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD* TAGO)<br>(ADD TAG)<br>(ADD* TAG)<br>(ADD+ TAGO)                                                                     |
|          | sing Mode:                | Absolute Page<br>Absolute Page,<br>Current Page,<br>Current Page,<br>Absolute Page<br>Auto-Incremer<br>Absolute Page<br>Auto-Decreme<br>Current Page,<br>Auto-Incremer<br>Current Page,<br>Auto-Decreme<br>Indirect Addre<br>For double op<br>address being i<br>For Auto-Inde<br>fetch, decreme<br>For Double o | , Direct<br>, Indirect<br>Direct<br>Indirect<br>, Indirect,<br>nt<br>Indirect<br>nt<br>Indirect<br>nt<br>sses must be<br>perand comm<br>ncremented c<br>ex Indirect A<br>enting will oc<br>perand comm | Bits 0, 1, 2<br>of Instruction<br>Code Byte<br>XXX = 000<br>XXX = 001<br>XXX = 010<br>XXX = 011<br>XXX = 100<br>XXX = 101<br>XXX = 110 | Assembler<br>Symbolic<br>Representation<br>(ADD TAGO)<br>(ADD TAGO)<br>(ADD TAG)<br>(ADD TAG)<br>(ADD TAG)<br>(ADD+ TAGO)<br>(ADD- TAGO)<br>(ADD+ TAG)<br>(ADD- TAG)<br>(ADD- TAG) |

• Memory reference instructions which reference a current page address and require more than two memory cycles for execution will not function properly when located in the last location of a page, (XXFE).

| ADD | Add                              | 10000XXX         M         3, 5 Memory Cycles         Status – V, Z           7         0         7         0                                                                                                                                                                                                                                                                                                                                                                            |
|-----|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                                  | The contents of the effective memory address are added to the A-Register.<br>The carry status bit is not affected. The addition will be made in binary<br>mode if the D status register bit is 0, or in decimal mode if D is 1.                                                                                                                                                                                                                                                          |
| AC  | Add with<br>Carry                | 10001XXX         M         3, 5 Memory Cycles         Status - V,Z,C           7         0         7         0                                                                                                                                                                                                                                                                                                                                                                           |
|     |                                  | The contents of the effect memory address and the C status register bit (carry) are added to the A-Register. The C status register bit will be set to the new value of the carry resulting from the addition, (0 or 1). The addition will be made in binary mode if the D status register bit is 0, or in decimal mode if D is 1.                                                                                                                                                        |
| AMC | Add to<br>Memory with<br>Carry   | 10011XXX         M         3, 5 Memory Cycles         Status – V,Z,C           7         0         7         0                                                                                                                                                                                                                                                                                                                                                                           |
|     |                                  | The contents of the A-Register and the C Status Register bit (carry) are added to contents of the effective memory address. The C Status Register bit will be set to the new value of the carry resulting from the addition, (0 or 1). The addition will be made in binary mode if the D status register bit is 0, or in decimal mode if D is 1.                                                                                                                                         |
| С   | Compare                          | 10010XXX         M         3, 5 Memory Cycles         Status - Z,V,C           7         0         7         0                                                                                                                                                                                                                                                                                                                                                                           |
|     |                                  | The 2's complement of the contents of the A-Register and the contents of effective memory address are added together in binary mode. The result is not saved but the Z (result zero) and C (carry) status register bits are set. The comparison jumps JGT, JNE, JLT, JEQ can be used subsequently.                                                                                                                                                                                       |
| DAM | Double Add<br>to Memory          | 10101XXX         M         4, 6 Memory Cycles         Status - Z,V,C           7         0         7         0         7                                                                                                                                                                                                                                                                                                                                                                 |
|     |                                  | The contents of the Z and A registers and the C status register bit (carry) are added to the two byte contents of the effective memory address and memory address + 1. The C status register bit (carry) is set to the new carry resulting from the two byte addition. The addition will be made in binary mode if the D status register bit is 0, or in decimal mode if D is 1. The Z status bit reflects both bytes of the result. The V status bit reflects only the high order byte. |
| DCM | Double<br>Compare with<br>Memory | 10100XXX         M         4, 6 Memory Cycles         Status - C,Z,V           7         0         7         0         7         0                                                                                                                                                                                                                                                                                                                                                       |
|     | ,                                | The 2's complement of the contents of the Z and A registers and the two byte contents of the effective memory address, and memory address $+ 1$ are added together. The result is not saved but the Z (result zero) and C (carry) status register bits are set. The comparison jumps, JGT, JNE, JLT, and JEQ can be used subsequently. The Z status bit reflects the result of both bytes. The V status bit reflects only the high order byte.                                           |
| DL  | Double Load                      | 10110XXX         M         4, 6 Memory Cycles         Status - Z, V           7         0         7         0                                                                                                                                                                                                                                                                                                                                                                            |

The contents of the effective memory location is loaded into the Z register, the contents of the effective memory location + 1 is loaded into the A-register. The V status bit reflects only the high order byte loaded, (final contents of Z register), while the Z status bit reflects the result of both bytes.

| <b></b>   |                          |                                                                                                                                                                                                                               |
|-----------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DU        | Double<br>Unload         | 10111XXX M 4, 6 Memory Cycles Status – None                                                                                                                                                                                   |
|           | Onioau                   |                                                                                                                                                                                                                               |
|           |                          | The contents of the Z register replaces the contents of the effective                                                                                                                                                         |
|           |                          | memory address, the contents of the A-register replaces the contents of                                                                                                                                                       |
|           |                          | the effective memory address + 1.                                                                                                                                                                                             |
| LA        | Load A                   | 11000XXX M 3,5 Memory Cycles Status – Z, V                                                                                                                                                                                    |
|           |                          |                                                                                                                                                                                                                               |
|           |                          | The contents of the effective memory address is loaded into the A-Register.                                                                                                                                                   |
| LZ        | Load Z                   | 11010XX         M         3, 5 Memory Cycles         Status - Z, V           7         0         7         0                                                                                                                  |
|           |                          | The contents of the effective memory address is loaded into the Z Register.                                                                                                                                                   |
| UA        | Unload A<br>(Store A)    | 11001XX         M         3,5 Memory Cycles         Status - None           7         0         7         0                                                                                                                   |
|           |                          | The contents of the A-Register replace the contents of the effective memory address.                                                                                                                                          |
| UAH       | Unload A<br>High Digit   | 11101XXX         M         3, 5 Memory Cycles         Status - None           7         0         7         0                                                                                                                 |
|           |                          | Bits 7 - 4 of the A register replaces bits 7 - 4 of the contents of the effective memory address.                                                                                                                             |
| UZ        | Unload Z<br>(Store Z)    | 11011XXX         M         3, 5 Memory Cycles         Status - None           7         0         7         0                                                                                                                 |
|           |                          | The contents of the Z register replace the contents of the effective memory address.                                                                                                                                          |
| XMA       | Exchange<br>Memory and A | 11100XXX         M         3,5 Memory Cycles         Status - V, Z           7         0         7         0                                                                                                                  |
|           |                          | The contents of the effective memory address is exchanged with the contents of the A-register. (V, Z status bits reflect final contents of the A-register.)                                                                   |
| C. Immedi | ate Reference Gr         | oup                                                                                                                                                                                                                           |
| All inst  | ructions use the s       | econd byte of the instruction, M, as an operand.                                                                                                                                                                              |
| AI        | Add<br>Immediate         | 00011000         M         2 Memory Cycles         Status - V, Z           7         0         7         0         7                                                                                                          |
|           |                          | The second byte of the instruction, M, is added to the A register. The status register C bit (carry) is not affected. The addition is performed in binary mode if the D status bit is set to 0, or in decimal mode if D is 1. |
| BAI       | Boolean AND<br>Immediate | 00011101         M         2 Memory Cycles         Status - V,Z           7         0         7         0                                                                                                                     |
|           |                          | The second byte of the instruction, M, is anded with the contents of the                                                                                                                                                      |
|           |                          | A-register, the result is stored in A.                                                                                                                                                                                        |
| BOI       | Boolean OR<br>Immediate  | 00011111         M         2 Memory Cycles         Status - V, Z           7         0         7         0                                                                                                                    |
|           |                          | The second byte of the instruction Main and initial                                                                                                                                                                           |
|           |                          | The second byte of the instruction, M, is ored with the contents of the A-register, the result is stored in A.                                                                                                                |

| BXI | Boolean<br>Exclusive or<br>Immediate | 00011110M2 Memory CyclesStatus - V, Z7070The second byte of the instruction, M, is Exclusive Ored with the contents of the A-register, the result is stored in A.                                                                                                                                                                                                                          |
|-----|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| СІ  | Compare<br>Immediate                 | 00011001       M       2 Memory Cycles       Status - C, V, Z         7       0       7       0         The 2's complement of the contents of A and the contents of the second byte of the instruction, M, are added together. No result is saved but the Z (result zero) and C (carry) status register bits are set. The comparison jumps JGT, JNE, JLT and JEQ can be used subsequently. |
| DLI | Double Load<br>Immediate             | 00011100M2 Memory CyclesStatus - C,V,Z7070The second byte of the instruction, M, replaces the contents of the A-register. The high order bit of M, $(M_7)$ , is propagated thru the Z-register. The C status bit, (carry) is set to 0.                                                                                                                                                     |
| LAI | Load A-<br>Register<br>Immediate     | 00011010M2 Memory CyclesStatus - V, Z7070The second byte of the instruction, M, replaces the contents of the A-register.                                                                                                                                                                                                                                                                   |
| LZI | Load Z<br>Register<br>Immediate      | 00011011     M     2 Memory Cycles     Status - V, Z       7     0     7     0       The second byte of the instruction, M, replaces the contents of the Z-register.                                                                                                                                                                                                                       |

# D. Shift and Rotate Group

For all instructions in this group except SDJ, SBJ, and SBCJ the low order two bits of the address instruction byte ( $M_0$  and  $M_1$ ), specify the shift count which can be 1 to 4 bits. The shift count for SDJ, SBJ, SBCJ is explicitly 1 bit or 1 digit (4 bits).

For all single register shift and rotate instructions the shift count, NN, is interpreted as follows:

| NN | = | 00 | Shift 1 bit  |
|----|---|----|--------------|
| NN | = | 01 | Shift 2 bits |
| NN | = | 10 | Shift 3 bits |
| ΝN | = | 11 | Shift 4 bits |

| RT | Rotate A | 00100010 | 000000NN | 2 Memory Cycles | Status – None |
|----|----------|----------|----------|-----------------|---------------|
|    | Left     | 7 0      | 7        | 0               |               |

The contents of the A-register is circularly rotated left NN bits, (1-4). Bits shifted out of  $A_7$  replace  $A_0$ .

| RTC | Rotate A           | 00100011 |   | 000000NN |   | 2 Memory Cycles                       | Status – C |
|-----|--------------------|----------|---|----------|---|---------------------------------------|------------|
|     | Left With<br>Carry | 7        | 0 | 7        | 0 | · · · · · · · · · · · · · · · · · · · | []         |

The C status register bit, (carry) is treated as an extension of the A-register. The contents of these 9 bits are circularly rotated left NN bits, (1-4). Bits shifted out of  $A_7$  replace C, bits shifted out of C replace  $A_0$ .

| SH   | Shift A<br>Left                           | 00100000         000000NN         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                     |
|------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                                           | The contents of the A register are shifted left NN bits, (1-4). Zeroes are shifted into the low order bit of A, (A <sub>0</sub> ).                                                                                                                                    |
| SHC  | Shift A<br>Left Wi <del>th</del><br>Carry | 00100001         000000NN         2 Memory Cycles         Status - C           7         0         7         0                                                                                                                                                        |
|      |                                           | The C status register is treated as an extension of the A register. The contents of these 9 bits are shifted left NN bits, (1-4). Zeroes are shifted into the C bit, the C bit is shifted into $A_0$ .                                                                |
| SBJ  | Shift Binary<br>Double And<br>Jump        | 00001000         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                            |
|      |                                           | The contents of the Z and A registers are treated as one 16-bit register, and are shifted left 1 bit. Zeroes are shifted into $A_0$ . Program Control is then transferred to the current page address specified by M.                                                 |
| SBCJ | Shift Binary<br>Double With<br>Carry And  | 00001001         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                            |
|      | Jump                                      | The contents of the Z and A register and the C status register bit (carry) are treated as a .17-bit register and are shifted left 1 bit. $(A_7 \rightarrow Z_0, C \rightarrow A_0)$ . Program Control is then transferred to the current page address specified by M. |
| SDJ  | Shift Decimal<br>Double And<br>Jump       | 00000010         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                            |
|      |                                           | The contents of the Z and A registers are treated as a 16-bit register and shifted left one decimal digit, (4 bits). Zeroes are transferred into the low order 4 bits of A $(A_0 - A_3)$ . Program Control is transferred to the current page address specified by M. |

# E. Conditional Jump Group

The following instructions produce jumps within the current page depending upon the current setting of the status register Z (result zero) and C (carry) bits. They are typically performed after compare instructions, (C, DCM, CI).

| JEQ   | Jump If                                                                                                                                      | 00100111                                                                                                                                           | м        | 2 Memory Cycles | Status – None              |  |  |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------|----------------------------|--|--|
| (JZ)  | Equal<br>(Jump If                                                                                                                            | 7 0                                                                                                                                                | 7 0      |                 |                            |  |  |
|       | Result Zero)                                                                                                                                 | If the Z status register bit (last result zero) is set to 1, (true), Program<br>Control is transferred to the current page address specified by M. |          |                 |                            |  |  |
| JGT   | Jump If                                                                                                                                      | 00100100                                                                                                                                           | м        | 2 Memory Cycles | Status – None              |  |  |
| (JNC) | Greater Than<br>(Jump If No                                                                                                                  | 7 0                                                                                                                                                | 7 0      |                 |                            |  |  |
|       | <i>Carry</i> ) If the C status register bit (carry) is set to 0, (no carry), Prog is transferred to the current page address specified by M. |                                                                                                                                                    |          |                 | ry), Program Control<br>M. |  |  |
| JLT   | Jump If<br>Less Than                                                                                                                         | 00100110<br>7 0                                                                                                                                    | M<br>7 0 | 2 Memory Cycles | Status – None              |  |  |

If the C status register bit (carry) is set to 1, (was a carry), and the Z status register bit (result zero) is set to 0, (last result not zero), Program Control is transferred to the current page address specified by M.

| JNE       | Jump If                     | 00100101         | м                             | 2 Memory Cycles      | Status – None |
|-----------|-----------------------------|------------------|-------------------------------|----------------------|---------------|
| (JNZ)     | Not Equal<br>(JNZ) (Jump If | 7 0              | 7 0                           |                      | <u> </u>      |
| Not Zero) | If the Z statu              | s register bit ( | result zero) is set to 0, (la | st result not zero), |               |

Program Control is transferred to the current page address specified by M.

#### F. Conditional Skip Group (A-Register, Status Register, I/O Register)

All instructions in this group operate in a similar manner. An 8-bit register or the equivalent is interrogated, (A-register, S-register, or I/O Status Register). The second byte of the instruction acts as a mask to specify which bits in the interrogated register will be examined, (a bit setting of 1 indicates that the bit is to be compared except for false skips, SMA, SFA, SFS, SFS where a setting of zero indicates that a bit is to be compared). If the specified condition is met, the next instruction (two bytes) is skipped.

| SAA | Skip If            | 00010010                     | м           |          | 2 Memory Cycles                                                     | Status – None                            |
|-----|--------------------|------------------------------|-------------|----------|---------------------------------------------------------------------|------------------------------------------|
|     | Any A              | 7 0                          | 7           | 0        |                                                                     |                                          |
|     |                    |                              |             |          | y corresponding 1 bits<br>uction is skipped.                        | in M are interrogated.                   |
| SMA | Skip If            | 00010001                     | м           |          | 2 Memory Cycles                                                     | Status – None                            |
|     | Mixed A            | 7 0                          | 7           |          |                                                                     |                                          |
|     |                    | -                            |             |          | y corresponding 0 bits<br>ed bit, the next instruc                  | in M are interrogated ction is skipped.  |
| STA | Skip If            | 00010000                     | м           |          | 2 Memory Cycles                                                     | Status – None                            |
|     | True A             | 7 0                          | 7           | 0        | J                                                                   | L.,                                      |
| SFA | Skip If            | 00010001                     | M           |          | nstruction is skipped.<br>2 Memory Cycles                           | Status – None                            |
|     | False A            | 7 0                          | 7           | 0        |                                                                     |                                          |
| STS | Skip If            | If all O's are p<br>00010100 | resent, th  | e next i | y corresponding 0 bits<br>nstruction is skipped.<br>2 Memory Cycles | s in M are interrogated<br>Status – None |
|     | True S             | 7 0                          | 7           | 0        |                                                                     |                                          |
|     |                    | interrogated.                | If all 1    | 's are   | cified by correspond<br>present, the next in                        | nstruction is skipped                    |
| SFS | Skip If<br>False S | 00010101                     | M           |          | 2 Memory Cycles                                                     | Status – None                            |
|     | raise S            | / 0                          | /           | 0        |                                                                     |                                          |
|     |                    |                              |             |          | cified by correspond<br>the next instruction is                     |                                          |
| STI | Skip If            | 00110000                     | M           |          | 2 Memory Cycles                                                     | Status – None                            |
|     | True I/O           | 7 0                          | 7           | 0        |                                                                     |                                          |
|     |                    |                              |             |          |                                                                     | in in the 7 meters                       |
|     | i rue I/O          | The I/O regis                | ster for th | ne I/O   | device whose address                                                |                                          |

The I/O register for the I/O device whose address is in the Z register is referenced. The register bits specified by corresponding 1 bits in M are interrogated. If all 1's are present, the next instruction is skipped.

| SFI | Skip if   | 00110000 |    | М | 2 Memory Cycles                       | Status – None |
|-----|-----------|----------|----|---|---------------------------------------|---------------|
|     | False I/O | 7        | 07 | 0 | · · · · · · · · · · · · · · · · · · · |               |

The I/O register for the I/O device whose address is in the Z register is referenced. The register bits specified by corresponding 0 bits in M are interrogated. If they are all 0, the next instruction is skipped.

# G. Register Transfer and Manipulation Group (With Micro Jumps)

The instructions in this group, in most instances, perform explicit operations with the Z, A, and S registers. In most cases the address portion of the instruction, M, is used to specify the address for a current page jump which is an automatic part of the instruction.

| AZAJ | Add Z To               | 00000100 M 2 Memory Cycles Status – Z,V,C                                                                                                                                                                                                                                                                                                |
|------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | A And                  | 7 0 7 0                                                                                                                                                                                                                                                                                                                                  |
|      | Jump                   | The contents of the Z and A registers and the C bit are added and stored in A. The carry from the addition is saved in C. Program Control transfers to the current page address specified by M. The addition will be performed in binary mode if the D status register bit is 0, or in decimal mode if D is 1.                           |
| DNJ  | Double Not<br>And Jump | 00000011         M         2 Memory Cycles         Status - Z           7         0         7         0                                                                                                                                                                                                                                  |
|      |                        | The contents of the Z and A registers are complemented. A 1's comple-<br>ment is performed if the D status register bit is set to 0, or a 9's comple-<br>ment (4 bit groups) if D is set to 1. Program Control transfers to the<br>current page address specified by M. The Z status bit reflects the final<br>result of the A register. |
| HLTJ | Halt And               | 00000000 M 2 Memory Cycles Status – None                                                                                                                                                                                                                                                                                                 |
|      | Jump                   | 7 0 7 0                                                                                                                                                                                                                                                                                                                                  |
|      |                        | Processing is halted. When processing is restarted, Program Control is transferred to the current page address specified by M.                                                                                                                                                                                                           |
| JZA  | Jump Via               | 00001111 00000000 2 Memory Cycles Status – None                                                                                                                                                                                                                                                                                          |
|      | Z and A                | 7 0 7 0                                                                                                                                                                                                                                                                                                                                  |
|      |                        | Program Control is transferred to the 16-bit address formed by the current contents of Z and A.                                                                                                                                                                                                                                          |
| LZAJ | Load Via               | 00001011 M 4 Memory Cycles Status – None                                                                                                                                                                                                                                                                                                 |
|      | Z and A<br>And Jump    | 7 0 7 0                                                                                                                                                                                                                                                                                                                                  |
|      |                        | The current contents of the Z and A registers form a 16-bit memory                                                                                                                                                                                                                                                                       |
|      |                        | address. The contents of this memory address and the address + 1 are                                                                                                                                                                                                                                                                     |
|      |                        | then loaded into Z and A respectively. Program Control is transferred to                                                                                                                                                                                                                                                                 |

-19-

Z and A must be even.

~

the current page address specified by M. The memory address specified in

| NJ   | Not A                  | 00000010       | М                            | 2 Memory Cycles                                                                                                 | Status – Z, V            |
|------|------------------------|----------------|------------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------|
|      | And Jump               | 7 0            | 7 0                          |                                                                                                                 |                          |
|      |                        | performed if   | the D status<br>if D is 1. P | jister is complemented. /<br>register bit is set to 0, o<br>rogram Control is transf                            | or a 9's complement      |
| PARJ | Parity And             | 0000001        | М                            | 2 Memory Cycles                                                                                                 | Status – None            |
|      | Jump                   | 7 0            | 7 0                          |                                                                                                                 |                          |
|      |                        | of the A reg   | jister. Program              | ted in bit 7 of the A regis<br>Control is transferred<br>it 7 of the A register                                 | to the current page      |
| TASJ | Transfer A             | 00001110       | м                            | 2 Memory Cycles                                                                                                 | Status – All bits        |
|      | To S And<br>Jump       | 7 0            | 7 0                          |                                                                                                                 |                          |
|      |                        |                |                              | gister replace the conter<br>red to the current page ac                                                         |                          |
| TSAJ | Transfer S             | 00000110       | M                            | 3 Memory Cycles                                                                                                 | Status – Z, V            |
|      | To A And<br>Jump       | 7 0            | 7 0                          |                                                                                                                 |                          |
|      |                        |                |                              | ister replace the conten<br>red to the current page ac                                                          |                          |
| TZAJ | Transfer Z             | 00000111       | м                            | 2 Memory Cycles                                                                                                 | Status – None            |
|      | To A And<br>Jump       | 7 0            | 7 0                          |                                                                                                                 |                          |
|      |                        |                |                              | ister replace the conten<br>red to the current page ac                                                          |                          |
| XZAJ | Exchange Z             | 00000101       | м                            | 2 Memory Cycles                                                                                                 | Status – None            |
|      | and A And<br>Jump      | 7 0            | 7 0                          |                                                                                                                 |                          |
|      |                        |                | Program Contr                | ister are exchanged with<br>ol transferred to the c                                                             |                          |
| OFS  | Off Status<br>Register | 00001101       | м                            | 2 Memory Cycles                                                                                                 | Status-Specified<br>Bits |
|      | -                      | 7 0            | 7 0                          | ، السبب المراجع | L <u></u>                |
|      |                        | The status reg | gister bits spec             | ified by corresponding 0                                                                                        | bits in M are set to 0.  |
| ONS  | On Status              | 00001100       | м                            | 2 Memory Cycles                                                                                                 | Status-Specified         |
|      | Register               | 7 0            | 7 0                          |                                                                                                                 | Bits                     |
|      |                        |                |                              |                                                                                                                 |                          |

The status register bits specified by corresponding 1 bits in the M field are set to 1.

# H. Input/Output And Interrupt Group

Most of the Input/Output instructions in this group are used in conjunction with a valid device address loaded in the Z-register. In addition, for all instructions in this group, the M portion of the instruction specifies the current page address of an in-page jump which is an integral part of the instruction.

| AKIJ | Acknowledge<br>Interrupt             | 00110010         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                                                                                                                                                                         |
|------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | And Jump                             | The execution of this instruction, after an interrupt causes the interrupting device address to be transferred to the A-register. Program Control is transferred to the current page address specified by M.                                                                                                                                                                                                       |
| DSIJ | Disable<br>Interrupt<br>And Jump     | 00110011         M         2 Memory Cycles         Status - None           7         0         7         0         7         0                                                                                                                                                                                                                                                                                     |
|      |                                      | The CP interrupt bit is set to 1, which inhibits all interrupts to the CP.<br>Program Control is transferred to the current page address specified by<br>M. (CP interrupt is automatically disabled when an interrupt occurs).                                                                                                                                                                                     |
| ONMJ | On Interrupt<br>Mask And<br>Jump     | 00111001         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                                                                                                                                                                         |
|      | Samp                                 | The contents of the A-register are transferred out as a station interrupt mask, one bit per logical I/O station, (bit 0 for station 0, bit 1 for station 1, etc.). If a zero bit is transmitted, interrupt is enabled at the corresponding station, a 1-bit disables interrupt at the station. Program Control is then transferred to the current page address specified by M.                                     |
| CIOJ | Control Signal<br>To I/O And<br>Jump | 00111100         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                                                                                                                                                                         |
|      |                                      | The I/O control command bits in the A-register are transferred to the device whose address is contained in the Z-register. Operations such as clearing and enabling devices, initiating writes or tape motion are performed. Program Control is then transferred to the current page address specified by M.                                                                                                       |
| RDDJ | Read Data<br>And Jump                | 00111010         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                                                                                                                                                                         |
|      |                                      | For character buffered I/O devices (I/O bus multiplex mode), one byte (8 bits) is read into the A-register from the character buffer of the device whose address is contained in the Z-register. For certain channel devices, a channel read into memcry is initiated for the device specified by the address in Z. In both cases, Program Control is then transferred to the current page address specified by M. |
| WRDJ | Write Data<br>And Jump               | 00111011         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                                                                                                                                                                         |
|      |                                      | For character buffered devices (I/O bus multiplex mode), one byte (8 bits) is output from the A-register to the device buffer of the device whose address is contained in the Z-register. For certain channel devices, a channel write from memory is initiated for the device specified by the address in Z. In both cases, Program Control is then transferred to the current page address specified by M.       |
| TIAJ | Transfer I/O<br>to A And<br>Jump     | 00111000         M         2 Memory Cycles         Status - None           7         0         7         0                                                                                                                                                                                                                                                                                                         |
|      |                                      | The I/O status register bits of the device specified by the address in the Z-register is transferred to the A-register. Program Control is then transferred to the current page address specified by M.                                                                                                                                                                                                            |

-21-

# VII. INPUT/OUTPUT AND INTERRUPT ORGANIZATION

#### A. Modes of Input/Output Operation

All input/output operations in the 3300 are carried out through the I/O bus structure. The I/O bus structure has two control modes of operation.

- Multiplex Mode

- Direct Memory Access Channel Mode

In multiplex mode, 8-bit characters are transferred between the CPU A-register and an I/O device buffer in the device control logic. The transfer is made upon execution of a CPU read or write instruction. Ready status information and a corresponding interrupt is signaled when a character has been received into the I/O buffer from a device or output is completed to that device.

In Direct Memory Access Channel Mode, information is transferred directly between computer memory and device control logic on a cycle stealing basis. When a channel demand is present, the CPU will allocate the next read/write memory cycle to the channel. Accordingly, channel operations are interlaced with CPU instruction executions. In fact, channel read/write memory cycles are allocated to the channel in the middle of an instruction to keep up with high data rates. A read or write command is not required to perform the data transfer, but the device and device control logic must be initialized or enabled prior to the I/O operation. The channel mode of I/O control is used for both low and high speed devices. The Wang 3315 teletype, a low speed terminal device, utilizes I/O Channel logic. Single characters are transferred between fixed memory buffer locations in Page 2 and the device I/O control logic. High speed devices such as discs, utilize the channel logic to asynchronously transfer blocks of characters between memory and the device controller. In this case, the starting memory address, the starting device address and block count are set up by 3300 channel commands (ICH) prior to the transfer, and information can be transferred to and from any computer memory address.

#### B. I/O Bus Structure Organization

#### 1. Device Addresses

Each I/O device attached to the 3300 has a seven-bit device address. Some devices will have two addresses, one for input and one for output. Up to 128  $(2^7)$  device addresses are available in the 3300. For devices with two addresses, the input device address is even and output device address is odd and one greater than the input address.

All 3300 I/O instructions operate identically in terms of device addressing. The device address is loaded into the low order 7 bits of the Z-register. For certain devices the high order bit of the Z register is set to the odd parity logical sum of the 7 address bits. A device will respond only if the address parity is correct. The I/O instruction which may enable a device, initiate a transfer, or sense I/O device status is then executed. The device address will always be taken from the current contents of the Z-register.



Setup of the Z register prior to an I/O instruction.

#### 2. I/O Bus Stations And Interrupt Priority

For purposes of interrupt, processing priority and control, the I/O bus structure is logically divided into stations. Figure 3 illustrates a typical I/O bus station organization for the 3300. A single device or a number of devices may be attached to a station. Up to 8 stations can be configured on a 3300, controlling up to 128 addressable devices in any combination. I/O operation within the station organization has the following characteristics:

(1) Interrupts and channel cycle stealing demands are sequential. Devices attached on the closest station to the CPU are given highest priority, the second closest, the second highest priority, etc. Lower priority device interrupts are stacked until they can be processed.

- (2) For devices on the same station, the ones attached closest to the I/O bus are given the highest priority. Lower priority device interrupts are stacked until they can be processed.
- (3) A single station and all devices on that station can be inhibited from interrupt, and subsequently re-enabled by a station interrupt mask instruction (ONMJ).

To summarize, devices to 3300 I/O bus stations are ordered in 128 levels of sequential interrupt priority on from 1 to 8 stations. All devices assigned to a single station can be inhibited from or enabled for interrupt as a group.

Since the 3300 can be configured with a number of different I/O devices in varying quantities, a variety of station configurations are useful. Typically, high-speed devices will be assigned to higher priority stations or positions on a station, lower speed devices to lower priority stations or positions. Similar devices with identical functions would be assigned to the same station, so that they will receive approximately the same priority and can be inhibited as a group.

#### C. I/O Status Registers

Figure 3 illustrates the status registers used with Input/Output.

- I/O Status Register - One for each device. They reflect the current operating status of each device.

1. I/O Status Registers



The logic which controls each device contains an 8-bit status register which reflects the current operating status of the device. These device status register bits are sensed by using STI, SFI and TIAJ instructions with the appropriate device address loaded into the Z-register. Typical I/O status bit settings are:

3315 Teletype

lo - Error

 $I_7, I_6, I_5, I_4$  Ready = 0000 Device Idle and Ready

= 1011 Character Received (Input)

= 1100 Character Transmitted (Output)

The status register bits are sensed to determine ready conditions for non-interrupt I/O and transmission errors. A typical sequence following a write for a 3315 Teletype would be:

| LZ    | DEVADR      | Load device address into Z |
|-------|-------------|----------------------------|
| SFI   | B'11000000' | SKIP if ready bits are set |
| JMP   | *-2         | Not, continue checking     |
| • • • |             |                            |
|       |             |                            |

Continue

. .



- (1) The Device Address from the Z-register is decoded at each station. If a device is attached to a particular station, I/O command signals and data will be passed thru the station to and from the device.
- (2) Each station has an Interrupt Inhibit/Enable Mask bit: J<sub>0</sub>, J<sub>1</sub>, J<sub>2</sub>, etc. They are set or reset by the ONMJ command using the A-register for a mask as follows:

J<sub>3</sub>

 $J_1$ 

J<sub>2</sub>

A-register setting for J<sub>7</sub> ONMJ

 $\mathbf{J}_6$ 

J<sub>5</sub>

 $J_4$ 

J<sub>0</sub> where J = 0 Enable where J = 1 Inhibit

(3) The control logic for each device contains I/O Status Register bits, (I<sub>0</sub> thru I<sub>7</sub>). They reflect current device status conditions such as ready, error, etc. They can be sensed by STI, STF, and TIAJ commands with the Z-register set to the device address.

#### FIG. 3. TYPICAL I/O BUS STATION ORGANIZATION

#### D. Interrupt Operations and Instructions

As was described in Section B, the 3300 has up to 128 sequential levels of priority interrupt. Priority is established by attaching I/O devices to I/O Bus stations. Stations closest to the CPU and positions on a station closest to the CPU have higher priority. In the station configuration shown in Figure 3, the following priority would be observed.

| Station 1 | Device 1 | Highest Priority      |
|-----------|----------|-----------------------|
| Station 1 | Device 2 | Next Highest Priority |
| Station 1 | Device 3 | Next Highest Priority |
| Station 2 | Device 1 | Next Highest Priority |
| Station 2 | Device 2 | Next Highest Priority |
| Etc.      |          | с ,                   |

Interrupt can be inhibited or enabled for all the devices attached to a station. Each station has its own interrupt mask bit. They are illustrated in Figure 3 as  $J_0$ ,  $J_1$ ,  $J_2$ , etc. The 8 interrupt mask bits for the 8 possible I/O bus stations are set or reset by the ONMJ instruction. For this instruction, the A-register is used as a mask to set and reset corresponding station interrupt inhibit bits, (Bit 0 = station 1, Bit 1 = station 2, etc).

#### For example:

LAI B'00000101' ONMJ would inhibit stations 1 and 3, and enable all other stations.

In addition to station interrupt bits, all interrupts to the CPU are inhibited or enabled by a single CPU interrupt bit contained in the I/O Bus Control Unit. The bit is automatically reset to 1, (inhibit), when an interrupt occurs. This prevents other interrupts from occurring during the processing of the current interrupt. When interrupt is completed the interrupt routine can be exited and CPU interrupt re-enabled by executing a JEI instruction, (Jump and Enable CPU Interrupt). The DSIJ instruction (Disable CPU Interrupt and Jump) can be used to inhibit CPU interrupt at any time.

During input/output processing with interrupt, (e.g. station interrupt enabled), an interrupt is requested when an I/O device becomes ready after an input or output operation. If an interrupt is currently being processed, (CPU interrupt temporarily inhibited), the request is stacked until the interrupt priority level associated with the device becomes available.

When the interrupt occurs, program control is transferred to location 2 of page 0. The previous current contents of the program counter, (registers B and C) are then stored in locations 0 and 1 of page 0.

In effect, the interrupt results in a subroutine jump to location 0 of memory. (JST 0). As the interrupt occurs, the CPU interrupt bit is automatically reset inhibiting all other interrupts. As the interrupt routine is entered the current contents of the A, Z, and S registers should be saved by the routine and restored upon exit. The interrupting device is determined by the execution of an AKIJ instruction, (Acknowledge Interrupt and Jump). When this instruction is executed, the device address of the interrupting device is transferred into the A-register, where it may be examined. The last instruction of the interrupt routine should be an indirect JEI command command which re-enables CPU interrupt. A typical I/O interrupt routine is illustrated below.

# **Typical Interrupt Routine**

| Loca    | ntion             |              |                                  |                             |                                                                                                                                                                                                                                      |
|---------|-------------------|--------------|----------------------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Page 0  | 0,1<br>1,2<br>3,4 | TRAP<br>IADR | DC<br>JMP*<br>DAC                | X'0000'<br>IADR<br>INTR     | Address of Interrupted Program Stored here<br>Jump indirectly to Interrupt Routine<br>Address of interrupt routine                                                                                                                   |
| •       |                   |              |                                  |                             |                                                                                                                                                                                                                                      |
| Page xx |                   | INTR         | DU<br>TSAJ<br>UA<br><br><br>AKIJ | SVZA<br>SAVS+1              | Save the Z-register and A-register<br>S-register to A-register<br>Save S-register in the 2nd byte of a ONS instruction<br>which will restore it.<br>(Acknowledge Interrupt (Device Address to A-register)                            |
|         |                   | SAVS         | DL<br>OFS<br>ONS<br>JEI*         | SVZA<br>X'FF'<br>**<br>TRAP | p Device Status and set up next I/O)<br>Restore Z-register and A-register<br>Clear status register to 0<br>Restore status register<br>Enable CPU interrupt and return to interrupted pro-<br>gram. (Indirect jump to saved address). |
|         |                   | SVZA         | DC                               | X'0000'                     | Location to save Z and A.                                                                                                                                                                                                            |

#### E. I/O Instructions

. .

The following I/O instructions are used to perform, test, and control input/output operations on the Wang 3300. In conjunction with each instruction, the Z-register must contain the proper device address of the device being controlled. Both a read or write address are used for certain devices.

| audi 633 0 | The device being controlled. Doth a read of write address are used for certain devices.                                                                                                                                                                                                                |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CIOJ       | - Control Signal to I/O and Jump                                                                                                                                                                                                                                                                       |
|            | This instruction transmits the current contents of the A-register to the device control logic. The bit pattern in A produces various control operations to be performed. Typically, functions such as clear device status, enable device for input/output, and initiate write are performed by CIOJ's. |
| RDDJ       | - Read and Jump                                                                                                                                                                                                                                                                                        |
|            | This instruction initiates read operations for certain devices.                                                                                                                                                                                                                                        |
| WRDJ       | - Write and Jump                                                                                                                                                                                                                                                                                       |
|            | This instruction initiates write operations for certain devices.                                                                                                                                                                                                                                       |
| TIAJ       | - Transfer I/O Register to A-Register and Jump.                                                                                                                                                                                                                                                        |
|            | This instruction transfers a device $I/O$ status register to the A-register, (for the device selected by the address in Z). The value can then be tested for ready error, etc.                                                                                                                         |
| STI        | - Skip if True I/O Status                                                                                                                                                                                                                                                                              |
|            | This instruction tests specified bits of a selected device I/O status and skips if they are all 1. It is used to test for device ready, error, etc.                                                                                                                                                    |
| SFI        | - Skip if False I/O Status                                                                                                                                                                                                                                                                             |
|            | This instruction tests specified bits of a selected device I/O status register and skips if they are all 0. It is used to test for device ready, error, etc.                                                                                                                                           |
|            |                                                                                                                                                                                                                                                                                                        |

# VIII. 3315 TELETYPE TERMINAL OPERATION

#### A. Operational Characteristics

The standard teletype used with the 3300 is the 33ASR Model TBE. The teletype terminal has both a keyboard/printing unit and a paper tape reader/punch unit. The operation of both units is quite similar. The only differences are:

- For tape input, an 'X-on' character is transmitted to the device to start the tape motion and an 'X-off' character is transmitted to halt tape motion. (For some Model 33ASR's the tape is started by a manual switch.)
- For tape output, the tape On/Off switch on the terminal is manually set to the On position to simultaneously produce a punched tape and printing.

The maximum transfer rate for both units is 10 cps. The major functional characteristics of the 3315 teletype terminal are:

- The teletype has no character buffer in the Control Unit and uses a fixed memory address location in page two for this purpose. Unique addresses are assigned each device. Data transfer is made directly to and from the device and memory without a read or write command. A Wang 3316 teletype control unit controls up to four teletypes in full duplex mode. The control unit transmits data bits serially at 9.09 ms intervals between two predetermined memory locations for each device and the device in a single character channel mode.
- There is no parity error checking capability for the Model TBE teletype I/O. Wang 3300 teletype code is the standard 3300 ASCII code set, (listed in Appendix D of this manual). The parity bit, (the 8th bit) is not used for parity and in general should be stripped and ignored for input. (All eight tracks are used when loading binary system tapes.)
- Teletype I/O operations are normally performed in a full duplex mode. That is, simultaneous input and output operations can occur at the same time and are completely independent. For keyboard input, each received character must be output back to the deivce to produce printing. This echo procedure also verifies correct transmission to the user. (The unit can also operate in half duplex.)

#### **B. I/O Status Register Settings**

The I/O status register for each teletype device acts like a counter during the transfer of a character. When an input or output operation is initiated, it is initially set to zero. As the transfer proceeds, bits 4 thru 7 of the register are incremented until it is complete. The I/O status register settings can be sensed by SFI, STI, and TIAJ commands at any time. The status register settings for both read and write operations are listed in Table 1.

TABLE 1 – TELETYPE I/O STATUS REGISTER SETTINGS DURING DATA TRANSFER

|                                                                |                                        | TTY INPUT                                                                                                                                     |                                                                |                                                  | ΤΤΥ ΟυΤΡυΤ                                                                                                        |
|----------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| TELETYPE<br>CONTROLLER<br>TRANSFER<br>CYCLE<br>(9.09 MS/CYCLE) | STATUS<br>REGISTER<br>SETTING<br>(HEX) | DESCRIPTION                                                                                                                                   | TELETYPE<br>CONTROLLER<br>TRANSFER<br>CYCLE<br>(9.09 MS/CYCLE) | STATUS<br>STATUS<br>REGISTER<br>SETTING<br>(HEX) | DESCRIPTION                                                                                                       |
|                                                                | 00                                     | Idle – No data transfer occurring                                                                                                             |                                                                | 00                                               | Idle – No data transfer occurring                                                                                 |
| 0 th                                                           | 10<br>thru<br>A0                       | Input request received and bits are being<br>transferred serially to the page 2 input<br>memory buffer.                                       | 10 u<br>10                                                     | 10<br>thru<br>B0                                 | Output request made and bits are being transferred serially from the page 2 output memory buffer.                 |
| 10<br>11                                                       | BO                                     | READY<br>Data transfer complete.<br>An interrupt will be issued if interrupt is<br>enabled.                                                   | 5                                                              | 8                                                | READY<br>Data transfer complete.<br>An interrupt will be issued if interrupt is<br>enabled.                       |
| During<br>Interrupt<br>or at the<br>end of cycle 11            | 8                                      | Status will be automatically reset back to<br>idle at the end of cycle 11 or when an AKIJ<br>command is executed in the interrupt<br>routine. | During<br>Interrupt                                            | 00                                               | Status will automatically be set back to idle<br>during an interrupt routine when an AKIJ<br>command is executed. |
| Any time<br>during<br>cycles 1 - 9                             | -                                      | Read Error<br>(A status clearing CIOJ command was<br>executed during data transfer.)                                                          | Any time<br>during<br>cycles 1 - 10                            | -                                                | Write Error<br>(Device power off or a status clearing CIOJ<br>command was issued during data transfer.)           |

- Note: The input status register for a Teletype is reset to idle (00) by the following:
- (1) When an AKIJ command is executed during the interrupt routine (cycles 10 and 11).
- (2) At the end of cycle 11. This will also cause a pending interrupt to be cancelled.
- When a Clear Status command is executed. (CIOJ with A = 83, Z = Input Address).

-

- Note: The output status register for a Teletype will be reset back to idle (00) by the following:
- (1) When an AKIJ command is executed during the interrupt routine, (cycle 11 or thereafter).
  - When a Clear Status command is executed. (CIOJ with A = 83 or 08, Z = Output Address.)

A pending output interrupt will never be cancelled unless status is reset by a CIOJ.

#### C. Read and Write Programming Procedures

#### 1. Keyboard Read Operations

Keyboard read is a self-initializing operation. It is not required that the teletype be enabled for input. When the terminal operator strikes a key, the character transfer is initiated automatically. The following steps are involved in the keyboard read operation:

- a. Enable station interrupt with an ONMJ, if interrupt required and not enabled. Enable CPU interrupt with JEI if required and not enabled.
- b. Clear the device for input with a CIOJ command.
   CIOJ with Z = Device Read Address; A = 83 (HEX)
- c. The device input status is set to and remains at 00, (idle) until a key is struck. At this point, the device input status register is incremented until the data transfer is complete, at which time a status value of B0 (HEX) exists. The character will be completely transferred to the appropriate page two memory buffer. If interrupt is enabled, an interrupt request will be set up.
- d. When the interrupt occurs, or when ready is sensed in non-interrupt mode, the character may be fetched from the appropriate page two memory buffer and processed. At this time, the character should be written back to the device to print it, (an independent I/O operation). In interrupt mode, status is reset back to 00, (idle) when the AKI instruction is executed in the interrupt routine. The input status is automatically reset back to 00, (idle), 13.5 milliseconds after data transfer is completed (B0 ready status) if not reset by an AKI or CIOJ. If an interrupt has not been executed by this time, the interrupt is lost although the character read will remain in the input buffer. At this time, additional input can be received and steps (c) and (d) are repeated for interrupt mode, steps (b), (c), and (d) are repeated for non-interrupt mode.

#### 2. Teletype Tape Read Operations

Teletype tape read operations are identical with keyboard tape read except that:

- A 'X-on' character is output to the teletype initially to initiate movement of the tape. After all required characters are read, a 'X-off' character is output to the teletype to halt tape motion. (Both are write operations.)
- Read tape characters are generally not echoed back to the Teletype for printing.

The following steps occur for tape read operations:

- a. A terminal operator mounts the tape, and sets the reader switch to the "STOP" position.
- b. Enable station interrupt with an ONMJ, and CPU interrupt with a JEI, if interrupt is desired.
- c. A 'X-on' character is transmitted to the teletype to start tape motion, (a code of 11 HEX).
- d. Initially clear the device for input. CIOJ with Z = Device Address, A = 83 (HEX).
- e. As each character is transmitted, the device status register is incremented until transfer is complete, status B0 (READY).
- f. An interrupt occurs, or ready is sensed and the character is fetched from the memory buffer and processed. Status is automatically set to 00 (idle) 13.5 milliseconds after ready, or by an AKI, and the next character transfer begins. Steps (e) and (f) are repeated.
- 9. If the last required character has been ready, a 'X-off' code is transmitted to the Teletype to halt tape motion (a code of 13 HEX). Since this takes approximately 100 milliseconds, two additional tape characters will be read before tape input is terminated.

#### 3. Print/Tape Punch Write Operations

Teletype printing and tape punching operations are simultaneous; the only differences being that the tape is manually switched on and off of the terminal. When the punch is on, both printing and punching will occur, while only printing occurs with the punch set to off. Unlike teletype read operations, write operation requires that an output enable and clear (CIOJ) be executed prior to every character transfer. In addition, an interrupt is issued after the transfer cycles are completed at the beginning of cycle 11 (90.91 ms after the start of write). The ready condition and/or interrupt may be processed any time after cycle 11 and is not lost. I/O register status is reset to **00**, (idle) either by a CIOJ command with A=83 (Clear), or A=08 (Clear and Write) or by the execution of an AKIJ command in the interrupt routine.

The following steps occur in a teletype write sequence:

- a. Enable the device station interrupt with an ONMJ, if interrupt mode is desired and the station is not already enabled. Enable CPU interrupt with a JEI command.
- b. Place the desired output character in the appropriate page two memory buffer.
- c. Initiate output, CIOJ with Z = Device Write Address, A = 08 (HEX) (Clear and Write). I/O status immediately becomes 10, (write requested).
- d. The teletype output status register is then stepped until data transfer is complete, at which time it is set to CO (interrupt pending, ready). If interrupt is enabled, an interrupt is then requested. When the data transfer is complete, the memory buffer will be cleared to zero.
- e. When the interrupt occurs, or when the status is sensed as ready for non-interrupt mode, a new character can be set up and enabled, repeating steps (c) through (e). If an interrupt occurs, status will be set back to 00 (idle) when an AKI command is executed. On output operations, the status is also reset by the execution of a CIOJ command with A = 83 (Clear) or A = 08 (Clear and Write).

#### **D. Program Examples**

| 1  | Bood a aborra  | tor from koubo   | ard without interrupt |                                 |
|----|----------------|------------------|-----------------------|---------------------------------|
| ١. |                |                  |                       | LOAD READ DEVICE ADDRESS        |
|    | READ           | LZ               | RADR                  |                                 |
|    |                | LAI              | X '83'                |                                 |
|    |                | CIOJ             |                       | DEVICE IN INPUT MODE            |
|    | WAIT           | STI              | X 'B0'                | CHECK READY AND WAIT TO         |
|    |                | JMP              | WAIT                  | RECEIVE CHARACTER               |
|    |                | LA*              | RBUF                  | INPUT COMPLETE, GET CHARACTER   |
|    |                |                  |                       | FROM MEMORY PAGE 2 BUFFER       |
|    |                | (PROCE           | ESS CHARACTER)        |                                 |
|    |                | •                |                       |                                 |
|    |                | •                |                       |                                 |
|    |                | •                |                       |                                 |
|    |                | JMP              | READ                  | BACK FOR NEXT INPUT             |
|    | RBUF           | DC               | X'0220'               |                                 |
|    | RADR           | DC               | X'20'                 |                                 |
| 2. | Print a charac | ter without inte | errupt                |                                 |
|    | WRITE          | LA               | CHAR                  | STORE PRINT CHAR INTO MEMORY    |
|    |                | UA*              | WBUF                  | DEVICE BUFFER (PAGE 2)          |
|    |                | LZ               | WADR                  | LOAD DEVICE ADDRESS             |
|    |                | LAI              | X'08'                 | INITIATE WRITE, CLEAR STATUS    |
|    |                | CIOJ             |                       |                                 |
|    | WAIT           | STI              | X 'C0'                | WAIT UNTIL CHARACTER            |
|    |                | JMP              | WAIT                  | IS OUTPUT, STATUS 0             |
|    |                | (GET N           | IEXT CHAR TO PRINT)   |                                 |
|    |                |                  |                       |                                 |
|    |                |                  |                       |                                 |
|    |                | •                |                       |                                 |
|    |                | JMP              | WRITE                 | BACK TO PRINT NEXT CHAR         |
|    | WBUF           | DC               | X'0220'               | LOCATION OF WRITE BUFFER IN     |
|    |                |                  |                       | MEMORY (TTY NO. 1)              |
|    | WADR           | DC               | X'A1'                 | WRITE DEVICE ADDRESS (TTY NO.1) |
|    |                |                  |                       |                                 |

| TREAD                          | LAI                                                                                    | X '11'                                                                                                                          | STORE X-ON CHARACTER                                                                                                                                                                                                                                                        |
|--------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | UA*                                                                                    | WBUF                                                                                                                            | IN PAGE 2 DEVICE BUFFER                                                                                                                                                                                                                                                     |
|                                | JST                                                                                    | TWRIT                                                                                                                           | OUTPUT CHAR TO TTY                                                                                                                                                                                                                                                          |
| CLEAR                          | LZ                                                                                     | RADR                                                                                                                            | LOAD DEVICE READ ADDRESS                                                                                                                                                                                                                                                    |
|                                | LAI                                                                                    | X '83'                                                                                                                          | LOAD CLEAR CODE                                                                                                                                                                                                                                                             |
|                                | CIOJ                                                                                   |                                                                                                                                 | CLEAR TTY IN INPUT MODE                                                                                                                                                                                                                                                     |
| WAIT                           | STI                                                                                    | X 'B0'                                                                                                                          | WAIT UNTIL A                                                                                                                                                                                                                                                                |
|                                | JMP                                                                                    | WAIT                                                                                                                            | CHARACTER IS READY                                                                                                                                                                                                                                                          |
|                                | LA*                                                                                    | RBUF                                                                                                                            | GET CHARACTER                                                                                                                                                                                                                                                               |
|                                |                                                                                        | DCESS READ CHARA                                                                                                                |                                                                                                                                                                                                                                                                             |
|                                |                                                                                        |                                                                                                                                 |                                                                                                                                                                                                                                                                             |
|                                |                                                                                        |                                                                                                                                 |                                                                                                                                                                                                                                                                             |
|                                |                                                                                        |                                                                                                                                 |                                                                                                                                                                                                                                                                             |
|                                | JMP                                                                                    | CLEAR                                                                                                                           | NOT LAST CHAR, BACK FOR NEXT                                                                                                                                                                                                                                                |
|                                | LA                                                                                     | X '13'                                                                                                                          | WAS LAST CHARACTER                                                                                                                                                                                                                                                          |
|                                | UA*                                                                                    | WBUF                                                                                                                            | SETUP X-OFF CHAR IN BUFFER                                                                                                                                                                                                                                                  |
|                                | JST                                                                                    | TWRIT                                                                                                                           | AND OUTPUT IT                                                                                                                                                                                                                                                               |
|                                | , (CONT                                                                                | INUE)                                                                                                                           |                                                                                                                                                                                                                                                                             |
|                                |                                                                                        |                                                                                                                                 |                                                                                                                                                                                                                                                                             |
| TWRIT                          | DC                                                                                     | X '0000'                                                                                                                        | ROUTINE TO OUTPUT CHAR TO TT                                                                                                                                                                                                                                                |
|                                | LZ                                                                                     | WADR                                                                                                                            | WRITE DEVICE ADDRESS IN Z                                                                                                                                                                                                                                                   |
|                                | LAI                                                                                    | X '08'                                                                                                                          | CLEAR AND WRITE MASK INTO A                                                                                                                                                                                                                                                 |
|                                | CIOJ                                                                                   |                                                                                                                                 | INITIATE TTY WRITE                                                                                                                                                                                                                                                          |
|                                | JMP*                                                                                   | TWRIT                                                                                                                           | RETURN                                                                                                                                                                                                                                                                      |
| RBUF                           | DC                                                                                     | X '0220'                                                                                                                        |                                                                                                                                                                                                                                                                             |
| WBUF                           | DC                                                                                     | X '0221'                                                                                                                        | ·                                                                                                                                                                                                                                                                           |
| RADR                           | DC                                                                                     | X '20'                                                                                                                          |                                                                                                                                                                                                                                                                             |
| WADR                           | DC                                                                                     | X 'A1'                                                                                                                          |                                                                                                                                                                                                                                                                             |
|                                |                                                                                        |                                                                                                                                 |                                                                                                                                                                                                                                                                             |
| Print or Dur                   |                                                                                        | pe with interrupt<br>TPUT MODE AND EN                                                                                           |                                                                                                                                                                                                                                                                             |
|                                |                                                                                        | IT OT MODE AND EN                                                                                                               |                                                                                                                                                                                                                                                                             |
| (SET UP D                      |                                                                                        | MACK                                                                                                                            |                                                                                                                                                                                                                                                                             |
| -                              | LA                                                                                     | MASK                                                                                                                            |                                                                                                                                                                                                                                                                             |
| (SET UP D                      | LA<br>ONMJ                                                                             |                                                                                                                                 | TO WHICH DEVICE IS CONNECTED                                                                                                                                                                                                                                                |
| (SET UP D                      | LA<br>ONMJ<br>JEI                                                                      | * + 2                                                                                                                           | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT                                                                                                                                                                                                                        |
| (SET UP D                      | LA<br>ONMJ<br>JEI<br>JST                                                               | * + 2<br>TWRIT                                                                                                                  | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR                                                                                                                                                                                     |
| (SET UP D                      | LA<br>ONMJ<br>JEI<br>JST<br>(CO                                                        | * + 2<br>TWRIT<br>NTINUE WITH PROG                                                                                              | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR                                                                                                                                                                                     |
| (SET UP DI                     | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT                                                 | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)                                                                            | ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR<br>RAM                                                                                                                                                                                                              |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1                                  | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR                                                        | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR                                                                                                                                                                                     |
| (SET UP DI                     | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT                                                 | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'                                            | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR<br>RAM                                                                                                                                                                              |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1                                  | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR                                                        | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR<br>RAM                                                                                                                                                                              |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1                                  | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'                                            | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR<br>RAM                                                                                                                                                                              |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1<br>DC                            | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'<br>(GET NEXT CHA                           | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WF<br>RAM<br>R IN PAGE 2 MEMORY BUFFER)<br>R TO OUTPUT)                                                                                                                                |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UN1<br>TO SET UP 1<br>DC<br>LA                      | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'<br>(GET NEXT CHA<br>CHAR                   | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WF<br>RAM<br>R IN PAGE 2 MEMORY BUFFER)<br>R TO OUTPUT)<br>LOAD NEXT OUTPUT CHARACTER                                                                                                  |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1<br>DC<br>LA<br>UA*               | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'<br>(GET NEXT CHA<br>CHAR<br>WBUF           | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WF<br>RAM<br>R IN PAGE 2 MEMORY BUFFER)<br>R TO OUTPUT)<br>LOAD NEXT OUTPUT CHARACTER<br>STORE IT IN DEVICE MEMORY BUF                                                                 |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1<br>DC<br>LA<br>UA*<br>LZI        | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>TIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'<br>(GET NEXT CHA<br>CHAR<br>WBUF<br>X 'A1' | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WE<br>RAM<br>R IN PAGE 2 MEMORY BUFFER)<br>R TO OUTPUT)<br>LOAD NEXT OUTPUT CHARACTER<br>STORE IT IN DEVICE MEMORY BUF<br>WRITE DEVICE ADDRESS INTO Z                                  |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1<br>DC<br>LA<br>UA*<br>LZI<br>LAI | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>FIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'<br>(GET NEXT CHA<br>CHAR<br>WBUF           | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WE<br>RAM<br>R IN PAGE 2 MEMORY BUFFER)<br>R TO OUTPUT)<br>LOAD NEXT OUTPUT CHARACTER<br>STORE IT IN DEVICE MEMORY BUF<br>WRITE DEVICE ADDRESS INTO Z<br>CLEAR AND WRITE CODE BIT INTO |
| (SET UP DI<br>INIT<br>(ROUTINE | LA<br>ONMJ<br>JEI<br>JST<br>(CO<br>UNT<br>TO SET UP 1<br>DC<br>LA<br>UA*<br>LZI        | * + 2<br>TWRIT<br>NTINUE WITH PROG<br>TIL INTERRUPT)<br>NEXT OUTPUT CHAR<br>X '0000'<br>(GET NEXT CHA<br>CHAR<br>WBUF<br>X 'A1' | TO WHICH DEVICE IS CONNECTED<br>ENABLE CPU INTERRUPT<br>CALL ROUTINE TO SET UP FIRST WR<br>RAM<br>R IN PAGE 2 MEMORY BUFFER)<br>R TO OUTPUT)<br>LOAD NEXT OUTPUT CHARACTER<br>STORE IT IN DEVICE MEMORY BUF                                                                 |

DEVICE BECOMES READY. THE INTERRUPT RESULTS IN A FORCED JST TO ADDRESS 0000.

| Location<br>0000 TRAP<br>0002<br>0004 IADR<br>INTR | ORG<br>DC<br>JMP*<br>DAC<br>DU<br>TSAJ<br>UA<br>OFS<br>DL<br>DU<br>AKI |                            | INTERRUPT PROCEDURE AT LOC. 1<br>ADDRESS OF INTERRUPTED INSTRUC-<br>TIONS STORED HERE<br>JMP INDIRECTLY TO INTERRUPT<br>ROUTINE ADDRESS OF INTERRUPT<br>ROUTINE<br>(SAVE Z, A AND S REGISTERS)<br>SAVE S REGISTER<br>SET S REGISTER TO ABSOLUTE PAGE 0<br>SAVE INTERRUPT RETURN ON CURRENT PAGE |
|----------------------------------------------------|------------------------------------------------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                    |                                                                        | DEVICE HAS INTERRU         | /ICE ADDRESS DETERMINE WHAT<br>PTED, WHETHER THERE IS MORE TO<br>FO OUTPUT NEXT CHARACTER                                                                                                                                                                                                       |
|                                                    | JMP                                                                    | EXIT                       | LAST CHARACTER DONE, RETURN                                                                                                                                                                                                                                                                     |
|                                                    |                                                                        |                            |                                                                                                                                                                                                                                                                                                 |
| MORE                                               | JST                                                                    | IWRITE                     | MORE OUTPUT NEXT CHARACTER                                                                                                                                                                                                                                                                      |
| EXIT                                               | DL                                                                     | SVZA                       | (RESTORE Z,A,S, REGISTERS)                                                                                                                                                                                                                                                                      |
|                                                    | OFS                                                                    | X 'ff'                     |                                                                                                                                                                                                                                                                                                 |
| SAVS                                               | ONS                                                                    | **                         |                                                                                                                                                                                                                                                                                                 |
|                                                    | JEI*                                                                   | INTR                       | ENABLE INTERRUPT, RETURN                                                                                                                                                                                                                                                                        |
| SVZA                                               | DC                                                                     | X '0000'                   | INTERRUPT PROGRAM                                                                                                                                                                                                                                                                               |
| 5. Read characte                                   | rs from keyboa                                                         | ard and echo back, without | interrupt.                                                                                                                                                                                                                                                                                      |
| READ                                               | LZI                                                                    | X '20'                     | LOAD DEVICE READ ADDRESS INTO Z                                                                                                                                                                                                                                                                 |
|                                                    | LAI                                                                    | X '83'                     | CLEAR/ENABLE CODE INTO A                                                                                                                                                                                                                                                                        |
|                                                    | CIOJ                                                                   |                            | CLEAR READ STATUS                                                                                                                                                                                                                                                                               |
| WAIT                                               | STI                                                                    | X 'B0'                     | WAIT FOR INPUT READY STATUS                                                                                                                                                                                                                                                                     |
|                                                    | JMP                                                                    | WAIT                       |                                                                                                                                                                                                                                                                                                 |
|                                                    | LA*                                                                    | RBUF                       | GET CHARACTER READ FROM BUFFER                                                                                                                                                                                                                                                                  |
|                                                    | LZI                                                                    | X 'A1'                     | LOAD DEVICE WRITE ADDRESS INTO Z                                                                                                                                                                                                                                                                |
|                                                    | SFI                                                                    | X 'FF'                     | CHECK IF STATUS ZERO (IDLE)                                                                                                                                                                                                                                                                     |
|                                                    | JMP                                                                    | *+4                        | NO                                                                                                                                                                                                                                                                                              |
|                                                    | JMP<br>STI                                                             | REDY                       | YES, GO TO WRITE                                                                                                                                                                                                                                                                                |
|                                                    | JMP                                                                    | X 'C0'<br>* - 2            | WAIT FOR READY STATUS                                                                                                                                                                                                                                                                           |
| REDY                                               | UA*                                                                    | WBUF                       |                                                                                                                                                                                                                                                                                                 |
|                                                    | LAI                                                                    | X '08'                     | STORE READ CHARACTER INTO WRITE BUFFER<br>CLEAR IWRITE CODE INTO A                                                                                                                                                                                                                              |
|                                                    | CIOJ                                                                   |                            | CLEAR STATUS/INITIATE WRITE                                                                                                                                                                                                                                                                     |
|                                                    | JMP                                                                    | READ                       | BACK TO GET NEXT INPUT                                                                                                                                                                                                                                                                          |
| RBUF                                               | DC                                                                     | X '0220'                   | LOCATION OF INPUT BUFFER TTY NO. 1                                                                                                                                                                                                                                                              |
| WBUF                                               | DC                                                                     | X '0221'                   | LOCATION OF OUTPUT BUFFER TTY NO. 1                                                                                                                                                                                                                                                             |

-32-

### E. Teletype Device Buffer Addresses

The following Page 2 memory locations are reserved as read and write buffers for sixteen teletype terminals.

| MEMORY BUFFER ADDRESS (HEX) | TERMINAL                | DEVICE ADDRESS (HEX)<br>WITH PARITY |
|-----------------------------|-------------------------|-------------------------------------|
| 220                         | Teletype No. 1, Input   | 20                                  |
| 221                         | Teletype No. 1, Output  | A1                                  |
| 222                         | Teletype No. 2, Input   | A2                                  |
| 223                         | Teletype No. 2, Output  | 23                                  |
| 224                         | Teletype No. 3, Input   | A4                                  |
| 225                         | Teletype No. 3, Output  | 25                                  |
| 226                         | Teletype No. 4, Input   | 26                                  |
| 227                         | Teletype No. 4, Output  | A7                                  |
| 228                         | Teletype No. 5, Input   | A8                                  |
| 229                         | Teletype No. 5, Output  | 29                                  |
| 22A                         | Teletype No. 6, Input   | 2A                                  |
| 22B                         | Teletype No. 6, Output  | AB                                  |
|                             |                         |                                     |
|                             | Etc.                    |                                     |
| 23E                         | Teletype No. 16, Input  | 3E                                  |
| 23F                         | Teletype No. 16, Output | BF                                  |

### INTERRUPT STATION ASSIGNMENTS

Teletypes may be connected to any interrupt mask station in groups of 4. The standard 3300 connection is:

| Teletypes No. 1 - No. 4  |    | Station 0 , | A register mask = (01) HEX |
|--------------------------|----|-------------|----------------------------|
| Teletypes No. 5 - No. 8  |    | Station 0 , | A register mask = (01) HEX |
|                          | or | Station 1 , | A register mask = (02) HEX |
| Teletypes No. 9 - No. 12 |    | Station 0 , | A register mask = (01) HEX |
|                          | or | Station 2 , | A register mask = (04) HEX |

Etc.

\_

### IX. CONTROL CONSOLE OPERATING PROCEDURES

The control console is located on the front panel of the CPU. The control panel is pictured in Figure 4. The switches and indicators are described in Table 2.

### A. Turn-On Procedures

To turn computer on, set the power switch on the rear panel of the computer to the "ON" position. (All peripheral devices should be turned on after the computer is turned on and turned off before the computer is turned off.) The CLEAR button on the computer console should then be pushed.

### B. Display Contents of Single Memory Location

The following procedure is used to display the contents of a single memory location:

- 1. Depress ENTER mode switch.
- 2. Set data bit switches to binary number of desired page.
- 3. Press B selector button (sets high order byte of BC counter).
- 4. Set data bit switches to binary number of location in page.
- 5. Press C selector button (sets low order byte of BC counter).
- 6. Depress DISPLAY mode switch.
- 7. Press CORE selector button.
- 8. Read contents of memory in MEMORY display section of panel.

### C. Read Consecutive Memory Locations

To read a series of successive memory locations without having to set the location every time, simply follow the single location procedure described for the first byte desired. Then simply continue pressing the CORE button which will cause the program counter to increment by one each time the button is depressed. Remember, when using this method however, that the location shown by the BC display is the address of the *next* logical location and not the address of the byte seen in the MEMORY display.

### D. Modify the Contents of a Single Memory Location

The procedure required to insert or modify data in a single location is as follows:

- 1. Follow procedure for setting BC counter to desired address (Steps 1 through 5 of Section B).
- 2. Depress ENTER mode switch (should already be depressed).
- 3. Set data entry switches to desired bit configuration.
- 4. Press CORE button (this enters data into address).

### E. Modify the Contents of Consecutive Memory Locations

Perform all steps in Section D for first location. Repeat steps 3 and 4 for each byte to be entered. The program counter will automatically be stepped each time the CORE button is depressed.

#### F. Enter or Modify Data in Registers

The following procedure is used to enter or modify data in the registers:

- 1. Depress ENTER mode switch.
- 2. Set data bit switches to desired configuration.
- 3. Press selector button of register desired;

Z for Z-Register A for A-Register S for Status Register M for M-Register B for B-Register C for C-Register

### G. Single Step Program Execution

A stored program may be examined in detail by executing it step by step in the following manner:

- 1. Set BC counter to address of first instruction to be executed.
- 2. Depress RUN mode switch.
- 3. Press STEP button. This will execute one complete instruction.
- The BC counter will show address of next instruction and the register will show their present contents.
- 4. Continue to press STEP button for each desired instruction execution until program end is reached.

### H. Automatic Program Execution

To run a loaded program:

- 1. Set the B and C registers to the desired starting address.
- 2. Depress the RUN mode switch.
- 3. Press the CLEAR button.
- 4. Press GO button. If program is correct, it should run until a halt instruction is encountered.
- 5. To stop program, press the STEP button. This will halt the program.

#### I. Execute Command from Control Panel

To execute command from the console, use the following steps:

- 1. Depress ENTER switch.
- 2. Set the data bit switches to the value of the 2nd byte of the instruction.
- 3. Press the M button. This will enter the 2nd byte of the instruction into the M-register.
- 4. Set the data bit switches to the value of the 1st instruction byte.
- 5. Press EXQ button. This will cause the instruction to be executed.

TABLE 2 – 3300 COMPUTER CONSOLE SWITCHES AND INDICATORS

| ITEM                                                            |                              | ТҮРЕ                            | FUNCTION                                                                                                                                                                        |
|-----------------------------------------------------------------|------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clear Button                                                    | Clear                        | Push Button                     | Initializes Computer and I/O Logic                                                                                                                                              |
| Z-Register Display<br>A-Register Display<br>Status Reg. Display | NAS                          | Bit<br>Configuration            | Shows by light display the contents of the Z-Register.<br>Shows by light display the contents of the Z-Register.<br>Shows by light display the contents of the Status Register. |
| B Counter Display<br>C Counter Display                          | <u>م</u> ں                   | Display Lamps                   | Shows by light display the high-order byte of the program counter.<br>(Memory page of next instruction)<br>Shows by light display the low-order byte of the program counter.    |
| Memory Display                                                  | Memory                       |                                 | (Address within page of next instruction)<br>Shows by light display the last byte of data fetched from memory.                                                                  |
| l/O Light<br>Carry Light                                        | I/O<br>CA                    | On/Off<br>Display Lamp          | Is lit when I/O bus is busy.<br>Is lit when last carry producing instruction resulted in a carry.<br>(Status Register Bit 5)                                                    |
| Load Button                                                     | Load                         | Push                            | Loads first block of program from peripheral device (Enter Mode).                                                                                                               |
| Step Button                                                     | Step                         | Buttons                         | Steps thru memory one consecutive address at a time.                                                                                                                            |
| Execute Button                                                  | EXO                          |                                 | (To single step thru program execution) or stops program execution.<br>Executes a command loaded in data bit switches and the M-register,                                       |
| GO Button                                                       | GO                           |                                 | (Enter Mode).<br>Causes a program to automatically run until a halt (Run Mode).                                                                                                 |
| Run Mode Switch<br>Display Mode Switch                          | Run<br>Display               | Interconnected<br>Push Switches | When depressed, the machine is in Run Mode (Execute Instructions).<br>When depressed, the machine is in Display Mode (Display memory or                                         |
| Enter Mode Switch                                               | Enter                        |                                 | registers).<br>When depressed, the machine is in Enter Mode (Enter data into<br>memory or registers).                                                                           |
| Data Bit Entry<br>Switches                                      | 80,40,20,10<br>8,4,2,1       | On/Off<br>Push Switches         | Used to set bit configuration for data entry.<br>(In position = 1, out position = 0.)                                                                                           |
| Selector Buttons                                                | B, C, Z,<br>A, S, M,<br>Core | Push Buttons                    | Enter or display data into or from corresponding location when pressed.<br>(Into B, C counters, A-Register, Z-Register, S-Register, M-Register or core.) (From Core)            |
|                                                                 |                              | T                               |                                                                                                                                                                                 |

\$

•

۵

-

\*



FIG. 4. WANG 3300 CONSOLE

(This page intentionally left blank.)

2

### APPENDIX A

# LIST OF INSTRUCTIONS BY GROUP

|                                                                                       |                                                                                                                                                                                                                                              |                                                      |                                                                                  |                                                                                  | NO DI                                                                            |                                                                                  | )r<br>                                                                           |                                                                                  |                                                                                  |                                                                                              | 1                                                                                           |                                                                            |
|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| MN                                                                                    |                                                                                                                                                                                                                                              |                                                      | T                                                                                | ·                                                                                | HEXI                                                                             | DECIM                                                                            | AL GF                                                                            | COD                                                                              | E                                                                                |                                                                                              |                                                                                             |                                                                            |
|                                                                                       |                                                                                                                                                                                                                                              |                                                      | A                                                                                | * A                                                                              | с                                                                                | * C                                                                              | + A                                                                              | -A                                                                               | + C                                                                              | -C                                                                                           |                                                                                             |                                                                            |
|                                                                                       |                                                                                                                                                                                                                                              | NO MEMORY<br>REFERENCE                               | ABSOLUTE PAGE<br>DIRECT                                                          | ABSOLUTE PAGE<br>INDIRECT                                                        | CURRENT PAGE<br>DIRECT                                                           | CURRENT PAGE<br>INDIRECT                                                         | ABSOLUTE PAGE<br>INDIRECT, AUTO-INCR.                                            | ABSOLUTE PAGE<br>INDIRECT, AUTO-DECR.                                            | CURRENT PAGE<br>INDIRECT, AUTO-INCR.                                             | CURRENT PAGE<br>INDIRECT, AUTO-DECR.                                                         | INSTRUCTION FORMAT                                                                          | PAGE WHERE DESCRIBED                                                       |
| A.                                                                                    | MEMORY REFERENCE GROUP                                                                                                                                                                                                                       |                                                      |                                                                                  | ,                                                                                |                                                                                  |                                                                                  | <b>1</b>                                                                         |                                                                                  |                                                                                  |                                                                                              | ·                                                                                           |                                                                            |
| BA<br>BO<br>BX<br>INC<br>JEI<br>JMP<br>JST                                            | BOOLEAN AND<br>BOOLEAN OR<br>BOOLEAN EXCLUSIVE OR<br>INCREMENT<br>JUMP, AND ENABLE INTERRUPT<br>JMP<br>JUMP AND STORE LOCATION                                                                                                               | -                                                    | 48<br>58<br>50<br>40<br>54<br>44<br>42                                           | 49<br>59<br>51<br>41<br>55<br>45<br>40                                           | 4A<br>5A<br>52<br>42<br>56<br>46<br>4E                                           | 4B<br>5B<br>53<br>43<br>57<br>47<br>4F                                           |                                                                                  |                                                                                  |                                                                                  |                                                                                              | 1<br>1<br>1<br>1<br>1<br>1                                                                  | 12<br>12<br>13<br>13<br>13<br>13                                           |
| В.                                                                                    | MEMORY REFERENCE GROUP<br>WITH AUTO-INDEX                                                                                                                                                                                                    |                                                      | ,                                                                                |                                                                                  |                                                                                  | 1                                                                                | 1                                                                                |                                                                                  |                                                                                  |                                                                                              |                                                                                             | 13                                                                         |
| AC<br>ADD<br>AMC<br>C<br>DAM<br>DCM<br>DL<br>DU<br>LA<br>LZ<br>UA<br>UAH<br>UZ<br>XMA | ADD WITH CARRY<br>ADD<br>ADD TO MEMORY WITH CARRY<br>COMPARE<br>DOUBLE ADD TO MEMORY<br>DOUBLE COMPARE TO MEMORY<br>DOUBLE LOAD<br>DOUBLE UNLOAD<br>LOAD A<br>LOAD Z<br>UNLOAD A<br>UNLOAD A HIGH DIGIT<br>UNLOAD Z<br>EXCHANGE MEMORY AND A |                                                      | 88<br>80<br>98<br>90<br>A8<br>A0<br>B0<br>B8<br>C0<br>D0<br>C8<br>E8<br>D8<br>E0 | 89<br>81<br>99<br>91<br>A9<br>A1<br>B1<br>B9<br>C1<br>D1<br>C9<br>E9<br>D9<br>E1 | 8A<br>82<br>9A<br>92<br>AA<br>82<br>82<br>8A<br>C2<br>D2<br>CA<br>EA<br>DA<br>E2 | 88<br>83<br>98<br>93<br>AB<br>A3<br>83<br>88<br>C3<br>D3<br>C8<br>E8<br>D8<br>E3 | 8C<br>84<br>9C<br>94<br>AC<br>A4<br>B4<br>BC<br>C4<br>D4<br>CC<br>EC<br>DC<br>E4 | 8D<br>85<br>9D<br>95<br>AD<br>A5<br>85<br>8D<br>C5<br>D5<br>CD<br>ED<br>DD<br>E5 | 8E<br>86<br>9E<br>96<br>AE<br>A6<br>B6<br>BE<br>C6<br>D6<br>CE<br>EE<br>DE<br>E6 | 8F<br>87<br>9F<br>47<br>87<br>87<br>87<br>07<br>07<br>07<br>07<br>07<br>6F<br>EF<br>0F<br>E7 | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 | 14<br>14<br>14<br>14<br>14<br>14<br>15<br>15<br>15<br>15<br>15<br>15<br>15 |
| C. I                                                                                  | MMEDIATE REFERENCE GROUP                                                                                                                                                                                                                     | T T                                                  | ſ                                                                                |                                                                                  | T                                                                                | T                                                                                | <del>-</del>                                                                     |                                                                                  |                                                                                  | T                                                                                            |                                                                                             |                                                                            |
| AI<br>BAI<br>BOI<br>BXI<br>CI<br>DLI<br>LAI<br>LZI                                    | ADD IMMEDIATE<br>BOOLEAN AND IMMEDIATE<br>BOOLEAN OR IMMEDIATE<br>BOOLEAN EXCLUSIVE OR IMMEDIATE<br>COMPARE IMMEDIATE<br>DOUBLE LOAD IMMEDIATE<br>LOAD A IMMEDIATE<br>LOAD Z IMMEDIATE                                                       | 18<br>1D<br>1F<br>1E<br>19<br>1C<br>1A<br>1 <b>B</b> |                                                                                  |                                                                                  |                                                                                  |                                                                                  |                                                                                  |                                                                                  |                                                                                  |                                                                                              | 3<br>3<br>3<br>3                                                                            | 15<br>15<br>16<br>16<br>16<br>16<br>16                                     |

# APPENDIX A - LIST OF INSTRUCTIONS BY GROUP

A-1

2

## APPENDIX A, CONT' – LIST OF INSTRUCTIONS BY GROUP

| N                                                    |                                                                                                                                                                                     |                                              |                         | F                         | IEXID                  | ECIMA                    | LOP                                   | CODE                                  |                                      | * <u></u>                            |                                 | $\square$                                    |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-------------------------|---------------------------|------------------------|--------------------------|---------------------------------------|---------------------------------------|--------------------------------------|--------------------------------------|---------------------------------|----------------------------------------------|
|                                                      |                                                                                                                                                                                     |                                              | A                       | * A                       | с                      | * C                      | + A                                   | - A                                   | + C                                  | - C                                  |                                 |                                              |
|                                                      |                                                                                                                                                                                     | NO MEMORY<br>REFERENCE                       | ABSOLUTE PAGE<br>DIRECT | ABSOLUTE PAGE<br>INDIRECT | CURRENT PAGE<br>DIRECT | CURRENT PAGE<br>INDIRECT | ABSOLUTE PAGE<br>INDIRECT, AUTO-INCR. | ABSOLUTE PAGE<br>INDIRECT, AUTO-DECR. | CURRENT PAGE<br>INDIRECT, AUTO-INCR: | CURRENT PAGE<br>INDIRECT, AUTO-DECR. | INSTRUCTION FORMAT              | PAGE WHERE DESCRIBED                         |
| D                                                    | . SHIFT AND ROTATE GROUP                                                                                                                                                            |                                              |                         |                           |                        |                          |                                       |                                       |                                      | <b>.</b>                             |                                 |                                              |
| RT<br>RTC<br>SH<br>SHC<br>SBJ<br>SBCJ<br>SDJ         | ROTATE A LEFT<br>ROTATE A LEFT WITH CARRY<br>SHIFT A LEFT<br>SHIFT A LEFT WITH CARRY<br>SHIFT BINARY DOUBLE & JUMP<br>SHIFT BIN. DBLE. W/CARRY, JUMP<br>SHIFT DECIMAL DOUBLE & JUMP | 22<br>23<br>20<br>21                         |                         |                           | 08<br>09<br>0A         |                          |                                       |                                       |                                      |                                      | 5<br>5<br>5<br>6<br>6<br>6      | 16<br>16<br>17<br>17<br>17<br>17<br>17<br>17 |
| E.                                                   | CONDITIONAL JUMP GROUP                                                                                                                                                              | - <b>I</b>                                   | 1                       | L                         |                        | L                        | L                                     | I                                     | I                                    |                                      |                                 | L                                            |
| JEQ<br>JGT<br>JLT<br>JNE                             | JUMP IF EQUAL<br>JUMP IF GREATER THAN<br>JUMP IF LESS THAN<br>JUMP IF NOT EQUAL                                                                                                     |                                              |                         |                           | 27<br>24<br>26<br>25   |                          |                                       |                                       |                                      |                                      | 6<br>6<br>6                     | 17<br>17<br>17<br>18                         |
|                                                      | CONDITIONAL SKIP GROUP                                                                                                                                                              | T                                            |                         |                           |                        |                          |                                       |                                       |                                      |                                      |                                 |                                              |
| SAA<br>SMA<br>STA<br>SFA<br>STS<br>SFS<br>STI<br>SFI | SKIP IF ANY A<br>SKIP IF MIXED A<br>SKIP IF TRUE A<br>SKIP IF FALSE A<br>SKIP IF TRUE S<br>SKIP IF FALSE S<br>SKIP IF TRUE I/O<br>SKIP IF FALSE I/O                                 | 12<br>13<br>10<br>11<br>14<br>15<br>30<br>31 |                         |                           |                        |                          |                                       |                                       |                                      |                                      | 4<br>4<br>4<br>4<br>4<br>4<br>4 | 18<br>18<br>18<br>18<br>18<br>18<br>18<br>19 |

A-2

| м                                                                                              | NEMONIC NAME                                                                                                                                                                                                                                                                               |                        |                         | ł                         |                                                    |                          |                                       | CODE                                  |                                      |                                      |                                                          |                                                                                        |
|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-------------------------|---------------------------|----------------------------------------------------|--------------------------|---------------------------------------|---------------------------------------|--------------------------------------|--------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------|
| l                                                                                              |                                                                                                                                                                                                                                                                                            |                        | A                       | * A                       | с                                                  | * C                      | + A                                   | - A                                   | + C                                  | - C                                  |                                                          |                                                                                        |
|                                                                                                |                                                                                                                                                                                                                                                                                            | NO MEMORY<br>REFERENCE | ABSOLUTE PAGE<br>DIRECT | ABSOLUTE PAGE<br>INDIRECT | CURRENT PAGE<br>DIRECT                             | CURRENT PAGE<br>INDIRECT | ABSOLUTE PAGE<br>INDIRECT, AUTO-INCR. | ABSOLUTE PAGE<br>INDIRECT, AUTO-DECR. | CURRENT PAGE<br>INDIRECT, AUTO-INCR. | CURRENT PAGE<br>INDIRECT, AUTO-DECR. | INSTRUCTION FORMAT                                       | PAGE WHERE DESCRIBED                                                                   |
| G                                                                                              | . REGISTER TRANSFER AND<br>MANIPULATION GROUP                                                                                                                                                                                                                                              |                        | <b></b>                 |                           | •                                                  |                          | •                                     | •                                     |                                      | -                                    |                                                          |                                                                                        |
| AZAJ<br>DNJ<br>HLTJ<br>JZA<br>LZAJ<br>NJ<br>PARJ<br>TASJ<br>TSAJ<br>TZAJ<br>XZAJ<br>OFS<br>ONS | ADD Z TO A AND JUMP<br>DOUBLE NOT AND JUMP<br>HALT AND JUMP<br>JUMP VIA Z AND A<br>LOAD FROM Z AND A & JUMP<br>NOT A AND JUMP<br>PARITY AND JUMP<br>TRANSFER A TO S AND JUMP<br>TRANSFER S TO A AND JUMP<br>TRANSFER Z TO A AND JUMP<br>EXCHANGE Z AND A & JUMP<br>OFF STATUS<br>ON STATUS | OF<br>OD<br>OC         |                         |                           | 04<br>03<br>00<br>02<br>01<br>0E<br>06<br>07<br>05 |                          |                                       |                                       |                                      |                                      | 6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>4<br>4 | 19<br>19<br>19<br>19<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20<br>20 |
| н.                                                                                             | INPUT/OUTPUT, AND INTERRUPT GROUP                                                                                                                                                                                                                                                          |                        |                         |                           |                                                    |                          |                                       |                                       |                                      |                                      |                                                          |                                                                                        |
| AKIJ<br>DSIJ<br>ONMJ<br>CIOJ<br>RDDJ<br>WRDJ<br>TIAJ                                           | ACKNOWLEDGE INTERRUPT & JUMP<br>DISABLE INTERRUPT & JUMP<br>ON INTERRUPT MASK & JUMP<br>CONTROL SIGNAL TO I/O & JUMP<br>READ DATA & JUMP<br>WRITE DATA & JUMP<br>TRANSFER I/O TO A & JUMP                                                                                                  |                        |                         |                           | 32<br>33<br>39<br>3C<br>3A<br>3B<br>38             |                          |                                       |                                       |                                      |                                      | 6<br>6<br>6<br>6<br>6                                    | 21<br>21<br>21<br>21<br>21<br>21<br>21<br>21                                           |

# APPENDIX A, CONT' - LIST OF INSTRUCTIONS BY GROUP

A-3

APPENDIX B

# ALPHABETIC LIST OF INSTRUCTIONS

### APPENDIX B – ALPHABETIC LIST OF INSTRUCTIONS

| MN                       | EMONIC NAME                                                                                     |                        |                         |                           | HEXIC                  | ECIM                     | AL OP                                 | CODE                                  |                                      |                                      |                    |                      |
|--------------------------|-------------------------------------------------------------------------------------------------|------------------------|-------------------------|---------------------------|------------------------|--------------------------|---------------------------------------|---------------------------------------|--------------------------------------|--------------------------------------|--------------------|----------------------|
|                          |                                                                                                 |                        | A                       | * A                       | с                      | * C                      | + A                                   | - A                                   | + C                                  | - C                                  |                    |                      |
|                          |                                                                                                 | NO MEMORY<br>REFERENCE | ABSOLUTE PAGE<br>DIRECT | ABSOLUTE PAGE<br>INDIRECT | CURRENT PAGE<br>DIRECT | CURRENT PAGE<br>INDIRECT | ABSOLUTE PAGE<br>INDIRECT, AUTO-INCR. | ABSOLUTE PAGE<br>INDIRECT, AUTO-DECR. | CURRENT PAGE<br>INDIRECT, AUTO-INCR. | CURRENT PAGE<br>INDIRECT, AUTO-DECR. | INSTRUCTION FORMAT | PAGE WHERE DESCRIBED |
| AC<br>ADD<br>AI          | ADD WITH CARRY<br>ADD<br>ADD IMMEDIATE                                                          | 10                     | 88<br>80                | 89<br>81                  | 8A<br>82               | 8B<br>83                 | 8C<br>84                              | 8D<br>85                              | 8E<br>86                             | 8F<br>87                             | 2                  | 14<br>14             |
| AKIJ<br>AMC<br>AZAJ      | ACKNOWLEDGE INTERRUPT & JUMP<br>ADD TO MEMORY WITH CARRY<br>ADD Z TO A AND JUMP                 | 18                     | 98                      | 99                        | 32<br>9A<br>04         | 9B                       | 9C                                    | 9D                                    | 9E                                   | 9F                                   | 3<br>6<br>2<br>6   | 15<br>21<br>14<br>19 |
| BA<br>BAI                | BOOLEAN AND<br>BOOLEAN AND IMMEDIATE                                                            | 1D                     | 48                      | 49                        | 4A                     | 4B                       |                                       |                                       |                                      |                                      | 1<br>3             | 12<br>15             |
| BO<br>BOI                | BOOLEAN OR<br>BOOLEAN OR IMMEDIATE                                                              | 1F                     | <sup>·</sup> 58         | 59                        | 5A                     | 5B                       |                                       |                                       |                                      |                                      | 1<br>3             | 12<br>15             |
| BX<br>BXI                | BOOLEAN EXCLUSIVE OR<br>BOOLEAN EXCLUSIVE OR IMM.                                               | 1E                     | 50                      | 51                        | 52                     | 53                       |                                       |                                       |                                      |                                      | 1                  | 13<br>16             |
| C<br>CI                  | COMPARE<br>COMPARE IMMEDIATE                                                                    | 19                     | 90                      | 91                        | 92                     | 93                       | 94                                    | 95                                    | 96                                   | 97                                   | 3<br>2<br>3        | 14<br>16             |
| CIOJ<br>DAM<br>DCM<br>DL | CONTROL SIGNAL TO I/O & JUMP<br>DOUBLE ADD TO MEMORY<br>DOUBLE COMPARE TO MEMORY<br>DOUBLE LOAD |                        | A8<br>A0<br>B0          | A9<br>A1<br>B1            | 3C<br>AA<br>A2<br>B2   | AB<br>A3<br>B3           | AC<br>A4<br>B4                        | AD<br>A5<br>B5                        | AE<br>A6<br>B6                       | AF<br>A7<br>B7                       | 6<br>2<br>2<br>2   | 21<br>14<br>14<br>14 |
| DLI<br>DNJ<br>DSIJ<br>DU | DOUBLE LOAD IMMEDIATE<br>DOUBLE NOT AND JUMP<br>DISABLE INTERRUPT & JUMP<br>DOUBLE UNLOAD       | 1C                     | В8                      | В9                        | 03<br>33<br>BA         | BB                       | вс                                    | ВD                                    | BE                                   | BF                                   | 3<br>6<br>6<br>2   | 16<br>19<br>21<br>15 |
| HLTJ<br>INC<br>JEI       | HALT AND JUMP<br>INCREMENT<br>JUMP AND ENABLE INTERRUPT                                         |                        | 40<br>54                | 41                        | 00<br>42<br>56         | 43<br>57                 |                                       |                                       | DL                                   | 51                                   | 6<br>1<br>1        | 19<br>13<br>13       |
| JEQ<br>JGT<br>JLT        | JUMP IF EQUAL<br>JUMP IF GREATER THAN<br>JUMP IF LESS THAN                                      |                        |                         | 50                        | 27<br>24<br>26         | 57                       |                                       |                                       |                                      |                                      | 6<br>6<br>6        | 17<br>17<br>17<br>17 |
| JMP                      | JUMP<br>JUMP IF NOT EQUAL                                                                       |                        | 44                      | 45                        | 20<br>46<br>25         | 47                       |                                       |                                       |                                      |                                      | 0<br>1<br>6        | 17<br>13<br>18       |
| JST<br>JZA               | JUMP AND STORE LOCATION<br>JUMP VIA Z AND A                                                     | 0F                     | 4C                      | 4D                        | 4E                     | 4F                       |                                       |                                       |                                      |                                      | 1<br>6             | 13<br>19             |
| LA<br>LAI                | LOAD A<br>LOAD A IMMEDIATE                                                                      | 1A                     | C0                      | C1                        | C2                     | С3                       | C4                                    | C5                                    | C6                                   | C7                                   | 2<br>3             | 15<br>16             |

B-1

2

|                                                                                                                                                                                                                                                                                | APPENDIX B, CONT' –                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                        | BEIIC                   |                           |                                                                                                                        | DECIM                    |                                       |                                       | -                                    |                                      | Τ                  |                                                                                                                                                                                  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------|---------------------------------------|---------------------------------------|--------------------------------------|--------------------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                        | <u> </u>                | <u>γ</u>                  |                                                                                                                        |                          |                                       | T                                     | :<br>                                | 1                                    | 4                  |                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                        | A                       | * A                       | С                                                                                                                      | * C                      | + A                                   | - A                                   | + C                                  | – C                                  |                    |                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NO MEMORY<br>REFERENCE                                                                 | ABSOLUTE PAGE<br>DIRECT | ABSOLUTE PAGE<br>INDIRECT | CURRENT PAGE<br>DIRECT                                                                                                 | CURRENT PAGE<br>INDIRECT | ABSOLUTE PAGE<br>INDIRECT, AUTO-INCR. | ABSOLUTE PAGE<br>INDIRECT, AUTO-DECR. | CURRENT PAGE<br>INDIRECT, AUTO-INCR. | CURRENT PAGE<br>INDIRECT, AUTO-DECR. | INSTRUCTION FORMAT | PAGE WHERE DESCRIBED                                                                                                                                                             |
| LZ<br>LZAJ<br>LZI<br>NJ<br>OFS<br>ONMJ<br>ONS<br>PARJ<br>RDDJ<br>RT<br>RTC<br>SAA<br>SBCJ<br>SBJ<br>SDJ<br>SFA<br>SBJ<br>SDJ<br>SFA<br>SFI<br>SFS<br>SH<br>SFS<br>SH<br>SFS<br>SH<br>SFS<br>SH<br>STA<br>STI<br>STS<br>TASJ<br>TIAJ<br>TSAJ<br>TZAJ<br>UA<br>UAH<br>UZ<br>WRDJ | LOAD Z<br>LOAD FROM Z AND A & JUMP<br>LOAD Z IMMEDIATE<br>NOT A AND JUMP<br>OFF STATUS J<br>ON INTERRUPT MASK & JUMP<br>ON STATUS<br>PARITY & JUMP<br>READ DATA AND JUMP<br>ROTATE A LEFT<br>ROTATE A LEFT WITH CARRY<br>SKIP IF ANY A<br>SHIFT BIN. DOUBLE W/CARRY, JUMP<br>SHIFT BIN. DOUBLE & JUMP<br>SHIFT DEC. DOUBLE & JUMP<br>SHIFT DEC. DOUBLE & JUMP<br>SKIP IF FALSE A<br>SKIP IF FALSE A<br>SKIP IF FALSE S<br>SHIFT A LEFT<br>SHIFT A LEFT WITH CARRY<br>SKIP IF TRUE A<br>SKIP IF TRUE A<br>SKIP IF TRUE S<br>TRANSFER A TO S & JUMP<br>TRANSFER S TO A & JUMP<br>TRANSFER Z TO A & JUMP<br>UNLOAD A<br>UNLOAD A HIGH DIGIT<br>UNLOAD Z<br>WRITE DATA & JUMP | 1B<br>0D<br>0C<br>22<br>23<br>12<br>11<br>31<br>15<br>20<br>21<br>13<br>10<br>30<br>14 | D0<br>C8<br>E8<br>D8    | D1<br>C9<br>E9<br>D9      | D2<br>0B<br>02<br>39<br>01<br>3A<br>09<br>08<br>0A<br>09<br>08<br>0A<br>0<br>8<br>0A<br>0<br>7<br>CA<br>EA<br>DA<br>3B | D3<br>CB<br>EB<br>DB     | D4<br>CC<br>EC<br>DC                  | D5<br>CD<br>ED<br>DD                  | D6<br>CE<br>EE<br>DE                 | D7<br>CF<br>EF<br>DF                 | -                  | 16<br>20<br>20<br>21<br>20<br>20<br>21<br>16<br>16<br>18<br>17<br>17<br>17<br>18<br>19<br>18<br>17<br>17<br>18<br>18<br>20<br>21<br>20<br>20<br>20<br>21<br>15<br>15<br>15<br>21 |
| XMA<br>XZAJ                                                                                                                                                                                                                                                                    | EXCHANGE MEMORY AND A<br>EXCHANGE Z AND A & JUMP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                        | E0                      | E1                        | E2<br>05                                                                                                               | E3                       | E4                                    | E5                                    | E6                                   | E7                                   | 2                  | 15<br>20                                                                                                                                                                         |

### APPENDIX B, CONT' – ALPHABETIC LIST OF INSTRUCTIONS

-45-

B-2

(This page intentionally left blank.)

### APPENDIX C

### TABLE OF INSTRUCTIONS BY OP CODE

.

### APPENDIX C - TABLE OF INSTRUCTIONS BY OP CODE

LOW ORDER HEX DIGIT OF OP CODE BYTE

| $\backslash$ | 0        | 1    | 2    | 3    | 4    | 5    | 6    | 7          | 8    | 9      | А     | В    | с    | D   | E    | F   |  |
|--------------|----------|------|------|------|------|------|------|------------|------|--------|-------|------|------|-----|------|-----|--|
| 0            | HLTJ     | PARJ | INJ  | DNJ  | AZAJ | XZAJ | TSAJ | TZAJ       | SBJ  | SBCJ   | SDJ   | LZAJ | ONS  | OFS | TASJ | JZA |  |
| 1            | STA      | SFA  | SAA  | SMA  | STS  | SFS  |      |            | AI   | СІ     | LAI   | LZI  | DLI  | BAI | BXI  | воі |  |
| 2            | SH       | SHC  | RT   | RTC  | JGT  | JNE  | JLT  | JEQ        |      |        |       |      |      |     |      |     |  |
| 3            | STI      | SFI  | ΑΚΙJ | DSIJ |      |      |      |            | TIAJ | ONMJ   | RDDJ  | WRDJ | CIOJ |     |      |     |  |
| 4            |          | I î  | NC   | >    | ←    | JI   | MP   |            | +    | — ВА - |       |      | ←    | JST |      |     |  |
| 5            |          | —— В | х    | >    | ←    | J    | EI   |            | *    | — во-  |       | >    |      |     |      |     |  |
| 6            |          |      |      |      |      |      |      |            |      |        |       |      |      |     |      |     |  |
| 7            |          |      |      |      |      |      |      |            |      |        |       |      |      |     |      |     |  |
| 8            | <b>*</b> | A    | DD   |      |      |      |      |            | AC   |        |       |      |      | I   |      |     |  |
| 9            | -        |      | С    |      |      |      |      | <b>*</b> . |      |        | - AMC |      |      |     |      |     |  |
| A            | -        | D    | СМ — |      |      |      |      | ←          |      |        | - DAM |      |      |     |      |     |  |
| В            | -        | C    | )L   |      |      |      |      | <b>~</b>   |      |        | —- DU |      |      |     |      |     |  |
| С            | <b>~</b> | L    | Α —— |      |      |      |      |            |      |        | UA    |      |      |     |      |     |  |
| D            |          | L    | z    |      |      |      |      | ← UZ       |      |        |       |      |      |     |      |     |  |
| E            |          | ←XMA |      |      | >    | UAH  |      |            |      |        |       |      |      |     |      |     |  |
| F            |          |      |      |      |      |      |      |            |      |        |       |      |      |     |      |     |  |

C-1

### APPENDIX D

.

# WANG 3300 ASCII CHARACTER CODE SET

-

### APPENDIX D – WANG 3300 ASCII CHARACTER CODE SET

|         |   |   | 7 | 0                  | 0             | 0            | 0 | 1 | 1 | 1 | 1 |
|---------|---|---|---|--------------------|---------------|--------------|---|---|---|---|---|
| <b></b> | • |   | 6 | 0                  | 0             | 1            | 1 | 0 | 0 | 1 | 1 |
| 4       | 3 | 2 | 1 | 0                  | 1             | 0            | 1 | 0 | 1 | 0 | 1 |
| 0       | 0 | 0 | 0 | Null               |               | (Space)      | 0 | @ | Р |   |   |
| 0       | 0 | 0 | 1 |                    | X - ON        | !            | 1 | А | Q |   |   |
| 0       | 0 | 1 | 0 |                    |               |              | 2 | В | R |   |   |
| 0       | 0 | 1 | 1 |                    | X - OFF       | #            | 3 | С | S |   |   |
| 0       | 1 | 0 | 0 |                    |               | \$           | 4 | D | Т |   |   |
| 0       | 1 | 0 | 1 |                    |               | %            | 5 | E | U |   |   |
| 0       | 1 | 1 | 0 |                    |               | &            | 6 | F | v |   |   |
| 0       | 1 | 1 | 1 | Bell               |               | ,<br>(Apos)  | 7 | G | w |   |   |
| 1       | 0 | 0 | 0 | Back<br>Space      |               | (            | 8 | н | x |   |   |
| 1       | 0 | 0 | 1 | Tab                |               | )            | 9 | I | Y |   |   |
| 1       | 0 | 1 | 0 | Line<br>Feed       |               | *            | : | J | z |   |   |
| 1       | 0 | 1 | 1 | Clear<br>Tab       | ESC           | +            | ; | к | [ |   |   |
| 1       | 1 | 0 | 0 | SET<br>TAB         | $\leq$        | ,<br>(Comma) | < | L | ١ |   |   |
| 1       | 1 | 0 | 1 | CARRIAGE<br>RETURN | +             | –<br>(Minus) | = | м | ] |   |   |
| 1       | 1 | 1 | 0 | Upper<br>Shift     | ≥             |              | > | N | ¢ |   |   |
| · 1     | 1 | 1 | 1 | Lower<br>Shift     | o<br>(Degree) | 1            | ? | о | ← |   |   |



836 North Street Tewksbury, Massachusetts 0187 TELEPHONE (617) 851-7311 TWX 710-343-6769

#### WANG EUROPE, S.A.

Rue Anatole France 115-121 1030 Brussels, Belgium TELEPHONE 15.48-01/02/03

#### WANG ELECTRONICS LTD.

40-44 High Street Northwood, Middlesex, England TELEPHONE Northwood 27677

#### WANG LABORATORIES GMBH

Moselstrasse No. 4 Frankfurt 6000 West Germany TELEPHONE (611) 23-00-49

#### WANG SKANDINAVISKA AB

Drottninggatan 80 4th Floor Stockholm, Sweden TELEPHONE 21.07.15

#### WANG LABORATORIES (CANADA) LTD

180 Duncan Mill Road Don Mills, Ontario TELEPHONE (416) 449-7890 TELEX 06-21-7549

#### WANG LABORATORIES (TAIWAN) LTD.

9, Sec. 5, Nanking East Road Taipei, Taiwan TELEPHONE 77.96.19 or 71.35.78

#### PHI COMPUTER SERVICES, INC.

800 Massachusetts Avenue Arlington, Massachusetts 02174 TELEPHONE (617) 648-8550

### WANG MEDICAL SYSTEMS, INC.

836 North Street Tewksbury, Massachusetts 01876 TELEPHONE (617) 851-7311 TWX 710-343-6769 TELEX 94-7421

#### WANG NEDERLAND N.V.

Damstraat 2 Utrecht, Netherlands TELEPHONE 030-930947

#### WANG PACIFIC LTD.

61, King Yip Street, 1st floor Kwun Tong, Kowlaon TELEPHONE K-444536



a

700-0365