# DATANET-30 Programming Reference Manual 



## APPENDIX L

# DATANET-30 PROGRAMMING <br> REFERENCE MANUAL 

THE CONTROLLER SELECTOR AND GE 200 SERIES PERIPHERAL EQUIPMENT (CSU931)

CPB-1019

October 1965

## PREFACE

This manual covers the aspects of programming the General Electric DATANET-30 Communications Processor. The assumptions are that the individual doing the programming is already familiar with programming techniques, and has a comprehensive understanding of the communications system in which the DATANET-30 is operating.

References to be used in addition to this manual are the DATANET-30 system manual and the glossary of terms of the X3.3.2 committee of the American Standards Association. Familiarity with these documents is important before proceeding into the actual programming of the DATANET-30.

This manual supersedes CPB-1019, dated January 1964.

Comments on this publication may be addressed to Technical Publications, Computer Department, General Electric Company, P. O. Box 2961, Phoenix, Arizona, 85002.

## CONTENTS

Page
I. GENERAL DESCRIPTION
The Memory Unit ..... I-1
The Buffer Selector ..... I-2
The Bit Buffer Unit Module (BBU) ..... I-2
General ..... I-2
Bit Buffer Channel (BBC) ..... I-2
The Character/Word Buffer Unit (CWU930) ..... I-3
The Character Buffer Channel (CBC930) ..... I-3
The Word Buffer Channel (WBC930) ..... I-4
The Character/Word Buffer Unit (CWU931) ..... I-4
General ..... I-4
The Character Buffer Channel ( $\dot{C B C} \dot{9} \dot{3} 1$ ) ..... I-4
The CIU-930 Computer Interface Unit ..... I-
The CIU-931 Computer Interface Unit ..... I-6
The Controller Selector Unit (CSU931) ..... I-7
Data Communications Processor ..... I-7
Data Flow ..... I-7
Detailed Block Diagram ..... I-10
Description of Registers ..... I-10
Instruction Cycles ..... I-17
Perforated Tape Reader ..... I-22
Hardware Load ..... I-22
The Elapsed Time Clock (Q-counter) ..... I-23
The Q-counter and Hardware Load ..... I-23
Instruction Formats ..... I-2 4
Nongeneral Instructions ..... I-24
General Instructions ..... I-25
Representation of Information in Memory ..... I-26
Alphanumeric Data ..... I-2 6
Numeric Data ..... I-27
Double Length Binary Data ..... I-29
II. INSTRUCTION REPERTOIRE
Internal Instructions ..... II-1
Pseudo-Operations ..... II-2
Load Instructions ..... II-3
Store Instructions ..... II-5
Arithmetic Instructions ..... II-6
Logical Instructions ..... II-8
Register Transfer Instructions ..... II-12
Branch Instructions ..... II-16
Macro-Instructions ..... II-18
Special Instructions ..... II-22
Buffer Selector Instructions ..... II-25
The Option Module Instructions ..... II-2 6
Page
III. ADDRESSING MEMORY
General Description ..... III-1
Detailed Description ..... III-2
Program Bank Addressing ..... III-2
Common Data Bank Addressing ..... III-4
Channel Table Addressing ..... III-4
Indirect Addressing ..... III-5
Indexing ..... III-6
Subroutine Linkage ..... III-7
Memory Addressing Using the Assembly Program ..... III-8
IV. CONTROL CONSOLE
The Mode Select Pushbutton Switches ..... IV -1
The SET A, B, C, and P Button ..... IV -1
The INSERT MEMORY Button ..... IV-2
The DISPLAY MEMORY Button ..... IV-2
The ERROR Light and Buzzer ..... IV-2
Power-On Sequence ..... IV-3
V. PROGRAMMING CONSIDERATIONS
Programming the Buffers ..... V-1
Service Rate ..... V-1
Basic Program Cycle ..... V-1
Functional Sequence ..... V-4
Programming Conventions ..... V-6
Buffer Operations ..... V-7
Bit Buffer Channel ..... V-7
Character Buffer Channel (CBC) ..... V-21
Word Buffer Channel (BC) ..... V-25
Programming the Perforated Tape Reader ..... V-32
Reading Perforated Tape Under Program Control ..... V-32
Hardware Load and the Perforated Tape Reader ..... V-35
Hardware Load Format ..... V-38
Assembly Programs ..... V-39
Utility Routines ..... V-39
Programming Aids ..... V-40


## IUUSTRATIONS

Figure ..... Page

1. Computer Interface Block Diagram ..... I-5
2. Basic Block Diagram ..... I-8
3. Basic Block Diagram ..... I-9
4. Detailed Block Diagram ..... I-11
5. Detailed Block Diagram DATANET-30 Instruction Cycle ..... I-17
6. Detailed Block Diagram DATANET-30 Load A (LDA) ..... I-18
7. Detailed Block Diagram DATANET-30 Store B (STB) ..... I-19
8. Detailed Block Diagram DATANET-30 Add Memory to A (AMA). ..... I-20
9. Detailed Block Diagram DATANET-30 Shift Right 1
10. Receive Lines to B-register (SR1 BR, B) ..... I- 21
Perforated Tape Reader ..... I-28
11. Control Console Switches ..... IV-4
12. General Timing Diagram ..... V-3
13. Relative Timing for Scanning Buffers ..... V-4
14. Data Flow Functional Block Diagram ..... V-5
15. Hardware Scan Block Diagram ..... V-17
16. CBC Receive Timing Diagram ..... V-23
17. CBC Transmit Timing Diagram ..... V-24
18. WBC Receive Timing Diagram ..... V-28
19. WBC Transmit Timing Diagram ..... V-29


DATANET - 30
.

## I. GENERAL DESCRIPTION

The DATANET-30 is a single address, stored program, special purpose, digital computer which operates primarily in a straight binary mode but processes both alphanumeric and binary information. It performs computation (arithmetic) operations and acts as central control for the DATANET-30 system. Programs to be executed and data to be operated upon are stored in a magnetic core memory where each core represents a binary digit (bit) of an instruction or data word. A word is the basic unit of addressable information in the memory.

The overall function is to simultaneously receive, store, process and transmit data in a communications oriented system.

The system can accommodate any standard transmission speed ranging from 45 to 3,000 bits per second. The basic DATANET-30 controls the transmission of digital data information over normal common carrier facilities to either another DATANET-30, a DATANET-15, a DATANET-600, or any of the standard Teletype terminal units in use, such as the Automatic Send Receive (ASR), Keyboard Send Receive (KSR), or Receive Only (RO) units.

The instruction repertoire contains 78 basic instructions. The hardware is capable of executing up to 144,000 instructions per second.

Figure 3 shows the major functional sections of the DATANET-30 Communication System, consisting of:

1. The buffer selector and associated buffer units
2. The controller selector and associated high-speed controllers
3. The DATANET-30 Data Communications Processor.

## THE MEMORY UNIT

The DATANET-30 uses a magnetic core memory to store program instructions, alphanumeric information, and binary data. Standard memory units are available in 4096, 8192 and 16,384 word sizes. Each word consists of 18 bits. An 18 -bit word can contain three 6 -bit characters, two 8-bit characters, or one machine instruction.

The memory cycle time is 6.94 microseconds for a read-restore cycle, a clear-write cycle, or a read-compute-write cycle.

During a read-restore cycle, 18 bits of information are read from the memory and transferred to the data communications processor.

During a clear-write cycle, 18 bits of information are transferred from the data communications processor and written into memory.

During a read-compute-write cycle, 18 bits of information are read from memory, changed by the data communications processor, and then the new information is written back into memory.

## THE BUFFER SELECTOR

All units connected directly to the buffer selector are referred to as "buffers." Information flows via the buffers and the buffer selector to and from the data communications processor.

The buffer selector contains 128 channels numbered 0 to 127. Each buffer occupies one channel address of the buffer selector, whether the channel is simplex, half-duplex, or full-duplex. The buffer selector channel address for each buffer is established by the wiring of an address plug. The address can be changed or new addresses (buffers) added by changing the existing plug wiring or inserting a new address plug. The channel addresses in any given buffer module need not be sequential. However the addresses for bit buffers must be sequential. Channel 0 is always reserved for the paper tape reader.

## THE BIT BUFFER UNIT MODULE (BBU)

## General

The bit buffer units contain a control section and up to ten bit buffer channels.

The bit buffer unit control section contains hardware that is common to all the bit buffer channels in the module. A bit buffer module may terminate from 1 to 10 full-duplex or half-duplex transmission lines which are all operating at the same bit rate.

## Bit Buffer Channel (BBC)

The function of a bit buffer channel is to transmit data to and receive data from a remote terminal on a bit basis.

Each bit buffer channel in a module is assigned a buffer selector address by the address plug for that module. The address applies to both the receive and the transmit section. The addresses for the bit buffers in a module can be whatever is desired for the system and they need not
be sequential. Thus, a bit buffer may be added to a module and given an address without disturbing the existing address arrangement. However, the addresses of all bit buffers must be sequential.

The bit buffer provides the interface between the DATANET-30 and one full-duplex, half-duplex, or simplex transmission line on a bit basis. Usually system considerations will limit the bit buffer lines to an operating speed of less than 300 bits per second. Standard teletype rates of $45,50,56.26,75,110$, and 150 bits per second are selected with the timing connector plug. The selected bit rate will apply to all the bit buffer channels physically located in that module. If more than one bit rate is in use in an existing system, the different bit rates must be terminated in separate bit buffer modules. Since the bit buffer channel communicates with the remote terminals on a bit basis, the code level can be different in the separate bit buffers. The code level of individual bit buffers is recognized by the program.

## THE CHARACTER/WORD BUFFER UNIT (CWU930)

The character/word buffer unit module can contain either two character buffer channels (CBC), two word buffer channels (WBC), or one of each. Each character/word buffer has a control section.

## The Character Buffer Channel (CBC930)

The function of a character buffer is to transmit data to and receive data from a remote terminal on a character basis. Transmission to and from a remote terminal is on a bit serial, asynchronous basis.

The character buffer control unit contains hardware to control the bit rate and character length. The character buffers in a module may be operating at different bit rates and different character lengths. The standard bit rates are $300,600,1200,1800,2000,2400$, or 3000 bits per second. The code level may be any one of $5-, 6-$, $7-$, or 8 -level codes with start-stop bit synchronization. Both the bit rate and code level (character length) may be selected or changed by means of a connector for each buffer. The timing connector plug is available in any one of the standard bit rates. The code level plug is available for $5-, 6-, 7-$, or 8 -level codes. Thus, by changing plug connectors, both bit rate and code level may be changed to suit changing remote terminal operations.

One character buffer channel provides the interface between the DATANET- 30 and a halfduplex transmission line.

Usually, a character buffer channel operates with a character oriented device at speeds higher than 300 bits per second. At this higher rate it is necessary to have some kind of digital subset (DSS) on each end of the transmission line.

## The Word Buffer Channel (WBC930)

The function of a word buffer channel is to transmit data to and receive data from another DATANET-30 or a DATANET-600.

The word buffer can operate at the same standard bit rates as the character buffer. The bit rate is established by a timing connector plug. The word length is not variable. It is established at 18 bits for a DATANET- 30 word, plus one parity bit and one control bit, giving a total of 20 bits per word. This word length is established by a 20 -bit code level connector. The DATANET600 word is similarly established at 14 bits.

## THE CHARACTER/WORD BUFFER UNIT (CWU931)

## General

The character/word buffer unit module can contain two character buffer channels (CBC). Each CWU occupies one module space.

## The Character Buffer Channel (CBC931)

The function of a character buffer is to transmit data to and receive data from a UNIV AC 1004 remote terminal or similar equipment on a character basis. Transmission to and from the remote terminal is on a bit serial synchronous basis. One character buffer provides the interface between the DATANET-30 and a half-duplex transmission line. The character buffer channel is synchronized by the digital subset connected to the transmission line.

The character buffer control unit contains hardware adaptable to the character length. The character buffers in a module may be operating at different character lengths and speeds. Speed is determined by the subset and remote terminal. It is necessary to have a synchronous digital subset on each end of the transmission line. The standard bit rates are 2000, 2400 bits per second.

The code level may be from 5 to 16 bit codes with character synchronization (no start/stop bits). The code level (character length) is selected or changed by a code level connector for each CBC. By changing code level connectors, the code level may be changed to meet changing remote terminal operations or programming techniques.

The code level connector defines the bit configuration of the synchronizing character, the number of bits per character and where the receive lines will enter the data bits into the working register (A- or B-register), that is, the high- or low-order position of the A- or B-register. The code level connector can be arranged to accept two characters ( 8 level) before setting the receive flag. Also, the code level connector can be arranged to mask off a bit.

## THE CIU930 COMPUTER INTERFACE UNIT

For those systems requiring a combination data communication-information processing system, a CIU 930 Computer Interface Unit is provided. This unit permits attaching a DATANET-30 data communication processor to a General Electric Compatibles/200 Information Processing System. With this combination, the DATANET-30 is responsible for the communications half of the system, while the GE-200 Series system is responsible for the data processing.

Twenty-one-bit words are transferred in parallel to and from the information processing system via the Computer Interface Unit. The memory address is also transferred in parallel from the address register in the CIU930 to the processing system prior to the data transfer.

The CIU allows addressing any location in the central processor memory. The CIU 930 connects into any channel of the DATANET-30 buffer selector in the same manner as any other buffer. The buffer selector address of the CIU930 is specified by the wiring of the buffer selector address plug for the module. There is no DATANET-30 hardware restriction on the number of CIU's which may be used, other than the physical space occupied. On processing system side the CIU 930 can connect into any GE-200 Series priority control channel. See Figure 1.


Figure 1. Computer Interface Block Diagram

The CIU can be tested for a busy/not-busy condition by the DATANET-30. This busy/not-busy test tells the DATANET-30 whether or not it can put data into the data and address registers of the CIU930, and whether or not it can take data from the data register.

The DATANET-30 communicates with the GE-200 Series central processor only on a memory interrupt basis. The DATANET-30, under program control, puts data and address information into the CIU to interrupt the central processor. The central processor cannot control the DATA-NET-30, as is possible with other peripheral equipment. Since both the DATANET-30 and the central processor have stored programs and since the DATANET-30 operates in real time, the DATANET-30 must have control and priority between the two programs. For additional information, refer to Appendix $E$ of this manual.

When the information processing system has data for the DATANET-30, it will set a flag in a memory location of the central processor, which is periodically interrogated by the DATANET30. When the DATANET-30 is ready to accept the traffic, a control instruction is sent to the central processor, the processing system program is interrupted, and the traffic is transmitted to the DATANET-30. The DATANET-30 then processes the traffic and sends it on to the designated remote station. Thus the information processing system and the DATANET-30 exchange control words, instructions, and traffic under control of the DATANET-30.

## THE CIU931 COMPUTER INTERFACE UNIT

The CIU931 Computer Interface Unit is an 18-bit buffer within the DATANET-30 that provides the connecting link between the DATANET-30 and a General Electric Compatibles/400 or 600 system. The CIU connects into the buffer selector of the DATANET-30 and one standard input/ output channel of a GE-400 or -600 Series system. The channel may be either a word channel or a character channel. Direction of data flow is under program control.

The transfer rate is up to 39,000 characters per second or 13,000 DATANET- 30 words per second. The actual transfer rate will be determined by the DATANET-30 program.

The CIU permits both the DATANET-30 and the GE-400 or -600 Series computer to execute programs concurrently with the transfer of data in either direction. When the CIU accepts data from a GE-400 or -600 Series computer, a signal is generated to indicate to the DATANET-30 program that service is required. The data will be stored in the CIU until the DATANET-30 program is able to service the request. Conversely, the CIU will request service from the GE-400 or -600 Series computer and store the request until the latter can respond.

All data transferred through the CIU931 is parity checked for accuracy. In the event of a parity error, an appropriate signal is generated by the CIU. For additional information, refer to Appendix D of this manual.

## THE CONTROLLER SELECTOR UNIT (CSU931)

The Controller Selector Unit permits connecting GE-200 Series peripherals to the DATANET-30.

Eight peripheral equipment controllers may be connected to the controller selector enabling the transfer of data to and from the DATANET-30 on a memory interrupt basis. The eight controllers, numbered 0-7, operate on a priority basis, with each controller assigned a channel plug number. The controller on channel 0 has the highest priority and channel 7 the lowest. Any controller except the printer controller may be assigned to any channel plug.

The following controller selector channel priority assignment is made, assuming that all types of controllers need to be connected.

Channels 0-1

Channels 2,3,4,5

Channels 6,7

Single-access disc storage unit controller. Dual-access disc storage unit controller. Each controller may have 4 disc storage units.

Magnetic tape controller. Each controller may have 8 tape units.

High-speed printer controller. Each controller may have 1 printer.

## DATA COMMUNICATIONS PROCESSOR

## Data Flow

The DATANET-30 is organized on an 18 -bit parallel, bus logic arrangement. Figure 2 is a basic diagram of the principal internal working units of the communications processor. The data is transferred from memory to the arithmetic unit or from a working register through the lower data bus and the Y-register to the arithmetic unit. The Y-register holds the data while it is being processed by the arithmetic unit. After the data has been processed by the arithmetic unit, it is sent to the $Z$-drivers, which are a common distribution center for all data coming from the arithmetic unit and going to a working register, memory, control unit, or an input/output channel. The plus, zero, and even flip-flops also connected to the Z-drivers will reflect the branch conditions of any data sent through the Z-drivers. For example, if a word coming from memory and going to a working register is plus, nonzero and odd, the branch conditions would be plus, nonzero, and odd. If the data word was all zeros the branch conditions would be plus, zero, and even. From the Z-drivers the data flows along the upper data bus to a working register, an input/output channel, or to the memory, according to the instruction currently being executed.

In Figure 3, the buffer selector and controller selector have been added to Figure 2. Data coming from a working register, going to a transmit data line, flows under program control from a specified register to the lower data bus into the Y-register. From the Y-register the


Figure 2. Basic Block Diagram
data flows through the arithmetic unit and the Z-drivers onto the upper data bus, where it is then distributed to the buffer selector. The buffer selector then passes the data along to the proper output channel.

Data being received from a specified remote terminal is temporarily stored in a bit buffer, word buffer, or character buffer. The buffer selector then passes the data from the receive buffer channel through the receive data lines to the lower data bus, where it is then sent to the Y-register. From the Y-register the data is sent through the arithmetic unit to the Z-drivers, where it is then distributed to the proper working register under program control.

The flow of data to and from the controller selector follows the same paths as for the buffer selector, with the exception that data going to a high-speed peripheral comes from memory and data coming from a high-speed peripheral is put into memory without first going through a working register.

Data flows to and from the controller selector under automatic control of the DATANET-30 circuitry.


Figure 3. Basic Block Diagram

## Detailed Block Diagram

The detailed block diagram (Figure 4) shows many more data paths of the communications processor, including those for the memory unit, the buffer selector, and the controller selector; but the overall pattern of data flow still applies. In general, data flows from one or more registers to the lower data bus, through the Y-register to the arithmetic unit, to the Z-drivers, and then to one or more of the registers connected to the upper data bus. Data may also go from the memory to the arithmetic unit at the same time that data is coming from the Y -register.

The register transfer instructions, a major class of instructions, permit any combination of up to six (specific) registers to be combined in the Y-register, to be manipulated in some selected manner, and then have the result putin any combination of up to four (specific) registers. Further details of the register transfer instructions are given in the discussion of the instruction repertorie.

## Description of Registers

This section contains information about each of the blocks on the detailed block diagram. Certain conventions are followed:

First Item: The size of the register.
Second Item: The abbreviation for the name of the register (no abb. means no abbreviation is used).

Third Item: A or N , to indicate that the register is accessible or is not directly accessible to the program.

## A-Register (18 bits, A, A)

## B-Register (18 bits, B, A)

The A- and B-registers are the principal working registers of the DATANET-30. They are identical and have identical functions and instructions except for the parity network, which is connected to the B-register only.

## C-Register (7 bits, C, A)

The C-register is used to specify a particular input/output channel of the buffer selector. In addition the C-register can be used as a normal index register when indirect addressing is used.

## L-Register (14 bits, L, N)

The L-register contains the address of the next memory location to be accessed. In the singlecycle mode, the register will contain the operand address of the instruction last executed.


## N-Register (7 bits, N, N)

The N-register is used to facilitate the instruction decoding process. The register contains the high-order 7 bits of the instruction to be executed. In the single-cycle mode, the register will contain the operation code of the last instruction executed.

## $\underline{\text { P-Counter (14 bits, P, A) }}$

The P-counter contains the address of the next instruction to be executed. Some bits of the P -counter are used for generating addresses. The P-counter will count up through program banks.

Q-Counter (14 bits, Q, A)
The Q-counter serves as the elapsed time clock.

Y-Register (18 bits, Y, N)
The Y-register is used to form and hold the intermediate operand for an instruction.

## Z-Drivers (18 bits, Z, N)

The Z -drivers are a common data distribution center for all data coming from the arithmetic unit and going to a working register, memory, control unit, or an input/output channel. Data passes through the Z-drivers without delay enroute to the destination determined by the instruction being executed at the time that the data exists in the drivers.

Arithmetic Unit (18 bits, no abb., N)
The arithmetic unit performs the following functions on the contents of the Y-and/or M-registers and puts the result into the Z -drivers:

1. Binary addition
2. Logical AND
3. Logical OR
4. Logical EXCLUSIVE OR
5. Shift left, right, circulate
6. Bit change
7. Address modification.

## Branch Flip-Flops (BFF's, A)

The plus, zero, and even flip-flops are connected to the Z-drivers. These three flip-flops are set at the completion of every nonbranch instruction and will reflect the branch conditions of any data passing through the Z-drivers. The plus FF (PFF) stores the status of the high-
order bit of the result $Z(18)$. The zero $F F(Z F F)$ stores the status of the entire result $Z(1-18)$. The even $F F$ (EFF) stores the status of the low order bit $Z(1)$ of the result. The result of an operation is available for test on the next instruction. When the branch is based on contents of the $C$-register, only $Z(1-7)$ are reflected in $Z F F$ and EFF. When the branch is based on the internal status lines, only $\mathrm{Z}(1-10)$ are reflected in ZFF and EFF .

## Plus Flip-Flop (1 bit, PFF, A)

The PFF records (for testing) the condition of $Z(18)$ at the end of an instruction. If $Z(18)$ was zero, the PFF would be plus; but if $Z(18)$ was one, the PFF would be minus. The notation $Z(18)$ refers to bit position 18 of Z -- that is, the high order position of Z .

## Zero Flip-Flop (1 bit, ZFF, A)

The $Z F F$ records (for testing) the condition of $Z$ at the end of an instruction. If all of the $Z$ drivers were zero, the ZFF would be zero; but if any one of the Z-drivers were nonzero, the ZFF would be nonzero.

Even Flip-Flop (1 bit, EFF, A)
The EFF records (for testing) the condition of $Z(1)$ at the end of an instruction. If $Z(1)$ was zero, the EFF would be even; but if $Z(1)$ was one, the EFF would be odd.

On double length instructions (AMD, LDD, STD) the branch flip-flops indicate the following:


Thus, the last word through the Z-drivers can be tested for being:

1. Plus or minus (sign bit)
2. Odd or even (numerical sense)
3. All zeros or not all zeros.

## Insert Switches (18 switches, S, A)

The switches are located on the control console and are described in the discussion of the control console, Chapter 4. They can be grated in under program control.

Internal Function Drivers (10 drivers, IFD, A)
These drivers can activate special control functions. These functions are listed under "Special Instructions" as the Drive Internal Function (DIF) instructions.

Internal Status Lines (10 lines, ISL, A)
These lines are used to test the status of various special conditions. These conditions are listed under "Special Instructions" as the AND Internal Status (NIS) instructions.

## THE MEMORY UNIT

M-Register (18 bits, no abb., N)
The M-register is the memory output register. References to M in many places in this manual refer to the contents of a memory location, which is actually made available in the M-register. In the single-cycle mode, the register will contain the contents of the last memory location accessed as specified by $L$.

Memory Drivers (18 drivers, no abb., N)

The memory drivers are used to write a new word into the memory and to regenerate a word when it is read out of the memory.

Memory Address Lines (14 lines, no abb., N)
These contain the address of the memory location being accessed.

## THE BUFFER SELECTOR

Receive Data Lines ( 21 lines, $R, A$ )
These lines are used to receive data from all buffer units on the buffer selector.

## Transmit Data Drivers (21 drivers, T, A)

These drivers are used to send data to all buffer units on the buffer selector.

## External Function Drivers (10 drivers, EFD, A)

These drivers are used to send control signals to a buffer unit. The function of each driver depends on the particular type of buffer unit. The functions are listed under "Buffer Selector Instructions" as the DEF instructions.

These lines are used to test various conditions in a buffer unit. The condition tested by each line depends on the particular buffer unit. The conditions are listed under "Buffer Selector Instructions" as the NES instructions.

Buffer Address Decode (128, N)
This unit decodes the C-register into a 1 out of 128 signal to select the desired buffer address.

## THE CONTROLLER SELECTOR

Data Register (21 bits, no abb., N)
The controller selector data register contains the data being transferred between the controller selector and the DATANET-30.

Address Register (14 bits, no abb., N)
The controller selector address register contains the address of the next memory location to be accessed by the controller selector.

PARITY NETWORKS (21 bits, no abb., A)
Although not shown on the block diagram, the parity networks are attached to the B-register and consist of a word parity network and a character parity network.

There are two outputs from the parity network, one for character parity and one for word parity. Either output may be tested to check incoming data. The appropriate output is automatically sent to a buffer unit when information is transmitted.

The input to the word parity network consists of the 18 bits of the B-register and the control bit 1 and control bit 2 flip-flops. The output of the word parity network is bit 21 and is used with the word buffer channel and CIU. The inputs to the character parity network are bits $1-6$ of the B-register and the control bit 1 and 3 flip-flops. The character parity is used almost exclusively for generating correct parity on 8 -level teletype characters. Each time a word is brought into the B-register, the word parity network will generate correct parity on it. At the same time, proper character parity will be generated on bits 1-6 of the B-register.

## CONTROL BITS 1, 2 and 3

The control bits are special-purpose flip-flops and are used as needed. Since there are 21 receive data lines and the registers are 18 -bit registers, the receive data lines 19,20 , and 21 go to control bits 1,2 , and 3, respectively. Control bit 3 is also referred to as the "parity bit." The following chart shows the instructions and conditions affecting the control bits.

