```
{NASA-CR-158647) A ROCKET-EGRNE N79-24571
DATA-MANIPULATION EXPERIMENT. USING A
UICROPROCESSOR: (I11incis U'iv.). 112 p
HC AO6/MF A01 CSCL 04A
G3/46 22317
```


## AERONOMY REPORT <br> NO. 84

## A ROCKET-BORNE DATA-MANIPULATION EXPERIMENT, USING A MICROPROCESSOR

by
L. L. Davis
L. G. Smith
H. D. Vas

April 1, 1979


## CITATION POLICY

The material contained in this report is preliminary information circulated rapidly in the interest of prompt interchange of scientific information and may be later revised on publication in accepted aeronomic journals. It would therefore be appreciated if persons wishing to cite work contained herein would first contact the authors to ascertain if the relevant material is part of a paper published or in process.

# AERONOMY REPORT <br> N O. 84 

## A ROCKET-BORNE DATA-MANIPULATION EXPERIMENT

 USING A MICROPROCESSOR
## by

L. L. Davis
L. G. Smith
H. D. Voss

Apri1 1, 1979


#### Abstract

This report describes the development of a data-manipulation experiment using a Z-80 microprocessor. The instrumentation is included in the payloads of two Nake Apache sounding rockets used in an investigation of energetic particle fluxes. The data from an array of solid-state detectors and an electrostatic analyzer is processed to give the energy spectrum as a function of pitch angle.

The experiment performed well in its first flight test: Nike Apache 14.543 was launched from Wallops Island at 2315 EST on 19 June 1978. The system has been designed to be easily adaptable to other data-manipulation requirements and some suggestions for further development are included.


## TABLE OF CONTENTS

Page
ABSTRACT. ..... $11 i$
TABLE OF CONTENTS ..... IV
LIST OF TABLES ..... vi
LIST OF FIGURES ..... vıi

1. INTRODUCTION. ..... 1
2. ENERGETIC PARTICLE EXPERIMENTS ..... 3
2.1 Introduction ..... 3
2.2 Energetic Particle Spectrometer. ..... 3
23 Electrostatic Analyzer ..... 8
3. GENERAL DESCRIPTION OF THE EXPERIMENT ..... 10
3.1 2-80 Microcomputer ..... 10
3.2 Peripheral Devices ..... 12
3.3 Data Manipulation ..... 14
4. HARDWARE ..... 20
4.1 CPU-Memory Board ..... 20
4.1.1 Memory address decoding ..... 20
41.2 Reset circuit ..... 27
4.1.3 Clock ..... 27
4.1.4 Read-write control ..... 27
4.2 PIO \#1 and CTC Board ..... 27
4.3 A/D and FIFO Board ..... 31
4.4 PIO \#2 ..... 37
5. SOFTWARE ..... 41
5.1 2-80 Architecture. ..... 41
5.2 Data-Manipulation Software ..... 44
5.2.1 Initialization. ..... 44
5.2.2 Input routine ..... 47
5.2.3 Output routine. ..... 49
6. THE SDB-80 BOARD AND THE EPROM PROGRAMMER ..... 59
6.1 The SDB-80 Board ..... 59
6.2 EPROM Progrommex ..... 62
6.2.1 Programming waveforms ..... 62
6.2.2 Programmer hardware ..... 62
Page
6.2.3 SDB-80 modifications ..... 65
6.2.4 EPROM,progrommer software ..... 67
6.2.5 Operation of the programer ..... 73
7. FLIGHT PERFORMANCE ..... 75
8. CONCLUSION AND RECOMMENDATIONS FOR FUTURE WORK ..... 80
8.1 Conclusion ..... 80
8.2 Suggestions for Future Work ..... 80
8.2.1 The data-manipulation progrom ..... 80
8.2.2 The MSD circuit ..... 80
8.2.3 Automatic reset circuit ..... 83
8.2.4 Circuit layout ..... 83
8.2.5 The development system ..... 83
8.2.6 Other applications of the rocket-bome data-manipulation experiment ..... 86
8.2.7 Data-transmission systems ..... 86
8.2.8 Applications in ground-based data processing ..... 86
REFERENCES ..... 89
APPENDIX I. Circuit Schematics. ..... 90
APPENDIX II. 1 Data-Manipulation Program ..... 94
APPENDIX II. 2 EPROM Programmer. ..... 97

## LIST OF TABLES

Table Page
' 1.1 Abbreviatıons ..... 2
2.1 Important characteristics of the six solid-state detectors in the payloads of Nike Apaches 14.542 and 14.543. . ..... 7
4.1 Z-80 Control signals. ..... 24

## LIST OF FIGURES

Figure Page
2.1 Surface barrier detector. Note the differences between the detectors with surface layers of (1) aluminum and (2) gold ..... 5
2.2 Major components of the solid-state detector instrumentation ..... 6
2.3 Block diagram of the electrostatic analyzer. The acceptance angle of the collimator is exaggerated ..... 9
3.1 The data-manipulation system ..... 11
3.2 (a) Rocket rotation sectors; (b) Address formed from the two data words; (c) Memory (d) RAM address ..... 15
3.3 Input routine algorithm. ..... 16
3.4 Output routine algorithm ..... 17
3.5 Example of output from D/A. The ordinate is the telemetered signal (in volts) and is proportional to number of units (5V $\equiv 32$ particles) in the accumulation period ..... 19
4.1 Data-manipulation system circuit boards. (a) boards connected for installing in payload, (b) CPU-memory board, (c) PIO \#1-CTC board, and (d) A/D FIFO board. ..... 21
4.2 Location of the data-manipulation system in the payload of Nike Apache 14.542 ..... 23
4.3 The CPU-Memory board. An arrow on one end of a line indicates a single direction signal; arrows on both ends indicate a bidirectional signal; dotted arrows indicate some lines go in one direction and some the other direction ..... 25
4.4 Address decoding: (a) Connection of the 8205 one-of-eight decoder; (b) Truth table ( $X=$ don't care state); (c) Memory addresses. ..... 26
4.5 Reset circuit. ..... 28
4.6 System clock ..... 29
4.7 The PIO\#1-CTC board. The arrows have the same meaning as in Figure 4.3 ..... 30
4.8 PIO block diagram (MOSTEK Z80 Manual) ..... 32
4.9 Timing diagrams: (a) PIO\#1 Port A handshake line timing;(b) A/D control signal timing; (c) FIFO handshake line timing.33
Figure Page
4.10 The A/D-FIFO board. The arrows have the same meaning as in Figure 4.3 ..... 34
4.11 The circuit and timing diagram for the input to the FIFO and the ready-for-input status signal ..... 36
4.12 The circuit and timing diagram for input to PIO\#1 from the FIFO ..... 38
4.13 The PIO\#2 board. The arrows have the same meaning as in Figure 4.3 ..... 39
5.1 Z80-CPU register configuration (MOSTEK Z80 Micro-Reference Manua1) ..... 42
5.2 Block diagrams of (a) one port of a PIO and (b) one channel of the CTC (MOSTEK Z80 Manual) ..... 43
5.3 Flow chart of the inıtialization section ..... 45
5.4 Magnetometer data bit positioning: (a) Data bits' are. put into register D; (b) shifted right two places into top two bits of E; (c) 800 H is then added. ..... 46
5.5 Flow chart of the input routine. ..... 48
5.6 Output section of the software ..... 50
5.7 Here and in the following figure the output of the MSD is represented as an analog signal to show the relationshipbetween the rocket spin period and the counter cycle time.The case shown here is for a 5.18 Hz spin rate (i.e., 193 msperiod). 10 ms must be added to the spin cycle time to getthe interval between the times when the output flag is setbetween succeeding sections. Since the counter is incrementedat 100 Hz , there are 20 increments between the times thecounter is reset (the last count has a shorter interval, 3 ms ).This diagram also represents the situation for a spin periodgreater than 193 ms and for no magnetometer signal. R indicatesindicates the internal reset of the 4 -bit counter and $M$ thereset of the counter by the magnetometer52
5.8 7.14 Hz spin rate causes the magnetometer signal digital representation to have 14 levels (refer to Figure 5.7). indicates reset of 4-bit counter by the magnetometer ..... 53
Figure Page
5.9 The interval between the output flag being set to output consecutive sectors depends on which sector it is being set for. (a) $1+1 / 16$ revolutions occur between when the output flag is set to output consecutive sectors except for 12,13 , and 14. (b) The interval between the output flag being set for sectors 11 and 12 is $1+4 / 16$ revolutions. (c) The interval between the output flag being set for sectors 12 and 13 , sectors 13 and 14 , and sectors 14 and 15 is exactly one revolution ..... 55
5.10 The marker signal is obtained from HL' and is put in $A^{\prime}$ for output to D/A. (a) Sector number in HL' is put in $\mathrm{A}^{\prime}$. (b) Three shifts are then done to put data in proper bit positions for output to the D/A (i.e., two right circular shifts and one right shift with a zero put into the 7th bit) ..... 57
6.1 The EPROM programmer and the teletype connected to the MOSTEK SDB-80 board. This system was used to develop the data- manipulation system software ..... 60
6.2 MOSTEK SDB-80 Board ..... 61
6.3 Programming waveforms. (a) 2716 program and verify waveforms.
(b) 2708 program waveforms ..... 63
6.42708 and 2716 EPROM programmer. Everything to the left side of the dotted line is on the SDB- 80 board ..... 64
6.5 Port B timing diagram, (a) 2716 program and verify. (b) 2708 program ..... 66
6.6 Connection of the 2716 EPROM that contains the programmer software ..... 68
6.7 Flow chart of the EPROM programmer software. (a) The initializaton and read routines. (b) 2716 program routine. (c) 2708 program routine. (d) QUIT routine ..... 69
7.1 Section of chart record from Nike Apache 14.543: 5 seconds before launch. ..... 76
7.2 Section of chart record from Nike Apache 14.543: 95 seconds after launch ..... 77
7.3 Section of chart record from Nike Apache 14.543: 185 seconds after launch ..... 79
Figure Page
8.1 Suggestion for improvement in the MSD system. (a) Block diagram showing how the system can be phase locked to the magnetometer. (b) Timing diagram of the counter compared to the magnetometer signal. ..... 82
8.2 Using the CTC to generate the MSD signal ..... 84
8.3 (a) Block diagram of the automatic reset circuit. (b) Timing diagram showing when the CPU would be reset. ..... 85
8.4 Ground-based data-reduction system. (a) Real-time data-logging system. (b) Off-1ine data-reduction system ..... 88
I. 1 CPU-memory board ..... 90
I. 2 PIO\#1 and CTC board. ..... 91
I. $3 \mathrm{~A} / \mathrm{D}$ and FIFO board ..... 92
I. 4 EPROM programmer ..... 93

## 1. INTRODUCTION

This report describes in detail the development of a rocket-borne datamanipulation experiment designed to process data from an array of solid-state detectors and an electrostatic analyzer into a form giving the energy spectrum as a function of pitch angle. The information provided by the system will aid in further study of energetic particles in the $E$ region of the ionosphere. Previous phases of the investigation have been described in reports by Voss and Smith [1974, 1977] and in papers by Smith et al. [1974], Geller et al. [1975] and Smith and Voss [1976].

The energetic partacle experiments in the rocket payloads are described in Chapter 2. These provide the input to the data-manipulation experiment.

A general description of the data-manipulation experiment is given in Chapter 3. The Z-80 microcomputer, the nucleus of the system, is described together with the devices used to interface the detectors to it. The hardware configuration is shown in block diagram form. The input and output algorıthms used in the software are shown and a description is given of the format in which data are output from the system.

The hardware and software are described in detail in Chapters 4 and 5, respectively. The four printed circuit boards that contain the data-manipulation experiment are described. Timing diagrams of the interface circuits are presented and an explanation is given of the timing logic. The software is shown in an instruction-1evel flow chart, and the effects of various parameters in the software are described. A feature of the design is the ability of the experiment to accept a range of rocket spin rates.

Chapter 6 contains a description of the equipment for developing the software; the MOSTEK software development board (SDB-80) was used. The chapter also includes details on the design and operation of the EPROM programmer.

In Chapter 7 the performance of the data-manipulation experiment during the flıght of Nıke Apache 14.543 is discussed. Some actual data from the flıghts are presented to show that the system fulfilled its design goal.

In Chapter 8 suggestions for future work are given. Some improvements to the present system in terms of both hardware and software are included. Possible uses of microprocessors in other experaments and in the telemetry system are suggested in a block diagram form.

Table 1.1 contains a glossary of abbreviations used in the text and figures of this report.

Table 1.1
Abbreviations

A/D
CPU central processing unit
CTC counter-timer circuit*
DIP dual in-1ine package
EPROM erasable programmable read-only memory
EPS energetic particle spectrometer
ESA electrostatic analyzer
FIFO first-in first-out memory
IEI interrupt enable input
I/0 input-output
LSI large-scale integration
MOS metal-oxide semiconductor
MSD magnetometer-signal digitizer
PHA pulse-height analyzer
PIO parallel input-output circuit*
RAM random access memory
*Circuits used in the $\mathrm{Z}-80$ microcomputer

## 2. ENERGETIC PARTICLE EXPERIMENTS

### 2.1 Introduction

The data-manipulation experiment in the rocket payload receives data from an energetic particle spectrometer (EPS) and an electrostatic analyzer (ESA). The function of these two types of particle detectors is to provide a broadband spectral analysis of energetic particles (including electrons and protons) which are believed to be important as an ionization source in the nighttime $E$ region. The energetic particle spectrometer is used for the higher energies and the electrostatic analyzer for the lower energies.

The energetic particle spectrometer and electrostatic analyzer experiments prepared for Nike Apache payloads 14.542 and 14.543 are described in th1s chapter. The objective here is to explain the origin and nature of the signals which are the input to the data-manipulation experiment.

It should be noted that the payloads each include, in addition to the datamanipulation experiment described in this report, two other systems for processing data from the particle detectors. One is a relatively simple system which generates a staircase waveform; this $1 s$ particularly valuable for rapid evaluation of the performance of the detectors. The system has been used in previous payloads and is described in Voss and Smith [1974].

The other system uses a multiplexer followed by a sample-and-hold circuit. This was developed for the payloads of Nike Apaches 14.542 and 14.543. It is described in detail in Leung et al. [1979].

The three systems involve some redundancy both for protection against instrumentation malfunction and to allow intercomparison of their performance. Only those circuits which are relevant to the microcomputer data-manipulation experiment will be described in the following sections.

### 2.2 Energetic Particle Spectrometer

The energetic particle spectrometer (EPS) comprises a group of six solidstate detectors in each of the payloads with each detector selected for a particular objective. The detectors are oriented in several directions relative to the payload spin axis and as a group will resolve the energy spectrum between 12 and 400 keV . The data obtanned from the detectors can be used to identify the particles as electrons, protons or heavier nuclei.

The solid-state detectors are so-called surface barrier devices with a depletion depth of $300 \mu \mathrm{~m}$ and a sensitive area of $50 \mathrm{~mm}^{2}$. They are manufactured by Ortec Inc. A surface-barrier detector is a reverse-biased diode'fabricated
by depositing a thin layer of gold or aluminum on n- or p-type silicon, respectively, as shown in Figure 2.1. The metal also serves to attenuate light.

When an energetic particle enters into the detector, it loses its kinetic energy through lattice interactions. These particles supply energy to the lattice electrons and lift them from the valence band into the nearly empty conduction band. The high electric field across the depletion region causes the electron-hole pairs created by the ionization event to be quickly swept out of the depletion region yielding a current pulse proportional to the energy of the incident particle. The particle loses some energy in the thin metal surface layer (dead zone) so that the thickness of the layer determines the low energy limit of the detector. The resolution (full-width at half-maximum) is typically 7 keV at room temperature.

Current pulses produced by the detectors are at low levels and must be amplified. The pulse is also shaped to minimize the noise content. A block diagram of the amplifying and shaping circuits is shown in Figure 2.2. The shaping circuits employ a triple-integration and single-differentiation scheme to improve the noise characteristics of the pulse. The output of the pulse shaper then goes to the data-manipulation experiment.

Table 2.1 shows the specifications of the six detectors in each of the payioads. The detectors have different energy ranges to aid in the identification of the energetic particles: detector 3 has a broom magnet to screen out low energy electrons while detector 2 , because of its thicker surface, screens out low energy protons; detector 6 detects both protons and electrons. If the output pulses from detectors 2 and 6 are similar while that from detector 3 is different, then the detected particles are electrons; if the output pulses from detectors 3 and 6 are similar while that from detector 2 is different, the detected particles are protons or heavier nuclei. Note that detectors 4 and 5 on the payload of Nike Apache 14.542 have aluminum surface layers while detectors 4 and 5 on the payload of Nike Apache 14.543 have gold surface layers. This is done because the payloads were designed to be launched at different times of the day into correspondingly different atmospheric brightness conditions (i.e., dusk and midnight).

More information on the solid-state detectors is given in Voss and Smith [1974, 1977]. The EPS experiment for Nike Apache payloads 14.542 and 14.543 is described in more detail in a report being prepared by K. L. Fries, L. G. Smith, and H. D. Voss.


Figure 2.1 Surface barrier detector. Note the differences between the detectors with surface layers of
(1) aiuminum and (2) gold.


Figure 2.2 Major components of the solid-state detector instrumentation.

Table 2.1
Important characteristics of the six solid-state detectors in the payloads of Nike Apaches 14.542 and 14.543.

| Designationl | $\begin{aligned} & \text { Geometilad } \\ & 1 \text { 小ctol } \\ & \left(1 \\|^{2} \text { stet }\right) \end{aligned}$ | rront <br> burtace <br> Mateinal <br> $\left(1 \mathrm{H} \mathrm{Lill}^{-2}\right)^{\text {ah }}$ | Looh Angle trom <br> Spin Axis (deg) |  | $1 \mathrm{gy}$ <br> ge <br> *) | 1 nergy <br> Channels | Putch <br> Angle Sectors | comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 1 10 | 005 | $40-\mathrm{Ala}$ | 90 | $\begin{gathered} \text { Elections } \\ =10 \end{gathered}$ | $\begin{aligned} & \text { riotons } \\ & -15 \end{aligned}$ | 12 | 15 | High Resolution Detectors Ineagetal Particle Identification |
| I'lo 11 | 005 | $40-\mathrm{Au}$ | 90 | $>150$ | >15 | 12 | 15 | Electron Broom Magnet CWIF:* |
| LPS 211 | 005 | 100-A1 | 90 | - $>12$ | >55 | 11 | 15 | Cor Fnergctic Particle Idemtufication, CWEF |
| 1 P | 005 | 40-A1 (Au) | 15 | -10 | >25 (15) | 12 | 15 | Precipitated I lux |
| (1P3 31$)$ | 005 | 40-A1 (Au) | 135 | $>10$ | -25 (15) | 12 | 15 | Backscattered Flux |
| 1 is 1 Ul | 005 | $4(1)-A 1$ | 90 | $>10$ | >25 | 12 | 15 | CIVI $F$ and lon Mass Determination |

