A microcomputer based data acquisition system and experiment controller by Ganz, M. W.
  
 
 
N O T I C E 
 
THIS DOCUMENT HAS BEEN REPRODUCED FROM 
MICROFICHE. ALTHOUGH IT IS RECOGNIZED THAT 
CERTAIN PORTIONS ARE ILLEGIBLE, IT IS BEING RELEASED 
IN THE INTEREST OF MAKING AVAILABLE AS MUCH 
INFORMATION AS POSSIBLE 
https://ntrs.nasa.gov/search.jsp?R=19810018806 2020-03-21T12:07:14+00:00Z
National Aeronautics and Space Administration Headquarter;
Washington, D.C. 20546
r
y
O	 A MICROCOMPUTER BASED DATA
ACQUISITION SYSTEM AND EXPERIMENT
CONTROLLER
The Ohio State University 	 Matthew W. Ganz
The Ohio State University
RKtroS&nce Laboratory
D" wrtmeM of Electrical Engineering
Columbus, Ohio 43212
(NASA —CR-164535) A MICRUCOtlPUTER BASED DATA
	 N81-27344
ACQUISITION SYSTEM AND EXPERIMENT CONTECLLER
(Ohio Stag
 Univ., Columbus.) 128 p
HC A07/!!F A01
	 CSCL 20N	 Unclas
G3/32 26554
Technical Report 712759-3
February 1981
Contract NASW-3393
•
4 .
NOTICES
When Government drawings, specifications, or other data ,.re
used for any purpose other than in connection with a definitely
related Government procurement operation, the United States
Government thereby incurs no responsibility nor any obligation
whatsoever, and the fact that the Government may have formulated,
furnished, or in any way supplied the said drawings, specifications,
or other data, is not to be regarded by implication or otherwise as
in any manner licensing the holder or any other person or corporation,
or conveying any rights or permission to manufacture, use, or sell
any patented invention that may in any way be related thereto.
,y
k
Unclassified
SECUR1TV CI AAAIFICATinu AF TI.IIS PA6E rften Dare tntered)
REPORT DOCUMENTATION PAGE 6EREAD INSTRUCTIONSFORE COMPLETING FORM
I. REPORT NUMBER 2. GOVT ACCESSION NO. 1. RECIPIENT'S CATALOG NUMBER
•.	 TITLE (and Subtitle) S. TYPE OF REPORT A PERIOD COVERED
A MICROCOMPUTER BASED DATA ACQUISITION SYSTEM AND Technical Report
EXPERIMENT CONTROLLER 6. PERFORMING ORG. REPORT NUMBER
ESL 712759-3
7	 AUTHOR(*) B. CONTRACT OR GRANT NUMBER(*)
Matthew W. Ganz Contract NASW-3393
!, PERFORMING ORGANIZATION NAME AND ADDRESS
The Ohio State Universi ty ElectroScience Labora—
10. PROGRAM ELEMENT, PROJECT, TASK
AREA& WORK UNIT NUMBERS
tory, Department of Electrical Engineering
Columbus, Ohio	 43212
11. CONTROLLING OFFICE NAME AND ADDRESS 12. REPORT DATE
NASA Headquarters
13. NUMBER	 PAGESO
120HQ Contracts and Grants Division
MONIT	 RING AGENCY NAME A ADDRESS(If different from Controlling Office) IS.	 SECURITY CLASS. (of this report)
Unclassified
ISe. DECLASSIFICATION/ DOWNGRADING
SCHEDULE
16.	 DISTRIBUTION STATEMENT (of this Report)
17.	 DISTRIBUTION STATEMENT (of the abstract entered In Block 20, If different from Report)
I6. SUPPLEMENTARY NOTES
19.	 KEY WOROS (Continue on revere* old@ fl neceeeary and Identify by block number)
AIM-65 microcomputer	 Analog conditioning circuit
Analog to digital converter 	 Microformatter
Digital input/output	 Expansion motherboard
Direct memory access
20.	 ABSTRACT (Continue on revers* side It nece*aary and Identify by block number)
This report describes a data acquisition system which was designed and imple-
mented at The Ohio State University's ElectroScience Laboratory. 	 The system
monitors and records the signal strength of a radio beacon sent to earth from
a geosynchronous satellite.
	