| CB1 | CB2 | CB3 (Parity) |  |
| :--- | :--- | :---: | :---: |
| Buffer Selector <br> Receive Data Lines | 19 | 20 | 21 |
| Instructions <br> BCO | YO9 | Resets only | YO6 |
| NIS | NIS 8 | NIS 9 | NIS 0 |
| DIF | DIF 8 | DIF 9 | DIF 0 |
| LDF | Z08 | Z09 | Z10 |
| STF | Z08 | Z09 | Z10 |
| DIF1 | Resets all 3 control bits |  |  |

The paper tape reader also uses the control bits in a special way when reading paper tape under program control.

The transmit data lines use the control bits as follows:


When transferring data to a word buffer or a CIU, where a parity bit is needed, put a word in the B-register, set bits 19, 20, and 21 as required (DIF instructions) and when a Register Transfer instruction is executed, the proper parity will go to line 21.

Set CB3 for even parity in transmitted word. Reset CB3 for odd parity in transmitted word. If only 18 bits are used, reset CB1, 2, and 3 before transmitting.

## Instruction Cycles

The following examples illustrate typical situations and the flow of information by large lines with arrowheads indicating the direction of flow. The steps are numbered to tie in with the corresponding explanation. These examples are for one 6.94 microsecond word time each.

The function the instruction cycle (Figure 5) performs is the initial decoding of the instruction and the generation of the desired memory address and its transfer to the L-register. This prepares the DATANET-30 for the execution cycles to follow:

1. At the very start of the instruction cycle (actually slightly before) the address of the next instruction is transferred from $P$ to $L$. After this takes place, $P$ is incremented by plus 1 .
2. The L-register is transferred to the memory address lines.
3. When the instruction is read out, it is transferred from M to N where, in this example, a non general instruction is decoded.
4. After the instruction is decoded the address modification mode is decoded and the correct section of the arithmetic unit enabled (see "Addressing Memory").
5. The desired memory address is transferred from the arithmetic unit to Z .
6. The address is then sent to $L$ to prepare for addressing memory on the next cycle.
7. Simultaneously with steps 3,4 , and 5 , the contents of $M$ are being regenerated by the memory drivers.


Figure 5. Detailed Block Diagram DATANET-30 Instruction Cycle

LOAD A-REGISTER (LDA) EXECUTION CYCLE. This instruction performs the function of transferring information from $M$ to $A$ (Figure 6):

1. The operand address in $L$ is transferred to the memory address lines for accessing the memory.
2. The contents of $M$ are transferred to the arithmetic unit.
3. The contents of M are transferred through the arithmetic unit to Z .
4. The contents of $M$ are transferred from $Z$ to $A$, thus loading $A$ with the contents of $M$.
5. Simultaneously with steps 2,3 , and 4 , the contents of $M$ are being regenerated by the memory drivers.
6. The branch flip-flops store the plus, zero, and even conditions of the contents of memory.


Figure 6. Detailed Block Diagram DATANET-30 Load A (LDA)

STORE B-REGISTER (STB) EXECUTION CYCLE. Information is again transferred from B to the memory (Figure 7):

1. The operand address in $L$ is transferred to the memory address lines for accessing the memory.
2. The contents of $B$ is transferred to $Y$ while the memory is being read out and cleared.
3. $B$ is transferred from $Y$ to the arithmetic unit.
4. $B$ is then transferred to $Z$.
5. The contents of $B$ is then transferred from $Z$ to the memory drivers for the generation in memory of the new information.
6. The branch flip-flops store the plus, zero, and even conditions of the contents of B.


Figure 7. Detailed Block Diagram DATANET-30 Store B (STB)

ADD MEMORY TO A-REGISTER (AMA) EXECUTION CYCLE, This instruction replaces A with the sum of $A$ and $M$, and regenerates $M$ (Figure 8):

1. The operand address in $L$ is transferred to the memory address lines for accessing memory.
2. The contents of $A$ is transferred to $Y$ while the memory is being read out.
3. The contents of $M$ is read from memory and transferred to the arithmetic unit.
4. The contents of A is transferred through Y to the arithmetic unit.
5. The binary arithmetic sum of $M$ and $A$ is generated by the arithmetic unit and transferred to Z .
6. The sum in $Z$ is transferred to $A$.
7. Simultaneously with steps $3,4,5$, and 6 , the contents of $M$ are being regenerated by the memory drivers.
8. The branch flip-flops store the plus, zero, and even conditions of the binary arithmetic sum of $A$ and $M$.


Figure 8. Detailed Block Diagram DATANET-30 Add Memory to A (AMA)

SHIFT RIGHT ONE (SR1) BR,B CYCLE. This instruction performs the Shift Right One (SR1) function in one word time (Figure 9):

1. At the very start of the instruction cycle (actually slightly before) the address of the next instruction is transferred from $P$ to $L$. After this takes place, $P$ is incremented by plus 1 .
2. The L-register is transferred to the memory address lines.
3. When the instruction is read out, it is transferred from $M$ to $N$ where, in this example, a general instruction (SR1 BR,B) is decoded.
4. After the instruction is decoded, the contents of B are transferred to Y.
5. Simultaneously with step 3 , the contents of $R$ are transferred to $Y$.
6. The logical OR of $B$ and $R$ is done in $Y$ and transferred to the arithmetic unit.
7. The arithmetic unit performs a SR1 function on $Y$ and transfers the result to $Z$.
8. The result in Z is transferred to B .
9. Simultaneously with steps $3,4,5,6$, and 7 , the contents of $M$ are being regenerated by the memory drivers.
10. The branch flip-flops store the plus, zero, and even conditions of the new contents of $B$.


Figure 9. Detailed Block Diagram DATANET-30 Shift Right 1 Receive Lines to B-register (SR1 BR, B)

## Perforated Tape Reader

The perforated tape reader will read 5-, 6-, 7-, or 8-level tape under program control, or 8 -level tape under hardware control. When reading is done under hardware control, this is referred to as "Hardware Load." Normally, 8-level tape is used in both cases. See Figure 10.

The reader is permanently tied to buffer selector address 0. It operates like any other remote terminal connected to the buffer selector when under program control, in the sense that it uses the external function drivers for control and the external status lines for testing. As information is read, it is transferred into input buffer 0 and the receive flag is set to indicate that data is present. This flag may be tested by an NES command.

The primary function of the perforated tape reader is to contain either a bootstrap program to be used at the start of a day, or a special restart and error recovery program to be used in the event that an error condition develops in the execution of the normal program.

The secondary function of Hardware Load and the perforated tape reader is to initially load the programs into memory. Once the programs are loaded, they may be stored in the disc storage unit or on magnetic tape and recalled as necessary.

The third possible function is to enter data via the perforated tape reader under program control. This is not a normal usage, however, and is more of an exception than a rule to the intended use of the reader.

## Hardware Load

Hardware Load is a process whereby data is transferred from the perforated tape reader to memory under hardware control. This is used for initial loading of programs, for the loading of maintenance diagnostics when necessary, and for the automatic restart of an operating program upon discovery of a fault condition.

Hardware Load may be initiated in five ways:

1. Manually from the control console.
2. By execution of a DIF 4 instruction.
3. When Q counts down to $\mathbf{- 3 2}$.
4. When the second LDQ instruction is executed after a program interrupt occurs while in the operate mode.
5. When in the operate mode and a halt occurs.


Figure 10. Perforated Tape Reader

Hardware Load has a special format. The generation of paper tape in the hardware load format is described in the section on programming the paper tape reader.

## The Elapsed Time Clock (Q-Counter)

The DATANET-30 is a real time data communications processor. Real time programs have a periodic nature of operation. The elapsed time clock (the Q-counter) provides an efficient technique for achieving this.

The $Q$-counter is loaded by the program, and is counted down one each word time. This serves as a word/time counter. $Q$ can be loaded with any number between -32 and $+16,351$. If loaded with 16,351 , this is equal to approximately 112 milliseconds.

When $Q$ counts down to zero, a program interrupt is initiated, thus permitting the periodic execution of programs at any period up to 112 milliseconds. The Q-counter may be used as a relatively accurate real time clock by counting the number of program interrupts when they occur. For example, if a delay of 900 milliseconds is desired and the communication lines are scanned every 12.5 milliseconds, then a count of 72 interrupts equals 900 milliseconds.

The $Q$-counter is a 14 -position straight binary counter. If the $Q$-counter is loaded with a number between 16,383 and 16,351 , a Hardware Load will occur before a program interrupt.

## The Q-Counter and Hardware Load

The Q -counter also serves as a reliability check on the system. When Q counts down to -32, the DATANET-30 assumes a circuit failure and automatically initiates loading a restart program by initiating hardware load. Successful operation of the programs depends on preventing $Q$ from counting to -32 and reading in a restart program. This is achieved in the Program Interrupt Routine by loading the Q -counter before it counts down to -32 . Also, in the operate mode, protection against a "dead loop" which includes an instruction to load the Q-counter, has been achieved by counting the number of times the counter has been loaded since the last program interrupt. Hardware load will be initiated upon execution of the second Load Q instruction. This assures that the Program Interrupt Routine is executed periodically. The Program Interrupt Routine may be written to check the program and initiate a hardware load if a fault is found. This hardware-software feature provides a very adequate check on the proper operation of the program. In the event that certain programs do not require a periodic interrupt, this feature may be inhibited by the Q-counter switch on the operating panel.

Upon the completion of loading the restart program, control is returned to the program and the necessary details involved in the restart process are completed.

## INSTRUCTION FORMATS

There are two main groups of instructions:

1. Nongeneral instructions - Those for which the low-order bits specify a memory address -- for example, memory reference instructions which may be subject to address modification.
2. General instructions - Those for which the low-order bits contain information to be used by the instruction.

The notation I ( ) refers to the contents of an instruction word. General instructions may be recognized by the fact that the three high-order bits, I (16-18), are all zeros. (When expressed in octal notation, the general instructions start with a 0 in the high-order position).

There is one format for nongeneral instructions and three for general instructions (register transfer, status line and function driver, and C-register instructions).

## Nongeneral Instructions

The nongeneral or memory reference, instructions have four fields:


[^0]
## General Instructions

The fields for the three types of general instructions are as follows:

1. The register transfer instructions have three fields:

2. The status line and function driver instructions have two fields:

3. The C-register instructions have two pertinent fields:


## REPRESENTATION OF INFORMATION IN MEMORY

## Alphanumeric Data

Each DATANET-30 word can contain three six-bit alphanumeric characters. The 64 possible bit combinations can be assigned to 64 symbols in any manner desired, because the DATANET- 30 does not use alphanumeric data as a unique code. Therefore, other system conditions will determine the actual bit-pattern-to-symbol assignment. An alphanumeric data word could be arranged to look like this in memory:


Each DATANET-30 word can contain two eight-bit alphanumeric characters. The particular code set used is dependent primarily on the remote terminals. This word might appear as follows:


Eight-level teletype characters can be stored conveniently in memory as six-bit characters. The DATANET-30 has two special instructions to facilitate stripping off and checking the parity and control bits when a character is received, and generation and insertion of parity and control bits when a character is to be transmitted. If desired for some applications, two eight-level characters could be stored in a word as eight-bit characters including the parity and control bits.



Two 8-level characters still containing parity and control bits, where:

$$
\begin{aligned}
& \mathrm{C}=\text { Control Bit } \\
& \mathrm{D}=\text { Data Bit } \\
& \mathrm{P}=\text { Parity Bit }
\end{aligned}
$$

## Numeric Data

Positive numbers are represented by integers. Negative numbers are represented in the 2's complement form. The DATANET-30 utilizes 2's complement arithmetic. Therefore, the high-order bit is properly thought of as the sign bit, when it is understood that the sign is a 2's complement sign, not an algebraic sign. The bits are shown in groups merely to simplify the presentation. There is no hardware sign bit in either the A-or B-registers. The sign is always programmed.


The number is considered a 17-bit number with bit 18 as the sign bit. In case of overflow of a positive number into bit 18 position, the sign changes and goes negative. Conversely, with a negative number, bit 18 will change in the event of overflow. This condition is tested with a Branch On Plus or Branch On Minus instruction.

## Examples of binary representation of numeric data are shown below:

SIGN

$$
2^{16} 2^{15} 2^{14} 2^{13} \quad 2^{12} 2^{11} \quad 2^{10} \quad 2^{9} \quad 2^{8} \quad 2^{7} \quad 2^{6} \quad 2^{5} \quad 2^{4} \quad 2^{3} \quad 2^{2} \quad 2^{1} \quad 2^{0}
$$

| 0 | 00 | 000 | 000 | 000 | 000 | 000 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| 18 | 17 |  | 1 |  |  |  |


| 0 | 00 | 000 | 000 | 000 | 000 | 101 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

$18 \quad 17$

| 1 | 11 | 111 | $\because 1$ | 111 | 111 | 011 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

$18 \quad 17$ 1

| 1 | 11 | 111 | $\because 1$ | 111 | 111 | 111 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| 19 | 17 |  |  | 1 | -1 |  |


| 1 | 00 | 000 | 000 | 000 | 000 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 18 | 17 |  |  | 1 |  |  |

-131,071 (the largest negative number)

+131,071 (the largest positive number)

| 2 | 00 | 000 | 020 | 000 | 000 | 000 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

$-131,072$ is not a valid number


## Double Length Binary Data

There are instructions which perform operation on double length words ( 36 bits). The numerical range is increased from ( $-131,071$ to $+131,071$ ) to $(-34,359,738,367$ to $+34,359,738,367)$.

These double length words are stored in memory and the registers as below, where $M(18)$, $\mathrm{A}(18)$ is a "two" complement sign. $M$ must be even for all double length instructions.


The branch flip-flops are treated in a special manner by the three double length instructions (LDD, STD, AMD). The plus flip-flop is set on A(18). The zero flip-flop is set on the entire 36 bits of the double length result. The even flip-flop is set on $\mathrm{B}(1)$. The sign is programmed.

## II. INSTRUCTION REPERTOIRE

There are over 78 basic instructions with many variations of some of them. These are classified into three groups:

1. Internal instructions
2. Buffer selector instructions
3. Option module instruction

## INTERNAL INSTRUCTIONS

The internal instructions are further classified into eight subgroups:

1. Load
2. Store
3. Arithmetic
4. Logical
5. Register Transfer
6. Branch
7. Macro
8. Special

In the following discussion, an $M$ in the Operand column means that the instruction refers to a memory location. All such instructions use one of the addressing modes; therefore, no specific mention is made of these modes here.

I or FROM, TO in the Operand column means that the information to be used in executing the instruction is made up of the bits in the low-order part of the instruction itself.

For brevity, the notation $I(1-7)$ will be used for the 7 low-order bits of the instruction word. B (18) stands for the high-order bit of B. M stands for all 18 bits of the memory location; B stands for all 18 bits of the B-register; C stands for all 7 bits of the C-register, etc.

At times the discussion will refer to $M$ as a memory location. It should be understood that what is really meant is the effective address -- that is, the memory location specified by $M$ and the addressing mode. $M$ is used for brevity.

The following word times assume that direct addressing is used. Add one additional word time when using indirect addressing. All instructions that address memory are also indirectly addressable.

## Pseudo-Operations

In addition to the machine instructions in the DATANET-30 instruction repertoire, there are a number of pseudo-operations which facilitate programming. A pseudo-operation is not a computer instruction. It is a control instruction to the assembly program in assembling a program, and it is listed the same as a normal instruction in the preparation of a program. Normally, pseudooperations are never executed by the computer as actual instructions. Pseudo-operations are used to generate constants, to control the assembly process, or to annotate the program listing.

## Load Instructions

| Mnemonic |  | Operand | Word Times |
| :---: | :---: | :---: | :---: |
| LDA |  | M | 2 |
|  | LOAD A. |  | The contents of $M$ replace the contents of A. The contents of M are unchanged. |
| LDB |  | M | 2 |
|  | LOAD B. |  | The contents of $M$ replace the contents of $B$. The contents of M are unchanged. |
| LDC |  | M | 2 |
|  | LOAD C. |  | The contents of $M(1-7)$ replace the contents of $C$. The high-order bits of $M$ are ignored and M is unchanged. |
| LDD |  | M | 3 |
|  | LOAD DOUBLE. |  | The contents of $\mathrm{M}(1-18)$ replace the contents of $A$. The contents of $M+1$ replace the contents of $B$. $M$ must be even. $M$ and $M+1$ are unchanged. |
| LDQ |  | M | 2 |
|  | LOAD Q. |  | The contents of $M$ replace the contents of $Q$. The contents of M are unchanged. |
| LDZ |  | M | 2 |
|  | LOAD Z. |  | The contents of M is placed only in Z and the branch flip-flops. $M$ remains unchanged. sets up the branch flip-flops. |
| CMA |  | M | 2 |
|  | COMPLEMENT MEMORY TO A. |  | The 1's complement of the contents of M replaces the contents of A . The contents of M are unchanged. |

Mnemonic
CMB

PIC

COMPLEMENT MEMORY TO B.

PLACE I IN C.
PLACE

Operand
M

## Word Times

The 1's complement of the contents of $M$ replaces the contents of $B$. The contents of M remain unchanged.

I
I (1-7) is placed in C. I is bits $1-7$ of the instruction.

## Store Instructions

M
STORE A.
M

Operand

The contents of $A$ replace the contents of $M$. The contents of A remain unchanged.

## Word Times

STORE C.

STD
STORE DOUBLE.

STZ
STORE ZERO.

CAM M
COMPLEMENT A TO MEMORY.

CBM
COMPLEMENT B TO MEMORY.

CMM
STORE B.

STC
~N..

COMPLEMENT MEMORY TO MEMORY.

2
The contents of $B$ replace the contents of $M$. The contents of $B$ remain unchanged.

M

M

M

M  The 1's complement of the contents of A is stored in $M$. The contents of $A$ remain unchanged.
The contents of $A$ are stored in $M$ and the contents of $B$ are stored in $M+1$. $M$ must be even. The contents of $A$ and $B$ are unchanged.

2
A zero is stored in M.

The 1's complement of the contents of $B$ is stored in M. The contents of $B$ remain unchanged.

## 2

The 1's complement of the contents of $M$ is stored in M, the same memory location.

## Arithmetic Instructions

Mnemonic
ADD MEMORY TO A.

## AMB

ADD MEMORY TO B.

## AIC

ADD I TO C.

AMD
M
ADD MEMORY DOUBLE.

AAM
ADD A TO MEMORY.

ABM
ADD B TO MEMORY.

ADO
ADD ONE.
Operand
M

## Word Times

2
The contents of M are added to the contents of A and the result is placed in A .

2
The contents of M are added to the contents of $B$ and the result is placed in $B$.

1
I (1-7) are added to the contents of $C$ and the result is placed in C.

The contents of $\mathrm{M}+1$ are added to the contents of $B$ and the result is placed in B, and the contents of $M$ and a carry from the first are added to the contents of A and the result is placed in $A$. $M$ must be even. $M$ and $M+1$ are unchanged.

The contents of A are added to the contents of M and the result is stored in M . A remains unchanged.

The contents of $B$ are added to the contents of $M$ and the result is stored in $M$. B remains unchanged.

One is added to the contents of $M$ and the result is stored in M.

## Word Times

## SBO

## 2

SUBTRACT ONE.

AAZ
ADD A TO Z.

ABZ

## M

ADD B TO Z.

M

One is subtracted from the contents of $M$ and the result is stored in M. 2

The contents of B are added to the contents of M . The result in the Z -drivers is placed only in the branch flip-flops. B and M remain unchanged.

## Logical Instructions

The truth table for the logical AND function is:

    Y
    
    M
    (A,B,C)
    0
    0 1
    1 0
    1 1
    Mnemonic
(M,I)
0
Operand

$$
\begin{gathered}
\mathrm{Z} \\
(\mathrm{~A}, \mathrm{~B}, \mathrm{M})
\end{gathered}
$$

00
0
1
Z
$(\mathrm{A}, \mathrm{B}, \mathrm{M})$
0
0
0
1

## Word Times

Operand
2

AND MEMORY TO A.

NMB
AND MEMORY TO B.

NAM
AND A TO MEMORY.

NBM
AND B TO MEMORY.

NAZ
M
AND A TO Z.
M

M

A logical AND is performed with the contents of $M$ and the contents of $A$. The result is placed in A .

## 2

A logical AND is performed with the contents of $M$ and the contents of $B$. The result is placed in $B$.

A logical AND is performed with the contents of $A$ and the contents of $M$. The result is stored in M .

A logical AND is performed with the contents of $B$ and the contents of $M$. The result is stored in M .

## 2

A logical AND is performed on the contents of $A$ and the contents of $M$. The result in the Z -drivers is placed only in the branch flipflops. A and $M$ remain unchanged.

NBZ
M

## AND B TO Z.

NCZ
AND C TO Z.

A logical AND is performed on the contents of $B$ and the contents of $M$. The result in the Z -drivers is placed only in the branch flipflops. B and $M$ remain unchanged.

I
A logical AND is performed on $I(1-7)$ and the contents of $C$. The result in the $Z$-drivers is placed only in the branch flip-flops. C remains unchanged.

The truth table for the logical OR function is:
Y
M
Z
(A,B)
0
0

$$
(\mathrm{A}, \mathrm{~B}, \mathrm{M})
$$

0
0
0 1

## 0

1
1
1

2

OR MEMORY TO A.

RMB
M
OR MEMORY TO B.

RAM
M
OR A TO MEMORY.

A logical OR is performed with the contents of $M$ and the contents of $A$. The result is placed in $A$.

A logical OR is performed with the contents of $M$ and the contents of $B$. The result is placed in $B$.

## 2

A logical OR is performed with the contents of $A$ and the contents of $M$. The result is stored in M .

## 2

OR B TO MEMORY.
A logical OR is performed with the contents of $B$ and the contents of $M$. The result is stored in $M$.

The truth table for the logical EXCLUSIVE OR function is:
$\mathbf{Y}$
$(\mathrm{A}, \mathrm{B}, \mathrm{C})$
0
M
(M,I)
Z
(A,B,M)
0
1
0
0
1
1
1
0
1
1
1
0

2

EXCLUSIVE OR MEMORY TO A.

XMB
M
EXCLUSIVE OR MEMORY TO B.

XAM

EXCLUSIVE OR A TO MEMORY.

XBM
EXCLUSIVE OR B TO MEMORY.

A logical EXCLUSIVE OR is performed with the contents of $M$ and the contents of $A$. The result is placed in A.

2
A logical EXCLUSIVE OR is performed with the contents of $M$ and the contents of $B$. The result is placed in $B$.

M
A logical EXCLUSIVE OR is performed with the contents of $A$ and the contents of $M$. The result is stored in M.

M
A logical EXCLUSIVE OR is performed with the contents of $B$ and the contents of $M$. The result is stored in M.

Mnemonic
XAZ
EXCLUSIVE OR A TO Z.

XBZ
EXCLUSIVE OR B TO Z.

XCZ
EXCLUSIVE OR C TO Z.

Operand

## 2

A logical EXCLUSIVE OR is performed on the contents of $A$ and $M$. The result in the $Z$ drivers is placed only in the branch flip-flops. $A$ and $M$ remain unchanged.

M
2

A logical EXCLUSIVE OR is performed on the contents of $A$ and $M$. The result in the Zdrivers is placed only in the branch flip-flops. $A$ and $M$ remain unchanged.

I
A logical EXCLUSIVE $O R$ is performed on I $(1-7)$ and the contents of $C$. The result in $Z$ is placed only in the branch flip-flops. C remains unchanged.

| TRUTH TABLES |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $X_{1}$ | $X_{2}$ | AND | $O R$ | XOR |
| 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 1 |
| 1 | 0 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 0 |

## Register Transfer Instructions

All of the register transfer instructions use the low order bits of the instruction to specify which locations are to be included in the FROM group and which in the TO group. The possibilities are:

## Bit Position in I

| FROM: | A | The A-register | - | 10 |
| :---: | :---: | :---: | :---: | :---: |
|  | B | The B-register | - | 9 |
|  | C | The C-counter | - | 8 |
|  | Q | The Q-counter | - | 7 |
|  | R | The receive data lines (From X , the address of a particular buffer) | - | 6 |
|  | S | The insert switches | - | 5 |
|  | $\varnothing$ | Zero is transferred to the specified TO location |  |  |
| TO: | A | The A-register | - | 4 |
|  | B | The B-register | - | 3 |
|  | C | The C-counter | - | 2 |
|  | T | The transmit data lines (To X , the address of a particular buffer) | - | 1 |
|  | Z | The Z-drivers; FROM remains unchanged. |  |  |

If $R$, $S$, or $T$ is specified, the control bit 1 , control bit 2 , and parity flip-flops (internal functions) are used for the "extra" positions, since $R$ and $T$ are all more than 18 bits.

Any register specified in the $F R O M$ group will remain unchanged after the register transfer operation if it does not appear in the $T O$ group. If $R$ is specified in the FROM group, after the data is transferred, the receive flag and receive data buffer are reset by an automatically generated signal activating external function driver 1 (DEF1).

With the exception of T in the TO group, the TO register will contain the result after a register transfer instruction. If $T$ is specified in the TO group, before the data is transferred, the transmit flag and transmit buffer are reset by an automatically generated signal activating external function driver 2 (DEF2). The $Q$-counter is not counted down when a TRA $Q$ instruction is executed.

When a register transfer instruction is executed, the contents of those registers which are specified to be used as the FROM group for this instruction are logically OR-ed together into the $Y$-register. Then the data goes from $Y$ to $Z$ with the operation specified by the instruction being performed on the data as it goes from $Y$ to $Z$. Finally the result goes from the Z drivers to all of those registers which are specified in the TO group. The plus, zero, and even flip-flops
will take on their new states in the normal manner. If no registers are specified in the FROM group, the output from the Y-register will be zero. If no registers are specified in the TO group, the only outputs are the new states of the plus, zero, and even flip-flops. Register transfer instructions with more than one register in the FROM and TO groups can be specified. For example: TRA O,ABC; TRA ABC,Z; SL6 BC,AB.

Mnemonic

TRA

TRC
FROM, TO
In going from Y to Z , no change is made in the data.

SL1
FROM, TO
In going from Y to Z , the data is changed into its 1's complement.

SR1

SL6

SR6

Operand

FROM, TO
Word Times

1

TRANSFER.

TRANSFER COMPLEMENT.

SHIFT LEFT ONE.

SHIFT RIGHT ONE.

SHIFT LEFT SIX.

SHIFT RIGHT SIX.

In going from $Y$ to $Z$, the data is shifted left one position. The high-order bit is lost and a zero goes into the low-order position.

FROM, TO
1

In going from Y to Z , the data is shifted right one position. The low-order bit is lost and a zero goes into the high-order position.

FROM, TO
1

In going from $Y$ to $Z$, the data is shifted left six positions. The six high-order bits are lost and zeros go into the six low-order positions.