* (umpatison with earlier flights
* farcntheses for Nake Apduhe 14.513 only
$i$ U indicates dscent and i) indicates descent


### 2.3 Electrostatic Analyzer

An ESA is included in the payloads to measure particle flux in the 0.5 to 10 keV range with a resolution of less than 1 keV . An ESA essentially consists of two cylindrical parallel plates followed by a detector. A voltage is applied to the plates to deflect particles into the detector. The plate voltage determines the energy of the particle which can successfully traverse the analyzer section.

A block diagram of the ESA is shown in Figure 2.3. The plate voltage is stepped logarithmically through six levels and then is allowed to decay exponentially to zero. The voltage sequence alternates between positive polarity and then negative polarity and is symmetrical about zero. This allows the ESA to scan for electrons and protons as well as positive ions. A fraction of the output of the sweep circuit is also telemetered to ground so that the actual plate voltage can be continuously monitored. The voltage sequence is synchronized to the rocket spin such that one step corresponds to one rocket rotation and the decay to two rocket rotations. The total sequence thus repeats after 16 rotations (i.e., six positive-going steps and decay plus six negative-going steps and decay).

The detector is an electron multiplier, Johnston Model MM1-5NG. An incoming particle strikes the first of the copper-beryllium dynodes and in so doing generates secondary electrons. An applied potential causes these electrons to strike succeeding dynodes thereby generating more electrons. After 20 stages the electrons strike an anode and the charge pulse is collected at the anode.

The signal from the detector is processed in the payload in two independent ways. In the first a charge preamplifier in the ESA is used to drive a staircase generator which gives a direct method of measuring the count rate. This does not involve the data-manipulation experiment.

The second method of processing the ESA data extracts considerably more information: it gives pulse-height analysis of the detector output (which allows energetic positive ions to be identified) and it provides pitch-angle information. For this method the detector is used with the preamplifier and charge shaping circults of the type developed for the solid-state detectors (see Figure 2.2). The signal is then processed in the data-manipulation experiment in exactly the same way as the signals from the solid-state detectors. The ESA is described in detail in Pozzi et al. [1979].


Figure 2.3 Block diagram of the electrostatic analyzer. The acceptance angle of the collimator is exaggerated.

## 3. GENERAL DESCRIPTION OF THE EXPERTMENT

This chapter presents a general description of the data-manipulation experiment in terms of the hardware and software involved. The information content of the output is also explained. A block diagram of the complete system is shown in Figure 3.1.

### 3.1 Z-80 Microcomputer

The Z-80 microcomputer family of components (available from Zilog and Mostek) has been used to implement the experiment. A microcomputer consists of three main parts: a CPU (the microprocessor), memory, and interface circuits to peripheral devices. AII of these main parts are MOS LSI devices and their small size allows a powerful system to be constructed in a small physical space.

The Z-80 CPU uses 8 -bit data words and 16 -bit addresses (i.e., a $2^{16}$ or 65,536 byte address space). It contains eighteen 8 -bit registexs and four 16 -bit registers. The registers include two sets of six general purpose registers that may be used individually as 8 -bit registers or in pairs as 16-bit registers. There are also two sets of accumulator and flag registers. There are six special purpose registers such as a program counter and a stack pointer. The Z-80 CPU can execute 158 instructions; these include special I/O instructions which allow the CPU to address $256 \mathrm{I} / 0$ devices in addition to the memory addresses. The CPU is contained in a 40 -pin dual-in-1ine package (DIP).

The Z-80 Parallel I/O Circuit (PIO) is a programmable device that provides two 8-bit parallel interfaces between peripheral devices and the CPU. Each of the two interfaces also has two 'handshake' lines so that the peripheral devices can control when data is input or output. The PIO can be programmed to operate in different modes depending on the application. For instance it can be programmed to be used as an input port that generates an interrupt to the CPU when one of the handshake lines is toggled; or interrupt capability and the handshake lines can be disabled so that data is input or output under software control. The PIO is contained in a 40-pin DIP,

The Z-80 counter-timer circuit (CTC) is a programmable four-channel device that provides counting timing functions for the CPU. It can also be programmed to act as an interval timer. In this mode a time constant is loaded into a down counter in the CTC by the CPU and the system clock is then used to decrement the counter; when it reaches zero, an interrupt is generated. Other modes allow external circuits to decrement the down counter or to be driven by


Figure 3.1 The data-manipulation system.
a divided system clock. The CTC is packaged in a 28 -pin DIP.
In the system described here the PIO's and the CTC are programmed as follows. One port of PIO \#1 (Port A) is programed as an interrupting input port with the handshake lines enabled. Port B is programmed as a non-interrupting output port and the handshake lines are not used. Port A of PIO \#2 is programmed as a non-interrupting input port and the handshake lines are again not used. The CTC is programmed to interrupt the CPU approximately every 1.5 ms .

An Intel 2716 EPROM is used to contain the non-volatile program for the rocket. It must be programmed by a special programmer (described in Chapter 6) before it is placed in the circuit. Its contents cannot be changed by the CPU after it is in the circuit although an ultra-violet light can be used to erase it if the program is to be changed. It can contain a 2 K byte program and is packaged in a 24 -pin DIP.

The RAM portion of the memory consists of four Intel 2114 memory chips (also available from EMM SEMI). The 2114 has $1 \mathrm{~K} \times 4$ bits and is packaged in an 18-pin DIP.

### 3.2 Peripheral Devices

When a particle is sensed by one of the detectors, the pulse that is generated (as described in the previous chapter) goes to a pulse-height analyzer (PHA). It latches onto the peak of the pulse and holds it until a reset signal is received. The peak of the highest level pulse is held if more than one is received before it is reset.

Four detectors are used in the PHA system although six particle detectors and the electrostatic analyzers are accommodated during a flight. An apogee switch is used to switch two of the particle detectors out and the electrostatic analyzer and another particle detector in at apogee. Thus the upleg and downleg records of a rocket flight produced by two of the PHA's are for different devices.

The four PHA outputs are sequentially multiplexed to the analog input of the A/D. Every $50 \mu \mathrm{~s}$ (actually $51.2 \mu \mathrm{~s}$ ) the multiplexer switches to the next PHA, thus each PHA is reset every $200 \mu \mathrm{~s}$. Two bits from the PHA system are incIuded with each PHA output going to the A/D to identify which PHA produced it.

The $A / D$ converts the 0 to 10 V analog signal from the PHA system to an 8-bit digital signal although only the upper 4 bits are used. An 8-bit converter was used due to the unavailability of a suitable 4 -bit converter. The A/D used
in the system is a Datel ADC-EH8B which converts the signal by the successive approximation method. The conversion time is approximately $2.4 \mu \mathrm{~s}$.

