## NOTICE

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

Matthew W. Ganz

# The Ohio State University ElectroScience Laboratory 

# Department of Electrical Engineering 

 Columbus, Ohio 43212

Technical Report 712759-3
February 1981
Contract NASW-3393


National Aeronautics and Space Administration Headquarters Washington, D.C. 20546

## NOTICES

When Government drawings, specifications, or other data ure 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.

Unclassified
sCUMITY CLABSIFICATION OF THIS PAGE (Whon Dete Entered)

16. DISTRIBUTION STATEMENT (of thie Repart)
17. DISTRIGUTION STATEMENT (Of the ebstract entored In Block 20, If different from Raport)
18. SUPPLEMENTARY NOTES
18. KEY WONOS (Continue on peverae olde If neceeaery and fiontify by block number)

AIM-65 microcomputer Analog conditioning circuit
Analog to digital converter
Microformatter
Digital input/output
Expansion motherboard
Direct memory access
20. ABSTRACT (Ëentinue on reverose side If necososery end lidentity by block number)

This report describes a data acquisition system which was designed and implemented 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 conditions along the Earth-space propagation path. The acquired data are stored in digital format on magnetic tape for analysis at the laboratory's computer

SECUMITY CLASSIFICATION OF THIS PAGE(When Date Entered)
center. This data acquisition system is based on the Rockwell AIM-65 Advanced Interactive Microcomputer. It replaces a previous system which used 2 minicomputers 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 diagrams, the theory of operation, and normal operating procedures.

TABLE OF CONTENTS
Page
LIST OF TABLES
LIST OF FIGURES$v{ }^{v}$
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

## Page

AFPENDIX A: DATA ACQUISITION SYSTEM - MEMORY MAP A-1
APFENDIX B: WIRE LISTS, PC LAYOUTS, ETC.
B-1
APPENDIX C: GLOSSARY OF SELECTED MNEMONICS
C-1

## LIST OF TABLES

Table 2.1. VIA Address Selection ..... 11
Table 3.1. A/D Address Selection ..... 23
Table 4.1. Microformatter Commands ..... 32
Table 4.2. AIM-65 VIA Port Assignments ..... 32
Table 4.3. DMA Controller Memory Map ..... 39
Table 4.4. Memory Selection Summary ..... 59
Table 4.5. Read/Write Logic Summary ..... 59
Page
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 - Deiailed 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

Figure 5.1. Radar Control Word Buffers

Figure 2.2. VIA \#2 Port Assignments

Figure 5.3. Radar Control Timing Diagram

70

Figure 5.4. Radar Control Program

75
Figure 6.1.

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 2116B 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 acquisition 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. Al? 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 Eraseable 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.

A 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/O) 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 $1 / 0$ board also contains several counters, timers, and special I/O functions. Chapter 2 gives operational and functional details 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 different enviornmental conditions such as temperature, pressure and ....d 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 sonstructed. 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
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 $1 / 0$ device.

The AIM-65 is also interfaced with a Pertec FT 8840A-9, 9-track digital ia;e 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 heart of the data acquisition system is the AIM-65 microcomputer. This computer was chosen for several reasons. It is very inexpensive, 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 64 K 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 transierred to these output devices using the user-available subroutines mentioned above.

The AIM-65 also has ore 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 $1 / 0$ ports. The coliputer sees each port as an ordiriary 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 1/O board and is treated in more detail in Chapter 2.

The AIM-65's manufacturer, Rockwe11, has published several books which provide quite extensive hardware and software support for the computer. They are The AIM-65 User's Guide, The P6500 Hardware Manual, The R6500 Programming Guide, and The A:i 65 Monitor Program Listing. These items are referenced as items [1], [2], [3], and [5] respectively, in the bibliography.


Ficure 1-1 Uata Acquisition System

## II. DIGITAL !/O 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 $1 / 0$ 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 VIAs are located in the AIM-65's memory. The VIA supplied with the computer occupies the addresses (memory locations) labeled A0日D through ADDF (in hexadecimal format). Each of the VIAs on the digital I/O board also occupies 16 memery 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 simultaneously 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-1(b) shows the memory map of a typical VIA's organization. The VIA (\#3), 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.


Figure ©-1 (a) Partial AIM-65 Memory Map
(b) Detalled Memory Maf of VIA \#3
(c) Detail of Port-Direction Register Relationship

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 progranmed 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 $\emptyset$ 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+(11111111) |
| :--- | :--- |
| STA 8133 | ;DIRA $+A$ |
| LDA \#00 | ;A+(00000000) |
| STA 8132 | ;DIRB + A |

7

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 $\emptyset$ written in this same A port bit causes a logic $\emptyset(\approx \emptyset V)$ to appear on the corresponding output port bit. Thus, to make all of our A port bits go to the logic $\varnothing$ state, a typical program segment might look like:

$$
\begin{array}{ll}
\text { LDA \#DD } & ; A+(\varnothing 0000 \rho D 0) \\
\text { STA } 8131 & ; \text { APort } \leftarrow A
\end{array}
$$

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 are 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 CB1, 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.

## C. Hardware Details

Standard address decoding techniques are used to select the digital l/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 bard 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\left(2^{16}\right)$ 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 CS8 in Figure 2-2. This line is normally at the logic 1 state. It only assumes the logic $\emptyset$ state when an address between 8000 and 8 FFF appears on the address bus (i.e. during a read or write operation to any memory location between 89010 and $8 F F F$ ).

The CS8 line and the five next most significant address lines (A11, A10, A9, A8, and A7) are connected to the input of a 6-bit magnitude comparator. This comparator is composed of two cascaried 74LS85 4-bit comparators ( $Z_{1}$ and $Z_{2}$ ). The address lines mentioned above are connected to the $A$ inputs of the comparators and the $B$ inputs are connected to switches S1-S6. These switches allow each $B$ input to be set to either the logic 1 or the logic $\square$ state. When one of these swithches is in the "ON" position, the corresponding B input is grounded (logic D). The same switch in the "OFF" position causes the $B$ input to be pulled up to +5 VDC (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
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_{3}$. When $Z_{3}$ is enabled, it selects one of the eight V.I.A.s. The V.I.A. selected depends on the status of the select inputs to $Z_{3}$ (A6, A5, aind 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, $\phi 2$, $\overline{I R Q}, \overline{R E S}$, ) and data bus (DBD-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 $\overline{C S}$ line is low. This $\overline{\mathrm{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, $A 3, A 2, A 1$, and $A \varnothing$, are connected to RS3, RS2, RS1, and RS@ of each V.I.A. (the RS stands for Register Select). These four lines select one of the V.I.A.'s 16 internal registers. A dataword 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 55 are closed ( ON position). Referring to Table 2-1, we see that this sets our address range to $8100-817 \mathrm{~F}$.

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 executinา this would be (see Section 2B):

TABLE 2-1

1

$$
m \square
$$

W


Figure 2-2 VIA Board

## I <br> I



VIA Connection Details

Figure 2-3

Thus, 8131 would be the address appearing on the address bus. The address bus state would be:


Since (A15, A14, A13, A12) $=(1, \varnothing, \varnothing, \varnothing), \overline{C S 8}$ will be at logic ด. Now ( $\left.\overline{C S E}, A_{11}, A_{10}, A_{9}, A_{8}, A_{7}\right)=(\varnothing, \varnothing, \varnothing, \varnothing, 1, \varnothing)$, and switches $\left(S_{1}, S_{2}, S_{3}, S_{4}, S_{5}, S_{6}\right)$ also equal ( $\left.\varnothing, \varnothing, \varnothing, \varnothing, 1, \varnothing\right)$, thus the same pattern of 1 's and $\varnothing$ 's appears at both the $A$ and $B$ inputs of the comparator. The $A=B$ output (pin 6, 22 ), will go to the logic 1 state. This enables $Z 3$. Now, the $C, B$, and $A$ inputs to $Z 3$ are set to $D, 1$, and 1 respectively, (i.e. the state of $A_{6}, A_{5}$, and $A_{4}$ respectively). Since $Z 3$ is enabled and $(C, B, A)=(0,1,1)$, the $Y 3$ output goes low (logic $D)$; thus, the CS line of V.I.A. \#3 goes low and V.I.A. \#3 is enabled. Since (A3, A2, A1, A $A$ ) = (RS3, RS2, RS1, RS $\varnothing)=(\varnothing, \emptyset, \emptyset, 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 / \bar{W}$ line. Since this line is in the write (logic $\emptyset$ ) 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 $1 / 0$ 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 $1 / 0$ subsystem, including the PC board layout, is given in the appendices.
111. ANALOG IMPUT SUESYSTEM
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 converters 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 AD7574JN 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 softdetalls 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 $\emptyset \mathrm{V}$ and 10 V 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:
Resolution $=\frac{V_{\text {max }}-V_{\text {min }}}{\# \text { of digital intervals }}=\frac{1 \varnothing V-\varnothing V}{255}=.039 \mathrm{~V}$

Most of the analog signals presented to the data acquisition system are in the -5 V to +5 V range. Since the $A D 7574$ requires an input in the $\emptyset V$ to 10 V range, the analog signals must be shifted up by $5!$ to make them compatible with the ADC. A board called the analog conditioning board provides this 5 vilt level shift. This board is located in a chassis, separate from the A/D board. The analog conditioning board contains 16 identical circuits, each with the transfer function:
$V_{\text {out }}=V_{\text {in }}+5 V$.
A few of the analog signals are in the 0 V to 5 V range. By changing the configuration of a few jumpers on a particular analog conditioning circuit, the circuit's transfer function can be changed to
$V_{\text {out }}=2\left(V_{\text {in }}\right)$.

This allows the $\emptyset V$ to +5 V input range to become transformed into our desired $\emptyset V$ to $+10 V$ 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 $\emptyset$ through r. 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 800. The fourth digit is the channel number. Thus, ADC \#D is addressed by 8000, ADC \#1 by 8001, etc., up to 890 F for ADC \#F (\#15 in base 10).

Before an $A / D$ conversion can be made, the $A D C$ must be reset. This is done simply by "reading" the ADC. For example, ADC \#9 can be reset by the instruction:

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 is initiated by "writing" to the ADC's address. The conversion takes approximately 15 us . 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 \#D and transfer the result to the accumulator might look like:

| LDA 8000 |  | Reset converter (During initialization procedure.) |
| :---: | :---: | :---: |
| - |  |  |
| STA 800p |  | Start conversion |
| NOP NOP |  |  |
| NOP NOP | Delay 16us (2us/NOP) |  |
| $\left.\begin{array}{l}\text { NOP } \\ \text { NOP }\end{array}\right\}$ |  |  |
| NOP |  |  |
| NOP |  |  |
| LDA 8009 |  | A + Result |

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 stiuroutines to display them. A program which will display the outpur of an ADC on the AIM-65's display is given below. The letter $X$ is used in place of the channel number ( $\mathcal{D}-\mathrm{F}$ ) of the $A D C$ to be calibrated.


When this program is run, a 2-digit hexadecimal number (which is the $\varepsilon$-bit output of the $A D C$ ) 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 $\emptyset . \emptyset V$ applied to the input to the channel, adjust the OFFSET ADJ. potentiometer until the number shown on the display is 80 or flickers between 7 F and 80.
2) Apply +5.0 V to the channel input. Adjust the GAIN potentiometer 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 $Q V$ or +5 V applied to the input.

This completes the operational description of the analog input section
C. Hardware Detalls

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 $A D C$ determine the internal clock rate and, thus, the $A / D$
conversion time. Details of the selection criteria for the R-C combination can be found in the manufacturer's data sheet. The values selected ( $R=125 \mathrm{~K} \Omega, C=100 \mathrm{pF}$ ) 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 $\emptyset$ appears at the $\overline{\mathrm{CS}}$ input (pin 16). The state of the $\overline{\mathrm{RD}}$ input (pin 15) determines what function the I.C. will perform once it is selected. A conversion is started when a logic $\emptyset$ pulse is applied to $\overline{C S}$ while $\overline{R D}$ is at logic 1. When the conversion is complete, the result can be read by pulling both $\overline{C S}$ and $\overline{R D}$ to logic $\varnothing$. 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 -10 V . 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.0 V into our desired -10.0 V reference. A pnp transistor placed in the inverter's feedback loop allows the circuit to tolerate substantial loading (approx. 100 mA ). This reference supply circuit is located on the A/D board.

The AD7574JN accepts an analog input in the 0.0 V to 10.0 V 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 -5 V to +5 V range, a conditioning circuit is required to shift each analog signal up by 5 V . 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 ICIA 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.1 \mathrm{~K} \Omega$ is determined by the equation:
$\left(R_{1} / / R_{2}\right) \simeq R_{3} / /\left(R_{4} / / R_{5}\right)$


Figure 3-1 AD7574JN Configuration


Figure 3-2 Reference Supply


Figure 3-3 Analog Conditioning Circuit
1
21

If 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:
$V_{1}=-v_{\text {in }}+V_{\text {offset }}^{*}$

The second stage of the analog conditioning circuit is an inverting amplifier with the transfer function:
$V_{0}=-V_{1}+5 V$
Combining equations (1) and (2) gives us the overall transfer function of the conditioning circuit:
$V_{0}=-\left(-V_{\text {in }}+V_{\text {offset }}\right)+5 V$
$V_{0}=V_{i n}+5 V-V_{\text {offset }}$
Since a few analog signals with limits of $O V$ to 5 V were anticipated, jumpers $w_{1}$ and $w_{2}$ were added to the conditioning circuit. Removing these jumpers provides a second stage transfer function of:
$v_{0}=-2 v_{1}$
Combining equations (1) and (4) yields the overall conditioning circuit transfer function:
$V_{0}=2 V_{i n}-2 V_{\text {offset }}$
Each of the op-amps in the conditioning circuit requires several

[^0]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 R1l 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}-A_{4}$. The $B$ inputs are all grounded. The $B$ inputs corresponding to $A_{11}, A_{10}$, and $A_{g}$ are grounded by jumper wires on the $A / D$ board. By jumpering one or more of these B inputs to +5 V (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-800F |
| 0 | 0 | 1 | 8200-820F |
| 0 | 1 | 0 | 8400-840F |
| 0 | 1 | 1 | 86月D - 860F |
| 1 | 0 | 0 | 8800-880F |
| 1 | 0 | 1 | 8ADD - 8ADF |
| 1 | 1 | 0 | 8 CDDD - 8CDF |
| 1 | 1 | 1 | 8Ep 0 - 8EAF |

TABLE 3-1

The $A=B$ output of this 8-bit comparator is connected to the G 1 "enable" input on each of two 74LS138 1 of 8 decoders (I.C. 3 and I.C. 4). CS8 is connected to the G2A "enable" input of eact. decoder. A3 is connected to the $\overline{G 2 B}$ "enable" input of I.C. 3. A3 is inverted before it is applied to the $\overline{\mathrm{G} 2 \mathrm{~B}}$ "enable" input of I.C. 4 . A particular decoder is only enabled when G1 is at logic 1, and toth G2A and G2B are at logic 0 . When one of the two decoders is enabled, it selects one of eight ADCs by pulling the ADC's $\overline{C S}$ line to logic $\varnothing$.

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, $\overline{\mathrm{CS}}$ and KD . The address decoders (just discussed) control the ADCs' $\overline{\mathrm{CS}}$ (Chip Select) lines. The $\overline{R D}$ line should be at logic $\emptyset$ during a "read" operation, and logic 1 during a "write" (start conversion) operation. The microcomputer's $\overline{R / \bar{W}} 1$ ine has these desired states and therefore it is directly connected to the $\overline{\mathrm{RD}}$ pin of each ADC. Thus, when the computer performs a STA (write) operation to an $A D C$, the $\overline{C S}$ line of that $A D C$ is pulled to logic $\varnothing$, while the $\overline{R D}$ 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 $\overline{C S}$ and $\overline{R D}$ lines of that $A D C$ are set to the logic $\emptyset$ 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


Figure 3-4 A/D Converter System
step would be a STA 8001 operation. When 8001 appears on the address bus, CS8 is at logic $\emptyset$, our comparator's output (pin 6, I.C. 2) is at logic 1 and $A 3$ is at logic $D$. Thus I.C. 3 is enabled. Since ( $A_{2}, A_{1}, A_{0}$ ) $=(0,0,1)$, pin 14 of I.C. 3 (and therefore $\overline{C S}-$ pin 16 of ADC \#1) goes to logic $\emptyset$. During a STA operation, $\overline{R / \bar{w}}$ is a logic 1 and an $A / D$ conversion is started on ADC "1.

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 $\overline{\mathrm{RD}}$ pin is at logic $\emptyset$. 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 $\overline{R / W}$ line is low, the enable line to I.C. 5 is pulled to logic $\varnothing$ and our data is transferred to the computer 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.

## IV. DMA COHTROLLER 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 substantial 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 understand. Some examples of tape deck operations are presented with flow diagrams and program listings of the programs which perform the operations. 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 transport and the microformatter. The tape transport consists of the electronic and servomechanical systems which cause tape motion and the transfer of data to and from the tape. The microformatter is a device which acts as an interface between the tape transport and the controller (the DMA Controller in this case.)


Figure 4-1(a) DMA Controller Block Diagram

Figure 4-1(b). DMA Controller - Detailled Block Diagram

Figure 4-1 (b) shows a detailed block diagram of the DMA Controller. Each block in this diagram has a schematic diagram and discussion explaining 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 zontrol 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 $\rho$ state.

We will first examine the controller to microformatter signals. Those which concern us are [4]:

IFEN-FORMATTER ENABLE

- This signal, when low (logic $\emptyset$ ) 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 $\emptyset=$ Write Logic 1 = Read
IREV-REVERSE/FORWARD
- This signal specifies forward or reverse tape motion. Logic $\emptyset=$ Reverse Logic 1 = Forward
IWFM-WRITE FILE MARK
- This pulse causes a Write File Mark to be written on the tape if IWRT 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.

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 microformatter after all of the necessary input signals to the microformatter have been set to their desired states.
IWB-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 ty 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 microformatter 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 excecution 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 $\emptyset$ ) each time a word (byte) is written onto the tape.

TABLE 4-1 Microformatter Commands

| Operations | IREV | IWRT | IWFM | IERASE |
| :--- | :---: | :---: | :---: | :---: |
| READ FORWARD | 1 | 1 | 1 | 1 |
| READ REVERSE | 0 | 1 | 1 | 1 |
| WRITE | 1 | 0 | 1 | 1 |
| WRITE FILE MARK | 1 | 0 | 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 Adaress | Bit | Function |
| :---: | :---: | :---: |
| ADOD | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | IFBY <br> IDBY <br> ICCG <br> LWD <br> IFMK <br> IRSTR <br> IGO |
| ADD 1 | $\begin{aligned} & 0 \\ & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | DKA <br> IWRT <br> IPEV <br> IWFM <br> IREW <br> IERASE <br> 10FL |

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 encounters a file mark.
IRD-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 connectec 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 operating procedures can be presented. The most important of these signals is the 1 ine labled DMA. 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 DMA line is in the logic $\emptyset$ 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 DMA line can only be in one of the two states at a particular instant, it is impossible for both the computer and the tape deck to have control of the DMA memory at the same time.

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 contain's the status signals from the tape deck. These devices and the significance of their addresses 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 taje, the starting address and block length must first be loaded into the DMA controller. The DMA line is then pulled to the logic $D$ state (by writing a bit into bit $\emptyset$ of A $\varnothing 1$ ). 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 DMA 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(a) 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 $\emptyset$ of location 8301.

For convenience, the starting address is nornally set to be the first byte of memory, 9090 . Thus ( 900$)_{16}$ should be loaded into the starting address counter. This can simply be accomplished by the following program segment:

```
LDA #DD A+(0000000D)
STA 8300 Adr. Ctr.-Lo*A
STA 8301 Adr. Ctr.-Hi+A
```

| nemest | Resper | *", | st 6 | ens | \%ta | 8ts | 0t2 | *t: | ato |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| me | Sextemen | ${ }^{1}$ | ${ }^{* 6}$ | ${ }_{\sim} 5$ | $\ldots$ | ${ }_{4}$ | ${ }^{2}$ | «1 | $\cdots$ |
| sm | cixemem | $\times$ | $\times$ | $\times$ | $\times$ | «n | ${ }_{*}^{*}$ | c, | ${ }^{\circ}$ |
| ens | ${ }_{\text {gra cme }}$ | ${ }^{\text {a }}$ | \% | 0 | ${ }^{\circ}$ | ${ }^{*}$ | ${ }_{\sim}$ | ${ }_{\sim}$ | ${ }^{\prime \prime}$ |
| ann | git cim. | $\times$ | $\times$ | $\times$ |  | ${ }^{\text {an }}$ | aco | $\ldots$ | ${ }^{\circ}$ |

$\begin{aligned} A C & =\text { Address Counter } \\ B C & =\text { Byte Counter } \\ X & =\text { Don't Care }\end{aligned}$
(a) Address Counter
(b) Byte Counter
Figure 4-2

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 ls state (FFF), it sends the IWLD (last word) pulse to the microformatter. This causes the termination 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 l's complement is obtained by sinply roplacing 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 1824 (base 10):
$(1024)_{\text {Base } 10}=(400)_{\text {Base } 16}=(01000000000)_{\text {Base }} 2$
the 1 's complement of this number is given by:

therefore, the 2 's complement is given by:

$$
(101111111111)+1=(110000000000)=(\mathrm{COD})_{16}
$$

Thus, we must load CDD (hex) into the byte counter to dump 1024 bytes of memory 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 $1 \varnothing 24$ bytes of data is given by:

LDA \#øD A+00日0, 0 DD
STA 8303 BYTE CTR.-LO $-A$
LDA \#DC A+Q9001100
STA 8302 BYTE CTR. $-\mathrm{Hi}+\mathrm{A}$

When the byte counter reaches the all l'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 $\emptyset$ when the microformatter is ready to accept a command.
IONL-ON LINE
- This line is at the logic $\emptyset$ state whenever the microformatter is on line.
IFPT-FILE PROTECT
- This line is at the logic $\varnothing$ state if the tape on the deck has had its file protect ring removed.
ILDP-LOAD POINT
- This line is at the logic $\emptyset$ state when the tape is at the load point (beginning of tape).
IEOT-END OF TAPE
- This line is at the logic $\emptyset$ state when the tape has been advanced to its end.
IRWD-REWINDING
- This line is at the logic $\varnothing$ state while the tape is rewinding.
IHER-HARD ERROR
- A logic pulse appears on this line whenever a word with a parity error is written onto or read from the tape.

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 8307 . 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 computer, 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 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| HER | - | IRWD | IEOT | ILDP | IFPT | IONL | IRDY |

Figure 4-3 - Status II..ر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 $\overline{D M A}$ 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 operations: 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.

TABLE 4-3 - DMA CONTROLLER MEMORY MAP

| ADDRESS | FUNCTION |
| :---: | :---: |
| 8300 <br> 8.3 L <br> 8302 <br> 8303 <br> 8304 <br> 8305 <br> 8307 | ADR. CTR. - LO <br> ADR. CTR. - HI <br> BYTE CTR. - HI <br> BYTE CTR. - LO <br> LWD flip-flop CLR <br> HER flip-flop CLR <br> Status Input Reg. (Figure 4-3) |
| $\begin{gathered} 9000 \\ \downarrow \\ 9 F F F \end{gathered}$ | DMA memory $(4 \mathrm{~K} \times 8)$ |
| A0DO <br> $+$ <br> A001 | Alm-65's I/O Ports (Fig. 4-2) |

This is done by the following program:

| LDA | \#FF | A+(11111111) |
| :---: | :---: | :---: |
| STA | A003 | DIRA+A |
| STA | A001 | A Port+A |
| LDA | \#80 | A+(100.0000) |
| STA | A0g2 | DIRB+A |
| STA | A000 | B Port+A |

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 utnil 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 0223 | LDA | $\left.\begin{array}{r} 8307 \\ \# 10 \end{array}\right\}$ | Stop if end of tape |
| :---: | :---: | :---: | :---: |
| 0225 | BNE | 0228 |  |
| 0227 | BRK |  |  |
| 0228 | LDA | 8307 7 |  |
| 0228 | AND | \#02 $\}$ | Stop if off line |
| D220 | BEQ | 0230 |  |
| ¢22F | BRK |  |  |
| 0230 | LDA | 8307 |  |
| ¢233 | AND | \#D1 $\}$ | Wait if busy |
| D235 | BNE | 0230 J |  |

I
1


Figure 4-4 Status Check Subroutine Flowchart


4

| 0237 | LDA | A000 ${ }^{\text {a }}$ |  |
| :---: | :---: | :---: | :---: |
| 123A | AND | \#01 \} | Wait if not ready |
| Q23C | BEQ | 0237 ) |  |
| $\emptyset 23 \mathrm{E}$ | RTS |  | Return |

This subroutine occupies locations 022 through D23E in the AIM65'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 flipflops. The necessary control lines (IWRT and IFEN) and the DMA line are then pulled down to the logic $\varnothing$ state, the IGO pulse is sent, ard 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 |
| :---: | :---: | :---: | :---: |
| 0303 | LDA | \#00) |  |
| 8305 | STA | 8390 |  |
| 0308 | STA | 8301 | (000) into Adr. Ctr. |
| 930 B | STA | 2303 | (COD) into Byte Ctr. |
| D30E | LDA | \#DC |  |
| 0310 | STA | 8302 |  |
| 0313 | STA | 8394 \} | Clear HER \& LWD flip-flops |
| 0316 | STA | 8305 |  |
| 0319 | LDA | \#7C |  |
| 0318 | STA | A001 | IWRT \& IFEN \& DMA to logic $\emptyset$ |
| Q31E | LDA | \#DD) |  |
| 0320 | STA | ADOD | Send IGO pulse |
| 0323 | LUA | \#80 |  |
| 0325 | STA | A000 |  |
| 0328 | LDA | A00D |  |
| Q32B | AND | \#89 | Wait for IFBY=LWD=logic l |
| 932D | CMP | \#109 |  |
| 932F | BNE | 0.328 |  |
| Q331 | LDA | \#FF | IWRT \& IFEN \& DMA to logic 1 |
| $\square 333$ | STA | ADD1 |  |
| 0336 | BRK |  | Stop |



Figure 4-5. Write Operation Flow Diagram

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 $\theta$ 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 | Check Status Check subroutine |
| :---: | :---: | :---: | :---: |
| \$353 | LDA | \#5B |  |
| $\square 355$ | STA | A001 | IFEN \& IERASE \& IREV to logic 0 |
| 0358 | LDA | \#80 | IGO to logic $\emptyset$ |
| 035A | STA | A006) |  |
| 0.35D | LDA | \#89 | IGO to logic 1 |
| 035 F | STA | A000 ${ }^{\text {a }}$ |  |
| Q362 | LDA | A908 |  |
| 0365 | AND | \#01 | Go back to 0362 if IFBY=0 |
| 0367 | DEQ | 0362 |  |
| D36A | LDA | \#FF | IFEN \& IREASE \& IREV to logic 1 |
| 036C | STA | A901 |  |
| D36F | BRK |  | 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 stown in Figure 4-7. The byte counter is not used during a read operation. Therefore, only the address counter needs to be preset (normelly to D0D). The operation begins when the computer pulls the IFEN and DNA lines to logic 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 DFK are returned to logic 1 and the computer stops. A program listing of the read program is given below:


Figuie 4-6. Space Back 1 Record Flow Diagram

| 0380 | JSR | 0220 | Check status |
| :---: | :---: | :---: | :---: |
| 0383 | LDA | \#00 |  |
| 0385 | STA | 8300 | Set Address Ctr. to 000 |
| 0388 | STA | 83015 |  |
| 038B | STA | 8304 | Clear last word flip-flop |
| 038 E | LDA | \#7E | IFEN \& DMA to logic 0 |
| 0390 | STA | A001 |  |
| 0393 | LDA | \#00 |  |
| 0395 | STA | A000 |  |
| 0398 | LDA | \#80 | Send IGO pulse |
| 0.39A | STA | A090) |  |
| 039 D | LDA | $A 9 D 07$ |  |
| 93AD | AND | \#181 | Wait until IFBY=1ogic 1 |
| $03 A 2$ | BEQ | 03903 |  |
| D3A4 | LDA | \#FF | IFEN \& DMA to logic 1 |
| 0346 | STA | A00i |  |
| 0349 | BRK |  | Stop |



