Scholars' Mine
Masters Theses

Student Theses and Dissertations

1972

A hardware and software interface between a magnetic tape unit
and a Nova mini-computer
Thomas Dean Steury

Follow this and additional works at: https://scholarsmine.mst.edu/masters_theses
Part of the Electrical and Computer Engineering Commons

Department:
Recommended Citation
Steury, Thomas Dean, "A hardware and software interface between a magnetic tape unit and a Nova minicomputer" (1972). Masters Theses. 4190.
https://scholarsmine.mst.edu/masters_theses/4190

This thesis is brought to you by Scholars' Mine, a service of the Missouri S&T Library and Learning Resources. This
work is protected by U. S. Copyright Law. Unauthorized use including reproduction for redistribution requires the
permission of the copyright holder. For more information, please contact scholarsmine@mst.edu.

A HARDWARE AND SOFTWARE INTERFACE
BETWEEN A MAGNETIC TAPE UNIT
AND A NOVA MINI-COMPUTER

BY

THOMAS DEAN STEURY, 1948-

A THESIS

Presented to the Faculty of the Graduate School of the

UNIVERSITY OF MISSOURI-ROLLA

In Partial Fulfillment of the Requirements for the Degree

MASTER OF SCIENCE IN ELECTRICAL ENGINEERING

1972

Approved by

?

'

ii

ABSTRACT
This thesis is concerned with the general operation of
the Kennedy Model 1400R incremental write/continuous read
magnetic tape unit and the hardware design and software
implementation needed to make it compatible for use with the
Data General Nova

Boo

mini-computer.

The hardware design was developed around a General Purpose Interface Board which provides a standard set of logic
needed for interfacing any external device to the Nova.

The

hardware consists of decode networks, mode selection networks, and I/0 timing networks.

Special circuits needed to

implement the hardware design and perform voltage conversions between the tape unit and the Nova computer are included.

The complete hardware design utilizes TTL Inte-

grated Circuit logic.
A software package was written in Nova assembler
language which allows the user to write programs or data on
magnetic tape and be able to read the programs or data off
the tape when needed.

Portions of these programs are dis-

cussed in this thesis.
The result of this hardware design and software
implementation is a device by which faster input and output
can be obtained.

iii

ACKNOWLEDGEMENT
The author wishes to express his sincere appreciation
to Dr. James Tracey for his patience and guidance in the
preparation of this thesis and to Dr. Hugh Spence for his
technical assistance.

Appreciation is also extended to

Wayne Omohundro for his assistance in testing both the hardware design and the software implementation.
Special thanks goes to my wife Janet for her patience
in this undertaking and for her excellent typing ability.

iv

TABLE OF CONTENTS

Page
ABSTRACT ••••••••••••••••••••••••••••••••••••••••••••••••• i i
ACKNOWLEDGEMENT •••••••••••••••.••••••••••••••••••••••••• i i i
LIST OF ILLUSTRATIONS •••••••••••••••••••••••••••••••••••• vi
L I S T 0 F TABLES • • • • • • • • • • • • • • • • • • • • • • • • • • • • • . • • • • • • • • . • • • vi i

I.
II.

INTRODUCTION .••.•••••••••••••••••••••••••••••••••• • l
TAPE DECK OPERATION ••••.•••••••••••••••••••••••..•• 3

A.

Incremental Write Description ................ 3

B.

Continuous Read Description .................. 7

C.

Pushbutton Controls . . . . . . . . . . . . . . . . . . . . . . . . . . 9

D.
III.

1.

Load Forward . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9

2.

Ready . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

3.

File Gap . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . lO

4.

Rewind . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . lO

Loading Procedure . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

HARDWARE DESIGN ••••••.••••••••.•••••.••••••••.••.• 13
A.

General Description of Nova Computer ........ 13

B.

General Purpose Interface . . . . . . . . . . . . . . . . . . . 14

C.

Spec i a 1 Circuits . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
1.

Clamping Circuit . . . . . . . . . . . . . . . . . . . . . . . 20

2.

Monostable Multivibrator ............... 22

3.

Delay Circuit . . . . . . . . . . . . . . . . . . . . . . . . . . 26

4.

Open Collector Inverters . . . . . . . . . . . . . . . 28

v

Table of Contents (continued)
D.

IV.

V.

Page

I/0 Control Networks ......................... 29
1.

Decode Network .......................... 29

2.

Read/Write Select Network ............... 32

3.

Input/Output Timing Networks ............ 34

SOFTWARE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41

A.

Basic I/0 Instructions ....................... 41

B.

Program Techniques ........................... 43

CONCLUSION . . . . . . . . . . . . . . . . . . . • . . . . . . . . . . . . . . . . . . . . . 4 8

BIBLIOGRAPHY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1~9
VITA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50

APPENDICES . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51

A.

Signal Abbreviation List ..................... 51

B.

Software Examples ............................ 53

vi

LIST OF ILLUSTRATIONS
Figures

Page

l.

NRZI Recording ....................................... 4

2.

End-of-Record and End-of-File Gaps ................... 6

3.

Skew Delay .... . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8

4.

Tape Path ........................................... 12

5.

Device Select Logic and Control Line Buffer ......... l6

6.

I/0 Data Buffer and Registers ....................... 17

7.

Interrupt Control and Acknowledge ................... 18

8.

Clamping Circuit .................................... 21

9.

Monostable Multivibrator and Signals ................ 24

10.

Delay Circuit and Signals ........................... 27

11.

Decode Network ...................................... 30

12.

Read/Write Select Network ........................... 33

13.

Input Timing Circuit and Signals .................... 35

14.

Output Timing Circuit ............................... 37

15.

Output Timing Signals ............................... 38

16.

Flow Chart Showing Format of Data on Tape ........... 44

vii

LIST OF TABLES
Table

Page

I.

Pulse Duration vs. Resistance and Capacitance ....... 25

II.

Bit Assignments for Control Signals ................. 31

III.

Bit Assignments for Status Signals .................. 42

IV.

Signal Abbreviation List ............................ 51

1

I.

INTRODUCTION

The University of Missouri-Rolla Electrical Engineering
Department is working on the development of a complete computer system for their facilities.

This system is based

around a Nova 800 general purpose computer with a 16K, 16
bit word memory and a cycle time of 800 nanoseconds.

The

system presently consists of the Nova 800 computer, digitalto-analog and analog-to-digital converters, a graphics display terminal, a high speed data line which provides access
to an IBM 360 computer through another Nova 800 located
within the school's computer center, and an ASR-33 teletype
containing a keyboard, printer, and paper-tape punch and
reader.
The programs which are used with the Nova in the
Electrical Engineering Department are punched out on paper
tape through the teletype punch.

The only local method of

entering these programs into the computer is through the
teletype reader.

The teletype reader and punch are slow

input/output devices which transfer data at the rate of 10,
eight-bit characters per second.

Some of the larger pro-

grams on tape take over 20 minutes to read in through the
teletype reader.