It acquires data from several devices such as a
radar, a radiometer, and a rain gauge which can monitor the meteorological con-
ditions along the Earth-space propagation path. 	 The acquired data are stored
in digital format on magnetic tape for analysis at the laboratory's computer
DD1 JAN 77 1473	 EDITION OF 1 NOV 65 IS OBSOLETE	 i Unclassified
SECURITY CLASSIFICATION OF THIS PAGE (When Data Entered)
• - -.. ..^^ ^...3 ^^,rs::^^. ms's.
Unclassified
nI IT %.L.naair vim^ I FUn U r I n13P Pn(.E(nn9n uap
center. This data acquisition system is based on the Rockwell AIM-65 Advanc-
ed Interactive Microcomputer. It replaces a previous system which used 2 mini-
computers to perform the same tasks.
This report gives a detailed description of the design and operation of the
system's various hardware components. The report also presents schematic dia-
grams, the theory of operation, and normal operating procedures.
Unclassified
SECURITY CLASSIFICATION OF TH11% PAGE(S'Aon Data Enferod)
it
TABLE OF CONTENTS
Page
LIST OF TABLES	 v
LIST OF FIGURES	 vi
I. INTRODUCTION 1
A.	 Overview 1
B.	 System Description 2
C.	 The AIM-65 3
II. DIGITAL I/O SUBSYSTEM 5
A.	 Introduction 5
B.	 Operation 5
C.	 Hardware Details 9
III. ANALOG INPUT SUBSYSTEM 15
A.	 Introduction 15
B.	 Operation and Calibration 15
C.	 Hardware Details	 , 18
IV. DMA CONTROLLER AND TAPE CONTROL 27
A.	 Introduction 27
B.	 Tape Control 27
C.	 Hardware Details 48
1.	 Tape Control Line Buffers 48
2.	 The Address Bus 50
3.	 The Data Bus 52
4.	 Status Input Register 54
5.	 The DMA Memory 54
6.	 Address and Byte Counters 58
V. HIGH RESOLUTION RADAR CONTROL 65
A.	 Introduction 65
B.	 Hardware Interconnections and Control Sequence 65
C.	 Radar Interface Operation 67
D.	 Software Considerations 71
VI. SENSE SWITCH INPUTS 76
VII. CONCLUSIONS AND FUTURE CONSIDERATIONS 78
REFERENCES 80
iii
P age
APPENDIX A: DATA ACQUISITION SYSTEM - MEMORY MAP	 A-1
APPENDIX B: WIRE LISTS, PC LAYOUTS, ETC. 	 B-1
APPENDIX C: GLOSSARY OF SELECTED MNEMONICS	 C-1
iv
LIST OF TABLES
Table 2.1.	 VIA Address Selection
Table 3.1.	 A/D Address Selection
Table 4.1.
	
Microformatter Commands
Table 4.2.	 AIM-65 VIA Port Assignments
Table 4.3.	 DMA Controller Memory Map
Table 4.4.	 Memory Selection Summary
Table 4.5.	 Read/Write Logic Summary
i
3
V
s..	 _.y —=^—	 .^.^^.a^.^	 .:.	
.,,...+r^=-_ar-^._. _+x-^^a:=^zz
	 -:._...p^i^s-at3-_^s^^.^^a._,^3+E 3^. a._ .^	 —..._..:.3 _s '^
	 ^z auas^c- mar-3-^	 —	 t
P
_ age
11
23
32
32
39
59
59
LIST OF FIGURES
P. a^.e
Figure 1.1.
	
Data Acquisition System	 4
Figure 2.1.	 (a) Partial Memory Map	 6
(b) Detailed Memory Map of VIA #3
(c) Detail of Port-Direction Register Relationship
Figure 2.2. VIA Board 12
Figure 2.3. VIA Connection Details 13
Figure 3.1. AD7574JN	 Configuration 20
Figure 3.2. Reference Supply 20
Figure 3.3. Analog Conditioning Circuit 21
Figure 3.4. A/D Converter System 25
Figure 4.1	 (a). DMA Controller Block Diagram 28
Figure 4.1
	
(b). DMA Controller - Derailed Block Diagram 29
Figure 4.2. (a)	 Address Counter 35
(b)	 Byte Counter
Figure 4.3. Status Input Register 38
Figure 4.4. Status Check Subroutine Flowchart 41
Figure 4.5. Write Operation Flow Diagram 43
Figure 4.6. Space Back 1 Record Flow Diagram 45
Figure 4.7. Read Program Flow Diagram 47
Figure 4.8. DMA Board Control I/O Buffering 49
Figure 4.9. DMA Address Buffering and Partial Decoding 51
Figure 4.10. Data Buffering 53
Figure 4.11. Status Input Register 55
Figure 4.12. DMA Memory and R/W Logic 56
Figure 4.13. Address Counter 60
Figure 4.14. Byte Counter 61
Figure 4.15. Address and Byte Counters - Load and Clock Logic 64
vi
W°
w
1 vii
Figure 5.1. Radar Control Word Buffers 66
Figure 2.2. VIA X12 Port Assignments 69
Figure 5.3. Radar Control Timing Diagram 70
Figure 5.4. Radar Control Program 75
Figure 6.1. Sense Switch Debouncing Circuit 77
I.	 INTRODUCTION
A.	 Overview
This report describes a data acquisition system designed,
constructed, and implemented at the Satellite Communications Facility
of the Ohio State University ElectroScience Laboratory. The system
replaced a former system which used a Hewlett-Packard 21168 Minicomputer
as its intelligent controller. The old system worked very well but it
underwent frequent modifications over the past decade and became quite
complicated. This system was not extensively documented and many of the
modifications were not documented at all. Operating and troubleshooting
this system were often difficult and frustrating. With the advent of
modern microprocessor technology it was decided that a new data acquisi-
tion system based on a small microcomputer should be built.
The new system was designed to be easily understood, easily
expanded, and well documented. The design stresses simplicity of design
and programming techniques so that people unfamiliar with the system's
operation would be able to master it quickly. The hardware design is
general enough that the data acquisition system can easily be used for
other applications.
The system is designed for easy maintenance and repairs. All
components, including the microcomputer, are inexpensive enough to
keep duplicates on hand. This will help reduce down time and costly
repairs.
The system's operating program can be stored in Eraseabie
Programmable Read Only Memory (EPROM), eliminating the need to load
the program during the system's start-up. The program in the EPROM
can be easily modified as the system's needs change.
This report is organized so that it will be useful to both the
system operator and the troubleshooter. Each of the several subsystems
has a chapter devoted to it. Each chapter begins with an overview of
the subsystem and instructions for proper operation. This is followed
by an indepth look at the subsystem's hardware and theory of operation.
Schematic drawings and wire lists appear with the explanatory text.
1
l	 1
1
rA glossary at the end of the report gives the meanings of some of the
commonly used words, abbreviations, acronyms and phrases.
B.	 System Description
The data acquisition system comprises several hardware components.
A block diagram of the system is shown in Figure 1-1. The Rockwell
AIM-65 Advanced Interactive Microcomputer is used as the intelligent
processor. Added to the basic microcomputer is an expansion mother
board. This board contains five sockets into which boards containing
Input/Output (I/0) or memory devices can be inserted. Two such
boards were constructed and a brief description of each of them follows.
The first board designed was a digital I/O board. This board
contains 128 digital lines each of which can act as an input or output.
The digital I/O board also contains several counters, timers, and
special I/O functions. Chapter 2 gives operational and functional de-
tails of this board.
The second board is an analog input board which contains 16
Analog to Digital Converters (ADCs). Each of the ADCs monitors an
analog voltage and produces a digital number proportional to the
voltage. The computer can then read, process, and
store this number. Thus, the computer can observe the analog voltages
produced by sensors which monitor d i fferent enviornmental conditions
such as temperature, pressure and ._id speed, in addition to signals
such as the received satellite beacon amplitude. Chapter 3 discusses the
design and operation of the analog input board.
A third board containing 8 kilobytes of additional Random Access
Memory (RAM) for the AIM-65 was designed but has not yet been :onstructed.
This board can provide expansion memory for user programs or data in
the system, although the present system does not require the use
of this board. If the need for additional RAM arises, this board can
be quickly constructed and implemented.
In addition to the boards on the expansion motherboard, several
other hardware devices support the AIM-65. A cassette deck is connected
2
to the cassette interface of the AIM-65. This cassette deck allows
the computer's operator to store programs or data on a standard
cassette tape. These data or programs can then be quickly reloaded
into the computer. The AIM-65 also provides a teletype (TTY) interface.
This allows a standard teletype to be used as an interactive I/O device.
The AIM-65 is also interfaced with a Pertec FT 8840A-9, 9-track
digital tare deck. The data which are acquired are stored on magnetic
tape using this deck. A special interface, called a Direct Memory
Access (DMA) controller, was designed to allow easy transfer of data
between the AIM-65 and the magnetic tape. Chapter 4 presents details
of the operation of the DMA controller and the digital tape deck.
C.	 The AIM-65
The hart of the data acquisition system is the AIM-65 micro-
computer. This computer was chosen for several reasons. It is very
i nexpensive, reliable and versatile. It is fairly well documented
and is easily expandable. The operation of the AIM-65 is the subject of
study in an undergraduate course at The Ohio State University. Some
of the futurE students working at the ElectroScience Lab will have
gained some experience with the AIM-65 through this course.
The AIM-65 contains many versatile features. The computer is
based on a Rockwell R6502 8-bit microprocessor. It has 4096 (4K) bytes
of RAM which can be used for program or data storage. The AIM-65's
addressing scheme permits expansion up to 64K bytes. The AIM-65
also has a monitor program in ROM (permanent memory). This monitor
program allows programs and data to be easily entered, debugged and
modified. It also has several powerful subroutines which can be used
in other programs to do several special functions. The microcomputer
has a full 54 key keyboard which allows the operator to control the
machine. A 20 character alpha-numeric display and thermal printer are
provided to allow the display and printout of messages and data.
Information can easily be trans erred to these output devices using
1-
	
the user-available subroutines mentioned above.
r
	
3
t
The AIM-65 also has ove very versatile integrated circuit (IC)
on board. This IC is the Rockwell R6522 Versatile Interface Adapter
(VIA). The terms VIA and 6522 are both used in this report to refer to
this IC. The 6522 has two 8 -bit bidirectional I/O ports. The computer
sees each port as an ordinary memory register.
To the outside world they look like standard TTL digital inputs
or outputs. These ports are programmable; that is, each can be
programmed to be either an input or an output port. The 6522 also has
two programmable counter/timers and several other useful features.
The 6522 is the basic building block used in the digital I/O board and
is treated in more detail in Chapter 2.
The AIM-65's manufacturer, Rockwell, has published several books
which provide quite extensive hardware and software support for the
computer. They are The AIM-65 User's Guide, The 86500 Hardware Manual,
The R6500 Programming Guide, and The Mee -65 Monitor Program listing.
These items are referenced as items [1], [2], [3], and [5] respectively,
in the bibliography.
120 DIGITAL
^1
/0 LINES	 ^vINPUT 	 ANAL OG
..^
7
	CON U1I ZONING
	
INPUT LINES
EOM IUIUN[-
[ KPX11UN
'	 •K MI	 DIGITAL	 ANALOG
I	 NAM
	 I/O	 INPUTS
i
tRPANSION
M OTN[R9OARD
CASSETTE	 AIM _ SS
TAPE BECK	 MICROCOMPUTER
	 PERM
28 CNAR ^`
	
MA	 TAP[
PRINTER	
CON1	 B[CK
S41t 't''	 ttt}t^t t 1 iI1l
.^.J	 Ls',111-
K[TYOARO
	
OPTIONAL TIT
XI/
Fil;ure 1-1	 Uata A(yuisition System
4
II.	 DIGITAL 1/0 SUBSYSTEM
A. Introduction
The digital input/output section of the data acquisition system
is based on the 6522 VIA integrated circuit. A circuit bcard containing 8
VIA's was designed and fabricated. Printed circuit techniques were used
for fabrication of the circuit board to allow easy duplication.
The digital I/O board is designed to be accessed quite easily
by the AIM-65. It is assumed that the reader is somewhat familiar with
the programming and use of the 6522. Extensive coverage of this subject
is given 'in [1] and [2].
B. Operation
Before we examine the programming of the VIA, we will see where
the `lIAs are located in the AI14-65's memory. The VIA supplied with the
computer occupies the addresses (memory locations) labeled A000 through
AOOF (in hexadecimal format). Each of the VIAs on the digital I/O board
also occupies 16 memcry locations. Thus the eight VIAs on the digital
I/O board require a total of 128 memory locations.
Figure 2-1(a) shows a map of the section of memory used by the
digital I/O board. This board occupies locations 8100 through 817F in
the AIM-65's memory. The block of memory which the board occupies can
be changed simply by changing the configuration of a set of switches
on the board. This allows several boards to be used in the system simul-
taneously by assigning each to a different memory block. The second
section of this chapter gives instructions for properly setting these
switches. For the following discussion we will assume that the switches
are set to be consistant with Figure 2-1.
Figure 2-I(b) shows the memory map of a typical VIA's organization.
The VIA (0), like all of the others, occupies 16 memory locations. The
name of each of these 16 registers is shown in the figure. Details of the
significance of each register can be found in Reference [1] and Reference
[2]. This chapter discusses only the most important registers and functions.
5
(a)	 (b)
8130 B PORT
AIM-65
A PORTMEMORY	 8131
8100 VIA #G 8132 OIR B
e1OF
8110
6uF VIA #1 8133 DIRA
6120
812E VIA #2 8134 TIL — L9 TIC-L
8130
613E VIA *3 8135 TIL-H & TIC-H
6140
814E VIA #4
8136 TIL-L
8150
81SF VIA #5 8137 TIL-H
6160
e16F VIA *6 8138 T2 L-L & T2C-L
6170
6nF V IA #7 8139 T2C-H
SRAIM-65
	
813A
MEMORY
8138 ACR
PCR813C
IFR813D
I ER813E
813F ORA
MSB	 LSB
8301 PAT PA6	 PAO A PORT
(c)
8303 7	 0 DIRA 0 INPUT l1 -+OUTPUT/
Figure C-I
	 (d) Par tial AIM-65 Memory Map
1, b) Detailed Memory Map of VIA N3
(c) Detail of Port-Direction Register Relationship
6
The only mode of V.I.A. operation that we will deal with here is
the simple I/O port mode. Each V.I.A. has two 8-bit bidirectional I/O
ports. The computer sees each of these ports as if it were an ordinary
memory register. To the outside world, the ports each look like a
set of 8 standard logic (TTL) gates. Each port can be designated as
either an input port or an output port. In fact, each of the eight
bits within a port can be programmed to be either an input bit or an
output bit. Our programming, however, will be much easier if we
designate the bits within a particular port to be all inputs or all
outputs.
The next concept we must understand is how to designate
(or program) a particular port to be an input port or an output
port. From Figure 2-1 we see that the two I/O ports in the V.I.A. are
labled "A port" and "B port". In V.I.A. #3 we see that they are located
at locations 8131 and 8130 respectively. Locations 8133 and 8132
are labled DIRA (for DIRection of A port) and DIRB respectively.
These two 8-bit registers are called direction registers. Each bit
in a direction register corresponds with a bit in its associated port.
Thus, by writing the proper bits into a direction register we can
define each bit in the associated port to be either an input or an
output.
The details of the correspondance between a typical port and
direction register is shown in Figure 2-1(c). A logical 1 in a direction
register bit makes the corresponding port bit an output. A logical 0
in a direction register bit makes the corresponding port bit an input.
Thus, if we wanted the A port in V.I.A. #3 to be an output port and
the B port to be an input port we might use the following sequence
of instructions
LDA #FF	 ;A*411111111)
STA 8133
	 ;DIRA- A
..	
LDA #00
	 ;A4-(00000000)
STA 8132	 ;DIRBf A
7
a
E.
These instructions would typically be placed at the very beginning of a
program as part of the initialization procedure. More examples of
V.I.A. programming are given in Chapter 8 of Reference [1].
Now that we have given our ports direction we will discuss the
passing of data between the computer and the outside world through the
port. The contents of our output port (A port) are controlled by
writing into location 8131. Writing a logic 1 into a bit in 8131
causes the corresponding output bit to go to the logic 1 state (+3VDC).
A logic 0 written in this same A port bit causes a logic 0 (=0V) to
appear on the corresponding output port bit. Thus, to make all of our
A port bits go to the logic 0 state, a typical program segment might
look like:
LDA #00
	
;A +(00000000)
STA 8131	 ;APort F A
The B Port is our input register and it can be read by a simple
LDA 8130 instruction. If any input is at a potential greater than 2
volts, a logical 1 will be found in the corresponding port location
when the port is read.
Each pair of I/O ports can be accessed by the outside world
through a 20-pin connector. One such connector is located next to
each 6522 I.C. Connector pin assignments arP shown in Figure 2-3.
Each V.I.A. output is capable of driving one standard TTL load. The
B Port outputs have a higher current sourcing ability which allows them
the capability of driving a Darlington transistor pair.
There are two control lines for each port. These lines (CA1,CA2
for the A port and CBI, CB2 for the B Port) can be used for some of the
more advanced features of the 6522 (such as handshaking or interrupt
control). Each of the 20 pin connectors has two spare pins (pins #10 and
#11). These spare pins can be jumpered to two of the control lines if
the user desires external access for these lines.
8
it.
C.	 Hardware Details
Standard address decoding techniques are used to select the
digital I/O board. Some preliminary decoding of the address bus
is done internally by the AIM-65. Additional decoding is done on the
digital I/O board. This decoding is done by comparing five address
bus bits with the output of a set of five switches. Setting the
configuration of these switches allows the user to select a particular
memory range for each board. When it is determined that a particular
L,oard has been selected, an additional decoder on that board selects
one of the eight V.I.A.'s. Details of this decoding and other aspects
of the hardware configuration of the digital I/O section are presented
in this section.
A schematic diagram of a V.I.A. board is shown in Figure 2-2.
The AIM-65 has a 16-bit address bus which is capable of addressing
65,536 (2 
16 ) 
memory locations. The four most significant bits of this
bus (A15, A14, A13, Al2) are internally decoded by the AIM-65. The
output of this internal decoder which interests us is the one labled
r$ in Figure 2-2. This line is normally at the logic 1 state. It
only assumes the logic 0 state when an address between 8000 and 8FFF
appears on the address bus (i.e. during a read or write operation to
any memory location between 8000 and 8FFF).
The CS$ line and the five next most significant address lines
(All, AID, A9, A8, and A7) are connected to the input of a 6-hit
magnitude comparator. This comparator is composed of two casca6ed
74LS85 4-bit comparators (Z 1 and Z2 ). The address lines mentioned
above are connected to the A inputs of the comparators and the B
inputs are connected to switches Sl-S6. These switches allow each
B input to be set to either the logic 1 or the logic 0 state. When
one of these swithches is in the "ON" position, the corresponding B
input is grounded (logic 0). The same switch in the "OFF" position
causes the B input to be pulled up to +5VDC (logic 1). Thus by
setting S1-S6, we can change the address range for which the
comparator's output will be active. Table 2-1 gives a summary of the
possible address ranges and the necessary switch configurations for
9
STA 8131
10 t
proper operation in each range.
When an address in the selected range appears on the address bus,
the comparator's output becomes active (pin 6 of Z 2 assumes a logic 1
state). This enables a 1 of 8 decoder, Z
...
 When Z3 is enabled, it
selects one of the eight V.I.A.s. The M.A. selected depends on the
status of the select inputs to Z 3 06, A5, and A4). An example will
be presented shortly which will clarify this address decoding process.
Before the address decoding example is presented, a few words
should be said about the 6522 I.C. itself. Figure 2-3 is a schematic
diagram showing the connection details of a typical 6522.
Several control signals from the AIM-65's control bus (SYS R/W, 02,
Imo, REM) and data bus (DB0-DB7) are connected to every V.I.A. These
lines are used for control and data transfer purposes. The V.I.A. will
only respond to signals on these buses when its CS line is low. This
CS line is connected to an output of Z 3 (the 1 of 8 decoder). Thus,
when a particular V.I.A. is selected by the address decoding process
(mentioned above), it becomes able to communicate with the computer
through the control and data buses.
The four remaining address bus lines, A3, A2, Al, and A0, are
connected to RS3, RS2, RS1, and RS0 of each V.I.A. (the RS stands for
Register Select). These four lines select one of the M .A.'s 16
internal registers. A data word can then be transferred to or
from the register on the data bus.
Now, the promised addressing example will be presented. Let's
first suppose that all of the address selection switches except S5
are closed ( ON position). Referring to Table 2-1, we see that this
sets our address range to 8100-817F.
We can verify this by examining the state of all of the logic
elements when we try to read from (or write to) a location in this range.
Let's suppose the computer was writing to the A port of V.I.A. #3. The
program step exeeutini this would be (see Section 2B):
	
..
n v
'p
Switch
Corresponding Bit
I
f	 ,<I
I
I
I
TABLE 2-1
Switch and
Corresponding	 Bit
S S S S S S
Address RangeCS8 H
0 0 0 0 0 0 8000-807F
0 0 0 0 0 1 8080-80FF
0 0 0 0 1 0 8100-817F
0 0 0 0 1 1 8180-81FF
0 0 0 1 0 0 8200-827F
0 0 0 1 0 1 8280-82FF
0 0 0 1 1 0 8300-837F
0 0 0 1 1 1 8380-83FF
0 0 1 0 0 0 8400-847F
0 0 1 0 0 1 8480-84FF
0 0 1 0 1 0 8500-857F
0 0 1 0 1 1 8580-85FF
0 0 1 1 0 0 8600-867F
0 0 1 1 0 1 8680-86FF
0 3 1 1 1 0 8700-877F
0 0 1 1 1 1 8780-87FF
0 1 0 0 0 0 8800-887F
0 1 0 0 0 1 8880-88FF
0 1 0 0 1 0 8900-897F
0 1 0 0 1 1 8980-89FF
0 1 0 1 0 0 8A00-8A7F
0 1 0 1 0 1 8A80-8AFF
0 1 0 1 1 0 8600-867F
0 1 0 1 1 1 8680-86FF
0 1 1 0 0 0 8000-8C7F
0 1 1 0 0 1 8C80-8CFF
0 1 1 0 1 0 8D00-8D7F
0 1 1 0 1 1 8080-8DFF
0 1 1 J 0 0 8E00-8E7F
0 1 1 1 0 1 8E80-8EFF
0 1 1 1 1 0 8F00-8F7F
0 1 1 1 1 1 8F80-8FFF
1 X X I X	 I X	 I X	 I None
F
11
L - =a
¢ 13 m
c	 o<Q	 y O
m
o^ a much
40 Z W	 IH
u
- p
<
Y a
a
I2 ( W
Z
m W 1[W WW Z1 4cZ Q y - O F
^xC ^OOZOW u o4 W U
j to^ 1
i^J ^4 hZ10 m
Q
F^
Z4
4 ¢ 16 1  IA mD
Y	 g
V!	 m
J	 H V1
K j O mF mZ
O
u
If •_ /^ N_
in VI
1p N
2¢ D
_ow
<v
bL
RS
Q
'17
d
N
1
N
41L
U
pr-
>	 y
aY
ti
0
h -	 O	 O
t
L_	
i
1.7
ia 
ae
C ^ W
^ W ^
1112- al ol r. ol in j el on j a
1•	
m
d
w 0 n
a	 aoa.
a on
a
1y
a
Q O
n^
a
m4 a a v
o
Ii 1=9	 Q N V
M CU
—S ^ 117 N
>	
«) vO	 cN	 —
O- wn ♦ 01rP00000000
13	 p N\ N^ WCam- rr
ONK NR
NiAjr
1+fNC NIV NUU
s
i
s
(	 1
N m
m
0
c N
Y r-
N
_ N h
Q Q Q
h
f•
C
O ^ ^
a
a
b)
O ~
^) O
V
10 0Icy Icy O CO
Om ^0000 ' Uu 4Q d
1n
1N
^v
T
•r
u
13
Thus, 8131 would he the address appearing on the address bus. The
address bus state would be:
A 15 A14 A13 A l2 A11 A 10 A9 A8 A7 A6 A5 A4 A3 A2 
Al 
A0
1 0 0 0 0 0 0 1 0 0 1 1 0 0 0 1
8	 1	 3	 1
Since (A15, A14, A13, Al2) = (1,0 0 0,0), MS will be at logic
0. Now (M. A W A10' A99 A8 , A7 ) _ (0,0.0,0,1,0), and switches
(S i , S2 , S3 , S4 , S5 , S6 ) also equal (0,0,0,0,1,0), thus the same pattern of
1's and 0's appears at both the A and B inputs of the comparator. The
A=B output (pin 6, Z2), will go to the logic 1 state. This enables Z3.
Now, the C,B, and A inputs to Z3 are set to 0, 1, and 1 respectively, (i.e.
the state of A6 . A5 , and A4
 respectively). Since Z3 is enabled and
(C,B,A) = (0.1,1), the Y3 output goes low (logic 0); thus, the LT line
of V.I.A. #3 goes low and V.I.A. #3 is enabled. Since (A3, A2, Al, A0)=
(RS3, RS2, RS1, RS0)=(0,0,0,1)=1 (Hex), the #1 register in V.I.A. #3
(the A port) is selected.
Now, since the V.I.A. sees that we have selected the A port, it
looks at the R/W line. Since this line is in the write (logic 0)
state, the data on the data bus (which equals the accumulator since
we are doing an STA operation) is written into the A Port and our
operation is complete.
There are several other functions which the 6522 V.I.A. can perform
and the versatility of the I.C. cannot be stressed enough. In this
chapter, we've seen how to accomplish some very simple digital I/O
operations. Several additional programming and hardware details are
presented in the Rockwell literature and the interested reader is
encouraged to examine these sources.
Additional information on the digital I/O subsystem, including
the PC board layout, is given in the appendices.
14
III.	 A14ALOG INPUT SUBSYSTEM
A. Introduction
The analog input section of the data acquisition system is
described in this chapter. This section (or subsystem) allows the
microprocessor to acquire data derived from analog quantities. Such
analog signals might typically be the outputs of a beacon receiver or
temperature, pressure, or wind speed transducers.
The analog input section consists of 16 analog to digital (A/D)
converters and the hardware necessary to interface them with the computer
and the analog signals. Analog Devices AD7574JN monolithic A/D con-
verters were chosen for use in the analog input section. Sixteen such
A/D converters are contained on the A/D board which can be inserted
into any slot on the AIM-65 expansion motherboard. The A07574JN was
chosen because it is inexpensive, readily available, and can be easily
interfaced with the microcomputer system.
Another board provides input conditioning for each A/D converter
on the A/D board. The conditioning board provides input buffering and
level shifting for the analog input signals before they are applied to
the A/D converters. Details of both the A/D board and the analog
conditioning board are given in the third section of this chapter.
B. Operation and Calibration
This section presents the operational details of the analog
input section. The basics of A/D conversion are presented and soft-
details are given. The final portion of this section gives a suggested
calibration procedure.
The AD7574JN is an 8-bit Analog to Digital Converter (ADC). It
converts an analog voltage between 0V and 10V to a digital number between
0 and 255 (base 10). This digital number is directly proportional
to the magnitude of the analog input voltage. Thus, the system resolution
is:
Vmax - Vmin
	
10V - 0V
_	 _ .039V
# of digital intervals
	
255
Resolution =
fi4
tieI	 15
t
E_.
Most of the analog signals presented to the data acquisition
system are in the -5V to +5V range. Since the AD7574 requires an
input in the OV to 10V range, the analog signals must be shifted up by
5V to make them compatible with the ADC. A board called the analog
conditioning board provides this 5 volt level shift. This board is
located in a chassis, separate from the A/0 board. The analog condi-
tioning board contains 16 identical circuits, each with the transfer
function:
Vout = V
in + 5V.
A few of the analog signals are in the 0V to 5V range. By
changing the configuration of a few jumpers on a particular analog
conditioning circuit, the circuit's transfer function can be changed to
Vout 3 2(V in).
This allows the OV to +5V input range to become transformed into our
desired 0V to +10V range. The next section of this chapter gives the
details for setting the jumpers to provide the desired input range.
The analog signals are brought into the analog input system through
BNC connectors located in the back of the chasis which contains the
analog conditioning board. These connectors are labled with the channel
numbers 0 through	 In this system, the word channel is used to
describe one A/D converter, its conditioning circuit, and the cable
which connects them.
Each A/D converter occupies one location in the AIM-65's memory.
The addressing scheme for the ADCs is quite simple. The first three
digits in the address are always 8B0. The fourth digit is the channel
number. Thus, ADC #0 is addressed by 8000, ADC #1 by 8001, etc.,
up to 80OF for ADC #F (#15 in base 10).
Before an A/D conversion can be made, the ADC must be reset.
This is done simply by "reading" the ADC. For example, ADC #9 can
be reset by the instruction:
16
LDA 8009.
Each ADC automatically resets itself after it performs a conversion.
Thus, "manual" resetting only needs to be done once (before the first
conversion). This manual resetting is usually done in the initialization
routine in the user's program.
An A/D conversion 1s initiated by "writing" to the ADC's address.
The conversion takes approximately 15us. When the conversion is
complete, the digital result can be transferred to the accumulator
by "reading" the ADC. Thus, a program segment which will perform an
A/D conversion on ADC N0 and transfer the result to the accumulator
might look like:
LDA 8000 Reset converter(During initialization
procedure.)
STA 8000
NOP
NOP
NOP
NOP
NOP
NOP
NOP
NOP
LDA 800
Start conversion
A - Result
Delay 16us (2us/NOP)
The calibration procedure for the ADC's is quite straightforward.
The easiest method to examine the outputs of the ADC's is to use some
of the AIM-65's user s!:L-outines to display them. A program which
will display the outpur :;f an ADC on the AIM-65's display is given below.
The letter X is used in place of the channel number (0-F) of the ADC to
be calibrated.
t
17
LDA 8PDX Reset ADC
Begin:	 STA 80OX Start Conversion
NOP
NOP
NOP Delay
NOP
NOP
JSR EB44 Clear Display
LDA 80OX A	 Conversion Result
JSR EA46 Display +,A
JMP begin Jump Back to Beginning
When this program is run, a 2-digit hexadecimal number (which is
the 8-bit output of the ADC) will appear on the display.
The GAIN and OFFSET ADJ. of the analog conditioning circuit
being calibrated must be adjusted for proper operation. The procedure
for proper adjustment is given below:
1) With O.OV applied to the input to the channel, adjust the
OFFSET ADJ. potentiometer until the number shown on the display is 80
or flickers between 7F and 80.
2) Apply +5.OV to the channel input. Adjust the GAIN potentio-
meter until the number shown on the display is FF or flickers between
FE and FF.
3) Repeat the above 2 steps until no trimming is required to get
the desired output with either OV or +5V applied to the input.
This completes the operational description of the analog input
section
C.	 Hardware Details
The AU7574JN analog to digital converter requires very little
supporting hardware. The basic ADC circuit is shown in Figure 3-1.
This circuit is duplicated 16 times on the A/D board. The necessary
address decoding and data buffering is also done on this board.
An external resistor and capacitor connected to the CLK input
(pin 17) of the ADC determine the internal clock rate and, thus, the A/D
18
k
3
u
r ^_
5 .
conversion time. Details of the selection criteria for the R-C combina-
tion can be found in the manufacturer's data sheet. The values selected
(11=1251M. C =100pF) yield a conversion time of about 16 microseconds.
This is the minimum conversion time recommended by the manufacturer.
The ADC is selected (enabled) when a logic 0 appears at the
Input (pin 16). The state of the V input (pin 15) determines what
function the I.C. will perform once it is selected. A conversion is
started when a logic 0 pulse is applied to tT while AU is at logic 1.
When the conversion is complete, the result can be read by pulling both
a and RD to logic 0. This enables the tri-state buffered data outputs
(pins 6-13) which are directly connected to the microcomputer's data bus.
The AD7574JN requires a reference voltage (Vref) of -10V. This
reference voltage is generated by the reference supply shown in Figure 3-2.
An Analog Devices AD580 provides a precision voltage of +10 volts. A
unity gain inverter using a CA3140 op-amp follows the AD580. This
inverts the +10.OV into our desired -10.OV reference. A pnp transistor
placed in the inverter's feedback loop allows the circuit to tolerate
substantial loading (approx. 100M). This reference supply circuit
is 'located on the A/D board.
The AD7574JN accepts an analog input in the O.OV to 10.OV range.
It generates an 8-bit number proportional to this input. The analog
input is applied to pin 4 of the I.C.
Since many of the existing analog signals at the Satellite
Communications Facility are in the -5V to +5V range, a conditioning
circuit is required to shift each analog signal up by 5V. The analog
conditioning board contains 16 such conditioning circuits. Figure 3-3
shows the schematic diagram of one of the 16 identical conditioning
circuits. The first stage is a simple unity gain inverter. An offset
adjust voltage is connected to the non-inverting input of IC1A to
allow the elimination of any offset errors introduced in the channel.
The value of R 3 was chosen to minimize offset errors caused by the
op-amp's input bias currents. Its value of 5.11M is determined by the
equation:
(R 1 // R2 ) = R3 //(R4 // R5)
I
	 19
l	 F
•5v
R	 125 K
1	 1710OpF	 r
R12	 Vcc	 CLK
VREF' -Il1V
2
VREFIKa 3 BINARY OFFSET
4 ANALOG INPUT
ANALOGINPUT
18 DIG. GNDO +. OV
(SEE FIG.3-3) 5 ANALOG GND 6
_ DB7 DATA
	
TO AIM-65CHIP OUTPUT	 DATA BUSSELECT 15 _ OBO 13FROM CS
DECODER
R/ - LINE 15 RD
AD7574JN
Figure 3-1	 AD7574JN	 Configuration
10Kn
•I5V
•I5V
AD580 'IOV
	 —
IOKA CA3140 6	 L
•	 VAEF — IOV
5 Ktl
Figure 3-2	 Reference Supply
—I5V
?n
21
M1
M
CJL
LL.
o:o
J ^Qao
z ~ ^-
aoo
ct
C-K N
3q
	
O >	 >N m m Q N
ClOle
 04	 ♦ 	 V	 1
	
pro	 1
N Y O	 Y r'v
-	 ^ O 10 Y	
O_^O
	
N	 >	 >
	
3	 N	 N
>	 t	 1
O	
>	 Cl Cl
	
CO
	
1	 V O N h Y
ti am N M Q R
N Y
O
1 
V
10	 rt1
	
co	 F	 M CS
	
Y	
W Y
	
0	 N
U.
> N > N
C)-n3 ♦ 3
IL e oO 3
O
i	 O 3
7
Vi
U
CTC
O
•r
4J
C
OU
v+
0
C
d
1If this equation is approximately satisfied, any voltages
caused by input bias currents will appear as common mode signals to
the op-amp and will therefore be suppressed. The transfer function of
the first stage is given by:
*
V1 
-Vin + Voffset	 (1)
The second stage of the analog conditioning circuit is an
inverting amplifier with the transfer function:
Vo = -V 1 + 5V	 (2)
Combining equations (1) and (2) gives us the overall transfer function
of the conditioning circuit:
Vo	
-(-Vin + V offset ) + 5V
	
(3)
or
Vo = V in + 5V - Voffset
Since a few analog signals with limits of OV to 5V were antici-
pated, jumpers w  and w2 were added to the conditioning circuit.
Removing these jumpers provides a second stage transfer function of:
Vo
 = -2V1
	(4)
Combining equations (1) and (4) yields the overall conditioning circuit
transfer function:
Vo
 = 2Vin - 2Voffset
Each of the op-amps in the conditioning circuit requires several
* Note that 
Voffset 
can be either positive or negative.
22
resistors which meet at the op-amp's inverting input. Single in-line
resistor networks are used here since they are small, inexpensive, and
track well with varying temperature.
Potentiometer R11 provides a gain adjustment (GAIN ADJ.) control.
This potentiometer, in conjunction with resistor R12 in Figure 3-1
allows the ADC's input gain to be adjusted during the calibration
procedure.
The output of each analog conditioning circuit is brought to the
corresponding ADC through a short length of sub-miniature coaxial cable.
A disconnect for each cable is provided on the conditioning board.
The A/D board occupies a slot in the AIM-65 expansion motherboard.
The interfacing between the ADC's and the AIM-65 buses is done on the
A/D board. The address decoding techniques used to select the ADCs
are very similar to those used in the digital I/O boards. Therefore,
the discussion of this decoding will not be quite as detailed as
that presented for the digital I/O boards in Chapter 2.
Figure 3-4 shows a schematic diagram of the ADC decoding
system. Two 4-bit magnitude comparators do the preliminary decoding.
The A inputs to the comparators examine address lines A 11-A4 . The
B inputs are all grounded. The B inputs corresponding to 
A11' A10, and
A  are grounded by jumper wires on the A/D board. By jumpering one or
more of these B inputs to +5V (logic 1), the A/D boards address range
can be changed. This allows multiple A/D boards to be used, each
with a unique address range.
INPUT CONFIGURATION* 	 ADDRESS RANGE OF A/D BOARD
C	 B	 A
0	 0	 0	 8000 - 80OF
0	 0	 1	 8200 - 820F
0	 1	 0	 8400 - 840E
0	 1	 1	 8600 - 860F
1	 0	 0	 8800 - 88OF
1	 0	 1	 8A00 - 8AOF
1	 1	 0	 8C00 - 8COF
"	 1	 1	 1	 8E00 - 8EOF
6=OVo ts, =+ Vol is
TABLE 3-1
23
The A=B output of this 8-bit comparator is connected to the G1
"enable" input on each of two 74LS138 1 of 8 decoders (I.C. 3 and I.C. 4).
is connected to the GSA "enable" input of eac" decoder. A3 is
connected to the GFB "enable" input of I.C. 3. A3 is inverted before it
is applied to the G2B "enable" input of I.C.4 . A particular decoder
is only enabled when G1 is at logic 1, and both GSA and GN are at
logic 0. When one of the two decoders is enabled, it selects one of
eight ADCs by pulling the ADC's CT line to logic 0.
TABLE 3-1 lists the address range corresponding to each possible
configuration of the three jumper wires mentioned above. Details of
the decoding operation might be more thoroughly understood if a
decoding example similar to the one given in Chapter 2 is worked. Since
the procedure is so similar, such an example will not be presented
here but the results shown in TABLE 3-1 can easily be verified.
As mentioned in the beginning of this section, each ADC has
only two control lines, CB and 1U. The address decoders ( just discussed)
control the ADCs' CS (Chip Select) lines. The RD line should be at
logic 0 during a "read" operation, and logic 1 during a "write" (start
conversion) operation. The microcomputer's R/w line has these desired
states and therefore it is directly connected to the RD pin of each
ADC. Thus, when the computer performs a STA (write) operation to an
ADC, the C^ line of that ADC is pulled to logic 0, while the RD line
is at logic 1. This causes a conversion to start in this ADC.
When the computer "reads" an ADC (an LDA operation), both the
tT and RD lines of that ADC are set to the logic 0 state. This enables
the data outputs of the ADC. The 8-bit output is buffered by a 74LS245
octal line transceiver (I.C. 5) before being applied to the AIM-65 data
bus. A few simple logic gates (I.C. 6) are used to insure that the
transceiver isolates the ADCs from the data bus when no ADC is being read.
If we look at the programming examples given in the previous
section, we can now analyze how the circuit shown in Figure 3-4 operates.
Let us first assume that the C,B, and A inputs to I.C. 1 are grounded.
TABLE 3-1 tells us that our A/D board is addressed by 8000 - 800F.
Let's suppose we wish ADC #1 to perform a conversion. Our first program
24
•5V
3
A•8
IN
10
74LS85
All 0 4 BIT1 COMP !—Cc) HARDWIRED
-11 -_%	 TO SELECT
A; I IN	 IN 4	 ADDRESS
IS i 	RANGEAll
ICI
A n BOUT Volt
6 -IOV
3
As8
IN
IO 74LS8S 9A, ^ 11A, °-- I A	 8
1
4A• IN	 IN
A 4 0 IS
1
A so ---,
I
I C 2
A•9
4	 5
L'5
6	 74LS136 IS
G^
14
G:e	 ENABLE 131 7400
	