Figure 4-7. Read Program Flow Diagram

The data which are read from the tape are transferred to a contiguous block of the DIM controller's memory. This block starts at the address which was 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,9091, \ldots$

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 presented in the previous section will make it much easier to understand the hardware features of the DMA controller. The DMA controller consists 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


Figure 4-8 DMA Board Control I/O Buffering
because the AIM-65's VIA outputs are each capable of driving only 1 TTL load. The microformatter's inputs present a greater lcad. 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 374365 IC's which are always enabled ( $\bar{G}_{1}$ and $\bar{G}_{2}$ are permanently tied to ground).
2. The Address Bus

The address bus ( $\overline{\operatorname{CSB}}$ and All-A $)$ 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 highimpedance state (isolating the controller from the computer) whenever the $\bar{G}_{1}$ and $\bar{G}_{2}$ 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 $\overline{\text { DMA }}$ line from the AIM-65 VIA. Thus, the DMA 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 vetween 8300 and 330 F 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 presented later in this section.


Figure 4-9 DMA Address Buffering and Partial Decoding
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/W 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 $\emptyset$ (WRITE) and transferred in the opposite direction when this line is logic 1 (READ).

IC3A's enable input (pin 19) is connected to the inverted output of $\frac{1}{2}$ of IC 11A. The trensceiver is enabled only when: (1) the SYS DMA line is at the logic $\emptyset$ state (i.e. $\overline{D M A}=\operatorname{logic~1)~and~(2)~either~} \overline{830 \mathrm{X}}$ or CS9 is at the logic 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 $\overline{C S 9}$ line, like the CS8 line mentioned previously, is an output from the AIM-65's internal address decoders. It assumes the logic $\varnothing$ 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 $\overline{83 \emptyset X}$ line is the complement of the 830 X line shown in Figure 4-9. Thus, IC3A is only enabled when we address a register in either the 8300-830F or the 9000-9FFF range (while DKA $=1$ ).