The first-in first-out memory (FIFO) is used to store data in a queue while the CPU is servicing an interrupt from the CTC (the CTC has a higher priority than PIO \#1). Nine-bit words are accepted at the input and automatically shifted toward the output and are removed at any rate in the same sequence in which they were entered. Up to $409-b i t$ words can be contained i the FIFO, but only 6 of the 9 bits are used in this system ( 4 bits from the A/D, 2 identifying bits from the PHA system). The three unused inputs are tied to ground. The FIFO allows data to be taken at a faster rate from the PHA system without losing data when the CPU cannot be interrupted by the PIO.

The D/A converts the system output from PIO \#2 to an analog signal varying between 0 and 5 V . The D/A used in the system, a Micro-Networks MN3020, converts an 8 -bit word to an analog signal between 0 and 10 V . Since the telemetry circuitry requires a signal between 0 and 5 V , the most significant bit of the D/A is not used and is tied to ground.

The magnetometer signal digitizer (MSD) converts the magnetometer signal to a 4-bit digital signal that represents the rocket's spin position. The magnetometer signal is a sine wave whose frequency equals the spin rate of the rocket. The conversion is done by incrementing a 4-bit counter at a constant rate ( 100 Hz ) and resetting it when the magnetometer signal crosses a zero reference point in the downward direction. Therefore, the counter is reset once per revolution of the rocket.

The circuit of the MSD is described in Levng et al. [1979]. It can be noted here that when the rocket is not spinning as during testing and before launch, the 4-bit counter resets itself, allowing the operation of the experiments to be observed.

The rotation is divided into equal sectors only for certain values of rocket spin rate: e.g., 6.67 Hz will give exactly 15 sectors (1.e., 100/6.67); 6.25 Hz will give exactly 16 sectors; and 5.88 Hz will give exactly 17 sectors. In general, because the rocket spin rate is pre-set only within a limited range, there will not be an integer number of sectors.

In the following section, for simplicity, the data manipulation will be described for the special case of a spin rate of 6.25 Hz . Later, in Section 5.2.3, the effect of other values of spin rate will be considered in detail.

### 3.3 Data Manipulation

As indicated above, the rocket rotation is divided into 16 discrete sectors (for a spin rate of 6.25 Hz ). This is shown in Figure 3.2(a). The 4-bit number provided by the MSD is used to generate an address for a memory sector that corresponds to a rotation sector. The offset within each memory sector is provided by the data from the FIFO. The entire memory address is formed by concatenating the 4 -bits from the MSD with the data from the FIFO, as shown in Figure 3.2(b).

The lower 1 K bytes of the RAM are divided into 16 sectors corresponding to the rocket rotation sectors as shown in Figure 3.2(c). Each of these 16 sectors is further divided into four areas corresponding to the PHA's. Each of these areas contains 16 bytes that correspond to 16 energy levels of the particles. Figure 3.2 (d) shows which parts of the 10 -bit address correspond to the rotation sectors, PHA's and energy levels.

When data is input to Port A of PIO \#1, an interrupt is generated by the PIO. The CPU services the interrupt by inputting the data. An address is then generated as stated above and the location pointed to is incremented. A flowchart of the input routine alogrithm is shown in Figure 3.3.

The CTC generates an interrupt every 1.536 ms which causes the CPU to go to an output routine. Data outputs are done in synchronism with rocket rotation. One memory sector (corresponding to a rotation sector) is output during $1+1 / 16$ revolution of the rocket. Data starts being output when the rocket has rotated to the rotation sector directly after the one corresponding to the memory sector to be output. For example, data from sector \#1 starts being output when the rocket has rotated to sector \#2 (referring to Figures 3.2(a) and 3.2(c)). Note that this results in the data in each sector being accumulated over 17 revolutions (i.e., $16+16 \times 1 / 16$ ). Since the duration of each sector 1 s 10 ms (the period of the 100 Hz oscillator), it follows that the output sequence represents the particle data (in each sector) accumulated for a period of 170 ms (i.e., $17 \times 10 \mathrm{~ms}$ ) less the reset time of the PHA ( 42.5 ms ). The output sequence repeats at intervals of 2.72 s (i.e., $17 \times 160 \mathrm{~ms}$ ) for this spin rate ( 6.25 Hz ).

The output routine algorithm as shown in Figure 3.4 outputs a byte of data when the output flag has been set. If the flag has not been set, the routine checks to see if the rocket has rotated to within the next sector. If it has, the output flag is set and the routine outputs the first byte in the sector.


Figure 3.2 (a) Rocket rotation sectors; (b) Address formed from the two data words; (c) Memory (d) RAM address.


Figure 3.3 Input routine algorithm.


Figure 3.4 Output routine algorithm.

Otherwise the routine just updates the stored magnetometer data and the routine is exited.

An address register (two of the 8-bit general purpose registers) is used to point to the byte to be output. After the data at a RAM location has been output to the D/A, the location is cleared. The address register is then incremented and checked to see if all of the sector has been sent. If it has, the output flag is reset. If all of the 16 memory sectors have been sent ( 1 K bytes), the address register is reset to the beginning address of the RAM.

An example of the output from the system is shown in Figure 3.5. Note that the data from each detector has a 5 V peak at the beginning. Although this peak should by definition correspond to the number of zeroes (no particles or particles below the sensitivity of the detectors) from each detector, it is automatically set to the maximum voltage by the CPU since the number of zeroes would be large anyway. The peaks are also useful in that they separate the detectors allowing the data to be read easily.

Note also the signal labeled "marker" at the beginning of the data for sector \#1. This signal is included to identıfy which sector is being output. It varies between 0 and approximately 5 V in 16 discrete steps. For instance the marker for sector \#0 is 0 V , the marker for sector \#7 is approximately 2.5 V and the marker for sector \#15 is approximately 5 V .


Figure 3.5 Example of output from D/A. The ordinate is the telemetered signal (in volts) and is proportional to number of units ( $5 \mathrm{~V} \equiv 32$ particles) in the accumulation period.

## 4. HARDWARE

The designs of the microcomputer, the A/D-FIFO interface, and the D/A interface are discussed in this chapter. The microcomputer and the $A / D$ and D/A converters are contained on four printed circuit boards as shown in Figure 4.1. The circuit board for PIO \#2 also contains the MSD and the PHA. A photograph of this board is shown in Leung et al. [1979]. Figure 4.2 shows the location of the system on the payload.

Some control signals used in the system are defined in Table 4.1. The detailed timing diagrams of these signals are not presented here as they are not necessary for an understanding of the system operation, but they are available in the MOSTEK data books in the reference list.

### 4.1 CPU-Memory Board

The CPU-memory board contains the $Z-80 \mathrm{CPU}$, EPROM and RAM memory, reset circuitry and the system clock oscillator as shown in Figure 4.3. A flexible ribbon cable (Ansley \#FSN-21A-20) from connector \#1 provides the necessary address, data, and control lines for the operation of the other three boards in the system.

A detailed schematic of the CPU-memory board is shown in Appendix I.1.
4.1.1 Memory address decoding. A one-of-eight decoder (Intel 8205 or T.I. 74LS138) is used to enable the RAM and EPROM memories. A diagram of the decoder circuit pin connections is shown in Figure 4.4 (a). Address bits All, A12, and A13 from the Z-80 CPU define which output of the decoder will go low. The $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{MREQ}}$ control lines are used as enabling inputs to the decoder. If $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ goes low and, in addition, $\overline{M R E Q}$ goes low, the decoder is enabled and one of the eight outputs specified by the address lines will go low. Only three of the eight outputs are used because only 4 K bytes of memory are in this system.

This particular decoder circuit was used because only one external gate was needed to generate the three select signals (the abbreviation for a select signal is $\overline{\mathrm{CS}}$ where the line indicates active low) and because it will allow easy system expansion in the future with a minimum of changes on the board (i.e., only additional address lines and the other $\overline{\mathrm{CS}}$ lines need be brought out to add another memory board). The resulting memory address map is shown in Figure 4.4 (c). The 1 K gap between the RAM segments exists because the decoder generates $\overline{C S}$ 's for 2 K memory segments and the RAM chips are 1 K segments.

(b)


Figure 4.1 Data-manipulation system circuit boards: (a) boards connected for installing in payload, (b) CPU-memory board.


Figure 4.1 Data-manipulation system circuit boards (continued). (c) PIO \#1-CTC board, and (d) A/D FIFO board.


Solid-state detectors, Preamplifiers, Shapers

Electrostatic analyzer experiment

Counting circuits
Microcomputer, Magnetometer digitizer, Pulse-height analyzer

Figure 4.2 Location of the data-manipulation system in the payload of Nike Apache 14.542 .

Táble 4.1
Z-80 Control signals.
$\overline{M 1}:$ An output signal from the CPU that indicates the current machine cycle is the instruction fetch cycle. $\overline{\mathrm{M1}}$ also occurs with $\overline{\mathrm{I} / \text { OREQ }}$ to indicate an interrupt acknowledge cycle, and it indicates to I/O devices when to place data on the data bus.
$\overline{\text { MREQ: }}$ The memory request signal is an output signal from the CPU that indicates the address bus holds a valid address for a memory read or memory write operation.

I/OREQ: The I/O request signal is an output signal from the CPU that indicates the lower half of the address bus holds a valid $\mathrm{I} / 0$ address for an $\mathrm{I} / 0$ read or write operation.
$\overline{\mathrm{RD}}$ : The read signal is an output signal from the CPU that indicates data should be placed on the data bus by memory or an I/O device.
$\overline{W R}$ : The write signal is an output signal from the CPU that indicates that the CPU data bus holds valid data to be stored in the addressed memory or an I/O device.
$\overline{\text { INT }: ~ T h e ~ i n t e r r u p t ~ r e q u e s t ~ s i g n a l ~ i s ~ g e n e r a t e d ~ b y ~} I / O$ devices. The request will be honored at the end of the current instruction by the CPU if software has enabled an internal interrupt enable flip-flop.
$\overline{\text { NMI }: ~ T h e ~ n o n-m a s k a b l e ~ i n t e r r u p t ~ r e q u e s t ~ s i g n a l ~ i s ~ a l s o ~ g e n e r a t e d ~ b y ~ I / O ~}$ devices. The request will always be honored at the end of the current instruction.
$\overline{\mathrm{RST}}$ : Reset signal
$\Phi$ : System clock
NOTE: The lines above the signals mean they are active low.


Figure 4.3 The CPU-Memory board. An arrow on one end of a line indicates a single durection signal; arrows on both ends indicate a bidirectional signal; dotted arrows indicate some lines go in one direction and some the other direction.

(a)

(b)

(c)

Figure 4.4 Address decoding: (a) Connection of the 8205 one-of-eight decoder; (b) Truth table ( $\mathrm{X}=$ don't-care state); (c) Memory addresses.
4.1.2 Reset circuit. The Z-80 CPU and CTC have a reset input that cannot be brought high until the data, address and control lines have stabilized after power-on. The reset input can also be used to restart the CPU and CTC in their initial states after power-on by bringing it low for a short period, but this feature was not needed in the data mannpulation experiment since it is a dedicated system (i.e., the software is not changed). When the reset line goes high, the CPU starts at address zero and the CTC is in its initial state (i.e., it is not yet programmed for operation). The PIO does not have a reset input but it is in its initial state automatically after a power-on.

The reset circuit itself is simple as shown in Figure 4.5. When power is applied, the $68 \mu f$ capacitor starts charging through the $10 \mathrm{k} \Omega$ resistor. When the Schmitt trigger input of the first NAND gate reaches approximately 1.6 V , it switches and an instant later the reset line goes high. If for some reason power is interrupted to the system, the capacitor discharges rapidly through the diode. The reset line goes high approximately 77 ms after power is applied [i.e., $\left.-\left(10^{4}\right)\left(68 \times 10^{-6}\right) \ln (1.6 / 5)\right]$.
4.1.3 Clock. A Motorola KIll5A 2.5 MHz crystal oscillator provides the system clock signal. It was used because of its small size, slightly larger than a 14 -pin DIP, and because it provides a TTL compatible output. As shown in Figure 4.6 a 7404 with $330 \Omega$ pull-up resistors on the outputs is used to buffer the clock signal. The $330 \Omega$ pull-up resistors are required in the $Z-80$ components' specifications. The K1115A oscillator is specified to tolerate a minnmum shock of $100 \mathrm{G}^{\mathrm{t}} \mathrm{s}$ for 0.1 milliseconds with three shocks in each plane. This specification is adequate for a rocket flight: the oscillator performed well both in pre-flight tests and in actual flight of Nike Apache 14.543.
4.1.4 Read-write control. As shown in Figure 4.3 the 2114 RAM circuits recelve the $\overline{\mathrm{WR}}$ control signal. It controls whether data is input or output: a high level causes data to be output by the RAM's; a low level causes data to be input (the $\overline{\mathrm{CS}}$ lines must be low also).

### 4.2 PIO \#1 and CTC Board

This printed curcuit board contains PIO \#1, the CTC and the D/A as shown in Figure 4.7. A detailed schematic of the board is shown in Appendix I.2.

The 8205 (or 74LS138) decoder on this board is used to select which I/0 port is enabled. PIO \#1 has I/O addresses 1 through 3, the CTC has 4 through 7, and PIO \#2 has 8 through 11. The other outputs of the decoder are brought out on connector \#2 for future expansion of the I/O capabilıty.


Figure 4.5 Reset circuit.


Figure 4.6 System clock.


Figure 4.7 The PIO\#1-CTC board. The arrows have the same meaning as in Figure 4.3.

The interrupt enable input (IEI) signal from PIO \#1 is brought out on connector \#2 so that other I/O ports added in the future can generate maskable interrupts. This signal would be used in the daisy-chain interrupt mode (i.e., Mode 2) described in the MOSTEK Z-80 literature in the reference list. This signal is not used in this system, however, since the Mode 1 interrupt option is used, as described in the following chapter.

Even though there are only two ports, the PIO's require four addresses because each port has control logic that must be addressed individually, as shown in Figure 4.8. This logic is programmed to control whether a port is an input or an output port, the handshake lines, and the generation of interrupts.

The two handshake lines, RDY and $\overline{\mathrm{STB}}$, control the data input to a port and the generation of an interrupt to the CPU when the port is programmed to operate in the appropriate mode (i.e., Mode 1, consult the PIO data book). In the data manipulation system the handshake lines are used only for Port $A$ of PIO \#1.

The timing diagrams for ARDY and $\overline{\text { ASTB }}$ are shown in Figure 4.9(a) where the "A" indicates they are for Port A. Data is loaded into the Port A input register by applying a pulse of 150 ns (or greater) to the $\overline{\mathrm{ASTB}}$ pin (normally high, pulsed low). ARDY indicates when the input register is empty and is ready to accept an input (normally low, active high). When data is loaded into the input register, an interrupt is generated by the PIO by bringing the INT line low. When the CPU has read the input register contents, ARDY returns high. When the PIO is initialized after power-on, Port A must be read once to bring ARDY high even though there is no data in the input register.

As stated in the previous chapter the CTC generates an interrupt when an internal down-counter reaches zero. The CTC in this system is connected to the $\overline{\text { NMI }}$ line of the CPU which is used to generate non-maskable interrupts. Thus it has a higher priority than PIO \#1 or any I/O port that would be added in the future.

### 4.3 A/D and FIFO Board

This board contains the A/D, the FIFO, and associated timing logic as shown in Figure 4.10. A detailed schematic of the board is shown in Appendix I. 3. Data is input to this board from the PHA system and is output to Port A of PIO \#1.

The A/D starts converting an analog signal to its digital representation when a pulse of 100 ns minimum width is applied to its start-convert pin as


Figure 4.8 PIO block diagram (MOSTEK 280 Manual).

(c)


Figure 4.9 Timing diagrams: (a) PIO\#l Port A handshake line timing; (b) A/D control signal timing;
(c) FIFO handshake line timing.


Figure 4.10 The A/D-FIFO board. The arrows have the same meaning as in Figure 4.3.
shown in Figure 4.9 (b). When the conversion is finished, the end-of-convert line goes low until another conversion is started.

The FIFO can be regarded as nine 40 -bit serial shift registers. Data is input to the first register and trickles through until a location containing data or the 40 th location is encountered. The FIFO has handshake signals similar to the PIO signals which control data input and output.

The timing diagram of the FIFO handshake signals is shown in Figure 4.9 (c). The input-ready signal indicates when data may be entered into the first register. Data is entered by bringing the shift-in line high. This causes the input-ready line to go low but data will stay in the first register until the shift-in input goes low. The data then propagates to the second location providing it is empty, and the input-ready line goes high again. The inputready line will stay low if the FIFO is full. Once data has been shifted to the second location, it automatically continues until other data or the last register is encountered as stated above. The output-ready line goes high when the data reaches the last location. Data is shifted-out when the shiftout line is brought low and returns high. Data is not shifted from the 39th to the 40 th location until the shift-out line goes back high, therefore, the output data is stable until then. The output ready line goes back high when the data has been shifted unless the FIFO is empty.

The end-of-convert signal from the $A / D$ is used to enter data into the FIFO. When the end-of-convert signal makes a high-to-low transition, it triggers a 74123 monostable multivibrator as shown in Figure 4.11. The multivibrator then generates a 475 ns pulse on the shift-in line of the FIFO.

The A/D end-of-convert signal and the FIFO input-ready line are combined to generate a status signal to indicate when the board is ready for an input, but it is not used by the PHA system. Since data is input at relatively long intervals of $50 \mu \mathrm{~s}$ the status signal is not needed. It may be noted that the ready-for-input signal, if used, would have to be used judiciously since it will momentarily go low up to 1.025 us before another start-convert can be applied, as noted on the diagram. It momentarily goes low because the FIFO input-ready signal does not go low for up to 440 ns after the shift-in input is brought high.

Data is strobed into PIO \#1 using: the output-ready signal from the FIFO; ARDY of the PIO; and the system clock divided by eight (i.e., 0.3125 MHz ). These three signals are input to a NAND gate whose output goes to another


Figure 4.11 The circuit and timing diagram for the input to the FIFO and the ready-for-input status signal.
monostable multivibrator as shown in Figure 4.2 (the multivibrator is the other half of the 74123 used above). When the divided clock signal makes a high-tolow transition while the other two NAND gate inputs are high, the monostable will be triggered and the $\overline{A S T B}$ line of the PIO will receive a 580 ns pulse. This signal is also used to drive the shift-out line of the FIFO. The divided clock signal is provided by the PHA system.

The divided clock signal is included because ARDY could possibly stay high longer than the time it takes the output-ready signal to go low and return high as shown in Figure 4.12. Because of this a method was needed to trigger the multivibrator after both signals have been high for a period of time. If only ARDY and output-ready were used, an extra pulse from the multivibrator could possibly occur causing a data sample to be lost. By using the high-tolow transition of the clock to tragger the multivibrator only one pulse will be generated by multivibrator.

On the systems constructed for Nike Apaches 14.542 and 14.543 ब/2 was used instead of $\Phi / 8$ (i.e., $\Phi$ is the symbol for the clock signal). This could cause a problem if $\Phi / 2$ goes low, high, then back low again after output ready has returned high and before ARDY goes low; or if ARDY goes low while both $\Phi / 2$ and output-ready are high. The system using $\Phi / 2$ appeared to work well during tests and the rocket flight but on future flights $\Phi / 8$ should be used.

The same signal for the PIO $\overline{\text { ASTB }}$ line and the FIFO shift-out line can be used because the data hold time beyond the $\overline{\mathrm{ASTB}}$ low-to-high transition required by the PIO 1 s zero and a finite amount of time is required to shift data from the 39th to the 40 th position in the FIFO after the shift-out transition. Since the data on the output pins of the FIFO will not change instantaneously when the transition occurs, the hold time of the FIFO is greater than zero.

In Figure 4.12 note that an extra trigger to the multivibrator could possibly occur during a pulse. This is permissible since it will only cause the pulse to be longer than 580 ns .

### 4.4 PIO \#2

As shown in Figure 4.13 PIO \#2 is on the board that contains the PHA system and the magnetometer signal digitizer. Four bits of Port A are used to input the magnetometer data, but Port B is not used.

Although only four of the sixteen PIO I/O bits are used, the PIO circuit provided the easiest and most efficient interface to the MSD since all the Z-80 control signals are handled by the PIO's internal logic. In addition the extra


Figure 4.12 The circuit and timing diagram for input to PIO\#1 from the FIFO.


Figure 4.13 The PIO\#2 board. The arrows have the same meaning as in Figure 4.3.

I/O bits could be used for a future experiment.
As stated before PIO \#2 has addresses 8 through 11 with the $\overline{\mathrm{CS}}$ provided by the decoder on the P-IO-CTC board, but only the addresses for Port $A$ are needed (i.e., 8 and 9).

A detailed schematic of this board is given in Leung et al. [1979].

## 5. SOFTWARE

The software written for the data-manipulation experiment is discussed in this chapter. Since some understanding of the $\mathrm{Z}-80$ architecture is needed, a brief description of it is included.

### 5.1 2-80 Architecture

The Z-80 CPU register configuration is shown in Figure 5.1; the CPU contains two sets of independent accumulator, flag, and general purpose registers. A single exchange instruction enables the CPU to switch between the accumulator and flag pairs while another single instruction is used to switch between the general purpose register sets. This exchange capability is useful (it saves time) when an interrupt is serviced because the contents of the registers do not have to be saved in RAM.

The 8 -bit accumulator register is used to hold the results of 8 -bit arithmetic and logical operations while the flag register indicates the status of 8 or l6-bit operations, such as indicating whether or not the result of an operation is negative or positive. The 8-bit general purpose registers can be used in pairs for 16-bit operations, specifically the BC, DE and HL pairs in both sets. The HL pairs are used by several instructions for memory addresses.

The program counter holds the 16 -bit address of the current top of the stack located in external RAM. The stack is a last-in-first-out memory file that is used to temporarily store data from the registers. The other special purpose registers are not used by the data manipulation experiment software.

The Z-80 CPU has both maskable and non-maskable interrupts. The CPU can be programmed to respond to a maskable interrupt in any one of three possible modes. Mode 1 is used in the present application since there are only two interrupting devices. In this mode a maskable interrupt from PIO \#1 causes the CPU to jump to location 0038 H (where H means hexadecimal or base 16). A non-maskable interrupt from the CTC causes the CPU to jump to location 0066 H.

The Port I/O logic of one port of a PIO is composed of six registers with "handshake" control logic as shown in Figure 5.2(a). The 2-bit mode control register is loaded by the CPU to select the desıred operating mode. The input register holds data input to the port and the output register holds data that is to be output. The handshake logic controls the transfer of data between the peripheral and the PIO.


Figure 5.1 Z80-CPU register configuration (MOSTEK Z80 Micro-Reference Manual).


Figure 5.2 Block diagrams of (a) one port of a PIO and (b) one channel of the CTC (MOSTEK Z80 Manual).

The 8 -bit $I / 0$ select register and the 8 -bit mask register are used when the port is programmed to operate in Mode 3. In this mode any of the data lines can be programmed to be an input or output as specified by the select register. The 2-bit mask control register and the mask register are used to control the generation of interrupts in Mode 3, but they are not used in the data manipulation software.

The logic for one channel of a CTC is composed of two registers, two counters and control logic as shown in Figure 5.2(b). The time constant register is loaded by the CPU to initialize and re-load the down counter at a count of zero. The channel control register is loaded by the CPU to select the mode and conditions of channel operation. The prescaler divides the system clock by 16 or 256 for decrementing the down counter. The external clock/timer trigger and the zero count/timeout signals are not used in the data manipulation experiment.

### 5.2 Data-Manipulation Software

The software for the system comprises three main parts: initialization, the input routine, and the output routine. During initialization the CTC and PIO's are programmed for operation, the RAM is cleared and other pre-operation details are taken care of. The input and output routines function as explained previously. These three sections of the software are discussed further below. A listing of the program is given in Appendix II.l.
5.2.1 Initialization. The flowchart of this section of the software is shown in Figure 5.3. After power-on the PIO's and the CTC are programmed as shown although the interrupt capability of PIO \#1 is not enabled and the CTC time constant is not loaded until just before the "Halt" instruction. This is done to prevent an interrupt from occurring before the initialization is finished. HL' and DC' are loaded with 800 H and zero respectively for use in the output routine. Data from the magnetometer must be shifted right two positions and 800 H must be added as shown in Figure 5.4 before it can be used to designate the rotation sector memory area shown in Figure 3.2(d). The ARDY line of PIO \#1 must be raised the first time by reading Port A although the data is not used. After the ARDY line is raised, the CPU executes.a "Halt" instruction. When this is done, the CPU enters an inactive state that can only be exited when an interrupt is received. After the interrupt is serviced, the CPU executes the instruction directly following the Halt instruction which is a jump back to it.


Figure 5.3 Flow chart of the initialization section.

(a)

| 0 | 0 | 0 | 0 | 0 | 0 | $M 3$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

REGISTER D
(b)


REGISTER D


REGISTER E
(c)

Figure 5.4 Magnetometer data bit positioning: (a) Data bits are put into register $D$; (b) shifted right two places into top two bits of E , (c) 800 H is then added.
5.2.2 Input routine. A more detailed flowchart of the input routine than in Figure 3.3 is shown in Figure 5.5. Register pair DE is used to hold the current magnetometer data and is updated by the output routine. The data from the PHA system in A is concatenated with the magnetometer data in DE by simply adding register E to A. Register pair HL is then used to hold the concatenated data which point to the RAM location to be incremented.

The two lowest order bits of each RAM location are not used since they could be lost when the location is output due to noise (i.e., low order accumulations would be difficult to discriminate from zero). Therefore, four must be added to each location so that it is incremented beginning in the third bit position (i.e., ${ }^{4} 10=100_{2}$ ).

When a maskable interrupt is serviced by the CPU, an internal flip-flop is automatically reset such that subsequent maskable interrupts will be ignored. This flip-flop must be set when the input routine is exited so that maskable interrupts are again enabled.

The input routine requires between 30 and $31.6 \mu s$ for execution (for a 2.50 MHz system clock) providing the CPU does not service a CTC interrupt. $24.8 \mu \mathrm{~s}$ are required for executing the instructions in the routine and from 5.2 to $6.8 \mu s$ are required by the CPU to exit the "Halt" state and prepare for servicing the interrupt (i.e., the contents of the program counter are stored in the stack file).

Since the input routine requires $31.6 \mu$ s and data is input to the FIFO every $51.2 \mu \mathrm{~s}$, the FIFO is never allowed to store data past its maximum limit. In fact, no more than four inputs are input to the FIFO during the output routine since the maximum time required for the output routine is about 170 . .

The time it takes for the system to catch up with the inputs waiting in the FIFO can be calculated as follows. Let $T_{1}$ equal the maximum time of the output routine, $T_{2}$ equal the time it takes the system to catch $u p, r_{1}$ equal the input rate to the FIFO, and $r_{2}$ the output rate from the FIFO to the data manipulation system.

$$
\begin{equation*}
r_{1}\left(T_{1}\right)+r_{1}\left(T_{2}\right) \leq r_{2}\left(T_{2}\right) \tag{5.1}
\end{equation*}
$$

Now although it would appear that $T_{1}=170 \mu \mathrm{~s}$, the possibility of the CTC interrupt occurring during the input routine must be taken into account. If the CTC interrupt is received directly after the PIO interrupt, the input routine for that interrupt would have to be finished after the output routine


Figure 5.5 Flow chart of the input routine.
since the CTC has a higher priority. In this case the time to complete the input routine should be added on to the maximum time of the output routine. The input routine would, in the worst case, start at the "Load H register with contents of $D^{\prime \prime}$ instruction as shown in Figure 5.5. In this case $T_{1}$ would be approximately equal to $195 \mu \mathrm{~s}$ (i.e., $170 \mu \mathrm{~s}+24.8 \mu \mathrm{~s}$ ).

Using equation (5.1) a value for $T_{2}$ can now be obtained as follows

$$
\begin{equation*}
\frac{1 \text { input }}{51.2 \mu \mathrm{~s}}(195 \mu \mathrm{~s})+\frac{1 \text { input }}{51.2 \mu \mathrm{~s}}\left(T_{2}\right) \leq \frac{1 \text { output }}{31.6 \mu \mathrm{~s}}\left(T_{2}\right) \tag{5.2}
\end{equation*}
$$

Since it is impossible to get a partial input, we round the first term up to 4. Thus equation (5.2) becomes

$$
\begin{equation*}
4+\frac{T_{2}}{51.2 \mu \mathrm{~s}} \leq \frac{T_{2}}{31.6 \mu \mathrm{~s}} \tag{5.3}
\end{equation*}
$$

This gives a value of $330 \mu \mathrm{~s}$ for $T_{2}$, but since this is not an integer multiple of $31.6 \mu \mathrm{~s}, 347.6 \mu \mathrm{~s}$ should be used.

Since this is the worst case value for the catch-up time, there is no danger of the system getting behind (i.e., $0.3476 \mathrm{~ms} \ll 1.536 \mathrm{~ms}$, the CTC interrupt interval). The output routine normally takes much less time than $170 \mu \mathrm{~s}$, as will be shown in the next section. In most cases no more than two or three inputs would be waiting in the FIFO at the end of the output routine.
5.2.3 Output routine. The output routine is the most complex of the three software sections. As will be explained below, this results from a desire to provide a method for outputting data in the event of failure of the MSD and the need to accommodate a range of values of rocket spin rate.

A more detailed flowchart than the one in Figure 3.4 is shown in Figure 5.6. The register sets are exchanged after the magnetometer data in DE is updated. Data for the input routine is contained in one register set while data for the output routine is contained in the alternate set. Note that $D E{ }^{\prime}$ also contains the updated magnetometer data for use later in the routine. Register $C^{\prime}$ is used as the output flag, as described in Chapter 3. A 01 H contained in $C^{\prime}$ corresponds to the flag being set while 00 corresponds to its being reset.
(a) MSD failure mode. The software includes a method to output data even if there is a failure of the MSD. In this mode the energy spectrums are obtained but there is no pitchmangle distribution.


Figure 5.6 Output section of the software.

Register $B^{\prime}$ is incremented every time there is a CTC interrupt (i.e., every 1.536 ms ) and is reset to zero when data is output. If the output flag is not set by the MSD before $B^{\prime}$ is incremented to 67 , it is set automatically.

The number of times $B^{\prime}$ is incremented before the output flag is set imposes a lower limit on the spin rate that can be accommodated. The last data output and the first time $B^{\prime}$ is incremented overlap such that $B^{\prime}$ would be incremented 67 times between outputs. Since there are 65 outputs (i.e., the 64 data bytes and the marker signal) and $\mathrm{B}^{\prime} 1 \mathrm{~s}$ incremented 67 times, the largest spin period that can be accommodated is 193 ms (i.e., ( $65+67$ ) $\times 1.536$ $\mathrm{ms}-10 \mathrm{~ms}$ ). Figure 5.7 illustrates the situation for a spin period of 193 ms (or longer). A spin period of 193 ms corresponds to a spin rate of 5.18 Hz which is considerably slower than the spin rates of past flights (which have been in the range of 6.4 to 7.5 Hz ).

The choice of 67 in the above discussion is determined as a compromise between complicating requirements. The output rate in the event of an MSD failure is desired to be as fast as possible, which sets an upper limit on the number of times $B^{\prime}$ is incremented. It was arbitrarily decided that the interval between outputs should be no more than $10 \%$ longer than the time it takes to output a sector. This corresponds to 110 ms and an upper limit of 72 times (i.e., $110 / 1.536$ ) to increment $\mathrm{B}^{\prime}$. A 5.5 Hz spin rate ( 182 ms period) was arbitrarıly decided upon as the slowest spin rate anticipated. This gives a lower limit of 60 times (i.e., 182/1.536) to increment $\mathrm{B}^{\prime}$. Thus the interval created should be greater than 60 but less than 72; 67 was adopted.
(b) Outputting sectors \#12 to \#15. The last four sectors are output when the magnetometer signal digitizer indicates the rocket has rotated to sector \#0 (1.e., the 4-bit counter output is zero). Figure 5.8 illustrates the reasons for doing this. When the spin rate is faster than 6.67 Hz (i.e., 150 ms period), data will not be input to one or more of the higher order sectors by the input routine. However, because the software is written assuming there would be sixteen sectors, all sixteen are always output even though the data in the highest order sectors may be zero. Therefore a method to set the output flag for the high order sectors was needed, other than the method used for the low order sectors explained in Chapter 3 (i.e., for the lower order sectors the output flag to output a particular sector is set when the rocket has rotated to the sector directly following it). By setting the output flag for the last four sectors when the 4 -bit counter is reset to zero, a spin rate of up to


Figure 5.7 Here and in the following figure the output of the MSD is represented as an alog signal to show the relationship between the rocket spin period and the counter cycle time. The case shown here is for a 5.18 Hz spin rate (i.e., 193 ms period). 10 ms must be added to the spin cycle time to get the interval between the times when the output flag is set between succeeding sections. Since the counter is incremented at 100 Hz , there are 20 increments between the times the counter is reset (the last count has a shorter interval, 3 ms ). This diagram also represents the situation for a spin period greater than 193 ms and for no magnetometer signal. R indicates the internal reset of the 4 -bit counter and $M$ the reset of the counter by the magnetometer.


Figure 5.87 .14 Hz spin rate causes the magnetometer signal digital representation to have 14 levels (refer to Figure 5.7). R indicates reset of 4-bit counter by the magnetometer.
8.33 Hz (i.e., 120 ms period: 12 sectors of input data) can be accommodated without causing the output to get out of synchronism with the rocket rotation.

Register pair HL' is used to contain the address of the next byte to be output, and the difference between the contents of $\mathrm{HL}^{\prime}$ and DE' is used to set the output flag since DE' contains the updated magnetometer data. If the output flag is not set, but the difference between the contents of HL' and DE' is FFCO H (i.e., the 2's complement of 0040 H ), it will be set. For instance if the contents of DE ' were 840 H and the contents of $\mathrm{HL}^{\prime}$ were 800 H , the output flag would be set. Since $H^{\prime}$ contains $0 B H$ when HL' points to a location in the last four sectors, the output flag can be set when the most significant byte of the difference between $\mathrm{HL}^{\prime}$ and $D E^{\prime}$ equals 03 . For example when HL' contains B40 H (i.e., corresponds to sector \#13) and DE' contains 800 H (i.e., corresponds to sector \#0) the difference is 340 H . By only considering the upper byte the software is simplified and takes less time.
(c) Sompling time. In the simplified description in Chapter 3 it was shown that the accumulation interval for each sector is the time it takes for 17 revolutions of the rocket. This will now be shown to be true for the actual output routine just described.

As shown in Figure 5.9 the interval between when the output flag is set for one sector and when it is set for the succeeding sector is $1+1 / 16$ revolution for the first twelve sectors. The interval between when it is set for sector \#11 and when it is set for sector \#12 is $1+4 / 16$ revolution since the flag is not set to output sector \#12 until the rocket has rotated to sector \#0. The following three sectors also start being output at sector \#0 on succeeding revolutions so that the interval between setting the flag is 1 revolution for these sectors. Thus the sum of the sixteen intervals is seventeen revolutions (i.e., $12(1+1 / 16)+(1+4 / 16)+4 \times 1=17)$.

The sampling time for most sectors is a constant ( 170 ms ) when the output is synchronized to the spin of the rocket, independent of the spin rate; the exceptions are the highest order sectors for spin rates greater than 6.25 Hz and the lowest order sectors for spin rates less than 6.25 Hz . After the rocket flight the spin rate is accurately known and the sampling time of the sectors can easily be calculated. For example, consider a spin rate of exactly 7 Hz . This is a spin perıod of 142.86 ms . Thus sectors \#0 to \#13 would have the full sampling time of 170 ms but sector $\# 14$ would have a sampling time of 48.6 ms (i.e., $17 \times 2.86 \mathrm{~ms}$ ) and sector \#l5 would have a sampling time of 0


Figure 5.9 The interval between the output flag being set to output consecutive sectors depends on which sector it is being set for. (a) $1+1 / 16$ revolutions occur between when the output flag is set to output consecutive sectors except for 12,13 , and 14 . (b) The interval between the output flag being set for sectors 11 and 12 is $1+4 / 16$ revolutions. (c) The interval between the output flag beang set for sectors 12 and 13 , sectors 13 and 14 , and sectors 14 and 15 is exactly one revolution
(i.e., no data). In practice only the data from sectors \#0 to \#13 would be used.

Now consider the situation for a spin rate of 5.5 Hz . The spin period of 181.82 ms results in sectors \#0 and \#1 accumulating samples twice and, therefore, having sampling times of 340 ms . Sector \#2 has a sampling time of 201 ms (i.e., $17 \times(10+1.82) \mathrm{ms})$. Sectors \#3 to \#l5 have a sampling time of 170 ms . Thus sectors \#0 to \#2 would contain more samples than the other 13 .

As noted in Section 3.2 the input to the data-manipulation experiment is the output of the PHA. The multiplexer in the PHA has a timing sequence, involving the sampling and resetting, which reduces the count rate to $70 \%$ of the rate originating at the particle detectors (ERS and ESA) [Leimg et al., 1979]. This factor must be taken into account in deriving flux densities from the output data of the data-manipulation experiment.
(d) The marker signal. The marker signal described in Chapter 3 is obtained by extracting the sector number from the HL' register pair and outputting it immediately after the output flag is set. The lower two bits from the $H^{\prime}$ register and the upper two bits from $L^{\prime}$ register are loaded into the A register. The data is then shifted in the $A^{\prime}$ register such that the most significant bit is in the sixth bit position as shown in Figure 5.10.
(e) Other features. Again referring to the flowchart in Figure 5.6 If the output flag is set when the output routine is entered, the program branches to "SEND". This section of the output routine outputs the sector data to the D/A and resets the output flag when all of a sector has been sent.
"END" is a RAM location that is used to contain the last address of a sector plus one. When HL' has been incremented enough times such that its contents equal the contents of the END and END +1 locations, the output flag is reset.

The hagh level outputs at zero energy locations that were discussed in Chapter 3 are obtained by outputting 7 FH when the four low order bits of $\mathrm{L}^{\text {r }}$ are all zeroes. The zero energy outputs will be slightly higher than the maximum output of the other fifteen energy levels since the two lowest order bits are ones whereas they are always zero for the other outputs.

Whenever the output routine is exited, the register sets are exchanged. As stated previously the DE register pair now contains the updated magnetometer data for use by the input routine.

(b)

Figure 5.10 The marker signal is obtaned from HL' and is put in $A^{\prime}$ for output to D/A. (a) Sector number in HL' is put in $A^{\prime}$. (b) Three shıfts are then done to put data in proper bit positions for output to the D/A (i.e., two right circular shifts and one right shift with a zero put into the 7th bit).

The "return from a non-maskable interrupt" instruction automatically enables maskable interrupts. Therefore, the interrupt enable instruction does not have to be used (it was used in the input routine).
(f) Output routine execution time. The amount of time necessary to execute the output routine depends on the branches taken within it. There are three main possible paths that can be taken: (1) the output flag is set and a byte of data is output to the D/A, (2) the output flag is not set when the routine is entered but it is set during the routine, and (3) the output flag is not set when the routine is entered and it is not set during the routine. Path ( 1 ) requires from $99.6 \mu \mathrm{~s}$ to $123.2 \mu \mathrm{~s}$ depending on whether the output flag must be reset or not and whether it is the end of sector 15 or not. Path (2) requires either $130,160.4$ or $168.8 \mu$ s depending on whether (a) the flag is set because $B^{\prime}$ has reached 67, (b) it is set for one of the last four sectors, or (c) it is set for one of the first twelve sectors. Path (3) requires either 112.4 or $104 \mu s$ depending on whether the flag test is applied for the first twelve sectors or for the last four.

Path (2) requires the greatest amount of time, but it is the path most seldom taken since the output flag is only set once per revolution. Path (1) will be taken 64 times per revolution since 64 bytes of data are output. The number of times path (3) is taken depends on the spin rate of the rocket but it will be taken fewer times than path (I) unless the spin rate is slower than or equal to 5.3 Hz .

## 6. THE SDB-80 BOARD AND THE EPROM PROGRAMMER

Software was developed for the rocket system using a MOSTEK SDB-80 board, a teletype, and an EPROM programmer as shown in Figure 6.1. Some of the features of the SDB-80 and the design and operation of the EPROM programmer are discussed in this chapter.

### 6.1 The SDB-80 Board

The SDB-80 is a complete stand-alone microcomputer designed around the Z-80 microprocessor. It contains 10 K bytes of on-board firmware for software development consisting of an assembler/editor and an operating system. Programs can be edited and assembled directly from 16 K bytes of on-board RAM; this is much quicker than using the teletype tape reader and punch for the source and object versions. Two PIO's and a serial port are provided to interface the SDB-80 to peripheral devices. A photograph of the board is shown in Figure 6.2.

The operating system, the DDT-80, has several commands that allow a user to control the operation of the SDB-80. The DDT-80 also provides the software routines for interfacing various peripherals, such as the teletype, to the board. The commands of the DDT-80 are useful when debugging a program on the SDB-80. For example the user can read and modify registers in the CPU, start the execution of a program at a particular address, or dump the contents of a memory segment to a paper tape punch. A particularly useful command allows the user to set a breakpoint at a particular address within a program (i.e., when program execution reaches this location, the contents of the CPU registers are printed out).

The text editor on the SDB-80 is used to generate and modify Z-80 assembly language source programs. There are several editing commands for both line and character editing. Examples of these are a delete-line command and a command that changes a string of characters to another string.

Once the source program is generated using the editor, it is assembled to produce Z-80 object code. The assembler on the SDB-80 is a two-pass assembler, and it supports conditional assemblies, global symbols, relocatable programs and a printed-symbol table.

The SDB-80 was used to generate, run and debug the initial software for the rocket system. The A/D, the D/A, and a simulated magnetometer signal digitizer were interfaced to the SDB- 80 using the two on-board PIO's. A CTC on another board was used to generate the non-maskable interrupts since the on-board CTC generated maskable interrupts and had a lower priority than the


Figure 6.1 The EPROM programmer and the teletype connected to the MOSTEK SDB-80 board. This system was used to develop the data-manipulation system software.


Figure 6.2 MOSTEK SDB-80 Board

PIO's. Once a version of the program was running well on the SDB-80, it was transferred, with some minor modifications, to a 2716 EPROM on the actual data manipulation circuit boards for further debugging. Using the SDB-80 for the initial versions of the software greatly reduced the debugging time.

### 6.2 EPROM Programmer

An EPROM programmer was designed and built to program 2708 and 2716 EPROM's. The EPROM programmer is interfaced to the SDB-80 by PIO \#2 (connector J3, Figure 6.2). Port $A$ is used for the 8 -bit word to be put on the EPROM, and Port B is used for the programmer control signals.
6.2.1 Programming waveforms. The 2716 EPROM is programmed by applying a 50 ms TTL-level pulse to pin 18 (the PD/PGM input) when there is 25 V on pin 21. Figure 6.3 (a) shows the 2716 program and verify waveforms. Before the pulse is applied, a data word and its corresponding address must be placed on the data and address lines of the 2716 and held for the duration of the pulse. The $\overline{\mathrm{CS}}$ line must also be held high during the program pulse, but the programmed data may be checked immediately after the 50 ms pulse by lowering the $\overline{\mathrm{CS}}$ line.

To program the 2708 it must first be put in the program mode by bringing the $\overline{\mathrm{CS}}$ line to +12 V and holding it there for the duration of the programming. A +26 V 1 ms pulse is applied to the PGM pin for each data word corresponding to an address generated by the 4040 counter. Programming all 1024 locations sequentially with a 1 ms pulse constitutes one loop and one hundred loops are required to program the 2708 (manufacturer's specifications). The program waveforms for the 2708 are shown in Figure 6.3(b).
6.2.2 Programmer hardware. The amount of hardware involved in constructing the programmer was kept to a minimum by implementing all the timing functions with software. A block diagram of the programmer is shown in Figure 6.4 (a detailed schematic is included in Appendix I.4).

The 4040, a CMOS binary counter circuit, is used to generate the addresses for the 2708 or the 2716 when one is being programmed or read. Since the data locations are programmed sequentially, the 4040 is reset and incremented to generate the corresponding addresses. A data word corresponding to the address generated by the 4040 is placed on Port A of PIO \#2. Then the PGM line of the 2708 or the PD/PGM line of the 2716 is raised for 1 ms or 50 ms respectively as described in the previous section. The 4040 is then incremented and the next location is programmed.


Figure 6.3 Programming waveforms. (a) 2716 program and verify waveforms. (b) 2708 program waveforms.


Figure 6.42708 and 2716 EPROM programmer. Everything to the left side of the dotted line is on the SDB- 80 board.

The AND gates are used to prevent the program pulse lines from going high or the $\overline{\mathrm{CS}}$ lines from going low accidentally. Before the programmer software is executed, the output buffers for Port B of PIO \#2 on the SDB-80 are high because the Port B lines are in a high impedance state and the Port B buffers are non-inverting TTL gates (i.e., the TTL-gate inputs float high; the buffers are not shown in Figure 6.3). When Port $B$ is initıalized, its output lines go low. Since both high and low states are encountered, an exclusive or type logic had to be used to avoid damaging the EPROM or incorrectly programming a location. By inverting one input to an AND gate and not inverting the other only one input state will cause the output to go high, which solves the problem.

The following Boolean equations show the $\overline{C S}$ lines and the program puise lines of the 2708 and 2716 as functions of the Port B lines. For the 2716 they are:

$$
\begin{align*}
& \overline{\mathrm{CS}}=\overline{\overline{\mathrm{B1}} \cdot \mathrm{~B} 6}=\mathrm{B1}+\overline{\mathrm{B} 6}  \tag{6.1}\\
& \mathrm{PD} / \mathrm{PGM}=\mathrm{B} 0 \cdot \overline{\mathrm{B7}} \tag{6.2}
\end{align*}
$$

For the 2708 they are:

$$
\begin{align*}
& \overline{\mathrm{CS}}=\overline{\mathrm{B} 4 \cdot \overline{\mathrm{~B} 1}}=\mathrm{BI}+\overline{\mathrm{B} 4}  \tag{6.3}\\
& \mathrm{PGM}=\mathrm{B} 0 \cdot \overline{\mathrm{~B} 5} \tag{6.4}
\end{align*}
$$

B0 and B1 control the input and output buffers for Port A of the SDB-80 PIO. B0 must be high to enable the output buffer and Bl must be low to enable the input buffer. As shown by the above equations the $\overline{\mathrm{CS}}$ lines cannot go low unless the input buffer is enabled, and the program pulse line cannot go high unless the output buffer is enabled.

As shown in Figure 6.4 there is a switch on one of the inputs to each of the program pulse AND gates. They prevent an EPROM from accidentally being programmed by some possible malfunction of the hardware or software on the SDB-80. Before Port B as initialized by the programmer software, the switches should not be switched with an EPROM in one of the sockets since there would be a possibility of a spike being generated and reaching the program pulse inputs. This could result in an incorrectly programmed location or damage to the EPROM.

The taming diagram for the Port B lines is shown in Figure 6.5 B2 is used to increment the 4040 and B3 is used to reset it to zero. The other lines function as explained previously.
6.2.3 SDB-80 modifications. The SDB-80 was modified to allow a user to easily operate the programmer and to generate the 50 ms program pulses for the 2716. An off-board 2716 EPROM was added to contain the progranmer software


Figure 6.5 Port B timing diagram. (a) 2716 program and verıfy. (b) 2708 program.
and the on-board CTC had two lines tied together.
As shown in Figure 6.6 two one-of-eight decoders (74LS138) are used to decode the memory address for the off-board 2716. The starting address for the 2716 is 4000 H . This places it directly above the 16 K bytes of the SDB-80 on-board RAM. The EPROM is interfaced to the SDB-80 through connector JI (the system bus connector, shown in Figure 6.2).

Note that the $\overline{\mathrm{CS}}$ signal for the 2716 also goes to the $\overline{\mathrm{DINB}}$ signal of connector J1. This enables a data bus input buffer on the SDB-80 when the $\overline{\mathrm{CS}}$ line goes low.

The zero count output of channel \#2 of the SDB-80 on-board CTC is tied to the timer trigger input of channel \#3 (pin 8 to pin 6 of connector J1). This allows the counter of channel \#3 to start being decremented when the counter of channel \#2 reaches zero. This is done to time the 50 ms program pulse necessary for programming 2716 EPROM's because a single channel of the CTC cannot time that long of interval.
6.2.4 EPROM programmer software. The programmer software in the offboard 2716 controls the sequencing required to program the 2708 and 2716 EPROM's. The user is queried to select which operations are performed by the firmware (i.e., he chooses either the 2708 or 2716 to be either read or programmed). A flowchart in Figure 6.7 shows how this is done. The program is listed in Appendix II. 2.

The SDB-80 PIO \#2 is programmed to be operated in Mode 3 for both port A and port $B$. Port $A$ is initially defined to be an input port, and port $B$ is defined to be an output port.

After port B is programmed, the 4040 reset line is raised and the I/0 buffer to port A is disabled. A message is then output to the user to ask whether a 2708 or a 2716 operation is to be performed. After the user defines which one, he is asked to specify a read or write operation.

The read routines for both the 2708 and 2716 are very simalar. The only differences are that the $\overline{C S}$ lines controlled by port $B$ are different and that the 2708 has 1024 locations while the 2716 has 2048 locations. To perform a read operation the corresponding $\overline{\mathrm{CS}}$ line is lowered and the input buffer is enabled. The data byte is then input and stored at the location specified by the HL registers. HL and the 4040 are then incremented. If the contents of HL then equal 1024 (for 2708) or 2048 (for the 2716), the routine is exited, otherwise it continues as above.


Figure 6.6 Connection of the 2716 EPROM that contains the programmer software.


Figure 6.7 Flow chart of the EPROM programmer software. (a) The initialızation and read routines.


Figure 6.7 (continued) (b) 2716 program routıne.


Figure 6.7 (continued) (c) 2708 program routine. (d) QUIT routine.

The program routines for the 2708 and 2716 differ chiefly in the way the programming pulses are applied and in the way the contents are checked after the EPROM is programmed. When either routine is entered, the contents are checked to make sure the EPROM has been erased (i.e., when an EPROM is erased, all locations contain FF H). After this is done, the 4040 and HL are both cleared, and port $A$ is changed to an output port with the output buffers enabled. A message is then output to the user telling him to turn on the "program enable" switch on the programmer. He then hits any key on the teletype keyboard to start the programming operation.

To program one location of the 2716 data is output on port $A$ and its PD/PGM line is raised for 50 ms as stated in the previous section. Since two channels of the CTC must be used to generate 50 ms , they must be programmed such that the sum of their time constants is 50 ms . One is programmed to start operating immediately while the other is programmed to start operating when its trigger line is brought low by the zero count output of the first channel. The second channel is checked continuously until it reaches zero. When this occurs, the PD/PGM line is brought low and the contents at that location are input and checked to make sure they agree with the data that was output to the 2716. To input the data port $A$ is changed back to an input port, the input buffers are enabled, and the $\widetilde{C S}$ line of the 2716 is brought low. If the contents of the 2716 do not agree with the data that was output, the buffers are disabled, the $\overline{\mathrm{CS}}$ line is brought high, and a message is output to the user notifying him of the error. The program routine is then exited and the SDB-80 jumps to the DDT-80 operating system. If the contents do agree, Port A is changed back to an output port with the output buffer enabled. HL and the 4040 are then incremenetd. If the contents of HL then equal 2048, the program routine then branches to "QUIT". Otherwise it continues as above.

To program the 2708 a 1 ms pulse is applied to the PGM line while the corresponding data is on port A for each location. This constitutes one loop and one-hundred loops must be gone through as stated in the previous section. Register C is used as the loop counter. Only one channel of the CTC has to be used since only a 1 ms pulse is required. After data is output to Port.A, the CTC is started and is checked continuously until it reaches zero. The PGM line is then brought low and the 4040 and HL are incremented. If the contents of HL equal 1024, then register C is incremented. Otherwise it continues as above. If the contents of $C$ are less than one hundred, another loop is started.

If it equals one hundred, HL and the 4040 are cleared and Port A is changed to an input port along with the buffers. Data is then sequentially input and checked to see if it equals the original data. If it does not, the user is notified as in the case of a 2716 error and the SDB- 80 jumps to the DDT- 80 operating system. If all the locations agree, then the QUIT routine is entered.

In the QUIT routine the buffers are disabled and a message is output to the user asking if he wants to do anything else. If he answers yes, the program is started over at the beginning. Otherwise a jump statement to the DDT-80 operating system is executed.
6.2.5 Operation of the progrommer. The programmer is simple to operate. The desired EPROM data is put into the SDB-80 RAM starting at location zero. Then the user causes the programmer firmware to start being executed by using the 'E' command of the DDT-80 operating system. The following sequence illustrates the operation of the programmer starting at the 'E' command.

```
'.E 4000'
ENTER A FOR 2708,B FOR 2716
'A'
ENTER P TO PROGRAM,R TO READ
'R'
WANT TO DO MORE? Y=YES,N=NO
'Y'
ENTER A FOR 2708,B FOR 2716
'A'
ENTER P TO PROGRAM,R TO READ
'P'
TURN ON PROGRAM ENABLE,THEN HIT ANY KEY
WANT TO DO MORE? Y=YES,N=NO
'N'
```

The above user responses are self-explanatory with the possible exception of the next to last one (the characters within the apostrophes are user responses). After the program switch is turned on, the user starts the programing operation by simply hitting a key on the teletype. Note that when the " N " is entered in the last statement, a jump to the DDT-80 operating system is executed.

The programmer firmware automatically checks to see if an EPROM is erased before it is programmed as noted in the last section. The following shows the response of the firmware when a user attempts to program an unerased EPROM.
${ }^{\prime}$. E 4000'
ENTER A FOR 2708, B FOR 2716
${ }^{1}$ B'
ENTER P TO PROGRAM, R TO READ
'p'
NOT ERASED
If the data from a location in an EPROM does not agree with the data that should be there after it is programmed, the programmer firmware notifies the user as in the following sequence.
'. E 4000'
ENTER A FOR 2708, B FOR 2716
'B'
ENTER P TO PROGRAM,R TO READ
'p'
TURN ON PROGRAM ENABLE, THEN HIT ANY KEY
ERROR AT 0001

## 7. FLIGHT PERFORMANCE

The first flight test of the data-manipulation experiment took place on 19 June 1978: Nike Apache 14.543 was launched from Wallops Island, Virginia, at 2315 EST as part of the Joint American-Soviet Particle Intercalibration (JASPIC) Project.

The rocket attained an altitude of 185 km at 214 s after launch. It has a mid-flight spin rate of 6.85 Hz , well within the design range of the datamanipulation experiment. The spin period is 146 ms .

Figure 7.1 shows a section of the chart record about 5 s before the launch. The time interval between outputs of 10 w order sectors is 160 ms and the output data sequence repeats at intervals of 2.54 s . Since the time interval between outputs of low order sectors is 160 ms instead of the expected value of 170 ms , it appears that the oscillator in the MSD has a frequency greater than the nominal value of 100 Hz (i.e., $17 / 160 \mathrm{~ms} \approx 106 \mathrm{~Hz}$ ). It can be seen that although there is no rocket spin the experiment is properly sequencing through the 16 sectors. (The signals from the detectors are principaliy noise).

A section of a chart record containing the signals from the data-manipulation experiment and the magnetometer is shown in Figure 7.2. This is taken at $T+95 \mathrm{~s}$ ( $T$ is the launch time), with the rocket at an altitude of 120 km .

The data output sequence repeats at intervals of 2.48 s . This is 17 revolutions ( $17 \times 146 \mathrm{~ms}$ ), as described in Section 5.2.3(c). The interval between the outputs from the low order sectors is 156 ms , in agreement with $1+1 / 16$ revolutions. The intervals between the highest order sectors do not correspond exactly with the description contained in Section 5.2.3(b); in particular sector \#15 finishes being output immediately before the output flag is set to output sector \#0.

It appears that the flag to output sector \#15 was not set when it should have been (i.e., when the MSD counter is reset to zero) and had to be set automatically when register $\mathrm{B}^{\prime}$ had been incremented to 67; see Section 5.2.3(a). The problem could be due to an error in the program in the 2716 EPROM. Some of the object code involved in setting the flag for the last four sectors was entered manually instead of being assembled from the source listing given in Appendix II.1. Thus the error in setting the flag for sector \#15 could have been the result of an error when typing in the object code. Possible improvements in this area are discussed in Chapter 8.


Figure 7.1 Section of chart record from Nike Apache 14.543: 5 seconds before launch.


Figure 7.2 Section of chart record from Nike Apache 14.543:
95 seconds after launch.

Although sector \#15 would not normally contain data for a 6.85 Hz spin rate, it did on this flight because of the 106 Hz frequency of the MSD oscillator. Since the spin period is 146 ms , sectors \#0 to \#14 have a duration (for input of data) of 9.4 ms for each revolution of the rocket. For these sectors each output represents a sampling time of 160 ms ; see Section 5.2.3(c). Sector \#15 has a duration of 5 ms for each revolution so that the sampling time for this sector is 85 ms (i.e., $17 \times 5 \mathrm{~ms}$ ).

The experiment performed well, with the anomalies noted above, until 182 s after launch (altitude 180 km ). Subsequent to that time data appears in sector \#0 with no data in the other sectors. Also the sequencing of sectors \#12, 13 and 14 is anomalous. This is illustrated in Figure 7.3 with a section of chart record at $T+185 \mathrm{~s}$. It appears that there was a failure involving the MSD or the PIO \#2 (the magnetometer itself did not fail; the signal still appears on channel 6 of the telemetry system). Supporting this interpretation is the observation that the interval between the outputs of low order sectors was 203 ms ; compare with Figure 5.7 which shows this interval for a low (or zero) spin rate. The data output sequence repeats, at intervals of 3.02 s .

As noted all the data after $T+182 \mathrm{~s}$ is accumulated in one sector. The energy spectrums from the several detectors are obtained but without any information on variation with pitch angle. The signal from the microprocessor ends abruptly at $T+348 \mathrm{~s}$ (altitude 101 km , descending).

The second rocket carrying the data-manipulation experiment, Nake Apache 14.542, was launched from Wallops Island, at 0030 EST on 27 September 1978. This rocket attained an apogee of 183 km at $T+212 \mathrm{~s}$.

Preliminary examination shows that the microprocessor data-manipulation experiment performed perfectly for the duration of the fiight. None of the anomalies noted earlier were observed during this flight.


Figure 7.3 Section of chart record from Nike Apache 14.543:
185 seconds after launch.
8. CONCLUSION AND RECOMMENDATIONS FOR FUTURE WORK

### 8.1 Conclusion

In the preceding chapters the design and operation of the data-manipulation experiment has been discussed in detail. It has been shown that it is an effective system for reducing the data from the energetic particle experiments (described in Chapter 2) to a form correlating accumulations of particles at several discrete energy levels with their pitch-angle distributions. The output from this system will reduce the amount of time necessary for interpreting the data from the energetic particle experiment.

Without the use of a microprocessor this rocket-borne system could not have been constructed. Nike Apache 14.543 was the first to include a microprocessor on a University of Illinois payload. The success of this system on Nike Apache 14.543 will provide an impetus for updating other rocket-borne instrumentation by making greater use of digital processing and LSI integrated circuits.

### 8.2 Suggestions for Future Work

After the data-manipulation system was completed, it became evident that some things should be changed. These changes are outlined below and are followed by suggestions for other applications of microprocessors in rocketborne instrumentation.
8.2.1 The data-manipulation progrom. A simple change in the data-manipulation program (listed in Appendix II.1) will enable the output flag to be set for the last four sectors in the same manner as it is for the other sectors; if the spin rate is too fast, it would continue to be set when the rocket had rotated to sector \#0. To do this statement \#102 ("JP NOSND") should be deleted and the two statements, "POP HL" and "PUSH HL", inserted in its place.

As an example of the result of this change suppose the spin rate is less than 6.67 Hz . The output flag to output sector \#14 would be set when the rocket had rotated to sector \#15, but if the spin rate were greater than 6.67 Hz (i.e., the MSD counter is reset before it reaches 15), the flag to output sector \#14 would be set when the rocket had rotated to sector \#0 as before.
8.2.2 The MSD-circuit. The change, described above, in the data-manipulation program will not be necessary if the following changes are made in the MSD circuits.

The method of converting the magnetometer signal to a digital form (Section 5.2) can be improved. It would be much better from a software stand-
point and from a data interpretation standpoint to always have exactly sixteen sectors of data. If there were always sixteen sectors of data regardless of the spin rate, the output flag would be set in the same manner for all sectors and there would not be transmission of useless data; in the present system when the spin rate is above 6.67 Hz , the last few sectors may not contain any useful data.

The simplest approach would be to use an A/D converter to convert the magnetometer signal. The magnetometer signal would be made to vary between constant voltage limits, 0 and 5 V , for instance.

Another approach would be to use a counter as in the present system but with the counter clock changed such that its frequency was always sixteen times the frequency of the magnetometer signal. This can be done by phase-1ocking the clock oscillator to the magnetometer signal as shown in Figure 8.1(a). Since the frequency of the $Q_{3}$ output is equal to the frequency of the clock signal divided by 16 , it is used to generate the error signal. The relation of the counter outputs in relation to the magnetometer signal is shown in Figure 8.1(b). The center frequency of the VCO should be about 108 Hz $(6.75 \times 16)$.

The CTC could also be used to generate a digital representation of the magnetometer signal. Since only one counter/timer channel (channel \#0) is used in the present system, the other three are available for other applications. Referring to Figure 5.2 (b) it is seen that the external clock/timer trigger input can be used to decrement the down counter. The zero count/ timeout output goes high when the counter is decremented to zero. The magnetometer signal could be used to decrement the channel \#1 counter. Since the CTC interrupts the CPU at intervals of 1.536 ms , the cycIe time of the magnetometer signal can be determined by counting the number of intervals it takes to decrement the counter. For instance if it takes 93 intervals to decrement the counter by one, the time constant of the magnetometer signal is 142.8 ms (i.e., $93 \times 1.536 \mathrm{~ms}=1 / 7 \mathrm{~Hz}$ ). Once the time constant is determined, channel \#2, programmed to be a timer, can be given a time constant of 8.925 ms (i.e., $142.8 \mathrm{~ms} / 16$ ). The zero count/timeout output of channel \#2 can then be used to decrement the counter of channel \#3. The lower four bits of channel \#3 then would be the digital representation of the magnetometer signal.

The advantage of this method over the phase-lock technique is that it takes little extra hardware and would cover a wider frequency range. The

(b)

Figure 8.1 Suggestion for improvement in the MSD system.
(a) Block diagram showing how the system can be phase locked to the magnetometer. (b) Timing diagram of the counter compared to the magnetometer sugnal.
disadvantage is that it has a much slower response time and it would require some CPU time. Figure 8.2 illustrates the extra connections to the CTC that would be required.
8.2.3 Automatic reset circuit. An automatic reset circuit would be useful during a flight if the CPU jumped to some unspecified location outside the defined program, perhaps due to noise. The circuit shown in Figure 8.3 would reset the CPU if it is not addressed after a period of time. For instance in the present system the CTC interrupts the CPU every 1.536 ms causing it to jump to the output routine. The reset circuit could be made to reset the system if this did not happen. One shot \#1 would be triggered by the CPU during initialization. The pulse would be sustained if it were addressed periodically. If it were not retriggered, its ' $Q$ ' output would go low triggering one-shot \#2 causing the system to receive a reset pulse. By requiring an $I / O$ instruction to be used to retrigger one-shot \#1 the probability of retriggering it unintentionally is reduced.

Other schemes such as requiring a particular data word at one address can be used to reduce that probability even further, thereby absolutely ensuring a reset if the system is not functioning properly.
8.2.4 Circuit layout. The printed circuit cards should be changed by separating standard microcomputer components from interface devices that will vary according to the requirements of a particular experiment. Cards containing such components as the CPU, memory and PIO's could be used for several applications without having to be changed. The method of connecting the cards together should be changed to edge connectors. This would allow a card to be easily replaced thereby simplifying debugging of the system. The cards could be strapped in by a bar on top of the cards during a flight to prevent any movement (the bar would also prevent movement when the system was foamed).
8.2.5 The development system. The development system should be improved by the addition of an in-circuit emulator and a good bulk-storage device. This will cut the development time by a significant amount.

Presently there is no equipment, other than an oscilloscope, available for debugging hardware problems. The in-circuit emulator would be useful in debugging both the system hardware and software. It interfaces external circuit boards to the SDB-80 by a 40 -pin connector inserted in place of the Z-80 CPU. It allows the actual software to be run on the boards just as if the CPU were still there while giving the user such capabilities as a real-


Figure 8.2 Using the CTC to generate the MSD signal.

(a)

(b)

Figure 8.3 (a) Block diagram of the automatic reset circuit.
(b) Timing diagram showing when the CPU would be reset.
time trace of program execution and single-stepping through a program. A faster bulk storage device than the teletype paper type reader/punch would allow programs to be changed faster.

There are software drivers in the SDB-80 operating system (DDT-80) for a high-speed paper tape reader and a punch. There is also a compatible flexible disc unit available from MOSTEK. More sophisticated hardware and software could be accomplished with this additional equipment.
8.2.6 Other applications of the rocket-borne data-manipulation experiment. Another function a microprocessor could perform during the rocket flight is the calculation of electron temperature. This function could be added to the present system since one channel of PIO \#2 was not used and since there is plenty of available space left on the EPROM. This calculation would not degrade the performance of the system since it would be done at relatively long time intervals.
8.2.7 Data-transmission systems. An even more valuable application would be in the data-transmission system. Currently this system is an analog frequency-division multiplexed FM device. It should be upgraded to a timedivision multiplexed digital system possibly using a microcomputer. This would allow higher resolution data to be sent back. By using a microprocessorcontrolled digital telemetry system data flow could be optimized. Since some experiments will have faster transients, they could be allotted more time slots. Other experiments might require data to be sent only at non-periodic intervals depending on the occurrence or non-occurrence of external stimuli. Interrupts could be used to send back the non-periodic data with priorities assigned depending on the most important occurrence, and a time slot could be specifically allocated for all the non-periodic data.

Some of the code-decode (codec) devices that have recently become available could be useful in a rocket-borne digital telemetry system. These devices convert an analog signal in the voice-frequency range to a digital bit stream using either pulse code or delta modulation. Some even have facilities for microprocessor control included.
8.2.8 Applications in ground-based data processing. A ground-based microprocessor-controlled system could be used (in conjunction with the data transmission systems) for bit-synchronization and demultiplexing the data. After the systems were synchronized, the demultiplexed data would be placed on a multi-track tape. After the flight the same system could be used to
process the data off-1ine. Figure 8.4 depicts block diagrams of the groundbased data-reduction systems.

(a)

(b)

Figure 8.4 Ground-based data-reduction system. (a) Real-tıme data-logging system. (b) Off-line data-reduction system.

## REFERENCES

Geller, M. A., L. G. Smith and H. D. Voss (1975), Analysis of nighttime ' E-region winds and ionization production, Radio Sci., 10, 335-345.

Leung, W., L. G. Smith and H. D. Voss (1979), A rocket-bome pulse-height analyzer for energetic particle measurements, Aeron. Rep. No. 83, Aeron. Lab., Dep. Elec. Eng., Univ. I11., Urbana.

Pozzi, M. A., L. G. Smith and H. D. Voss (1979), A rocket-bome energetic analyzer for measurement of energetic particle flux, Aeron. Rep. No. 82, Aeron. Lab., Dep. Elec. Eng., Univ. I11., Urbana.

Smith, L. G., M. A. Geller and H. D. Voss (1974), Energetic electrons in the midlatitude nighttime E region, J. Atmos. Terr. Phys., 36, 1601-1612.

Smith, L. G. and H. D. Voss (1976), Ionization by energetrc electrons in the midlatitude nighttime $E$ region, Space Res., 17, 427-432.

Voss, H. D. and L. G. Smith (1974), Design and calibration of a rocket-borne electron spectrometer for investigation of particle ionization in the nighttime midlatitude $E$ region, Aeron. Rep. No. 62, Aeron. Lab., Dep. Elec. Eng., Univ. Ill., Urbana.

Voss, H. D. and L. G. Smith (1977), Energetic particles and ionization in the nighttime middle and low latitude ionosphere, Aeron. Rep. No. 78, Aeron. Lab., Dep. Elec. Eng., Univ. Ill., Urbana.


Figure I. 1 CPU-memory board.


Figure I. 2 PIO\#I and CTC board.


Figure I. 3 A/D and FIFO board.


Figure I. 4 EPROM programmer.

APPENDIX İı1: Data-Manipulation Program

| DATA MANIPLLATIOM, |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADDF | OEJECT | ST* |  | $\pm 1$ |  |  |
| >G0Q |  | 0002 | P1A | EQU | Q6 | ; PIO\#l PORT A |
| > 1320 |  | 0003 | END | EQU | 1320H | ; ENE OF SECTOR ADDR. |
| >8001 |  | 0004 | PIAC | EQU | 01 | ; PIOH1 PORT A CONTROL |
| >0002 |  | 0005 | P!B | EQU | 02 | ; PIO\#l PORT ${ }^{\text {B }}$ |
| > 0003 |  | 0006 | PIBC | EQU | 03 | ; PIO\# 1 PORT E CONTROL |
| >0008 |  | C007 | P2A | EQU | 08 | ; PIO\#2 PORT A |
| >0009 |  | 0088 | P2AC | EQU | 09 | ; PIO:2 PORT A CONTROL |
| $>13 \mathrm{FG}$ |  | 0009 | STAK | EQU | 13 FgH | ; STACK ADDRESS |
| > 9004 |  | 0010 | CTI | EQU | 04 | ; CTC CHANNEL \#1 ADDRES |
|  |  | 0011 |  | ORG | 08 |  |
| -0000 | ED56 | 0012 |  | IM | 1 | ; INTERRUPT MODE I |
| -0002 | 31F613 | 0013 |  | LD | SP, STAK | ; STACK POINTER |
| -0005 | 3E4F | O014 |  | LD | AO1001111B | B MMODE 1 CONTROL WORD |
| -0007 | D301 | 0015 |  | OUT | $(P \mid A C), A$ | ; PIO\#1 PORT A |
| -0009 | 3ECF | 0016 |  | L. D | A, 11061111日 | B GMODE 3 CONTROL MORD |
| - 000B | D303 | 0017 |  | OUT | (P1BC), A | ; PIO\#l PORT B |
| - 000 D | D309 | 0018 |  | OUT | ( P2AC) , A | ;PIOZZ2 PORT A |
| - OEDF | 3E.06 | C819 |  | LD | A, 0 |  |
| -001! | D303 | 0020 |  | OUT | (P1EC), A | ; OUTPUT PORT |
| - 2613 | 3EFF | 0621 |  | LE | A, OFFH | ; PROGRALI TO BL |
| - 0015 | D309 | 0022 |  | OUT | (P2AC), A | ; INPLT PORT |
| - 2017 | 3EA5 | Q623 |  | L. | A 10120101B | 3 ; CTC CONTROL WORD |
| - 0019 | E304 | 0024 |  | OUT | (CT1), A | ; Crifnncl \#! |
|  |  | 0025 | ; CLEAR | LOWER | F 1 K OF EAM | USING BLOCX liove. |
| - 001B | 210008 | 0026 |  | LD | HL, 800 H | ; BEGINNINS ADLRESS |
| - 001 L | 3600 | 0027 |  | LD | (HL), 06 | ; Clear first locati oiv |
| -0020 | 110108 | Q828 |  | LD | DE, 8011 | ; ADDEESS TO MCUE TO |
| -0023 | $01 F 503$ | 0029 |  | LD | BC, 1023 | ; NUMBER CF MOVES - |
| -0026 | EDBG | 0030 |  | LDIF |  | ; block liove |
| - 0e2s | D9 | 0031 |  | EXX |  |  |
| -0029 | 810000 | 0032 |  | LD | $B C, 80$ | ; SET UP BC' AND HL' |
| - 022C | 210008 | 0033 |  | LE | AL, 800\% | ; FOR OUTPUT ROUTINE |
| -802F | D9 | 0034 |  | EXX |  |  |
| - ロ03 | C35061* | Q035 |  | JP | SPLT | ; GO ATOUIND OTHER STUFF |
|  |  | 8836 |  | ORG | 1584 |  |
| -2150 | DBD8 | 0037 | SPLT: | IN | A. (D2A) | ; INPUT MSD EATA |
| - 0152 | E60F | ¢038 |  | FiND | OQQ611113 | ;GET RID OF EXTRA BITS |
| - 0154 | 57 | 2039 |  | LD | D, $A$ |  |
| - 0155 | 3E00 | 0.046 |  | LD | A. 60 |  |
| -8157 | CB3A | 0041 |  | SRL | D | ; Silft to proper eit |
| - 0159 | IF | 8842 |  | RRA |  | ; POSITIONS. |
| Q15A | CB3A | 2043 |  | SRL | D |  |
| -015C | $1 F$ | 0644 |  | RRA |  | ; LOJET TWO BITS IN A |
| - 15 D | $6 F$ | 0645 |  | LD | L, $A$ | ; PUT SiIffed date |
| - D15E | 3E08 | 0846 |  | LD | A. 98 | ; in al alve di aftiq |
| C160 | 82 | 0247 |  | ADE | A, D | ; ADEING ON UPPEF EIT. |
| 0161 | 57 | 0848 |  | LD | D, $A$ |  |
| -0162 | 62 | 0049 |  | LD | H, D |  |
| 2163 | 3 E83 | 905\% |  | LD | A. 10006011B | ; Ellable pio\#1 I:IT. |
| 6165 | 2301 | 0051 |  | OUT | ( $P \mid A C$ ) $A$ |  |
| 0167 | 3E6F | 0652 |  | LD | A, 15 | ; CTC tile constant |
| 0169 | D304 | 0053 |  | OUT | (CTI), A | ; Start ctc |
| D16E | FB | 0054 |  | EI |  | ; ENABLE INTERRUET FF |
| 016 C | DEDO | Ce55 |  | IN | $A,(P \mid A)$ | ; RAI SE ARDY LIIVE |
| C16E | 76 | B656 | HLT: | Hifl T |  | ; WAIT FOR INTEERUPTS |
| - 916 F | C36E9 1' | 2057 |  | JP | HLT |  |
|  |  | 0659 |  | ORG | 38H | ;INPUT ROUTIN 2 ADDPESS |


| Lath ilanipulation |  |  | PaOGkfil |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| G.DL:- | OBJECT | ST\# |  |  |  |  |
| - 2039 | LECD | 2668 |  | IN | $A,(P 1 A)$ | ; INPUT DATG, FROM FIFO |
| 10038 | 83 | 0661 |  | ADE | A, E | ; CONCGTLNATE Data litil |
| - 003 C | $6 F$ | 0862 |  | LL | L, A | ;ilSd data Iil L . |
| - 003D | 7E | 0063 |  | LD | A, (:iL) | ; IUPUT DFTA TO A |
| - 003E | C604 | 0064 |  | ADD | A. 04 | ; INC: THIED BIT |
| -0048 | 77 | 0065 |  | LD | (HL), A |  |
| - 8041 | FB | 0066 |  | EI |  | ; REENAELE liASKAELE I IJT |
| - 0842 | EL4D | 0067 |  | RETI |  |  |
|  |  | 0 068 |  | ORG | 66\% | ; OUTPUT FOUTINE f.LD. |
| - 0066 | 88 | Q 869 |  | EX | $A F, A F{ }^{\prime}$ | ; EXCHANGE AF DEGISTL=S |
| - 2067 | LBCB | 0078 |  | IN | A) (P2A) | ; UDDATE IISD Dt.TA IN DE |
| - 6069 | E60F | 0671 |  | AND | OODO1111E |  |
| - BR6E | 57 | 0072 |  | LD | D, A. |  |
| - 006 C | 3Ege | 0873 |  | LD | A,00 |  |
| - 006 E | CB3A | 0074 |  | SRL | D |  |
| - 0070 | 1 F | 0075 |  | RRA |  |  |
| - 9871 | CB3A | 0076 |  | SRL | D |  |
| -0073 | $1 F$ | 0077 |  | RRA |  |  |
| - 8 C74 | 5 F | 0678 |  | LD | E, $A$ |  |
| - 2075 | 3E68 | 0079 |  | LD | A, 98 H |  |
| - 2077 | 82 | 0080 |  | ADD | A, D |  |
| - 0078 | 57 | 0881 |  | LD | D, $A$ |  |
| - 0079 | D5 | 0082 |  | PUSA | DE | ; STORE DE |
| -007A | D9 | 0083 |  | EXX |  | ; EXCHANGE PEGISTERS |
| -007B | D1 | 0084 |  | POP | DE | ; PUT DE LATA IN DE* |
| -007C | 3EC! | 0085 |  | LD | A, 01 |  |
| -007E | B9 | 0086 |  | $C P$ | C | ; SEE IF OUTPUT FLG SET |
| - 207 F | CAC808 ${ }^{\circ}$ | 0687 |  | JP | Z.SEND1 | ;GO TO SEND IF IT IS |
| - 2082 | 04 | 0088 |  | INC | E |  |
| - 2083 | 78 | 0089 |  | L. ${ }^{\text {d }}$ | A, B |  |
| - 0084 | FE. 43 | 0690 |  | CP | 67 | ; SEE IF B' HAS EEEN |
| - 0086 | CAB600' | CR9 1 |  | JP | 2, SNDF1 | ; INCR. TO 67,IF SO SET |
| - 2089 | E5 | 0692 |  | PUSH | HL |  |
| -008A | 7 C | リ®9 3 |  | LD | A, H |  |
| - 008 B | FECS | 0094 |  | CP | OBH | ; SEE IF LAST 4 SECTORS |
| - 008D | C29 L00' | 0 C 95 |  | JP | NZ.inOTBE | ; IF NOT GO TO NGTEE |
| - 0090 | 37 | 0096 |  | SCF |  | ; CLEAR CARRY |
| '0091 | $3 F$ | 8097 |  | CCF |  |  |
| - 0092 | ED52 | 0098 |  | SBC | HL, DE | ; SUBTRACT DE' FROM $\mathrm{HL}^{\prime}$ |
| 19094 | 7C | 9899 |  | LD | A, i |  |
| 10095 | Fec3 | 0100 |  | CP | 83 | ; IS UPPEP EYTE 03. |
| -6097 | CAB500' | 0101 |  | JP | Z, SNDFL | ; IF IT IS ,SLT FLAG. |
| -009A | C3AC06' | 0102 |  | JP | NOSND | ; IF NOT, EXIT ROUTINE |
| -009D | 37 | 6103 | NOTBE: | SCF |  | ; Clear carny |
| - 009 E | 3 F | 0104 |  | CCF |  |  |
| - 609 F | ED52 | 8105 |  | SEC | HL, DE |  |
| - B0A1 | 7 C | 8106 |  | LD | A, H |  |
| - 日gaz | FEFF | 0107 |  | CP | QFFH | ; SEE IF DIFFERENCE IS |
| ' EGA4 | CEACDA. | 0188 |  | JP | NZ,NOSND | ; FFCEH (2'S COMPLEMENT |
| - Eca7 | FECE | 6189 |  | CP | OCOH: |  |
| - ERA9 | CAE506' | 0110 |  | JP | Z, SIJDFL | ; IF IT IS, SET FLAG |
| - beac | E1 | E111 | NOSND: | POP | HL |  |
| - gead | 3ERE | C112 |  | LD | $A, Q E$ |  |
| - QQAF | D302 | 8113 |  | OUT | ( $F 1 B$ ), $A$ | ; SET D/A OUTPLT TO 0 |
| - EOEI | D9 | 0114 |  | EXY |  | ; EXCHGNGI F.EG. SETS |
| - OCE | ¢8 | 0115 |  | EX | $A F, A F^{\prime}$ |  |
| - ERE3 | ED4S | e 116 |  | CETN |  |  |
| - ECE5 | E1 | 0117 | SivLFL: | POP | : 1 L | ;SET FLfa routilie |


| DATA MANIPLLATION |  |  | PFOGRAS |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADLR | OBJECT | ST \＃ |  |  |  |  |
| －88E6 | OEC－1 | 8118 | SINDF 1： | LD | C． 01 | ；SET OUTELT FLf． |
| －CaEs | 06EE | 0119 |  | LL | E， 00 | ；CLEAF E＇ |
| －GEEA | D5 | 0128 |  | PLSH | DE |  |
| －G\＆EB | L5 | 0121 |  | PUSH | 1 L |  |
| －0CbC | 114882 | 8122 |  | LL | DE， 64 |  |
| －BREF | 19 | C123 |  | ADE | HL，DE | ；LOAD（END）TIITH |
| －QQCE | 2c2e13 | C124 |  | L． | （END）， HL | ；END ADEFESS OF SECTO？ |
| －00c3 | E． 1 | 0125 |  | POP | HL |  |
| －00C4 | D1 | 0126 |  | POP | DE |  |
| －Dec5 | C3FA0C ${ }^{\text {－}}$ | 0127 |  | JP | MAFK |  |
| －DeC8 | 86Cb | 2128 | SENDI： | L．L | B，08 | ；CLEAP B |
| －D日Ca | 7 L | C129 |  | L．L | A，L |  |
| －ØロCE | E68F | 6130 |  | ANL | QFh |  |
| － 08 CL | FERE | C131 |  | CP | 20 | ；Ste If e buepgy pos． |
| －GECF | C20708 | \＆132 |  | JP | WZ，SENLZ |  |
| －EED2 | 3E7F | 2133 | SENL6： | LL | A，7FH | ；OUTPUT MAX LEVEL |
| －EEDA | C3DAD日＇ | 0134 |  | JP | SENL3 |  |
| －00D7 | 7 E | 0135 | SENL2： | LD | A，（HL） | ；PUT ACCLisULetI ON IN A |
| －geds | 3600 | 8136 |  | LD | （HL）， 68 | ；CLEAR TO ZESO |
| －geda | D302 | 6137 | SENL3： | OUT | （ $P \mid B$ ，$A$ | ；OUTPUT TO D／A |
| －ODDC | 23 | 6138 |  | INC | HL |  |
| －OODD | 3 A2G13 | 0139 |  | LD | A，（ENL） | ；SEE IF END OF SECTOR |
| －QQEq | BD | 0140 |  | CP | L |  |
| －DOE 1 | C2F600＇ | 0141 |  | JP | NZ，SENLS |  |
| －DOE4 | 3A2113 | 6142 |  | LD | A，（ENL＋1） |  |
| －DGE7 | BC | 0143 |  | CP | H |  |
| －DEE8 | C2F6e ${ }^{\prime}$ | 0144 |  | JP | NZ，SENES |  |
| －DDEB | 3EDC | 0145 |  | LD | $\mathrm{A}, \mathrm{CCH}$ | ；SEE IF ALL 16 SECTORS |
| －QEED | EC | 0146 |  | CF | H | ；AAVE LELN SENT． |
| －ø®EE | C2F400＇ | 0147 |  | JP | NZ，SEND4 |  |
| －GUF 1 | 210008 | 2148 |  | LD | HL，80EH | ；RESET TO REGILNING |
| －00F4 | GEQG | C149 | 5ENE4： | LD | C．0e | ；RESET OUTPUT FLAG |
| －Qef6 | D9 | C150 | SEINL5： | EXX |  | ；EXCHALULE REGISTERS |
| －00F7 | 08 | 0151 |  | EX | $A F, A F{ }^{\prime}$ |  |
| － 0058 | 2．545 | 0152 |  | RETN |  |  |
| － 00 FA | 7 C | 8153 | MARK： | LD | fish | ；MGRKER SIGNAL ROUTINE |
| － 00 FE | E603 | 8154 |  | Givis | 0002GO11女 | ；EXTEACT SECTOF NUMEEF |
| －GOFD | 85 | 0155 |  | ADD | A，L | ；FRO\％1iL＇ |
| －DOFE | $0 F$ | 0156 |  | ERCA |  | ；SHIFT TO nIGHT POS． |
| －Deff | QF | 0157 |  | RRCA |  |  |
| －6100 | CB3F | 2158 |  | SEL | A |  |
| － 0102 | D302 | Q159 |  | OUT | （P1B），A | ；OUTPUT TO D／A |
| － 0184 | D9 | 0168 |  | EXX |  | ；EXCHANGE REGISTERS |
| －0105 | 08 | 2161 |  | EK | $A F, A F^{*}$ |  |
| － 0126 | EL4．5 | 0162 |  | RETN |  |  |
|  |  | 8163 |  | ENL |  |  |

ERFORS＝QQQ ERRORS $=0000$

| EPFOM PROG \#AIMER |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADER | OBJECT | ST $\#$ |  |  |  |  |
|  |  | Q002 |  | ORG | 4000H |  |
| - 4000 | 3150 FF | 0003 |  | LD | SP, DFFSEH | ; STACK POINTE ADDE |
| - 4003 | 3ECF | 0004 |  | LD | A, ©CFH | MMODE 3 CONTEOL VOFE |
| - 4005 | D3D7 | 0005 |  | OUT | ( 0 D7H), A | ; PIO\# 2 COMTROL |
| '4007 | 3E06 | 0006 |  | LD | A, 80 |  |
| -4009 | 53D7 | 0907 |  | OUT | (DD7H), A | ; DEFINE TO EE OUTPUT |
| . 400 B | 3ECF | 0008 | BGN: | LD | A, DCFH | ;iODE 3 CONTROL NOPD |
| - 400 D | D3D5 | Q009 |  | OUT | ( $\triangle D 5 H$ ), A | ;PIO\#2 POFT E CONTPOL |
| - 400F | 3EFF | 0010 |  | LD | A, DFFH |  |
| '4811 | D3D5 | 0011 |  | OUT | ( 0 D5\% ) , A | ; DEFINE TO BE INPUT |
| 14813 | 3EAE | 0012 |  | LD | As 1010111cE | ; RAISE 4040 NST, |
| '4015 | D3D6 | 0613 |  | OUT | (0D6: ) , A | ; DI SABLE BUFFEPS |
| - 4017 | 1 E00 | 0014 | PT: | LD | E, 0 |  |
| '4019 | 217442' | 0615 |  | LD | HL, MESGø | ; OLTPUT ON TTY TO |
| - 4010 | CDC7E3 | 0016 |  | CALL | PTXT | ;USER. ASK TO DEFINE |
| - 401F | CD9 CES | 0017 |  | CALL | CRLF | ;2708 OF 2716. DDT-80 |
| - 4022 | C597E5 | 0818 |  | CALL | ECHO | ; MOUTINES FOR TTY I/O |
| '4025 | 42 | 0019 |  | LD | B, D |  |
| - 4026 | CD9CE5 | 0020 |  | CALL | CRLF |  |
| - 4829 | 78 | 0621 |  | LD | $A, B$ | ; USER SPECIFIED |
| - 402A | FE41 | 8022 |  | CP | 'A' | ;2708 OF 2716? |
| - 402 C | CA4841' | 0023 |  | JP | 2, $\times 2708$ |  |
| - 402F | FE42 | 0024 |  | CP | ' $\mathrm{B}^{\prime}$ |  |
| -4031 | CA3740' | 0925 |  | JP | Z,X2716 |  |
| - 4034 | C31740 | 9826 |  | JP | PT | ; REPEAT IF JFONG CHAR |
| -4037 | 1 EOD | 0027 | X2716: | LD | E, 8 |  |
| - 4039 | 219042' | 0028 |  | LD | HL, MESG! | ; ASK WETHER TO READ |
| 1403C | CDC7E3 | 0029 |  | CALL | PTXT | ; OR PRGGRAN. |
| - 403 F | CD9 CE5 | 0030 |  | CALL | CFLF |  |
| 14842 | CL97ES | 0031 |  | CALL | ECHO |  |
| 14045 | 42 | 0032 |  | LD | B, D |  |
| 14846 | CD9CE5 | 2033 |  | CALL | CRLF |  |
| 14049 | 78 | 0034 |  | LD | A, b |  |
| 1404 A | FE50 | 0035 |  | CP | 'F' | ; USEİ SPECIFIED |
| 1404C | CA7940' | 0036 |  | JP | Z,PROG | ; READ OR PROGRAU? |
| 1404F | FE52 | 0037 |  | CP | 'R' |  |
| - 4051 | CA5740' | 0838 |  | JP | 2, READ |  |
| 14054 | C33748' | 0839 |  | JP | X2716 | ; REPEAT If wRONG CAAT. |
| - 4057 | 116008 | 0040 | READ: | LD | DE, 800 H | ; NUMEER OF EYTES |
| 1485A | 210000 | 0641 |  | LD | HL, 0008 | ; STARTING ADDRESS |
| - 405D | 3 EE4 | 8042 |  | LD | A, 1112C180E | ; LOMER 4E4G RST AIND |
| 1405F | D3D6 | 0243 |  | OUT | ( 0 D6H), $A$ | ;2716 CS. |
| - 4061 | LEL4 | 0244 | RE1: | IN | A, (0D4: ) | ; INPLT LATA FNO: 2716 |
| 14063 | 77 | 0045 |  | LD | (HL) , $A$ | ; STORE AT ADLR (il) |
| 14064 | 23 | 0046 |  | INC | HL. |  |
| 1 4065 | 3EED | C247 |  | LD | A, 11160008 | ; INC.EMEIT 4240 |
| - 4867 | D3D6 | 0043 |  | OUT | ( $\mathrm{DD6} \mathrm{\%}$ ), $A$ |  |
| - 4269 | 3EE4 | 0049 |  | LD | f, 1110012C5 |  |
| 1 406B | E3D6 | 0050 |  | OUT | ( 2 Lori), A |  |
| - 4065 | E5 | 0251 |  | PUS. 1 | HL |  |
| - 406 E | 37 | Qe52 |  | SCF |  | ; cliner carge |
| 1 466F | 3 F | 0053 |  | CCF |  |  |
| - 4070 | EL52 | 0054 |  | SEC | HL, DE |  |
| -4872 | CA5542' | 0855 |  | JF | Z, QUIT | ; GLIT IF IT HOES |
| '4875 | El | 0056 |  | POP | HL |  |
| - 4876 | C36142 | Q657 |  | JP | RE1 | ; CONTINUE OTHERIISE |


| EPTO: PROGRAMEES |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ALDE: | OEJECT | ST \# |  |  |  |
| * 407F | 3EE4 | 0260 | LD | A, 111021005 | ; ENA,LLE INJUT EUFFEFS |
| - 4 C ¢ 1 | D3 L6́ | 0061 | OUT |  | ; LOUER 271\% CS |
| - 4033 | ESD4 | 0062 Pra: | IN | A. (0D4 ) | ; INこUT TO S上z IF |
| 14085 | FLFF | 0063 | CP | BFFH | ; IT IS LRASEL |
| - 4C37 | C23041' | 0064 | JP | NZ, PG6 | ;if luOT, TELL USEP. |
| - 4CJA | 23 | 0265 | INC | IL |  |
| - 4483 | 3Eby | 0066 | LD | A) 12110csen | ; INCrEityst 4640 |
| - 408 D | 5306 | 0867 | OUT | (2D6\%), A |  |
| - 488 F | 3E54 | 0268 | LD | A, 1\%112120i |  |
| -4091 | D3D6 | 0069 | OUT |  |  |
| -4893 | E5 | 2076 | PLSti | HL |  |
| -4894 | 37 | 0071 | SCF |  | ; CLEGF CAPRY |
| -4095 | $3 F$ | E672 | CCF |  |  |
| - 4696 | EL52 | Ee73 | SEC | KL, DE | ; SEE IF (HL) $=828 \mathrm{HH}$ |
| 14898 | CA9F4 ${ }^{\circ}$ | 0074 | JP | 2, PR 3 | ; STOF IF IT DOES |
| - 409 E | E1 | 0075 | POP | HL |  |
| - 489 C | C3834 ${ }^{\prime}$ | 8076 | JP | Pre | ; OTAERWISE CONTINUL |
| '489F | E1 | Q677 PR3: | POP | HL |  |
| - 40 AR | 3EAE | 0878 | LD | A 101811105 | ; di Salle buffins, |
|  | L3D6 | 0879 | OUT | (QD6H), A | ;2716 CS AND 4E4C PST |
| - 40 E4 | 3ECF | 6080 | LD | A, DCFH |  |
| - 4 EA6 | D3D5 | 0081 | OUT | (0D5H), A |  |
| - 40 AB | 3E00 | 0082 | LD | A, CD | ; CHANGE PORT A TO |
| - 40 AA | D3D5 | 0683 | OUT | ( 8 D5 \% ) , $A$ | ; OUTPUT POPT. |
| 148 AC | 3 EA7 | 0884 | LD | $A=101001113$ | ; ENAELE OUTPUT EUFFET |
| - 48 AE | D3D6 | $0 \mathrm{C85}$ | OUT | ( 0 D6H), A | ; LOWLR 4040 EST. |
| - 408 E | 1Ege | 0086 | LL | E, $C^{\text {e }}$ |  |
| * 40B2 | 21AL42' | 0087 | LD | HL, liESG2 | ; TELL USER TO TUPN OM |
| - 40 BE | CDC7E3 | 0088 | CALL | PTXT | ; PROGPAAK ENGELE |
| - 40 B8 | CD9 CE5 | 2089 | Call | CELF | ; SUI TCHES. |
| - 408 BE | CD22E5 | 0090 | CALL | RDCHR | ; VAIT FOR ANJ INPUT |
| - 40 BE | CD9 CE5 | C091 | CALL | CRLF | ; FROM USER. |
| - 40 Cl | 110008 | 0892 | LD | DE, 80 gri |  |
| - $40 \mathrm{C4}$ | 210800 | 0693 | LD | IL, 8000 |  |
| - 40 C 7 | 7 E | Q294 PFE1: | L. D | A ( HL ) | ; OUTPUT DATA ON DOATTA |
| - 40 c8 | D3D4 | CE95 | OUT | ( 8 D4H), A |  |
| - $40 . \mathrm{CA}$ | 3E37 | EC96 | LD | A,001181115 | ; SET UP CTC FOR 50 MS |
| - 4 CCC | D3DA | 6097 | OUT | ( $8 D A H$ ), $A$ | ; Iijterval. Have to |
| - 40 CE | 3EFG | 0098 | L. D | A, 240 | ; USE Tijo Chanisels. |
| - 40 D0 | D3EA | 8699 | OUT | ( $\cap$ DAR $)$, A |  |
| - 40 D 2 | 3E3F | 8100 | LD | A, De 111111B |  |
| - 40 D4 | L3DE | 0101 | OUT | ( $\triangle$ DEH), $A$ |  |
| - 40 D6 | 3EE 8 | 8182 | LD | A, 232 |  |
| - 40 D8 | L3 5 | 0163 | OUT | (CDBi) , A |  |
| - 40 DA | 3E27 | 0184 | LD | A COLCO11:5 | ; PAISE pdrail Lind of |
| - 40 DC | [3E6 | 6165 | OUT | (ED6H), A | ; 2716. |
| - 40 DE | DBDU | 0106 PULSL: | IN | fis (EDBH) | ;JAI T FOF CTC TO |
| - 42 EE | FED 1 | 8107 | CP | 01 | ; COLIJT DOm, |
| - 40 E2 | C2DE40' | 0108 | JP | NZ, PULSE |  |
| - 4 EES | 3EA7 | 0109 | LD | A) 18100111E | ; LONET 2716 FD/PGU |
| [40E7 | D3D6 | E118 | OUT | (eD6H), A |  |
| -40E9 | 3EA6 | 0111 | LD | A 18180112E | ; DISABLE RUFEENE |
| - 40 EE | D3 D6 | 0112 | OUT | ( 2 D 6 H ), A |  |
| - $40 E D$ | 3ECF | el1 13 | LD | A, ECFEI | ; CHANGE POET 1 TO |
| - 4 CEF | E3D5 | Q114 | OUT | (EDSH), $A$ | ; AN INPUT PORT. |
| -40F1 | 3EFF | 0115 | LD | A, ©FFH |  |
| - 40 F3 | D3D5 | E116 | OUT | ( 2 D 5 H ), A |  |
| - 4 CF5 | 3 EA4 | 0117 | LD | A, 1018018EB | ; ENALLE INPUT EUTFe=S |



| EPFO：1 PROGTRAMIL |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| のLDu | OEJECT | ST |  |  |  |
| － 4172 | DBD4 | Q176 RDI： | IN | A．（ ©D 4H） | ；INPUT DKTA Fr．O：278\％ |
| － 41.74 | 77 | 0177 | LD | （HL），A | ；STOFE AT GULP（l．L） |
| ， 4175 | 23 | 8178 | INC | HL |  |
| 14176 | 3EE6 | 0179 | LD | A 10110006E | ；INCREHENT 4C40 |
| ， 4178 | D3D6 | 0180 | OUT | （ 0 D6H），$A$ |  |
| ＇417A | 3 EE 4 | 0181 | LD | $A=10118100 \mathrm{~B}$ |  |
| 1417C | D3D6 | Q182 | OUT | （ 8 D 6 H ）， A |  |
| －417E | E5 | 6183 | PUSH | HL |  |
| ＇417F | 37 | 0184 | SCF |  | ；CLEAR CAPFY |
| ＇418ø | 3F | 0185 | CCF |  |  |
| ＇4181 | ED5 2 | 8186 | SEC | HL，DE | ；SEE IF（HL）$=4 \mathrm{CCH}$ |
| ＇4183 | CA5542＇ | 0187 | JP | Z，QUIT | ；QUIT IF IT DOLS |
| ． 4186 | E］ | 6188 | POP | HL |  |
| ＇4187 | C3724 ${ }^{\circ}$ | 0189 | $J P$ | RD1 |  |
| －418A | 110004 | 0190 PG： | LD | DE，400H |  |
| ． 418 D | 210002 | 0191 | LD | HL， OCD |  |
| ＇4190 | 3EE4 | ¢192 | LD | A． 101101005 | ；LOWER 2708 CS， |
| － 4192 | D3D6 | 0193 | OUT | （ED6H），A | ；ENABLE INPUT EUFEER |
| － 4194 | DED4 | 0194 PG5： | IN | A．（ 8 D 4 H ） | ；INPUT TO SLE IF |
| ＇4196 | FEFF | 0195 | CP | CFFH | ；IT IS ERASEL |
| 14198 | CEBU41＇ | 0196 | JP | N2，PG6 | ；IF NOT，TELL USES |
| ． 419 万 | 23 | 0197 | INC | HL | － |
| ． 419 C | 3 EBD | 6198 | LD | A．1211000＠E | ；INJCREMISTT 4E46 |
| ＇419E | D3D6 | 0199 | OUT | （ 0 D6H），A |  |
| ＇41AØ | 3EB4 | 0200 | LD | $A, 10118100 B$ |  |
| ， 41 A 2 | D3D6 | 0201 | OUT | （ 8 D 6 H ） A A |  |
| ＇41A4 | E5 | 0202 | PUSH | HL |  |
| － 41 A 5 | 37 | 6203 | SCF |  | ；Clear carry |
| － 41 A6 | 3 F | 0204 | CCF |  |  |
| ＇41A7 | ED52 | 0205 | SBC | HL，DE | ；SEE IF（HL）$=400 \mathrm{H}$ |
| － 41 A9 | CAC241＇ | 0206 | JP | Z，PG7 | ；IF SO，GO TO PG7 |
| － 41 AC | ［1 | 0207 | POP | HL． |  |
| － 41 AD | C39441＇ | 0208 | UP | PG5 | ；OTHERNISE CONTINUE |
| － 4150 | 1EGC | 6209 PG6： | LD | E， 0 |  |
| ＇41E2 | 21FB42＇ | 0218 | LD | ILL，MESG5 |  |
| 14185 | CDC7E3 | CE11 | CALL | PTXT |  |
| ＇4188 | CD9 CE5 | 5212 | Cfile | CRLF |  |
| $1415 B$ | 3EA6 | 0213 | LL | f，1018011而 | ；LiShlle buffeps， |
| ， 418 D | D3L6 | E214 | OUT | （ CD 6 H ），A | ；RAISE CS |
| －41EF | C31LE1 | 0215 | JP | ： $\mathrm{H} T \mathrm{~T}$ |  |
| － 41 C 2 | E1 | 6216 FG7： | pop | IRL |  |
| 141C3 | 3EAE | 0217 | LD | A 121811102 | ；di sajle muffens， |
| － 4165 | E3D6 | ¢ 218 | OUT | （ 0 D6i）， A | ；RAISE 4040 RST． |
| ＇41C7 | 3ECF | 6219 | LD | A，ECFH | ；Clifinge pont in TO |
| － 41 C 9 | D3D5 | 8220 | OUT | （eD5 i ），A | ；OUTPJT DOET． |
| － 41 CE | 3 ERD | 0221 | LD | A， 08 |  |
| － 41 CD | L3E5 | 2222 | OUT | （ $0 D 5 \mathrm{H}$ ）， A |  |
| ， 41 CF | 1 ERQ | － 22 E3 | LD | E，${ }^{\text {S }}$ |  |
| － 41 Dl | 21AD42＇ | 2224 | LE | ．lL，licSG2 | ；TELL LSER TO TUF： |
| ，41D4 | CECTE3 | 0225 | CALL | PTXT | ；Olv PROGRAII ENAELE |
| －4107 | CD9CES | 6226 | CALL | CRLF | ；SUITCaES． |
| 141DA | CD22E5 | 0227 | CALL | RDCHP | ；WAIT FOE INDUT |
| － 41 DD | CD9CES | 2228 | CfiLl | CRLF | ；FROLI LSER． |
| － 41 EG | 110084 | 0229 | LD | DE，420．： |  |
| －41E3 | QE64 | ［23\％ | LL | C， 108 | ；$C$ IS LGOP COEJTER |
| －41E5 | 210008 | ©231 PG1： | LD | HL，eg |  |
| －41上8 | 3 EA7 | 0232 | LD | A，121Cx111L | ；LOIES 40．40 TST， |
| －41EA | D3E5 | 0233 | OUT | （ 2 D6：$), A$ | ；ENALLE OUTPUT EUFFER |


| Lraik prograilser |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \＆゙んL！ | OSJECT | ST\＃ |  |  |  |  |
| － 41 EC | 75 | 0234 | PG2： | LD | A，（HL） | ；OUTEUT data cin |
| －41ED | D3 54 | 8235 |  | OLT | （eD4if），A | ；PORT is． |
| － 4 ILF | 3E17 | 0236 |  | LD | ASEQ 1C1112 | ；SET UP CTC FOT． 1 I：S |
| － 4171 | E3DA | 0237 |  | OUT | （EDAF），A | ；INTEFVAL． |
| ， 4173 | 3 E 97 | 6234 |  | LD | $A=151$ |  |
| 141F5 | D3DA | 13239 |  | OUT | （ 0 DAH），$A$ |  |
| ： 4157 | 3E67 | ஏ248 |  | LD | A，10ECOL11E | ；FAISE E70B EG：1 LINL |
| － 4159 | D3D6 | 0241 |  | OUT | （ 0 D6H），A |  |
| ， 415 F | DEDA | 8242 | PG3： | IN | A，（GDAH） | ：Wait fof CTC TO |
| － 41 FD | FEQ1 | 8243 |  | CP | 01 | ；COLNT DOW： |
| － 417 F | C2FB41＇ | 0244 |  | JP | NZ，PG3 |  |
| － 4262 | 3EA7 | 0245 |  | LD | A， 10108111 E | ；LOJEI．E70R PGM LINE |
| －4204 | D3DE | 0246 |  | OUT | （ $8 D 6 H$ ），A |  |
| ＇ 4206 | 3EAS | 0247 |  | LD | A $=101000115$ | ；INCRELIENT 404Q |
| ＇4208 | D3D6 | 0248 |  | OUT | （ 0 D 6 H ），A |  |
| － 420 A | 3EA7 | 0249 |  | LD | $A=101801118$ |  |
| － 4200 | D3D6 | 0250 |  | OUT | （0D6H），$A$ |  |
| － 420 E | 23 | 0251 |  | INC | HL |  |
| ，420F | E5 | 0252 |  | PUSH | HL |  |
| － 4210 | 37 | 6253 |  | SCF |  | ；CLEAR CAREY |
| －4211 | $3 F$ | 0254 |  | CCF |  |  |
| ＇4212 | ED52 | 0255 |  | SBC | HL，DE | ；SEE IF（HL）$=4 \mathrm{CQ} \mathrm{H}$ |
| ＇4214 | CA1B42＇ | 0256 |  | JP | Z，PG4 | ；GO TO PG4 IF SO． |
| ＇4217 | E1 | 0257 |  | POP | HL |  |
| ， 4218 | C3EC41＇ | 0258 |  | JP | PG2 | ；OTHERWISE CONTINLE |
| ，421B | El | 0259 | PG4： | POP | HL |  |
| － 421 C | OL | 0260 |  | LEC | C |  |
| －4210 | CA27 42＇ | 0261 |  | JP | Z，CHK | ；IF IRE LOOPS，STOP |
| ． 4220 | 3EAF | 0262 |  | LL | A，121011115 | ；RAISE 4040 RST |
| ＇4222 | E3D6 | ¢263 |  | OLT | （0D6H），A |  |
| ＇4224 | C3E541＇ | 0264 |  | JP | PG1 | ；IF＜IEE，COINTINUE |
| ＇4227 | 3 EAE | 0265 | C：HK： | LL | A，10101118E | ；DISAELE ELFFERS |
| － 4229 | E3D6 | 8266 |  | OLT | （ED615），$A$ | ；PAISE 4 C4Z－K．ST． |
| ＇422B | 3ECF | 2267 |  | LD | A，ECFI | ；Cifujge port a to |
| ＇422D | E3 L5 | Q268 |  | OUT | （ 6 DSil），$A$ | ；I：JPUT PORT． |
| －422F | 3EFF | 0269 |  | LD | A，DFFH： |  |
| － 4231 | D3E5 | 8278 |  | OUT | （GU5A），$A$ |  |
| － 4233 | 218200 | Q271 |  | LD | HL， 6 C |  |
| ＇4236 | 3EB4 | E272 |  | LD | A，IG11c163S | ；EMALLE INPUT EUFFET， |
| － 4238 | D3D6 | e273 |  | OUT | （ 2 D 6 i ），$A$ | ；LOWER 484C PST \＆CS． |
| －423A | DBD4 | 0274 | CHK 1： | IN | A，（0D4H） | ；SLE IF Custaits Of |
| ＇423C | BE | 8275 |  | CP | （HL） | ；27e3 AFE COPRECT． |
| －423D | C22841＇ | e276 |  | JP | NZ，EFFOT | ；IF IOT，GO TO ERIIOR |
| ＇4240 | 23 | 0277 |  | INC | HL |  |
| － 4241 | E5 | Q278 |  | PUSH | HL |  |
| 14242 | 37 | 0279 |  | SCF |  | ；Cliear ceffry |
| － 4243 | 3 F | 0288 |  | CCF |  |  |
| ＇ 4244 | ED5 2 | 0281 |  | SBC | HL，DE | ；SEE IF（HL）$=48 \mathrm{ClH}$ |
| － 4246 | CA5542＇ | 0232 |  | JP | $Z$ ，QUIT | ；1F SO GLIT |
| － 4249 | E1 | 0283 |  | POP | HL |  |
| －424A | 3EEの | 0234 |  | LD | A，101180e8b | ；INCSEITJT 484C |
| －424C | 23D6 | 2285 |  | OUT | （ $8 D 6: 1), A$ |  |
| －424E | 3ES4 | 0286 |  | L． | A，16118126E |  |
| －4258 | L3D6 | 0287 |  | OUT | （ ED 6 H ）， A |  |
| － 4252 | C33A42＇ | 2288 |  | JP | Clint | ；OTHEFivise CONTINUE． |
| － 4255 | 3EA6 | $02: 59$ | CUIT： | LL | A，10108116E | ；LISABLE BUFFE？S |
| ＇4257 | D3E6 | 0290 |  | OUT | （ 2 D6ri）， 6 |  |
| － 4259 | 1ERE | 2e91 |  | LD | $E, \varepsilon$ |  |



ERRORS $=8000$
ERRORS $=0 \mathrm{EDO}$

## ORIGINAL PAGE IS OE POOR QUALMT