1 C 4	 G
=A 12 TO ADC #2
6 3	 OUT II 4
10?	 SELECT *y
JJJJ 7 *6
DECOD *7
C58 IC3
74 L 5138
6 G I	 TO ADC *8
S Gie	 ENABLE 14.0 aM9
4 Gz ^ 12 44 A
3	 OUT 11 *L
A.
2	
SELECT 01 * D
Ao I	 JJJ 9 *E
j DECOR
IC4
R/W
ADC M 0
16 CS
_LS 0AIN
o; o,
2
1 KA Vm[rAD 7574
ADC * 1
16 CS
	 A	 4 ANALCIS Rb
	 ,^ 7-13 INPUT
2
I KA
	
vital,
AD7574
•
•
•
ADC * f
1
IS5 CS	 A^e ,4 ANALOG1M7-13 INPUT*15
2 DO-D7
V 119I KA
AD7574
INPUT
7400	 74LS245
iC6
IS	 1ye, ENABLE L 
DIR.	
.ATA
14	 1 N
OUT ICSTO AIM-65 8	 8 SIT 8USDATA 6,,3
Figure 3-4	 A/D Converter System
25
step would be a STA 8001 operation. When 8001 appears on the address
bus, CM is at logic 0, our comparator's output (pin 6, I.C. 2) is at
logic 1 and A3 is at logic 0. Thus I.C. 3 is enabled. Since (A 2 , A19 AD)
= (0,0,1), pin 14 of I.C. 3 (and therefore CS-pin 16 of ADC #1) goes to
logic 0. During a STA operation, R/w is a logic 1 and an A/D conversion
is started on ADC ni.
Sixteen microseconds later the A/D conversion is complete. Our
LDA 8001 instruction causes 8001 to again appear on the address bus.
ADC #1 is again selected; but this time its RD pin is at logic 0. The
8-bit result of the conversion is presented to I.C. 5 (our output buffer).
Since pin 6 of I.C. 2 is high, and the VW_ line is low, the enable line
to I.C. 5 is pulled to logic 0 and our data is transferred to the com-
puter via the data bus.
Additional details of the analog input subsystem including PC
board layouts are given in the appendices.
The entire analog input section of the data aquisition system
has been presented in this chapter. We have seen how to calibrate
and operate the ADCs under computer control. We have also seen the
theory behind the operation of the controlling logic. This completes
the discussion of the main data input sections of the data acquisition
system and prepares us for the discussion of the DMA controller which
will allow us to store our newly acquired data on magnetic tape.
Ii-
26
IV.	 DMA CONTROLLER AND TAPE CONTROL
A. Introduction
The Direct Memory Access (DMA) Controller described in this
Chapter serves as an interface between the AIM-65 and the Pertec
FT8840A-9 nine track digital tape recorder. Direct memory access is
necessary in this syste:- because the AIM-65 cannot supply data directly
from its memory as fast s the tape deck requests it. The DMA controller
acts as a buffer into which the computer can store data. When a substan-
tial quantity of data has been stored, the contents of the buffer can
be quickly dumped to the tape Jeck. The DMA Controller can also be
used to read a data record from the tape deck and transfer it to the
computer.
A block diagram of the DMA Controller is shown in Figure 4-1(a). The
heart of the DMA Controller is 4096 bytes of static Random Access Memory
(RAM). This memory acts as the data buffer which stores the data to be
transferred to the tape. The controller also contains circuitry which
controls this memory and allows data to be transferred to the tape deck.
The controller is constructed on an Augat wire-wrap board. A
wire list for this board is presented in Appendix B.
This chapter first presents some fundamentals of the operation of
the Pertec FT8840A-9 digital tape deck. Understanding these fundamentals
will make the DMA Controller's operational theory much easier to under-
stand. Some examples of tape deck operations are presented with flow
diagrams and program listings of the programs which perform the opera-
tions. The final section of this chapter presents the hardware details
of the DMA Controller.
B. Tape Control
The Pertec tape deck has two primary components, the tape trans-
port and the microformatter. The tape transport consists of the elec-
tronic and servomechanical systems which cause tape motion and the
transfer of data to and from the tape. The microformatter is a device
3	
which acts as an interface between the tape transport and the controller
(the DMA Controller in this case.)
i
^_	
27
CONTROL
IGNALS	 DMA CONTROL
FROM I	 LOGIC
AIM 65 VIAI
	
!
I 	 4KX8 RAM
I
INPUT	 OUTPUT
AIM 65 ) BUFFER	 BUFFER ISTAT US, DATA
	
ADDRESS'	 ADR.	 BYTE	 19 CONTROL9 DATA	 COUNTER	 COUNTER	 BUSES FROM
BUSES
	 (PERTEC
Figure 4-1(a)
	 DMA Controller Block Diaqram
28
O yVj
^ G	 p
r	 ;0	 g^W	 ^<
l^ fl	 ^^ M ,^^	 V	 1 2 19 2	 1 H hLLl>	 ~^>	 Zm ♦ 	 0m	
-00<	 < <O	 «<	 t
u
ml
E
aLm
.o
Q
O
m
V
40
r10N
r
O
L
CO
t..1
dV
1
L
pf
4L
29
Figure 4-1(b) shows a detailed block diagram of the DMA Controller.
Each block in this diagram has a schematic diagram and discussion ex-
plaining it in the final section of this chapter. This diagram shows
how all of the DMA Controller's subsystems are integrated.
Figure 4-1(b) also shows the .ontrol signals which connect the
microformatter and the controller. These signals fall into the following
three categories: microformatter to controller signals, controller
to microformatter signals, and tape status signals. The tape deck's
operating manual, [4], gives a description of each of these signals. A
brief summary of the most important signals is given in this section.
Note that the microformatter uses negative logic. Thus, a line is
considered active (or true) when it is in the logic 0 state.
We will first examine the controller to microformatter signals.
Those which concern us are [4]:
IFEN-FORMATTER ENABLE
- This signal, when low (logic 0) clears the microformatter
and enables it to accept a command from the controller.
IWRT-WRITE/READ
- This signal specifies the mode of the system.
Logic 0 = Write
Logic 1 = Read
IREV-REVERSE/FORWARD
- This signal specifies forward or reverse tape motion.
Logic 0 - Reverse
Logic 1 = Forward
IWFM-WRITE FILE MARK
- This pulse causes a Write File Mark to be written on the
tape if 1WRT is also low.
IERASE-ERASE
- This signal, when low, cuases a length of tape to be
erased if IWRT is low. If IWRT is high (logic 1) a
record will be spaced over instead of being erased.
30
ILWD-LAST WORD
During a write operation this pulse is used to tell the
microformatter that the word which is being sent from the
controller is the last word in the record.
IGO-INITIATE COMMAND
- This pulse initiates a command. It is given to the micro-
formatter after all of the necessary input signals to the
microformatter have been set to their desired states.
IWO-IW7-WRITE DATA LINES
- These are the lines on which the data to be written are
transferred to the microformatter.
The tape deck can perform many tape operations. Table 4-1 shows
the operations with which we are most concerned. The operations listed
in Table 4-1 are self-explanatory and details can be found in the Pertec
Microformatter Addendum [4]. A tape operation is initiated by setting
the control lines for the desired operation and then sending the IGO
pulse.
In addition to the controller to microformatter signals, several
microformatter to controller signals also exist. These signals allow
the computer to monitor the tape deck as it performs an operation. The
most important of these microfermatter to controller signals are [4]:
IFBY-FORMATTER BUSY
- This line is low between the time of the IGO command
and the time at which tape motion ceases after the excecu-
tion of a command.
IHER-HARD ERROR
- This is a pulse which indicates that a parity error has
occurred during either a read or write operation.
IWSTR-WRITE STROBE
- This line is pulsed (to logic 0) each time a word (byte)
is written onto the tape.
31
TABLE 4-1 Microformatter Commands
Operations IREV IWRT IWFM IERASE
READ FORWARD 1 1 1 1
READ REVERSE 0 1 1 1
WRITE 1 1 1
WRITE FILE MARK 1 0 1
SPACE FORWARD 1 1 1 0
SPACE REVERSE 0 1 1 0
FILE MARK SEARCH FORWARD 1 1 0 0
FILE MARK SEARCH REVERSE 0 1 0 0
TABLE 4-2 - AIM-65 VIA Port Assignment
Port Address	 Bit	 Function
0 IFBY
1 IDBY
2 ICCG
AOOO 3 LWD
4 INK
5 -
6 IRSTR
7 IGO
0 DC
1 IWRT
2 IREV
A001 3 IWFM
4 IREW
5 IERASE
6 IOFL
7 IFEN
32
IRSTR-READ STROBE
- This line is pulsed each time a word is read from the
tape.
IFMK-FILE MARK
- This line is pulsed whenever the microformatter encoun-
ters a file mark.
IRO-IR7-READ DATA LINES
- These are the lines on which the data which are read
are transferred to the DMA controller.
So' eral of these control signals are connecter to the VIA on
the AIM-65 board. The port assignments for this VIA are given in Table
4-2. The signals shown in Table 4-2 which were not mentioned above are
discussed in the Pertec Microformatter Addendum [4]. These signals are
not used in the elementary tape operations which we will discuss. They
are, however, connected to the AIM-65 to allow the excecution of some
commands which are not presented in this chapter.
Most of the lines shown in Table 4-2 have been mentioned already;
but there are a few which must be explained before the tape deck operat-
ing procedures can be presented. The most important of these signals is
the line labled DMT. This line determines in which of two modes the
DMA controller will operate. When this line is in the logic 1 state the
DMA controller is connected to the AIM-65 and isolated (by tri-state
buffers) from the tape deck. In this mode the 4096 bytes of memory on
the DMA controller board can be accessed by the computer. This memory
occupies the address range 9000-9FFF (see memory map in Appendix A).
When the DW line is in the logic 0 state, the computer is
isolated from the DMA memory (again by tri-state buffers) and the tape
deck is connected to this memory. It is in this mode that data
are transferred between the magnetic tape and the DMA controller. Since
the DW line can only be in one of the two states at a particular instant,
it is impossible fcr both the computer and the tape deck to have control
of the DMA memory at the same time.
s
33
3 '
E
The DMA memory occupies locations 9000 through 9FFF in the
AIM-65's memory map. Several other devices, which occupy addresses
in the 8300 through 8307 range, are also located on the DMA controller
board. These devices include two 12-bit counters, two flip-flops which
the computer controls, and a register which contains the status signals
from the tape deck. These devices and the significance of their addres-
ses are explained as the need arises during the following discussion
of the DMA Controller's operation.
The DMA Controller can transfer the contents of any contiguous
block of its memory to the magnetic tape. To dump a block of memory
to the take, the starting address and block length must first be loaded
into the DMA controller. The DW line is then pulled to the logic 0
state (by writing a 0 bit into bit 0 of A001). The computer sets up and
starts the tape deck, waits for the write operation to be complete, and
then regains command of the DMA Controller by returning the DW line to
the logic 1 state.
The starting address is loaded into the DMA controller by
writing the address into the starting address counter. Since all of the
memory on the DMA controller board is in the 9000-9FFF range, the leading
9 need not be loaded into the counter. Only the last 3 hexadecimal
digits (12 bits) must be loaded. Since the AIM-65 is an 8-bit machine,
two operations must be performed to load all 12 bits into the counter.
Figure 4-2(d) shows the addresses and bit assignments for the starting
address counter. The 8 least significant bits are loaded into location
8300 and the 4 most significant bits are loaded into bit 3-bit 0 of
location 8301.
For convenience, the starting address is normally set to be the
first byte of memory, 9000. Thus (000) 16 should be loaded into the
starting address counter. This can simply be accomplished by the follow-
ing program segment:
LDA #00
	 A4-(00000000)
STA 8300	 Adr. Ctr.-Lo-A
STA 8301	 Adr. Ctr.-Hip-A
34
O^	
{i^	
00	
ui
	
{m^^
~ < ^ m m
m
.r ^••1 O^ r•1 01
r 4 < m
m
m Q
N N .-4 N r+
aUD4 4
m
M M .ti M •'+
mq C
co
u ¢ x x
L
^Oim C L
7 Npp ^ V
i.^ C L
U7 Lek
7 /0
N O V
1J V¢ x Vm x
N U
d	 Y
^aO+cm
n 	 N	 M
^o YD '° C m x
CIO
a x x
m I ¢ I x l m l x
0J S i t
.+ •r v •^ v v v
N
r LS.
S+
L W W
CA q L b L H F•
N¢ UY4 mJ
_
m2
NN
v m m ^ m
q	 CMD	 OMD	 00	 OMO
	
q	 e
L.N
4J
C S-
=  GJ
U C
N OH U
N
i N
a m
to M
r v
N1
i7
Cf
r
4.
35
The number of bytes to be dumped is then loaded into the byte
counter of the DMA controller. This is not quite as simple as the
address counter loading procedure. The byte counter is a 12-bit counter
which is incremented each time a data word is transferred to the tape
deck. When the counter reaches the all is state (FFF), it sends the
IWLD (last word) pulse to the microformatter. This causes the termi-
nation of the write operation.
Since the ILWD signal is sent when the counter reaches FFF, the
number loaded into the counter must be the difference between FFF and
the number of bytes to be dumped. Thus, we must load the counter with
the 2's complement of the .,umber of bytes to be dumped. The 2's
complement is easily calculated using the formula:
2's Complement = 1's Complement +1.
The 1's complement is obtained by simpl3 r ,^ placing each 1 in the number
with a 0 and vice versa. Thus if we want-:d to dump 1024 bytes we would
determine the number to be loaded into the byte counter by finding the
2's complement of 1024 (base 10):
(1024 ) Base 10 = (400) Base 16 = (010000000000)Base 2
the 1's complement of this number is given by:
0000 = (101111111111)
therefore, the 2's complement is given by:
(101 111111111) + 1 = (110000000000) = (C00)16
Thus, we must load C00 (hex) into the byte counter to dump 1024 bytes of
memcry to the tape. Figure 4-2(b) shows the addresses and bit assignments
of the byte counter. The 8 least significant bits of the number to be
loaded are written into location 8303 and the 4 most significant bits
are written into 8302. Thus, a program segment which will set our byte
counter to dump 1024 bytes of data is given by:
LDA #00
	 Aj-00000000
STA 8303	 BYTE CTR.-LO*A
LDA #0C	 A-90001100
STA 8302	 BYTE CTR. -Hi*A
36
When the byte counter reaches the all 1's state, it sends the
ILWD pulse to the tape deck and sets a flip-flop on the DMA controller
board. The output of this flip-flop, labled LWD, is connected to bit
3 of the AIM-65's input port (see Table 4-2). During a write operation,
the computer observes the LWD signal and waits for it to make the low
to high transition which signals the completion of the operation. This
LWD flip-flop must be manually reset before each write operation. This
is done by excecuting the instruction, STA 8305.
Before any tape operation is attempted, the computer must examine
several of the status lines which come from the tape deck. The status
lines with which we are concerned are [4]:
IRDY-READY
- This line only becomes a logic 0 when the microformatter
is ready to accept a command.
IONL-ON LINE
- This line is at the logic 0 state whenever the microfor-
matter is on line.
IFPT-FILE PROTECT
- This line is at the logic 0 state if the tape on the deck
has had its file protect ring removed.
ILDP-LOAD POINT
- This line is at the logic 0 state when the tape is at the
load point (beginning of tape).
IEOT-END OF TAPE
- This line is at the logic 0 state when the tape has been
advanced to its end.
IRWD-REWINDING
This line is at the logic 0 state while the tape is
rewinding.
IHER-HARD ERROR
A logic 0 pulse appears on this line whenever a word
with a parity error is written onto or read from the tape.
37
The computer can examine the state of each of these lines by
reading location 8307. Figure 4-3 shows how these status signals are
assigned to the various bits of register 83¢7. This register is called
the Status Input Register (SIR).
Bit 7 of the SIR is labled HER, not IHER. This is due to the
fact that, like the ILWD signal, the IHER signal is a short pulse (approx.
20 microseconds). To ensure that this pulse is observable to the compu-
ter, the IHER pulse, like the ILWD pulse is used to set a flip-flop.
It is the output of this flip-flop, labled HER, that is connected to the
SIR. This flip-flop is cleared by executing the operation, STA 8304.
Bit 7	 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit
HER	 - IRWD IEOT ILDP IFPT IONL IRDY
Figure 4-3 - Status It.,,ut Register
The status input register transfers data to the computer on the
data bus. Since the register is located on the DMA controller board,
the DPt line must be in the logic 1 state when the SIR is read.
A memory map summarizing all of the registers which affect DMA
operations is shown in Table 4-3. A complete memory map of the entire
data acquisition system is shown in Appendix A.
Now that the groundwork has been laid for tape operations, the
details will be explained with several examples. We will examine three
short programs which will perform these simple tape operation -3: 1) write
a record, 2) space back one record, 3) read a record. A flow diagram
and program listing will be presented for each of these programs.
Before we do any operations we must set the directions of the
AIM-65's I/O ports so they will be in agreement with the directions
shown in Table 4-2. We should also load a logic 1 into each output
bit so no tape command is inadvertantly given to the microformatter.
38
TABLE 4-3 - DMA CONTROLLER MEMORY MAP
ADDRESS	 FUNCTION
8300 ADR. CTR. - LO
8.101 ADR. CTR. - HI
8302 BYTE CTR. - HI
8303 BYTE CTR. - LO
8304 LWD flip-flop CLR
8305 HER flip-flop CLR
8307 Status Input Reg.	 (Figure 4-3)
9000
y
DMA memory
(4K x 8)
9FFF
A000
+
AIM-65's I/O Ports
(Fig. 4-2)
A001
39
This is done by the following program:
LOA #FF A+(11111111)
oTA A003 DIRA•-A
STA A001 A Port+A
LOA #80 A- (10000000)
STA A002 DIRB+,A
STA A000 B Porto
BRK
Before each tape operation, we must check the tape deck status to
insure that the deck is ready to accept our instruction. Since this
must be done before each operation, it might be wise for us to write a
subroutine which checks the tape status. This subroutine (or subprogram)
can then be called from any of our 3 programs. This eliminates the
need for an identical status check program segment in each of the 3
programs. This subroutine will act as a good first example since it
will be quite short and simple.
Figure 4-4 shows a flow diagram for our status check subroutine.
The program first checks to see if we are at the end of the tape or off
line. If either of these conditions exists, the program is aborted and
the machine is told to stop. The computer then examines the IFBY line
to see if the microformatter is busy. If it is busy, the computer goes
back and checks it again. This is repeated uttil the microformatter is,
no longer busy. The computer then checks the IRDY line. If the deck
isn't ready, the computer waits until it is before returning. A listing
of our status check subroutine is given below:
0220 LDA 8307
0223 AND #10
	
Stop if end of tape
0225 BNE 0228
0227 BRK
0228 LOA 8307
0228 AND #02	 Stop if off line
022D BEQ 0230
022F BRK
0230 LOA 8307
0233 AND #01	 Wait if busy
0235 BNE 0230
40
START
IS	 Y
TAPE
FINISHED
STOP
IS
TAPE DECK	 N
ON LINE
STOP
IS	 Y
ICROFORMATTER
BUSY
?
ISN
TAPE DECK
READY
\?
RETURN
Figure 4-4	 Status Check Subroutine Flowchart
41
o
^E
	0237	 LDA	 A000
	023A	 AND	 #01	 Wait if not ready
	
023C	 BEQ	 0237
	
023E	 RTS	 Return
This subroutine occupies locations 0220 through 023E in the AIM-
65's memory. There is no special significance to this address range,
but each of the programs presented in this chapter occupies a unique
range. This subroutine can be excecuted by a JSR 0220 operation in each
of our 3 programs.
The first program to be presented is the write program. A
flow diagram is shown in Figure 4-5. Our first step is to call the
status subroutine. If the tape deck is ready for our instructions we
then load the address and byte counters and clear the HER and LWD flip-
flops. The necessary control lines (IWRT and IFEN) and the 5W line are
then pulled down to the logic 0 state, the IGO pulse is sent, and the
operation begins. When the last word has been sent and the formatter
is no longer busy, all of the control lines are returned to the logic
1 state and we are finished. A program listing for the write program is
given below:
	
0300	 JSR	 0220	 Check status
	
303	 LDA	 #00
	
305	 STA	 8300
	
0308	 STA	 8301	 (000) into Adr. Ctr.
	
030B	 STA	 8303	 (C00) into Byte Ctr.
	
030E	 LDA	 #0C
	
0310	 STA	 8302
	
0313	 STA	 8304	 Clear HER & LWD flip-flops
	
0316	 STA	 83051
	
0319	 LDA	 #7C t
	
0318	 STA	 A001J	 IWRT & IFEN & Mi to logic 0
	031E	 LDA	 #00
	 20	 STA	 A000	 Send IGO pulse
	
0323	 LUA	 #80
	
0325	 STA	 A000
	
0328	 LDA	 A000
	0328
	
AND	 X09	 Wait for IFBY-LWD-logic 1
	
032D	 CMP	 #09
	
032F	 BNE	 0328
	
0331	 LDA	 #FF t	 IWRT & IFEN & BU to logic 1
	0333	 STA	 A001 1
	 6	 BRK	 Stop
42
0
I
I 43
Figure 4-5. Write Operation Flow Diagram
I
If a parity error occurred during the write operation, the HER
flip-flop will have been set and a logic 1 will appear in bit 7 of the
SIR. If such an error occurs we might want to space back 1 record and
try to write the record again. This exemplifies the need for our "space
back 1 record" program.
A flow diagram for this second program is given in Figure 4-6.
We first call the status check subroutine. If the deck is ready for our
instructions, we set IFEN, IERASE, and IREV (see Table 4-2) to logic 0
and send the IGO pulse. When the tape has spaced back by one record and
stopped, IFBY will go to the logic 1 state and the computer is stopped.
A program listing for this program is given below.
0350 JSR 0220
0353 LOA #5B
0355 STA A001
0358 LDA #001
035A STA A000
035D LDA #80
035F STA A000
0362 LDA A000
0365 AND #01
0367 DEQ 0362
036A LDA #F
036C STA A001
036F	 BRK
Check Status Check subroutine
IFEN & IERASE & IREV to logic 0
IGO to logic 0
IGO to logic 1
Go back to 0362 if IFBY=0
IFEN & IREASL & IREV to logic 1
Stop
The third program we will examine will read a record and transfer
the data from the tape to the DMA memory. This read program is very
similar to our write program. There are a few significant differences
which must be discussed. A flow diagram of the read program is shown
in Figure 4-7. The byte counter is not used during a read operation.
Therefore, only the address counter needs to be preset (normr'ly to 000)•
The operation begins when the computer pulls the IFEN and DW lines to
logic 0 and sends the IGO pulse. The record is read; and the data are
transferred to the DMA memory. Then the tape stops, IFBY becomes a
logic 1, IFEN and OW are returned to logic 1 and the computer stops. A
program listing of the read program is given below:
44
ir
FigUrp 4-6. Space Back 1 Record Flow Diagram
45
0380 JSR 0220
0383 LDA #00
0385 STA 830911
0388 STA 8301
038E STA 8304
038E LDA #7E
0390 STA A001
0393 LDA #00
0395 STA A000
0398 LDA #80
039A STA A000
0390 LDA A000
03A0 AND #01
03A2 BEQ 039D
030 LDA #FF
03A6 STA AM
Check status
Set Address Ctr. to 000
Clear last word flip-flop
IFEN & M to logic 0
Send IGO pulse
Wait until IFBY=logic 1
IFEN & DMA to logic 1
0349	 BRK	 Stop
i
i
46
n ,
START
CALL
STATUS CHECK
SUBROUTINE
SET Adr
COUNTER &
CLEAR HER
FLIP-FLOP
IFEN t- 0
DMA + 0
ND
IGO
PULSE
IS	 Y
IFBY = 0
IFEN + 1
DMA + 1
STOP
Figure 4-7. Read Program Flow Diagram
47
The data which are read from the tape are transferred to a
contiguous block of the DMA controller's memory. This block starts at
the address which wa y loaded into the address counter (preceded by 9).
Thus, if the address counter is preset to 000, this block of data will
start at 9000. The block of data which was transferred to the DMA
controller can be read by examining 9000,9001,...
Since we don't necessarily know the number of bytes in a record
in advance, a method of counting the number of bytes transferred is
provided. Each time a byte is transferred, a pulse appears on the
IRSTR line. This line is connected to bit 6 of the B Port of the
AIM-65's VIA. The VIA has the ability to count pulses on bit 6 of
its B Port and this ability can be used to count the incoming read
strobes. Details of this counter's operation (timer 2, pulse counting
mode) can be found in Chapter 6 of Reference [2].
These 3 programming examples have shown how the computer can use
the DMA controller to perform some simple tape operations. All of the
tape operations shown in Table 4-1 can be performed using the same
basic methods. This section has given all of the operational details
necessary to use the DMA controller. The next section will explain
the hardware details.
C.	 Hardware Details
In this section, the hardware details of the DMA controller will
be presented. A good understanding of the operational concepts pre-
sented in the previous section will make it much easier to understand
the hardware features of the DIIA controller. The DMA controller con-
sists of several integrated subsystems. This section presents a
schematic diagram and description of each of these subsystems.
1.	 Tape Control Line Buffers
The first subsystem which we will discuss contains the buffers
which are inserted into the lines connecting the DMA controller and
the tape deck's microformatter. These buffers are shown schematically
in Figure 4-8. The buffers give the controller to microformatter lines
the ability to drive the microformatter. This buffering is necessary
48
nI
	 615
I WRT(IN)
RV(IN)
2 IAGo	
Gz 3 1 WRT(OUT)
4 2A	 2Y 5 1 REV (OUT)
I WFM (IN) 6 3A	 3Y 7 I WFM (OUT)
i REW (IN) 8 4A	 4Y 9 1 REW (OUT)
> i ERASE (IN) 10 5A	 5Y II I ERASE (OUT)
FROM I OFL (I N) 12
6A IC98 6Y
13 IOFL (OUT) TO PERTEC
AIM-65
V. I.A. 74365
VIA J28
V 1 A J2A
1	 15
I FEN (IN) 2 IA
G.
	 G ^Y 3 1 FEN(OUT)
L1  (IN) 4 2A	 2Y 5 IGo (OUT)
i FBY (IN)
—I-X-6
 3A	 3Y 7 1 FBY (OUT)
FROM DBY (IN) 2 4A	 4Y 9 I DBY (OUT) TO AIM-65
PERTEC CCG ( IN)
51FMK
10 5A	 5Y II ICCG (OUT) V.I.A.	 VIAVIA J28
  (IN) 4 12 13 I FMK (OUT) J2A6A IC886Y
74365
I	 IS
FROM I RSTR (IN)	 5 2 IAGo	 G2 3 1 RSTR (OUT) TO DMA
J28
VAR I WSTR (IN ),C
--
4
2A	 2Y
5 1 WSTR (OUT)_ LOGIC( FIG. 4-15)
•5V
IRSTR(IN)
	 1 
220 f1
PIN 6
IC78
IC 308	 3308
74365
TYP
PASSIVE
	 LINE TERMINATOR
— IC30 B — BOURNS 4116R-003 221/ 331
Figure 4-8	 DMA Board Control 1/0 Buffering
I
1
1
1
I
I
1
1
1
1
49
because the AIM-65's VIA outputs are each capable of driving only 1 TTL
load. The microformatter's inputs present a greater lead. Therefore,
the controller to microformatter signals are bufferred to give them
the extra driving ability they need.
The microformatter to controller lines are also bufferred to
reduce the effects of any noise which may have been introduced along
the relatively long lines. Passive line terminators, (shown as X's in
Figure 4-8) are connected to each line at the input to the buffers.
These terminators also help to eliminate noise and are suggested for
use in noisy applications by the tape deck manufacturer. This buffering
system consists of 3 74365 IC's which are always enabled (G 1 and G2 are
permanently tied to ground).
2.	 The Address Bus
The address bus (CS8 and All-AO) from the AIM-65 is also buffered
as it enters the DMA controller. This address buffering is shown in
Figure 4-9. Two 74LS365 IC's (IC4A and IC5A) are used for the address
buffers. They perform 2 functions. First, they give the address lines
the ability to drive several TTL loads. Secondly, they can be used to
isolate the AIM-65 from the DMA controller. The buffers go to a high-
impedance state (isolating the controller from the computer) whenever
the G I and G2 inputs go to the logic 1 state. These inputs are tied
together and connected to the line labled SYS DMA. This line is the
compliment of the DMA line from the AIM-65 VIA. Thus, the W line must
be in the logic 1 state for any data transfer between the computer and
the DMA controller.
Figure 4-9 also shows three 74LS85 ICs configured as a 10-bit
address comparator. The operation of this comparator is analogous to
that of the address comparators on the digital I/O and analog input
boards. Its output, labled 830X, assumes the logic 1 state whenever an
address between 8300 and 830F appears on the address bus. This line
is used to select several of the registers shown in the DMA controller's
memory map (Table 4-3). Details of this selection process will be pre-
sented later in this section.
50
A n810 A
o OUT 8o 9
12 A
	 8	 it