FROM, TO
1

In going from $Y$ to $Z$, the data is shifted right six positions. The six low-order bits are lost and zeros go into the six high-order positions.

FROM, TO
1

## CL1

CIRCULATE LEFT ONE.

CR1
CIRCULATE RIGHT ONE.

CL6
CIRCULATE LEFT SIX.

CR6

CIRCULATE RIGHT SIX.

SHIFT LEFT SPECIAL.

SRS
SHIFT RIGHT SPECIAL.

This instruction is a SL1 instruction with one added function. Bit B (18) is shifted into Bit A (1).


This instruction is a SR1 instruction with one added function. Bit $A$ (1) is shifted into Bit B (18).


Mnemonic
Operand
BC0

FROM, TO

## Word Times

1

## BIT CHANGE ZERO.

This is a special instruction for use with eight-level Friden data. In going from $Y$ to $Z$, the data is rearranged from the eightlevel format used on a transmission line to the six-bit alphanumeric format used in computers. The other two bits, the parity and control bits, are put in the CB1 and CB3 flip-flops.

FROM | X | X | X | X | X | X | X | X | X | C | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | P | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | X |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

T0 $\quad$| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

P goes to the parity flip-flop
(CB3)
C goes to the control bit flip-flop 1

BIT CHANGE ONE.

This is the reverse operation of BCO . In going from $Y$ to $Z$, the data is rearranged from the six-bit alphanumeric format into the eight-level format used on a transmission line. The control bit comes from BC1 and the parity bit comes from the output of the character parity network.

FROM


Y

TO

| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | $C$ | $D_{6}$ | $\mathrm{D}_{5}$ | P | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | Z

$P$ is the output from the character parity network
$C$ is the control bit 1 flip-flop

## Branch Instructions

The states of the plus, zero, and even flip-flops are not changed by any branch instruction.

| Mnemonic | Operand | Word Times |
| :---: | :---: | :---: |
| BRU | M | 1 |
| BRANCH UNCONDITIONALLY. |  | Control is transferred to the instruction in $M$ within the same program bank. When indirect addressing is specified, control is transferred to the address in M . |
| BRS | M | 3 |
| BRANCH TO SUBROUTINE. |  | The location of the instruction following the BRS is stored in $M$; then, control is transferred to the location specified by the contents of $M+1$. M must be even. |

The remaining branch instructions are conditional branches. Control is transferred to $M$ if the appropriate conditional test is satisfied. Otherwise, control goes to the next instruction that is, the instruction following the branch instruction.

| BZE |  | M | 1 |
| :---: | :---: | :---: | :---: |
|  | BRANCH ON ZERO. |  | If the ZFF is zero, control is transferred to M. |
| BNZ |  | M | 1 |
|  | BRANCH ON NON-ZERO. |  | If the ZFF is nonzero control is transferred to M . |
| BPL |  | M | 1 |
|  | BRANCH ON PLUS. |  | If the plus flip-flop is plus, control is transferred to M . |
| BMI |  | M | 1 |
|  | BRANCH ON MINUS. |  | If the plus flip-flop is minus, control is transferred to M . | ferred to M .



## Macro Instructions

The following instructions are macro-instructions. That is, they are not actual machine instructions; however, the General Assembly Program will recognize the mnemonics for the macroinstructions and generate the appropriate series of instructions to do the specified operation.

## Mnemonic

CL2

## Word Times

FROM, TO
2

CIRCULATE LEFT 2.

## CL3

CIRCULATE LEFT 3.

## CL4

FROM, TO
CIRCULATE LEFT 4.

CL5
FROM, TO
The contents of the specified FROM location is shifted left 2 places. The bits leaving position 18 are shifted into position 1 of the TO location.

FROM, TO

CIRCULATE LEFT 5.

## CL7

FROM, TO
CIRCULATE LEFT 7.

CL8
FROM, TO
3
CIRCULATE LEFT 8.

CL9
FROM, TO
4
CIRCULATE LEFT 9.

CR2
FROM, TO
2
The contents of the specified FROM location are shifted right 2 places. Bits leaving position 1 are shifted into position 18 of the TO location.

| Mnemonic | Operand | Word T |
| :--- | :--- | ---: |
| CR3 | FROM, TO | 3 |

CIRCULATE RIGHT 3.

CR4
FROM, TO
3

CIRCULATE RIGHT 4.

CR5
FROM, TO
2
CIRCULATE RIGHT 5.

CR7
FROM, TO
2

CIRCULATE RIGHT 7.

## CR8

FROM, TO
3
CIRCULATE RIGHT 8.

CR9
FROM, TO
4
CIRCULATE RIGHT 9.

SAM
M
6

SUBTRACT A FROM MEMORY.

SBM
SUBTRACT B FROM MEMORY.

The contents of the A-register are subtracted from the specified memory location $M$. The result is placed in M.

## 4

The contents of the B-register are subtracted from the specified memory location $M$. The result is placed in $M$.

SL2
FROM, TO
2
The contents of the FROM location are shifted left 2 binary places and put into the TO location.

## SL3

## SHIFT LEFT 3.

## SL4

SHIFT LEFT 4.

## SL5

SHIFT LEFT 5.

## SL7

SHIFT LEFT 7.

## SL8

FROM, TO
3

SHIFT LEFT 8.

## SL9

FROM, TO
4
SHIFT LEFT 9.

SLD

SMA
M

## Word Times

FROM, TO
3

## 寝

## 縣

I 2(I)

SHIFT LEFT DOUBLE.
SHIFT LEFT DOUBLE.

SUBTRACT MEMORY FROM A.

The contents of registers A and B are shifted left double I number of times. Bits shifted out of $B$ (18) enter A (1). Bits shifted out of A (18) are lost. The vacated positions of the B-register are filled with zeros.

The contents of the specified memory location $M$ are subtracted from the contents of the Aregister. The result is placed in A.

M

## Word Times

## 4

SUBTRACT MEMORY FROM B.
FROM, TO
FROM, TO
SR5
FROM, TO
SHIFT RIGHT 5.
SR 7
FROM, TO
SR8
FROM, TO
SHIFT RIGHT 8.
SR9
FROM, TO
4
SHIFT RIGHT 9.
SRD
I
SHIFT RIGHT DOUBLE.

The contents of the specified memory location M are subtracted from the contents of the B -register. The result is placed in B.

SHIFT RIGHT 2.

SR3
SHIFT RIGHT 3.

SR4
SHIFT RIGHT 4.
路
FROM, TO
The contents of the FROM location are shifted right 2 binary places and placed in the TO location.
-
3
路

## SHIFT RIGHT 7.

4
SHIFT RIGHT 8.
The contents of registers A and B are shifted right I places. The vacated positions of the A-register are filled with zeros. Bits shifted out of A (1) go into B (18). Bits shifted out of B (1) are lost.

## Special Instructions

## INTERNAL FUNCTION DRIVERS

Mnemonic
DIF

DRIVE INTERNAL FUNCTION.
DIF 1

DIF 2
DIF 3
DIF 4
DIF $5-6$
DIF 7
DIF 8
DIF 9
DIF 0

## INTERNAL STATUS LINES

AND INTERNAL STATUS LINES TO Z.

Operand

I
A signal will be sent to those internal function drivers which correspond to 1 -bits in I. DIF 0 is bit position 10 in the instruction.

## Function

Reset control bit flip-flops 1 and 2, and parity bit flip-flop.
Reset the buzzer flip-flop.
Set the buzzer flip-flop.
Initiate the hardware load process.
Not assigned.
This is the SEL instruction.
Set control bit flip-flop 1.
Set control bit flip-flop 2.
Set the parity bit flip-flop.

The NIS instructions allow the program to interrogate the status of the I internal status lines. A logical AND is performed with I (1-10) and the internal status lines. NIS 0 is bit position 10 in the instruction.

The result of the AND sets the branch flip-flops in accordance with the results of the AND.

If the tested condition is true, the zero flipflop will have been set $\neq 0$. A 1 is a true condition. If the zero flip-flop is to be 0, then $\mathrm{Z}(1-10)$ must all have been 0 .

NIS $1 \quad$ Will be true if
NIS 2 Will be true if
NIS 3 Will be true if

NIS 4 Will be true if
NIS 5 Will be true if NIS 6 Will be true if

NIS 7 Will be true if NIS 8 Will be true if NIS 9 Will be true if NIS $0 \quad$ Will be true if

The character parity output of the parity network is a 1. $1=$ odd parity, $0=$ even parity.
The word parity output of the parity network is a 1. $1=$ odd parity, $0=$ even parity.
Control bit flip-flop 2 and the word parity output of the parity network are identical. This is intended for use when transmitting data with error-correcting techniques.
The MANUAL/PROGRAM switch is in the MANUAL position.
Not assigned.
Status is present in memory location 6. Used only with the CSU931.
Controller selector is ready.
Control bit flip-flop 1 is a 1.
Control bit flip-flop 2 is a 1.
The parity bit flip-flop is a 1.


Bit Positions of NIS, NES, DEF, and DIF Instructions

Mnemonic

LDF

LOAD SPECIAL FLIP-FLOPS.

Selected bits from the contents of $\mathbf{M}$ are used to restore the conditions (saved by an STF instruction) of the plus, zero, even, control bit 1, control bit 2, and parity flip-flops. Bit position 1 goes to the even flip-flop. Bit position 2 goes to the zero flip-flop and bit position 18 goes to the plus flip-flop. Bits 8,9 , and 10 go to control bit flip-flops 1 and 2 and the parity flip-flop, respectively.


STORE SPECIAL FLIP-FLOPS.

HLT

M
The conditions of the plus, zero, even, control bit 1, control bit 2, and parity flip-flops are stored in $M$ in positions $18,2,1,8,9$, and 10 , respectively (same as in LDF).

I

1

CONDITIONAL HALT.
If the MANUAL/PROGRAM switch is in the MANUAL position and the HALT DISABLE light is off, the DATANET-30 will halt. If the key switch is in the PROGRAM position, Hardware Load is initiated. If the key switch is in MANUAL position and the HALT DISABLE light is on, a Halt instruction is ignored.

## Buffer Selector Instructions

There are six buffer selector instructions. The register transfer FROM R, and the register transfer TO T have already been covered.

## Mnemonic <br> LDT <br> LOAD T. <br> EXTERNAL FUNCTION DRIVERS

Operand

M

DEF

## I