Figure 4-10 also shows 2 biairectional 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 ( $\overline{\mathrm{DMA}}=$ logic $\theta$ ). The state of the IWRT line determines the direction of data transfer. When IWRT=logic $D$, 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


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 (B1-B8 are inputs, A1-A8 are outputs). The ouiputs of this transceiver are directly connected to the data bus.

The SIR is only enabled when 830x, A2, A1, and AD 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 $\emptyset$ 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 ( $\frac{1}{2}$ of IC2@B). The output 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 DMA 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 controller. This memory is comprised of eight 2114-L static RAM ICs. Each IC contains 10244 -bit registers ( $1 \mathrm{~K} \times 4$ ). They are connected in pairs (IC1B with IC11B, IC2B with IC12B, IC3B with IC13B, IC4B with IC14B), and each pair then has 10248 -bit registers. Thus, there is a total of 4096 eight-bit meniory registers.

The data lines from the RAM ICs are directly connected to the buffered data bus. Ten buffered address bits, A9-A $\emptyset$, are connected to the address inputs of each memory IC. These ten lines address the


[^1]
Figure 4. 12 DMA Memory and R/W Logic
$1024\left(=2^{10}\right)$ registers within each memory IC. Our two most significant bits, $A_{11}$ and $A_{10}$, are used to select one of the four pairs of memory ICs. A 1 of 4 decoder ( $\frac{1}{2}$ of IC9A) is used for this selection process. This decoder (and thus the memory) is enabled when $\overline{C S S}$ or DMA is at the logic state, i.e., when reading or writing from 9000-9FFF or during DMA operations. When the decoder is enabled, it examines its $2 A$ and $2 B$ inputs which are connected to $A_{10}$ and $A_{11}$. The state of these two lines determines which 1 of the 4 outputs ( $2 Y 0,2 Y 1,2 Y 2, \& 2 Y 3$ ) will be pulled low. When one of the outputs is low, a pair of memory ICs is selected by pulling their $\overline{C S}$ (Chip Select) inputs (pins 8) to logic $\emptyset$. 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 ICIIA) is connected to the $\overline{W E}$ (Write Enable) line of each memory IC (pin 10). Table 4-5 summarizes the function of the read/write logic. When the WE and $\overline{C S}$ 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 $\overline{C S}$ is a logic $\theta$ while WE 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 DMA line is at logic 1 , the WE line assumes the state of the computer's RAM R/W line and the computer provides the read/write signal. During a DMA operation (i.e. DMAA $=$ logic $\varnothing$ ), the WE 1 ine only becomes a logic $\emptyset$ 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 DIM 1 ines are generated. The DMA ine is brought from the computer to pin 1 of IC158. This signal is inverted twice and the outputs of these inverters are used as our SYS DMA and SYS DMP. signals. These signals are then used in several places throughout the DMA controller. Note that the SYS D.MA line is at the same state as the DWMA line but has the ability to drive several TTL inputs (Remember the DTMA line can only drive 1 TTL input since it comes from a VIA).
6. Address and Byte Counters