Me A Z	 B2 14
IS AS	 8' 1
A„	 IA	 IY
l4 13
IC 13A
74LS85
A ,o	 6A	 6Y A=8  1N +5V
All	 4 2A	 2Y 5 3 1
12	 IIAs	 6 5A	 SY 7
A	 3A	 3Y
6 R20A
IA^	
4A	 4Y
10	
A=8
Ao OUT	 9 3
C5A
74LS365 12	 iiA,	 8,
AIM-65 13 AZ	 82 14
ADR 15I
BUS
A	 2 I A	 IY 36
A^IC 14A 2
74LS85
I4	 13A4	 6A	 6Y
A=8 IN
A 3	 4 2A	 2Y 5 3
AZ	 12 5A	 5Y II
A^	 6 3A	 3Y 7 6
Ao	 104A
C4A4Y 9
A-8
74LS3
10 AoOUT	 9
I	 Gl15 d2
12	 11A,	 B,
13 A2	
B2 14
15	 1A S	 83
IC15A
74LS85
DMA A=B IN
(F ROM FIG. 4-12) 3
Ao An
FROM ADR. COUNTER
OUTPUT ( FIG.4-13)
Figure 4-9	 DMA Address Buffering and Partial Decoding
TO DMA	 83OX
	
MEMORY (FIG. 4-12)	 IC17A
Ao	 A„	 13	 12830X
#j11#If 1#A#1	 (TOFIG.4-10)
51
n -+
3.	 The Data Bus
figure 4-10 shows the data bus section of the DMA controller.
This bus is brought into the controller through a buffer which, like the
address buffers, can isolate the AIM-65 from the controller. Similar
buffers interface the data bus and the tape deck's data lines. Additional
logic provides the necessary enable and direction signals for the buffers.
The AIM-65's data bus is brought into the DMA controller through
a 74LS245 octal line transceiver (IC3A). The AIM-65's SYS R/Q line
is connected to the direction input of the transceiver to set the
direction of data flow. Data are transferred from the computer to
the controller when this line is logic 0 (—WR-I"M and transferred in
the opposite direction when this line is logic 1 (READ).
IVA's enable input (pin 19) is connected to the inverted output
of =z of IC 11A. The tr:,.nsceiver is enabled only when: (1) the SYS DMA
line is at the logic 0 state (i.e. DMf----logic 1) and (2) either $WX or
M is at the logic 0 state. Thus, no data can be transferred between
the controller and the computer when the DMA line from the computer is
at logic 0. The CIN line, like the C310 line mentioned previously, is
an output from the AIM-65's internal address decoders. It assumes the
logic 0 state whenever an address between 9000 and 9FFF appears on the
computer's address bus. This is the address range reserved for the
DMA controller's memory. The 8 X line is the complement of the 830X
line shown in Figure 4-9. Thus, IC3A is only enabled when we address
a register in either the 83 00 -83OF or the 9000-9FFF range (while
DEC-1).
Figure 4-10 also shows 2 bidirectional data buffers which
connect the DMA controller's data bus to the data lines from the tape
deck's microformatter. These buffers are only enabled when the SYS DMA
line is at the logic 1 level (D^F--logic 0). The state of the IWRT
line determines the direction of data transfer. When IWRT=logic 0,
data are transferred from the controller to the microformatter. When
IWRT=logic 1, data are transferred in the opposite direction.
The data bus also connects the computer with the Status Input
52
630 x
	 = 74lS51(FROM I
FIG 4-9)
	 9 1
CS9
(FROM AIM-65) I	 II	 i
SYS DMA
( FROM FIG-4-12)
ICIIA
8	 9
19	 ICISB^^
11 as A,9
TO INPUT
STATUS REGISTER
D^^D
I	 19
^n 18
	 IW7
7	 IR7
IW6
14	
IR6
t	
1W5
3 
IRS
IW4
IR4
ICIA
74LS240
PERTEC
O IR3IW2IR2IWlIRIIWOIRO
	12 B y 	AT
	
I4B^	 A, 6AIM-65
	
1E	 IS Be	 A^ 5DATA
BUS	 t6 94
	 A; 4
	
It Bt	A
18
	
8,	 A 2
	
D i	 IC3A l
74 L S245
SYS Alz }----^
FROM AIM-65
ICIOA
IWRT (OUT)
	 10	 6( FROM FIG.4-8)
	 9
	