A faster input/output device which can be

used locally is clearly needed.
Available for use was a Kennedy incremental write/continuous read tape unit.

With this unit, programs could be

stored on magnetic tape and later read off the tape when
needed.

The advantages of storing programs on magnetic

2

tape instead of paper tape are substantial.

Programs stored

on magnetic tape take up less space and require less time to
be read into memory.

A program on paper tape requiring 20

minutes to be read into memory would take approximately 20
seconds if it were stored on magnetic tape.
This thesis is concerned with the general operation of
the Kennedy tape unit and the hardware design and software
implementation to make it compatible for use with the Data
General Nova 800 general purpose computer.

A similar thesis

was written which describes the interface logic needed to
connect the same tape unit to an SCC-650 computer [1].
There is an interesting difference between the two hardware
designs.

The software written for the SCC-650 interface is

discussed in [2].

The software written for each interface,

Nova and SCC-650, have only slight differences.

3

II.

A.

TAPE DECK OPERATION

Incremental Write Description
Of several schemes for digital magnetic recording, the

Kennedy 1400R tape deck uses the most widely adopted IBM
NRZI system (Figure 1).

Under this system, digital informa-

tion is recorded as transitions between saturation states of
the tape magnetic coating.

A transition bewteen saturation

states in either direction records a logic one, while no
transition records a logic zero.
The Kennedy tape deck has seven recording tracks.

A

character is represented by a combination of six bits which
are recorded simultaneously in six of the seven tracks.
For purposes of error detection, a parity bit is recorded in
the seventh track such that an odd number of logic ones are
~~.rr' t~·.J..,. ,. ,

recorded for each character.

If

:,#;:

~·bit~

of·

"'"' .- ;;:':.

of a character ,.i-s·

written wrong, the character will then have even parity and
the error will be detected.
Characters are spaced 0.005 inches apart or at a density of 200 per inch.

A character is recorded onto the tape

upon receiving a Write-Step command which steps the drive
motor one increment of 0.005 inches.

Depending on the rate

at which the Write-Step command is received, the write rate
of the tape unit is 0-300 characters per second.
At intervals, a gap must be inserted to allow the tape
transport to stop.

These gaps are designated as record gaps

because they separate data into records (Figure 2).

A

4

1

1

0

0

1

l

l

0

CODE
+SATURATION

-SATURATION

IN EITHER DIRECTION
RECORDS LOGIC ONE

~--TRANSITION

Figure 1.

NRZI Recording

5
record gap contains a longitudinal check character (LCC)
which is internally generated by the tape deck so that even
parity will exist in each track for that record.

This check

character is separated from the last character in the record
by 0.023 inches or approximately five blank characters.

The

total length of the record gap is three-fourths inch.
Files on tape are separated by file gaps (Figure 2).
File gaps contain a file mark (15 in binary) and its LCC

(15 in binary also) which are both internally generated by
the tape unit.

The file mark occurs approximately 2.7

inches from the last character in the last file.

The LCC

occurs five character spaces later or approximately 0.025
inches from the file mark.

The LCC is followed by three-

fourths inch of blank tape.

The total length of the file

gap is 3.5 inches.
A beginning-of-tape gap is 3.5 inches of blank tape
starting at the beginning-of-tape marker.

This gap is in-

ternally generated when the tape unit is in the Write mode
and the beginning-of-tape marker is sensed while the stepper
motor is driving the tape forward.

No file marks or LCC's

are written.
A write ring is located on the back of every reel of
tape.

If this ring is in place the magnetic tape may be

used for recording data.

If the ring is removed, the data

which was previously recorded on the tape is protected and
cannot be erased.

This feature allows data to be stored on

tape which cannot be erased accidentally.

6

data

x,xlxlxlxlx,x

XXXXXXX
I I I I

I I I I
I

five blank
character
spaces

I

.,;? XTXT X,...X
X'x
1 1 1
1

x1x'x 1x x x x
I I
I
I
I

I
I

2.7 inches
of blank
tape

I I
LCC

data

X XIXIXIXIX X

I I I I
I

3/4 inch

I

of blank
tape

I

I

data

1 1 1 1 0 0 0

I I I I
X XIXIXIXIXIX
XXXXXXX

five blank
character
spaces

I
I

End-of-Record Gaf

file mark

1 1 1 110 0 0

LCC

I

I
3/4 inch
of blank
tape

I

I

tape motion

I
I

I

x1x x x 1x1x x
~! x_01 x_~x 1 xlx

-

~

data

._.

End-of-File Gap

Figure 2.

End-of-Record and End-of-File Gaps

7
B.

Continuous Read Description
The Kennedy 1400R tape deck is a continuous read tape

unit.

As long as a Load Forward signal is applied, data

will appear as a continuous stream of pulses together with a
clock signal.

The reading rate is dependent upon the drive

rate of the stepper motor which is 1,000 characters per
second.

During the read operation the stepper motor moves

in a smooth motion and not in steps as in the write
operation.
In reading magnetic tape, presence of a character is
indicated by at least one bit in the logical one state being
read.

Because of tolerances, not all bits in a character

will be read simultaneously (Figure 3).

In order to assure

that all bits in a character have been sensed before data is
gated out, a skew delay is provided.

When the first bit of

the character is read, the delay allows approximately onehalf character spacing for the remaining bits to be sensed.
This is the maximum available time under worst case conditions.

At the end of the skew delay, the character read is

transmitted to the data lines.
Under the Incremental Write Description it was pointed
out that a parity bit was used with each six bit character
to provide odd parity over the seven tracks.

The tape deck

can provide even parity for each character but then there is
a problem.

When a character is zero (000000) the parity bit

for even parity is also zero.

Since there are no bits in

the logical one state, the presence of the character will

8

CORRECT CHARACTER LOCATIONS

~

Tc

~

~

\
\

)

~

\

)

\

\

t

l,