We now must see how the 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 transferreci, 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-bit 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 $\overline{D N A}$ line goes to logic 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 DPM line is at logic $\emptyset$, these buffers are enabled and the output of the address counter appears on the address bus. Remember, when SYS DMA is at logic 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. is 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 tyte counter reaches the all logic is state, the RCO (Ripple Carry Output) of IC 25 ( 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 (1/2 of IC 2DB) when the counter indicates that the last byte hes been sent. The inverted RCO

> TABLE 4-4 - Memory Selection Summary

| Pin 6 <br> IC18A | $A_{11}$ | $A_{10}$ | Address Range | ICs Selected |
| :--- | :--- | :--- | :---: | :--- |
| 1 | $X$ | $X$ |  | none |
| 0 | 0 | 0 | $9000-93 F F$ | $4 B \& 14 B$ |
| 0 | 0 | 1 | $9400-97 F F$ | $3 B \& 13 B$ |
| 0 | 1 | 0 | $9800-98 F F$ | $2 B \& 12 B$ |
| 0 | 1 | 1 | $9 C 00-9 F F F$ | $1 B \& 1: B$ |
|  | $X=$ Don't Care |  |  |  |

TABLE 4-5 - Read/Write Logic Summary

| LINE | DMMA | RAM R/W | IWRT | IRSTR | WE |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 | 1 | $x$ | $\chi$ | 1 |
|  | 1 | 0 | $x$ | $x$ | 0 |
| STATF | 0 | $x$ | 0 | $x$ | 1 |
|  | 0 | $x$ | 1 | 1 | 1 |
|  | 0 | $x$ | 1 | 0 | 0 |
|  | $x=$ Don't Care |  |  |  |  |



Figure 4-14. Byte Counter
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 as 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 Gl input (pin 6) is at logic 1 and both $\overline{\mathrm{G} 2 \mathrm{~A}}$ and $\overline{\mathrm{G} 2 \mathrm{~B}}$ (pins 5 \& 4) are at iogic $\varnothing$. G1 is connected to the 830 X line (which goes high when $83 \varnothing 0-830 \mathrm{~F}$ is addressed). The computer's R/W line (which goes to logic $\emptyset$ during STA operations) is connected to $\overline{\mathrm{G} 2 \mathrm{~A}}$. The computer's $\overline{\phi 2}$ clock signal is connected to the $\overline{\text { G2B }}$ input. This signal becomes a logic $\emptyset$ 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 $\overline{\phi 2}$ 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 $\emptyset$. Thus, a STA 8300 operation causes a logic $\emptyset$ pulse to appear on $Y$ ( $\emptyset$ in 15), STA 8301 causes a pulse on $Y 1$, etc.

A STA $83 \emptyset 4$ operation causes a logic $\emptyset$ pulse on Y4 (pin 11). This output is connected to the clear input of our HER flip-flop (Figure 4-11). Therefors, 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 analysis much easier. Let us first ignore IC16A and IC17A. We will also assume that pin 8 of $I C 6 B$ is at the logic 1 state (which it will be during the loading operations).

The 74LS163 counters (Figures 4-13 and 4-14) require their load inputs to be logic during a load operation. If, while the load line is low, a positive (logic $\emptyset$ 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 $\varnothing$ pulse will appear at the $Y \emptyset$ output of IC22B. This causes both the ADR. CTR-LO CLOCK and ADR. CTR-LO LOAD signals to also momentarily go to logic $\emptyset$ (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 $\emptyset, 2$ inverters are placed in the load signal's path to cause a small delay (approximately 50 nanoseconds) for the load pulse. Thus, when $Y \emptyset$ of 1 C22B 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 $\emptyset$ 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 $=\operatorname{logic} \theta$ ), 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 IURT line because both read and write strobes are sent by the microformatter during 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 IC6B), 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. A complete wire list giving all of the wire wrap connections is presented


Figure 4-15. Address and Byte Counters - Load and Clock Logic
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 generate 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 +12 V on an $\mathrm{I} / 0$ pin to be a logic $\emptyset$. $\emptyset \mathrm{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 TFL levels ( +5 V logic) to the +12 V logic the interface requires. We must also change the logic signals which go from the interface to the VIA from $+12 V$ logic to +5 lcgic to avoid damaging the VIA inputs.

There are 4 signals which run from the VIA to the interface which must be changed frori the $g V$ to $+12 V$ 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 $1 K_{\Omega}$ resistors. This circuit is contained on a small printed circuit


Figure 5-1 Radar Control Word Buffers
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 $\emptyset V$ to +5 V range from the $\rho V$ to 12 V range by changing the voltage on their pull-up resistors (in the interface) from +12 V to +5 V . A switch was installed to allow this voltage to be switched from +12 V to +5 V . 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 2116B 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 10011 -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 $\emptyset$ pulse (the HP flag) to the computer. This 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 rariar 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
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 $\emptyset$ pulse appears when the interface has completed the radar firing routine. The remaining 3 bits of the A port ind 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 $\emptyset$ 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 $\emptyset$ level for any signals or data to be transferred betwee:. the computer and the radar interface.
RESET - A logic $\emptyset$ pulse on this line (while DC is at logic $\emptyset$ ) causes the radar interface to be reset and initiates the radar firing sequence.
S-SELECT - This line, when logic $\square$ (with DC at logic $\emptyset$ ), 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 $\emptyset$ pulse on this line (while DC and S-SELECT are at logic $\emptyset$ ) 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 $\emptyset$. The $D C$ line remains at logic $\emptyset$ during the entire radar operation. The RESET line returns to logic 1 and the radar begins its firing sequence.


Figure 5-2 - V.I.A.\#2 Port Assignments

Figure 5-3. Radar Control Timing Diagram

After 320 milliseconds have elapsed, a logic 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 $\square$ 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 $\square$ 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 $\emptyset$. 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 $D C$ 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 $\varnothing$ might look like:

| START: LDA 8121 | A+A Port of VIA \#2 |
| :--- | :--- |
| AND \#10 | A+A•(DOD10QD) |
| BNE START | Jump Back to Start if Bit 5 of the $A$ |
|  | Port $=1$ |

Since the HF 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
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 if 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 CAI 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 intialization routine of our program.

Sy writing a logical $\varnothing$ into bit $\varnothing$ of the PCR (location 812 C ), we can cause the CAl interrupt flag to set whenever a logic 1 to logic $\emptyset$ transition occurs on the CAl input. This flag can be examined by reading bit $\emptyset$ of the IFR. Since we have cleared all of the IER bits, liu interrupt will occur when this CAl interrupt flag is set. The computer can, however, monitor bit $\emptyset$ of the IFR. When the HP FLAS 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 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.

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-55 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 EOR \#FF 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 is given below:

| 0500 | LDX | \#00 |  |
| :---: | :---: | :---: | :---: |
| 0502 | LDA | \#00) |  |
| 0504 | STA | 8122 | Set Direction Registers |
| 0507 | LDA | \#DF |  |
| 0509 | STA | 8123 |  |
| 505C | LDA | \#00 | PCR + (00) |
| 950E | STA | 812C) |  |
| 0511 | LDA | \#7F | IER + (7F) |
| 0513 | STA | 812E |  |
| 8516 | LDA | \#FF | Clear IFQ |
| 0518 | STA | 8120 |  |
| 0518 | LDA | \#03 | D.C. \& RESET to Logic $\emptyset$ |
| 051D | STA | 812] |  |
| 0520 | LDA | \#12F | Reset to logic 1 |
| 0522 | STA | 8121 |  |
| 0525 | LDA | 81207 | Wait for HP FLAG |
| 0528 | AND | \#10 |  |
| 152A | BEQ | 9525 |  |
| 052C | LDA | \#85 | S-Select to Logic $\quad$ D |
| 052E | STA | $8121\}$ |  |
| 0531 | LDA | 8121 | Compliment First Word and Store in |
| 0534 | EOR | \#FF |  |
| 0536 0539 | STA | 9600 | - Jump to Print Subroutine |
| 8539 | JSR | 9700 | - Jump to Print Subroutine |
| 053C | LDX | \#01 |  |
| 053E | LDA | \#194 | SHIFT to Logic |
| 0540 | STA | 8121 | Shif to Logic |

\begin{tabular}{|c|c|c|c|}
\hline $$
\begin{array}{r}
0543 \\
6546
\end{array}
$$ \& $$
\begin{aligned}
& \text { LDA } \\
& \text { EOR }
\end{aligned}
$$ \& $$
\left.\begin{array}{c}
8120 \\
\# F F
\end{array}\right\}
$$ \& Put Next Word in 0600, \% <br>
\hline 0548 \& STA \& 0600, $x$ ] \& <br>
\hline 054B \& JSR \& 0700 \& - Jump to Print Subroutine <br>
\hline 054E \& LDA \& "05 \& - SHIFT to Logic 1 <br>
\hline 0550 \& STA \& 8121 \& <br>
\hline 0553 \& INX \& \& <br>
\hline 0554

0555 \& TXA
CMP \& \#64 \& Words Have Not Been Read <br>
\hline 0557 \& 3NE \& 0535 \& <br>
\hline 0559 \& LDA \& \#FF \& All Control Bits to Logic 1 <br>
\hline 055B \& STA \& 8121\} \& <br>
\hline 055E \& BRK \& \& <br>
\hline
\end{tabular}

Note that this program only recovers tie 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 instruction is excecuted each time 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.



FIGURE 5-4 - RADAR CONTROI. PROGRAM

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 resclution 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 prore to contact bounce upon closure, an electronic debouncing circuit was installed so jitter free logic signals will be presented to the viA inpu s.

Figure 6-1 shows the schematic diagram of the sense switch debouncing 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 6-1 also shows the port bit assignments for the switches. For VIA\#4 the A port occupies location 8141 and the B port occupies location 8140.

Both the switches and the debouncing circuit are located in the


Figure 6-1 Sense Switch Dehouncing Circuit
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 sys eem. 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.

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 programs 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.

## REFERENCES