SYS DMA	 ICIOA(FROM FIG.4-12)	 4
3	 4	 5	 6
D	 Do.
TO DMA COUNTER
INPUTS 8 MEMORY
IWRT (TO FIG. 4-15)
o-
Figure 4-10	 Data Buffering
t
t
Register, the DMA memory, the address counter and the byte counter. The
details of each of these subsystems will be examined next.
4. Status Input Register
Figure 4 - 11 shows the schematic diagram of the Status Input
Register ( SIR). The status signals from the tape deck are connected to
the B inputs of a 74LS245 octal line transceiver (IC2A). The direction
input of this IC is tied to ground so the direction of data flow is
fixed (81-B8 are inputs, A1-A8 are outputs). The ou^puts of this
transceiver are directly connected to the data bus.
The SIR is only enabled when 830X, A2, Al, and A0 are all at the
logic 1 state. This occurs when 8307 appears on the address bus.
When these 4 lines are all at logic 1 the A=B output of IC12A (pin 6)
assumes the logic 1 state. This A =B output is inverted by 1/6 of
IC15B. This inverted output enables IC2A (the SIR). Thus, when the
computer excecutes a LDA 8307 instruction, IC2A is enabled and the
status signals appear on the data bus to be transferred to the accumulator.
The IHER signal from the tape deck is a logic 0 pulse which is
sent each time a parity error occurs during a read or write operation.
This IHER pulse is used to preset a flip-flop ( z of IC20B). The out-
put of this flip-flop is connected to a SIR input to allow the computer
to detect a parity error after a tape operation is complete. The
clearing of this flip-flop will be discussed shortly. Note that
since the SIR is connected to the buffered data bus, the SAM line must
be a logic 1 for the SIR to be read by the computer.
5. The DMA Memory
Figure 4-12 shows the memory which is the heart of the DMA con-
troller. This memory -is comprised of eight 2114-L static RAM ICs.
Each IC contains 1024 4-bit registers (1K x 4). They are connected in
pairs (IC1B with IC11B, IC2B with IC12B, IC3B with IC13B, IC4B with
IC14B), and each pair then has 1024 8-bit registers. Thus, there is a
total of 4096 eight-bit memory registers.
The data lines from the RAM ICs are directly connected to the
buffered data bus. Ten buffered address bits, A9-A0, are connected
to the address inputs of each memory IC. These ten lines address the
54
74 LS 245
Qp	
9 As Be 11 —^ I ROT
7
IONL STATUS
TO BUFFERE <— 6 13A, B, 14 IFPT OUTPUTS
US
— As Bs ILDP FROM
( FAG 4 B0) 4 A4 84 I5 IEDT TAPE DECK
3 A3 B 17 I RWD
D74,	
2 A:
B, 18
ENAB. DIR. 1 19
12LOGIC I
WHEN 8307	 IC158
ADDRESSED ^ is
6
10 A OUT 9 •5V
FROM	 A 12
0A	 B, 11 4.7K
BUFFERED 13 14ADDRESSI A, A 2	82
BUS
A o
15
A3	 83
1
(FIG. 4-9)
IC12A
74 LS85
A=81N
3
i IC208
IHER ( FROM 5 10 6 MER
TAPE DECK) PR
IC 74LS109
7
830X
( FROM FIG.4-9) UNUSEDINPUTS TIED
NIGH
8304 ( FROM FIG.4-15)
Figure 4-11
	
Status Input Register
55
Id
D
m ^
N }
Y
a
m
vH
40
h
N
W
Z a N m
NW 
N
H Q_.
W W -IN NW n
U. O N	 ND N
m a M O -
a a
_LO
m
J a
I-ICY
	 H i