(

\

~

\

~

\

~

\

\

Ske w

\
\
\

\

\

1

\

t,

\

•

\

~

~

\

'

~

t__ Skew

delay - starts when first bit in
character is sensed. Maximum delay =

Figure 3.

Skew Delay

L
~Tc

9
not be determined.
C.

The zero character will be lost.

Pushbutton Controls
Four pushbutton controls are located on the front

panel for local control of the tape deck.

These controls

allow the user to load and remove tapes easily and to place
the unit in any condition required to transfer data.

The

functions of each of these pushbuttons can be duplicated by
computer control when the Read-Write-Remote selector switch
is in the Remote position.

The four pushbutton controls

and their functions are as follows.
l.

Load Forward
With power on, pressing the Load Forward button causes

tape to be advanced at the rate of 1,000 steps per second in
search of the beginning-of-tape marker.
switch is in the Write mode, a

If the selector

3.5 inch beginning-of-tape

gap is produced immediately upon the sensing of the beginning-of-tape marker.

If the selector switch is in the Read

mode, the tape will stop upon sensing the beginning-of-tape
marker.

At any time after the beginning-of-tape marker has

been sensed, pressing the Load Forward button causes tape
to be advanced at the rate of 1,000 steps per second as
long as the button is depressed.

If the tape deck is ready

and the selector switch is in the Write mode, tape is erased
as it advances.

10

2.

Ready
The Ready light indicates that the tape deck is ready

to write data.

After the beginning-of-tape marker has been

sensed the Ready condition is automatically achieved and the
Ready light will be on until a Rewind command is given.

If

desired, pressing Ready while the Load Forward action described is in process will place the tape unit in the Ready
condition without the presence of the beginning-of-tape
marker.

3.

File Gap
If the tape unit is Ready and in the Write mode a file

gap with file mark is written on tape when the button is
depressed.

4.

Rewind
Once depressed, Rewind cannot be stopped until the be-

ginning-of-tape marker is sensed.

Upon the sensing of the

beginning-of-tape marker, the driver motor will stop but
inertia will carry the marker several inches into the supply
reel.

To remove the tape depress Load Forward and Ready

together momentarily and then depress Rewind.
D.

Loading Procedure
Open the dust cover by pulling gently on the left side.
With the main power on and the toggle switch located

below the left hub off, place a reel of tape on the supply

11

hub (left).

The reel of tape should have a beginning-of-

tape marker located on the surface of the tape.

Make sure

the reel is on perfectly straight before the knob in the
center of the tape reel is tightened by turning it in a
clockwise direction.
Thread the tape around the tension ring, through the
photo-cell, over the head, between the pinch roller and the
capstan, and around the tension ring onto the take-up reel
(Figure 4).
Wind about two turns onto the take-up reel.
Turn the toggle switch below the left hub to the on
position.

Make sure the Read-Write-Remote selector switch

is in the Remote position.
Turn the Data General Nova computer on.

Flip the

Reset-Stop toggle switch on the front panel of the computer
to Reset.
Depress the Load Forward button on the tape unit and
release.

The tape should move forward until the beginning-

of-tape marker is directly under the photocell.
light should now be on.

The Ready

The tape deck is ready for opera-

tion.
For further information about the Kennedy 1400R
magnetic tape unit, see the unit's operation manual [3].
Information about other magnetic tape units that use the IBM
NRZI mode of recording are discussed in [4].

Machine para-

meters are given and the IBM NRZI system of recording is
described in detail.

Figure 4.

Tape Path

13
III. HARDWARE DESIGN
A.

General Description of Nova Computer

The Data General Corporation Nova computer comes in two
models, the table top and rack-mounted models.
mounted model is the one that will be discussed.
comes in two different size chassis.

The rackThe model

The five and one-

quarter inch unit has seven slots for the mounting of 15 x
15 inch printed circuit boards.

The ten and one-half inch

unit has provisions for mounting

17 printed circuit boards

of size 15 x 15 inches.

These printed circuit boards may be

memory modules, central processing units, or input/output
control boards.

All memory boards are connected to the CPU

through the memory bus.

All input/output control boards

(otherwise known as interfaces) are connected to the CPU
through the I/0 bus.

External lines from the interfaces to

their respective peripheral devices are connected through
the back panel of the computer.

The back panel of the com-

puter connects directly to the edge connectors of the
printed circuit boards.
The I/0 bus consists of sixteen bidirectional data
lines, six device selection lines and 19 control lines from
the CPU to the interfaces, and six control lines from the
interfaces to the CPU.

Signals on the control lines from

the processor synchronize the transfer on the data lines,
start and stop the device, and control the program interrupt.
Signals on the control lines from the interface to the

14

processor indicate the states of its control flip flops,
Busy, Done, and Interrupt Request.

The bus signals and

their description can be found in the Nova manual [5]

A3.

page

B.

General Purpose Interface
Before proceeding it may be helpful to refer to Appen-

dix A for the meaning of the abbreviations used in all the
sections that follow.

The 15 x 15 inch printed circuit

board for I/0 control mentioned in the previous section has
a standard set of logic and a basic configuration.

This

standard set of logic which is needed by every external device to be used with the Nova makes up what is known as the
General Purpose Interface.

Approximately half of the board

is consumed by this standard set of logic.

The remainder of

the board is configured to accept 65 (14 or 16 pin) integrated circuits, or 50 (14 or 16 pin) plus nine 24 pin
integrated circuits of the designers logic.
layed out such that

I.e.

The board is

sockets and wire wrap pins may be

used.
A series of some 200 wire wrap pins separates the two
halves of the board.

Some of these wire wrap pins connect

to the standard logic and CPU signals.

Others are connected

to the back panel to be used for external connection of the
device.
The Device Select logic, part of the General Purpose
Interface, is controlled by a series of jumpers which are

15

set such that a particular six-bit device code will be recognized (Figure 5).

The output of the Device Select logic

is connected to the control line buffer to gate the control
signals STRT, CLR, IOPLS, DATIA, DATOA, DATIB, DATOB, DATIC,
and DATOC in from the CPU when the device is selected.

The

other control signals RQENB, MSKO, INTA, and IORST are input
to the control buffer directly without dependence upon the
device selection.
The I/0 portion of the General Purpose Interface consists of the I/0 Data Buffer and the Input and Output Data
Registers (Figure

6).

Data which is computer output from an

accumulator is passed through the I/0 Data Buffer and
clocked into the Output Data Register.

As soon as the data

has been clocked in the Output Data Register it appears on
the external data lines to the device.

Data which is input

to the computer is first clocked into the Input Data
Register from the external lines.

A signal from the CPU

then gates the data through the I/0 Buffer to the proper
accumulator.
The interrupt logic of the General Purpose Interface
consists of an Interrupt Control circuit and an Interrupt
Chain and Acknowledge circuit (Figure 7).

The Interrupt

Control circuit consists of four D-type flip flops BUSY,
DONE, INT DIS, and INT REQ.

The BUSY and DONE flip flops

monitor the state of the device.

If a STRT pulse is given,

the BUSY flip flop is set which starts the device.

When

DSO
DSl
DS2

DS3
DS4
DS5

c{>
c{>
c{>
c{>
c{>
c{>

RQENB

D

IORST

I )

STRT

CLR

DA~OC --~...____,

Figure

5.

Device Select Logic and Control Line Buffer

CPU
Control
Signals

External

Data Lines

Input

Data

To Accumulator

Data

Lines

Register

External
Clock

Output

External

Data

Data
Lines

Data Lines
From Accumulator

Register
------~

~---------

Figure 6.

CPU Control Signal

I/0 Data Buffer and Registers

c

RQENB
INT
DIS(O)
DONE(l)

l

INT REQ

1

INT DIS

INTP IN

INT~(O)J;

INTP IN

)

INTP OUT

D

MSKO

c

DATA10

D

DEV COMP

c

BUSY(l)

D

INTP IN

DATA10

DAT.Il~l

DONE

l

DATA12

DATA13

IORST
DONEk1)

INT ACK
INT REQ(1)

i

'
i
!

l

\.,._,_..

'

BUSY

1

I
I1

--

__., , _ _ , .... ~~

DATA14

~
•.

~.,.,

.. . ,.,, •. ~-,t'. -"' •

._ ..•

DATA15

k"L-~

Figure 7.

Interrupt Control and Acknowledge

19

the device completes its operation, DONE is set and BUSY is
clear.
To request an interrupt, DONE must be set and the INT
DIS flip flop must be clear.

This flip flop is controlled

by a particular mask bit assigned for that device.

It is

set only when the proper mask bit in the accumulator is set
and a MSKO signal is generated.

With DONE set and INT DIS

clear, the INT REQ flip flop is set when a RQENB signal is
received.

The RQENB signal is generated every machine

cycle.
An interrupt chain is then used to determine if a device of higher priority has interrupted.

The chain is inter-

connected to all the other interfaces in the order of the
interrupt priority of the devices.

As an INTP signal is

passed through the chain, if an INT REQ flip flop of a device is set the chain will be broken, the INTP signal will
not pass to the next device, and that device can now interrupt.

Upon the receival of an INTA signal, the device code

is put onto data lines 10-15.

These data lines can be de-

coded to determine what device has interrupted.
The General Purpose Interface logic was only covered in
a general sense in this thesis.

For more detailed drawings

and descriptions, see the Nova manual [5].
C.

Special Circuits
As was mentioned above, the logic of the General Pur-

pose Interface was already provided by Data General

20

Corporation for use with their Nova computer.

The General

Purpose Interface only controlled signals between the CPU
and the interface.

Networks must be designed and built to

control signals between the interface and a specific external
device.

What follows is a discussion of special circuits that

are only parts of certain networks in the total interface
design.

These circuits warrant special attention because of

their importance.

The networks which comprise the total

interface design will be discussed in the next section and
can also be found in [6].

Further information about switch-

ing circuits like the ones in this section can be found in [7].
1.

Clamping Circuit
The Kennedy tape unit is powered by a 10 volt supply.

As a consequence, most of the signals output from the tape
deck are 10 volts when at a logical one state.

These same

signals are outputs from circuits with a lK or lower impedance.

This means at least 10 milliamps of current is drawn

from a tape deck signal when it is at a logical one state.
The General Purpose Interface Board is made up of integrated circuits which are powered by a five volt supply.
the input of an I.C. the maximum voltage allowed is

At

5.5

volts and the maximum current allowed is one milliamp.
Because of these limitations, the tape deck signals are not
input directly to the Input Data Register but are passed

8).

The tape deck

signals are input to the cathode of diode 1.

The anodes of

through a Clamping Circuit first (Figure

r------------+5

,.----------..,

R

Diode 1

"------Diode 2

L_. _ _ _ _ _ ,_ _ _ _ _ _
Input Data Register

+5
L-----~---J
Clamping Circuit

Figure 8.

Clamping Circuit

22

diodes 1 and 2 are connected to an input of the Input Data
Register.

The cathode of diode 2 is connected to a five

volt supply.
Diode 1 is in the Clamping Circuit to block the large
current flow from the tape deck.

When the tape deck signal

is high, diode 1 is reversed bias and the voltage on the
input of the Data Register is dependent upon the internal
circuitry of the Data Register I.e. itself.

Since TTL logic

is used, the input is applied at the emitter of an NPN transistor.

The voltage at the emitter will be the supply volt-

age of the I.C. minus the voltage drop across the base resistor and base-emitter junction.
approximately

3.3 volts.

This voltage will be

When the tape deck signal is low,

diode 1 is forward biased and the voltage at the input of
the Data Register will be approximately the same voltage as
the signal.
Diode 2 is in the Clamping Circuit to guarantee that
the voltage at the input of the Data Register will not
exceed five volts.

If diode l breaks down, the large

amount of current from the tape deck signal will be absorbed
by the five volt power supply.

The input will then be with-

in the voltage and current limitations allowed by the I.e.,
and the I.C. will not be damaged.
2.

Monostable Multivibrator
Some of the signals from the computer to the tape deck

are voltage levels which only need to hold their value for

23

a minimum period of time.

Other signals output from the

computer are required to be pulses of certain duration in
order for the tape deck circuitry to receive them properly.
All of the computer pulse output signals originate from
pulse signals from the CPU.

The pulse signals from the CPU

all have a constant duration.

In order to make the CPU

pulses the proper duration for input to the tape deck, they
must pass through a monostable multivibrator (basically a
flip flop with only one stable state).

A configuration

using one 7400 Quad two-input NAND gate I.e., a resistor, a
capacitor, and a diode was developed to perform as a monostable multivibrator (Figure 9).
The input is at gate l, and the output is at gate 3.
The diode is placed in the circuit so that the output of the
monostable will not trigger until the input pulse drops its
voltage from high to low.

The output pulse will drop its

voltage from high to low upon triggering and stay low until
the capacitor charges up.

At this time the output pulse

will return to a high voltage level.

The duration of the

output pulse is dependent upon the values of the resistor
and capacitor.
In Table I, the output pulse duration is given for
different values of resistors and capacitors.

These values

were measured using the same I.e. and may be slightly different when using another I.e. due to the internal resistance and capacitance of each I.e.

Therefore, use the values

in the table only as approximations.

If the pulse duration

24

+5

Gate 2

Gate l

Gate 3

Input-~

Output

I

Input
I

I
I

I
I

I I
I
I

Pulse Duration

Figure 9.

~

I

Output

I

I
I+-

I

Monostable Multivibrator and Signals

25

Capacitance in Microfarads

Resistance

.rn

.05

.1

.5

1

5

1.0

.6

3.5

7

38

so

420

5.3

3.0

15.2

30

180

330

2100

18.0

3.7

18.8

38

210

400

2400

24.3

3.9

20.0

40

230

4 30

2600

47.0

4.3

22.0

43

250

460

2800

in Kilohoms

Pulse Duration in Microseconds

Table I.

Pulse Duration vs. Resistance and Capacitance

26

needed is a critical value, it is best to measure the output
pulse while trying various combinations of resistors and
capacitors.

3.

Delay Circuit
As was mentioned in the section Continuous Read Descrip-

tion, when the tape unit is reading, the data appears on the
external line as a continuous stream of pulses coincident
with a clock pulse.

To clock the data into the Input Data

Register of the General Purpose Interface, the data has to be
on the input lines of the Data Register for at least 30
nanoseconds before the clock pulse comes up.

This means

that the clock pulse has to be delayed at least 30 nanoseconds.

The clock pulse cannot be delayed too long because

it must come up before the data on the input of the Data
Register falls.

The data remains on the data line for 20

microseconds.
The Delay Circuit (Figure 10) consists of a two-input
NAND gate and resistor and capacitor.

When the input

pulse voltage goes high, the output pulse voltage will go
low after the capacitor has charged up.

Once the input

pulse voltage goes low, the output pulse voltage will go
high immediately.

Therefore the leading edge of the input

pulse is delayed on the output, but the trailing edge remains the same.

27

Input --'ti~~------D

Output

~I c
~

____.II...___

Input

I
I

I
I
I

I
I

- , 1.--I

Pulse Duration

Figure 10.

1
I

I
I
,.._.._

I

I

~

Output

Delay Circuit and Signals

28
4.

Open Collector Inverters
As was discussed in the subsection Clamping Circuit,

there is a difference in voltage operation levels between
the tape deck and the Nova computer.

The Clamping Circuit

succeeded in converting the tape deck signals to the operation level of the Nova computer.

Some type of circuit is

needed to convert the computer signals to the operation
level of the tape deck.

Among the 7400 series I.C.'s, there

is a circuit which can be used to raise the voltage level of
signals.

This I.e. is the 7416 Open Collector Hex Inverter.

When using the Open Collector Inverter, the user must furnish a pull-up resistor and supply voltage that will be
connected to the output of the gate.
The input signals to the tape deck are required to have
voltages from five to 15 volts.

The Nova computer has volt-

age supplies of five and 15 volts.

Since the use of the

five volt supply at the output of the Open Collector Inverters would generate some signals with voltages below the
necessary range, it was decided to use the 15 volt supply.
Pull-up resistors had to be chosen such that the rise
and fall times of the pulses were less than two microseconds.
Also the pull-up resistors had to be large enough so that
the current from the supply-resistor combination was not
greater than the breakdown current of 40 milliamps.

Those

signals that were normally at a low voltage required small
pull-up resistors to decrease the rise time of the pulse.

29
Those signals that were normally at a high voltage required
large pull-up resistors to decrease the fall time of the
pulse.
D.

I/0 Control Networks
What follows are the three basic networks needed to

interface the Nova Computer with the Kennedy l400R magnetic
tape unit.

All of the interface networks are built from

7400 series TTL Integrated Circuit Logic.

The only logic

gates used in the design are NAND gates and Inverters.
1.

Decode Network
There are certain signals which must be generated by

the computer to provide control over the tape deck while it
is in the Remote mode.

Certain bits of the accumulator are

assigned as the control word.

Bit 13 of the accumulator is

used to place the tape unit in either the Read or Write mode.
A zero in bit 13 is used for Read, and a one in bit 13 is
used for Write.

The other control signals are decoded from

bits 10 through 12 of the accumulator (Figure 11).

The bit

assignments for each control signal are shown in Table II.
As can be seen, no two control signals decoded from
accumulator bits 10 through 12 can be output simultaneously.
Since bit

13 is used for determining the Read-Write mode,

any control signal which is output must also select either
the Read or Write mode.

30

DATOA
DATAlO

IORST

c
DATAll
DATA13

D

MTPR
MTPW

DATA12

RRWD

EOR

-----~ C l

RLDF

>--.......,.1--~D

RVSTP

EOF

RRDY

Figure 11.

Decode Network

31
Accumulator Bits

Control Signal

10

ll

12

0

0

1

Remote Rewind

0

1

0

End of Record

0

1

1

Remote Load Forward

1

0

0

Reverse Step

1

l

0

End of File

1

1

l

Remote Ready

Table II.

Bit Assignments for Control Signals

In order to distinguish when bits 10 through 13 of the
accumulator are used for control instead of data, a DATOA
pulse from the CPU is used to gate the control words out to
the tape deck.

At any other time bits 10 through 13 of the

accumulator are considered as data.
Four of the above mentioned control signals are required
to be voltage levels.

Those signals are Read, Write, Remote

Load Forward, and Reverse Step.
signals are pulses.

The rest of the control

Making the four control signals into

levels is accomplished by setting a flip flop when the
proper accumulator bits are one and the DATOA pulse is
generated.

The DATOA pulse serves as a clock input to a D-

type flip flop.

To drop the level control signals Reverse

Step and Remote Load Forward, either another control signal
must be output or the IO RESET pulse must be generated.
Either the Read or Write control signal will always be output, but the IO RESET pulse sets the Read mode.

32
2.

Read/Write Select Network
All of the control signals generated from the Decode

Network are output directly to the tape deck except the Read
and Write signals.

With the Read-Write-Remote selector

switch on the front panel of the tape deck, manual selection
of the Read or Write mode may be made.

When the selector

switch is in the Remote mode, then the computer should have
full control over the selection of the Read or Write mode.
Remote selection of the Read or Write mode is accomplished by connecting either the Remote Read Select line
(RRSL) or the Remote Write Select line (RWSL) to the Selector Common line (SLCM).

The Selector Common line has a 10

volt level signal when the Read-Write-Remote selector switch
is in the Remote position.

If the selector switch is in any

other position the 10 volt level on the Selector Common line
drops and the selector switch controls the mode of operation.
To make the connections of the Remote Read Select line
or Remote Write Select line with the Selector Common line,
a relay was used.

To be compatible with the General Purpose

Interface board, the relay had to be in a dual in-line package that could be placed into an

I.e.

socket and could be

driven by five volts (Figure 12).

fo control the switching of the relay, the Mag Tape
Read (MTPR) signal from the Decode Circuit was used.

The

contact for the Remote Write Select line is normally closed,
and the contact for the Remote Read Select line is normally
open.

When the Mag Tape Read control signal is output from

33

MTPR _ _ __.

+5

RWSL - - - - - - - -

1

14

2

6

8

SLCM
RRSL

Figure 12.

Read/Write Select Network

34
the Decode Circuit it causes current to flow through the
coil which closes the Remote Read Select contact and opens
the Remote Write Select contact.

The diode is placed in the

circuit so that when the output of the Inverter gate goes
low the surge current will pass through the diode instead of
the Inverter.

3.

This keeps the Inverter from being damaged.

Input/Output Timing Networks
During a Read operation the data appears on the exter-

nal lines as a stream of pulses coincident with a clock
pulse.

To clock the data into the Input Data Register, the

leading edge of the clock pulse must be delayed at least 30
nanoseconds.

Therefore the clock pulse is input to the

Delay Circuit (Figure 13).

The output of the Delay Circuit

could be used to clock the data into the Data Register.
Instead the signal is passed through a monostable multivibrator to decrease the duration of the pulse.

The output

signal of the monostable is used to clock the data into the
Data Register.

Also this signal is used as a device com-

pletion signal to set the DONE flip flop of the General
Purpose Interface.
During a Write operation the data is written on tape
upon the receival of a Write-Step pulse.

Both the data and

the Write-Step pulse are controlled by the DATOB CPU pulse.
The DATOB pulse clocks the data in the accumulator into the
Output Data Register.

Once the data has entered the regis-

ter it appears on the data lines as voltage levels.

Also

35

DELAY
EX CL

-

----

-

MONO STABLE

CDLY

CIRCUIT

...-

~

Delay-1 us.

Pulse Duration-1 us

EXCL

CDLY

u
Figure 13.

-

ECP L

Input Timing Circuit and Signals

36

the DATOB pulse is passed through a monostable to increase
the pulse duration needed for the Write-Step pulse (WSTP).
The Write-Step pulse is sent directly to the tape deck and
the data is written on tape.
Approximately 60 microseconds after the leading edge of
the Write-Step pulse, the tape deck generates a parity check
s~gnal.

This signal originates from a Parity Check network

within the tape deck.

Upon writing the data, the normal

parity bit is generated and written in track seven.

The

Parity Check circuit generates its own parity bit from the
data and compares it with the parity bit written in track
seven.

If the two parity bits agree, no error occurred and

no signal is generated.

If the two parity bits disagree, a

writing error has occurred and signal is sent to the computer.

The signal is a pulse of 15 microseconds duration.

To hold the signal, it is clocked into a flip flop.

The out-

put of the flip flop is used as a status signal.
In order to secure the proper timing, the Write-Step
pulse (WSTP) is passed through a monostable to produce a
delay pulse (DLYl) of such duration that the combined time
between the leading edge of the Write-Step pulse and the
trailing edge of the delay pulse is between 60 and 75 microseconds (Figures 14 and 15).

The delay pulse (DLYl) is

passed through a monostable to produce a short duration
pulse (EPCP) to clock the Parity Check pulse into the flip
flop.

37

D ATOB

-

MONOSTABLE
WITH
INVERTED
OUTPUT

[>

WSTP

--

Pulse Duration-40us

MONOSTABLE
WITH
INVERTED
OUTPUT

I>

DLYl

....

Pulse Duration-20us
EPCP

DLYl

DLY2
.....

-

MONO STABLE
WITH
INVERTED
OUTPUT

MONO STABLE
WITH
INVERTED
OUTPUT

Pulse Duration-2us

Pulse Duration-2ms

MONOSTABLE
WITH
INVERTED
OUTPUT

[>

Pulse Duration-2ms

Figure 14.

DLY3

-...

DLY2

STDN
MONOSTABLE

Pulse Duration-lus

Output Timing Circuit

---

38

u

DATOB

WSTP

DLYl
I

I
I

--~----r-l~__

E_P_cP_

DLY2

DLY3

Figure 15.

Output Timing Signals

39

Another timing consideration is the duration between
successive Write-Step pulses.

The speed of the tape deck

while in the Write mode is 300 characters per second maximum.
This means that a delay of 3.3 milliseconds must occur
between successive Write-Step pulses.

To accomplish this

the first delay pulse (DLYl) is inverted and passed through
a monostable.

By using the inverted delay signal (DLYl) on

the input of the monostable, the output delay pulse (DLY2)
will trigger correspondingly to the trailing edge of the
Write-Step pulse.
The output delay pulse (DLY2) is passed through a monostable to produce another delay pulse (DLY3).

The two mono-

stables are set such that the combined delay of the two
pulses (DLY2 and DLY3) is four milliseconds.

Two monostables

were needed instead of one because a four millisecond pulse
could not be obtained from any resistor-capacitor combination with the DLYl signal on the input.

The DLYl signal

did not allow enough time for the capacitor in the monostable to recover.
The DLY3 signal is then passed through a monostable to
produce a short duration pulse (STDN) used as the device
completion signal to set the DONE flip flop of the General
Purpose Interface.

Once DONE is set another Write-Step

pulse may be output.
Only the major portions of the hardware interface have
been presented here.

To get a more complete and detailed

40

description of the entire interface design and the external
connections needed, see the maintenance manual on the interface design [6].

~1

IV.

A.

SOFTWARE

Basic I/0 Instructions
After completion of the hardware design, it was neces-

sary to develop the system software so that the hardware
could be used.

All of the signals used in the hardware de-

sign are controlled by signals which originate in the CPU of
the computer.

These signals are generated by the CPU upon

command of the programmer.

These commands are in the form

of instructions which the computer recognizes.
The instructions in question are the input-output type.
All words in the computer consist of 16 bits numbered zero
to

15 from left to right.

For the I/0 instructions the last

six bits (bits 10-15) are used for the device code.

For the

magnetic tape unit the device code is 22 in base eight.
Since the computer has four accumulators, bits three and
four of the I/0 instruction are used to specify the accumulator that will be used for the operation.

Bits five, six,

and seven are used to designate the specific I/0 instruction.
These instructions are NIO, DIA, DOA, DIB, DOB, DIC, DOC,
and SKP.

Bits eight and nine when used with all the in-

structions except SKP specify the START, CLEAR, and IO

PULSE signals.

When used with the SKP instruction bits

eight and nine test the state of the BUSY or DONE flip flops.
Uses of the I/0 instructions are demonstrated in the next
few paragraphs and in Appendix B.

42

As was mentioned in the subsection Decode Network,
accumulator bits 10 through 13 are assigned as a control
word.

The bit assignments for each control signal can Je

found in that subsection.

To generate the proper control

signal, the programmer must load the proper bits of the
accumulator and then execute a DOA instruction.
There is also a status word which is assigned accumulator bits zero through seven.
signal from the tape deck.

Each bit is assigned a status

The bit assignments for each

status signal are shown below in Table III.
Accumulator Bits

In order to

Status Signal

0

Gap Detect

1

Echo Parity

2

Ready

3

Remote Status

4

Gap in Process

5

File Protect

6

End of Tape

7

Load Point

Table III.

Bit Assignments

r•

_;_ Ul'

Status Signals

bring the status signals into the Data Register, an 10 PULSE
signal is needed.

After the status is in the Data Register

a DIA instruction is needed to bring the status into the
accumulator.
To output data to the tape deck a DOB instruction must
be used.

To sense when the data has been written on tape,

the DONE flip flop should be checked.

The next DOE instruc-

tion should not be executed until DONE is nonzero.
To bring data into the computer, the DONE flip flop
must be checked to be nonzero.

This state occurs when the

data has been brought into the Data Register.

After DONE is

found to be nonzero, a DIB instruction should be executed to
bring the data into the accumulator.
The instruction sequences needed for executing any input or output (whether data, control or status) between the
magnetic tape unit and the Nova computer are included in
the examples in Appendix B.
B.

Program Techniques
In this section the basic operation of the read and

write routines is discussed.

Along with the discussion,

some subroutines contained in Appendix B are referenced.
For a complete listing of the Mag Tape Write and Mag Tape
Read routines see the interface users manual [6].
The main objective for building and designing the hardware interface was so that the magnetic tape unit could be
used to write a library of programs on tape and to read
programs from the library when needed.

Software was devel-

oped that would write programs on magnetic tape in a certain
format and use that format for reading programs from the
tape.

The format in which a program is written on tape is

shown in flow table form in Figure

16.

START

Starting Address of Record

t

Number of Words in Record

t

Data

yes

no

'+

Checksum
Record Gap

t
77

t

File Gap

+
Record
I

66

BOT Gap

I

Gap

1

yes

77

t

66

+

Name of Program

Starting Address of Program

t

177777

~

END

Figure 16.

Flow Chart Showing Format of Data on Tape

45
The basic idea behind the write routine is to dump the
contents of memory between two locations onto the magnetic
tape.

Since the tape unit can only write six bits at a

time, a word in memory is written as three characters on
tape.

A subroutine to write a word on tape is shown in

Appendix B, example one.

Included in the example is the sub-

routine to bring in status.
It should be noticed in the subroutine that each time a
character is written, the status of the tape unit is checked.
This is to see if an error occurred in writing the character.
If an error is detected, the program halts.

Notice also in

the subroutine that a checksum is computed as each character
is written.
record.

This checksum is written at the end of the

The purpose of the checksum is for detecting read-

ing errors.
The process of converting three characters into a word
while reading is a little more difficult than writing the
word into three characters.

Example two in Appendix B is a

subroutine to format three characters into a word.

Included

in the example is a subroutine to read a character and a
subroutine to compute the checksum.
The complete data cannot be written continuously
because, at intervals, a gap must be inserted to allow the
tape transport to stop.

The write routine is set up to

write 200 words in a record.
record gap.

Each record is separated by a

Example three in Appendix B is a subroutine

used to write gaps.

A delay is provided before and after

46

the gap is written to allow the capstan to stop completely.
Status is checked during the writing of the gap to detect
when the gap stops.
The characters 77 and 66 are written after each gap as
control characters.

When these characters are read from the

tape, the read routine knows that the characters that follow
are useful information.

With the use or these control

characters, the LCC written during the record gap does not
affect the read operation.

Two control characters are used

because there is a possibility that the LCC written in the
record gap might be the same as a control character.

If

this occurred while one control character was being used,
all useful information would be phased together by one sixbit character.

Example four in Appendix B is a subroutine

to detect the control characters.

Example five in Appendix

B is a subroutine to write a control character.
The first useful information that is written on tape is
the name of the program.
in a word or 16 bits.

The name of a program is specified

The first part of the word (bits zero

to seven) is the assigned tape number).

The second part of

the word (bits eight to 15) is the number assigned to that
program.

For example, the first program on tape 5000 would

probably have the name 5001.

The second program on the

same tape would probably have the name 5002.

During a read

operation, the name of the desired program is specified by
the user.

Only that program will be stored into memory.

47

The two words written before each record, the memory
address of the first data word in the record and the number
of data words contained in the record, are used by the read
routine to store the data which is read into the proper
memory location.

Also, knowing the number of words in the

record allows the read routine to recognize when the checksum has been read.

It then compares the checksum that was

read to the one that was computed by the routine as each
character was read.

If the two checksums compare, no read-

ing error occurred.

If the two checksums are not equal the

program is halted.
After all the data has been written, a record gap and
the two control characters

77 and 66 are written.

The

starting address of the program is then written followed by
an end-of-file control character

177777.

During the read

routine when the end-of-file control character is read, the
tape rewinds and then loads forward back to the load point
or beginning-of-tape marker.

Example six in Appendix B is

a subroutine to rewind the tape and load forward to the
load point.

In the subroutine, a delay is used to guarantee

that the tape will completely rewind before the load forward
signal is transmitted to the tape unit.
During the read routine, the starting address of the
program that was read is stored in a specific location.
When the read routine halts, pressing the Continue toggle
switch on the computer console causes execution of the program which was just read off tape.

48

V.

CONCLUSION

The hardware interface that was built has very few
limitations that would hinder the complete utilization of
all the functions available on the magnetic tape unit.

The

software interface that was written is the limiting factor.
A much more complex software package could be written.

For

example, the hardware interface provides the circuitry to
drive the tape in reverse while writing.
to correct a writing error.

This could be used

Software could be written that

would read data from the magnetic tape unit and punch it out
on paper tape.

Almost anything practical can be done with

the magnetic tape unit if the software is provided.

49

BIBLIOGRAPHY
[1]

Keeve, Frederic H. The Design of a Tape Deck Controller.
A Thesis.
Rolla, Missouri. 1968.

[2]

Rhine, George I. Operations Manual for the Magnetic
Tape Recorder. Technical Bulletin CRL 69.2. Rolla,
Missouri. 1969.

[3]

Kennedy Company. Operation and Maintenance Manual,
Model 1400R Incremental Magnetic Recorder.
Altadena,
California, 1967.

[4]

Loeschner, F. W.
"Techniques of Digital Recording,"
Instrument Control Systems, 42,1 (Jan. 1969), 73-4.

[5]

Data General Corporation. How to Use the Nova Computers, 4th Edition.
Southboro, Massachusetts. 1970.

[6]

Steury, Thomas D.
User and Maintenance Manual for the
Nova-Mag Tape Interface. Technical Manual CRL 72.2
Rolla, Missouri. 1972.

[7 J

Millman, J. and Taub, H.
Pulse, Digital~ and Switching
Waveforms. New York: McGraw-Hill, 19 5.

50

VITA
Thomas Dean Steury was born on November 23, 1948 in
Kansas City, Missouri and received his primary education
from there.
Missouri.

He received his secondary education in Raytown,
He received his college education from Metropol-

itan Junior College in Kansas City, Missouri and the University of Missouri-Rolla in Rolla, Missouri, where he
received his Bachelor of Science degree in Electrical
Engineering in August 1970.
He has been enrolled in the Graduate School of the
University of Missouri-Rolla since September 1970 but missed
the spring semester 1971 because of active duty in the Armed
Forces.

He has been a Graduate Assistant in the Electrical

Engineering Department during his enrollment as a graduate
student.

51

APPENDIX A
Signal

Description

CDLY

Clock Delay

CLR

Clear

DATAO to DATA15

Data

DIA or DATI A

Data In A Buffer

DOA or DATOA

Data Out A Buffer

DIB or DATIB

Data In B Buffer

DOB or DATOB

Data Out B Buffer

DIC or DATIC

Data In C Buffer

DOC or DATOC

Data Out C Buffer

DLYl

Delay One

DLY2

Delay Two

DLY3

Delay Three

DSO to DS5

Device Selection

ECPL

External Clock Pulse

EOF

End of File

EOR

End of Record

EPCP

Echo Parity Check Pulse

EXCL

External Clock

IC

Integrated Circuit

INTA

Interrupt Acknowledge

INTP

Interrupt Priority

INTR

Interrupt Request
Table IV.

Signal Abbreviation List

52

Signal

Description

IOPLS

IO Pulse

IORST

IO Reset

MSKO

Mask Out

MTPR

Mag Tape Read

MTPW

Mag Tape Write

NIO

No IO

RLDF

Remote Load Forward

RQENB

Request Enable

RRDY

Remote Ready

RRSL

Remote Read Select

RRWD

Remote Rewind

RVSTP

Reverse Step

RWSL

Remote Write Select

SELB

Selected Busy

SELD

Selected Done

SKP

Skip

SLCM

Selector Common

STDN

Set Done

STRT

Start

TTL

Transistor Transistor Logic
Table IV.

Signal Abbreviation List (continued)

53

APPENDIX B
Software Examples
Example 1.

Assume that a 16-bit word has been loaded into

accumulator zero.
;WRITES THREE CHARACTERS OR A WORD ON TAPE IN THE ORDER
;BITS 10-15 FIRST, BITS 4-9 SECOND, BITS 0-3 THIRD
WRTWD:

STA

3, RTRN

DOBS

0,22

SKPDN

22

JMP

.-1

JSR

DELAY

JSR

STAT

LDA

2,STAT2 ;041000

AND

2,l,SZR

HALT

;PARITY ERROR OR END OF TAPE

MOV

0,3

LDA

2 ,EORf1

;77

AND

2,3

;KEEP SIX DATA BITS

LDA

l,CHECK

ADD

3,1

AND

2,1

STA

l,CHECK

MOVZR

o,o

DSZ

CWl

JMP

.-2

;COMPUTE CHECKSUM

;SIX SHIFTS FOR A NEW CHARACTER

54

DELAY:

LDA

2,ICW1

;RESET COUNT 1

STA

2,CW1

DSZ

CW2

JMP

WRTWD+1

LDA

2,ICW2

STA

2,CW2

JMP@

RTRN

DSZ

DLY

JMP

.-1

LDA

2,IDLY

;20

STA

2,DLY

;RESET DLY

JMP

0,3

;THREE CHARACTERS PER WORD

;RESET COUNT 2

;STAT

BRINGS IN STATUS OF TAPE DECK

STAT:

NIOP

22

DIA

1,22

JMP

0,3

RTRN:

0

STAT2:

041000

EOR:vl:

77

CHECK:

0

CWl:

6

ICWl:

6

CW2:

3

ICW2:

3

DLY:

20

IDLY:

20

55
Example 2 .
;RDFMT
RDFMT:

- FORMATS THREE CHARACTERS INTO A WORD
STA

3,RTRN1

JSR

RDCH

JSR

CCHS

MOV

0,1

JSR

RDCH

JSR

CCHS

ADDZL

;TO FORM

ADDZL

o,o
o,o
o,o

ADD

0,1

;12 BITS FORMED

JSR

RDCH

JSR

CCHS

MOVS

ADDZL

o,o
o,o
o,o

;TO FORM AC BITS 0-3

ADD

0,1

;FORM 16 BIT WORD

JMP@

RTRNl

ADDZL

ADDZL

;AC BITS 10-15

;SHIFT SIX PLACES LEFT

;AC BITS 4-9

;SWAP HALVES OF AC
;SHIFT FOUR PLACES LEFT

;RDCH

READS A CHARACTER FROM A TAPE

RDCH:

NIOS

22

SKPDN

22

JMP

.-1

DIB

0,22

;STROBE IN DATA

LDA

2,DBR

;77

AND

2,0

;KEEP AC BITS 10-15

JMP

0,3

;WAIT FOR DATA

56

;CCHS

COMPUTES THE CHECKSUM

CCHS:

STA

3,RTRN2

LDA

3,CHECK

ADD

0,3

AND

2,3

STA

3,CHECK

JMP@

RTRN2

RTRNl:

0

DBR:

77

RTRN2:

0

CHECK:

0

Example 3.

Assume accumulator one has been loaded with

either 24 for record gap or 64 for file gap.
;GAP

WRITES A GAP ON TAPE

GAP:

STA

3 ,RTRN

JSR

DELAY

DOA

1,22

JSR

STAT

LDA

O,RBOUT ;177400

AND

0,1

LDA

2,STAT3 ;130000

SUB#

2,l,SZR ;WAIT FOR GAP TO STOP

JMP

.-5

JSR

DELAY

JMP@

RTRN

;DELAY -

;KEEP ONLY STATUS BITS

CAUSES A DELAY SO CAPSTAN WILL STOP

57

DELAY:

STAT:

LDA

2,ICW2

STA

2,CW4

DSZ

CW4

JMP

.-1

DSZ

CW5

JMP

.-5

LDA

2,ICW5

;1000

STA

2,CW5

;RESET COUNT 5

JMP

0,3

NIOP

22

DIA

1,22

JMP

0,3

RTRN:

0

RBOUT:

177400

STAT3:

130000

ICW4:

400

cw4:

400

ICW5:

1000

CW5:

1000

·400
'
;RESET COUNT 4

Example 4.
;BORMK
BORMK:

-

IDENTIFIES THE MARKS AT BEGINNING OF RECORD
STA

3 ,RTRNl

JSR

RDCH

SUB#

0,2,SNR ;CHARACTER IS 77?

JMP

.+11

MOV

O,O,SZR ;CHARACTER IS 00?

;YES

58

JMP

.+3

;NO

ISZ

LPF

;YES

JMP

.+5

DSZ

BID

JMP

BORMK+l

.4

'

IORST
HALT

;NO MARK FOUND

JSR

RDCH

LDA

2,SBR

SUB#

0,2,SNR ;IS CHARACTER 66?

JMP@

RTRNl

;YES

DSZ

BID

;NO

JMP

.-5

·66

'

IORST
HALT
RDCH:

;NO MARK FOUND

NIOS

22

SKPDN

22

JMP

.-1

DIB

0,22

;STROBE IN DATA

LDA

2,DBR

;77

AND

2,0

;KEEP AC BITS 10-15

JMP

0,3

RTRNl:

0

LPF:

0

BID:

4

SBR:

66

DBR:

77

;WAIT FOR DATA

59

Example 5.

Assume accumulator one has been loaded with

either 77 or 66.
;SPCH

WRITES A SPECIAL CHARACTER ON TAPE

SPCH:

DOBS

1,22

SKPDN

22

JMP

.-1

STA

3 ,RTRN

JSR

DELAY

JSR

STAT

LDA

2,STAT2 ;041000

AND

2,l,SZR
;PARITY ERROR OR END OF TAPE

HALT

DELAY:

STAT:

JMP@

RTRN

DSZ

DLY

JMP

.-1

LDA

2,IDLY

;20

STA

2,DLY

;RESET DLY

JMP

0,3

NIOP

22

DIA

1,22

JMP

0,3

RTRN:

0

STAT2:

041000

DLY:

20

IDLY:

20

60

Example 6.
;RWND

REWINDS TAPE LOADS FORWARD TO LOAD POINT

RWND:

LDA

l,RWD

DOA

1,22

LDA

2,ICW1

STA

2,CWl

DSZ

CWl

JMP

.-1

DSZ

CW2

JMP

.-5

LDA

2,ICW2

STA

2,CW2

LDA

l,LDF

DOA

1,22

LFLP:

IORST
JMP

0,3

RWD:

10

ICW1:

7000

CWl:

7000

ICW2:

1000

CW2:

1000

LDF:

30

;10 FOR REWIND

;BESET COUNT 1

;7000

;1000

;RESET COUNT 2

;30 FOR LOAD PORWARD