[1] AIM-65 Microcomputer User's Guide. Rockwell International, document Mo. 29650 N36, 1979.
[2] R6500 Microcomputer System Hardware Manual. Rockwell International, document No. 29650 N31, 1979.
[3] R6500 Microcomputer System Programming Manual. Rockwell International, document No. 29650 N30, 1979.
[4] Model FT8840A Formatted Tape Transport Operating and Service Manual Ho. 104927 with Microformatter Addendum, Chatsworth Calif., Pertec Computer Corp. 1977.
[5] AIM-65 Microcomputer Monitor Program Listing. Rockwell International, document No. 98650 N36L, 1979.

APPENDIX A - DATA ACQUISITION SYSTEM - MEMORY MAP

|  | Scratch pad memory for operating program | $\begin{aligned} & 8180 \\ & \downarrow \\ & 82 \mathrm{FF} \end{aligned}$ | Not currently used |
| :---: | :---: | :---: | :---: |
| $\stackrel{100}{+}$ | Reserved for AIM-65 stack and monitor subroutines | 8300 | AOR. CTR. -LO |
| 020] | User available RAM for | 8301 | ADR. CTR. - Hi $^{\text {d }}$ |
| OFFF |  | 8322 | BYTE CTR. -Hi |
| 1000 | Not currently used |  |  |
| 7FfF |  | 8303 | BYTE CTR. -Lo |
| $\begin{aligned} & 8000 \\ & 8001 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ADC \#O } \\ & \text { ADC \#1 } \end{aligned}$ | 8304 | L.WD - Clear |
| 8002 | ADC \#2 |  |  |
| + |  | 8385 | HER - Clear |
| 800F | ADC \#F: | 8306 | Not Used |
| 8010 | Not currentiy used | 8387 | STATUS INPUT REG. |
| $\stackrel{8100}{+}$ | V.I.A. \#1 | $8308$ | Not currently used |
| 8110 | V.I.A. \#2 | 9000 | DNA Memory (4K RAM on Dith board) |
|  | - | $\stackrel{\text { AlOO }}{+}$ | AIM-65 V.I.A. |
|  | - A. 7 - | $\underset{+}{\text { A D A }}$ | AIM-65 I/O and RAM |
| 8178 | V.I.A. \#7 |  |  |
| 817F |  | B200 | Reserved for ROM (or EPROII) sockets or AIM65 Board |
|  |  | DFFF |  |
|  |  | E000 | AIM-65 IKnito: Program (ROM) |
|  |  | FFFF |  |

APPEHDIX B - WIRE LISTS, PC LAYOUTS, ETC.
DMA Controller - Connector Key

|  | J1A | J2A | J1B | J2B |
| :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{D}_{0}$ | CS9 | IRD | IROY |
| 2 | $\mathrm{D}_{1}$ | $\overline{\$ 2}$ | IR1 | IONL |
| 3 | $\mathrm{D}_{2}$ | RAM R/W | IR2 | IFPT |
| 4 | $\mathrm{D}_{3}$ | IRSTR (OUT) | IR3 | ILDP |
| 5 | $\mathrm{D}_{4}$ | LWD | 1 R4 | IFIT |
| 6 | $\mathrm{D}_{5}$ | IWRT (OUT) | IR5 | IRND |
| 7 | $\mathrm{D}_{6}$ | IWRT (IN) | IR6 | IWRT (OUT) |
| 8 | $\mathrm{D}_{7}$ | DMM (IN) | 127 | IWSTR (IN) |
| 9 | $A_{11}$ | IREV (IN) | NC | IRSTR (III) |
| 10 | AO | IWFM (IN) | HC | IHER |
| 11 | SYS R/W | IREW (iin) | NC | ILWD |
| 12 | CS9 | NC | NC | IREV (OUT) |
| 13 | $\overline{\text { ¢ }}$ | NC | NC | NC |
| 14 | A10 | SYS R/T | NC | IDFM |
| 15 | A9 | CS3 | IW | IREW |
| 16 | A8 | IERASE (IN) | IW1 | IEPASE |
| 17 | A7 | IOFL (IIN) | IW2 | 10FL |
| 18 | A6 | I FEN (IN) | IW3 | IFEN |
| 19 | A5 | IGO (Iii) | IW4 | IGO |
| 20 | A4 | lfey (OUT) | IW5 | IFBY |
| 21 | A3 | I OBY (OUT) | IW6 | IDEY |
| 22 | A2 | ICCG (OUT) | IW7 | ICCS |
| 23 | A1 | IfMK (OUT) | HC | IF ${ }^{\prime \prime} \mathrm{K}$ |
| 24 | NC | NC | IVC | Sİ GND |
| 25 | C58 | NC | HC | NC |
| 26 | RAM R/W | NC | NC | NC |

## B-1

CAELE KEY - JIA TO AIM-65 EXPANSION CONNECTOR

| Jla pin. | Expansion Connector \# | Labe 1 |
| :---: | :---: | :---: |
| 1 | 15 | $D_{0}$ |
| 2 | 14 | $\mathrm{D}_{1}$ |
| 3 | $1:$ | $\mathrm{D}_{2}$ |
| 4 | 12 | $\mathrm{D}_{3}$ |
| 5 | 11 | $\mathrm{D}_{4}$ |
| 6 | 10 | $\mathrm{D}_{5}$ |
| 7 | 9 | $\mathrm{D}_{6}$ |
| 8 | 8 | $\mathrm{D}_{7}$ |
| 9 | N | $A_{11}$ |
| 10 | A | $A_{0}$ |
| 11 | $v$ | SYS R/W |
| 12 | 19 | $\overline{C 59}$ |
| 13 | $Y$ | $\overline{4}$ |
| 14 | M | $\mathrm{A}_{10}$ |
| 15 | L | $A_{9}$ |
| 16 | K | $A_{8}$ |
| 17 | $\checkmark$ | $A_{7}$ |
| 18 | H | $A_{6}$ |
| 19 | F | $A_{5}$ |
| 20 | E | $A_{4}$ |
| 21 | 0 | $A_{3}$ |
| 22 | c | $A_{2}$ |
| 23 | 3 | $A_{1}$ |
| 24 | il |  |
| 25 | 18 | C58 |
| 26 | z | RAM R/W |

CABLE KEY - J2A TO AIM-65 APPLICATION CONNECTOR
J2A pin
Application Connector Label

cable key - jab to pertec interface

| J18 | Pertec Connector | Labe! |
| :---: | :---: | :---: |
| 1 | 837 | IRO |
| 2 | A37 | IR1 |
| 3 | 839 | 1R2 |
| 4 | A39 | $1 \mathrm{R}^{2}$ |
| 5 | B40 | 1 R4 |
| 6 | A40 | IR5 |
| 7 | B42 | 1R6 |
| 8 | A42 | IR7 |
| 9 | A35 | G\% |
| 10 | A35 | GND |
| 11 | NC |  |
| 12 | NC |  |
| 13 | NC |  |
| 14 | B16 | IWE |
| 15 | A16 | IW1 |
| 16 | 318 | IW2 |
| 17 | A18 | IW3 |
| 18 | B19 | IW4 |
| 19 | A19 | IW5 |
| 20 | B21 | IW6 |
| 21 | A21 | 1W7 |
| 22 | A35 | GND |
| 23 | A35 | GND |
| 24 | NC |  |
| 25 | HC |  |
| 26 | NC |  |

CABLE kEy - j2B TO PERTEC interface

| J28 | Pertec Connector | Label |
| :---: | :---: | :---: |
| 1 | 827 | IRDY |
| 2 | A27 | IONL |
| 3 | A28 | IFPT |
| 4 | 830 | ILDP |
| 5 | A30 | IEDT |
| 6 | 828 | IRIID |
| 7 | A4 | IWRT |
| 8 | A34 | IWSTR |
| 9 | 836 | IRSTR |
| 10 | A24 | IHER |
| 11 | 813 | IL! 10 |
| 12 | ${ }^{84}$ | irev |
| 13 | NC | - |
| 14 | B6 | IUF: 1 |
| 15 | 812 | IREW |
| 16 | 87 | IERASE |
| 17 | A 12 | 10 FL |
| 18 | A13 | Ifen |
| 19 | A3 | 160 |
| 20 | B22 | If ${ }^{\text {PY }}$ |
| 21 | A22 | IDBY |
| 22 | B24 | ICCG |
| 23 | A25 | JFMK |
| 24 | B35 | GND |
| 25 | HC | - |
| 26 | HC | - |

OMA CONTROLLER - IC LIST