I
I
M
a
o m
v '^
H U
N
m
H
N	 10
n
U ^
H _
Mf	 m!fl
u
u u+
I a?	 I^	 a-3Ida D	 D	 #'D	 0
'nU -1
'n°	 i	 •!
V1	 Vf	 H
D N	 al 0	 O
Ir	 QI	 k
u
..	 IVt _H N M`-_W	 ()
I
W m J
OU N
IN H N ML V
s
W m J
S N O N_
IN
U _-
H N M
^ U
O
I
W m
VO N
I H Nm U
I
^
4
W m J
IU
U
H N MOD U
I
W m JM
t OU N
IN M N M
m U
o ^
W m
O
2
N
IlA
U
H ly MOD U
a
N
a Q a a a 4 d 4 a -in V
v, a0 r- - N M 4 r to	 lA I {
L_ —1WVj^
wQ ,o n•	 ^	 n-94 a -t a a a Q oa or m^W
W ,"W
m °
wx mO4
U
O
.J3
C
b
i
N
0l
L
LL.
5F,
I
1024 (=2 10 ) registers within each memory IC. Our two most significant
bits, A 11 and A10 , are used to select one of the four pairs of memory
ICs. A 1 of 4 decoder (h of IC9A) is used for this selection process.
This decoder (and thus the memory) is enabled when M or DW is at the
logic 0 state, i.e., when reading or writing from 9000-9FFF or during
DMA operations. When the decoder is enabled, it examines its 2A and 28
inputs which are connected to A10 and A11 . The state of these two lines
determines which 1 of the 4 outputs (2Y0, 2Y1, 2Y2, b 2Y3) will be pulled
low. When one of the outputs is low, a pair of memory ICs is selected
by pulling their M (Chip Select) inputs (pins 8) to logic 0. Table 4-4
summarizes the memory selection process.
The read/write control for the memory system is provided by
parts of IC15B, IC10A, and IC11A. The output of this read/write logic
(pin 6 of IC11A) is connected to the 'WE (Write Enable) line of each
memory IC (pin 10). Table 4-5 summarizes the function of the read/write
logic. When the Ar and § to a memory IC are both low, the data on the
data bus are transferred to the memory register which has been selected
(i.e., the data word is written into the memory). When U is a logic 0
while Wff is logic 1, the contents of the selected memory register is
presented to the data bus, i.e., the memory is read.
Table 4-5 shows us that when the DEC line is at logic 1, the
line assumes the state of the computer's RAM R/A line and the computer
provides the read/write signal. During a DMA operation (i.e. W -
logic 0), the VE line only becomes a logic 0 when the IWRT line is a
logic 1 (we are reading from the tape) and a read strobe is being sent.
Thus a data word will be transferred from the data bus to the memory at
each read strobe during a tape read operation.
Figure 4-12 also shows where the SYS DMA and SYS 5C lines are
generated. The DW line is brought from the computer to pin 1 of IC15B.
This signal is inverted twice anJ the outputs of these inverters are
used as our SYS DMA and SYS DM. signals. These signals are then used in
several places throughout the DMA controller. Note that the SYS Du
line is at the same state as the D	 line but has the ability to drive
several TTL inputs (Remember the 	 line can only drive 1 TTL input
since it comes from a VIA) .
57
6.	 Address and Byte Counters
We now must see hoa she address and byte counters operate.
The address counter is a 12-bit counter which generates the addresses
for the memory during DMA operations. The byte counter (also 12 bits)
counts the number of bytes which the DMA controller has transferred,
and sends the last word signal when the preset byte count has been
reached. The basic hardware configuration of both counters will be
presented, followed by a discussion of their loading and counting
operations.
Figures 4-13 and 4-14 show the address and byte counters. Each
counter consisits of 3 cascaded 74LS163 4-bi* counters. The counters
are enabled (allowed to count) only during DMA operations (i.e. SYS
DMA is a logic 1). The counting and loading signals are provided by
a set of logic gates which will be discused shortly.
We will first examine the address counter. We will assume
that it has already been loaded with our desired starting address. When
the DW line goes to logic 0 our counters are enabled and will increment
each time a count pulse appears at their clock inputs. The address
counter outputs are tri-state buffered by two 74LS365 ICs (IC25A and
IC24A). When the SYS W line is at logic 0, these buffers are enabled
and the output of the address counter appears on the address bus. Re-
member, when SYS DU is at logic 0 the AIM-65's address bus is isolated
from the DMA controller.
The address which the counter supplies to the address bus is
presented to the memory's address inputs. The contents of the selected
memory register can then be transferred to or from the tape deck on
the data bus. As the address counter is incremented, sequential memory
locations are selected and sequential data words are transferred.
Each time the address counter is incremented, the byte counter
is also incremented. When the byte counter reaches the all logic is
state, the RCO (Ripple Carry Output) of IC 25B (pin 15) goes to
the logic 1 state. This signal is inverted by 1/6 of IC 17A. The
inverted RCO signal presets the LWD flip-flop (112 of IC 20B) when the
counter indicates that the last byte hrs been sent. The inverted RCO
58
TABLE 4-4 - Memory Selection Summary
^I
Pin 6
IC18A
A11 A10 Address Range ICs Selected
1 X X - none
0 0 0 9000-93FF 4B & 14B
0 0 1 9400-97FF 3B & 13B
0 1 0 9800-9BFF 2B 6 126
0 1 1 9000-9FFF 1B 6 1:8
X n Don't Care
TABLE 4-5 - Read/Write Logic Summary
LINE DW RAM RAT IWRT IRSTR A^
1 1 X X 1
1 0 X X 0
STATF 0 X 0 X 1
0 X 1 1 1
p X 1
X - Don't
A
Care
0
I
1	 59
1
,1
	 ) I 11, it,
o°	 o
O N ^W ^ O
e "pw i
eat
Q^
C
c
1
V+
V'
Q'
LQ
i
,, wW	 ,
W K ^
,,god
dD
4
p	 OZ.•Z. 31 v V
4
7
U
Q	 Y F ?
	
f p r p	 r z
	
^ d V O	 V U V n
	
J	 Q V	 V
	Q o	 U ° f1
	
d _I	 Q J d 2
T
60
rI- v —
O a r er
O	 V z
J	 ri
U ^^ V
NNJ	 Z
Hti m
O
N
O Q
U
M
m
1` = —
O a F-
O	 u zJ
U co 40N
t0
^NJ z
H^ z
O Q MQ
IY
I',-
v
Oar It
O	 U z
J	 ^
V mw ^
N J E
H^ m
Os
mN
7
V Q
w
M
m
S-
0
V
41
m
a
et
L7
v+
O^	 O
z`—' Warn
J:EQ O Waa]W OW
Oli
m
61
UWr
O W3aOJ
T EY.
J
LL co
==OJJO ZL N ^O
_ O
O —
N - - !D -
UUC^U mm Y	 N N
WWWW toNN Y. UO	 tiH
r r 1- ►- N
Ln m m CO M
,1 > Q ^!
• ^y aD M ^!
W N (^r0
m
N
r	 m ^O	 O
d
NJ
(^_
Z
 
O
Q
M,
V 
	
N
cvW^	 O
cn 
O
2 O J
O
W
V
Hr
3 "'
.^ J
m
_O m1D
W d
I
O
a C4wo
Ir
IL
ON
in
signal also is used to fire a one-shot multivibration (IC21B). This
one shot produces an extended pulse of approximately 1 millisecond
which is sent to the microformatter es the ILWD pulse. During a tape
write operation, this ILWD pulse will tell the tape deck that the last
word is being sent. The tape deck will automatically stop upon receipt
of this pulse.
The circuit shown in Figure 4-15 generates the clock and load
signals for the address and byte counters. A 1 of o decoder (IC22B)
is used to control the load and clock circuitry. The outputs of this
decoder are enabled when the decoder's G1 input (pin 6) is at logic 1
and both G2A and GFB (pins 5 & 4) are at logic 0. G1 is connected to
the 830X line (which goes high when 8300-83OF is addressed). The
computer's R/W line (which goes to logic 0 during STA operations) is
connected to G2A. The computer's ^T clock signal is connected to the
G2B input. This signal becomes a logic 0 during the latter half of
each computer cycle. It is during this last half of the cycle that
the computer puts a data word on data bus and guarantees that the word
is valid (correct and stable). Thus, using the _^7 clock to enable our
loading operation insures that the counters will be loaded during the
time when the data are on the data bus and stable.
When IC22B is enabled, it examines its A, B and C inputs and
pulls the corresponding output to logic 0. Thus, a STA 8300 operation
causes a logic 0 pulse to appear on YO (pin 15), STA 8301 causes a
pulse on Y1, etc.
A STA 8304 operation causes a logic 0 pulse on Y4 (pin 11). This
output is connected to the clear input of our HER flip-flop (Figure '4-11).
Therefore, when the computer excecutes a STA 8304 instruction, the HER
flip-flop is cleared. -Similarly, STA 8305 clears the LWD flip-flop
(Figure 4-14).
We will now examine the loading of the counters. We will make
some simplifying assumptions which will make the initial circuit an-
alysis much easier. Let us first ignore IC16A and IC17A. We will also
assume that pin 8 of IC6B is at the logic 1 state (which it will be
during the loading operations).
o2
The 74LS163 counters (Figures 4-13 and 4-14) require their load
inputs to be logic 0 during a load operation. If, while the load line
is low, a positive (logic 0 to logic 1) transition occurs on the IC's
clock input, the counter will load the number on the data bus.
We will examine the loading of the least significant byte of
the address counter as an example. If the computer executes a STA 8300
instruction, a logic 0 pulse will appear at the Y0 output of IC22B.
This causes both the ADR. CTR-LO CLOCK and ADR. CTR-LO LOAD signals to
also momentarily go to logic 0 (remember pin 8 of IC6B is at logic 1).
Since the clock signal must go to logic 1 while the load signal
is still logic 0, 2 inverters are placed in the load signal's path to
cause a small delay (approximately 50 nanoseconds) for the load pulse.
Thus, when Y0 of 1C22B returns to logic 1, the clock pulse will return
to logic 1 approximately 50 nanoseconds before the load pulse, and the
counter will be loaded with the data on the data bus. The other counter
bytes are loaded similarly. The only difference is the unique address
which selects each counter byte (see Table 4-3).
After the counters have been loaded and the tape deck started,
read or write strobes (logic 0 pulses) are sent from the microformatter.
IC6B examines these strobes and the status of the IWRT line. If IWRT
is set for a write operation (IWRT = logic 0), the write strobes will
be transferred through IC6B and will appear on pin 8 of this IC.
They will then appear at each output of IC19A and each counter will be
incremented. Similarly, if IWRT is at logic 1, the read strobes will
be sent to the clock inputs of the counters.
The strobes from the tape deck must be gated with the IWRT line
because both read and write strobes are sent by the microformatter dur-
ing a write operation. This is because the tape deck reads the freshly
written data to determine if a parity error occurred during the write
operation. If the strobes are not gated with the IWRT line (by ICU),
read strobes which occur during a write operation can increment the
counters causing valid data words to be skipped.
This concludes the discussion of the Direct Memory Access Controller.
H
A complete wire list giving all of the wire wrap connections is presented
63I
t
TO BYTE
COUNTER
(FIG.4-14)
BYTE
CTR. - LO
LOA D
BYTE
CTR.-LO
CLOCK
BYTE
CTR.- H I
CLOCK
BYTE CTR.-HI
LOAD
ADR. CTR.-HI
LOA D
ADR. CTR.- HI
CLOCK
TO
ADDRESS
COUNTER ADR. CTR.-LO
(F16.4-13) CLOCK
ADR. CTR.- Ld
LOAD
TO HER 8 LWD 8305
FLIP-FLOP CLR. 8304
(FIG'S 4-11 a
4-14 )
741-04
6	 5 2	 I (SEE FIG. S
4-894-10)
IC16A	 IC16A \
^3	 IC66 2	 1IWRTIIIRST
8	 IC6B
9	 (	 1
10	 (OUT)
aIC16A
g	 4iIIWRTIC68 5 U I WSTR
 1 (OUT)_
830X J62 R/ W
6	 5	 2	 I (FIG.4-9) 6	 5	 4
IC17A^8 10
- - -
G2	
2,
YG^
1C19A g 9 Y6 IC22B10 Ys 74LS136
13 12 Y411 3I C 19A 12 14 Y2Yj
IC17A	 IC17A 1
 YoA8	 9	 12	 13 8 CI	 2	 3
Ao A Az74 L04 '
BUFFERED
TO LWD FF ADDRESS
TO HER. FF LINES
Figure 4-15. Address and Byte Counters - Load and Clock Logic
64
in Appendix B. A connector key giving the connec.or and pin number
of each line which enters or leaves the DMA controller, is also given
in this Appendix.
V.	 HIGH RESOLUTION RADAR CONTROL
A. Introduction
A high resolution S-band radar which can determine the spatial
distribution of water along an Earth-space propagation path is connected
to the data acquisition system through a VIA. This radar is controlled
by a radar interface which was originally designed to interface the
radar with the I/O section of the Hewlett-Packard 2116B minicomputer.
This chapter describes the hardware which was used to connect the
radar interface with the AIM-65. This is followed by a discussion of
the signals which drive the interface and retrieve the radar video.
The last section of this chapter gives the software required to gen-
erate and receive these signals.
B. Hardware Interconnections and Control Sequence
The radar interface is designed to operate under the control of
a Hewlett-Packard 16-bit duplex register. This duplex register is
an I/O device which is very similar to a VIA. There are, however, some
very important differences. The H-P 16-bit duplex register considers
+12V on an I/O pin to be a logic 0. 0 V on the same pin corresponds
to a logic 1. The radar interface's inputs and outputs are designed to
be consistent with these logic level definitions. Therefore, to connect
a VIA to the interface we must shift the VIA's output signals from
TTL levels (+5V logic) to the +12V logic the interface requires. We
must also change the logic signals which go from the interface to the
VIA from +12V logic to +5 logic to avoid damaging the VIA inputs.
There are 4 signals which run from the VIA to the interface
which must be changed from the OV to +12V range. A circuit was designed
and constructed which performs this function. It is shown schematically
in Figure 5-1. The 4 signals are buffered by a 7417 hex open collector
buffer IC. The open collector outputs are pulled up to +12 Volts by
four 1M resistors. This circuit is contained on a small printed circuit
65
INPUT	
12V	 OUTPUT+CONNECTOR	 CONNECTOR
1	 0/
ALL OTHER LINES
	 I	 m
5	 ( PA3)
	 13	 12
FROM
VIA*2	 4	 ( PA2)	 1	 2
20
3	 ( PAI)	 3	 4
2	 ( PAO)
	 5	 6
HEX , OPEN
COLLECTOR
NON — INV.
BUFFER
2	 ^ 5
3	 14
4	 13
I	 I
1	 5 1 2
1
SINGLE IN—LINE
RESISTOR PACK
( 1000 S EACH)
TO RADAR
INTERFACE
to
20
Figure 5-1
	
Radar Control Word Buffers
66
°°9
board located in the chassis containing the analog conditioning board.
The signals which go from the interface to the VIA are shifted
down to the OV to +5V range from the OV to 12V range by changing the
voltage on their pull-up resistors (in the interface) from +12V to +5V.
A switch was installed to allow this voltage to be switched from
+12V to +5V. This switch is located near the radar interface. The
switch should be set to the AIM position when the interface is to be
run by the AIM-65, and set to the H.P. position when the interface
when operation with the 21166 is desired.
C.	 Radar Interface Operation
Before describing the actual timing and control signals
necessary for radar operations, a brief overview of the radar interface's
operation will be presented. The interface fires the radar when the
computer sends the interface a RESET command. A radar pulse is fired
and a receiver gate is opened during the trailing edge of the pulse.
The received radar video is then sampled 100 times and each sample is
converted into a digital word which is stored in a shift register
memory. Each of these digital words is proportional to the relative
strength of the signal received from one of the 100 samples (range
bins). The interface automatically sends 31 additional pulses and
samples the video 100 times for each pulse. The results from all of
the 32 pulses are digitally integrated (averaged) for each of the
100 range bins. The result of this process is 100 11-bit video words
representing the average signal returned for each of the 100 range bins.
This entire process takes 320 milliseconds.
After the 32 pulses have been integrated, the interface sends a
logic 0 pulse (the HP flag) to the computer. Yhis pulse tells the
computer that the interface has stopped and the data can be retrieved.
The computer can then take the data from the interface and the entire
process is complete.
The ra ,:ar interface is connected to VIA #2 of the data acquisition
system. Figure 5-2 shows the bit assignments for the I/O ports in this
VIA. The 4 least significant bits of the A Port are outputs and all
of the other port bits in this VIA are inputs. The 4 output bits
67
y°
l°
comprise the radar control word. These bits are labled DEVICE COMMAND
(DC), RESET, S-SELECT, and SHIFT. Bit 4 of the A port is labled HP
FLAG. This is the line on which a logic 0 pulse appears when the inter-
face has completed the radar firing routine. The remaining 3 bits
of the A port and the entire B port are connected to the 11 data output
lines of the interface.
All of the lines going between the computer and the tape deck
use negative logic, i.e., a line is considered active when it is at the
logic 0 state. The 4 control word signals are explained below:
DEVICE COMMAND (DC) - Each of the other 3 control signals and
the HP flag is gated with this line. The
line must be at the logic 0 level for any
signals or data to be transferred between.
the computer and the radar interface.
RESET
	
- A logic 0 pulse on this line (while DC
is at logic 0) causes the radar interface
to be reset and initiates the radar firing
sequence.
S-SELECT	 - This line, when logic 0 (with DC at logic
0), causes a video data word to appear on
the outputs of the interface. The word
can then be read by the computer.
SHIFT - A logic 0 pulse on this line (while DC
and S-SELECT are at logic 0) causes the
next sequential data word (of the 100)
to be placed on the interface's outputs.
The proper command sequence for driving the radar interface is
most easily explained with the aid of a timing diagram. Such a diagram
is shown in Figure 5-3. The radar firing sequence is started by pulling
the DEVICE COMMAND (DC) and RESET lines to logic 0. The DC line remains
at logic 0 during the entire radar operation. The RESET line returns
to logic 1 and the radar begins its firing sequence.
68
U 	 LA-
N ^»
^ N }
W
F•► 1 J
r W ^}
ID N N ^
V F—
W
d y)
W 119
D ^ }
W Z
^ U
^
r.r
ULJ
G }
Q1
C. r•- n] = LL }
co
i
I
.r
'
I
> a
N
4- 
NO I O :40::
11 +r 11	 i-^OQ LQ
N 0. ^--^ N 0. ^r
1
1
c
e
a
C
LA
i
0
n
4-
.r
cc
O
t •C
in
L of 4J r
R1 -	 = m
GJ O. V)
iJ oil
7 1	 1`
CL Q
Q
• Cl
4n
c
c
rnN
W
a
4j
i
O
a
N
SIR
Q
}
N
1
N
NL
Q)
69
f- I
WN
W
at
Oix
00
s O
— 0 00
,o
3
ir
iO
13
0
MO3
O
0
I;	 3O
Zi W
p O O
E
L
3 W cm
D
tT
C
•r
.r
O
L
O
U
L
W ^
W
CC
e^ f
LA
L7
cn
LL-
'	 ^ 7
N 0 r^ O N O N_ OI 0
t
70
After 320 milliseconds have elapsed, a logic 0 pulse appears on
the HP FLAG line. This pulse tells the computer that the 32 radar pulses
have been fired and the integrated results can be transferred to the
computer. The computer then pulls the S-SELECT line to logic 0 and
the first video word appears on the outputs of the interface. The
computer then reads this word. The SHIFT line is then pulled to logic
0 and the second word appears on the interface's outputs. After the
computer reads this word it toggles the SHIFT line to logic 1 and back
to logic 0. The third word is then read. This toggle and read process
is repeated until all 100 video words have been read. The computer
then returns all of the control lines, including the DC line, to logic 1
and the process is finished.
	
D.	 Software	 Considerations
This section presents some basic software which will perform the
radar control sequence and acquire the video data.
Before presenting the software details we must first deal with
a few minor problems. The first problem concerns the HP FLAG signal.
This signal is a pulse of approximately 1 microsecond duration. Since
most of the AIM-65's instructions require 3 or 4 microseconds to be
excecuted, the HP FLAG pulse is too short to be observed jy simply
examining the port bit connected to the HP FLAG. A simple program loop
which examines this bit and waits for it to be a logic 0 might look like:
	
START: LDA 8121
	 A+A Port of VIA #2
AND	 #10
	 Af-A • (00010000)
	
BNE START
	 Jump Back to Start if Bit 5 of the A
Port = 1
Since the HP FLAG is only 1 microsecond long this 'loop will miss
this signal unless it occurs during the program cycle in which the
accumulator is loaded with the contents of location 8121. Therefore, we
must find a method of positively detecting this short pulse. One
F
71
method might be to have the pulse set a flip flop which the computer can
read and then clear after the pulse is detected. This would be quite
straightforward and the required hardware would be small and easy to
build.
There is an easier method of detecting this pulse using a
feature of the VIA. The VIA contains several internal flip-flops which
are virtually identical to the one which was just described. Use of one
of these flip-flops will eliminate the need for any additional hardware,
but will require that we learn the necessary software to control the
flip-flop.
Space does not permit us to discuss the details of all of the
VIA's internal features. Several of the VIA's internal registers will
be used to allow us to set and read a flip-flop which is connected to
the HP FLAG line. Reference to Chapter 8 of Reference [1] and Chapter
6 of Reference [2] is strongly suggested ;f you are not thoroughly
familiar with the VIA's operation. Particular attention should be given
to the discussions of the Interrupt Enable Register (IER), the Interrupt
Flag Register (IFR) and the Peripheral Control Register (PCR).
We will detect the pulse on the HP FLAG line by connecting this
line to the CA1 input of VIA #2. Since we will never need to interrupt
the processor, all bits of the IER should be cleared. This can be done
by writing (7F) into the IER (location 812E) during the intialitation
routine of our program.
Ry writing a logical 0 into bit 0 of the PCR (location 812C). we
can cause the CAI interrupt flag to set whenever a logic 1 to logic 0
transition occurs on the CA1 input. This flag can be examined by reading
bit 0 of the IFR. Since we have cleared all of the IER bits, tiro inter-
rupt will occur when this CA1 interrupt flag is set. The computer can,
however, monitor bit 0 of the IFR. When the HP FLAB is sent, this bit
will become a logic 1, and the computer can then retrieve the radar data.
Before each radar operation, the computer must clear bit 0 of the
IFR. If a logic 1 is written into any IFR bit, that bit will be cleared.
Thus we can easily clear the IFR by writing (FF) into it.
72
The second problem which we must recognize before we write our
radar control program is the fact that the data which the radar interface
outputs to the computer is inverted. This is because the 16-bit duplex
register from the Hewlett-Packard computer recognizes ground potential
as a logic 1 and a positive voltage as a logic 0. Since AIM-65 uses
conventional TTL logic levels, the data outputs from the radar interface
should be inverted (complemented) before the computer writes it onto the
magnetic tape. This complementing operation can easily be done by the
computer without the need for any additional hardware. When the inverted
data word is in the computer's accumulator, excecution of an FOR OF
instruction will cause the word to be complemented.
We are now ready to write a simple program which will fire and
read the radar. A flow diagram for this program is given in Figure 5-4.
A program listing  i s given below:
0500 Lox #00
0502 LDA #f00
0504 STA 8122 Set Direction Registers
0507 LDA #OF
0509 STA 8123
505C LDA #00
812C)
PCR_ (00)
050E STA
0511 LDA VFJ IER+(1F)
0513 STA 812E
0516 LDA #OFF Clear IFR
0518 STA 812D
0518 LDA #F03^ D.C. & RESET to Logic 0
051D STA 8121
0520 LDA #0F Reset to logic  1
0522 STA 8121
0525 LDA 8120 Wait for HP FLAG
0528 AND #' O1
052A BEQ 0525
052C LDA #F05 S-Select to Logic 0
052E STA 8121
0531 LDA 8121 Compliment First Word and Store in0534 FOR #fFF
0536
0539
STA
JSR
0600
0700 - Jump to Print Subroutine
053C LDX #E01
053E LDA #04 SHIFT to Logic 0
0540 STA 812 
73
0543
0546
LDA
FOR
8120
OFF Put Next Word in 0600, n
0548 STA 0600,X
0548 JSR 0700
- Jump to Print Subroutine
054E LDA 005 - SHIFT to logic 1
0550 STA 8121
0553
0554
INX
TXA  Jump Back to 053E if all 100
0555 CMP 064 Wordy Have Not Been Read
0557 BNE 053E
0559 LDA OFF All Control Bits to Logic 1
0556 STA 8121
055E	 BRK
Note that this program only recovers t:ie 8 most significant bits of each
video word. All 11 bits are brought to the VIA from the radar interface
and the program could be easily modified to read the entire 11 bit word
if extended precision is required.
It should also be noted that a JSR 0700 instruction is excecuted
each tine a word is retrieved. If the following subroutine is entered
into the AIM-65, a facsimile of the A-scope radar display will be printed
by the computer.
0700 ROR A
0701 ROR A
0702 ROR A
0703 ROR A
0704 AND 00F
0706 STA OA
0708 TXA
0709 SBC 0OF
070B BPL 0721
070D JSR EB44
0710 LDA OA
0712 BEQ 011E
0714 LDA #23
0716 JSR EEFC
0719 DEC OA
0718 JMP 0710
071E JSR E9FO
0721
	