DRIVE EXTERNAL FUNCTION. (Bit positions 1-10 in the instruction correspond directly to the DEF instruction number. (DEF 0 is used for line 10.)

## EXTERNAL STATUS LINES

## NES

## I

AND EXTERNAL STATUS

## LINES TO Z

(Bit positions 1-10 in the instruction correspond directly to the NES instruction number. (NES 0 is used for line 10.)

SCAN.

## Word Times

## 2

The contents of $M$ are sent to the transmit data drivers and from there to whichever channel has been preselected by the contents of the Ccounter. The contents of M are unchanged. Use of this instruction is restricted to certain buffers on the buffer selector.

## The Option Module Instructions

The option module instructions are covered in the appendix for the particular option module.

When computer type peripheral equipment is used, the instructions for the peripheral equipment are included in the appendix for the option module interfacing with the peripheral equipment.

The table of contents shows the appendix applicable to an individual option module.

## III. ADDRESSING MEMORY

## GENERAL DESCRIPTION

The address field of the instruction is divided into a partial memory address and an addressing mode.

| 12 | 109 |  | 1 |
| :--- | :--- | :---: | :---: |
| MODE | PARTIAL <br> ADDRESS |  |  |

The four modes for addressing memory are:

1. Program Bank addressing
2. Common Data Bank addressing
3. Channel Table addressing
4. Indirect

Bit Positions

| 12 | 11 | 10 |  |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | First Half Program Bank-Direct |
| 0 | 0 | 1 | Second Half Program Bank-Direct |
| 0 | 1 | 0 | Common Data Bank addressing |
| 0 | 1 | 1 | Channel Table Address |
| 1 | 0 | 0 | First Half Program Bank-Indirect |
| 1 | 0 | 1 | Second Half Program Bank-Indirect |
| 1 | 1 | 0 | Common Data Bank-Indirect |
| 1 | 1 | 1 | Channel Table Address-Indirect |

## DETAILED DESCRIPTION

The following descriptions of the hardware aspects of memory addressing are given for use when debugging programs. The assembly program automatically assigns proper addressing for each instruction.

## Program Bank Addressing

Program bank addressing can only address locations in the common data bank or another location in the same program bank. The addresses within 1024 memory locations of the base location of the program bank in which the instruction is located may be directly addressed by an instruction within the program bank.

The sixteen 1024 -word program banks for a 16,384 -word memory are listed in the table below:

| $\underline{\text { Program Bank }}$ | Memory Locations |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Start |  |  | End |  |
|  | Decimal | Octal |  | Decimal | Octal |
| 1 | 0000 | 0000 | to | 1023 | 1777 |
| 2 | 1024 | 2000 | to | 2047 | 3777 |
| 3 | 2048 | 4000 | to | 3071 | 5777 |
| 4 | 3072 | 6000 | to | 4095 | 7777 |
| 5 | +096 | 10000 | to | 5119 | 11777 |
| 6 | 5120 | 12000 | to | 6143 | 13777 |
| 7 | 6144 | 14000 | to | 7167 | 15777 |
| 8 | 7168 | 16000 | to | 8191 | 17777 |
| 9 | 8192 | 20000 | to | 9215 | 21777 |
| 10 | 9216 | 22000 | to | 10239 | 23777 |
| 11 | 10240 | 24000 | to | 11263 | 25777 |
| 12 | 11264 | 26000 | to | 12287 | 27777 |
| 13 | 12288 | 30000 | to | 13311 | 31777 |
| 14 | 13312 | 32000 | to | 14335 | 33777 |
| 15 | $1-336$ | 34000 | to | 15359 | 35777 |
| 16 | 15360 | 36000 | to | 16383 | 37777 |

Each program bank has upper and lower limits for direct addressing. When it is necessary to go from one program bank to another, indirect addressing is used. When approaching the upper limit of a program bank, some caution is necessary regarding the type of instruction placed in the last location of the program bank. Upon the execution of the last instruction in a program bank, the P-counter contains the address of the first instruction in the next program bank. If a branch instruction is in the last location, the program will branch to the corresponding address in the next program bank.

There are two ways to change from one program bank to another:

1. The P-counter counts up past the program bank boundary.
2. A branch instruction is given in the indirect mode.


## Common Data Bank Addressing

The common data bank is the first 512 words of memory and may be addressed directly from any location in memory. In the following example, common data bank addressing is denoted by the 2 in the third digit of the octal instruction. All instructions that refer to an address in the common data bank will always be assigned common data bank addressing by the assembly program, unless the instruction itself is in the first program bank.

| Location | Instruction | OPR | Operand | Remarks |
| :---: | :---: | :---: | :---: | :---: |
|  | 11610 | ORG | 5000 |  |
| 11610 | 402024 | LDA | 20 | LOAD A-register with contents cell 2010 |
| 11611 | 702231 | STB | 153 | STORE B-register in location 15310 |
| 11612 | 342764 | ADO | 500 | ADD one to location 50010 |

## Channel Table Addressing

A channel table must be symbolic and start with the character $\$$. The starting locations of the channel table must be a multiple of 16 decimal and located in the first 8192 words of memory. The channel table may be addressed directly from anywhere in memory. The maximum table length is 128 locations. When referred to, the base address (starting location) is automatically indexed by the C-register. The channel table addressing mode will be assigned to any instruction which refers to a channel table (\$ - -).

Example 1:

|  | ORG | 512 |
| :---: | :---: | :---: |
| \$SW1 | DEC 0 |  |
|  | . |  |
|  | . |  |
|  |  | Scan Word Table Channel 0 |
|  |  |  |

Example 2:
ORG 608
\$POINT DEC 0
Pointer for Channel 0
. Pointer for Channel 1

Example 3:

|  |  | ORG | 2048 |
| :--- | :--- | :--- | :--- |
| 4000 | 403040 | PIC | 1 |
| LDA | \$SW1 |  |  |

The A-register is loaded with the contents of location 513 (Location 512 + value of C-register)

If the number of channels (table size) exceeds 16 , the location of the table must be a multiple of the next higher power of 2 .

Example:

## Number of Channels

$$
1-16
$$

Starting location must be a multiple of
$17-32 \quad 16$

17-3232
33-64 ..... 64
65-128 ..... 128

## Indirect Addressing

Indirect addressing (2nd level addressing) is where the address part of an instruction is the location in memory where the address of the operand may be found or is to be stored.

If the format of the assembly program run on a GE-225 system is used, indirect addressing is specified in an instruction when an X is placed in the index column (column 20) of the coding sheet. If the format of the assembly program run on the DATANET-30 is used, indirect addressing is specified by a comma immediately following the operand.

Indirect addressing must be used to access an address in another Program Bank, with the exception of the Common Data Bank or Channel Table. It must also be used to branch across bank boundries.

Indirect address (second level address) example:


## Indexing

During indirect addressing, the first operand address can be indexed by any one of $\mathrm{A}-$, $\mathrm{B}-$, or C registers by specifying which register in the pointer. Bits 16-17 of the indirect address word specify which register to be used for indexing as follows:

| Bits $(18-17-16)$ | Function | Pseudo- <br> Operation |
| :---: | :--- | :--- |
|  | No indexing | IND |
| 000 | Index by A | INA Base address indexed by contents of A |
| 001 | Index by B | INB Base address indexed by contents of B |
| 011 | Index by C | INC Base address indexed by contents of C |

The pseudo-operations IND, INA, INB, and INC are used by the assembly program to automatically add these bits as required.


## Subroutine Linkage

Indirect addressing and a special Branch Subroutine (BRS) instruction provide a means for getting to and from subroutines and program banks. The BRS command is a 3-word-time instruction which, during the first execution cycle, stores $\mathrm{P}+1$ (the address of the word following the BRS) in memory location $M$ and during the second cycle loads the contents of ( $M+1$ ) into the P -counter, as follows:

| ALPHA | BRS | SUBRN | Transfer to Subroutine |
| :--- | :---: | :--- | :--- | :--- |
|  | LDA | 0 | Continue |
|  | $\cdot$ |  |  |
| SUBRN | IND | 0 | Subroutine linkage |
|  | IND | SUBRN 1 |  |
| SUBRN1 | LDB | SUBRN | Start of subroutine |
|  | $\cdot$ |  | Exit from subroutine |

When the BRS at location ALPHA is executed:

1. The P-counter +1 is stored in SUBRN.
2. The program branches to location contained in SUBRN +1 .
3. The subroutine is executed. This subroutine may be located anywhere in memory.
4. The exit from the subroutine via the BRU SUBRN X causes the contents of SUBRN (location ALPHA +1 ) to be loaded into P.
5. The LDA instruction following the BRS is executed after execution of the subroutine.

Thus, 1 instruction (BRS), 2 words in memory (SUBRN and SUBRN+1), and 5 word times (BRS and BRU X) are needed for the general subroutine linkage, since the two linkage words are normally in the common data bank and can be accessed from anywhere in memory.

This technique of subroutine linkage has these advantages:

1. Only one instruction is needed in the main program to call a subroutine.
2. The subroutine may be located anywhere in memory at no sacrifice in time or memory.
3. The subroutine may be called from anywhere in memory at no sacrifice in time or memory.
4. The program can branch to the subroutine and return to the point of the branch, or elsewhere, depending on the purpose of the subroutine.
5. All subroutine linkage bookkeeping is handled by hardware and not by the main program or the subroutine.
6. All three registers, $A, B$, and $C$, may be used for input to the subroutine, since no register is used for linkage.

The following rules must be observed when using the subroutine BRS command:

1. The first word of the subroutine linkage must be in an even location. (The assembly program will error tag an odd location or force it to an even location.)
2. The subroutine linkage must be placed in a common location to both program points; that is, common data bank, same program bank.

## MEMORY ADDRESSING USING THE ASSEMBLY PROGRAM

The previous discussion has centered on describing the memory addressing features built into the DATANET-30. This section will describe the memory addressing features built into the assembly program.

The assembly program instruction mnemonics and pseudo-operations provide a technique for program preparation. This is particularly true with respect to memory addressing, since the assembly program does a great deal of the generation and validity checking of addresses.

The assembly program provides facility for the assignment of addresses relative to some starting point (relative addressing). Assume, for example, that the symbol $B$ is equal to memory location 0500. Using the technique of relative addressing, memory location 0510 can now be addressed by writing $\mathrm{B}+10$ in the operand field of the coding sheet:

| Symbol | Operation | Operand |
| :---: | :---: | :---: |
| B | EQU | 500 |
|  | LDA | B |
|  | - |  |
|  | - |  |
|  | - |  |
|  | LDA | $B+10$ |

The EQU pseudo-operation equates the symbol $B$ to memory location 0500 . The instruction LDA (Load Register A) loads the A-register with the contents of memory location 0500. The next LDA instruction, some program steps later, loads register A with the contents of B+10 (location $0500+10=0512$ ).

The assembly program will interpret an asterisk (*) in the operand field on input data to mean the address of that instruction. The $*$ serves as a flag to the assembly program and causes the performance of a special calculation to generate the desired address.
$\frac{\text { Location }}{05000} \quad \frac{\text { Instruction }}{\text { LDA } *+10}$

In this example, ${ }^{*}=05000$ and the relative address ${ }^{*}+10$ will be 05012.

The assembly program is also flagged by the character X in the " X " column. This indicates that indirect addressing is desired on that instruction. The assembly program generates the desired address according to the standard rules and then adds a 1 -bit in I (12). One other special requirement must be flagged to the assembly program by the programmer. When it is desired to use channel table addressing, a symbolic operand must be used and the symbol must start with the character $\$$ (dollar sign). The assembly program, upon finding this condition, will assign addressing mode 3 (channel table addressing) by making $\mathrm{I}(10-11)=11$. It then checks the location of the symbol, verifies that it is less than 8192 and that it is a multiple of 16 (that the low-order 4 bits are all zero), divides the location by 16 and inserts the remaining 9 significant bits in the instruction. To use this mode properly, the symbol must start with a $\$$ sign, and must be in a modulo 16 address in the first 8192 words of memory.

The two remaining techniques for specifying the desired address are pure symbolic and decimal. Examples of these are:

| LDA | CONST3 |
| :--- | :--- |
| LDA | WS1 |
| LDA | 5 |
| LDA | 511 |
| LDA | 8000 |

CONST 3 and WS1 are symbolic addresses; and 5, 511, and 8000 are decimal addresses. The assembly program checks the desired address, to determine if it is in the same program bank as the instruction being assembled. If it is, address modification mode 0 or 1 (program bank addressing) is assigned along with the correct partial address. If it is not in the same program bank, it is checked for being in the common data bank. If it is, address modification mode 2 (common data bank addressing) is assigned along with the correct partial address. If neither case applies, it is not possible to generate the address directly. The assembly program flags this condition with an $A$ on the assembly program output listing. This indicates an invalid address and must be corrected.

With program banks of 1024 words, most desired addresses will be either in the common data bank or in the same program bank. The first assembly by the assembly program will indicate the addresses which need to be changed to indirect addressing.

## IV. CONTROL CONSOLE

The control console (Figure 11) serves both operator and maintenance functions. The control exercised by the console is not usually used during normal program execution. Control from the console is concerned with initially loading the program into memory, starting the execution thereof, monitoring the progress of the program, and program debugging.

The switches and lights and their more important functions are:

1. The contents of the $\mathrm{A}-, \mathrm{B}-, \mathrm{C}$ - and P-registers may be modified directly from the control console.
2. The contents of memory may be displayed in the M-register. The P-counter is used to specify the memory location to be displayed.
3. The P -counter is automatically incremented so that sequential locations in memory may be displayed by depressing the SINGLE CYCLE button.
4. The contents of memory may be modified by the 18 INSERT SWITCHES.
5. The automatic loading of a program may be initiated from the control console (Hardware Load).

## the mode select pushbutton switches

The SET A, B, C, and P Button
The following steps are used to set the $\mathrm{A}, \mathrm{B}$ or C registers and the P -counter to a desired configuration.

1. Press the Set $\mathrm{A}, \mathrm{B}, \mathrm{C}$, or P button.
2. Lift the INSERT SWITCHES under the register position to be inserted.
3. The inserted configuration is immediately set up in the desired register (counter).

## The INSERT MEMORY Button

The following steps are used to insert data into memory:

1. Press SET P button.
2. Put desired memory address in the P-counter.
3. Press the INSERT MEMORY button.
4. Lift the INSERT SWITCHES to the desired input. The input is indicated in the Yregister.
5. Press the SINGLE CYCLE button. The input from the Y-register is transferred to the memory location specified by the P-counter. The P-counter will count up 1.
6. Repeat 4 and 5 for consecutive positions; repeat 1 through 5 for nonconsecutive positions.
7. Do 1 and 2 to set the P -counter to starting location.
8. Press the PROGRAM RUN button, then the RUN button to start the program. The program will start at the location specified by the P -counter.
9. Press the PROGRAM RUN button, then the RUN button to start the program. The program will start at the location specified by the P-counter.

## The DISPLAY MEMORY Button

The following steps allow the contents of memory to be displayed:

1. Press the SINGLE CYCLE button to halt.
2. Press DISPLAY MEMORY button.
3. Press SINGLE CYCLE. The contents of memory location as specified by the P-counter are displayed in the M-register. The $P$ counter counts up 1.
4. The contents of the other registers will be as previously defined under description of registers.

## THE ERROR LIGHT AND BUZZER

The ERROR light and buzzer are used to indicate that data read out of memory does not agree with the INSERT SWITCHES.

If a DIF 3 instruction is executed, the error light will turn on. This does not indicate an alert halt and the program will continue to run.

The error light and buzzer only work in either the DISPLAY MEMORY or INSERT MEMORY mode. The error light does not refer to an error in an operating program. The error light and buzzer are both turned on and off with the DIF 3 and DIF 2 instructions.

If the INSERT MEMORY or DISPLAY MEMORY mode is set, the RUN button has been pressed, and the HALT/DISABLE switch is in the HALT position, the error light turning on will indicate an error, halt the DATANET-30, and the location of the error will be indicated in the L-register. This is mainly a maintenance feature.

## POWER-ON SEQUENCE

The power-on sequence is shown below:

1. Turn on main circuit breaker located behind the front panel of rack 3.
2. Press AC ON button
3. Wait 10 seconds, then press DC ON button.
4. Press MANUAL RESET.


Figure 11. Control Console Switches


Figure 11. Control Console Switches (con't)

## V. PROGRAMMING CONSIDERATIONS

## PROGRAMMING THE BUFFERS

## Service Rate

When servicing transmission lines on a bit basis there are certain timing factors which must be taken into account. The following table shows the service rate for six standard teletype transmission speeds:

## Bits per Second

Service Rate (milliseconds)

## 45 <br> 22.2

50
20.0
56.25
17.7

75
13.3

## 110 <br> 9.09

150
6.67

In each case, the service rate can be defined as the operation of the receive or transmit flag of the bit buffer.

When scanning the bit buffers, the service rate is taken into account and the Program Interrupt Executive initiates scanning at a rate slightly faster than the service rate. For a 45 -bit/second transmission line having a service time of 22.2 milliseconds, the line would be scanned approximately every 21.0 milliseconds to ensure that any speed variations in the remote terminal would not result in data lost at the DATANET-30.

## Basic Program Cycle

A real time program response time to certain events must be very small. The communications programs must be divided into the following events:

1. Receive bits
2. Assemble bits into characters
3. Assemble characters into words
4. Assemble words into blocks
5. Assemble blocks into messages
6. Assign message routing
7. Disassemble blocks into words for transmission
8. Disassemble words into characters
9. Put the character in the buffer for transmission.

The program to do this is divided into two basic cycles.

1. Line service cycle (hardware scan and program scan) -- when each buffer is sampled within a bit or character time and the bit or character present is moved to or from the buffer.
2. Processing cycle-- when all the rest of the processing to be done by the program must be accomplished. The bit buffer assembly areas and the other buffers are serviced on a character time bases.

Since a basic premise of the DATANET-30 is to receive (or transmit) each bit or character within rigid time limitations, the line service cycle must be initiated within a certain amount of time.


The time will vary with the line service rate required by the remote terminals. One full cycle must therefore be completed at a rate slightly faster than the fastest service rate. In order to do this, processing must be interrupted to allow the hardware scan instruction to service the lines ( 3 word times per line). The interruption must be timed so that, from the end of one scan cycle to the end of the next scan cycle, the total elapsed time is less than one bit time. Consideration must also be given to memory cycles used during the scan by the controller selector peripherals.

Although the above only discussed the bit time for the bit buffers, the scanning and processing of character and word buffers follow the same rules. The scanning of character and word buffers however is done by programming for each buffer.

The control of data transfer going to or from a buffer is accomplished by the register transfer instructions, the C-register and the transmit/receive data lines. The receive buffer address in the C-register allows the character or word in the receive buffer to be set up on the receive data lines. The register transfer instruction -- that is, TRA R, B -- then transfers the configuration of the receive data lines to the designated working register.

The transmit sequence using the transmit data lines is basically the opposite of the sequence using the receive data lines. The address of the transmit buffer is first set up in the C-register. Then the transfer of the configuration in one of the FROM registers, again using a register transfer instruction, is transferred to the transmit data lines. The only transmit buffer that will be able to accept the configuration on the transmit data lines will be the one addressed by the C-register.


Figure 12. General Timing Diagram



Figure 13. Relative Timing for Scanning Buffers

## Functional Sequence

The normal flow of data occurs as shown below. The program periodically halts to allow the SCN instruction to take bits from the bit buffers to form characters in memory. When a character is formed, it is transferred over to another area of memory where the program accumulates characters into words. The words are accumulated into blocks of variable lengths and then transferred to the disc storage unit, where the queue, journal, intercept, and in-transit storage areas are established under program control. The same basic process occurs for the character and word buffers. However, all other buffers must be scanned by the program.


Figure 14. Data Flow Functional Block Diagram

## PROGRAMMING CONVENTIONS

In writing programs for the DATANET-30, there are a few conventions which should be considered. The suggestions made here are not hard and fast rules, but must be considered for maximum programming efficiency:

1. Do not use locations 0 and 1 in memory; these locations are used by program interrupt. When the Q -counter counts down to zero, $\mathrm{P}+1$ is stored in location 0 and control is transferred to the location specified by location 1.
2. Do not use cells 3, 4, and 5. These locations are used by the controller selector unit for storage of command words.
3. If possible, all subroutine linkages and constants should be located in the common data bank (cells 8 - 511 in memory).
4. Channel tables must be located in the first 8192 words of memory.
5. Utility routines should be stored at the top of the memory, so that they will not be destroyed when reading in later programs.
6. The following checks should be made:
a. Before issuing any SEL instruction, check the ready status of the controller with the CSR instruction.
b. Before issuing any CSR instruction, check for the completion of the previous SEL sequence with an NIS 7 instruction.
c. Before changing memory locations 3,4 , and 5 , check for completion of the previous SEL sequence with an NIS 7 instruction.
7. When closing a file on magnetic tape always write an end of file on the tape.
8. When branching to a subroutine, the symbolic name of the subroutine link will be followed by 1 :

|  | $\sum_{\text {REPRT }}^{\text {BRS }}$ | REPRT |
| :--- | :--- | :--- |
| IND 0 | Go to report subroutine |  |
| IND | REPRT1 | Subroutine linkage <br> REPRT 1 is the actual starting <br> address of the subroutine. |

9. The last character to be transmitted at the end of transmitting a message must be an all marks character (all 1's).
10. At the end of each program bank, careful consideration should be given to the instructions in the last 2 positions and to those instructions that fell into the succeeding program bank.
11. The following memory allocation has been established as a standard programming convention:
$\underline{\text { Decimal Location }}$

0000 - 0007
0008-0031
0032-0511
512-1023
1024-7499
$7500-7999$
8000-8191

Contents
Program interrupt and controller selector command words Parameters for utility routines and general use
Program constants, subroutine linkage
Scan words (channel tables) and constants
Object programs
Utility programs and programming tools
Loader programs
12. The C-register instructions (PIC, AIC, XCZ, NCZ) will have decimal or symbolic operands which will be assembled as a numerical value rather than a memory address.
13. If a symbol has been referred to by a double-length instruction before the symbol is defined, the symbol will be forced to an even location. Zeros are inserted in the vacated odd location.

## BUFFER OPERATIONS

## Bit Buffer Channel

Data is sent to a buffer via the transmit data drivers. Data is received from a buffer via the receive data lines. Control signals are sent to a buffer by the DEF instructions. Information as to the status of a buffer is tested by the NES instructions.

The bit buffers are available in two models: BBC930G1 and BBC931G4. Each model can interface with a Voltage Current Adaptor (VCA), a 103 A or 103 F data set. The DEF and NES instructions for a bit buffer are different, depending on the model used and the type of line interface.

| DEF Instructions BBC930G1, G2 | NES Instructions |
| :--- | ---: |
| - Reset receive flag and buffer | 1 - Receive data flag set |
| 2 - Reset transmit flag and buffer | 2 - Transmit data flag set |
| 3 - Reset request to send (103F) | $3-8$ - Not used |
| Reset data terminal ready (103A) | 9 - Test receive line |
| 4 - Set request to send (103F) | 0 - Not used |
| Set data terminal ready (103A) |  |
| 5 - Reset receive clock |  |
| 6 - Set Echoplex mode |  |
| 7 - Reset Echoplex mode |  |
| $8-0$ Not used |  |

## BIT BUFFER INSTRUCTIONS

MnemonicOperand
Word Times
Register Transfer
TRA
R,
FROM, TO The bit contained in the receive buffer istransferred to position 18 of R to position 18of $Y$ and then according to the register transferinstructions. The receive buffer and flag arereset.
Register Transfer ..... , T
TRAFROM, TOBit 1 of the Z-drivers is transferred to thetransmit data buffer. The transmit flag isreset.
SCN ..... I
SCAN
DEF Instructions BBC931G4,G5
1 - Reset receive flag and buffer
2 - Reset transmit flag and buffer
3 - Reset request to send (103F)Reset data terminal ready (103A)
4 - Set request to send (103F)
Set data terminal ready (103A)
5 - Reset receive clock
6 - Set restraint (103A)
Set originate mode (103F)
7 - Reset restraint (103A)
Reset originate mode (103F)
8-0 - Not used

## $1+3 \mathrm{~N}$

Scan the bit buffer units. The bit buffers are interrogated for data received or to be transmitted. Data is moved to and from the bit buffers. I is the number of the starting channel. N is the number of bit buffers scanned.

NES Instructions
1 - Receive data flag set
2 - Transmit flag set
3-4 - Not used
5 - Data set ready (interlock on)
6 - Carrier off (103F)
7 - Not used
8 - Supervisory receive data
9 - Test receive data
0 - Not used

The DEF and NES instructions for other bit buffers not shown here are furnished on an individual basis.

## RECEIVE OPERATION

Assume that a remote terminal device is sending out a continuous stream of marks, (the line is in the idle condition). Then the operator at the remote terminal begins transmitting information. When the start bit (a space) is received, a clock is started. The clock is used to time the future sampling of the line. The start bit is transferred into the receive data buffer by the bit buffer channel (BBC), and the receive flag is set. When the clock reaches the proper time, the line is sampled again, the bit on the line is transferred to the receive data buffer, and the receive flag is set. This process of sampling the line at regular intervals, transferring the data on the line to the receive data buffer, and setting the receive flag continues until the clock of the BBC is stopped by the program. Since the BBC will transfer the information from the line into the receive data buffer every bit time, the program must test the receive flag and take away the bit in the receive data buffer before the line is sampled again by the BBC.

Whenever the bit is taken, the receive flag and the receive data buffer are automatically reset. At some point, the program decides that the appropriate number of bits have been received and sends a signal to the BBC which stops the clock. The receive flag will remain reset until another start bit is received. As a protection against noise on the transmission line causing the clock to start running, the BBC circuitry requires the space condition to exist on the line for at least one-half of a bit-time to start the clock. Thus, noise of less duration than one-half of a bit-time will have no effect.

A BBC can be used with a half-duplex line by ignoring the receive section when sending and by ignoring the transmit section when receiving. If a subset is used, control of the carrier is accomplished by activating the appropriate external function driver (with a DEF instruction).

The following timing diagram shows how the character $Y$ would be received by a bit buffer as a 5-level teletype character.


1. When a start pulse is received the clock in the receive unit is started and the line is sampled in the center of each bit period of the character.
2. The receive flag is set when the line is sampled and the bit is sent to the receive data buffer.
3. The data buffer temporarily stores the bit which has just come in from the line.
4. The program tests to see if the flag is set. If it is, the program will transfer the bit to a register. Transferring the bit will automatically reset the receive flag and data buffer by issuing a DEF1 instruction.
5. After the complete character is received the program initiates a DEF5 instruction which resets the clock. The clock will not be set again until another start bit is received.

## TRANSMIT OPERATION

Assume that the program is not transmitting and that the transmit flag is set. This means that the BBC is ready to take a new bit from the program. The program sends a bit to the transmit data buffer. This automatically resets the transmit flag. At regular intervals, the BBC transfers the bit in the transmit data buffer to the transmission line. When this happens, the transmit data buffer shifts a bit onto the line, whether or not a new bit has been supplied. The program must test the transmit flag and provide a new bit before this transfer occurs. This process will repeat for each bit in the bit stream. At the end of the bit stream, the last bit will remain in the transmit data buffer and will be transferred to the line regularly. Therefore, the last bit in a bit stream will be a 1, so that the line remains in the mark condition when no information is being transmitted. Note that with a BBC the length of the bit stream is completely under program control.

The next diagram illustrates how the character $R$ would be transmitted to a communications line. The character $R$ would be represented in memory as 11101010 , where the right-hand 0 is the start bit and the two left-hand 1's are the stop bits. The 5 bits in between the start bit and stop bits represent the 5 -level teletype code for the letter $R$.

1. The transmit clock occurs every bit period as specified by the data timing unit.
2. The transmit flag is set each time the transmit clock occurs and is reset when the data is transferred to the transmit buffer.
3. When the program finds the transmit flag set, it transfers the next data bit to the BBC, which automatically resets the transmit flag.
4. This shows how the transmit buffer would look over a period of one character time.
5. This shows the signal as it appears on the line.
6. Transmit Clock

7. Transmit Flag

8. Data Transfer
9. Transmit Buffer

10. Transmit Line


## HARDWARE SCAN

The SCN instruction is for use with the bit channels only. It will not operate properly with any other buffer unit. Therefore, only bit buffers should be among the channels from $C_{i}$ to $C_{f}$. This means that all bit buffer channels should be addressed sequentially.

Bit buffer channel addresses can not be intermixed with character buffer channels or word buffer channels.

The initial channel to be scanned is specified in the instruction. The final channel to be scanned is specified by the scan words or channel 127, whichever occurs first. Channels are scanned sequentially as follows:

$$
C_{i}, \quad C_{i+1}, \quad C_{i+2}, \cdots, \quad C_{f-2}, \quad C_{f-1}, \quad C_{f}
$$

where
$C_{i}$ is the initial channel,
$\mathrm{C}_{\mathrm{f}}^{1}$ is the final channel, and
$\mathrm{N}^{\mathrm{f}}=$ number of channels scanned
$=\mathrm{f}-\mathrm{i}+1$.

The time required for $S C N$ is one word time for setup plus three word times for each channel scanned, or:

Word Times $=1+3 \mathrm{~N}$.

This time is required whether data is transferred or not. Also, this time is required for a simplex, half-duplex, or full-duplex channel.

The SCN instruction uses the $A$ and $B$ registers, and the previous conterts will be destroyed. Also. the C-register will contain $C_{f}$ after it is completed. At the end of a Transmission, the last word placed in scan word one continues to be transmitted. It is necessary to put a word of all marks in scan word one for idle line condition.

DEF1, DEF2, DEF5, NES1, NES2, and all data transfer is handled automatically by the SCN instruction. The program must, however, give the DEF3 and DEF4 instructions appropriately.

Scan Word 1


It is possible to transmit $5-, 6-, 7-$, and $8-l e v e l$ codes of $8,9,10$, and 11 bits. The format for 5-level, 8-unit codes is:


The format for 8 -level, 11 -unit codes is:


The format for 6- and 7-level codes is similar.

It is sometimes necessary to transmit one or more fill characters. A delay time of one character is a marking condition on the line for one character time. This can be achieved by making the start bits, data bits, and stop bits all 1's. This should also be the last character transmitted at the end of transmitting a message. A one-character delay for 8 -level, 11-unit codes is as follows:


The end-of-character bit is defined as the last 1-bit in the field. This must be present. If not, the last 1 -bit of data will be interpreted as the end-of-character bit.

To initialize scan word 1, the start, data, stop, and end-of-character bits must be set to all ones and the rest must be zero filled.


SW2F1 is controlled entirely by hardware and requires no detail program control. The bits are shifted right to the bit buffer channel and then to the line until the end-of-character bit is in position 1. This occurs when SW2F1 is (000000000001).

SW2F2 is set to indicate the final bit buffer channel number when the program is initially assembled and thereafter need not be considered. It is necessary to change SW2F2 for the final channel for any change in the number of bit buffer channels:
$1=$ this is the last bit buffer to be scanned.
$0=$ continue scanning.

If the final channel is not indicated, the SCN instruction will automatically end at channel 63 in Model 1 and at channel 127 in Models 2 and 3.

SW2F3 defines for receive purposes the code level of the line (5, 6, 7 or 8 ). This is set when the program is initially assembled (or changed octally) and thereafter need not be considered.

SW2F3 (Bits 17 and 16)

## 1716

$00=5$-level code
$01=6$-level code
$10=7$-level code
11 = 8 -level code

SW2F4 is set by the hardware when the new transmit character is transferred from SW1F1 to SW2F1. It is reset by the program after the new character is loaded into SW1F1.
$1=$ SW1F1 is ready for a new character
$0=$ SW1F1 is not ready for a new character.

To initialize scan word 2, bit positions 1-12 are set the same as in scan word 1. Bit position 15 is set in the last line to be scanned. Bits 17 and 16 must be set in each scan word in accordance with the code level for that line and bit 18 is always zero.

## Scan Word 3

SW3F1 is set by the hardware when SW3F2 receives a full character as defined by SW2F3. The data bits of SW3F1 will be in the following positions:

5-level code in positions 2-6. Positions 7-9 are 0. 6 -level code in positions 2-7. Positions $8-9$ are 0. 7 -level code in positions $2-8$. Position 9 is 0.
8 -level code in positions 2-9.


SW3F2 is controlled entirely by hardware and requires no program control.

SW3F3 is set by the hardware when the new received character is transferred from SW3F2 to SW3F1. It is reset by the program after the new character is removed from SW3F1. SW3F1 does not have to be changed by the program.

SW3F3
$1=$ SW3F1 has a new character
$0=$ SW3F1 does not have a new character.

Initialize scan word 3 as all zeros.

Scan Word Locations in Memory

The three scan words per line are located in memory as follows.

|  |  | Location |  |
| :---: | :---: | :---: | :---: |
|  |  | Decimal | Octal |
| Scan Word $1\{$ | $\begin{array}{ll}\text { Channel } \\ \text { Channe1 } & 0 \\ 1\end{array}$ | 512 513 | $\begin{aligned} & 1000 \\ & 1001 \end{aligned}$ |
|  | . | - |  |
|  |  |  |  |
|  | Channel 127 | 639 | 1177 |
| Scan Word 2 \{ | Channel 0 | 640 | 1200 |
|  | Channel 1 | 641 | 1201 |
|  | . | . |  |
|  |  | $\stackrel{.}{ }$ |  |
|  | Channel 127 | 767 | 1377 |
| Scan Word $3\{$ | Channel 0 | 768 | 1400 |
|  | Channel 1 | 769 | 1401 |
|  | . | . |  |
|  |  | . |  |
|  | Channel 127 | 895 | 1577 |

Any of the 384 locations not used for scanning BBC's, may be used for any other purpose. For example, channel 0 is used for the paper tape reader and the scan instruction does not apply to paper tape. Scan words 1, 2 and 3 for the paper tape reader are wired in hardware.

## Receive and Transmit

The Scan instruction accomplishes the following at a rate necessary to check each bit buffer once each bit time.

## Receive

When a start bit appears in the bit buffer, the receive flag is set. The SCN instruction transfers the bit to the character-being-received half of scan word 3 , and resets the receive flag. When the next bit of the character appears in the bit buffer, the receive flag is set, the SCN instruction shifts the previous bit over 1 position and transfers in the new bit of the character. Prior to each shift and transfer of a bit, the SCN instruction checks for whether or not the bit in the bit buffer is the last bit for the character. When the last bit is in the bit buffer, the character is shifted to the last-character-received side and the last bit is shifted in also. The character must then be shifted out by the program before another character is fully received. New characters are shifted into the last-character-received side whether the preceding one was shifted out or not.


Figure 15. Hardware Scan Block Diagram

## Transmit

Assuming that the transmit mode has been set, once each scan cycle a bit will be transmitted from the bit buffer. If nothing is to be transmitted, the line should be in a marking condition (idle). Scan word 2 contains the character being transmitted. Upon the completion of transmitting a character from scan word 2 , the character in scan word 1 is transferred into scan word 2, and automatically transmitted. The program loads scan word 1 with the next character to be transmitted.

## PROGRAM INTERRUPT

Program interrupt occurs under control of the Q-counter. When $Q$ counts to zero, the following sequence occurs:

1. The instruction being executed is completed. This can take from 1 to 10 (ten word times is the *worst case execution time of the CSR instruction) word times, depending on the instruction.
2. If a memory interrupt is requested by the controller selector, 1 word time is taken to service the request.
3. Effectively, a BRS 0 is executed. This operation requires 2 word times plus execution of the program. Interrupt can take from 3 to 13 word times.

If Alpha is the location of the instruction being executed when the program interrupt occurred, then the BRS 0 performs the following:

1. Alpha +1 is stored in location 0 .
2. The contents of location 1 is transferred to the P-register and program execution started there.

The Program Interrupt Routine must begin with:

| * STF | WS1 | Store special flip-flops |
| :--- | :--- | :--- |
| STD | WS2 | Store A and B |
| STC | WS3 | Store C |
| LDB | Count | Load Q with new value |

The Program Interrupt Routine must end with:

| * LDC | WS3 |  | Load C |
| :--- | :--- | :--- | :--- |
| LDD | WS2 |  | Load A and B |
| LDF | WS1 |  | Load special flip-flops |
| BRU | 0 | X | Return to point of interrupt |

The Program Interrupt Routine will normally include execution of the Scan instruction. Also, the worst case execution of the Program Interrupt Routine will be less than the time period between program interrupts. Thus, a program interrupt cannot occur while a Scan instruction is being executed. A program interrupt during an SCN instruction cannot be successfully done.

## PROGRAMMING EXAMPLES, BIT BUFFER CHANNEL

The following example shows one method that might be used to receive one character from a bit buffer. This method does not use the SCN instruction, and therefore is rarely used.

| Location | Instruction | Symbol | OPR | Operand | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 15530 |  | ORG | 7000 | ORIGIN LOCATION 7000 |
| 15530 | 011006 |  | PIC | 6 | ADDRESS OF BIT BUFFER |
| 15531 | 600000 | RECVE | LDB | BIT7 | bit number seven |
| 15532 | 022001 |  | NES | 1 | RECEIVE FLAG SET |
| 15533 | 121531 |  | BZE | *-1 | NO, GO BACK |
| 15534 | 042444 |  | SR1 | BR, B | YES, SHIFT NEW BIT TO B-REGISTER |
| 15535 | 160000 |  | BEV | RECVE+1 | COMPLETE CHARACTER NOT IN, GO BACK |
| 15536 | 026020 |  | DEF | 5 | CHARACTER IN, RESET RECEIVE CLOCK |

1. Initially bit 7 is put into the B-register. This will be used to test whether a whole character has been received.
2. The NES1 command tests to see if the receive flag is set. If the flag is not set, the BZE command branches back to test the flag again.
3. If the flag is set, the bit contained in the data buffer is shifted into position 17 of the B -register.
4. If the B-register is even, control is transferred back to get the next bit. If the Bregister is odd, meaning the initial bit set in $B$ has reached position 1, the even test fails and the program continues with the next instruction.
5. The DEF5 instruction resets the receive clock.

The next example is one method which might be used to transmit one character onto a transmission line via a bit buffer without using the SCN instruction.

| Location | Instruction | Symbol | OPR | Operand | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 03720 |  | ORG | 2000 |  |
|  | 02400 | \$NCHAR | EQU | 1280 |  |
| 03720 | 603120 |  | LDB | \$NCHAR | LOAD CHARACTER FROM TABLE |
| 03721 | 011006 |  | PIC | 6 | ADDRESS OF BUFFER |
| 03722 | 022002 | XMIT | NES | 2 | TRANSMIT FLAG SET |
| 03723 | 121721 |  | BZE | *-1 | NO, GO BAC: |
| 03724 | 060401 |  | TRA | B, ${ }^{\text {T }}$ | transfer bit to transmit data drivers |
| 03725 | 042404 |  | SR1 | B, B | SHIFT B-REGISTER RIGHT ONE |
| 03726 | 131721 |  | BNZ | XMIT | WHOLE CHARACTER NOT OUT, GO BACK |

1. The character to be transmitted is put into the B-register.
2. The transmit flag is tested to see if it is set.
3. When the flag sets the low order bit of $B$ is sent to the transmit buffer.
4. Bits shifted right 1 place and tested for zero. If B is non-zero, control is transferred back to transmit next bit. When $B$ becomes zero, the BNZ test fails and the program goes on to execute the next instruction.

The next two examples show how to receive a character and transmit a character using Hardware Scan (SCN). It should be noted these are examples and do not necessarily show the way they will be written in the operating programs.

Receive - Hardware Scan

| Location | Instruction | Symbol | OPR | Operand | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | REM |  | SAMPLE HARDWARE SCAN RECEIVE PROGRAM |
|  | 05670 |  | ORG | 3000 | ORIGIN 3000 |
|  | 01400 | \$SCW3 | EQU | 768 | SCAN WORD STARTING ADDRESS |
| 05670 | 377777 | NBIT18 | OCT | 377777 | MASK FOR RECEIVE FLAG |
| 05671 | 030001 | START | SCN | 1 | SCAN BIT BUFFER |
| 05672 | 603060 |  | LDB | \$SCW3 | LOAD CHARACTER BEING RECEIVED |
| 05673 | 141671 |  | BPL | *-2 | CHARACTER NOT IN, GO BACK |
| 05674 | 401670 |  | LDA | NBIT18 | CHARACTER IN, GET MASK CONSTANT |
| 05675 | 533060 |  | NAM | \$SCW3 | MASK OFF RECEIVE FLAG |

## Transmit - Hardware Scan

| Location | Instruction | Symbol | OPR | Operand | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 01750 |  | ORG | 1000 | ORIGIN LOCATION 1000 |
|  | 01000 | SSCW1 | EQU | 513 | SCAN WORD ONE |
|  | 01200 | SSCW2 | EQU | 641 | SCAN WORD TWO |
| 01750 | 030001 |  | SCN | 1 | SCAN BIT BUFFER |
| 01751 | 603050 |  | LDB | \$SCW2 | LOAD SCAN WORD TWO |
| 01752 | 141750 |  | BPL | *-2 | TRANSMIT FLAG NOT SET, GO BACK |
| 01753 | 603070 |  | LDB | \$XWORD | LOAD CHARACTER TO BE TRANSMITTED |
| 01754 | 703040 |  | STB | \$SCW1 | STORE IN SCAN WORD ONE |
| 01755 | 601767 |  | LDB | BIT18N | LOAD MASK |
| 01756 | 733050 |  | NBM | \$SCW2 | MASK OFF TRANSMIT FLAG |
|  | $\beta$ |  |  |  |  |
| 01767 | 377777 | BIT18N | OCT | 377777 | MASK CONSTANT |
|  | 01600 | \$XWORD | EQU | 896 | table location, next character to XMIT. |

Next, is a simplified example of a Program Interrupt Executive Routine containing a Scan instruction. At Symbol PIE1 is found the Store Flip-Flops instruction. This saves all the branch and control flip-flops from the last instruction executed. Next, all the registers are stored and the SCN (Scan) instruction is issued. Upon leaving the Scan instruction, the registers and flipflops are restored and control is transferred back to the program which was interrupted.

If control of mode conditions within the bit buffers is required, it should be noted that the individual channels must be set to their appropriate mode before entering the Scan Operation (Receive or Transmit Mode).

DATANET-30

| Location | Instruction | Symbol | $\underline{O P R}$ | Operand | X | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | REM |  |  | SAMPLE PROGRAM INTERRUPT EXECUTIVE |
|  | 00000 |  | ORG | 0000 |  | ORIGIN OF SUBROUTINE LINK |
| 00000 | 000000 | PIE | IND | 0 |  | LOCATION ZERO |
| 00001 | 017500 |  | IND | PIE 1 |  | LOCATION ONE |
|  | 17500 |  | ORG | 8000 |  | ORIGIN OF PIE SUBROUTINE |
| 17500 | 361514 | PIE 1 | STF | PIEF |  | STORE FLIP-FLOPS |
| 17501 | 231515 |  | LDQ | PIEQ |  | LOAD Q-COUNTER |
| 17502 | 301511 |  | STC | PIEC |  | STORE C-COUNTER |
| 17503 | 311512 |  | STD | PIED |  | STORE A- AND B-REGISTERS |
| 17504 | 030001 |  | SCN | 1 |  | SCAN BIT BUFFERS |
| 17505 | 211512 |  | LDD | PIED |  | LOAD A- AND B-REGISTERS |
| 17506 | 201511 |  | LDC | PIEC |  | LOAD C-COUNTER |
| 17507 | 261514 |  | LDF | PIEF |  | LOAD FLIP-FLOPS |
| 17510 | 106000 |  | BRU | PIE | X | BRANCH BACK TO EXIT POINT |
| 17511 | 000000 | PIEC | DEC | 0 |  | TEMPORARY STORAGE FOR C-COUNTER |
| 17512 | 000000 | PIED | DEC | 0 |  | STORAGE FOR A-REGISTER |
| 17513 | 000000 |  | DEC | 0 |  | STORAGE FOR B-REGISTER |
| 17514 | 000000 | PIEF | DEC | 0 |  | FLIP-FLOP STORAGE |
| 17515 | 003554 | PIEQ | DEC | 1900 |  | Q-COUNTER STORAGE (CONSTANT) |

## Character Buffer Channel (CBC)

The character buffer channel provides the interface to a half-duplex transmission line. The standard bit stream lengths are 5, 6, 7, and 8 bits. The character buffers should be used on lines operating at 300 bits per second or greater.

## CHARACTER BUFFER INSTRUCTIONS

Mnemonic
Operand
Word Times
Register Transfer
,T (TRA from $\qquad$ to T)

The least significant $5,6,7$ or 8 bits of the Z -drivers are sent to the transmit data buffer and the transmit flag is reset.

Register Transfer
R, (TRA from R to ___)
The $5,6,7$ or 8 bits as specified by the size of the character buffer are transferred from $R$ to the least significant positions in $Y$ and then in accordance with the register transfer instructions. The receive data buffer and flag are reset (DEF1).

$$
5,6,7, \text { or } 8 \text { bits }
$$



R ( $8,7,6$, or $5-1$ )


The two models of this character buffer are CBC930 and CBC930G2. The character buffer channel can interface with a Voltage Current Adaptor or telephone company data sets $103 \mathrm{~A} / \mathrm{F}, 201 \mathrm{~A} / \mathrm{B}$, or $202 \mathrm{C} / \mathrm{D}$. The DEF and NES instructions for a CBC vary depending on the model used and the line interface. Model CBC930G2 has all the DEF and NES instructions shown above. Model CBC930 has all instructions shown except DEF 5, DEF 6, and NES 9. The variations according to the subset are indicated.

## RECEIVE OPERATION

Assume that the character buffer channel (CBC) has been put in the receive mode by the program, that the receive flag is reset, and that the sending unit is transmitting a continuous stream of marks. (The line is in the idle condition.) The sending unit starts transmitting a character. The character is preceded by a start bit (a space) and followed by a stop bit (a mark). When the start bit is received, a clock is started. The clock is used to time the future sampling of the line. The start bit is shifted into the shift register. At regular intervals, the line is sampled and the bit which is present at sampling time is shifted into the shift register. When the shift register is full, the character bits are automatically transferred into the data register, the receive flag is set, and the clock is stopped. The clock will start again and the above process will repeat when the next start bit is received on the transmission line. As a protection against noise on the transmission line causing the clock to start running, the character buffer circuitry requires that the space condition exist on the line for at least one-half of a bit time to start the clock. Thus, noise of less duration than one-half of a bit time will have no effect. Since the character buffer will transfer a word into the data register whether or not the data register and receive flag are reset, the program must test the receive flag and take the character before
another is transferred into the data register. When the program takes the character from the data register, the data register and the receive flag are automatically reset.

The timing diagram (Figure 16) illustrates how an 8 -bit word would be received at a CBC.

1. The DEF 3 instruction puts the CBC into the receive mode.
2. The DEF 1 instruction resets the receive flag and data buffer.
3. The receive clock is shown sampling the line every bit period.
4. Line 4 shows that the contents of the receive buffer are transferred to the data register after all the bits are received.
5. Line 5 shows the receive communications line going into the CBC.
6. Line 6 shows what the receive buffer would look like after all bits are received.
7. Line 8 shows the receive flag setting when the receive buffer is transferred to the data register.
```
1 DEF 3
```



2 DEF 1


3 Rec. Clock


4 Transfer Receive
 Buffer to Data Register

5 Receive Line


6 Receive Buffer


7 Receive Flag
Figure 16. CBC Receive Timing Diagram

## TRANSMIT OPERATION

Assume that the program has put the CBC in the transmit mode, the CBC is in the process of sending a word out on the line, and a word is waiting in the data register. When the current word has been shifted into the line, the CBC will transfer the word in the data register to the shift register. At this time, the transmit flag will automatically be set. The 5 bits transferred into the shift register will automatically be preceded by a start bit and followed by 2 stop bits when transmitted onto the line for a total of 8 bits. When the shift register is again empty, the CBC will transfer the word in the data register to the shift register and repeat the process if the transmit flag is reset. However, if the transmit flag is still set, indicating that the program has not put a new word into the data register, the CBC will continue to put stop bits (marks) on the line until the transmit flag is reset. When the program transfers a new word into the data register, the transmit flag will be automatically reset and the above process will be repeated. For maximum line utilization, the program must test the transmit flag and supply a new word before the current word has been completely shifted onto the line.

The timing diagram (Figure 17) illustrates graphically what happens when a 5 -bit character is transmitted onto a communications line by a character buffer channel.

```
1 DEF 4
```

2 Transmit Clock


3 Transfer Data
Register to Transmit
Buffer shift register

4 Transmit Buffer


5 Transmit Line


6 Transmit Flag


Figure 17. CBC Transmit Timing Diagram

1. The DEF 4 instruction sets the character buffer to the transmit mode.
2. The transmit clock sends data onto the line at regular intervals.
3. When the transmit buffer shift register becomes empty the data contained in the data register is transferred to the shift register.
4. This is the binary representation of the character in the shift register.
5. Line 5 shows the output of the transmit section of the character buffer.
6. The transmit flag is shown setting when the word is transferred from the data register to the shift register.

The example below shows one method that might be used to receive characters from a character buffer.

| Symbol | OPR | Operand | X | Remarks |
| :---: | :---: | :---: | :---: | :---: |
| LOOK | ORG | 7000 |  |  |
|  | DEF | 31 |  | SET RECEIVE MODE, RESET FLAG AND BUFFER |
|  | NES | 1 |  | RECEIVE FLAG SET? |
|  | BZE | $\therefore-1$ |  | NO, GO BACK |
|  | TRA | R, B |  | YES, TRANSFER CHARACTER TO B |
|  | STB | INPUT | X | STORE IN MEMORY |
|  | ADO | INPUT |  | ADD ONE TO INPUT ADDRESS |
|  | XBZ | EOM |  | IS THIS THE END OF MESSAGE? |
|  | BNZ | LOOK |  | NO, GO GET ANOTHER CHARACTER |
| INPUT | IND | 1000 |  | INPUT ADDRESS |
| EOM | OCT | 000077 |  | END-OF-MESSAGE CHARACTER |

1. The DEF 31 instruction puts the character buffer into the receive mode and resets the receive flag and data buffer.
2. The NES 1 command tests the receive flag for a set condition.
3. When the flag sets, the BZE test fails and the character is transferred to the B-register.
4. The character is stored in memory and tested to see if it is an end-of-message character.
5. If the character isn't an EOM, control is transferred back to get next character.

## Word Buffer Channel (WBC)

The word buffer channel (WBC) provides the interface to a half-duplex transmission line, on a word basis. A WBC buffers a bit stream 20 bits in length, where the length is determined by the wiring in the 20 -bit code level connector.

The 20 -bit buffer is intended for interconnecting DATANET-30's. Usually system considerations indicate that a WBC should be used on lines operating at more than 300 bits per second. The following rates are selectable with standard speed connectors: 600, 1200, 1800, 2000, 2400, and 3000 bits per second. Two WBC's can be mounted in a buffer module and the speeds of operation may be independently selected. Each buffer selector address of each WBC is independently assigned and is specified by the wiring of the address plug for the module.

## WORD BUFFER INSTRUCTION

| Mnemonic | Operand | Word Times |
| :--- | :---: | :---: |
| Register Transfer | $R, \quad$ (TRA from R, to__) |  |

The 20 bits in the data register are distributed as follows:
Bits $18-1$ go to $R(18-1)$. Bit 19 goes to the control bit 1 flip-flop and bit 20 goes to the control bit 3 flip-flops. The receive flag and data register are reset.


Register Transfer ,T (TRA from to T)
Bits 18-1 of the B-register are transferred to bits $18-1$ of the transmit data register. Bits 19 and 20 of the transmit data register come from control bit 1 and the word parity network.



LDT - Do not use.
SCN - Do not use.

## RECEIVE OPERATION

Assume that the WBC has been put in the receive mode by the program, that the receive flag is reset, and that the sending unit is transmitting a continuous stream of marks (the line is in the idle condition). The sending unit starts transmitting a 20 -bit word. The word is preceded by a start bit (a space) and followed by a stop bit (a mark). When the start bit is received, a clock is started. The clock is used to time the future sampling of the line. The start bit is shifted into the shift register. At regular intervals, the line is sampled and the bit which is present at sampling time is shifted into the shift register. When the shift register is full, the 20-data bits are automatically transferred into the data register, the receive flag is set, and the clock is stopped. The clock will start again and the above process will repeat when the next start bit is received on the transmission line. As a protection against noise on the transmission line causing the clock to start running, the word buffer circuitry requires that the space condition exist on the line for at least one-half of a bit time to start the clock. Thus, noise of less duration than one-half of a bit time will have no effect. Since the word buffer will transfer a word into the data register whether or not the data register and receive flag are reset, the program must test the receive flag and take the word before another is transferred into the data register. When the program takes the word from the data register, the data register and the receive flag are automatically reset.

The timing diagram (Figure 18) illustrates how a 20 -bit word would be received at a WBC:

1. The DEF 3 instruction puts the WBC into the receive mode.
2. The DEF 1 instruction resets the receive flag and data buffer.
3. The receive clock is shown sampling the line every bit period.
4. Line 4 shows that the contents of the receive buffer are transferred to the data register after all the bits are received.
5. Line 5 shows the receive communications line going into the WBC.
6. Line 6 shows what the receive buffer would look like after all 22 bits are received.
7. Line 7 shows the receive flag setting when the receive buffer is transferred to the data register.

1 DEF 3


3 Rec. Clock


4 Transfer Receive
Buffer to Data
Register

5 Receive Line


6 Receive Buffer


7 Receive Flag
Figure 18. WBC Receive Timing Diagram

## TRANSMIT OPERATION

Assume that the program has put the WBC in the transmit mode, the WBC is in the process of sending a word out on the line, and a word is waiting in the data register. When the current word has been shifted into the line, the WBC will transfer the word in the data register to the shift register. At this time, the transmit flag will automatically be set. The 20 bits transferred into the shift register will automatically be preceded by a start bit and followed by a stop bit
when transmitted onto the line for a total of 22 bits. When the shift register is again empty, the WBC will transfer the word in the data register to the shift register and repeat the process if the transmit flag is reset. However, if the transmit flag is still set, indicating that the program has not put a new word into the data register, the WBC will continue to put stop bits (marks) on the line until the transmit flag is reset. When the program transfers a new word into the data register, the transmit flag will be automatically reset and the above process will be repeated. For maximum line utilization, the program must test the transmit flag and supply a new word before the current word has been completely shifted onto the line.


3 Transfer Data Register to Transmit Buffer


Start

Transmit Buffer

$\left.\right|_{0} ^{1}$ 1 | Stop |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | 1



5 Transmit Line

6 Transmit Flag

Figure 19. WBC Transmit Timing Diagram

The timing diagram (Figure 19) illustrates what happens when a 20 -bit word is transmitted onto a communications line by a word buffer channel:

1. The DEF 4 instruction sets the WBC to the transmit mode.
2. The transmit clock sends data onto the line at regular intervals determined by the baud rate of the line.
3. When the transmit buffer shift register becomes empty the data contained in the data register is transferred to the shift register.
4. This is the binary representation of the binary word in the shift register.
5. Line 5 shows the output of the transmit section of the WBC.
6. The transmit flag is shown setting when the word is transferred from the data register to the shift register.

## RECEIVE-WORD BUFFER EXAMPLE

| Location | Instruction | Symbol | $\underline{O P R}$ | Operand | X | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | REM |  |  | RECEIVE VIA WORD BUFFER |
|  | 03720 |  | ORG | 2000 |  | ORIGIN LOCATION 2000 |
| 03720 | 011017 |  | PIC | 15 |  | PLACE BUFFER ADDRESS IN C |
| 03721 | 026005 |  | DEF | 31 |  | SET RECEIVE MODE, RESET BUFFER |
| 03722 | 022001 | RECVE | NES | 1 |  | TEST FOR FLAG SET |
| 03723 | 121722 |  | BZE | *-1 |  | NOT SET, GO BACK |
| 03724 | 060044 |  | TRA | R, B |  | SET, TRANSFER R TO B |
| 03725 | 705730 |  | STB | MEMORY | X | STORE WORD IN MEMORY |
| 03726 | 341730 |  | ADO | MEMORY |  | INCREMENT MEMORY ADDRESS |
| 03727 | 101722 |  | BRU | RECVE |  | GO GET NEXT WORD |
| 03730 | 005670 | IEMORY | IND | 3000 |  | INPUT AREA INDIRECT ADDRESS |

Initially the word buffer address is put into the C-register. The receive mode is set and the buffer is reset by the DEF 31 instruction. The flag is tested and the program waits for the flag to set. When the flag sets, the contents of the data buffer are transferred to the B-register, which automatically resets the receive flag and data buffer. The data is stored in memory, and control is transferred back to get next word.

TRANSMIT-WORD BUFFER-EXAMPLE

| Location | Instruction | Symbol | OPR | Operand | X | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 07640 |  | ORG | 4000 |  | ORIGIN LOCATION 4000 |
| 07640 | 011032 |  | PIC | WBCHN |  | PUT WORD BUFFER ADDRESS IN C |
| 07641 | 062004 |  | TRC | O, B |  | TRANSFER ALL 1's TO B |
| 07642 | 022002 |  | NES | 2 |  | TRANSMIT FLAG SET |
| 07643 | 121642 |  | BZE | *-1 |  | NO, GO BACK |
| 07644 | 060401 |  | TRA | B, T |  | YES, TRANSFER WORD TO BUFFER |
| 07645 | 026010 |  | DEF | 4 |  | SET TRANSMIT MODE |
| 07646 | 605655 | LOOP | LDB | NEXTWD | X | LOAD NEXT WORD TO GO |
| 07647 | 022002 |  | NES | 2 |  | TRANSMIT FLAG SET |
| 07648 | 121647 |  | BZE | *-1 |  | NO, GO BACK |
| 07649 | 060401 |  | TRA | B, T |  | YES, TRANSFER WORD TO BUFFER |
| 07650 | 341655 |  | ADO | NEXTWD |  | ADD ONE TO OUTPUT AREA ADDRESS |
| 07651 | 351654 |  | SBO | WDCNT |  | SUBTRACT ONE FROM WORD COUNT |
| 07652 | 131646 |  | BNZ | LOOP |  | BRANCH TO TRANSMIT NEXT WORD |
| 07653 | 106000 |  | BRU | 0 | X | BRANCH LOCATION 0 |
| 07654 |  | WDCNT | DEC | 50 |  | NUMBER OF WORDS TO GO |
| 07655 |  | NEXTWD | IND | 6000 |  | OUTPUT AREA INDIRECT ADDRESS |
|  |  | WBCHN | EQU | 26 |  |  |

## PROGRAMMING THE PERFORATED TAPE READER

The perforated tape reader reads at a continuous rate of 300 characters per second. Tape can be read under program control or hardware control, depending upon the format in which it is punched. Perforated tape punched in the hardware load format is always read at the maximum 300 -character-per-second rate under automatic control of the DATANET-30 circuitry. The perforated tape reader is always on buffer selector address 0 .

Perforated tape may be read under program control in two modes, continuous mode and step mode. Five- to eight-level tape may be read but normally only eight-level tape will be used. If perforated tape is read in continuous mode, the character under the read station must be taken away 500 microseconds after the flag is set. If the 500 microsecond timing restriction is not met, reading must be done in the step mode at a speed of approximately 50 characters per second.

In either mode, when the sprocket hole is detected, the character under the read station causes the receive flag to be set. When the character is taken away, the flag is automatically reset and the reader moves the tape to the next character. This control of the movement of tape is in effect at both 300 and 50 characters-per-second speeds. The sprocket hole serves as a timing source. A sprocket hole only indicates a character and will set the receive flag.

The reader is turned on by the POWER ON switch on the perforated tape reader control panel. Normal operation requires that the reader be turned on at all times.

## Reading Perforated Tape Under Program Control <br> PERFORATED TAPE READER INSTRUCTIONS

Following are the perforated tape reader instructions:
Register Transfer (From R, $\qquad$ )

The character contained in the buffer is transferred to register A or B , as in the diagram below. The receive flag and data buffer are reset. If stopped, any register transfer instruction from $R$ starts tape moving or allows the movement of tape to continue.


DEF 1 Reset flag and read next character. The reader starts tape moving through the reader or allows the movement of tape to continue.

DEF 2-10 No effect.
NES $1 \quad$ Read flag set (a new character is ready).
SCN Do not use.
LDT No effect.
Register Transfer $\qquad$ . T - No effect.

The following example is a few lines of coding which show one way in which perforated tape might be read. In this example, tape is punched in $6-1$ evel code and 3 characters are assembled into one word. Channels 7 and 8 are not punched. In this example, the 7 and 8 channels are transferred but are not used.

| Locat ion | Instruction | Symbol | $\underline{O P R}$ | Operand | X | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 13560 |  | ORG | 6000 |  | ORIGIN LOCATION |
| 13560 | 011000 |  | PIC | 0 |  | PL'T PAPER TAPE READER ADDRESS IN C |
| 13561 | 022001 | READ | NES | 1 |  | CHARACTER PRESENT? |
| 13562 | 121561 |  | BZE | *-1 |  | NO, GO BACK |
| 13563 | 044044 |  | SL6 | R, B |  | YES, SHIFT TO B-REGISTER |
| 13564 | 022001 |  | NES | 1 |  | CHARACTER PRESENT? |
| 13565 | 121564 |  | BZE | *-1 |  | NO, GO BACK |
| 13566 | 044444 |  | SL6 | BR, B |  | YES, SHIFT TO B-REGISTER |
| 13567 | 02.2001 |  | NES | 1 |  | CHARACTER PRESENT? |
| 13570 | 121567 |  | BZE | *-1 |  | NO, GO BACK |
| 13571 | 060444 |  | TRA | BR, B |  | YES, TRANSFER TO B |
| 13572 | 705576 |  | STB | WKSTOR | X | STORE IN MEMORY INPUT AREA |
| 13573 | 341576 |  | ADO | WKSTOR |  | ADD 1 TO INDIRECT MEMORY ADDRESS |
| 13574 | 771577 |  | XBZ | STOP |  | IS THIS A STOP WORD? |
| 13575 | 131561 |  | BNZ | READ |  | NO, GO READ NEW WORD |
| 13576 | 001750 | WKSTOR | IND | 1000 |  | INDIRECT ADDRESS |
| 13577 | 777777 | STOP | OCT | 777777 |  | STOP CONSTANT |

Initially buffer selector address 0 is put into the C-register. The NES1 command tests the buffer for a character, and status line 1 will remain a 0 until a character is present. When the flag sets, the program falls through the BZE test and shifts the character into the B-register. When three characters have been assembled in the B-register, they are stored away in memory and a test is made to see if the last word was a stop signal. If the word was not a stop signal, control is transferred back to the symbol READ and the reading process continues.

Note: When tape is loaded in the reader, the tape will stop with a sprocket hole over the read station. A sprocket hole by itself will set the flag and represents a "blank" character.

## PROGRAM LOAD FORMAT

A perforated tape generated by General Assembly Program 3 (run on a GE-225 computer) in the program load format can only be loaded into the DATANET-30 by a loader program. It is not hardware loadable.

The program load perforated tape code is shown below:

|  |  | Channe1 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | on Tape |  |  |  |  |  |  |  |
|  | Leader | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
|  | Flag | 0 | 0 | 1 | 0 | 0 | 0 | 0 |  |
|  |  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Digit | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 |
|  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
|  | 2 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
|  | - | - | - | - | - | - | - | - | - |
|  | 7 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |

$1=$ Hole
$0=$ No Hole

EXAMPLE:


## Hardware Load and the Perforated Tape Reader

Once initiated, the loading of data from the perforated tape reader is accomplished entirely under hardware control. A special format (operation code), in channels 7 and 8 (the control channels) controls the shift of data in channels 1-6 from the reader to the B-register and then into memory. The characters in channels 1-6 are transferred into the B-register and assembled to form a word. Since the DATANET-30 word is 18 bits, two shifts of 6 bits each are required.


When the B-register is filled with the third transfer of data into $B$, the word is transferred to memory. (Operation code 01 XXXXXX .)

Operation code in channels $8 \& 7$

## Operation

87654321
10111111 Begin hardware load. The reader searches for this code before the transfer of data can start.

00 XXXXXX SL6 BR,B
Bits 1-6 from the paper tape reader are OR-ed into $1-6$ of $Y$ with the contents of the $B$-register. $Y$ is shifted left 6 to $Z$. $Z$ is transferred to the B-register.

01 XXXXXX TRA BR, B
Store B in memory location specified by P. Count P up 1. Clear B.
Bits 1-6 from the paper tape reader are OR-ed into $1-6$ of $Y$ with the contents of the $B$-register. $Y$ is transferred to $Z$ without change. $Z$ is transferred to the B-register. The contents of the B-register are stored in memory as specified by $P$. $P$ is counted up by 1 , and the $B-r e g i s t e r$ is cleared.

11 XXXXXX TRA BR, B
TRA B, P. Clear B
Bits 1-6 from the paper tape reader are OR-ed into $1-6$ of $Y$ with the contents of the B-register. $Y$ is transferred to $Z$ without change. $Z$ is transferred to $B$. Then the contents of the B-register are transferred to P , and the B -register is cleared.

## Operation

10 XXXXX0 End hardware load. Control is automatically transferred to the program. The program starts at the address specified by the P-counter.

Note: Only begin hardware load and end hardware load use all 8 channels for the operation code. A punch is a 1, a blank is a 0. A blank space (sprocket hole only) causes zeros to be transferred into $B$.

## STRUCTURE TABLE TO

HARDWARE LOAD OPERATION
The sequence of operations for hardware load is shown by the following steps:

1. When hardware load is initiated, the C-register is set to zero, the Q-counter is set to -1 , the paper starts moving through the reader, and the tape is examined for the begin hardware load character.
2. Read a character.

| Character <br> 871654321 | This Occurs | Go To Step |
| :---: | :---: | :---: |
| $10: \begin{aligned} & 111111 \\ & \mathbf{I}_{1} \text { Begin HWL } \\ & \hline \end{aligned}$ | Sets B-register to Zero | 3 |
|  | Nothing happens | 2 |

3. Read a character.


## Hardware Load Format

The Hardware Load format output of the assembly program may be loaded into the DATANET-30 by either Hardware Load or a Loader program. When the perforated tape is loaded via a Loader program, checking is accomplished by the block hash total and program hash total. When the perforated tape is loaded via Hardware Load, no checking by hash total is accomplished.

The block hash total is located at position $N+1$ of a block of $N$ words. Frogram hash total is located after the address of a transfer word, and before the end hardware load character. Block is the equivalent of a binary card or binary tape record. Octal cards will be converted to a block length of one. An example of Hardware Load perforated tape format is shown below:


## ASSEMBLY PROGRAMS

DATANET-30 source programs can be assembled either on a GE-225/235 computer or on a DATANET-30.

The DATANET-30 assembly program run on the GE-225/235 is CD225F2.001/2. Information on this assembly program is included in Appendix A of this manual.

The DATANET-30 assembly program run on the DATANET-30 is CDD30F1.001/2. Information on this assembly program is contained in publication CPB-1074.

The assembly program run on the DATANET-30 will accept programs written for the DATANET30 assembly program run on the GE-225 computer, thus providing compatibility for assembling DATANET-30 source programs.

## UTILITY ROUTINES

Since the output from the DATANET-30 assembly program run on the GE- 225 is magnetic tape (switch option) or punched cards and the input to the DATANET-30 is perforated tape, a conversion program is needed. A utility routine (General Assembly Program 3) on the DATANET-30 General Assembly Program systems tape will accomplish this, producing perforated tape in various formats on a free-standing perforated tape unit which has the eight-level straight transfer mode. One of the formats is compatible with Hardware Load, so that self-loading programs can be produced. Other formats are read by tape loader programs. The Paper Tape Conversion (General Assembly Program 3) Utility Routine for perforated tape can be run following the DATANET-30 General Assembly Program by setting the console switches.

## PROGRAMMING AIDS

Aids for program debugging are abailable. The following is a list of these and other software that have been developed. Information regarding these and other software aids as they are developed can be obtained from the Computer Program Library, Computer Department, General Electric Company, P.O. Box 2961, Phoenix, Arizona, 85001.

## LIBRARY NUMBER

CDD30B1.001

CDD30B1. 002

CDD30B2.001

CDD30B2.002

CDD30B2.003

CDD30B2.005

CDD30B2.006

CDD30B3. 001

CDD30B3.002

CDD30B3.003
CDD30B3. 004

CDD30D1. 001
CDD30D1.002

## DESCRIPTION

Card Loader--Loads binary and octal cards into memory. This is a paper tape loop for the tape reader of the DATANET-30.

Bootstrap Tape Loader--Loads programs from magnetic tape.
Edited Memory Dump--Dumps all of memory on the printer except for the memory dump program. Prints 8 memory locations per line. The starting address of the 8 memory locations is to the left of each line printed. ( 8 or 16 k .)

CORE Dump Mnemonics--Dumps memory on the printer. Dumps a line in octal and on the next line prints mnemonic op code.

Memory Dump--Octal/Baudot--Dumps on the printer 8 words per line followed on the same line by the Baudot Equivalent of the 8 words.

Trace--Prints every instruction of a non-real time program and the state of the working registers after each instruction is executed.

Memory Lookup--Searches for specified bit patterns entered through the switches and lists on the printer all locations where the bit pattern appears. Will also list all references to a specific memory location.

Magnetic Tape Dump--Dump to printer binary or BCD tape in octal format.

Tape or Card to Tape--Writes BCD tapes to tape or Hollerith cards to tape.

Decimal Tape to Printer--Dumps BCD tape to printer.
Mixed Binary Octal Cards to Magnetic Tape--Writes DATANET-30 object programs on magnetic tape.

Multiply--Multiplies two 17 bit words to produce a 35 bit product.
Divide--Divides 35 bit word by 17 bit word to produce up to a 17 bit quotient and 16 bit remainder.

## LIBRARY NUMBER

CDD30E1.001

CDD30E8.001

CDD30E8.002

CDD30E8.003

CDD30E8. 004

CDD30E8. 005

CDD30F2.001

CDD30F2.002

CDD225F2.001
CDD225F2.002

## DESCRIPTION

Card Read--Reads a card and stores in memory. No conversion.

Disc Storage Unit I/O--Simplifies the use of the DSU by performing the necessary preparatory and error checking functions associated with reading and writing on the DSU.

Data to Disc Storage Unit--Loads card data on DSU in Octal, Baudot or BCD.

Dynamic DSU Dump with I/O--Permits dumping the DSU transfers in real-time on the printer. Also permits DSU updates and moves.

DSU Dump to Printer--Printout in octal and Baudot of selected sequential DSU records.

Zero DSU--Zero selected areas of the DSU under console switch control.

DATANET-30 Assembler on the DATANET-30 (Cards).
DATANET-30 Assembler on the DATANET-30 (Tape).
DATANET-30 Assembler on the GE-225 (Cards).
DATANET-30 Assembler on the GE-225 (Tape).

## APPENDIX A

## ASSEMBLY PROGRAMS

Appendix A to this manual covers the DATANET-30 General Assembly Program run on the GE-225 computer.

Publication CPB-1074 covers the DATANET-30 Assembly Program run on the DATANET-30

Both Appendix A to this manual and CPB-1074 are available from:

Marketing Distribution Center<br>Computer Department<br>General Electric Company<br>P. O. Box 2961<br>Phoenix, Arizona, 85002

## APPENDIX B

## CHARACTERISTICS SUMMARY

COMMUNICATIONS PROCESSOR
Single address
Stored program
Read/compute/write cycle
Binary
18 bit word length
Parallel
128 buffer selector channels
Automatic program reload
Memory interrupt feature
Automatic bit buffer scan command
Elapsed time program interrupt counter
78 basic instructions
Indirect addressing
Indexing
6.94 microsecond word time
MEMORY
6. 94 microsecond memory cycle
Memory size (words) :
4,096
8,19216,384
HARDWARE SCAN
Bit buffer units only
5-, 6-, 7-, or 8-level codes
Scan time: 21 microseconds per simplex, half-duplex, or full-duplex channel.

## INSTRUCTION SUMMARY

Time in Microseconds
Load
Store Single and double wordSingle and double word
Arithmetic 18 bit parallel addition ..... 14
Logical AND, OR and EXCLUSIVE OR ..... 14
Branch Conditional and unconditional ..... 7
To subroutine ..... 21
Register Transfer ..... 7
BUFFER SELECTOR BUFFER UNITS
Bit Buffer Unit
10 simplex channels input and 10 simplex channels output/module
10 half-duplex channels/module
10 full-duplex (or echoplex) channels/module
Module data rates (bits/sec)
4550
56.25
75

110
150
Code level: 5, 6, 7 , or 8 bits/character
Character format: start/stop bit asychronous;one stop bit (minimum).
Compatible digital subsets: 103A; 103 F.
20 ma d-c loop, bipolar voltage interface, or VCA
CHARACTER/WORD UNIT (CWU930)
Character Buffer Channel (CBC930)
2 simplex channels/module
2 half-duplex channels/module
1 full-duplex channel/module14 and 2114 and 21

[^1]Channel data rates
300 bits/sec to 2400 bits/sec
Code level: 5, 6, 7, or 8 bits/character
Character format: start/stop bit asychronous;one stop bit (minimum).
Compatible digital subsets: $202 \mathrm{~A} ; 202 \mathrm{C} / \mathrm{D} ; 103 \mathrm{~A} / \mathrm{F}$
Bipolar voltage interface. VCA
WORD BUFFER CHANNEL (WBC930)
2 simplex channels/module
2 half-duplex channels/module
1 full-duplex channel/module
Channel data rates (bits/sec)
12001800
2000
2400
Code level: 20 bits
Character format: start/stop bit asychronous;
one stop bit (minimum).
Compatible digital subsets: 202A; $202 \mathrm{C} / \mathrm{D} ; 103 \mathrm{~A} / \mathrm{F}$
Bipolar voltage interface, VCA
COMPUTER INTERFACE UNIT (CIU93O)
GE-200 Series computer interface
$1 \mathrm{CIU} / 2$ modules
20-bit parallel transfer
Transfer rate determined by DATANET-30 program
COMPUTER INTERFACE UNIT (CIU931)
GE-400/600 Series computer interface
1 CIU/ 2 modules
3 characters per transfer
Transfer rate synchronized by the DATANET-30

## CONTROLLER SELECTOR UNIT (CSU930)

Maximum transfer rate
Data transfer cycle time DATANET-30 memory interrupt time Execute status request

28,800 words/sec 17.34 microseconds 7 microseconds/word 28-70 microseconds

Peripheral Combination Chart:

| Peripheral | ** Possible Channel <br> Address (plug no.) | * Load Factor <br> Per Peripheral |
| :--- | :---: | :---: |
| $\left.\begin{array}{ll}\text { Single access DSU } & 0,1 \\ \text { Dual access DSU } & 0,1 \\ 15 \mathrm{kc} \text { tape controller } & 2,3,4,5 \\ 41.5 \mathrm{kc} \text { tape controller } & 2,3,4,5\end{array}\right\}$ only | 1. |  |
| Printer | 6,7 only | 1. |
|  |  | .3 |
|  |  | .45 |
|  |  | .05 |

## CONTROLLER SELECTOR UNIT (CSU931)

Maximum transfer rate Data transfer cycle time DATANET-30 memory interrupt time

57,600 words/sec
17.34 microseconds

7 microseconds/word

## Peripheral Combination Chart:

Peripheral
Single access DSU
Dual access DSU
15 kc tape controller
41.5 kc tape controller Printer

| ** Possible Channel | * Load Factor |
| :---: | :---: |
| Address (plug no.) | Per Peripheral |

0-7 . 55
0-7 . 55
0-7 . 1
0-7 . 28
6,7 only . 05

* The load factor represents the index for peripherals that may be run concurrently if sum of load factors does not exceed 1.00 .
** The assignment of a priority channel to a peripheral, and therefore which plug number, depends upon the data transfer rate of the peripheral equipment. The peripheral equipment with the higher transfer rate must have priority over a peripheral with a slower transfer rate.


## DIALING ADAPTOR UNIT (DAU93O)

10 Dialing Adaptor Units/Module
Associated buffer units per DAU1 bit buffer
1 character buffer
1 word buffer
Telephone company equipment
1 automatic calling unit per DAU
1 data set per buffer
Numbers dialed under program control
Code level: Not applicable
Character format: Binary to automatic calling unit
Compatible digital subsets: 103A, 202C
PROCESSOR INTERRUPT UNIT (PIU930)
DATANET-30 to DATANET-30 interface
1 PIU/module
18-bit parallel transfer
Transfer rate 28,800 words/'sec
COMMON PERIPHERAL CHANNEL (CPC930)
1 peripheral per CPC
$1 \mathrm{CFC} / 2$ modules
6 -bit character transfer
Transfer rate up to 57,600 words/sec
CARD READER UNIT (CRU93O)
1 card reader per CRU
1 CRU/module
Reads 400 cards per minute
PUNCH/READER UNIT (PRU93O)
1 card reader and 1 card punch per PRU
1 PRU/ 2 modules
Reads 400 cards per minute
Punches 100 cards per minute
CHARACTER BUFFER UNIT (CBU931)
2 character buffer channels/module
Interface with the UNIV AC 1004 system

## PARALLEL CHANNEL ADAPTOR (PCA930)

Will parallel one communication line via one VCA (or DSS) into two Bit Buffer Channels (BBC931G4), two Character Buffer Channels (CBC930), or two Word Buffer Channels (WBC930) of two separate DATANET-30 processors.

## PARALLEL CHANNEL ADAPTOR (PCA931)

Will parallel ten communication lines via one VCA931 (or VCA940) into ten Bit Buffer Channels (BBC931G4) of two separate DATANET-30 processors. May be combined with a CBC.

## DUAL CHANNEL ADAPTOR

Transfers control of a peripheral controller between a DATANET-30 with a CPC930 and a GE-400 or -600 Series computer.

## APPENDIX C

## INSTRUCTION SUMMARY CONVERSION TABLE, 5-LEVEL BAUDOT TO OCTAL

## MACRO COMMANDS

The DATANET-30 assembly program recognizes various macro commands, and will assemble them as follows:



F is the Register FROM T is the Register TO

The macro commands that are register transfer commands (with the exception of the double shifts) have the same error checks as a non-macro register transfer command, plus some additional checks. An error will be flagged when the user attempts to:

Register Transfer MACRO 0 , anything
Register Transfer MACRO anything, Z
Register Transfer MACRO anything, T

The FROM-TO bits in the instruction will not be deleted on any of the above errors. The error tag only signifies that the instruction should be examined to see if it is correct.

The macro commands SMA, SMB, SAM and SBM, will have the same error checks and same addressing capabilities as non-macro commands requiring a memory address.

No error checks are perfomed on the macro double shift commands SLD and SRD. The operand must be decimal and must be left-justified in the operand field.

## BAUDOT TO OCTAL CONVERSION TABLE <br> (Alphabetic Sequence)


*) Note: These symbols are not on printer; for convenience, however, they are printed on this form.

DATANETO 30

BAUDOT TO OCTAL
CONVERSION TABLE
(Numerical Sequence)

| LETTERS | FIGURES | $\begin{gathered} \text { LEFT } \\ \text { JUSTIFIED } \end{gathered}$ | $\begin{gathered} \text { RIGHT } \\ \text { JUSTIFIED } \end{gathered}$ | LETTERS | $\begin{gathered} \text { HIGH-SPE } \\ \text { OCTAL } \end{gathered}$ | PRINTER <br> FIGURES | OCTAL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Blank | Blank | 00 | 00 | $\triangle$ | 60 | $\triangle$ | 60 |
| E | 3 | 02 | 01 | E | 25 | 3 | 03 |
| Line Feed | Line Feed | 04 | 02 | $=$ | 16 | $=$ | 16 |
| A | - | 06 | 03 | A | 21 | - | 40 |
| Space | Space | 10 | 04 |  | 15 |  | 15 |
| S | BELL *) | 12 | 05 | $\bar{S}$ | 62 | S | 62 |
| I | 8 | 14 | 06 | I | 31 | 8 | 10 |
| U | 7 | 16 | 07 | U | 64 | 7 | 07 |
| Carr.Ret. | Carr.Ret. | 20 | 10 | \% | 74 | \% | 74 |
| D | \$ | 22 | 11 | D | 24 | \$ | 53 |
| R | 4 | 24 | 12 | R | 51 | 4 | 04 |
| J | ' *) | 26 | 13 | J | 41 | J | 41 |
| N | , | 30 | 14 | N | 45 | , | 73 |
| F | ! *) | 32 | 15 | F | 26 | , | 73 |
| C | - | 34 | 16 | C | 23 |  | 57 |
| K | ( | 36 | 17 | K | 42 | ( | 75 |
| T | 5 | 40 | 20 | T | 63 | 5 | 05 |
| $z$ | " *) | 42 | 21 | $z$ | 71 | \# | 13 |
| I | ) | 44 | 22 | L | 43 | ) | 76 |
| W | 2 | 46 | 23 | W | 66 | 2 | 02 |
| H | 4 | 50 | 24 | H | 30 | \% | 13 |
| Y | 6 | 52 | 25 | Y | 70 | 6 | 06 |
| P | 0 | 54 | 26 | P | 47 | 0 | 00 |
| Q | 1 | 56 | 27 | Q | 50 | 1 | 01 |
| $\emptyset$ | 9 | 60 | 30 | $\emptyset$ | 46 | 9 | 11 |
| B | ? | 62 | 31 | B | 22 |  | 55 |
| G | + | 64 | 32 | G | 27 | + | 20 |
| Figs. | Figs. | 66 | 33 | * | 54 | * | 54 |
| M | . | 70 | 34 | M | 44 | , | 33 |
| X | 1 | 72 | 35 | X | 67 | / | 61 |
| V | ; *) | 74 | 36 | V | 65 | , | 73 |
| Itrs. | Ltrs. | 76 | 37 | @ | 14 | @ | 14 |

DATANET= 30

| CHARACTER | $\begin{array}{\|c} 3 C 0 \\ \text { LPM } \\ \text { PRINTER } \\ \text { SYMBOLS } \end{array}$ | CONSOLE TYPEWRITER CHARACTER OR ACTION | PERFORATED PAPER TAPE ( 8 LEVEL) |  | $\begin{aligned} & \text { BCD } \\ & \text { MEMORY } \\ & \text { (OCTAL)** } \end{aligned}$ | BCD MAGNETIC TAPE (OCTAL) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | Space | 0 | 00 | 12 |
| 1 | 1 | 1 | 1 | 1 | 01 | 01 |
| 2 | 2 | 2 | 2 | 2 | 02 | 02 |
| 3 | 3 | 3 | 3 | 3 | 03 | 03 |
| 4 | 4 | 4 | 4 | 4 | 04 | 04 |
| 5 | 5 | 5 | 5 | 5 | 05 | 05 |
| 6 | 6 | 6 | 6 | 6 | 06 | 06 |
| 7 | 7 | 7 | 7 | 7 | 07 | 07 |
| 8 | 8 | 8 | 8 | 8 | 10 | 10 |
| 9 | 9 | 9 | 9 | 9 | 11 | 11 |
| A | A | A |  | 12-1 | 21 | 61 |
| B | B | B | S | 12-2 | 22 | 62 |
| C | C | C | T | 12-3 | 23 | 63 |
| D | D | D | U | 12-4 | 24 | 64 |
| E | E | E | V | 12-5 | 25 | 65 |
| F | F | F | W | 126 | 26 | 65 |
| G | G | G | X | 12-7 | 27 | 67 |
| H | H | H | Y | 12-8 | 30 | 70 |
| I | 1 | 1 | Z | 12-9 | 31 | 71 |
| J | J | J | J | $11-1$ | 41 | 41 |
| K | K | K | K | 11-2 | 42 | 42 |
| L | L | L | L | 11-3 | 43 | 43 |
| M | M | M | M | 11-4 | 44 | 44 |
| N | N | N | N | 11-5 | 45 | 45 |
| 0 | 0 | 0 | 0 | 11-6 | 46 | 46 |
| P | P | P | P | 11.7 | 47 | 47 |
| Q | Q | Q | Q | 11-8 | 50 | 50 |
| R | R | R | R | 11-9 | 51 | 51 |
| S | S | S | B | 0-2 | 62 | 22 |
| T | T | T | C | 0-3 | 63 | 23 |
| U | L | U | D | 0-4 | 64 | 24 |
| V | V | V | E | 0-5 | 65 | 25 |
| W | W | W | F | 0-6 | 66 | 26 |
| X | X | X | G | 0-7 | 67 | 27 |
| Y | Y | Y | H | 0.8 | 70 | 30 |
| Z | Z | Z | I | 0.9 | 71 | 31 |
| + | - |  | 0 | 12 | 20 | 60 |
| - | - | - | - | 11 | 40 | 40 |
| (Space) | Blank | Biank) | \& | Blank | 60 | 20 |
| , |  |  | A | 0-1 | 61 | 21 |
|  |  |  |  | 2-8 | 12 | 12 |
| \# | \# | 1 | Stop | 3-8 | 13 | 13 |
| @ | $\underline{6}$ |  |  | 4-8 | 14 | 14 |
| (Underline) | - |  |  | 5-8 | 15 | 15 |
| $=$ | $=$ |  |  | 6-8 | 16 | 16 |
|  |  |  |  | 7-8 | 17 |  |
|  |  |  |  | 12-2-8 | $32^{*}$ | 72 |
| -0 |  |  |  | 12-0 | 32* |  |
| . | . | . |  | 12-3-8 | 33 | 73 |
|  |  |  |  | 12-4-8 | 34 |  |
|  |  |  |  | 12-5-8 | 35 | 75 |
|  |  |  | Tab | 12-6-8 | 36 | 76 |
|  |  | Carriage Return |  | 12-7-8 | 37 | 77 |
| -0 |  |  |  | 11-0 | $52^{*}$ | 52 |
|  |  |  |  | 11-2-8 | $52^{*}$ | 52 |
| \$ | 5 | 5 | \$ | 11-3-8 | 53 | 53 |
|  | * |  |  | 11-4-8 | 54 | 54 |
|  |  |  |  | 11-5-8 | 55 | 55 |
|  |  |  |  | 11-6-8 | 56 | 56 |
|  |  |  |  | 11-7-8 | 57 | 57 |
|  |  | Print Red |  | 3-2-8 | 72 | 32 |
|  |  |  |  | 0-3-8 | 73 | 33 |
| \% | ${ }_{c}$ |  |  | 0-4-8 | 74 | 34 |
| 1 | [ | Print Black |  | 0-5-8 | 75 | 35 |
| 1 | $]$ | Tab |  | 0-6-8 | 76 | 36 |
|  |  |  | Delete | 0-7-8 | 77 | 37 |

GE-225 Representation of Characters

DATAMET- 30

| Standard Character Set | GE-Internal Machine Code | Octal <br> Code | Hollerith Card Code | Standard Character Set | GE-Internal Machine Code | Octal <br> Code | Hollerith Card Code |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 000000 | 00 | 0 | 4 | 100000 | 40 | 11-0 |
| 1 | 000001 | 01 | 1 | J | 100001 | 41 | 11-1 |
| 2 | 000010 | 02 | 2 | K | 100010 | 42 | 11-2 |
| 3 | 000011 | 03 | 3 | L | 100011 | 43 | 11-3 |
| 4 | 000100 | 04 | 4 | M | 100100 | 44 | 11-4 |
| 5 | 000101 | 05 | 5 | N | 100101 | 45 | 11-5 |
| 6 | 000110 | 06 | 6 | 0 | 100110 | 46 | 11-6 |
| 7 | 000111 | 07 | 7 | P | 100111 | 47 | 11-7 |
| 8 | 001000 | 10 | 8 | Q | 101000 | 50 | 11-8 |
| 9 | 001001 | 11 | 9 | R | 101001 | 51 | 11-9 |
| II [ \\| | 001010 | 12 | 2-8 | $\\|-\\|$ | 101010 | 52 | 11 |
| $\\|$ 非 | 001011 | 13 | 3-8 | \$ | 101011 | 53 | 11-3-8 |
| @ | 001100 | 14 | 4-8 | * | 101100 | 54 | 11-4-8 |
| : | 001101 | 15 | 5-8 | ) | 101101 | 55 | 11-5-8 |
| $\\|>\\|$ | 001110 | 16 | 6-8 | (1) 11 | 101110 | 56 | 11-6-8 |
| 11 ? 1 | 001111 | 17 | 7-8 | $11!11$ | 101111 | 57 | 11-7-8 |
| \\|ち\| | 010000 | 20 | (blank) | $+$ | 110000 | 60 | 12-0 |
| A | 010001 | 21 | 12-1 | / | 110001 | 61 | 0-1 |
| B | 010010 | 22 | 12-2 | S | 110010 | 62 | 0-2 |
| C | 010011 | 23 | 12-3 | T | 110011 | 63 | 0-3 |
| D | 010100 | 24 | 12-4 | U | 110100 | 64 | 0-4 |
| E | 010101 | 25 | 12-5 | V | 110101 | 65 | 0-5 |
| F | 010110 | 26 | 12-6 | W | 110110 | 66 | 0-6 |
| G | 010111 | 27 | 12-7 | X | 110111 | 67 | 0-7 |
| H | 011000 | 30 | 12-8 | Y | 111000 | 70 | 0-8 |
| I | 011001 | 31 | 12-9 | 2 | 111001 | 71 | 0-9 |
| \& | 011010 | 32 | 12 | 4 | 111010 | 72 | 0-2-8 |
| . | 011011 | 33 | 12-3-8 | , | 111011 | 73 | 0-3-8 |
| ] | 011100 | 34 | 12-4-8 | \% | 111100 | 74 | 0-4-8 |
| $($ | 011101 | 35 | 12-5-8 | $=$ | 111101 | 75 | 0-5-8 |
| $<$ | 011110 | 36 | 12-6-8 | " | 111110 | 76 | 0-6-8 |
| 1 | 011111 | 37 | 12-7-8 | ! | 111111 | 77 | 0-7-8 |

Characters inside $\|x\|$ have special Edit functions.
Characters inside (x) normally do not print.

GE-Compatibles/ 400 Standard Character Set

DATANETO 30

| Standard Character Set | GE－Internal Machine Code | Octal Code | Hollerith Card Code | Standard Character Set | GE－Internal Machine Code | Octal <br> Code | Hollerith Card Code |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 000000 | 00 | 0 | 4 | 100000 | 40 | 11－0 |
| 1 | 000001 | 01 | 1 | J | 100001 | 41 | 11－1 |
| 2 | 000010 | 02 | 2 | K | 100010 | 42 | 11－2 |
| 3 | 000011 | 03 | 3 | L | 100011 | 43 | 11－3 |
| 4 | 000100 | 04 | 4 | M | 100100 | 44 | 11－4 |
| 5 | 000101 | 05 | 5 | N | 100101 | 45 | 11－5 |
| 6 | 000110 | 06 | 6 | 0 | 100110 | 46 | 11－6 |
| 7 | 000111 | 07 | 7 | P | 100111 | 47 | 11－7 |
| 8 | 001000 | 10 | 8 | Q | 101000 | 50 | 11－8 |
| 9 | 001001 | 11 | 9 | R | 101001 | 51 | 11－9 |
| $\Gamma$ | 001010 | 12 | 2－8 | － | 101010 | 52 | 11 |
| 非 | 001011 | 13 | 3－8 | \＄ | 101011 | 53 | 11－3－8 |
| （a | 001100 | 14 | 4－8 | ＊ | 101100 | 54 | 11－4－8 |
| ： | 001101 | 15 | 5－8 | ） | 101101 | 55 | 11－5－8 |
| ＞ | 001110 | 16 | 6－8 | ； | 101110 | 56 | 11－6－8 |
| ？ | 001111 | 17 | 7－8 | ； | 101111 | 57 | 11－7－8 |
| ち | 010000 | 20 | （blank） | $+$ | 110000 | 60 | 12－0 |
| A | 010001 | 21 | 12－1 | ／ | 110001 | 61 | 0－1 |
| B | 010010 | 22 | 12－2 | S | 110010 | 62 | 0－2 |
| C | 010011 | 23 | 12－3 | T | 110011 | 63 | 0－3 |
| D | 010100 | 24 | 12－4 | U | 110100 | 64 | 0－4 |
| E | 010101 | 25 | 12－5 | V | 110101 | 65 | 0－5 |
| F | 010110 | 26 | 12－6 | W | 110110 | 66 | 0－6 |
| G | 010111 | 27 | 12－7 | X | 110111 | 67 | 0－7 |
| H | 011000 | 30 | 12－8 | Y | 111000 | 70 | 0－8 |
| I | 011001 | 31 | 12－9 | Z | 111001 | 71 | 0－9 |
| \＆ | 011010 | 32 | 12 | 4 | 111010 | 72 | 0－2－8 |
| ， | 011011 | 33 | 12－3－8 | ， | 111011 | 73 | 0－3－8 |
| 1 | 011100 | 34 | 12－4－8 | \％ | 1111.00 | 74 | 0－4－8 |
| （ | 011101 | 35 | 12－5－8 | $=$ | 111101 | 75 | 0－5－8 |
| $<$ | 011110 | 36 | 12－6－8 | ＂ | 111110 | 76 | 0－6－8 |
| 1 | 011111 | 37 | 12－7－8 | ！ | 111111 | 77 | 0－7－8 |

GE－625／635 Standard Character Set

## INSTRUCTION FORMATS SUMMARY

A. Instructions Without Memory Addressing.

1. C-Register instructions.


Code - Bits 18-10
010-014. -AIC, PIC, NCZ, XCZ.
2. Other nonmemory addressing instructions.


Code - Bits 18-11, even-numbered codes only.
00X. Conditional Halt - HLT.
020-026. Status lines and function driversNIS, NES, DIF, DEF.
030-032. Hardware scan and controller selector-SCN, CSR. 040-046. Shift - SL1, SR1, SL6. SR6.
050-056. Circulate - CL1, CR1, CL6, CR6.
060-066. Transfer - TRA, TRC, BC0, BC1.
070-076. Special shift and circulate - SLS, SRS.
Flags - Bits 10-1

Status Lines and Function Drivers - Bit position number (10-1) corresponds to line or driver number.

Shift, Circulate, and Transfer - Bits 10-5 indicate "From"; Bits 4-1 indicate "To". Each bit position has register significance (see below). No bits in "From" indicates zero. No bits in "To" indicates Z-drivers.

B. Instructions With Memory Addressing.


Codes - Bits 18-13
10-17. Branch - BRU, BRS, BZE, BNZ, BPL, BMI, BEV, BOD.
20-26. From memory to registers, non A or B. LDC, LDD, LDZ, LDQ, LDT, LDF.

30-37. To memory from registers, non A or B . STC, STD, STZ, CMM, ADO, SBO, STF, AMD.

40-46. From memory to A - LDA, CMA, AMA, NMA, RMA, XMA, AAZ.
50-57. To memory from A - STA, CAM, AAM, NAM, RAM, XAM, NAZ, XAZ.
60-66. From memory to B-LDB, CMB, AMB, NMB, RMB, XMB, ABZ.
70-77. To memory from B - STB, CBM, ABM, NBM, RBM, XBM, NBZ, XBZ.

Modes - Bits 12-10

| 0-3. | Direct addressing |
| :---: | :--- |
| $0,1$. | Program bank addressing |
| 2. | Common data bank addressing |
| 3. | Channel table addressing |
| 4-7. | Indirect addressing |
| $4,5$. | Program bank addressing |
| 6. | Common data bank addressing |
| 7. | Channel table addressing |


|  | Bits |  |  | P. B. |
| :---: | :---: | :---: | :---: | :---: |
|  | 12 | 11 | 10 |  |
| Direct | 0 | 0 | 0 |  |
|  | 0 | 0 | 1 | P.B. |
|  | 0 | 1 | 0 | C.D.B. |
|  | 0 | 1 | 1 | C.T. |
|  | 1 | 0 | 0 | P.B. |
| In- | 1 | 0 | 1 | P.B. |
| direct | 1 | 1 | 0 | C.D.B. |
|  | 1 | 1 | 1 | C. T. |

## HARDWARE ADDRESSING RESPONSE TO INSTRUCTION FORMAT

A. Direct Addressing - Bit 12 of Instruction, Off.

1. Program bank $-4,8$, or 16 groups of 1024 words, depending on memory size.

P Counter


Instruction

Memory Address Lines
2. Common data bank - first 512 words only.

3. Channel table - First 4096 or 8192 words only, depending on memory size.

*Note: Bits 9-1 of the instruction and the entire C register are logically or'ed -not addedinto the memory address lines offset as shown. Since three bits overlap, care must be exercised with respect to designating channel table length and location to insure valid addressing.
B. Indirect Addressing - Bit 12 of Instruction, On.

An address is first generated as a direct address. This address is the memory location of a word containing a 14 -bit address that is used as a base address for instruction execution.

1. Indirect addressing without register indexing. - IND


* Not Used

The 14-bit address in the indirect word is the address used for execution.
2. Indirect addressing with register indexing. -INA, INB, INC

*Not Used

Bits 14-1 of the indirect word and the contents of the specified register are added together into the memory address lines for the execution address. The register is specified by bits 17 and 16 of the indirect word as shown below.
Bits

| 17 | 16 |
| :--- | :--- |
| 0 | 0 |
| 0 | 1 |
| 1 | 0 |
| 1 | 1 |$\quad$| No Register Indexing |
| :--- |
| Register A |
| Register B |
| Register C |

The next character to be transmitted

Scan Word 1


Initialize: Start, data bits, stop and end-of-character bits to all 1's. Zero fill.

Scan Word 2
$\begin{array}{lllllll}18 & 17 & 16 & 15 & 14 & 13 & 12\end{array}$


SW2F3 Code level

SW2F2-End Hardware Scan Flag

Do Not Use

SW2F1 the character in the process of being transmitted.

| Code | Bits |  |
| :---: | :---: | :---: |
| Level | 17 | 16 |
|  |  |  |
| 5 | 0 | 0 |
| 6 | 0 | 1 |
| 7 | 1 | 0 |
| 8 | 1 | 1 |

Initialize
Bits $1-12$ as in Scan Word 1. Bits 16, 17 to indicate code level and bit 15 for end scan at last channel. Bit 18 as zero.

Scan Word 3
 character flat

Initialize: As all zeros.

## INSTRUCTION WORD FORMATS SUMMARY

## Non-Memory Addressing

C REGISTER


OPERATION CODE NOT USED VALUE

BITS 10-18
BITS 8, 9
BITS 1-7

OTHER


Memory Addressing


OPERATION CODE ADDRESSING MODE PARTIAL ADDRESS

BITS 13-18
BITS 10-12
BITS 1-9



BINARY DOUBLE LENGTH


BIT 36 IS SIGN


5 LEVEL TELETYPE CHARACTERS 3 TO A WORD BITS 1，7，AND 13 ARE START BITS


8 LEVEL FRIDEN CHARACTERS
2 TO A WORD BITS 1 AND 10 ARE START BITS BITS 6 AND 15 ARE PARITY BITS BITS 9 AND 8 ARE CONTROL BITS

# INSTRUCTION REPERTOIRE 

| WORD | CODE |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| TIMES | OCTAL |  | OPERAND | FUNCTIONAL DESCRIPTION |
| ****** | LOAD INS |  | JCTIONS |  |
| 2 | 40 | LDA | M | LOAD A FROM M |
| 2 | 60 | LDB | M | LOAD B FROM M |
| 2 | 20 | LDC | M | LOAD C FROM M |
| 3 | 21 | LDD | M | LOAD DOUBLE -- A FROM M, B FROM M+1 |
| 2 | 26 | LDF | M | LOAD SPECIAL FLIP-FLOPS FROM M |
| 2 | 23 | LDQ | M | LOAD Q FROM M |
| 2 | 25 | LDT | M | LOAD T -- SEND M TO TRANSMIT DATA DRIVE |
| 2 | 22 | LDZ | M | LOAD Z -- SEND M TO Z DRIVERS (NO FURTH |
| 2 | 41 | CMA | M | LOAD A WITH M-NOT (COMPLEMENT M TO A) |
| 2 | 61 | CMB | M | LOAD B WITH M-NOT (COMPLEMENT M TO B) |
| 1 | 011 | PIC | I | PLACE I IN C |
| ***** | STORE INSTRLCTIONS |  |  |  |
| 2 | 50 | STA | M | STORE A IN M |
| 2 | 70 | STB | M | STORE B IN M |
| 2 | 30 | STC | M | STORE C IN M |
| 3 | 31 | STD | M | STORE DOUBLE -- A IN M, B IN M+1 |
| 2 | 36 | STF | M | STORE SPECIAL FLIP-FLOPS IN M |
| 2 | 32 | STZ | M | STORE ZERO IN M |
| 2 | 51 | CAM | M | STORE A-NOT IN M (COMPLEMENT A TO M) |
| 2 | 71 | CBM | M | STORE B-NOT IN M (COMPLEMENT B TO M) |
| 2 | 33 | CMM | M | STORE M-NOT IN M (COMPLEMENT M TO M) |
| $* * * * *$ | ARITHMETIC INSTRUCTIONS |  |  |  |
| 2 | 42 | AMA | M | ADD M TO A |
| 2 | 52 | AAM | M | ADD A TO M |
| 2 | 46 | AAZ | M | ADD A, M - RESULT TO Z DRIVERS |
| 2 | 62 | AMB | M | ADD M TO B |
| 2 | 72 | ABM | M | ADD B TO M |
| 2 | 66 | ABZ | M | ADD B, M - RESULT TO Z DRIVERS |
| 2 | 37 | AMD | M | ADD DOUBLE LENGTH WORD $\mathrm{M}-(\mathrm{M}+1)$ TO $\mathrm{A}-\mathrm{B}$ |
| 2 | 34 | ADO | M | ADD ONE TO M |
| 2 | 35 | SBO | M | SUBTRACT ONE FROM M |
| 1 | 010 | AIC | I | ADD I TO C |


| word <br> TIMES | $\begin{aligned} & \text { CODE } \\ & \text { OCTAL } \end{aligned}$ |  | OPERANI) | FUNCTIONAL DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: |
| ***** | branch instrictions |  |  |  |
| 1 | 10 | BRU | M | BRANCH UNCONDITIONALLY |
| 3 | 11 | BRS | M | BRANCH TO SUBROUTINE |
| 1 | 12 | BZE | M | BRANCH IF ZERO FF IS ZERO |
| 1 | 13 | BNZ | M | Branch if zero ff is non-zero |
| 1 | 14 | BPL | M | Branch if plus ff is plus |
| 1 | 15 | BMI | M | branch if Plus ff is minus |
| 1 | 16 | BEV | M | BRANCH IF EVEN FF IS EVEN |
| 1 | 17 | BOD | M | Branch if even ff is odd |
| ****** | LOGICAL OPERATION INSTRUCTIONS |  |  |  |
| 2 | 43 | NMA | M | M AND A TO A |
| 2 | 53 | NAM | M | M AND A TO M |
| 2 | 63 | NMB | M | M AND B TO B |
| 2 | 73 | NBM | M | M AND B TO M |
| 2 | 56 | NAZ | M | M AND A TO Z ONLY |
| 2 | 76 | NBZ | M | M AND B TO $Z$ ONLY |
| , | 012 | NCZ | I | I AND C TO $Z$ ONL |
| 1 | 020 | NIS | I | I AND Internal status lines to z only |
| 1 | 022 | NES | I | I and external status lines to z only |
| 2 | 44 | BMA | M | M OR A TO A |
| 2 | 54 | RAM | M | M OR A TO M |
| 2 | 64 | RMB | M | M OR B TO B |
| 2 | 74 | RBM | M | M OR B TO M |
| 2 | 45 | XMA | M | M XOR A TO A |
| 2 | 55 | XAM | M | M XOR A TO M |
| 2 | 65 | YMB | $\cdots$ | M XOR B TO B |
| 2 | 75 | XBM | M | M XOR B TO M |
| 2 | 57 | XAZ | $\because$ | M XOR A TO Z ONLY |
| 2 | 77 | xbz | M | M XOR B TO Z ONLY |
| 1 | 014 | Xcz | I | I XOR C TO 2 ONLY |
| ****** |  | REGISTER | R TRANSFER İ | IONS FROM ABCQRS - TO ABCTZ |
| 1 | 060 | TRA | FROM, TO | TRANSFER |
| 1 | 062 | TRC | FROM, TO | TRANSFER COMPLEMENT |
| 1 | 040 | SL1 | FROM, TO | SHIFT LEFT ONE |
| 1 | 042 | SR1 | FROM, TO | SHIFT RIGHT ONE |
| , | 044 | SL6 | FROM, TO | SHift left six |
|  | 046 | SR6 | FROM, TO | Shift Right six |
| 1 | 070 | SLS | FROM, TO | SHIFT LEFT SPECIAL |
|  | 072 | SRS | FROM, TO | Shift right special |
| 1 | 050 | CL1 | FROM, TO | CIrculate left one |
| 1 | 052 | CR1 | FROM, TO | CIRCULATE RIGHT ONE |
|  | 054 | CL6 | FROM, TO | CIrculate left Six |
|  | 056 | CR6 | FROM, TO | CIRCULATE RIGHT SIX |
| 1 | 064 | BCO | From, TO | bit Change zero (8-LEVEL LINE TO 6-BIT) |
| 1 | 066 | BC1 | FROM, TO | BIT CHANGE ONE ( 6 -bit TO 8 -LEvEL LINE) |



## ABBREVIATED

## INSTRUCTION REPERTOIRE

| FIRST | SECOND | THIRI |
| :--- | :--- | :--- |
| OCTAL | OCTAL | OCTAL |
| DIGIT | DIGIT | DIGIT |



## ALPHANUMERIC LISTING

| OPR | OPERAIID | OCTAL | GROUP | DESCRIPTION | W.T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| GROUP | MNEMONIC |  |  | INTERNAL INSTRUCTIONS |  |
| GROUP | MNJEMONIC |  | BBC | BIT RUFFER CHANNEL INSTPUCTIONS |  |
| riROUP | MNEMONIC |  | ESU | BUFFER SELECTOR UNIT INSTPUCTICNS |  |
| GROUP | MNEMONIC |  | CRC | CHARACTER BUFFER CHANINEL INSTRUCTIONS |  |
| GROUP | MNEMONIC |  | CIU | COMPUTER INTERFACE UNIT INISTPUCTIONS |  |
| GROUP | MNEMONIC |  | CSU | CONTROLLER SELECTOR UNIT INSTRUCTIONS |  |
| GROUP | MPIEMONIC |  | DSU | DISC STORAGE UNIIT INSTRUCTIONS |  |
| GROUP | MNEMONIC |  | HSP | HIGH SPEEC PRIINTER INSTRUCTIONS |  |
| GROUP | MNEMONIC |  | MACRO | GENERAL ASSEMBLY PROGPAM MACRO INSTPUCTIONS |  |
| GROUP | MNEMONIC |  | MTS | MAGNETIC TAPE SYSTEM INSTRUCTIONS |  |
| GROUP | MNEMONIC |  | DTP | PAPER TAPE READEP INSTRUCTICNS |  |
| GROUP | MNEMONIC |  | $\because!C$ | WORD BUFFER CHANINEL INSTPUCTIONS |  |
| AAM | M | 520000 |  | ADD A T $\cap$ | 3 |
| AAZ | M | 460000 |  | ADD A,M - RESULT TO Z DRIVEPS | 2 |
| $A B M$ | M | 720000 |  | ADD B TO M | 3 |
| $A B Z$ | M | 660000 |  | ADD B,M - RESULT TO Z DRIVEPS | 2 |
| ADO | 11 | 340000 |  | ADD ONE TO M | 3 |
| AIC | I | 010000 |  | ADD I TO C | 1 |
| AMA | M | 420000 |  | $A D D M T \cap A$ | 2 |
| AMB | $\mu$ | 620000 |  | $A D D M T \cap B$ | 2 |
| AMD | M | 240000 |  | $A D D$ DOUBLE -- ADD ${ }^{11}, \cdots+1$ T $\cap A, B$ | 3 |
| BCO | FROM, TO | 064000 |  | bit chance zepo (8-LEVEl line to 6-EIT) | 1 |
| $B C 1$ | FROM, TO | 066000 |  | BIt Change One (6-bit to 8-LEVEL Line) | 1 |
| BEV | M | 160000 |  | BRANCH IF EVEN FF IS EVEN | 1 |
| BKW |  |  | MTS | RACKSPACE AND POSITION ! IRITE HEAD | $1+3$ |
| BMI | 11 | 150000 |  | BRANCH IF PLUS FF IS MINUS | 1 |
| BNZ | M | 130000 |  | BRANCH IF ZEPO FF IS IOII-ZERO | 1 |
| $B O D$ | M | 170000 |  | BPANCH IF EVEII FF IS OnC | 1 |
| BPL | M | 140000 |  | BRANCH IF PLUS FF IS PLUS | 1 |
| BRS | M | 110000 |  | BPANCH TO SUBROUTINE | 3 |
| BRU | M | 100000 |  | BPANCH UNCONDITIONALLY | 1 |
| B ZE | M | 120000 |  | BRANCH IF ZERO FF IS ZERO | 1 |
| CAM | $1 /$ | 510000 |  | STCRE A-MINT IN M (COMPLEMENT A TO M ) | 2 |
| CBM | M | 710000 |  | STOPE B-NOT IN M (COMDLEMENT P TO M) | 2 |
| CLI | FROM, TO | 050000 |  | CIRCULATE LEFT 1 | 1 |
| CL2 | FROM, TO |  | MACRO | CIPCULATE LEFT 2 | 2 |
| CL3 | FROM, TO |  | MACRO | CIPCULATE LEFT 3 | 3 |
| CL4 | FROM, TO |  | MACRO | Circulate left 4 | 3 |
| CL5 | FROM, TO |  | MACPO | CIRCULATE LEFT 5 | 2 |
| CL6 | FROM, TO | 054000 |  | CIPCulate left 6 | 1 |
| CL7 | FROM, TO |  | MACRO | CIRCULATE LEFT 7 | 2 |
| CL8 | FROM, TO |  | MACRO | CIRCULATE LEFT \& | 3 |


| OPR | OPERAND | OCTAL | GROUP | DESCRIPTION | W.T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CL9 | FROM, TO |  | MACRO | CIRCULATE LEFT 9 | 4 |
| CMA | M | 410000 |  | LOAD A HITH M-NOT (COMPLEMENT M TO A) | 2 |
| CMB | M | 610000 |  | LOAD B WITH M-NOT (COMPLEMENT M TO B) | 2 |
| CMM | M | 330000 |  | STORE M-NOT IN M (COMPLEMENT M TO M) | 2 |
| CR 1 | FROM, TO | 052000 |  | CIPCULATE RIGHT 1 | 1 |
| CR 2 | FROM, TO |  | MACRO | CIfCULATE RIGHT 2 | 2 |
| CR 3 | FROM, TO |  | MACRO | CIRCULATE RIGHT 3 | 3 |
| CR 4 | FROM, TO |  | MACPO | CIPCULATE RIGHT 4 | 3 |
| CR 5 | FROM, TO |  | MACRO | CIRCULATE RIGHT 5 | 2 |
| CR6 | FROM, TO | 056000 |  | CIRCULATE RIGHT 5 | 1 |
| CR 7 | FROM, TO |  | MACRO | CIRCULATE RIGHT 7 | 2 |
| CR. 8 | FRCM, TO |  | MACRO | CIRCULATE PIGHT 8 | 3 |
| CR9 | FROM, TO |  | MACRO | CIPCULATE RIGHT 9 | 4 |
| CSR | I | 032000 | CSU | CONTROLLER STATUS REOUEST | 3-10 |
| DEF | I | 026000 | BSU | DRIVE EXTERNAL FUNCTION | 1 |
| DEF | 1 | 026001 | BBC | RESET RECEIVE FLAG AND DATA BUFFER | 1 |
| DEF | 2 | 026002 | BBC | RESET TRANSMIT FLAG AND DATA BUFFER | 1 |
| DEF | 3 | 026004 | BBC | TURN CARRIER OFF | 1 |
| DEF | 4 | 026010 | BBC | TUPN CARPIER ON | 1 |
| DEF | 5 | 026020 | B8C | RESET PECEIVE CLOCK | 1 |
| DEF | 6 | 026040 | $B B C$ | SET ECHO MODE | 1 |
| DEF | 7 | 026100 | BBC | RESET ECHO MODE | 1 |
| DEF | 1 | 026001 | $C B C$ | RESET RECEIVE FLAF AND DATA RUFFER | 1 |
| DEF | 2 | 026002 | CBC | RESET TRANSMIT FLAC, AND DATA BUFFER | 1 |
| DEF | 3 | 026004 | CBC | TURN CAPRIER OFF | 1 |
| DEF | 4 | 026010 | CBC | TURN CARRIER ON | 1 |
| DEF | 9 | 026400 | $C B C$ | ANSWER INCOMING CALL | 1 |
| DEF | 0 | 027000 | CBC | DISCONNECT CALL | 1 |
| DEF | 1 | 026001 | CIU | RESET FLAG AND BUFFER, SET RECEIVE MODE | 1 |
| DEF | 2 | 026002 | CIU | RESET FLAG AND BUFFER, SET TRANSMIT MCDE | 1 |
| DEF | 9 | 026400 | CIU | AUTOMATIC PRIORITY INTERRUPT THE 225 | 1 |
| DEF | 0 | 027000 | CIU | RESET THE ADDRESS REGISTER |  |
| DEF | 1 | $026 ? 01$ | nTP | reset flag and pean next chafactep | 1 |


| OPR | OPERAND | OCTAL | GROUP | DESCRIPTION | V! . T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DEF | 1 | 026001 | UBC | RESET RECEIVE FLAF AND DATA BUFFER | 1 |
| DEF | 2 | 026002 | WBC | RESET TRANSMIT FLAF, AND DATA BUFFER | 1 |
| DEF | 3 | 026004 | $\cdots B C$ | TURN CARRIER OFF | 1 |
| DEF | 4 | 026010 | $\because B C$ | TUPI: CARRIER ON | 1 |
| DIF | I | 024000 |  | DRIVE INTERNAL FUNCTION | 1 |
| DIF | 1 | 024001 |  | RESET CB 1 AND 2, AND PESET PARITY RIT FF | 1 |
| DIF | 2 | 024002 |  | PESET BUZZER FLIP-FLOP | 1 |
| DIF | 3 | 024004 |  | SET BUZZER FLIP-FLOP | 1 |
| DIF | 4 | 024010 |  | IHITIATE HARDWARE LOAD ppocess | 1 |
| DIF | 7 | 024100 | CSU | SELECT PEPIPHEPAL CONTROLLER | $1+3$ |
| DIF | 8 | 024200 |  | SET CONTROL BIT FLIP-FLOP 1 | 1 |
| DIF | 9 | 024400 |  | SET CONTROL BIT FLIP-FLOP 2 | 1 |
| DIF | 0 | 025000 |  | SET THE PAPITY BIT FLIP-FLOP | 1 |
| HLT | I | 000000 |  | CONDITIONAL HALT | 1 |
| LDA | M | 400000 |  | LCAD A FROM M | 2 |
| LDB | $M$ | 600000 |  | LOAD B FROM M | 2 |
| LDC | 1 | 200000 |  | LOAD C FROM M | 2 |
| LnD | M | 210000 |  | LOAD DOUBLE -- A, B FROM M, M+1 | 3 |
| LDF | M | 260000 |  | LOAD SPECIAL FLIP-FLOPS FROM M | 2 |
| LDO | M | 230000 |  | LOAD $\cap$ FRCM M | 2 |
| LDT | M | 250000 | BSU | L.OAD T (TRANSMIT DATA DPIVERS) FROM M | 2 |
| LDZ | M | 220000 |  | LOAD $Z$ (BPANCH FLIP-FLCPS) FROM M | 2 |
| MAM | $M$ | 530000 |  | $M$ AND A TO M | 2 |
| NAZ | $M$ | 560000 |  | $M$ AND A TO Z ONLY | 2 |
| NBM | M | 730000 |  | $M$ AND $B$ TC M | 2 |
| NEZ | M | 760000 |  | $M$ AND B TO Z ONLY | 2 |
| NCZ | I | 012000 |  | I AND C TO $Z$ OIILY | 1 |
| NES | I | 022000 | BSU | I AND EXTERNAL STATUS LINES $T \cap Z$ ONLY | 1 |
| NES | 1 | 022001 | RBC | RC FLAG SET (BUFFER CNNTAINS A NEW BIT) | 1 |
| NES | 2 | 022002 | BBC | TX FLAG SET (BUFFER READY FOR A NEW EIT) | 1 |
| NES | 5 | 022020 | ERC | INTERLOCK ON | 1 |
| NES | 6 | 022040 | BBC | CARPIEP ON | 1 |
| NES | 1 | 022001 | $C B C$ | PC FLAG SET (BUFFEP CONTAINS A NEW CHAP.) | 1 |
| IIES | 2 | 022002 | $C B C$ | TX FLAF SET (BUFFER READY FOR A NEW CHAR.) | 1 |
| INES | 3 | 022004 | $C B C$ | CALL IN PROGRESS | 1 |
| NES | 4 | 022010 | $C B C$ | RENUEST ANSVER. | 1 |
| NES | 5 | 022020 | CFC | DATA MODE | 1 |
| NES | 6 | 022040 | CBC | CARRIER ON |  |
| NES | 7 | 022100 | CBC | CLEAR TO SEND | 1 |
| NES | 1 | 022001 | CIU | FLAG SET (BUFFER READY) | 1 |
| NES | 1 | 022001 | PTR | READ FLAG SET (BUFFER CONTAINS A NEW CHAR.) | 1 |


| OPR | OPERAND | OCTAL | GROUP | DESCRIPTION | W.T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NES | 1 | 022001 | WBC | RC FLAG SET (BUFFER CONTAINS A NEW WORD) | 1 |
| NES | 2 | 022002 | WBC | TX FLAG SET (BUFFER READY FOR A NEW WORD) | 1 |
| NIS | 1 | 020000 |  | I AND INTERNAL STATUS LINES TO $Z$ Only | 1 |
| NIS | 1 | 020001 |  | CHARACTER PARITY OUTPUT | 1 |
| NIS | 2 | 020002 |  | WORD PARITY OUTPUT | 1 |
| NIS | 3 | 020004 |  | CB FF 2 AND WORD PARITY OUTPUT ARE E OUAL | 1 |
| NIS | 4 | 020010 | csu | SWitch is in the maintenance mode | 1 |
| NIS | 7 | 020100 | CSU | SELECT COMMAND IS COMPLETED | 1 |
| NIS | 8 | 020200 |  | CB FF 1 1 | 1 |
| NIS | 9 | 020400 |  | CB FF 2 | 1 |
| NIS | 0 | 021000 |  | PARITY FF |  |
| NMA | M | 430000 |  | $M$ AND A TO A | 2 |
| NMB | M | 630000 |  | $M$ AND B TO B | 2 |
| PIC | I | 011000 |  | PLACE I IN C | 1 |
| PRF |  |  | DSU | POSITION DISC STORAGE UNIT |  |
| RAM | M | 540000 |  | M OR A TO M | 2 |
| RBD |  |  | MTS | READ BACKWARD DECIMAL | $1+3$ |
| RBM | M | 740000 |  | M OR B TO M | 2 |
| RBS |  |  | MTS | READ BACKWARD BINARY | $1+3$ |
| RMA | M | 440000 |  | M OR A TO A | 2 |
| RMB | M | 640000 |  | $M O R B T \cap B$ | 2 |
| RRF |  |  | DSU | READ DSU |  |
| RTB |  |  | MTS | READ TAPE BINAPY | $1+3$ |
| RTD |  |  | MTS | READ TAPE DECIMAL | $1+3$ |
| RHD |  |  | MTS | PEWIND | $1+3$ |
| SAM | M |  | MACRO | SUBTRACT A FROM M | 7 |
| SBM | M |  | MACRO | SUBTRACT R FROM M | 7 |
| SBO | M | 350000 |  | SUBTRACT ONE FROM M | 3 |
| SCN | I | 030000 | BBC | SCAN BIT BUFFER UNITS | $1+3 \mathrm{~N}$ |
| SEL |  | 024100 | csu | SELECT PERIPHERAL COMTPOLLER | $1+3$ |
|  | FROM, TO | 040000 |  | SHIFT LEFT 1 |  |
| SL2 | FROM, TO |  | MACRO | SHIFT LEFT 2 | 2 |
| SL3 | FROM, TO |  | MACRO | SHIFT LEFT 3 | 3 |
| SL4 | FROM, TO |  | MACRO | SHIFT LEFT 4 | 4 |
| SL5 | FROM, TO |  | MACRO | SHIFT LEFT 5 | 5 |
| SL6 | FROM, TO | 044000 |  | SHIFT LEFT 6 | 1 |
| SL7 | FROM, TO |  | MACRO | SHIFT LEFT 7 | 2 |
| SL8 | FROM, TO |  | MACRO | SHift Left 8 | 3 |
| SL9 | FROM, TO |  | MACRO | SHIFT LEFT 9 | 4 |
| SLD | I |  | MACRO | SHIFT A, B LEFT I BITS | 2 I |


| OPR | OPEPAND | OCTAL | GROUP | DESCRIPTION | W.T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SLS | FROM, TO | 070000 |  | SHIFT LEFT SPECIAL | 1 |
| SLT |  |  | HSP | SLEW PAFER TO TAPE PUNCH | $1+3$ |
| SLW |  |  | HSP | SLEVING OF PAPER | $1+3$ |
| SMA | M |  | MACRO | SUBTPACT M FROM A | 4 |
| SMB | M |  | MACRO | SUBTRACT M FROM B | 4 |
| SMD | M |  | MACRO | SIJBTRACT $M, M+1$ FRCM A, B | 7 |
| SR 1 | FROM, TO | 042000 |  | SHIFT RIGHT 1 | 1 |
| SR 2 | FROM, TO |  | MACRO | SHIFT RIGHT 2 | 2 |
| SR3 | FROM, TO |  | MACRO | SHIFT PIGHT 3 | 3 |
| SR 4 | FROM, TO |  | MACPO | SHIFT PIGHT 4 | 4 |
| SR 5 | FROM, TO |  | MACRO | SHIFT RIGHT 5 | 5 |
| SR6 | FROM, TO | 046000 |  | SHIFT RIGHT 6 | 1 |
| SR 7 | FROM, TO |  | MACRO | SHIFT RIGHT 7 | 2 |
| SR 8 | FROM, TO |  | MACRO | SHIFT PIGHT 8 | 3 |
| SR9 | FROM, TO |  | MACRO | SHIFT RIGHT 9 | 4 |
| SRD | 1 |  | MACRO | SHIFT A, B RIGHT I BITS | 2 I |
| SRS | FROM, TO | 072000 |  | CIRCULATE RIGHT SPECIAL | 1 |
| STA | M | 500000 |  | STORE A IN M | 2 |
| STB | M | 700000 |  | STORE B IN M | 2 |
| STC | M | 300000 |  | STOPE C IN M | 2 |
| STD | M | 310000 |  | STARE DOUBLE -- A, B IN M, M+1 | 3 |
| STF | M | 360000 |  | STORE SPECIAL FLIP-FLOPS | 2 |
| STZ | M | 320000 |  | STOPE ZERO IN M | 2 |
| TRA | FROM, TO | 060000 |  | TPAISFEP | 1 |
| TRC | FROM, TO | 062000 |  | TPANSFER COMPLEMENT | 1 |
| WEF |  |  | MTS | W!RITE END OF FILE | $1+3$ |
| WFL |  |  | HSP | URITE FORMAT LINE | $1+3$ |
| WPL |  |  | HSP | WPITE PRINT LINE | $1+3$ |
| WRF |  |  | DSU | URITE DSU |  |
| WTB |  |  | MTS | Write tape binary | $1+3$ |
| WTD |  |  | MTS | WPITE TAPE DECIMAL | $1+3$ |
| XAM | M | 550000 |  | $M X \cap R$ A $T \cap M$ | 2 |
| XAZ | M | 570000 |  | M X O A A TO $Z$ Oilly | 2 |
| $X B M$ | M | 750000 |  | $\mu X O P \quad B \quad T O M$ | 2 |
| XBS 2 | M | 770000 |  | 14 XOP R TO Z OIlly | 2 |
| $X C Z$ | I | 014000 |  | I XOR C TO Z ONLY | 1 |
| XMA | M | 450000 |  | $M X \cap R \quad A \quad T \cap A$ | 2 |
| $X \wedge 1 B$ | M | 650000 |  | $M X O R \quad B \quad T \cap B$ | 2 |

DATANET•马30

|  |  |  |  | OCTAL LISTING, |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| OPR | OPERAND | OCTAL | GROUP | DESCRIPTION | W.T. |
| group | MPEMONIC |  |  | INTERNAL INSTRUCTIONS |  |
| GROUP | MIJEMONIC |  | BBU | BIT BUFFER UNIT INSTRUCTIONS |  |
| group | MNEMONIC |  | BSU | BUFFER SELECTOR UNIT INSTRUCTIONS |  |
| group | MNEMONIC |  | CBIJ | CHARACTER BUFFER UNIT INSTRUCTIONS |  |
| group | MNEMONIC |  | ciu | COMPUTER INTERFACE UNIT INSTRUCTIONS |  |
| GROUP | M MNEMONIC |  | csu | CONTROLLER SELECTOR UNIT INSTRUCTIONS |  |
| group | MNEMONIC |  | HSP | HIGH SPEED PRINTER INSTPUCTIONS |  |
| GROUP | MNEMONIC |  | MACRO | GENERAL ASSEMBLY PROGRAM MACRO INSTRUCTIONS |  |
| group | MNEMONIC |  | MTS | magentic tape system instructions |  |
| GROUP | MNEMONIC |  | PTR | PAPER TAPE READER INSTRUCTIONS |  |
| GROUP | MNEMONIC |  | WBU | WORD BUFFER UNIT INSTRUCTIONS |  |
| HLT | I | 000000 |  | CONDITIONAL HALT | 1 |
| AIC | I | 010000 |  | ADD I TO C | 1 |
| PIC | I | 011000 |  | place i in c | 1 |
| NCZ | I | 012000 |  | I AND C TO Z ONLY | 1 |
| XCZ | I | 014000 |  | I XOR C TO Z ONLY | 1 |
| NIS | I | 020000 |  | I AND INTERNAL STATUS LINES TO Z ONLY | 1 |
| NIS | 1 | 020001 |  | CHARACTER PARITY OUTPUT | 1 |
| NIS | 2 | 020002 |  | WORD PARITY OUTPUT | 1 |
| NIS | 3 | 020004 |  | CB FF 2 AND IIORD PARITY OUTPUT ARE ENUAL | 1 |
| NIS | 4 | 020010 |  | Shitch is in the manual mode | 1 |
| NIS | 7 | 020100 | csu | SELECT COMMAND is COMPLETED | 1 |
| NIS | 8 | 020200 |  | CB FF 1 | 1 |
| NIS | 9 | 020400 |  | CB FF 2 | 1 |
| NIS | 0 | 021000 |  | PARITY FF | 1 |
| NES | , | 022000 | BSU | I AND EXTERNAL Status lines to $Z$ Only | 1 |
| NES | 1 | 022001 | BBC | RC FLAG SET (BUFFER CONTAINS A NEW BIT) | 1 |
| NES | 1 | 022001 | CBC | RC FLAG SET (BUFFER CONTAINS A NEW CHAR.) | 1 |
| NES | 1 | 022001 | CIU | FLAF SET (BUFFER READY) | 1 |
| NES | 1 | 022001 | PTR | READ FLAG SET (BUFFER CONTAINS A NEW CHAP.) | 1 |
| NES | 1 | 022001 | WBC | RC FLAG SET (BUFFER CONTAINS A NEW WORD) |  |
| NES | 2 | 022002 | BBC | TX FLAG SET (BUFFER READY FOR A NEW EIT) | 1 |
| NES | 2 | 022002 | CBC | TX FLAG SET (BUFFER READY FOR A NEW! CHAR.) | 1 |
| NES | 2 | 022002 | WBC | WBC FLAG SET (BUFFER PEADY FOR A NEW WORD) | 1 |
| NES | 3 | 022004 | CBC | CALL IN PROGRESS | 1 |
| NES | 4 | 022010 | CBC | RENUEST ANSWER | 1 |
| NES | 5 | 022020 | CBC | data mode | 1 |


| OPR | OPERAND | OCTAL | group | DESCRIPTION | W.T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NES | 6 | 022040 | CBC | CARRIER ON | 1 |
| NES | 7 | 022100 | $C B C$ | CLEAR TO SEND | 1 |
| DIF | I | 024000 |  | DRIVE INTERNAL FUNCTION |  |
| DIF | 1 | 024001 |  | RESET CB 1 AND 2, AND RESET PARITY BIT FF | 1 |
| DIF | 2 | 024002 |  | RESET BUZZER FLIP-FLOP | 1 |
| DIF | 3 | 024004 |  | SET BUZZER FLIP-FLOP | 1 |
| DIF | 4 | 024010 |  | INITIATE HAPDWARE LOAD PROCESS |  |
| DIF | 7 | 024100 | csu | SELECT PERIPHERAI. CONTROLLER | $1+3$ |
| SEL |  | 024100 | csu | SELECT PEPIPHERAL CONTPOLLEP | $1+3$ |
| DIF | 8 | 024200 |  | SET CONTR ${ }^{\text {c }}$ SIT FLIP-FLOP 1 | 1 |
| DIF | 9 | 024400 |  | SET CONTROL BIT FLIP-FLOP 2 | 1 |
| DIF | 0 | 025000 |  | SET THE PARITY EIT FLIP-FLOR | 1 |
| DEF | I | 026000 | BSU | DRIVE EXTERNAL FUNCTIOM | 1 |
| DEF | 1 | 026001 | BBC | PESET RECEIVE FLAG AND CATA RUFFER | 1 |
| DEF | 1 | 026001 | CBC | RESET RECEIVE FLAF AND CATA BUFFER | 1 |
| DEF | 1 | 026001 | CIU | RESET FLAs, AND BUFFER, SET RECEIVE MODE | 1 |
| DEF | 1 | 026001 | PTR | RESET flar, and read next chafacter | 1 |
| DEF | 1 | 026001 | VBC | RESET RECEIVE flar and mata buffer | 1 |
| DEF | 2 | 026002 | BBC | RESET TRANSMIT FLAG AND DATA BUFFEP | 1 |
| DEF | 2 | 026002 | CBC | RESET TRANSMIT FLAG ANC CATA BUFFER | 1 |
| DEF | 2 | 026002 | CIU | RESET FLAr, AND BUFFER, SET TRANSMIT MCDE | 1 |
| DEF | 2 | 026002 | HBC | RESET TPANSMIT FLAG, AND DATA PUFFER | 1 |
| DEF | 3 | 026004 | REC | TURN CAPRIER OFF | 1 |
| DEF | 3 | 026004 | CBC | TURN CAPRIER OFF | 1 |
| DEF | 3 | 026004 | MBC | TURN CAPFIEP OFF |  |
| DEF | 4 | 026010 | BBC | TUPN CARRIER ON | 1 |
| DEF | 4 | 026010 | CBC | TURN CARRIER ON | 1 |
| DEF | 4 | 026010 | WBC | TURN CAFRIER ON | 1 |
| DEF | 5 | 026020 | $B B C$ | RESET RECEIVE CLOCK | 1 |
| DEF | 6 | 026040 | BBC | SET ECH M Mode | 1 |


| OPR | OPERAND | OCTAL | rrROUP | DESCRIPTION | U.T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DEF | 7 | 026100 | $B B C$ | RESET ECHO MODE | 1 |
| DEF | 9 | 026400 | CBC | ANSWER INCOMINT CALL | 1 |
| DEF | 9 | 026400 | CIU | AUTOMATIC PRIORITY INTERRUPT THE 225 | 1 |
|  |  |  |  |  | 1 |
| DEF | 0 | 027000 | CBC | DISCONNECT CALL | 1 |
| DEF | 0 | 027000 | CIU | RESET THE ADDRESS REGISTER | 1 |
| SCN | I | 030000 | BEC | SCAN BIT BUFFER UNITS | $1+3 \mathrm{~N}$ |
| CSR | I | 032000 | CSU | CONTROLLEP STATUS REOUEST | 3-10 |
| SLI | FROM, TO | 040000 |  | SHIFT LEFT 1 | 1 |
| SR1 | FROM, TO | 042000 |  | SHIFT RIGHT 1 | 1 |
| SL6 | FROM, TO | 044000 |  | SHIFT LEFT 6 | 1 |
| SR6 | FROM, TO | 046000 |  | SHIFT RIGHT 6 | 1 |
| CL1 | FROM, TO | 050000 |  | CIRCULATE LEFT 1 | 1 |
| CR1 | FROM, TO | 052000 |  | CIRCULATE RIGHT 1 | 1 |
| CL6 | FROM, TO | 054000 |  | CIRCULATE LEFT 6 | 1 |
| CRG | FROM, TO | 056000 |  | CIRCULATE RIGHT 6 | 1 |
| TRA | FROM, TO | 060000 |  | TRANSFER | 1 |
| TRC | FROM, TO | 062000 |  | TRANSFER COMPLEMENT | 1 |
| BCO | FROM, TO | 064000 |  | BIT CHANGE ZERO (8-LEVEL LINE TO 6-bIT) | 1 |
| BC1 | FROM, TO | 066000 |  | BIT CHANGE ONE (6-BIT TO 8-LEVEL LINE) | 1 |
| SLS | FROM, TO | 070000 |  | SHIFT LEFT SPECIAL | 1 |
| SRS | FROM, TO | 072000 |  | CIRCULATE PIGHT SPECIAL | 1 |
| BRU | M | 100000 |  | BRANCH UNCONDITIONALLY | 1 |
| BRS | M | 110000 |  | BPANCH TO SUBROUTINE | 3 |
| BZE | $M$ | 120000 |  | BRANCH IF ZERO FF IS ZERO | 1 |
| BNZ | 11 | 130000 |  | BRANCH IF ZERO FF IS NON-ZERO | 1 |
| BPL | $M$ | 140000 |  | BRANCH IF PLUS FF IS PLUS | 1 |
| BMI | M | 150000 |  | BPANCH IF PLUS FF IS MINUS | 1 |
| BEV | $M$ | 160000 |  | BRANCH IF EVEN FF IS EVEN | 1 |
| BOD | $M$ | 170000 |  | BRANCH IF EVEN FF IS ODD | 1 |
| LDC | M | 200000 |  | LOAD C FROM M | 2 |
| LDD | M | $210000$ |  | LOAD DOUBLE -- A, B FPOM $M, M+1$ | 3 |
| LDZ | $M$ | 220000 |  | LOAD Z (BPANCH FLIP-FLOPS) FROM M | 2 |
| LDO | M | 230000 |  | L@AD $\cap$ FROM M | 2 |
| AMD | M | 240000 |  | ADN DOUBLE -- ADD M, $M+1$ TO $A, B$ | 3 |
| LDT | M | 250000 | BSU | LOAD T (TRANSMIT DATA DRIVEPS) FROM M | 2 |
| LDF | M | 260000 |  | LOAD SPECIAL FLIP-FLOPS FROM M | 2 |
|  |  |  |  | - |  |


| OPR | OPERAND | OCTAL | GROUP | DESCPIPTION |  | W.T. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STC | M | 300000 |  | STORE C IN M |  | 2 |
| STD | M | 310000 |  | STORE DOURLE -- A, B IN M, M+1 |  | 3 |
| STZ | M | 320000 |  | STORE ZEPO IN M |  | 2 |
| CMM | M | 330000 |  | STORE M-NOT IN M (COMPLEMENT M | $T \cap M$ ) | 2 |
| ADO | M | 340000 |  | ADD ONE TO M |  | 3 |
| SBO | M | 350000 |  | SUBTRACT ONE FROM M |  | 3 |
| STF | M | 360000 |  | STORE SPECIAL FLIP-FLOPS |  | 2 |
| LDA | 11 | 400000 |  | LOAD A FROM M |  | 2 |
| CMA | 11 | 410000 |  | LOAD A WITH M-NOT (COMPLEMENT M | $T \cap A)$ | 2 |
| A ${ }^{1}$ A | M | 420000 |  | ADD M TO A |  | 2 |
| NMA | M | 430000 |  | $M$ AND A TO A |  | 2 |
| RMA | $\cdots$ | 440000 |  | $M \cap R$ A TO A |  | 2 |
| XMA | M | 450000 |  | $M X \cap R \quad A \quad T \cap A$ |  | 2 |
| AAZ | $M$ | 460000 |  | AחD A,M - RESULT TO Z DRIVEPS |  | 2 |
| STA | M | 500000 |  | STORE A IN M |  | 2 |
| CAM | M | 510000 |  | STORE A-NOT IN M (COMPLEMENT A | TO M) | 2 |
| AAM | $\cdots$ | 520000 |  | ADD A TO M |  | 3 |
| NAM | M | 530000 |  | $M$ AND A TC M |  | 2 |
| RAM | M | 540000 |  | $M \cap R \quad A \quad T O M$ |  | 2 |
| XAM | $\uparrow$ | 550000 |  | $M$ XOR A TO M |  | 2 |
| NAZ | M | 560000 |  | $M$ AND A TO Z ONLY |  | 2 |
| XAZ | $\mu$ | 570000 |  | M XOR A TO Z ONLY |  | 2 |
| LDE | M | 600000 |  | LOAD B FROM M |  | 2 |
| $C M B$ | M | 610000 |  | LOAD B HITH M-NOT (COMPLEMENT * | $T \cap B)$ | 2 |
| AME | $M$ | 620000 |  | ADD M T $\cap$ B |  | 2 |
| NME | M | 630000 |  | $M$ ANID B TO B |  | 2 |
| RMB | $M$ | 640000 |  | $M \cap R \quad B T \cap B$ |  | 2 |
| $X{ }^{M} B$ | 14 | 650000 |  | $\mu X \cap R \quad B \quad T \cap B$ |  | 2 |
| $A E Z$ | $M$ | 660000 |  | ADO R,M - RESULT TO Z DRIVERS |  | 2 |
| STB | $\stackrel{ }{M}$ | 700000 |  | STOPE B IN M |  | 2 |
| CEM | 11 | 710000 |  | STCRE B-HOT IN M (COMPLEMENT S | $T \cap$ M) | 2 |
| ABM | $\cdots$ | 720000 |  | ADD P TO M |  | 3 |
| ISBM | M | 730000 |  | M AND B TO M |  | 2 |
| REM | $M$ | 740000 |  | $M$ OP. B TO M |  | 2 |
| XEM | M | 750000 |  | $M \times \cap \mathrm{B}$ B $T \cap M$ |  | 2 |
| IVEZ | $M$ | 760000 |  | M ANIN B TO Z ONILY |  | 2 |
| XeZ | M | 770000 |  | M XOP P, TO Z OMILY |  | 2 |
| graup | MPIEMONIIC |  | HSP | hirhe speed printep in:structirais |  |  |
| SLT |  |  | HSP | SLEl PAPEP TO TAPE PUMCH |  | $1+3$ |
| SL.' |  |  | HSP | SLEVING OF PAPER |  | $1+3$ |
| WFL |  |  | HSP | I!RITE FOPMAT LINE |  | $1+3$ |
| UPL |  |  | HSP | UPITE PPINT LINE |  | $1+3$ |
| GROUP | MNEMOHIC |  | DSU | DISC STOPAGE UNIT INSTRUCTIONS |  |  |
| PRF |  |  | DSU | FOSITION CISC STORACE UNIT |  |  |
| RRF |  |  | DSU | PEAD DSU |  |  |
| VRF |  |  | DSU | WRITE DSU |  |  |


| OPR | CPERAND | OCTAL | GROUP | DESCRIPTION | W.T. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| GROUP | MNEMONIC |  | MTS | MAGNETIC TAPE SYSTEM INSTRUCTIONS |  |
| BKW |  |  | MTS | BACKSPACE AND POSITION WRITE HEAD | $1+3$ |
| RBD |  |  | MTS | READ BACKWARD DECIMAL | $1+3$ |
| RBS |  |  | MTS | READ BACKWARD BINARY | $1+3$ |
| RTB |  |  | MTS | READ TAPE BINARY | $1+3$ |
| RTD |  |  | MTS | READ TAPE DECIMAL | $1+3$ |
| RWD |  |  | MTS | REWIND | $1+3$ |
| WEF |  |  | MTS | WRITE END OF FILE | $1+3$ |
| WTB |  |  | MTS | WRITE TAPE BINARY | $1+3$ |
| WTD |  |  | MTS | WPITE TAPE DECIMAL | $1+3$ |
| GRRUP | MNEMONIC |  | MACRO | GENERAL ASSEMBLY PROGRAM MACRO INS |  |
| CL2 | FROM, TO |  | MACRO | CIPCULATE LEFT 2 | 2 |
| CL3 | FROM, TO |  | MACRO | CIRCULATE LEFT 3 | 3 |
| CL4 | FROM, TO |  | MACRO | CIRCULATE LEFT 4 | 3 |
| CL5 | FROM, TO |  | MACRO | Circulate left 5 | 2 |
| CL7 | FROM, TO |  | MACPO | CIRCULATE LEFT 7 | 2 |
| CL8 | FROM, TO |  | MACRO | CIRCULATE LEFT 8 | 3 |
| CL9 | FROM, TO |  | MACRO | Circulate left 9 | 4 |
| CR2 | FROM, TO |  | MACRO | CIRCULATE PIGHT 2 | 2 |
| CR3 | FROM, TO |  | MACRO | CIRCULATE RIGHT 3 | 3 |
| CR 4 | FROM, TO |  | MACRO | CIRCULATE RIGHT 4 | 3 |
| CR 5 | FROM, TO |  | MACRO | CIPCULATE RIGHT 5 | 2 |
| CR 7 | FROM, TO |  | MACRO | CIRCULATE RIGHT 7 | 2 |
| CR 8 | FROM, TO |  | MACRO | CIRCULATE RIGHT 8 | 3 |
| CR9 | FROM, TO |  | MACPO | CIPCULATE RIGHT 9 | 4 |
| SAM | M |  | MACRO | SUBTRACT A FROM M | 7 |
| SBM | M |  | MACRO | SUBTRACT B FROM M | 7 |
| SL2 | FROM, TO |  | MACRO | SHIFT LEFT 2 | 2 |
| SL3 | FROM, TO |  | MACRO | SHIFT LEFT 3 | 3 |
| SL4 | FROM, TO |  | MACRO | SHIFT LEFT 4 | 4 |
| SL5 | FROM, TO |  | MACRO | SHIFT LEFT 5 | 5 |
| SL7 | FROM, TO |  | MACRO | SHIFT LEFT 7 | 2 |
| SL8 | FROM, TO |  | MACRO | SHIFT LEFT 8 | 4 |
| SL9 | FROM, TO |  | MACRO | SHIFT LEFT 9 | 4 |
| SLD | I |  | MACRO | SHIFT A, B LEFT I BITS | 2 I |
| SMA | M |  | MACRO | SUBTRACT M FPOM A | 4 |
| SMB | M |  | MACRO | SUBTRACT M FROM B | 4 |
| SMD | M |  | MACRO | SUBTRACT M, M+1 FROM A, B | 7 |
| SR2 | FROM, TO |  | MACRO | SHIFT RIGHT 2 | 2 |
| SR3 | FROM, TO |  | MACRO | SHIFT RIGHT 3 | 3 |
| SR 4 | FROM, TO |  | MACRO | SHIFT RIGHT 4 | 4 |
| SR 5 | FROM, TO |  | MACRO | SHIFT RIGHT 5 | 5 |
| SR 7 | FROM, TO |  | MACRO | SHIFT RIGHT 7 |  |
| SR8 | FROM, TO |  | MACRO | SHIFT RIGHT 8 |  |
| SR9 | FROM, TO |  | MACRO | SHIFT RIGHT 9 | 4 |
| SRD | I |  | MACRO | SHIFT A, B RIGHT I BITS | 2 I |

INDEX TO INSTRUCTIONS

| INSTRUCTIONS |  |  | PAGE | $\begin{gathered} \text { LOGICAL } \\ \text { OPERATION } \\ \text { INSTRUCTIONS } \end{gathered}$ |  |  | PAGE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 40 | LDA | M | II-3 |  |  |  |  |
| 60 | LDB | M | 3 | 43 | NMA | M | II-8 |
| 20 | LDC | M | 3 | 53 | NAM | M | 8 |
| 21 | LDD | M | 3 | 63 | NMB | M | 8 |
| 26 | LDF | M | 24 | 73 | NBM | M | 8 |
| 23 | LDQ | M | 3 | 56 | NAZ | M | 8 |
| 25 | LDT | M | 25 | 76 | NBZ | M | 9 |
| 22 | LDZ | M | 3 | 012 | NCZ | I | 9 |
| 41 | CMA | M | 3 | 020 | NIS | I | 22 |
| 61 | CMB | M | 4 | 022 | NES | I | 25 |
| 011 | PIC | I | 4 | 44 | RMA | M | 9 |
|  |  |  |  | 54 | RAM | M | 9 |
|  | ORE |  |  | 64 | RMB | M | 9 |
| INST | RUCTIO | NS |  | 74 | RBM | M | 10 |
|  |  |  |  | 45 | XMA | M | 10 |
| 50 | STA | M | 5 | 55 | XAM | M | 10 |
| 70 | STB | M | 5 | 65 | XMB | M | 10 |
| 30 | STC | M | 5 | 75 | XBM | M | 10 |
| 31 | STD | M | 5 | 57 | XAZ | M | 11 |
| 36 | STF | M | 24 | 77 | XBZ | M | 11 |
| 32 | STZ | M | 5 | 014 | XCZ | I | 11 |
| 51 | CAM | M | 5 |  |  |  |  |
| 71 | CBM | M | 5 |  | GISTE |  |  |
| 33 | CMM | M | 5 |  | ANS F |  |  |
|  |  |  |  | INST | RUCTI | NS |  |
| $\begin{aligned} & \text { ARI } \\ & \text { INSI } \end{aligned}$ | RUCTIC | NS |  | 060 | TRA | FROM, TO | 13 |
|  |  |  |  | 062 | TRC | FROM, TO | 13 |
| 42 | AMA | M | 6 | 040 | SL1 | FROM, TO | 13 |
| 52 | AAM | M | 6 | 042 | SR1 | FROM, TO | 13 |
| 46 | AAZ | M | 7 | 044 | SL6 | FROM, TO | 13 |
| 62 | AMB | M | 6 | 046 | SR6 | FROM, TO | 13 |
| 72 | ABM | M | 6 | 070 | SLS | FROM, TO | 14 |
| 66 | ABZ | M | 7 | 072 | SRS | FROM, TO | 14 |
| 37 | AMD | M | 6 | 050 | CL1 | FROM, TO | 14 |
| 34 | ADO | M | 6 | 052 | CR1 | FROM, TO | 14 |
| 35 | SBO | M | 7 | 054 | CL6 | FROM, TO | 14 |
| 010 | AIC | I | 6 | 056 | CR6 | FROM, TO | 14 |
|  |  |  |  | 064 | BC0 | FROM, TO | 15 |
|  | RANCH |  |  | 066 | BC1 | FROM, TO | 15 |
| INST | RUCTI | NS |  |  | 㖪 |  |  |
| 10 | BRU | M | 16 | INST | RUCT | ONS |  |
| 11 | BRS | M | 16 |  |  |  |  |
| 12 | BZE | M | 16 | 00 | HLT |  | 24 |
| 13 | BNZ | M | 16 | 024 | DIF | I | 22 |
| 14 | BPL | M | 16 | 026 | DEF | I | 25 |
| 15 | BMI | M | 16 | 030 | SCN | I | 25 |
| 16 | BEV | M | 16 |  |  |  |  |
| 17 | BOD | M | 17 |  |  |  |  |


| TITLE: | DATANET-30 Programming Reference Manual |
| :---: | :---: |
| CPB | 1019A |

Name: $\qquad$
Position: $\qquad$
Address: $\qquad$

CHECK ONE:

$\square$
Additional information would be helpful on following subjects.
$\square$ Errors indicated and pages where errors occur.
$\square$ Usefulness of manual could be improved as noted.

## FOLD



FOLD


[^0]:    Position in the Instruction Word, I

[^1]:    * For ease of computation the $6.94 \mu \mathrm{sec}$ memory cycle is rounded to $7.0 \mu \mathrm{sec}$.