| A side |  | B side |  |
| :---: | :---: | :---: | :---: |
| 16. | TYPE | IC | TYPE |
| 1 | 74LS240 | 1 | 21:4L |
| 2 | 74LS245 | 2 | 2114 L |
| 3 | 74LS245 | 3 | 21146 |
| 4 | 74L5365 | 4 | 2114 L |
| 5 | 7445365 | 5 | 74L5240 |
| 6 |  | 6 | 7400 |
| 7 |  | 7 | 74365 |
| 8 |  | 8 | 74365 |
| 9 | 74L5139 | 9 | 74365 |
| 10 | 741500 | 10 |  |
| 11 | 741.551 | 11 | 21141 |
| 12 | 741585 | 12 | 2114 L |
| 12 | 74L585 | 13 | 21146 |
| 14 | 74LS:5 | 14 | 2114L |
| 15 | 74LS35 | 15 | 74LS04 |
| 16 | 74L04 | 16 |  |
| 17 | 74L04 | 17 |  |
| 18 | 74L508 | 18 |  |
| 19 | 74LS08 | 19 |  |
| 20 | Resistor Pack | 20 | 74109 |
| 21 | 74LS109 | 21 | 74121 |
| 22 | 74L. 3169 | 22 | 74LS138 |
| 23 | 7415169 | 23 | 74L5169 |
| 24 | 741.5365 | 24 | 74LS169 |
| 25 | 7415365 | 25 | 74L5169 |
| 26 |  | 26 | Discrete Component |
| 27 |  | 27 |  |
| 23 |  | 28 |  |
| $2 \cdot$ |  | 23 |  |

3-6

CABLE KEY - viA "O TO DATATRON CLOCK CABLE

VIA MO Connector
Clock Cable
Label

| 1 | 13 | GND |
| :--- | ---: | ---: |
| 2 | 1 | USC 1 |
| 3 | 2 | 2 |
| 4 | 3 | 4 |
| 5 | 4 | 8 |
| 6 | 5 | TSC 1 |
| 7 | 6 | 2 |
| 8 | 7 | 4 |
| 9 | 13 | GND |
| 10 | NC | - |
| 11 | NC | - |
| 12 | 8 | URC 1 |
| 13 | 9 | 2 |
| 14 | 10 | 4 |
| 15 | 11 | 8 |
| 16 | 12 | THC 1 |
| 17 | 15 | 2 |
| 18 | 13 | GI:D |
| 19 | 13 | GHD |

CALLE KEY - VIA \#1 TO DATATRON CLOCK CABLE

VIA \# Connector \#
Clock Cable \#
Labe 1

| 1 | 13 | GND |
| :--- | ---: | ---: |
| 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 | 16 | - |
| 12 | 17 | UHC 1 |
| 13 | 18 | 2 |
| 14 | 19 | 4 |
| 15 | 20 | 8 |
| 16 | 21 | THC 1 |
| 17 | 34 | 2 |
| 18 | 35 | HDC 1 |
| 19 | 13 | 2 |
| 20 |  | GND |

62

## CAGLE COHNECTOR SENSE SWITCH CONHECTOR (ON CHASIS) TO VIA \#4

Sense Switch Connector \#
VIA 4 pin
Label

| 15 | - | +5V |
| :---: | :---: | :---: |
| 16 | - | +5V |
| 17 | 1 | GMD |
| 18 | 20 | GHD |
| 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. D-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. 0-14 |
| 34 | 3 | S.S. D-15 |
| 35 | 2 | S.S. 0-10 |