RTS
Rotate Accumulator 4 bits to
the Right
- Mask Off 4 m.s.b.'s
- OA4
RTS 1f x > 16
- Clear Print Buffer
Put a Rote of 0 Signs Proportional
to Original Contents of OA into
Print Buffer
- Print Contents of Print Buffer
74
FIGURE 5-4 - RADAR CONTROL PROGRAM
75
T
This subroutine prints a row of # symbols (ASCII 23) proportional to the
magnitude of each video word. The result is a printed pattern which
resembles the radar A-scope display. In order to save time and paper,
only the first 16 video words (range bins) are displayed. This number
can be varied by varying the object of the SBC operation (step 0709).
This subroutine might be very useful during repairs or tests of the
radar interface or radar. If the printed display is not necessary, it
can be eliminated by turning the printer off or by inserting a RTS
instruction into location 0700.
This concludes the discussion of the control of the high resolu-
tion radar. Wire lists for the cables which connect the computer and the
radar interface are given in Appendix B.
VI.	 SENSE SWITCH INPUTS
A set of 16 switches is connected to the 2 input ports of VIA#4.
These switches can be set by the system's operator. The computer can
then determine the configuration of the switches by simply reading the
input ports. The switches might typically be used to stop or idle the
system or to tell the computer that the data being returned from each
particular experiment are or are not valid.
The computer can periodically examine the switch configuration
and operate the system accordingly. Since mechanical switches are
prcne to contact bounce upon closure, an electronic debouncing circuit
was installed so jitter free logic signals will be presented to the vIA
i npu- s.
Figure 6-1 shows the schematic diagram of the sense switch de-
bouncing circuit. The 16 switches are connected to the inputs of three
MC14490 hex keybounce eliminators. A debounced version of the inputs
to these IC's appears at their outputs
Figure C-1 also shows the port bit assignments for the switches.
For VIA#4the A port occupies location 8141 and the B port occupies
location 8140.
Both the switches and the debouncing circuit are located in the
76
5I	 # 2	 I5 5	 (PA7) 28
17	 12	 4 17	 (PBO) 26
13
SS16
8
14
7
15
6
\	 16
14 anv	 vcc
8^N	 BOUT
AiN 
#3 
Aour
D AN	 DOYT
MC 14490
C IN	 CouT
F IN
	
FOUT
Eir
OSC. IN	 EouT
2	 13 (PAO) 35
I 15	 8 (PAIL	 34
12 4	 14 (PA 2) 33
3 13	 -f 32
10 6	 15 ( PA4) 315
11	 6
161
(PA5) 307
1	 141" PA6)	 29-12 TO VIA#4
T
20
SENSE SWITCH
t" — — — — — — — — — —1^DEBOUNCER
I	 I BOARD m
9.,.,	 to .	 171 1 1
t
4	 3 MC 14490 13 4	 (PSI) 25
18	 10	 6 18	 ( P82) 24
5
3	 7 OSC IN	 11 3	 ( P83) 23
19	 14	 2 19	 (P84) 22
# i
2	 1	 15 2	 P85 21
20	 12	 4 20
	
( P86) 20
MC 14490
1	 3	 13	 1	 ( P87) 19
	
_	
SSI
9 OSC OUT
	
180 pF-l+	 7 OSC IN
	 (	 T
	
~	 1	 CONNECTOR
I J ON CHASSIS
Figure 6-1	 Sense Switch Debouncing Circuit
77
chassis which contains the analog conditioning board. The circuit is
constructed using wire-wrap techniques. Connectors are provided so the
board can be disconnected from the system for repairs or modifications.
VII.	 CONCLUSIONS AND FUTURE CONSIDERATIONS
This report has presented a detailed description of each of the
data acquisition subsystems. Details of both hardware and software
design techniques have been given. We have seen how this system has
the ability to acquire digital and analog data, manipulate them and store
them on magnetic tape for future analysis. The system also has powerful
digital I/O features which allow it to control the system from which
it acquires the data.
The AIM-65 is a powerful yet easy to use computer. It's basic
operation can be learned in a few hours. This ease of operation can lead
to some very useful modifications and extensions of the system's hardware
and software. In this chapter we will discuss a few of these possible
future extensions and their implications.
An Erasable Programable Read Only Memory (EPROM) Programmer
might be a very useful first addition to the system. This proarammer
can be used to write the system's operating program in a permanent
memory. This would eliminate the need to load the program from cassette
tape when starting the system. The EPROMS can be erased and reprogrammed
if the system's operating program must be changed.
Another useful addition to the system might be a video monitor.
This monitor could be used to output real-time displays of the system
status or data. A graphic display of the data being acquired could be
of great aid to the operator or troubleshooter.
An interface could be designed to connect the interface to a
standard telephone line. This would allow the system's operator to
monitor or change the system's status from a remote location. This
feature might make it much easier to insure that good data are taken
during late night thunderstorms when no operator is present.
78
Audible alarms might be added to the system which could indicate
that the system has encountered a problem. This problem might be the
end of the magnetic tape, loss of the receiver's lock on the beacon; or
the failure of a sensor or hardware component.
There is practically no limit to the software features which can
be added to the system. Useful programs, program segments, and subroutines
can be designed to perform many operations. Software extentions can
be designed which will make the system more automatic by making its own
operational decisions. Component calibration and troubleshooting pro-
grams can turn the AIM-65 into an extremely powerful piece of test
equipment. Anyone who is involved in any way with the system or the
data it acquires should master the programming techniques which can
modify and improve the system's performance.
We have seen that the microcomputer based data acquisition system
is quite versatile and powerful. It can be used in many applications
where automatic data acquisition and/or experiment control are required.
The straightforward hardware design and ease of software design should
make this system a most useful addition to the laboratory's facilities.
79
REFERENCES
[1] AIM-65 Microcomputer User's Guide. Rockwell International, document
No. 29650 N36, 1979.
[2] R6500 Microcomputer System Hardware Manual. Rockwell International,
document No. 29650 N31, 1979.
[3] R6500 Microcomputer S stem Programming Manual. Rockwell International,
document No. 29650 N30, 1979.
[4] Model FT8640A Fornatted Tape Transport Operating and Service Manual
Ho. 104927 with  Microformatter Addendum, Chatsworth Calif., ertec
Computer Corp. 1977.
[5] AIM-65 Microcomputer Monitor Program Listing. Rockwell International,
document No. 98650 N36L, 1979.
80
APPENDIX A - DATA ACQUISITION SYSTEM - MEMORY MAP
seas
OQFF
0100
01FF
a2aa
OFFF
1000
7FFF
8000
8001
8002
800F
8010
88FF
8100
810E
8110
811E
8170
4
817F
Scratch pad memory for
operating program
Reserved for AIM-65 stack
and monitor subroutines
User available RAM for
operatinn program
Not currently used
ADC MO
ADC #1
ADC p2
ADC NF
Not currently used
V.I.A. M1
V.I.A. N2
V.I.A. N7
Not currently used
ADR. CTR. -LO
ADR. CTR. -Hi
BYTE CTR. -Hi
BYTE CTR. -Lo
LWD - Clear
HER - Clear
Not Used
STATUS INPUT REG.
Not currently used
DMA Memor (4K RAM on
DliA board
AIM-65 V.I.A.
AIt4-65 I/O end RAH
Reserved for ROM (or
EPROM) sockets o, AIM-
6F Board
AI14-65 tioni for Program
(ROM)
i
8180
82FF
8300
8301
8302
8303
8304
8305
8306
8307
8308
i
8FFF
9000
A009
AOOF
AOOF
i
HFFF
8000
DFFF
EOaO
FFFF
A-1
iw"'	 £	 1
1
Y	 1
APPENDIX B - WIRE LISTS, PC LAYOUTS, ETC.
DMA Controller - Connector Key
J1A J20 JIB J2B
1 DO CS9 IRO IRDY
2 D1 IR1 IONL
3 D2 RAM R/W IR2 IFPT
4 D3 IRSTR (OUT) IR3 ILDP
5 D4 LWD IR4 IFOT
6 D5 IWRT (OUT) IRS IR14D
7 D6 IWRT	 (IN) IR6 IWRT (OUT)
8 D7 D	 (IN) IR7 IWSTR (IN)
9 A (IN) NC IRSTR	 (Itt)
10 AO IWFM	 (Itl) NC IHER
11 SYS R/W IREW (IN) NC ILWD
12 NC NC IREV	 (OUT)
13 NC NC NC
14 A10 SYS R/4 NC IWFM
15 A9 m IWp IREW
16 A8 IERASE	 (Iti) IW1 IER. SE
17 A7 IOFL (IN) IW2 IOFL
18 A6 IFEN	 (IN) IW3 IFEN
19 A5 IGO (IN) IW4 IGO
20 A4 IFBY (OUT) IW5 IFBY
P1 A3 IDBY (OUT) 1W6 IDBY
22 A2 ICCG (OUT) 1W7 ICCG
P3 Al IFMK (OUT) NC IF"K
24 NC NC tic SIG GND
25 C158 NC NC NC
26 RAM R/W NC NC
NC
B-1
CABLE KEY - J1A TO AIM-65 EXPANSION CONNECTOR
J1A pin N	 Expansion Connector # 	 Label
1 15 DO
2 14 D1
3 1: 02
4 12 D3
5 11 04
6 10 D5
7 9 06
8 8 D7
9 N All
10 A AO
11 v SYS R/Q
12 19 TS-9
13 Y
14 h' A 10
15 L A9
16 K A8
17 J A7
18 H A6
19 F A5
20 E A4
21 D A3
22 C A2
23 U Al
24 NC
25 18 U8
26 Z RAM R/W
B-2
k-
CABLE KEY • J2A TO AIM-65 APPLICATION CONNECTOR
J2A pin M	 Application Connector N	 Label
1 NC MS'S
2 NC
3 NC RAM R/17
4 17 IRSTR
5 1z LWD
6 NC
7 4 IWRT (IN)
8 14 m
9 3 IREV	 (IN)
10 2 IWFM (IN)
11 5 IREW	 (in)
12 NC
13 NC
14 NC Sys R/G
15 NC m
16 6 ?ERASE	 (IN)
17 7 IOFL	 (Iii)
18 8 IFEN	 (I:4)
19 15 IGO	 (IN)
20 9 IFBY (OUT)
21 10 IDBY	 (OUT)
2" 11 ICCG (OUT)
23 13 IFMK
24 NC
25 NC
26 NC
B-3I
CABLE KEY - J18 TO PERTEC INTERFACE
JIB Pertec Connector N label
1 837 IRO
2 A37 IR1
3 B39 IR2
4 A39 IR3
5 B40 IR4
6 A40 IR5
7 B42 IR6
8 A42 IR7
9 A35
10 A35 GND
11 I4C
12 NC
13 NC
14 BIG IW;
15 A16 IW1
16 B18 IW2
17 A18 IW3
18 819 IW4
19 A19 IW5
20 B21 IW6
21 A21 IW7
22 A35 GND
23 A35 GND
24 NC
25 tic
26 NC
B-4
4
CABLE KEY - J2B TO PERTEC INTERFACE
J28 N Pertec Connector N Label
1 B27 IRDY
2 A27 IONL
3 A28 IFPT
4 830 ILDP
5 A30 IEOT
6 828 I RIID
7 A4 IWRT
8 A34 IWSTR
9 836 IRSTR
10 A24 IHER
11 B13 ILWD
12 84 IREV
13 NC -
14 B6 I11M
15 812 IREW
16 B7 IERASE
17 Al2 IOFL
18 A13 IFEN
19 A3 IGO
20 B22 IFBY
21 A22 IDBY
22 024 ICCG
23 A25 IFMK
24 835 GND
25 dC -
26 uG -
B-5
DMA CONTROLLER - IC LIST
A side D side
IC	 M TYPE IC N TYPE
1 74L S240 1 21 •.4l
2 74LS245 2 2114L
3 74LS245 3 2114L
4 74LS365 4 2114L
5 74LS365 5 74LS240
6 6 7400
7 7 74365
8 8 74365
9 74LS139 9 74365
10 74LS00 10
11 74LS51 11 2114L
12 74LS85 12 2114L
1.1 74LE85 13 2114L
14 74535 14 2114L
15 74LS85 15 74LSQ4
16 74L04 16
17 7404 17
18 74LS08 18
19 74LS08 19
20 Resistor Pack 20 74109
21 74S169 21 74121
22 74L5169 22 74LS138)
23 74LS169 23 74LS169
24 74LS365 24 74LS169
25 74LS365 25 74LS1G9
26 26 Oi%rrete Components
27 27
26 28
;. 29
3-6
..
CABLE KEY - VIA NO TO DATATRON CLOCK CABLE
VIA 00 Connector N Clock Cable Label
1 13 GND
2 1 USC 1
3 2 2
4 3 4
5 4 8
E 5 TSC 1
7 6 2
8 7 4
9 13 GND
10 NC -
11 NC -
12 8 Utu 1
13 9 2
14 10 4
15 11 8
16 12 TIC 1
17 14 2
18 15 4
19 13 GND
20 13 GND
1
B-1
CACLE KEY - VIA B1 TO DATATRON CLOCK CABLE
VIA k Connector "	 Clock Cable 0	 Label
_	 13 GNO
2	 26 UDC 1
3	 27 2
4	 28 4
5	 29 8
6	 30 TDC 1
7	 31 2
8	 32 4
9	 33 8
10	 NC -
11	 NC -
12	 16 UHC 1
13	 17 2
14	 18 4
15	 19 8
16	 20 THC 1
17	 21 2
18	 34 HOC 1
19	 35 2
20	 13 GND
i
B-8
B-9
CABLE KEY - VIA /2 TO RADAR INTERFACE (R.I.)
VIA i2 pin !
	
R.I. /	 Label
1
2
3
4
5
6
7
- 8
9
10
11
12
13
14
15
16
17
i 18
19
- 20
36 GNO
23 SHIFT
19 S-SELECT
24 RESET
35 D.C.
17 HP FLAG
1 Bit 0
2 1
3 2
17 HP FLAG
NC -
4 Bit 3
5 4
6 5
7 6
8 7
9 8
10 9
11 10
36 GNO
`	 * This connector is located on the circuit board shown in Figure 5-1.
This pin is connected to VIA 02's CAI input.
Note: Unused control ward inputs (pins 20, 21, 22, of the R.I. connector)
must be tied to +12V.
CABLE CONNECTOR SENSE SWITCH CONNECTOR (ON CHASIS) TO VIA 04
Sense Switch Connector # VIA #4 pin # Label
15 - +5V
16 - +5V
17 1 GND
18 20 GND
19 19 S.S.	 D-1
20 18 S.S.	 D-2
21 17 S.S.	 D-3
22 16 S.S.	 D-4
23 15 S.S.	 D-5
24 14 S.S.	 D-6
25 13 S.S.	 0-7
26 12 S.S.	 0-8
27 - NC
28 9 S.S.	 D-9
29 8 S.S.	 D-10
30 7 S.S.	 D-11
31 6 S.S.	 D-12
32 5 S.S.	 D-13
33 4 S.S.	 D-14
34 3 S.S.	 D-15
35 2 S.S.	 D-1G
.r
-T
9-10
x1 a
F
FROM
IC PIN N0.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
IC1A 74LS244 20
1 1 1OA-6
1 1 5B-1 5B-1
2 2 lA-3
2 3A-9 30	 (i-Lo
4 4 AA-5 1A-5
4 4 3A-8 3A-8
6 6 1A-7 1A-7
6 3A-7 3A-7
8 1A-9 1A-9
8 3A-6 3A-6
10 5A-1 GND
11 5A-16 J1B-5 1R4
12 ``
	HV n J1B-18 1W4
13 9 J1B-6 1R5
14 10 J1B-19 1W5
15 11 J1B-7 1R6
16 12 J1B-20 1W6
17 13 J1B-8 1R7
18 14 J1B-21 1W7
19 15 10A-8 1OA-8
19 15 5B-19 5B-15
20 16 cc
IC2A 74LS245 20
1 1 GND GND
2 2 5B-9 5B $Y-	 o
3 3 5B-7 5B-7
4 4 5B-5 5B-5
5 5 5B-3 5B-3
6 6 1A-9 lA	
e 
o
7 7 1A-7 1A-7
8 8 1A-5 1A-5
I ---	 -	 I
- I ---	 tj
B-11
FROM
P	 -NO.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
9 daueGL 1A-3 1A-3
10 7A-1 GND
11 7A-16 J2B-1 IRDY
12
a	
e H?ln- J2B-2 IONL
13 9 J2B-3 IFPT
14 10 J2B-4 ILDP
15 11 J2B-5 IEOT
16 12 J2B-6 IRWD
17 13 GND
14 20B-6 20B-6
19 15 15B-12 15B-14
20 16 5V
IC3A 74LS245 20
1 J2A-7 R/W
10 8A-1 GND
11 8A-16 0
12
addeddin-
ol
13 9 2
14 10 3
15 11 4
16 12 5
17 13 6
18 14 7
19 15 15B-8 15B-8
20 16
IC4A 74LS365 16
1 1 4A-15 4A-15
1	 , 1 5A-1 5A-1
1 1 15B-3 15B-3
2 2 J1A-19 5
4 4 J1A-21 A3
B-12
fI
FROM
0.
FROM
AUGAT NO.
TO
IC PIN NO.
-
TO
(AUGAT N0.
LABEL
A6 6 J1A-23
10 10 J1A-24 A
12 12 J1A-22 A
14 14 J1A-20 A
IC5A 74LS365 16
1 5A-15 5A-15
2 J1A-13 All
4 J1A-15 A
6 J1A-17 A7
10 10 J1A-18 A6
12 12 J1A-16 A8
14 14 J1A-14 A 0
IC9 74LS139 16
9 9 11B-8 11B-8
10 10 12B-8 12B-8
11 11 13B-8 13B-8
12 12 14B-8 14B-8
13 13 5A-3 5A-3
14 14 5A-13 5A-13
15 15 18A-6 18A-6
IC10A 74LSOO 1
1 1 J2A-2 IWRT
2 2 15B-6 15B-6
3 3 11A-3 11A-3
4 4 16A-4 16A-4
5 5 1OA-9 IOA-11
5 5 15B-2 15B-2
5 5 11A-1 11A-1
7 7 1OA-8
B-13
FROM
PIN N0.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
10 12 16A-3 16A-3
10 12 10A-1 1OA-1
IC11A 74LS51 14
1 1 11A-13 11A-15
1 1 11A-12 11A-14
2 2 15B-2 15B-2
2 2 15B-3 15B-3
4 4 15B-4 15B-4
5 J2A-3 RAM R/W
4 4 18A-5 18A-5
6 6 15B-11 156-13
7 11A-8 GND
8 10 15B-9 15B-11
9 11 17A-12 17A-14
10 12 11A-11 lIA-13
10 12 18A-4 18A-4
10 12 J2A-1 CC9
IC12A 74LS85 16
1 1 20A-2 20A-2
1 1 12A-14 12A-14
3 3 13A-6 13A-6
3 3 22B-6 22B-6
6 6 15B-13 15B-15
9 9 12A-11 12A-11
9 9 12A-10 12A-10
11 11 12A-14 12A-14
12 1? 22B-3 22B-3
12 12 4A-11 4A-11
13 13 22B-2 22B-2
13 13 4A-7 4A-7
15 15 4A-9 A-
B-14
4
T'
ib
r
FROM
P	 0.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
15 22B-1
IC13A 74LS85 16
13A-14
14A-6
6 17A-11 17A-13
9 13A-11
13A-12
13A-8 GND
13A-14
13A-10
13 J24-9 ^3$
15 5A-3
IC14A
1 14A-9
3 15A-6
9 10-8 GND
10 SA-13
11 20A-3
11 14A-14
12 5A-5
13 5A-11
15 5A-7
15A 74LS85 16
1 15A-14
3 14A-14
9 15A-11
9 15A-14
10 5A-9
11 15A-8 GND
12 4A-3
13
_	 _	
- -	 I i
B-15
FROM
0.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGHT N0.
LABEL
15 -
IC16A 7 LO
2 16A-5
1 19A-1
1 22B-12
6 236-9
9 11 16A-12 16A-14
3 10 25B-9
13 15 19A-5
13 15 22B-13
I C 1'A 74LO4
1 19A-10 19A-12
1 22B-14
2 17A-5
6 23A-9
8 10 21A-9
9 11 17A-12
13 15 19A-12 19A-1
13 15 22B-15
IC18A
7 18A-8 GND
B-16
FROM
PIN, NO,
FROM
LAAUGAT N0.) ,
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
74L508 14IC19A
2 19A-4
24B-2
25B-2
19A-8 GND
10 23A-2
9 11 19A-13 19A-15
13 21A-2
R-Pack 16
20A-16 +5V
21A-1
5 23A-7
IC21A 74L5163 16
1 22A-1
1 23A-1
2 22A-2
3 3A-9 3A a	 E
23A-3
3 23B-3
4 3A-8
4 23A-4
4 23B-4
5 3A-7
5 23A-5
5 23B-5
6 3A-6
6 23A-6
6 23B-6
7 21A-10
9 22A-9
11 24A-10
12 24A-6
13 24A-12
B-17
FROM FROM
AUGHT N0.
TO
IC PIN NO.
TO
(AUGHT N0.
LABEL
14 24A-4 a
15 22A-10
IC22A 74LS163 16
3A-5
3 24B-3
4 3A-4
4 24B-4
3A-3
24B-5
3A-2
6 248-6
11 24A-14
12 24A-2
13 25A-10
14 25A-6
15 23A-10
IC23A 74LS163 16
7 22A-7
11 25A-12
12 25A-4
13 25A-14
14 25A-2
B-18
I
I
I
r
1
FROM FROM
(AU GAT NO
TO
IC PIN NO.
TO
(AUGHT N0.
LABEL
74LS365IC24A
1 24A-15
1 25A-15
3 5A-9
5 4A-9
7 4A-11
9 4A-5
11 4A-7
13 5A-7
IC25A 74LS365 16
1 25A-15
3 5A-11
5 5A-13
7 4A-13
9 4A-3
11 5A-3
13 5A-5
15 58-4
B-19
pi ns
1,2,3,4,5,6,
7,8,15,16, 6
17 of IC's 18,
28, 3B, 4B, 11B,
126, 13B, & 14B
are Daisy Chained
Some of these
connections are
made on IC36 to
minimize crowding
at IC4B
FROM
Tr pj^N_No.
FROM
AUGHT N0.
TO
IC PIN NO.
TO
(AUGAT NO.
LABEL
2114LIC1B
3 11B-8
IC2B 2114E 18
12B-8
IC38 2114E 18
3 13B-8
2114L 18
14B-8
1 5A-9
2 4A-3
3 4A-13
4 4A-5
4A-95
6 4A-7
7 4A-11
9 Added pin-Lc GND
10 Added pin-H I 15B-10 15B-12
11 5B-9
12 5B-7
13 5B-5
14 5B-3
15 5A-5
16 5A-11
17 5A-7
nx
8-20
r
r
l
I
i
!I
FROM
IC P I ft NO
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGHT NO.
LABEL
IC56
2 5B-3
2 3A-5
4 5B-5
4 3A-4
6 5B-7
6 3A-3
8 5B-9
8 3A-2
10 1OB-1 1OB-8 GND
11 1OB-16 J1B-1 IRO
12 Added pin-Hi J1B-14 IWO
13 9 J1B-2 IRI
14 10 J1B-15 IWI
15 11 J1B-3 IR2
16 12 J1B-16 Iw2
17 13 J1B-4 IR3
18 14 J1B-17 IW3
IC14B 2114L 18
11 IA-9 lA	
^e^o
12 lA-7
13 lA-5
14 lA-3
IC15B 74LSO4 14
1 J2A-8 DMA
5 J2A-4 IRSTR
7 15B-8 GND
B-21
IFROM
PI	 NO.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
IC6B 7400
1 1 9B-3 9B-3 IWRT
4 4 16A-4 16A-4 II WRY`
2 2 7B-3 7B-3 IRSTR (out)
5 5 7B-5 7B-5 IWSTR (out)
3 3 9 11
6 6 10 12
7 7 8 GND
8 19A-9 19A-11
B-22
sE
B-23
i'
f
`	 t 
9
FROM
IC PIN-NO.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
IC20B 74LS109 16
1 22B-11
5 J2B-10 IHER
10 J2A-5 LWD
J2B-11 ILWD
15 22B-10
IC22B 74LS138
5 J2A-6 T2
J2A-7 R/W
IC23B 74LS163 16
1 23B-10
1 23B-7
1 21A-7
3 25B-3
4 25B-4
5 25B-5
6 25B-6
15 246-10
2 24B-2
9 24B-9
1 15B-2
IC24B 74LS163 16
1 24B-7
1 22A-7
15 25B-10
IC25B 74LS163 16
1 25B-7
1 24B-1
15 17A-3
FROM
PI	 N0.
FROM
AUGAT NO.)
TO
IC PIN NO.
TO
(AUGAT N0.
LABEL
J2A-7 9B-2 9B-2 IWRT	 in
J2A-9 9B-4 9B-4 IREV	 (in)
J2A-10 9B-6 9B-6 IWFM	 (in)
J2A-11 9B-10 9B-10 IREW	 (in)
J2A-16 9B-12 9B-12 IERASE	 (in)
J2A-17 9B-14 9B-14 IOFL	 (in)
9B-3 9B-3 J2B-7 IWRT (out)
-5 9B-5 J2B-12 IREV	 (out)
- 9B-7 J2B-14 IWFM (out)
-
-9 J2B-15 IREW (out)
- 9B-11 J2B-16 IERASE	 (out)
—9B-13 9B-13 J2B-17 IOFL (out)
J2A-18 8B-2 8B-2 IFEN	 (in)
J2A-19 8B-4 8B-4 IGO	 (in)
8B-6 8B-6 IFBY	 (in)
8B-10 8B-10 IDBY	 (in)
8B-12 8B-12 (CCG	 (in)
8B-14 8B-14 IFML	 (in)
8B-3 8B-3 J2B-18 IFEN (out)
8B-5 8B-5 J2B-19 IGO (out)
86-7 8B-7 J2A-20 IFBY (out)
8B-9 8B-9 J2A-21 IDBY (out)
8B-11 8B-11 J2A-22 ICCG (out)
8B-13 8B-13 J2A-23 IFMK (out)
J2B-9 7B-2 7B-2 IRSTR (in)
J2B-8 7B-4 7B-4 IWSRT (in)
8-24
VWIRE LIST	 DMA BOARD
JUMPERS J2A-J1A
FROM	 TO	 LABELFROM TO LABEL
CS9J2A1 J1Al2
J2A2 J2AI3
JJ2A14 JlAll SYS R/9
J2A15 J1A25 CS
J2A3 JIA26
B-25
I
s -
In
co
N
J
ti N
1
d
ro
d ^
H
d d'
>
;r,Zaa^
ON
CID
aiL
v+
.r.
U-
r
d ^
w
O
HV
W
2
d Z
F4>.x
p_
3
GJ
CL
0
0
bJ
COCO
Ov
L
A
O
co
O
a
rn
ft-
Cl
d N
>
IA
m
to
J
d'
ti
d ^
>
mN
J
d'
ti
_N
A
V
N
r
v
B-26
%1	 it
o	 O oo	 ao ooy s7
0^^	 eoeoeo	 Z	 Zil o ea 1 e0 o
I I
•^ oZ^loeeoeeej
0
e
}t^lt^tl^jtli^^tg
1.1
u
Ln
0
v
v
V)
CL
0
cL
a-^
4-
(a
CL
U
a
i
ra
O
Co
n
N
m
L
Q1
U-
00	 O
0
00	 °
60
4
0
O oc000000o	 O 0  o o 
l
oo
p r
o 
P
o 
p
op
0^A1^^1^lilili0il^
B-27
	X111101	 V I I I IlIO OIe101010 0 010
	
0e	
^eroocoo 00
ro^ o
00000000000000000000
°+011'11 I I I I I I I I ele'011^1101110
00	
^^\0 0 0 o c o;O e•
Fe ' 	y D •
00
// ^OOOe01/00000000// I
	
0.11 11111	 1	 1
 1^
^21 I 111011111111 a
0^
	-eoeoe0000
Ile
o 	 ^-+ eooeeeeee
^-e^ff e o
	 ^H ^^ D e
v
V)
E
O
4+
4J
O
CID
L
ro
O
m
O
ro
0
F-^
bill
M
1
m
L
rn
LL
o	 o	 0	 0
	
00	 eo
	
ooal000000000eoeeec	 eo/^Ilooe00000l0000e
a
0
o o	 o+
O	 ^
e	 e^^
^^ O
0	 o e'ee aoe o e
s ere o e
e
--j
o e
e e
e 
O ro
v
ro
0
PQ	 i
00
00 ooeoeel000eeeolo
^uul V I I I I^e euleul a eye
♦-eooee•oeoo
^^^ Do
I 
0
e IIINIII:1 11111
oe	 ♦•^	
e o
e.,eluel I I I I I I I nnlneule l u
00	
=eeeooe e
0
0 000 ,,,/11111111111
00	 ^^ •eeeeeeee
1le~1e^ e e
8-28
,k	 N
1F	 ii
0 # E77401
J
V
ti
ll1
vr
V
O
Li
3
v
a
0
.-J
O^ `OJ
C
Z
Q CO
c' a
Q UZ
S-
a
o
b0m
O p
^^ Q
V v
CIO
O
ODo In S-
o
^Q
OD
inJ
O
J
m	 a
	
a
	
rua:)
u
^Z V)
J
ti a- 	 V
0
Q ^
'Cf
N
N
J
ti
B-29
1--O O	 0
	
