A PDP-8/E digital interface for the Heath Hl0 paper tape reader/punch by Mehrdad, Mehrdad R.
Retrospective Theses and Dissertations Iowa State University Capstones, Theses andDissertations
1-1-1980
A PDP-8/E digital interface for the Heath Hl0
paper tape reader/punch
Mehrdad R. Mehrdad
Iowa State University
Follow this and additional works at: https://lib.dr.iastate.edu/rtd
Part of the Engineering Commons
This Thesis is brought to you for free and open access by the Iowa State University Capstones, Theses and Dissertations at Iowa State University Digital
Repository. It has been accepted for inclusion in Retrospective Theses and Dissertations by an authorized administrator of Iowa State University Digital
Repository. For more information, please contact digirep@iastate.edu.
Recommended Citation
Mehrdad, Mehrdad R., "A PDP-8/E digital interface for the Heath Hl0 paper tape reader/punch" (1980). Retrospective Theses and
Dissertations. 18738.
https://lib.dr.iastate.edu/rtd/18738
A PDP-8/E digital interface for the 
Heath HlO paper tape reader/punch 
$Sil 
/9/".1 
1n~73r by 
(}. ::;> 
Mehrdad R. Mehrdad 
A Thesis Submitted to the 
Graduate Faculty in Partial Fulfillment of the 
Requirements for the Degree of 
MASTER OF SCIENCE 
Major: Biomedical Engineering 
Signatures have been redacted for privacy 
Iowa State University 
Ames, Iowa 
1980 
'ii 
TABLE' OF CONTENTS 
TABLE \:!F SYMBOLS 
INTRODUCTION 
HEATH CONTROL INTERFACE FUNCTIONAL DESCRIPTION 
· DETAILED LOGIC .. . . 
· ADDRESS .DECODER Logic 
OPERATIONS DECODER Logic 
TAPE .READ. _and SKJ.P Logic 
TAPE PUNCH and SKIP Logic 
. READER 1!tJ¥FER .Logic 
PUNCH'BUF~R Logic 
PHYSICAL.DESCRIPTION ' ·- '' -, •. 
_ 
0
Pri.nted° Ci;:cuit ~PC) Board 
Sign~1- Cabie 
He.a th .'Reader/Punch· 
" ' -
, .. cINSTALLA'j.'J.ON 
BASIC -·CmlPlJ'.rER Ol:'ERATION 
Loadi~g of• Binary Programs 
Pt!n,cJ_i;Lng '!f, B:!-nary· Programs 
bat~_ Transfer Between Magnetic and Paper Tapes 
·Reading 
l:'unching 
CONCLUSION 
.BIBDIOGRAPHY . ..• 
,• '•. 
.. ,: 
Page 
vi. 
1 
6 
10 
10 
16 
16 
19 
24 
24 
w 
27 
32 
·32 
44 . ·" 
4S 
46 
47 
48' 
'48. 
-· 48' 
so 
SJ 
' 
ACKNOWLEDGEMENTS 
APPENDIX 
OMNIBUS Signals 
iii 
Page 
52 
53 
53 
'iV 
LIST OF FIGURES 
Page 
Figure 1. Interface control board block diagram 8 
Figure . · 2. Schematic diagram of the Heath/PDP-8/E interface 12 
Figure 3. ADDRESS DECODER logic diagram 
Figure . 4. OPERATIONS DECODER logic diagram 
Figure 5. TAPE.READ and SKIP logic diagram 
Figure 6. Timing diagram for the Heath reader hand.shake lines 
·Figure 7. TAPE PUNCH and SKIP logic diagram 
Figure 8. Timing diagram for the Heath punch handshake lines 
Figure 9. READER BUFFER logic diagram 
:!figure 10. 
!igure 11. 
Figure i2 . 
Figure 13. 
Figure 14. 
Figure 15. 
:Figure 16; 
Figure 17. 
PUNCH. BUFFER logic di_agram 
Hard-wired inter-connection of the IC's on the back· 
of the Douglas board 
. Physical layout of the mounted IC's on the Douglas 
board 
Heath unit,. interface board and .the cable connected 
together 
Heath unit, interface board and the cable connected 
together with the interface control module inserted 
in the OMNIBUS 
Signal cable 
Pin connection numberi_ng .of sides A and B of the 
signal cable 
·Heath inodel HlO paper tape reader/punch 
:Figure· 18'. S:l.gnals .and pin assignments of the OMNIBUS 
( 
·-. 
',... ~ 
15 
17 
18 
21 
22 
23 
25 
26 
29 
31 
34 
36 
38 
40 
43 
56 
v 
LIST OF TABLES 
Table 1. Manufacturer numbers and descriptions of the 
IC's used 
Table 2. IOT instructions list and description 
Table 3. Cable/connector pin assignments 
Table 4. Description of OMNIBUS signals 
Page 
13 
20 
41 
53 
ABSLDR 
AC 
BCD 
BUILD 
co 
Cl 
CPU AC 
DATA 
H 
IC 
INTERNAL I/O 
I/O 
IOP 
I/O PAUSE 
IOT 
L 
l1D 
PIP 
RDR 
SKIP 
TP 3 
0--
vi 
TABLE OF SYMBOLS 
Absolute Loader 
Accumulator 
Binary Coded Decimal 
System generation program for OS/8 
OMNIBUS 
OMNIBUS 
. all sign 
1 
signal 
Central Processing Unit Accumulator 
1 
Data Bus data line (OMNIBUS signal) 
Active high 
Integrated circuit 
1 
OMNIBUS signal 
Input/Output 
Input/Output pulse 
. 1 
OMNIBUS signal 
Input/Output transfer 
Active low 
( ' 1 Memory data line OMNIBUS signalJ 
Perpheral Interchange Progr.am 
Reader 
OMNIBUS signal l 
1 
Timing pulse 3 (OMNIBUS signal) 
Represents an OMNIBUS signal 
1i<-or all OMNIBUS signals, refer to the APPENDIX. 
1 
INTRODUCTION 
Twelve-bit minicomputers such as the Digital Equipment Corportation 
(DEC) PDP-8/E (1) or equivalent are often used in biomedical experimenta-
tion and research by hospitals and clinics to control and monitor biological 
and physiological parameters. To maintain their versatility, mini-
computers are commonly used in conjunction with other peripherals and 
memory devices to perform the basic task of inputting programs and out-
putting information. Although the cost of minicomputers and their 
peripherals has decreased considerably in the past few years, to purchase 
a complete computer system, one would have to spend anywhere between 
ten to twenty thousand dollars or more depending on the quality and the 
complexity of the system. 
In an effort to minimize this cost, a study was undertaken to 
develop a more effective method of accomplishing the task of information 
input/output. This study utilizes the DEC PDP-8/E minicomputer; there-
fore, all discussions following refer to this sytem, although applications 
to other equivalent mini and micro computers are possible. There are 
several means of inputting and outputting information. The most connnon 
of these are the Teletype, DECwriter (LA36), DEC high-speed paper tape 
reader/punch, Floppy disk memory system and DECtape transport. However, 
there are advantages and disadvantages associat'ed with each one of 
these to be considered. 
To further elaborate on the various methods of information input/ 
output listed above, consider the following example. Suppose a program 
is entered into the computer by keying it in via the front panel switches 
2 
of the PDP-8/E and it is run and the desired output is obtained. It is 
then decided to save this program. What are the .methods .available which 
allow you to save this program? The exotic methods, of course, are such 
things as DECtape or Floppy disc which are moderately expensive at 
pres1mt (DECtape costs around $4000, Floppy disc around $2500) and in 
terms of relative cost, most people cannot afford them. The next 
choice to consider may be the Teletype, It is true.that the Teletype 
with proper interfacing is capable of reading information into the PDP-8/E 
memory and can save information on pape·r tape. However, there ·are some 
disadvantages in using the Teletype: 
'. 
1) :Teletypes are expensive (around $1300). 
2) Teletypes: are mechanical, subject to wear problems. 
3) Teletypes are slow (operate at a data rate of 110 baud). 
One might consider the DECwriter (LA36); ~his unit has .several 
advantages over the Teletype. The DECwriter has a lower failure rate than 
the Tel,E!type,and is similar in cost but three times as fast. Although not 
d'J;rectly related., another feature: of the DECw.riter is its abi1ity to 
commup.icate back and forth at 300 baud over fairly long lines, thus . ., - ' ' 
making ~t abou~ as fast a device as one can get that is versatile. 
Since the ultimate goal is to input and output information as fas't 
as pos·siblo; and yet not go overboard on price; the DECwriter seems like 
the ideal device. Unifortunately, the DECwriter unlike the Teletype, has 
no paper tape input/output, capability. Thus if .you have only a DECwri'ter and 
',' 
a PDP-8/E, you have no method of programming the PDP-8/E with paper-tape 
·g~ogra~s or saving programs (other than a hard Gopy that the DECwriter 
'provides). Th.erefore to maintain the DECwriter's speed and yet eliminate 
3 
the tedious task of entering programs step by step, the objective becomes 
one of obtaining paper tape capability at low cost . 
Since paper tape reader/punch units are expensive, time 
was spent researching the capabilities and costs of different units . 
The Heath model HlO paper tape reader/punch was found to be the most cost 
effective unit available at the present time. It can read at a speed of 
SO characters per second and can punch at a speed of 10 characters per 
second using 8-level, 1 'inch paper tape. It costs $500 as opposed to a 
$5000 DEC unit, thus possessing an economic avdantage. the DECwriter 
in conjunction with this Heath reader/punch constitutes a fast and inexpen-
sive system which has the ability to read information into the PDP-8/E and 
transfer information from the PDP-8/E to the inexpensive medium of paper 
tape . 
One might argue that with the presence of Floppy disc, DECtape, and 
magnetic tape on the market, paper tape is a little bit on the obsolete 
side. But there are some good reasons to justify the use of the paper 
tape. One of the advantages of paper tape is that it has a relatively 
long life. Better yet, if you put the information on mylar tape as opposed 
to paper, it will last virtually forever. 
Another advantage is that paper tape has a built-in method of trouble-
shooting. For example, if you were to punch a program on paper tape and 
then read it back in the computer and it didn ' t work, you could actually 
read down through that paper tape and find out where the error had occurred. 
If there were no errors and the information was still not being received at 
the computer, then you could automatically say the problem is within the 
reader. The above method of troubleshooting is not applicable to other 
4 
input/output units such as magnetic tape recorders. To find out whether 
the recording on a magnetic tape is correct is a f airly di f ficult 
operation. 
Other advantages of paper tape are that heat, cold, or magnetic 
fields won't affect it. Also, the problem of crosstalk developed on mag-
netic tapes after long periods of storage is eliminated when using 
paper tapes. 
It should be mentioned that, like other mechanical units, there are 
mechanical disadvantages associated with the memory units utilizing 
paper tape. Other disadvantages associated with paper tape are that it is 
slow and limited in its density of recording. In most applications, 
however, you can fit all of the information for a substantial program on 
a small roll of paper tape. So paper tape, although slow and having lower 
density capability than many of the newer techniques, still has a very 
valid place in programming and storing information. 
The Heath paper tape reader/punch unit, as supplied, has to be inter-
faced to the PDP-8/E minicomputer in such a way that the action of the 
reader and punch can be controlled from program instructions (2). This 
task involves both hardware and software aspects of interfacing. In the 
hardware design of the interface various fundamental points such as the 
device address selection, operations decoding, input/output to the bus, 
and flags and their conditions have to be considered. For the software 
aspect of the interface, one has to worry about the coding of a device 
handler program in order to actually control the action of the Heath 
reader/punch with the program instruction (3). 
It is the objective of this research to interface the Heath reader/ 
5 
punch to the DEC PDP-8/E minicomputer, thereby developing an economical 
method of information input/output and storage for use in biomedical 
experimentation and research. Although the details of this interfacing 
would vary with other equivalent minicomputers, the principles involved 
remain very similar. 
6 
HEATH CONTROL INTERFACE FUNCTIONAL DESCRIPTION 
A block diagram of the Heath control interface is illustrated in 
Figure 1. The primary logic/functions needed to interface the Heath 
unit to a PDP-8/E are illustrated by blocks. The ADDRESS DECODER provides 
selection logic to ensure that the processor is communicating with the 
Heath unit rather than some other device. It receives memory data 
(MD 3 - MD 8), decodes them, and signals the OPERATIONS DECODER that this 
input/output transfer (IOT) instruction is addressed to the unit. The 
input/output (I/O) PAUSE signal is used as a gating input to ensure that 
the instruction is an IOT instruction. If MD 3 to MD 8 equal Ol(octal), 
the reader is addressed and 02(octal) addresses the punch (4). 
The OPERATIONS DECODER begins to function when the ADDRESS DECODER 
signals that the reader or punch has been addressed. The OPERATIONS 
DECODER then looks at bits MD 9 to MD 11 and decodes the type of instruc-
tion to be performed (4). The OPERATIONS DECODER is divided into two 
sections, reader and punch functions. Only one function can be turned 
on during any one IOT. After the function has been selected, the OPERATIONS 
DECODER enables all of the other functional blocks. If the Heath unit 
control is to read information, the OPERATIONS DECODER enables the Heath 
unit TAPE READ and READER BUFFER. If the Heath unit control is to punch 
information, the OPERATIONS DECODER enables the Heath unit TAPE PUNCH and 
PUNCH BUFFER. 
The reader function is represented by the logic blocks above the 
broken line in Figure 1. Three IOT instructions 6012 (Read Reader Buffer 
Register), 6014 (Fetch Reader Character) and 6016 (Read Buffer, Fetch 
Figure 1. Interface control board block diagram 
OMNIBUS 
SIGNALS 
DATA 4-11 L 
CO, Cl L 
SKIP L 
I/0 PAUSE L 
MD 3-8 L 
INT I/O L 
MD 9-11 L 
DATA 4-11 L 
TP 3 H 
SKIP L 
-
-
I 
DATA BUS (PARALLEL DATA IN) 
CONTROL 
SIGNALS 
RDR 
•. I 
I 
6012, 6014, 6016 BUFFER I 
RDR 6011 I 
IOT'S + RDR DATA STROBE I I 
TAPE I 
READ - I 
I 
6011. SKIP I+ I -
. ADDRESS H> OPERATIONS READER FUNCTIONS ,_____ 
DECODER DECODER PUNCH FUNCTIONS I 
t r-l> PUNCH · · 
BUFFER I 
DATA BUS (PARALLEL DATA OUT) t t I PUNC~ STROBE 
6022, 6024, 6026 I PUNCH 6021 TAPE 
IOT'S PUNCH I I 6021 I SKIP ~ 
HEATH HAND-
SHAKE SIGNALS 
READ HOLE l-8 
READER START 
READER READY 
PUNCH HOLE l-8 
PUNCH START 
PUNCH READY 
00 
9 
Reader Character), read the infonnation currently over the photo array 
and then initiate tape feed . When either of these instructions is decoded 
by the OPERATIONS DECODER logic, the TAPE READ logic generates a READER 
(RDR) DATA STROBE pulse which enables the READER (RDR) BUFFER gates and 
allows the information present on the READ HOLE 1-8 lines to pass 
through. The 6011 instruction (Skip On Reader Flag) senses the state of 
the READER READY line . The READER READY line being low, indicates that 
the information is ready to be transferred. Data on READ HOLE 1-8 lines 
are transferred to the Central Processing Unit Accumulator (CPU AC) 
Register by either of the 6012 or 6014 instructions or a microprogram of 
them both, which is the 6016 instruction . 
The punch function is represented by the logic blocks below the 
broken line in Figure 1. Upon decoding a 602X instruction, the OPERATIONS 
DECODER logic signals the loading of the information of the DATA BUS 4- 11 
lines into the PUNCH BUFFER register. At TIME PULSE (TP 3) of the instruc-
tion, the PUNCH STROBE signal causes the transfer of the character signals 
from the PUNCH BUFFER to the PUNCH HOLE 1-8 lines. The 6021 instruction 
senses the state of the PUNCH READY line . The PUNCH READY lines being high 
indicates that the punch is ready. 
10 
DETAILED LOGIC 
The overall schematic diagram of the Heath/PDP-8/E interface is 
shown in Figure 2. The following subsections discuss in detail the 
different circuits utilized in the interface. Figures 1 and 2 illus-
trating the block andthe schematic diagrams of the interface, should be 
referred to when reading these subsections. In all of the diagrams through-
out, the symbol ~represents an OMNIBUS signal. Letters to the right 
of each signal name specify the pin assignments of the OMNIBUS and are 
described in the APPENDIX. The L and H after the signal name identify 
the most common assertion level. The interface supply voltage (Vee) is 5 
volts. The numbers and descriptions of IC's used are listed in 
Table 1. 
ADDRESS DECODER Logic 
The ADDRESS DECODER logic (Figure 3) decodes MD 3 through MD 11. The 
device address is contained in bits 3 through 8, and the operation code is 
contained in bits 9 through 11. If the middle six bits are decoded as 
Ol(octal), the OPERATIONS DECODER is directed to the reader functions. If 
the middle six bits are decoded as 02(octal), the OPERATIONS DECODER is 
directed to the punch functions. The I/O PAUSE gates the address bits 
through the decoder. The output of the ADDRESS DECODER logic provides an 
enabling signal either to the reader or to the punch portion of the OPERATIONS 
DECODER. It also generates the INTERNAL I/O signal, which is used in the 
positive I/O Bus Interface to prevent the generation of input/output pulses 
(IOP's) (4). 
Figure 2. Schematic diagram of the Heath/PDP-8/E interface 
CONNECTORIP31 
' '"' 
FROM 
READER 
MD9-DL 1 
MD10-0M1 
M011-DP1 
MDB-DK1 
MD7-BP1 
M06-BM1 
M05-BL 1 
M04-BK1 
M03-AP1 
B 
7 
6 
5 
4 
3 
2 
, 
' 
' 
' 
' ·-
' 
( 
' 
' 1/0 PAUSE 
CD1 
I 
H10 DATA 
OUTPUT LINES 
7 
6 
5 
4 
3 
2 
1 
0 
• .. ~ 
' , ~ • 3 
_._,4 
' ' ~
' 
, 
' 4_1]/" ~ 
10~ --ii_11 .. 
" ...!..!t!_!,r -
' -"t.!Y' ' -
....:.,_,~ 
~ 12 12 " ' 
~13 7 
0 - • 4-B1R "8 
8 "'1..10 n 5-B1S 
Q.J e J 
128,-'' n 6-B1U 
-
o· 7-B1V ' ' " B ·-. ' 1 , n B-D1R 
. 
" 0 9-D1S " 1 .. n10-D1U 
111 1 J " 
' r>11-D1v 3 1 ; ' 
v 
I cc 
0,47K 0.47K 
" " 9 110 
~2 
l~ • 18 3 
I 
I 
I 6 • 
r trs • .• , 6 " .. 
->-
f-- ' f--1-< • 
~· INT 1/0 CL 1 
• 17 3 
9 21"" " " - 2 1 B 
" ' • ~ ' 
H10 DATA CONNECTORIPSI ··- l ·~ INPUT LINES "" " 7 1 • 9 " B .. 
" " ' " 9 1 •• 6 1 7 10 • ' ' ' 9 3 " 5 1 6 • 
' '9 
3 " 4 1 • " 5 TO ... ' ·~ ' 2 " I " 3 1 PUNCH 4 .. 
" " 2 1 " 2 1 3 - 3 • ' ' , 2 3 " 1 1 2 .. 
3 " ' 2 • " 0 1 - rvcc 
IENASLEI E 0.4iK 0.47K R IRESETI 
e. I 8114 5 ... 
D 2(12111093" 5 
0 " 3" " 
~~ 
-~\· 20 I ~ 11113 
D 2ft21110934 5 
0 1 2 3 .. 5 6 7 
TP3-CH2 
CHIPIS ,.. y 
3.10 ll1.t • .. 5.20 fil...! ' .. 13.21 ""-'-' ' • • l!!...1. 1 " 1.7.8.19.22 ill..!. 1 " 2 .... e.11.12. ~ ' ' 17.18 
I '~ 
:fVcc Vee 4.7K , ' 19 
8 
4. 7 K Lu-::--.. 4 
e190V 7J 
·~~13 19 13 12 7 
7 " 
Vee .. ,~r~.. v 
' • "·~ " I 4.7K 4.7K 13 6 13 5 " 4 12 Vee 22 " 
2 4. K 
I ~22 1 
R EADER START 
P3(t10) 
R EADER READY 
P3!19J 
SKIP-C51 
-
p 
CO-CE1 
C1-CH1 
UNCH READY 
P3l119) 
P. UNCH START 
P3Cl20) 
,_. ...., 
13 
Table 1 
MANUFACTURER NUMBERS AND DESCRIPTIONS OF THE IC'S USEDa 
IC CHIP II' s 
3 ,, 10 
5, 20 
13, 21 
6 
1, 7' 8, 
19, 22 
2,4,9,11, 
12,17,18 
MANUFACTURER' S TYPE II 
9314 
8251 
SP314 
8881 , 
7401 
SP380 
FUNCTION 
Quad Latch 
BCD-TO-Decimal Decoder 
Single 7-input NOR Gate 
Quad 2-input NAND Gate 
(with open-collector 
output) . 
Quad 2-input NAND Gate 
(with open-collector 
output) 
Quad 2-input NOR Gate 
'Note: All IC' s are of plastic DIP package type, 
Figure 3. ADDRESS DECODER logic diagram 
~· ,• 
16 
OPERATIONS DECODER Logic 
Figure 4 shows the OPERATIONS DECODER logic. Table 2 lists the 
high-speed paper tape reader/punch IOT instructions and a description of 
each (5). The OPERATIONS DECODER logic receives either 01 or 02(octal) 
from the ADDRESS DECODER logic to enable the reader or punch logic, respec-
tively (4). The operation to be performed is determined by the last three 
MD bits, MD 9-11. The 601X signal and bits MD 9-11 are applied to the 
Binary Coded Decimal (BCD)-to-Decimal decoder, (chip #5). This decoder 
provides the reader IOT signals, as illustrated in Figure 4. The 602X 
signal and bits MD 9-11 are applied to another BCD-to-Decimal decoder 
(chip #20), which provides the punch IOT signals. 
TAPE READ and SKIP Logic 
The TAPE READ and SKIP logic is shown in Figure 5. The TAPE READ 
logic generates timing signals in response to the IOT instructions 6012, 
6014 and 6016. When an IOT instruction (6014, for example) is decoded, 
the control logic first causes the character to pass through the READER 
BUFFER gates by the RDR DATA STROBE signal. It then generates stepping 
signals that cause the reader motor to run. The 6014 signal advances the 
tape one character by applying a TTL high-to-low transition to the 
READER START line. 6011 instruction (Skip on Reader Flag) senses the 
state of the READER READY line in the SKIP logic. The READER READY line 
being low indicates that the data are ready to be transferred. When this 
line is low, the program counter is incremented so that the next sequential 
instruction is skipped. 
; 17 
,M09-DLT 9 14 c l 10 4 12 6011 ( RSF) L 
~ 7 MDlO-DMl 2 B 14 . 4 11 6012 (RRB) L 6 
5 
MDl 1-DPl 3 A 15 ·4 9 6014. (RFC) L 
BUFFERED 
l/O PAUSE L 
.601X L. 6 
4 D 2 6 6016 (RRB, RFC) L 
c 1 12 6021 (PSF) L 
B 14 11 6022 (PCF) L 
A 15 
20 
9 6024 (PPC) L 
602X L 18 
13 D 2 6 6026 (PLS) L -
Figure 4. OPERATIONS DECODER Logic Diagram 
6012. L 
6014 L 
___ 6016. L 
____ 6011 L·-__ -1--" 
Vee 
4. 7K 
JO 
18 
RDR DATA STROBE 
TO READER BUFFER . 
6 
Vee 
·1. 7K 
l 
READER START 
P3(#10) 
. READER READY 
P3(#9) 
5 
-
6 -7 'ri-----0 SKIP-CSl 
13 
7 
CO-CEl 
10 Cl-CHl 7 
Figure 5. TAPE READ and SKIP Logic Diagram 
19 
Two i mportant control signals , CO and Cl are used t o determine the 
type of data transfer between the processor and the Heath control (2). 
When the data on READ HOLE 1-8 lines are passed through the READER BUFFER 
ga tes and put on the DATA BUS, the 6016 instruction asserts CO and Cl, 
transferring the data to the Accumulator (AC) register. 
Figure 6 is a timing diagram of the Heath Reader Handshake lines (6). 
Two handshake signals, READER START and READER READY are generated by 
the Heath Reader. The READER START signal (active low) advances tape one 
character. READER READY line (active low) is sensed by program instruction 
to determine when the data are ready to be transferred. READER START 
input may be pulsed only when this line is low. 
TAPE PUNCH and SKIP Logic 
The TAPE PUNCH and SKIP logic are shown in Figure 7. A tape loaded 
in the punch feeder mechanism can be punched, if a punch command is 
issued by an IOT instruction. When the 6026 IOT instruction is issued, for 
example, it applies a high-to-low transition to the PUNCH START line 
which initiates the punch cycle of a character. The 6021 instruction 
(Skip on Punch Flag) senses the state of the PUNCH READY line in the Skip 
logic. The PUNCH READY line being high indicates punch is ready. When this 
line is high, the program counter is incremented so that the next sequential 
instruction is skipped. Figure 8 is a timing diagram of the Heath punch 
handshake lines (6). Two handshake signals PUNCH START and PUNCH READY 
are generated by the Heath punch. The PUNCH START signal (active low) 
starts the punch cycle o.f a character. PllNCH READY (active high} indicates 
that the punch is ready. A TTL low is present from the Heath unit within 
20 
Table 2 
IOT INSTRUCTIONS LIST AND DESCRIPTIONa 
Octal Code Mnemonic 
6011 
6012 
6014 
6016 
6021 
6022 
6024 
6026 
a 
RSF 
RRB 
RFC 
RRB, RFC 
PSF 
PCF 
PPC 
PLS 
Source: 7, p. 2-4. 
Functj_on 
Skip on Reader Flag. Senses the state of the 
RDR FLAG flip-flop. If the flip-flop is set, the 
program counter is incremented so that the next 
sequential instruction is skipped. 
Read the RDR Buffer Register. Causes the RDR 
Buffer Register to be ORed into the AC Register, 
clears the RDR FLAG flip-flop. 
Fetch a Character from the tape . Clears the 
RDR FLAG flip-flop, loads a character into the 
RDR Buffer Register from the tape, sets the 
RDR FLAG flip-flop when the RDR Buffer Register 
is loaded. 
Microprogram of 6012 and 6014 . RDR Buffer 
Register contents are ORed into AC Register, 
RDR FLAG flip-flop is cleared, character is 
loaded into Register, and RDR FLAG flip-flop 
is set. 
Skip on Punch Flag. Senses the state of the 
PUNCH FLAG flip-flop. If the flip-flop is set, 
the program counter is incremented so that the 
next sequential instruction is skipped. 
Clear the Flag. Clears the PUNCH FLAG flip-flop. 
Load Punch Buffer Register, punch Character. 
Transfers the AC 4-11 contents to the Punch 
Buffer Register, punches the character, sets the 
PUNCH FLAG flip-flop when done . 
Microprogram of 6022 and 6024. Clears the 
PUNCH FLAG flip-flop, transfers AC 4-11 contents 
to the Punch Buffer Register, punches the 
character, sets the PUNCH FLAG flip-flop when 
done. 
I 21 
-->j 14---100 ns 
READER START---u 
4 r- 200 ns max 
READER READY 
'"' 
16. 5 ms 
LJ 
NOTE: READER MAY BE PULSED 
ONLY WHEN .READER READY LINE 
IS LOW •. 
LJ 
"I . 
.. NOTE: OUTPUT DATA.ARE VALID WHEN READER READY LINE IS LOW. 
~ 
Figure 6,. Timing Diagram for the Heath Reader Handshake Lines. 
Abstracted from (3). · 
22 
Figure 7. TAPE PUNCH and SKIP Logic Diagram 
I 23 
f.i----200 ns min~ 
i~~~~ --~, .80 ms max .-
1 
---:._ _____ __, 
200 ns max -+I 
PUNCH 
READY 
--I 1-- 200 !15 max 
-+j · ~25 ms (min) 
~~ .~™~~ 
L 
I 
DATA INPUT MUST BE VALID AND NOT CHANGE DURING THIS TIME . 
. NOTE: PUNCH MAY BE TRIGGERED ONLY WHEN PUNCH READY LINE IS HIGH. 
Figure B. Timing Diagram for the Heath Punch Handshake Lines, 
' Abstracted from (8). 
24 
200 ns after leading edge of PUNCH START input signal and remains low until 
the punch is ready for the next character. 
READER BUFFER Logic 
The READER BUFFER logic is shown in Figure 9. Data supplied on the 
READ HOLE 1-8 lines are enabled through the READER BUFFER gates in parallel 
form by the RDR DATA STROBE signal. Either the 6012, 6014 or 6016 instruction 
gates the character onto the OMNIBUS DATA 4-11 lines. At the same time, the 
IOT instruction asserts the OMNIBUS CO and Cl signals, resulting in a 
transfer of the DATA 4-11 bits to the CPU AC register (5). 
PUNCH BUFFER Logic 
The PUNCH BUFFER logic is shqwn in Figure 10. It receives information 
from the AC via the DATA BUS, in parallel form, and transmits the information 
out to the Heath punch unit in parallel form. 
A 602X instruction causes the loading of the DATA BUS (bits 4-11) into 
the PUNCH BUFFER registers (IC's 3 and 10). At Time TP3 of the 6022, 
6024 or 6026 instruction, the PUNCH STROBE signal causes the transfer of 
the character signal from the PUNCH BUFFER registers to the PUNCH HOLE 
1-8 lines. Information in the PUNCH BUFFER registers remain there 
until another punch instruction is issued (5). OMNIBUS signals CO and 
Cl cause the transfer of the contents of the AC register to DATA BUS 
when pulled high. 
25 
Figure 9. READER BUFFER Logic Diagram 
I 26 
_HlD 
DATA 
INPUT CONNECTOR 
LINES {P3) PIN# 
10 l 9 
9 9 . 
5 12 7 18 PATA 4 6 
12 11 
DATA 5 11 -g 7 10 6 17 
6 
10 
2 
DATA 6 7 9 3 15 5 16 
4 14 
DATA 7 5 -9 4 13 4 15 PUNCH 
10 l 9 HOLE 
9 -2 5 12 3 14 
1-8 
DATA 8 6 
12 11 
DATA 9 11 2 7 3 10 2 13 
6 2 
DATA 10 7 2 3 15 l 12 
4 14 
DATA 11 5 2 4 13 0 11 
- Vee 
___ 602X l (ENABLE) E 0.47K 0.47K R (RESET) 
6022 L "6022 b 
6024 L 
6026 L 
PUNCH STROBE 
Figure 10. PUNCH BUFFER Logic Diagram ' 
27 
PHYSICAL DESCRIPTION 
Printed Circuit (PC) Board 
In order to interface to the PDP-8/E OMNIBUS, a printed circuit 
board of a special configuration is needed. This is available from 
Douglas Electronics (7). The board provides for both the special 
configuration adaptable to the PDP-8/E OMNIBUS and room for the mounting 
of integrated circuits (IC's) required for the interface. 
For this interface, the mounting of IC's was done on a 26DE8 Douglas 
Electronics module which makes provision for some of the required chips. 
Mounting of additional IC's is required. Procurement of the Douglas 
board facilitated this interfacing design. The cost of this board is 
approximately $70. The inter-connecting of the IC's is done by soldering 
them on the Douglas board and hard-wiring them on the back to accomplish 
the desired functions (Figure 11). The physical layout of the mounted 
IC's on the module is shown in Figure 12. They are numbered 1 through 22 
from left to right starting from the bottom row. The corresponding 
manufacturers IC numbers and their descriptions are listed in Table 1 (8,9). 
Douglas boards are available with some of the IC's already mounted 
on them. In using these boards, however, certain modifications have to 
be made. In particular, since the use of interrupt in this interface 
design was not necessary, one must make certain that the interrupt 
request line (CPl) on the OMNIBUS is not affected (pulled low) when 
Douglas board is plugged into the OMNIBUS. Also, in most cases these 
boards are built to interface one peripheral unit only. However, the 
• 
Figure 11. Hand-wired inter-connection of the !C's on the back of the 
Douglas Board 

Figure 12. Physical layout of the mounted IC's on the Douglas Board 

32 
Heath unit functions as two separate peripheral units and must be 
addressed with two different codes, i.e., one for the reader and one for 
the punch. Thus in using the Douglas board, three of the printed lines have 
to be physically disconnected and rerouted to allow for both the reader and 
the punch logic. The three lines which connect IC 's 2, 9 and 15 (on 
the Douglas board) to pin 2 of IC 5 should be disconnected and rerouted to 
pin 2 of IC 20. 
The interface control module plugs into the PDP-8/E OMNIBUS and 
connects to the external Heath reader/punch through a single cable. See 
Figures 13 and 14. 
Signal Cable 
The signal cable is a 10-foot-long, 25-conductor cable with three 
of the conductors not used. See Figures 15 and 16. Table 3 lists the 
Cable/Connector pin assignments. 
Heath Reader/Punch 
The paper tape reader/punch is a Heath model HlO, manufactured by 
Heath Company (10). It weighs about 22 pounds (10 kgs) and its overall 
dimensions are: 
9-3/4"S x 10-5/8"W x 12-5/8"H (24.77 Cm W x 49.85 Cm D x 32 Cm H) 
Power requirements: 100-135 volts or 200-270 volts, 
50-60 HZ, 100 watts maximum. 
The Heath reader/punch reads and punches standard 8-level, 1-inch 
(10-inch maximum diameter roll or f an-fold), oiled or unoiled paper tape . 
It has a maximum reading speed of 50 characters per second and a maximum 
punching speed of 10 characters per second. A picture is shown in Figure 17. 
Figure 13. Heath unit, interface board and the cable connected together 

Figure 14. Heath unit, interface board and the cable connected together 
with the interface control module inserted in the OMNIBUS 

Figure 15. Signal cable 
H
I 
Figure 16. Pin connection numbering of sides A and B of the signal cable 
/ 
_/ 
/ 
0 <ID cg g g g 
1 2 3 4 
.. -- . 
g g 
5 6 
-
8 g g g 8 g g g g g g g g g g g, © 
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 
HOOD BOTTOM VIEW 
P3 FEMALE CONNECTOR 
VIEWED FROM OUTSIDE 
OF REAR PANEL 
) 
--
/ 
• .·r .. 
41 
Table 3 
CABLE/CONNECTOR PIN ASSIGNMENTS 
Hood Connector (P3) 
Pin II Pin II Wire 
(Side A) (Side B) Color Signal Name 
1 1 RED READ HOLE Line 1 
2 2 WHT-BLK-RED READ HOLE Line 2 
3 3 ORG-GRN READ HOLE Line 3 
4 4 BLK-WHT READ HOLE Line 4 
5 5 WHT READ HOLE Line 5 
6 6 GRN READ HOLE Line 6 
7 7 ORG-RED READ HOLE Line 7 
8 8 BLU-RED READ HOLE Line 8 
9 9 BLK-BRN READER READY 
10 10 BLU-WHT READER START 
11 11 RED-GRN PUNCH HOLE Line 1 
12 12 BLU-BLK PUNCH HOLE Line 2 
13 13 ORG-BLK PUNCH HOLE Line 3 
14 14 GRN-WHT PUNCH HOLE Line 4 
15 15 WHT-BLK PUNCH HOLE Line s 
16 16 WHT-RED PUNCH HOLE Line 6 
17 17 GRN-BLK PUNCH HOLE Line 7 
18 18 BLU PUNCH HOLE Line 8 
19 19 RED-BLK PUNCH READY 
20 20 RED-WHT PUNCH START 
21 21 ORG PUNCH READY 
22 N. C. 
a 
23 N. C. 
a 
22 24 BLK GROUND 
~.c.: No connection. 
\ 
Figure 17. Heath model HlO paper tape reader/punch 
• 
• 
• 
44 
INSTALLATION 
The interface control module is inserted in the PDP-8/E OMNIBUS . 
The control module is connected to the Heath reader/punch with the signal 
cable. The hood side of the cable (side A) connects to the control 
nx:>dule and the female connector side of the cable (side B) plugs into 
the male connector (P3) on the back of the Heath unit. Refer to Figure 14. 
45 
BASIC COMPUTER OPERATION 
In order for the Heath high-speed paper tape reader/punch t o communi-
cate with the PDP-8/E minicomputer, there must exist an active device 
handler program in the existing operating system (OS/8) . The Heath 
interface control board is designed so that it operates under the control 
of the device handler for the DEC high-speed paper tape reader/punch. 
This device handler is supplied with the system generation program for 
OS/8, (BUILD). Only one of the device handlers, either the low-speed 
reader/punch (Teletype handler) or the DEC high-speed reader/punch handler 
can be active at one time. To make the desired device handler active, 
the BUILD commands DELETE and INSERT are used (3). This procedure is 
shown below. 
The following command is typed in response to the dot printed by the 
OS/8 Keyboard Monitor. 
RUN SYS BUILD 
BUILD responds by p-rinting a $, signaling that it is ready to 
accept commands. Typing the following commands, respectively, deactivates 
the existing paper tape reader/punch handler and activates the high- speed 
paper tape reader/punch handler . 
DELETE PTR 
DELETE PTP 
INSERT PT8E PTR 
INSERT PT8E PTP 
BOOTSTRAP 
OS/8 then prints the following two lines and a dot indicating that 
46 
the control is returned to the Keyboard Monitor . 
DSK = SYS 
SYS BUILD 
To preserve the current system status the following is typed in response 
to the dot printed by the Keyboard Monitor: 
SAVE SYS BUILD 
To deactivate the high-speed reader/punch handler and activate the 
Teletype handler, the previous procedure is repeated with the following 
exception: 
The COIIDilands INSERT PT8E PTR and INSERT PT8E PTP are replaced with 
INSERT KS33 PTR and INSERT KS33 PTP. 
Loading of Binary Programs 
After the high-speed paper tape reader/punch handler has been activated 
using BUILD, binary programs on tapes can be loaded and run via the Heath 
reader. This is done using the Absolute Loader (ABSLDR). The user calls 
the ABSLDR from the system device by typing the following in response to 
the dot printed by the Keyboard Monitor (3): 
R ABSLDR 
The system prints an asterisk (*) when it is ready to receive a 
connnand line. The following command is typed in response to the asterisk: 
PTR: /G 
The connnand decoder responds by printing an up-arrow ( t ) or ( f\ ). At 
this point the program on paper tape is inserted in the reader and the READ 
switch located on the Heath front panel is turned on (IN position). 
47 
Typing any character on the keyboard causes the tape to be read. After 
the tape is fed through completely, the reader stops automatically. The 
outco~e of the program on the tape will be printed on the Teleprinter and 
the c omputer halts. At this point the program loaded may not be physically 
in core (3). To examine core locations after using ABSLDR, use Octal 
Debugging Technique (ODT). Running the program under ODT ensures 
the loading of the information in core . The same program can be run again 
by hitting the CONTINUE switch on the PDP-8/E front panel . To get back to 
the Monitor, the procedure for bootstrapping the OS/8 System must be 
performed. 
Punching of Binary Programs 
Information contained in selected blocks of core memory can be 
punched on the Heath punch as binary-coded paper tape using the Binary 
Punch program (11) . This program is loaded by means of the Binary Loader 
(2). It basically picks up data from memory and punches it on paper tape 
via high-speed or Teletype Punch. 
This procedure is used when, there are only a DEC PDP- 8/E, a Decwriter 
and the Heath paper tape reader/punch available to the user . When a DECtape 
transport is available, storing and punching of binary ?rograms 
on paper tape can be accomplished much easier. Information can 
be stored on and recalled from the magnetic tape r a ther than the PDP-8/E 
core memory. The explanation of this procedure follows. 
48 
Data Transfer Between Magnetic and Paper Tapes 
Reading 
To store a binary tape on the DECtape transport via Heath paper tape 
reader, the Peripheral Interchange Program (PIP) is used . 
To call PIP from the system device, in response to the dot printed 
by the Keyboard Monitor, the user types: 
R PIP 
The command decoder then prints an asterisk (*) at the left margin of 
the Teleprinter paper and waits to receive a line of I/O files and options 
(3). The following is typed in response to the asterisk: 
DTAO: File name<PTR:/B 
The connnand decoder responds by printing an up-arrow (t ) or ( f\ ). 
At this point the tape is inserted under the reader head and the READ 
switch is turned on (IN position) . Finally, typing any character on the 
keyboard causes the information to be transferred to the magnetic tape. 
After the paper tape is fed through completely, the READ switch is turned 
off (OUT position). 
Punching 
To punch a binary tape on t he Heath paper tape punch from DECtape 
transport, the procedure below if followed : 
R PIP 
The Heath PUNCH switch is turned on (IN position). (Note : The READ 
switch will not affect the punch operation). The following command is then 
typed in response to the asterisk (*) . 
PTP:<DTAO: File name/B 
49 
The PUNCH switch stays on during the entire punch operation. 
After the tape punch is completed, the system returns to PIP 
automatically . 
50 
CONCLUSION 
A digital electronic interface was designed to enable a Digital 
Equipment Corporation PDP-8/E minicomputer to exchange data with a Heath 
model HlO paper tape reader/punch. The design was implemented with TTL 
integrated circuitry. It has been tested in the laboratory and performs 
satisfactorily. 
With the Heath unit now installed, data can be transferred to the 
core memory of the PDP-8/E at a maximum speed of 50 characters per second 
(6). Also, the Heath interface permits recording of any data or program 
on paper tape for long-term storage. 
51 
BIBLIOGRAPHY 
1 . Digital Equipment Corp. 1972. Introduction to Programming. 
2. 
Digital Equipment Corp . , Maynard, Mass. 
Digital Equipment Corp. 1973 . PDP-8/E, PDP-8/M and 
PDP-8/F Small Computer Handbook. Digital Equipment Corp . , 
Maynard, Mass. 
3 . Digital Equipment Corp. 1974. OS/8 Handbook . Digital 
Equipment Corp., Maynard, Mass. 
4. Digital Equipment Corp. 1973. PDP-8/E Program Maintenance 
Manual . Volume 1. Digital Equipment Corp., Maynard, Mass. 
5. 
6. 
Digital Equipment Corp. 1974. 
Maintenance Manual. Volume 3. 
Mass. 
PDP- 8/E External Bus Options 
Digital Equipment Corp . , Maynard, 
Heath Company. 1977. Operation Manual for the Paper Tape Reader/ 
Punch Model HlO. Heath Company, Benton Harbor, Mich. 
7. Douglas Electronics, Inc. 1975 . PDP-8/E Compatible I/O Interface 
Breadboar d, Data Sheet No . 26DE8 . Douglas Electronics, Inc. , 
718 Marina Blvd., San Leandro, Calif. 
8. Signetics Corp. 1972. Application Handbook. Signetics 
Corp., Sunnyvale , Calif . 
9 . Fairchild Camera and Instrument Corporation. 1972 . TTL Data 
Book. Fairchild Camera and Instrument Corporation , Mount ain 
View , Calif. 
10. Heath Company . 1977. Assembly Manual for the Paper Tape Reader / 
Punch Model HlO . Heath Company, Benton Harbor, Mich . 
11 . Digital Equipment Corp . 1971. PDP-8 Family Connnonl y Used 
Routines. First edition . Digital Equipmen t Corp., Maynard, 
Mass. 
52 
ACKNOWLEDGEMENTS. 
I wish to' express my a~preciation to Dr. Leo R. Soderholm for making 
possible the work described on the preceding pages and for· his helpful 
direction and. enco.uragement during preparation of the manuscript. I also 
would like to thank. Dr. David L. Carlson for .his suggestions and assi!'tance, 
. and for serving as my major advisor; Dr. Curran s. Swift and Dr." M1fry R. 
·.Greer, members of my committee, for the help they have given. 
Finally, many than\{s go to my pa~ents for their constapt encouragement. 
and Siljlpdrt. 
All assistance given me by- the Biomedical Engineering Program is 
,greatly appreciated. 
53 
APPENDIX 
OMNIBUS Signals 
The signals and pin assignments of the OMNIBUS were abstracted from 
Reference 2 and are given in Figure 18. The L and H after the signal name 
identifies the most common assertion level. The description of each 
signal in the interface logic is provided in Table 4. 
SIGNAL 
MD 0- 11 L 
I/O PAUSE L 
TP 3 H 
INTERNAL I/O L 
TABLE 4 
Programmed I/O OMNIBUS Signals 
Abstracted from (2) 
FUNCTION 
Provides IOT instruction as follows : 
68 
(used by 
processor) 
(O 1 2) 
Device Select 
Code 
(3 4 5 6 7 8) 
Device 
Operation 
Code 
(9 10 11) 
Used to gate the device select and device operation 
codes into the programmed I/O interface decoders 
and generate BUS STROBE at TP 3. I/O PAUSE is 
grounded when MD 0-2 equals 6 (octal). 
TP 3 is used to clear the flag and clock the 
output buffer of a Programmed I/O interface. 
It is generated in the timing generator as a 
positive-going 100 ns pulse. 
Signal INTERNAL I/O is grounded by the device 
selector decoder. The Positive I/O Bus Interface 
cannot generate IOP's when this line is grounded. 
This inhibits decoding any Internal OMNIBUS IOT 
SIGNAL 
DATA 4- 11 L 
C lines : CO, Cl L 
SKIP L 
54 
TABLE 4 (Continued) 
FUNCTION 
instruction. Failure to ground this line will 
result in long IOT timing. 
The 8 DATA lines called DATA BUS serves as a 
bidirectional bus for both input and output data , 
between the AC register in the processor and the 
interface buffer register. During Time State 
TS 3 of an IOT instruction, the contents of the 
DATA BUS are applied to the processor's major 
register gating in accordance with the C lines . 
For output transfers, information must be taken 
from the DATA BUS by edge triggering only, using 
the leading edge of TP 3. 
Signals CO and Cl determine the type of transfer 
between a device and the processor. These lines 
control the data path within the processor and 
determine if data are to be placed onto the DATA BUS 
(CO and Cl high) or received from the DATA BUS 
(CO and Cl low). 
An IOT checks the flag for a ONE state and causes 
the device logic to ground the SKIP line if the 
flag is set. The result (PC + 1) is loaded into 
Central Processor Memory Address Register (CPMA). 
The SKIP line is sampled by the processor at TP 3, 
and must be grounded 50 ns before TP 3 in order 
for the skip to occur. 
Figure 18. Signals and pin assignments of the OMNIBUS 
... [ 01 I 02 I Cl C2 Bl --
• I Tp I +15y TP +OV TP I TP ;-• -15Y TP -IS TP 
c GNO GND GND GND GND 
D ... A6L IRO L !ID P-'USE l TPI H MA4L 
E ! M.:.9L IRIL .C0L TP2 H MA5L 
I F I G"'O GND GNO GND GND 
I H J "°;:.IC L IR2 L CIL TP3 H MA6L 
! MA II L -J FL C2L TP4 H MA7L 
·-· 
I • ' MC-3L CL BUS STFiOBE L lSI L 'M04 L 
L ' M09L EL INTERNAL i10 L T SZ L M05 L 
I M I "!C:.10 L USt.R MOr.t: H NOT LAST )(FER L TS3 L ~06 L --!-------·----- ------
N C!iO GNO GNO GNO GND 
p r1011 L F SET L '"' ROST L TS4 L M0.7 L • CATA BL PULSE. LAH INITIALIZE H LINK DATA L DATA 4 L ---
I s I CATA 9L STOP L SKIP L LINK LOAD L DATA 5 L 
T j GNO G~O GND GND GNO 
-----~ u DATA 10 L KE't CONTROL L CPMA DISABLE L tNO IL DATA 6 l -v : tAT4 II L SW - MS,JR DISABLE L lNDZ l DATA 1L 
I * THIS PIN IS CONNECTED TO GROUND ON THE BUS, BUT SERVES AS A LOGIC 
SIGNAL WITHIN MODULES TO FACll:.tTATE TESTING. 
CJ 
rc~~~~ZKr-XL%~monmJ> 
---DI 
CJ 
C:UAU MC6uLf 
(COMPONENT SIDE I 
l<c.::~:ii"Ozl:r-""'- :r..,r>1t:J.nm,.. 
L Cl .· 
00Nf£CTOR D 
SIDE I 
02 \ C2 
CONN~CTOA 0 
510£ 2 
------------------- -
82 Al A~ 
+OV TP . .. -
- l~V TP ~1!r.V 
GND SP GNO If GND 
INT STROBE H MA0 L fr,1.1:,Q L 
BRK IN Pf>OG L I JJA1L EMt. IL 
GNO GNO GNO 
MA,MS LOAD cc;t..IT L MA2L EYA2 L -
OVERFLOW L MA3L MEM S"!'"i\RTL 
BREAK Ct.TA CCNT L M00 L "'AO Olio~ L -
BREAK CYCLE L MOIL SOUF<CE H 
LA ENABLE l M02 L STR05£ H 
GNO GND r,r,!) 
INT IN PROG H • MD3 L INHIBIT H 
RES 1 H DATA 0 L RET'.JH!'I H 
RES 2 H. OAT!. t L ~RITE H 
' GND GtlD ~NO 
RI.JN l OATAZL ROM AOCf<fSS L 
POWER OK H DATA 3 L LINK L 
-
CJ 
ez A2 