| FROM $\qquad$ | FROM (AUGAT NO.) | $\begin{aligned} & \text { TO } \\ & \text { IC PIN No. } \end{aligned}$ | TO (augat no. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IC1A |  |  |  | 74LS244 | 20 |
| 1 | 1 | 10A-6 |  |  |  |
| 1 | 1 | 5B-1 | 58-1 |  |  |
| 2 | 2 | 1A-3 |  |  |  |
| 2 | 2 | 3A-9 |  |  |  |
| 4 | 4 | 1A-5 | 1A-5 |  |  |
| 4 | 4 | 3A-8 | 3A-8 |  |  |
| 6 | 6 | 1A-7 | 1A-7 |  |  |
| 6 | 6 | 3A-7 | 3A-7 |  |  |
| 8 | 8 | 1A-9 | 1A-9 |  |  |
| 8 | 8 | 3A-6 | 3A-6 |  |  |
| 10 | 5A-1 |  |  | GND |  |
| 11 | 5A-16 |  | J18-5 | 184 |  |
| 12 | ${ }^{\text {added }}{ }^{\text {P }}{ }^{\text {n- }}$ |  | J1B-18 | 1 W 4 |  |
| 13 | 9 |  | J1B-6 | 1R5 |  |
| 14 | 10 |  | J1B-19 | 1W5 |  |
| 15 | 11 |  | J18-7 | 1R6 |  |
| 16 | 12 |  | J1B-20 | 1W6 |  |
| 17 | 13 |  | J1B-8 | 1R7 |  |
| 18 | 14 |  | J1B-21 | 167 |  |
| 19 | 15 | 10A-8 | 10A-8 |  |  |
| 19 | 15 | 58-19 | 5B-15 |  |  |
| 20 | 16 |  |  | $V_{c c}$ |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| IC2A |  |  |  | 74LS245 | 20 |
| 1 | , | GND |  | GND |  |
| 2 | 2 | 58-9 | 5B Brotecto |  |  |
| 3 | 3 | 58-7 | 58-7 |  |  |
| 4 | 4 | 5B-5 | 5B-5 |  |  |
| 5 | 5 | 5B-3 | 5B-3 |  |  |
| 6 | 6 | 1A-9 |  |  |  |
| 7 | 7 | 1A-7 | 1A-7 |  |  |
| 8 | 8 | 1A-5 | 1A-5 |  |  |
|  |  |  |  |  |  |


| FROM <br> IC PINNO. | FROM <br> (AUGAT NO.) | TO <br> IC PIN NO. | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 9 | aded $\mathrm{L}^{\text {b }}$ in- | 1A-3 | 1A-3 |  |  |
| 10 | 7A-1 |  |  | GND |  |
| 11 | 7A-16 |  | J2B-1 | IRDY |  |
| 12 | $\mathrm{added}_{H} \mathrm{p}^{\text {in- }}$ |  | 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 |  |
| 18 | 14 | 20B-6 | 20B-6 |  |  |
| 19 | 15 | 15B-12 | 15B-14 |  |  |
| 20 | 16 |  |  | 5 V |  |
|  |  |  |  |  |  |
| IC3A |  |  |  | 74LS245 | 20 |
| 1 |  |  | J2A-7 | R/W |  |
| 10 | 8A-1 |  |  | GND |  |
| 11 | 8'A-16 |  |  | ${ }^{0}$ |  |
| 12 | $\mathrm{added}_{H} \mathrm{p}^{\text {in- }}$ |  |  | $0_{1}$ |  |
| 13 | 9 |  |  | $\mathrm{D}_{2}$ |  |
| 14 | 10 |  |  | $\mathrm{V}_{3}$ |  |
| 15 | 11 |  |  | $\mathrm{U}_{4}$ |  |
| 16 | 12 |  |  | ${ }_{5}$ |  |
| 17 | 13 |  |  | $0_{6}$ |  |
| 18 | 14 |  |  | ${ }^{0} 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 | $A_{5}$ |  |
| 4 | 4 |  | J1A-21 | ${ }^{\text {A }}$ |  |


| FROM $\qquad$ | FROM <br> (AUGAT NO.) | TO <br> IC PIN NO. | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 6 | 6 |  | J1A -23 | $A_{1}$ |  |
| 10 | 10 |  | J1A-24 | $\mathrm{A}_{0}$ |  |
| 12 | 12 |  | J1A-22 | $A_{2}$ |  |
| 14 | 14 |  | J1A-20 | $\mathrm{A}_{4}$ |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| IC5A |  |  |  | 74LS365 | 16 |
| 1 | 1 | 5A-15 | 5A-15 |  |  |
| 2 | 2 |  | J1A-13 | $\mathrm{A}_{12}$ |  |
| 4 | 4 |  | J1A-15 | $\mathrm{Ag}_{9}$ |  |
| 6 | 6 |  | J1A-17 | $A_{7}$ |  |
| 10 | 10 |  | J1A-18 | $\mathrm{A}_{6}$ |  |
| 12 | 12 |  | J1A-16 | $\mathrm{A}_{8}$ |  |
| 14 | 14 |  | J1A-14 | $\mathrm{A}_{10}$ |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| IC9 |  |  |  | 74LS139 | 16 |
| 9 | 9 | 11B-8 | 118-8 |  |  |
| 10 | 10 | 12B-8 | 12B-8 |  |  |
| 11 | 11 | 13B-8 | 138-8 |  |  |
| 12 | 12 | 14B-8 | 148-8 |  |  |
| 13 | 13 | 5A-3 | 5A-3 |  |  |
| 14 | 14 | 5A-13 | 5A-13 |  |  |
| 15 | 15 | 18A-6 | 18A-6 |  |  |
|  |  |  |  |  |  |
| IC10A |  |  |  | 74LS00 | 14 |
| 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 | 10A-9 | 10A-11 |  |  |
| 5 | 5 | 15B-2 | 15B-2 |  |  |
| 5 | 5 | 11A-1 | 11A-1 |  |  |
| 7 | 7 |  | 10A-8 | GND |  |


| FROM <br> IC PIN NO. | FROM <br> (AUGAT NO.) | TO <br> IC PIN NO. | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | 12 | 16A-3 | 16A-3 |  |  |
| 10 | 12 | 10A-1 | 10A-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 | 15B-13 |  |  |
| 7 |  |  | 11A-8 | GND |  |
| 8 | 10 | 15B-9 | 15B-11 |  |  |
| 9 | 11 | 17A-12 | 17A-14 |  |  |
| 10 | 12 | 11A-11 | 11A-13 |  |  |
| 10 | 12 | 18A-4 | 18A-4 |  |  |
| 10 | 12 |  | J2A-1 | $\overline{\text { C59 }}$ |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| 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 | 4A-9 |  |  |



| FROM IC PIN NO. | FROM <br> (AUGAT NO.) | TO IC PIN NO. | TO (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 15 |  | 4A-5 |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| IC16A |  |  |  | 74L04 | 14 |
| 2 |  | 16A-5 |  |  |  |
| 1 |  | 19A-1 |  |  |  |
| 1 |  | 22B-12 |  |  |  |
| 6 |  | 23B-9 |  |  |  |
| 9 | 11 | 16A-12 | 16A-14 |  |  |
| 3 | 10 | 25B-9 |  |  |  |
| 13 | 15 | 19A-5 |  |  |  |
| 13 | 15 | 22B-13 |  |  |  |
|  |  |  |  |  |  |
| ICI.A |  |  |  | 74L04 | 14 |
| 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-14 |  |  |
| 13 | 15 | 22B-15 |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| IC18A |  |  |  | 741508 | 14 |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| 7 |  |  | 18A-8 | GND |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |


| FROM IC PIN NO. | FROM <br> (AUGAT NO.) | $\begin{aligned} & \text { TO } \\ & \text { IC PIN NO. } \end{aligned}$ | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IC19A |  |  |  | 74L508 | 14 |
| 2 |  | 19A-4 |  |  |  |
| 3 |  | 24B-2 |  |  |  |
| 6 |  | 258-2 |  |  |  |
| 1 |  |  | 19A-8 | GND |  |
| 8 | 10 | 23A-2 |  |  |  |
| 9 | 11 | 19A-13 | 19A-15 |  |  |
| 11 | 13 | 21A-2 |  |  |  |
|  |  |  |  |  |  |
| IC20A |  |  |  | R-Pack | 16 |
| 1 |  | 20A-16 |  | +5V |  |
| 4 |  | 21A-1 |  |  |  |
| 5 |  | 23A-7 |  |  |  |
| IC21A |  |  |  | 74LS163 | 16 |
| 1 |  | 22A-1 |  |  |  |
| 1 |  | 23A-1 |  |  |  |
| 2 |  | 22A-2 |  |  |  |
| 3 |  | 3A-9 | $3 A^{\text {added }}$ |  |  |
| 3 |  | 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 |  |  |  |


| FROM <br> IC PINNO. | FROM <br> (AUGAT NO.) | TO <br> IC PIN NO. | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 14 |  | 24A-4 |  |  |  |
| 15 |  | 22A-10 |  |  |  |
| IC22A |  |  |  | 74LS163 | 16 |
| 3 |  | 3A-5 |  |  |  |
| 3 |  | 24B-3 |  |  |  |
| 4 |  | 3A-4 |  |  |  |
| 4 |  | 24B-4 |  |  |  |
| 5 |  | 3A-3 |  |  |  |
| 5 |  | 24B-5 |  |  |  |
| 6 |  | 3A-2 |  |  |  |
| 6 |  | 24B-6 |  |  |  |
|  |  |  |  |  |  |
| 11 |  | 24A-14 |  |  |  |
| 12 |  | 24A-2 |  |  |  |
| 13 |  | 25A-10 |  |  |  |
| 14 |  | 25A-6 |  |  |  |
| 15 |  | 23A-10 |  |  |  |
|  |  |  |  |  |  |
| 1C23A |  |  |  | 74LS 163 | 16 |
| 7 |  | 22A-7 |  |  |  |
| 11 |  | 25A-12 |  |  |  |
| 12 |  | 25A-4 |  |  |  |
| 13 |  | 25A-14 |  |  |  |
| 14 |  | 25A-2 |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |


| $\begin{aligned} & \text { FROM } \\ & \text { IC PIN NO. } \end{aligned}$ | FROM <br> (AUGAT NO.) | T0 <br> IC PIN NO. | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IC24A |  |  |  | 7415365 |  |
| 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 |  | 5B-4 |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |


|  | $\begin{aligned} & \text { FROM } \\ & \text { IC PIN NO. } \end{aligned}$ | FROM <br> (AUGAT NO.) | $\begin{aligned} & \text { TO } \\ & \text { IC PIN NO. } \end{aligned}$ | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| pins | 1 Cl 18 |  |  |  | 2114L | 18 |
| 1, 2, 3,4,5,6, | 3 |  | 11B-8 |  |  |  |
| 7,8,15,16, \& |  |  |  |  |  |  |
| 17 of IC's 1B, | IC2B |  |  |  | 2114 L | 18 |
| 2B, 3B, 4B, 11B, | 8 |  | 128-8 |  |  |  |
| 12B, 138, \& 24B |  |  |  |  |  |  |
| are Daisy Chained | IC3B |  |  |  | 2114 L | 18 |
|  | 3 |  | 13B-8 |  |  |  |
|  |  |  |  |  |  |  |
|  | 1 CAB |  |  |  | 2114L | 18 |
|  | 3 |  | 14B-8 |  |  |  |
|  | 1 |  | 5A-9 |  |  |  |
|  | 2 |  | 4A-3 |  |  |  |
|  | 3 |  | 4A-13 |  |  |  |
|  | 4 |  | $4 A-5$ |  |  |  |
|  | 5 |  | 4A-9 |  |  |  |
|  | 6 |  | 4A-7 |  |  |  |
| Some of these | 7 |  | 4A-11 |  |  |  |
| connections are | 9 | Added pin-L |  |  | GND |  |
| made on IC3B to $\{$ | 10 | Added pin-H | 15B-10 | 15B-12 |  |  |
| minimize crowding | 11 |  | 5B-9 |  |  |  |
| at IC4B | 12 |  | 5B-7 |  |  |  |
|  | 13 |  | 58-5 |  |  |  |
|  | 14 |  | 5B-3 |  |  |  |
|  | 15 |  | 5A-5 |  |  |  |
|  | 16 |  | 5A-11 |  |  |  |
|  | 17 |  | 5A-7 |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
| - |  |  |  |  |  |  |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |



| FROM <br> IC PIN NO. | FROM <br> (AUGAT NO.) | TO IC PIN NO. | T0 (augat no. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IC6B |  |  |  | 7400 | 4 |
| 1 | 1 | 9B-3 | 9B-3 | IWRT |  |
| 4 | 4 | 16A-4 | 16A-4 | IWRT |  |
| 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 |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |



| FROM <br> IC PIN NO. | FROM <br> (AUGAT NO.) | $\begin{aligned} & \text { TO } \\ & \text { IC PIN NO. } \end{aligned}$ | TO <br> (AUGAT NO. | LABEL | $\checkmark$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 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 | 98-12 | IERASE (in) |  |
|  | J2A-17 | 98-14 | 9B-14 | IOFL (in) |  |
| 9B-3 | 9B-3 |  | J2B-7 | IWRT (out) |  |
| 9B-5 | 9B-5 |  | J2B-12 | IREV (out) |  |
| 9B-7 | 9B-7 |  | J2B-14 | IWFM (out) |  |
| 9B-9 | 9B-9 |  | J2B-15 | IREW (out) |  |
| 9B-11 | 98-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) |  |
|  |  | 88-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) |  |
| 8B-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 | 78-2 | 7B-2 | IRSTR (in) |  |
|  | J2B-8 | 7B-4 | 7B-4 | IWSRT (in) |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |




Figure B-1. Digital I/O Board Component Layout - Top View (Full Scale)







Figure B-7 Analog Conditioning Circuit Component Layout


Figure B-8 Analog Conditioning Circuit PC Pattern (full scale)

Figure B-9 Analog Conditioning Board - Top Side (.80 Scale)


Figure B-10 Analog Conditioning Board Bottom Side (. 80 Scale)




| ADC | - Analog to Digital Converter |
| :--- | :--- |
| A/D | - Analog to Digital |
| D/A | - Digital to Analog |
| DMA | - 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) |


[^0]:    * Note that $V_{\text {offset }}$ can be either positive or negative.

[^1]:    Figure 4-11 Status Input Register