0 O	 O O
°	 00: 0 q	 o	 o:o o ^o	 °	 °
00oq
	
0 0	 0 °	 ° y
0	 000 0	 0	 000 0	 \
^)OOe	 o-	 ^^000	 °
	
o	 °	 --a 0	 0	 °
	
0 0
	
0 0
0	 coo e	 0	 ::o o	 ° °°°°
	
^J 000	 X000	 °	 °O°	 —^^
°—	 —00  0
0 ° 000 0	 0o aoa e	
° 0^
	 —^
^J o00
	 °	 0001	
a	
o ^	 ,
°
e0
0
	
P^	 -
v 	 1
	
0 0
	
0 O	 -
9	 Doe e	 0	 000 0	 '	 °
	
--aJeeo
	 ^ooe	 ^
	
°	 o	 ° o
	
o	 °---	 >—^
	
0 0	 0 0
0	 000	 0	 0	 000	 a
0
o
0
	
o	 °	 °	 —
4 O	 0 0
	
0	 w
0	 eoo 0	 0	 0e0 e	 _
♦ 000	 ^011^	 °	 ^Y'.
9 0 :00 o	 d o	 o ceo e^
	 0—^
°
0 000	 °	 ^^001	 °
v
ro
uN
O
co
v
V)
n
O
F-
L
roO
m
0
Ln
m
Q)
B-30
N0C9
Ln
E0
m
L^
o0m
0
Q
m
m
vL
rn
e
0
---o
°	 00	 If 10 0
	
°	 C7Y7 0000
—t-1 000000 e--	 000100
0
•	 o
°	 00	 0
—a_^ooeeoo —	 • ^ o^oe000
	 e
—^ 400eeee	 eeeeee
• ee o^
	 ° oo eeee
° ^o^ooece ^_—^ ^ eoeeoo
•1
1	
^=
—° 000^^ ee o	 ° oo	 eeee
	 ..f
o	
^ ooello	 °	 ^ ooe, oeoe
— °^0^0 0000 0	 0 00
	 Oe00
o	
^ 000000	
•	
^ e00001
°	 101160000 0
	
0	 00W,0000
^IOOe00	 0 ^ 000001
0	 0
/
0,'0001	 0	 00	 0/'^	 011
—^J ^0000D0 0	 000000
o ^ \	 Og
000
0	 0 0	 0
	ee 	 e
00
I
r
B-31
RESISTOR NETWORKS
TOP S I DE
4558
2Ka7 POTENTIOMETERS
Figure B-7	 Analog Conditioning Circuit Component Layout
B-32
o-o 0	 o O
O
O	 °O
O O O
O
O O O O
a.; Top View
o-o0
O 0
O °	 O
b.j bottom View
Figure 4-6 Analog Conditioning Circuit PC Pattern
(full scale)
(	 4-33
0
00
v
v
n0
L
IU0
m
rn
0
cn
J0
b
cQ
m
Ch
t,
L7
O^
La-
-^i^u qQ
MN
• W• .
like
MN • •
• v•
—1	 •
MN • •
r
--Ii1LJ •
=ii • •
Z iii
	
o a
• a
f►
 w • 0-
;,lr
--+1^u •
• 0 •
—49 L----D o
00
. o
• • •
. ^o .
6^^0	 s •
•
^' 9 °
—4i L--D o
° 000 0
• t^j o a
Le
• V . e-
:,fir°
--+ 1, u o
=Slit •• •0 0
V 0 o-
ggg0 o
O 0
1^.
-li^^- 	 1e0
• • ow•
. 
^^ r
^Jr •
:M: 00
• V•
—a1	 0
Siiti
o ^o
:ear
v
B -34
^t •
:eee1
	 1
ee--0 0 0
ar O
Zeee
	 I01l ^^
b 0 a
W
b
v
V)
0
co
v
V)
E0
.-)0
cia
i.
b0
co
0
ro
c
rn
Q0
m
L7
0)
LL-
	
^ l	 l1	
0 
1
01	 •	 0	 o-
	
/	 o-
e/
	e 	 e	 e	 e ^--
t Zeee
	 1	 ;eee^
	 l	 teee	 ^^
,^ e	 e	 ^ e r--
0 0 0	 ^• d
	 c 0
Zeee
	 1	 :eel	 ` ?	 =eel	 d
r	
A
I	
O	 •	 O 0-
le s A	 0 0	 0 0
6-35
J ^'
CL
N
co
^	 V7
CD
J	
V)
J
O
J
ti
I
N
J
ti
^r
!L
v
Li
3
ti
G
C
O
T
RS
J
C
Q!
C
O
dC
O
U
L
f4
O
co
L
OE
Ql
C
O
LnC^
o
d
X
w
m
a
L
7
01
LL
3-36
O 1 °° O
0 0	 °^ o
d
I
00 0
o el, oo O o°	 1
N
m
Ql
L
rJ• 1
ro
v
0
v
Vn
n
0
ro
0
co
SS-oE
oj
0N
c
ro
n
x
w
0
°
a
O O^--0 0 0
0 0l a1
o ^
	 a
0 0
O
a o
0r
6
O OI
o^
o E/I
I
IT
-0 1
O C
v
O
4
O
o°
o^
a
B-37
tt c00000:17—^--^ :c000::I
a—s77:o:oc7 0—{:00:::::
°	 o777:co ILAt. ;--0
P—oc:c:c::: v—E::oococc
	:7oo:ooa;
	 p o77:a0000-01
	
p--^o7000070	 0-000007oEO
-b 0070000 C^^ 07::000'0'---°I
	
o--17000:000	 0^0007EC000
°	 o
..	 p
°	 o
°	
o
0
0
0
0
0
0
0
0
d 111 a d d r--Q-----^ d^!! 61' 7^	 a
	
017111111c	 a-1cIc:o:oo
0000700 ^-0 777:::7
	 o o
	
077770700
	 :ooIIIE7o	 ^I
000coo7	 00000 0^ 0
	
--oo0:eo7o0	 ^-000000000 0
	
Fo,^ c0700000	 X007000000
B-38
v
^o
uN
O
v
•rN
EO
O
CIO
i
O
m
iOE
vf
c
0
cbCL
x
w
M
.-r
m
ai
rn
LL-
k
APPENDIX C - GLOSSARY OF SELECTED MNEMONIES
ADC -	 Analog to Digital	 Converter
A/D -	 Analog to Digital
D/A -	 Digital	 to Analog
DW, -	 Direct Memory Access
HER -	 Hard (Parity) Error
IC -	 Integrated Circuit
IER -	 interrupt Enable	 Register
IFR -	 Interrupt Flag Register
I/O -	 Input/Output
LSB -	 Least	 Significant Bit
LWD -	 Last Word
MSB -	 Most Significant Bit
PCR -	 Peripheral	 Control	 Register
VIA -	 Versatile
	
Interface Adapter	 (a	 6522	 IC)
i
t	 C-1
i
