BUILD YOUR OWN
Z80 COMPUTER

Design Guidelines
and
Application Notes

by Steve Ciarcia
Build Your Own
Z80 Computer

Design Guidelines
and
Application Notes

Steve Ciarcia
Build Your Own Z80 Computer

Copyright © 1981 by Steve Ciarcia. All rights reserved. Printed in the United States of America. No part of this book may be reproduced, stored in a retrieval system, or transmitted, in any form, or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the author.

The author of the circuits and programs provided with this book has carefully reviewed them to ensure their performance in accordance with the specifications described in this book. Neither the author nor BYTE Publications Inc., however, make any warranties concerning the circuits or programs and assume no responsibility or liability of any kind for errors in the circuits or programs, or for the consequences of any such errors. The circuits and programs are the sole property of the author and have been registered with the United States Copyright Office.

The author would like to acknowledge that portions of this book have been reprinted by permission of the manufacturers. The instruction codes in Chapter 3 and Z80 CPU technical information have been reprinted by permission of Zilog, Inc. Chapter 9 is based on an application note reprinted by permission of SMC Microsystems Corporation.

Library of Congress Cataloging in Publication Data

Ciarcia, Steve.
Build your own Z80 computer.

Includes index.
1. Electronic digital computers—Amateurs’ manuals.
2. Zilog Model Z-80 (Computer) I. Title.
TK9969.C52 621.3819'582 81-4335
ISBN 0-07-010962-1 AACR2

5 6 7 8 9 10 KGP KGP 89876543
ISBN 0-07-010962-1

Text set in Paladium by BYTE Publications
Edited by Bruce Roberts and Nicholas Bedworth
Design and Production Supervision
by Ellen Klemper
Production by Mike Lonsky
Cover Photo by Charley Freiberg
Copy Edited by Rich Friedman and Peg Clement
Figure and Table Illustrations
by Tech Art Associates
Printed and bound using 45# Bookmark
by Kingsport Press, Kingsport, Tennessee
To my wife Joyce,

Steve Sunderland, and Judy and Lloyd Kishinsky
Build Your Own
Z80 Computer
Introduction

A few years ago, when microprocessors were first introduced, computer enthusiasts and electrical engineers were one and the same. Those of us who lived only to solder kluge after kluge basked in our glory. Now, however, the prices of completely assembled and packaged systems have plummeted. Today anyone with an interest, almost regardless of technical capabilities, can own and operate a computer. Buying a computer is now similar to purchasing a television set and the ranks of computer enthusiasts have swelled accordingly.

With any popular movement, the available literature reflects the concerns of a majority of the followers. And, consistent with the popularization of computer science, the technical emphasis on computer bookshelves has shifted away from hardware design. Other than introductory texts called, say, How Logic Gates Work, most computer books either treat microcomputer hardware simplistically or attempt to be “catch-all” cookbooks, sometimes omitting tasty ingredients. Often, the only alternatives are engineering texts and trade journals, tedious reading at best.

For a number of years, I have been writing a column for BYTE magazine, and reader response has shown that there still exists a great deal of interest in hardware design and do-it-yourself projects. At the same time, I’ve been painfully aware of the lack of materials for such people. Most queries come from technical or high school students who have read all the descriptions and studied the block diagrams, but who crave practical answers and system examples. Unfortunately, there are very few books I can suggest.

Build Your Own Z80 Computer is a book written for technically minded individuals who are interested in knowing what is inside a microcomputer. It is for persons who, already possessing a basic understanding of electronics, want to build rather than purchase a computer. It is not an introductory electronics handbook that starts by describing logic gates nor on the other hand is it a text written only for engineering students. While serving to educate the curious, the objective of this book is to present a practical, step-by-step analysis of digital computer architecture, and the construction details of a complete and functional microcomputer.

The computer to be constructed is called a Z80 Applications Processor—ZAP computer for short. It is based on the industry standard Zilog Z80 microprocessor chip. This chip was chosen on the basis of its availability and low cost, as were the other components for ZAP. To further help the homebrew enthusiast, and for those experimenters who prefer to start a book at the back, I have listed in Appendix A a company that supplies programmed EPROMs (erasable-programmable read-only memory).

I have structured the book as a logical sequence of construction milestones interspersed by practical discussions on the theory of operation. My purpose is twofold: to help a potential builder gain confidence, and to make the material more palatable through concrete examples.

Though this is basically a construction manual, considerable effort is given to the “why’s” and “how’s” of computer design. The reader is exposed to various subjects, including: the internal architectures of selected microprocessors, memory mapping, input/output interfacing, power supplies, peripheral communication, and programming. All discussions try to make the reader aware of each individual component’s effect on the total system. Even though I have documented the specific details of the ZAP computer, it is my intention (and the premise of the book) that the reader will be able to configure a custom computer. ZAP is an experimental tool that can be expanded to meet a variety of applications.
ZAP is constructed as a series of subsystems that can be checked and exercised independently. The first item to be built is the power supply. This is a good way to test ability and provide immediate positive reinforcement from successful construction. The three-voltage supply is both overvoltage and overtemperature protected and has adequate current for an expanded ZAP system.

Next, the reader learns why the Z80 was chosen for ZAP and the architectural considerations that affect component selection on the other subsystems. A full chapter is devoted to the Z80 chip. Each control signal is explained in detail and each instruction is carefully documented.

The hardware construction proceeds in stages with intermediate testing in order to ensure success. The basic elements of the computer are assembled first and then checked out. The reader selects which peripherals are to be added. The book contains sections on the construction of a hexadecimal display, keyboard, EPROM programmer, RS-232C serial interface, cassette mass storage system, and fully functional CRT terminal. In addition, a chapter addresses interfacing the ZAP to analog signals. I provide specific circuits that can convert ZAP into a digital speech synthesizer or a data acquisition system and data logger.

A special 1 K (1024 bytes) software monitor coordinates the activities of the basic computer system and the peripherals. Software is explained through flow diagrams and annotated listings. With this monitor as an integral component, ZAP can function as a computer terminal, a dedicated controller, or a software development system.

*Build Your Own Z80 Computer* is a book for hardware people. It cuts through the theoretical presentations on microcomputers and presents a real "How-to" analysis suitable for the reader with some electronics experience or for the novice who can call someone for supervision. From the power supply to the central processor, this book is written for people who want to understand what they build.

Steve Ciarcia
May 1981
TABLE OF CONTENTS

Introduction

Chapter 1  Power Supply ................................. 1
Chapter 2  Central Processor Basics ...................... 21
Chapter 3  The Z80 Microprocessor ...................... 27
Chapter 4  Build Your Own Computer - Start With the Basics . . . 91
Chapter 5  The Basic Peripherals ......................... 129
Chapter 6  The ZAP MONITOR Software .................. 151
Chapter 7  Programming an EPROM ....................... 173
Chapter 8  Connecting ZAP to the Real World .......... 183
Chapter 9  Build a CRT Terminal ......................... 213

Appendix A  Construction Techniques .................... 225
Appendix B  ASCII Codes ................................ 229
Appendix C  Manufacturers' Specification Sheets .......... 233
           C1  2708 8K (1K × 8) UV Erasable PROM ............... 235
           C2  2716 16K (2K × 8) UV Erasable PROM ............... 239
           C3  2102A 1K × 1 Bit Static RAM ..................... 243
           C4  2114A 1K × 4 Bit Static RAM ..................... 247
           C5  8212 8-Bit Input/Output Port .................... 251
           C6  KR2376-XX Keyboard Encoder Read-Only Memory .... 259
           C7  COM2017 Universal Asynchronous Receiver Transmitter . 263
           C8  CRT 5027 CRT Video Timer and Controller .......... 271
           C9  CRT 8002 Video Display Attributes Controller ...... 279
           C10 COM8046 Baud Rate Generator ................... 287

Appendix D  ZAP Operating System ....................... 293
Appendix E  Z80 CPU Technical Specifications .......... 307
           E1  Electrical Specifications ......................... 309
           E2  CPU Timing .................................. 313
           E3  Instruction Set Summary ......................... 321

Glossary ................................................. 325

Index ..................................................... 329
CHAPTER 1
POWER SUPPLY

It's not enough to build a central processor card with a little input/output (I/O) and memory, and call it a computer. From the time you walk over to the computer and flip the switch, the system is completely dependent upon the proper operation of its power supply. A book concerned with building a computer system from scratch would be completely inadequate without a description of how to construct an appropriate power supply.

Much has been written on the subject of direct current (DC) power supplies. There are DC to DC and AC (alternating current) to DC converters, switching and shunt regulators, constant voltage transformers, and so on. It's not my intention to make a power supply expert out of everyone. Instead, I will outline the design of the specific DC power supply which we will use to power the Z80 Applications Processor (ZAP).

In large computers, the DC supplies convert enormous amounts of power to run thousands of logic chips; by necessity, manufacturers choose the most efficient methods of power conversion. These state of the art methods would be expensive and difficult for the hobbyist to build in prototype form. Fortunately, the power demands for ZAP are much less than those of the large computers; we can take advantage of established design methods while incorporating the latest advances in regulator technology. Figure 1.1 is a block diagram of the power supply for ZAP.

Each of the three DC supplies necessary to power ZAP consists of three basic modules: a transformer section to reduce the 120 VAC line voltage to the lower voltage used by the computer; an input rectifier/filter to convert AC to low ripple DC; and a regulator which stabilizes the output at a fixed voltage level. Overvoltage protection circuitry will be discussed separately.

Figure 1.1 A block diagram of the basic power supply for the Z80 Applications Processor (ZAP).
The proper specification of the transformer and input filter is often neglected by hobbyists who overlook the consequences of a poorly designed filter. This is caused, in part, by the abundant technical information circulated by semiconductor manufacturers extolling the virtues of their regulator circuits. One can easily conclude from this “publicity gap” that the regulation section of the power supply is the only component worthy of consideration; and in fact, advances in regulator design and the advent of high-power, three-terminal regulators have reduced the need for the analog designer in the application. In the past, 25-odd components and considerable calculations were necessary to produce an adequate voltage regulator. Now, however, the majority of applications can be accommodated with a single, compact device. Even so, an input filter section should not be taken lightly and still requires thorough consideration and a modest amount of computation for each application.

There are three supply voltages necessary to operate ZAP. Each supply incorporates an input filter section. Because the +5 V supply is the most important, it receives the most attention. For the purposes of this discussion, we will divide the supply into two sections: transformer/input filter, and output regulator.

A standard input filter block diagram is shown in figure 1.2. In its simplest form, it consists of three components that function as follows:

- A transformer that isolates the supply from the power line and reduces the 120 VAC input to usable, low-voltage AC.
- A bridge rectifier that converts AC to full-wave DC and satisfies the charging current demands of the filter capacitor.
- A filter capacitor that maintains a sufficient level between charging cycles to satisfy the regulator input voltage limitations.

![Photo 1.1 120 VAC RMS input/output waveform of a saturated transformer.](image1) ![Photo 1.2 Rectifier waveform.](image2) ![Photo 1.3 Ripple waveform at various loads.](image3)

**Figure 1.2 A block diagram of a standard input filter.**

2 POWER SUPPLY
DESIGNING AN INPUT FILTER

You would think that specifying the transformer would be the first consideration when designing a power supply. Yes and no. The approximate output voltage can be determined by rule of thumb, but the exact requirements are deduced only by a thorough analysis that proceeds from the desired output voltage back. In practice, the difference between a reasonable guess and a laborious analysis will be important only to a person capable of manufacturing his own transformer. In most instances, the hobbyist will have to rely upon readily acquired transformers with standard output voltages. For this reason, my approach is predicated on the practical aspects of power supply design rather than on the minute engineering details that have no real bearing on the outcome.

A 120 VAC RMS (root mean square) sine wave is applied to the primary of the transformer. Figure 1.2 illustrates the waveforms anticipated at selected points through the filter section. Photo 1.1 shows that 120 VAC is actually 340 V peak to peak; care should be used in the insulation and mounting of components.

The secondary output of the transformer will be a similar sine wave, reduced in voltage. It is then applied to a full-wave bridge and the waveform will appear as in photo 1.2. You'll notice a slight flat spot between "humps." As a result of dealing with actual electronic components rather than mathematical models, we should be aware of certain peculiarities. Silicon diodes exhibit threshold characteristics and, in fact, have a voltage drop of approximately 1 V across each diode. This voltage drop becomes significant in full-wave bridge designs and, as figures 1.3a, 1.3b, and photo 1.2 illustrate, can accumulate as diodes are added in series. The 2 V loss in the bridge is an important consideration and should be reflected in the calculations.

The voltage regulator requires a certain minimum DC level to maintain a constant output voltage. Should the applied voltage dip below this point, output stability is

![Diagram](image)

**Figure 1.3** The direction of the current flow through the full-wave bridge.

* a) During the positive half of the AC cycle, current flow is through $D_1$ and $D_3$; $D_2$ and $D_4$ are not conducting. $V_{p1} + V_{p3} = 2$ volts.

* b) During the negative half of the AC cycle, current flow is through $D_2$ and $D_4$; $D_1$ and $D_3$ are not conducting. $V_{p2} + V_{p4} = 2$ volts.
severely degraded. Thus, a filter capacitor is used to smooth out the "humps" in the rectified sine wave. When the diodes are conducting, the capacitor stores enough charge to maintain the minimum voltage required until the next charge cycle. (In practice, we wouldn't want to cut it that close.) The input to the transformer is 60 Hz, but because of the characteristics of full-wave rectification, the charging cycles occur at 120 Hz. The capacitor charges up during one 8.3 ms cycle, and, as the regulator draws power from it to satisfy the load demands, it must continue to provide at least the highest minimum input voltage required by the regulator until the next charge cycle, 8.3 ms later. This periodic charge/discharge phenomenon is shown in photo 1.3. The magnitude of the voltage fluctuation between the two peaks of the cycle is referred to as ripple. The highest magnitude of the waveform including the ripple is designated as peak voltage. Both are important to remember and are shown in figure 1.4.

![Figure 1.4 Output voltage as a combination of a certain steady-state voltage \( V_C \) plus a ripple voltage \( V_{\text{RIPPLE}} \).]

Given a basic understanding of the individual components at this stage, we can proceed to the case at hand: a 5 V, 5 A power supply. For reasons we'll discuss later, the 5 V regulator section of this supply will require an absolute minimum of 8.5 V for proper operation. This means that whatever the magnitude of \( V_{\text{PEAK}} \) and \( V_{\text{RIPPLE}} \), the final \( V_C \) level must not go below 8.5 V, or the regulator will not work. By giving ourselves some leeway, say \( V_C = 10 \) V, we can take a little more poetic license with the calculations and still produce a good design. Going much above 10 V, while still satisfying the input criteria, would increase power dissipation and possibly destroy the regulator. There is an answer to this vicious circle and that's to be conservative. Experience shows that adding a little insurance is worthwhile.

Now that 10 V is the goal, we can appropriately select the other filter components to meet it. Figure 1.5 is the filter circuit of our 5 V supply. \( R_s \) is the resistance of the secondary winding of the transformer. For a 5 to 8 A transformer, it will average about 0.1 ohms. The first values to recognize follow:

\[
\begin{align*}
V_C &= V_{\text{REGULATOR MINIMUM INPUT VOLTAGE}} = 10 \text{ V} \\
I_{\text{OUT}} &= I_{\text{REGULATOR LOAD}} = 5 \text{ A} \\
R_s &= R_{\text{TRANSFORMER SECONDARY RESISTANCE}} = 0.1 \text{ ohms}
\end{align*}
\]

\( V_{\text{PEAK}} \) can be any voltage up to the maximum input for which the regulator is rated. However, this will increase the circuit power dissipation. The rule of thumb I use when designing supplies of this type is that \( V_{\text{PEAK}} \) should be approximately 25% higher than \( V_C \). In this way, the capacitor value will be kept within reasonable limits. The ratio of \( V_C \) to \( (V_{\text{PEAK}} - V_C) \) is referred to as the ripple factor of the filter capacitor.

\[
\gamma_r = \frac{V_{\text{PEAK}} - V_C}{V_C} = \frac{12.5 - 10}{10} = 25\% 
\]

A ripple factor of 25% at 5 A will fall well within the acceptable capacitor ripple current ratings and eliminate the need for the hobbyist to dig into manufacturers' specifications of capacitors. This ripple factor is arbitrary, but it is best to keep it as low as possible.
SIZING THE CAPACITOR

We now know that the capacitor must sustain 10 V from a peak input of 12.5 V.

\[
\begin{align*}
V_{\text{PEAK}} &= 12.5 \text{ V} \\
V_C &= 10 \text{ V} \\
V_{\text{RIPPLE}} &= 2.5 \text{ V}
\end{align*}
\]

\[
\text{ } = V_{\text{PEAK}} - V_{\text{RIPPLE}}
\]

The next consideration is to choose a capacitor that will accomplish this goal. Another rule of thumb calculation that saves considerable labor is

\[
C = \frac{dt}{dv} I
\]

where

- \( C \) = capacitor value in farads = ?
- \( I \) = maximum regulator current = 5 A
- \( dt \) = charging time of capacitor = 8.3 ms (120 Hz)
- \( dv \) = allowable ripple voltage = 2.5 V

Plugging in the values of our circuit,

\[
C = \frac{(5)(8.3 \times 10^{-3})}{(2.5)} = 16.6 \times 10^{-3} \text{ farads}
\]

or,

\[
C = 16,600 \text{ microfarads (\mu F)}
\]

Generally available commercial electrolytic capacitors have a tolerance of ±50 and ±20%. To be on the safe side and to make it easier to find a standard stock component, a value of 20,000 \( \mu \)F is better. The added 3,400 \( \mu \)F reduces the ripple by another 0.4 V and gives us a little "insurance." The only other item to consider with the capacitor is operating voltage. Because the design dictates that \( V_{\text{PEAK}} \) is 12.5 V, this should be a satisfactory rating. However, experience shows that transformers end up running at higher output voltages than labeled and that 12.5 V at 115 VAC hits 13.6 V when the line voltage goes up to 125 VAC. A capacitor voltage of 15 VDC would appear to satisfy the requirement, but I recommend using the next increased standard value of 20 VDC.

The capacitor is therefore 20,000 \( \mu \)F at 20 VDC. The rectifier can be a monolithic full-wave bridge, or it can be four discrete diodes. Note that because a bridge is usually encapsulated, the four terminals are labeled instead of showing the polarity markings of the individual diodes. The designations for the four terminals are two AC input terminals, and a + and − output terminal.
THE RECTIFIER

There are three considerations when choosing a rectifier: surge current rating, continuous current, and PIV (peak inverse voltage) rating. These choices are not inconsequential and must be considered carefully.

When a power supply is first turned on, the capacitor is totally discharged. In fact, it will instantaneously appear to be a 0 ohm impedance to the voltage source. The only aspect of the circuit that limits the initial current flow is the resistance of the secondary transformer windings and the connecting wiring; designers often add a series resistance to limit surge current.

The surge current in this circuit is
\[ I_{\text{SURGE}} = \frac{V_{\text{PEAK}}}{R_s} = \frac{12.5}{0.1} = 125 \, \text{A} \]

and the time constant of the capacitor is
\[ \tau \equiv R_s \times C \equiv (0.1)(20 \times 10^{-3}) = 2 \, \text{ms} \]

As a rule of thumb, the surge current will cause no damage to the diode if \( I_{\text{SURGE}} \) is less than the surge current rating of the diode and if 
\[ \tau < 8.3 \, \text{ms} \] (which it is)

We can't check surge rating until after we choose a diode bridge, but the other two parameters can be defined.

The bridge can be either of the following:

Motorola MDA 980-2: \( I_{\text{CONT}} = 12 \, \text{A}, I_{\text{SURGE}} = 300 \, \text{A}, \text{PIV} = 100 \, \text{V} \)

Motorola MDA 990-2: \( I_{\text{CONT}} = 27 \, \text{A}, I_{\text{SURGE}} = 300 \, \text{A}, \text{PIV} = 100 \, \text{V} \)

Both of the above bridges have a surge current rating of 300 A, so our surge requirement is also satisfied.

PIV

PIV (peak inverse voltage) is the maximum voltage that may appear across the diode before it self-destructs. Diodes, unlike capacitors, are unforgiving; transients will wipe them out. It is not unusual to have 400 V transients on the 115 VAC input line. This causes our 12.5 V to shoot up momentarily to 43 V! The bridge rectifier should therefore have a minimum PIV rating of 50 V. For a few pennies more, you can get a bridge rated for 100 PIV. Remember, insurance costs less than computers.

CONTINUOUS CURRENT

The last consideration is continuous current rating. Whereas the regulator may be designed for a 5 A output, the particular regulator I have chosen will draw 7 A if shorted. This is not standard operating procedure, but it can happen. The suggested standard component would be a 12 A, 50 PIV bridge. A preferred component would be one rated for 12 A at 100 PIV or, for an additional 15% cost premium, a 27 A at 100 PIV. This last design choice is strictly brute force, but it saves the diode bridge should the capacitor ever short-out accidentally. A 6 A transformer might put out more than 12 A in a short-circuit mode, but it's unlikely that it would be capable of 27 A. Either choice will satisfy the design, but only one saves the design from the builder.

THE TRANSFORMER

Now let's consider the transformer. We have determined the voltage drops across the various components. The values are used to calculate the required RMS (root mean
square) secondary voltage in the following way:

\[
V_{\text{sec(rms)}} = \frac{V_C + V_{\text{ripple}} + V_{\text{RECT}}}{\sqrt{2}} \quad V_{\text{RECT}} = \text{Voltage drop across each diode—(approximately } 1 \text{ V per diode)}
\]

\[
= \frac{10 + 2.5 + 2.0}{1.414}
\]

\[
= 10.25 \text{ V}
\]

In practice, a 10 V, 6 A standard value transformer will be close enough.

The components of the + and −12 V supplies are chosen in a similar manner, with the exception that required current is only 1 A, and a 200 PIV bridge is recommended because of the particular rectifier configuration. The finished schematic of the transformer and filter section of our computer is illustrated in figure 1.6.

![Schematic Diagram of Transformer and Input Filter Section](image)

**Figure 1.6** A schematic diagram of a transformer and input filter section.

**VOLTAGE REGULATORS**

The voltage regulator section of our power supply is the next consideration. All voltage regulators perform the same task: they convert a given DC input voltage into a specific, stable DC output voltage and maintain this setpoint over wide variations of input voltage and output load. The typical voltage regulator, as shown in figure 1.7, consists of the following:

- a reference element that provides a known stable reference voltage
- a voltage translation element that samples the output voltage level
- a comparator element that compares the reference and output level to produce an error signal
- a control element that can utilize this error signal to provide translation of the input voltage to produce the desired output

The control element depends on the design of the regulator and varies widely. The control determines the classification of the voltage regulator: series, shunt, or switch-
ing. For the series regulator, the control element regulates the output voltage by modulating the series element, usually a transistor, and causes it to act as a variable resistor (figure 1.8). As the input voltage increases, the series resistance $R_s$ also increases, causing a larger voltage drop across it. In this way, the output voltage ($V_{out}$) is maintained at a constant level.

Figure 1.7 A block diagram of a typical voltage regulator.

\[ V_{out} = V_{IN} - \left( R_s I_{load} \right) \]

Figure 1.8 A series control element in the voltage regulator.

a) The series control element acts as a variable resistance, $R_s$.

b) The series element is most often a transistor.

To accomplish this closed-loop control, a reference comparison and feedback system is incorporated into the hardware. A fixed and stabilized reference voltage is easily produced by a zener diode. The current produced is low, however; the device could not serve as a power regulator by itself.

The voltage translator connected to the output of the series control element produces a feedback signal that is proportional to the output voltage. In its simplest form, the voltage translator is a resistor-divider network. The two signals, reference and feedback, provide the necessary information to the voltage comparator for closed loop feedback to occur (figure 1.9). The output of the comparator effectively drives the base of the series pass transistor so that the voltage drop across the transistor will be maintained at a stabilized preset value when subtracted from the input voltage.

Modern power supply designers can still use individual components to construct the modular elements of a series voltage regulator, but most reserve this laborious endeavor for specialized applications. The ZAP computer system outlined here requires $+5$ V, $+12$ V, and $-12$ V. The combined temperature, stability, and drift
tolerances cannot exceed ±5% on any of the three set points. The easiest way to minimize risk is to reduce the number of circuit components to the bare minimum. Other designers had the same idea and thus the three-terminal regulator was invented. Figure 1.10 is the block diagram of such a device.

![Diagram](image)

**Figure 1.9 A schematic diagram of a series voltage regulator.**

![Diagram](image)

**Figure 1.10 A block diagram of a three-terminal voltage regulator.**

Basically, a three-terminal regulator incorporates all the individual transistors, resistors, and diodes into a single integrated circuit. While simple to use, these devices have a far more complicated internal structure than the series regulator of figure 1.9. Only three terminals are necessary in applications where the fixed output is a standard value such as: ±5 V, ±6 V, ±8 V, ±12 V, ±15 V or ±24 V. The three connections are unregulated DC from our input filter, a ground reference, and finally, regulated DC output.
In a three-terminal regulator, the voltage reference is the most important part because any abnormality or perturbation will be reflected in the output. Therefore, the reference must be stable and free from noise or drift. More advanced designs use band-gap reference circuits rather than zener diodes. Because of its complexity, such an approach is practical only in the integrated circuit (IC) environment. Essentially, a band-gap reference voltage is derived from the predictable temperature, current, and voltage relationships of a transistor base-emitter junction.

Another advantage of the three-terminal regulator is that in monolithic circuits, stable current sources can easily be realized by taking advantage of the good matching and tracking capability of monolithic components. Also, as in the previous case, the designer can add as many active devices as necessary without significantly increasing the IC circuit area. Operation of the reference circuit at a constant current level reduces fluctuations due to line-voltage variation. Thus, the output has increased stability. The error amplifier is also operated at a constant current to reduce line-voltage influence.

The most important consideration for the hobbyist is that these chips incorporate protective circuitry, guarding the regulator from certain types of overloads. They protect the regulator against short-circuit conditions (current limit); excessive input/output differential condition (safe operating area); and excessive junction temperatures (thermal limit). Of course, all this circuitry is designed to protect the regulator, not the computer.

**CHOOSING A REGULATOR**

The 5 A \(\mu\text{A78H05}\) hybrid voltage regulator has all the inherent characteristics of the monolithic three-terminal regulator (ie: full protective circuitry). Each hermetically-sealed TO-3 package contains a \(\mu\text{A78M05}\) monolithic regulator chip driving a discrete series-pass transistor Q1 and two short-circuit-detection transistors Q2 and Q3 (see figure 1.11). The pass transistor is mounted on the same beryllium oxide substrate as the regulator chip, thus insuring nearly ideal thermal transfer between Q1 and the temperature-sensing circuit of the 78M05.

![Figure 1.11 A block diagram of a 5 A \(\mu\text{A78H05}\) and \(\mu\text{A78HG05}\) hybrid voltage regulator.](image-url)
The output circuit is designed so that the worst-case current requirement of the Q1 base, added to the current through R2, always remains below the current-limit threshold of the 78M05. Resistor R1, in conjunction with Q2 and Q3, makes up a current sense and limit circuit to protect the series-pass device from excessive current drain.

Safe area protection is achieved by brute force and is designed with the hobbyist in mind. The series-pass transistor is capable of handling the short-circuit current at the maximum input voltage rating of the 78H05. (See Figure 1.12 for the electrical characteristics of the 78H05.)

The output of the device is nominally 5.0 V but can vary between 4.8 and 5.2 V. Even though this falls within the 5.0 V ±15% tolerance necessary to run the computer, there might be a problem with the voltage drop in the cabling between the power supply and the computer. Up to 0.5 V could be lost in the wiring and connectors. Remember that at 5 A, a resistance of only 0.1 ohms can cause a 0.5 V drop. Unfortunately, the 78H05 is a fixed-output device when referenced to ground. If 4.8 V happens to come out, “that’s all you gets” (sic). But, in a classic case of engineering razzle-dazzle, we can fool the regulator by making the ground reference adjustable. Figure 1.13 shows the circuit that makes this possible. A potentiometer sourced from the −12 V supply creates a relative-ground reference for the 78H05. If the particular device in question had an output of 4.95 V, and we adjusted R1 for a potential of 0.20 V on the common regulator pin, the output referenced to ground would change to 4.95 + 0.20, or 5.15 V. For the fanatics in the crowd, this particular circuit also allows a high-output device to be reduced to 5.00 V by selecting an appropriate negative voltage ground reference pin.

Figure 1.12 Electrical characteristics of the μA78H05 voltage regulator.

Figure 1.13 Adding “trim adjust” to the μA78H05 three-terminal voltage regulator.
With the 5 V supply complete, our next concern is the +12 V and -12 V supplies. Other devices within the 7800 family of regulators will satisfy the requirements. The 7812 and a 7912 are 1 A positive and negative regulators respectively; they exhibit the same protection characteristics as the 78H05. Figures 1.14 and 1.15 outline the exact specifications. Because we are dealing with much lower currents than the +5 V supply, there is considerably less concern over voltage losses through connecting cables, and it is unnecessary to add trim adjustment circuitry. Figure 1.16 is the finished schematic of the ZAP power supply. Additional regulator circuit diagrams (figures 1.17a, b, c and d) are included to demonstrate how the 7800 series of regulators can be used in our application. Are we finished yet? Of course not. Close examination of figure 1.16 shows two items not discussed previously: heat sinks and overvoltage protection. These two subjects and a short discussion of the importance of correct layout complete the chapter.

### µA7812

**ELECTRICAL CHARACTERISTICS:** V_IN = 18 V, I_OUT = 500 mA, -55°C < T_J < 150°C, C_IN = 0.33 μF, C_OUT = 0.1 μF, unless otherwise specified.

<table>
<thead>
<tr>
<th>CHARACTERISTICS</th>
<th>CONDITIONS</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
<th>UNITS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Output Voltage</td>
<td>T_J = 25°C</td>
<td>11.5</td>
<td>12.0</td>
<td>12.5</td>
<td>V</td>
</tr>
<tr>
<td>Line Regulation</td>
<td>T_J = 25°C</td>
<td>14.5 V ≤ V_IN ≤ 30 V</td>
<td>10</td>
<td>120</td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td>16 V ≤ V_IN ≤ 22 V</td>
<td>3.0</td>
<td>60</td>
<td>mV</td>
</tr>
<tr>
<td>Load Regulation</td>
<td>T_J = 25°C</td>
<td>5 mA ≤ I_OUT ≤ 1.5 A</td>
<td>12</td>
<td>120</td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td>250 mA ≤ I_OUT ≤ 750 mA</td>
<td>4.0</td>
<td>60</td>
<td>mV</td>
</tr>
<tr>
<td>Output Current</td>
<td>T_J = 25°C</td>
<td>15.5 V ≤ V-IN ≤ 27 V</td>
<td>11.4</td>
<td>12.6</td>
<td>V</td>
</tr>
<tr>
<td>Quiescent Current</td>
<td>T_J = 25°C</td>
<td>15 V ≤ V_IN ≤ 30 V</td>
<td>4.3</td>
<td>60</td>
<td>mA</td>
</tr>
<tr>
<td>Quiescent Current Change</td>
<td>with line</td>
<td>5 mA ≤ I_OUT ≤ 1.0 A</td>
<td>0.6</td>
<td>1.2</td>
<td>mA</td>
</tr>
<tr>
<td></td>
<td>with load</td>
<td>5 mA ≤ I_OUT ≤ 1.0 A</td>
<td>0.5</td>
<td>1.0</td>
<td>mA</td>
</tr>
<tr>
<td>Output Noise Voltage</td>
<td>T_A = 25°C, 10 Hz ≤ f ≤ 100 kHz</td>
<td>8</td>
<td>40</td>
<td>μV/V/OUT</td>
<td></td>
</tr>
<tr>
<td>Ripple Rejection</td>
<td>f = 120 Hz, 15 V ≤ V_IN ≤ 25 V</td>
<td>61</td>
<td>71</td>
<td>dB</td>
<td></td>
</tr>
<tr>
<td>Dropout Voltage</td>
<td>I_OUT = 1.0 A, T_J = 25°C</td>
<td>2.0</td>
<td>2.5</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Output Resistance</td>
<td>T_J = 1 kHz</td>
<td>18</td>
<td>30</td>
<td>mΩ</td>
<td></td>
</tr>
<tr>
<td>Short Circuit Current</td>
<td>T_J = 25°C, V_IN = 25 V</td>
<td>0.75</td>
<td>1.2</td>
<td>A</td>
<td></td>
</tr>
<tr>
<td>Peak Output Current</td>
<td>T_J = 25°C</td>
<td>1.3</td>
<td>2.3</td>
<td>A</td>
<td></td>
</tr>
<tr>
<td>Average Temperature Coefficient of Output Voltage</td>
<td>I_OUT = 5 mA, -55°C ≤ T_J ≤ 150°C</td>
<td>0.4</td>
<td>1.4</td>
<td>mV/°C</td>
<td></td>
</tr>
</tbody>
</table>

**Figure 1.14** Electrical characteristics of the µA7812 voltage regulator.

### µA7912

**ELECTRICAL CHARACTERISTICS:** V_IN = -19 V, I_OUT = 500 mA, C_IN = 2 μF, C_OUT = 1 μF, -55°C ≤ T_J ≤ 150°C, unless otherwise specified.

<table>
<thead>
<tr>
<th>CHARACTERISTICS</th>
<th>CONDITIONS</th>
<th>MIN</th>
<th>TYP</th>
<th>MAX</th>
<th>UNITS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Output Voltage</td>
<td>T_J = 25°C</td>
<td>-11.5</td>
<td>-12.0</td>
<td>-12.5</td>
<td>V</td>
</tr>
<tr>
<td>Line Regulation</td>
<td>T_J = 25°C</td>
<td>-14.5 V ≤ V_IN ≤ -30 V</td>
<td>10</td>
<td>120</td>
<td>mV</td>
</tr>
<tr>
<td></td>
<td></td>
<td>-16 V ≤ V_IN ≤ -22 V</td>
<td>3.0</td>
<td>60</td>
<td>mV</td>
</tr>
<tr>
<td>Load Regulation</td>
<td>T_J = 25°C</td>
<td>250 mA ≤ I_OUT ≤ 750 mA</td>
<td>4.0</td>
<td>60</td>
<td>mV</td>
</tr>
<tr>
<td>Output Voltage</td>
<td>-15.5 V ≤ V_IN ≤ -27 V</td>
<td>11.4</td>
<td>-12.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Quiescent Current</td>
<td>T_J = 25°C</td>
<td>15 V ≤ V_IN ≤ 30 V</td>
<td>1.5</td>
<td>3.0</td>
<td>mA</td>
</tr>
<tr>
<td>Quiescent Current Change</td>
<td>with line</td>
<td>5 mA ≤ I_OUT ≤ 1.0 A</td>
<td>1.0</td>
<td>3.0</td>
<td>mA</td>
</tr>
<tr>
<td></td>
<td>with load</td>
<td>5 mA ≤ I_OUT ≤ 1.0 A</td>
<td>0.5</td>
<td>1.0</td>
<td>mA</td>
</tr>
<tr>
<td>Output Noise Voltage</td>
<td>T_A = 25°C, 10 Hz ≤ f ≤ 100 kHz</td>
<td>25</td>
<td>80</td>
<td>μV/V/OUT</td>
<td></td>
</tr>
<tr>
<td>Ripple Rejection</td>
<td>f = 120 Hz, -15 V ≤ V_IN ≤ -25 V</td>
<td>54</td>
<td>60</td>
<td>dB</td>
<td></td>
</tr>
<tr>
<td>Dropout Voltage</td>
<td>I_OUT = 1.0 A, T_J = 25°C</td>
<td>1.1</td>
<td>2.3</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Peak Output Current</td>
<td>T_J = 25°C</td>
<td>1.3</td>
<td>2.3</td>
<td>A</td>
<td></td>
</tr>
<tr>
<td>Average Temperature Coefficient of Output Voltage</td>
<td>I_OUT = 5 mA, -55°C ≤ T_J ≤ 150°C</td>
<td>0.3</td>
<td>1.2</td>
<td>mV/°C</td>
<td></td>
</tr>
<tr>
<td>Short Circuit Current</td>
<td>V_IN = -25 V, T_J = 25°C</td>
<td>0.3</td>
<td>1.2</td>
<td>A</td>
<td></td>
</tr>
</tbody>
</table>

**Figure 1.15** Electrical characteristics of the µA7912 voltage regulator.
Figure 1.16 A schematic diagram of the finished power supply for the ZAP computer.

Figure 1.17 Additional voltage regulator circuit diagrams to demonstrate how the 7800 series of regulators can be used.

a) A high-current voltage regulator using a 500 mA 78M05 three-terminal regulator.

b) A high-current short-circuit protected voltage regulator, an enhanced version of figure 1.17a.

c) Using a 7805 +5 V voltage regulator to produce a higher output voltage.

d) A dual ±12 V tracking voltage regulator.
LAYOUT IS IMPORTANT

Integrated circuit regulators employ wide-band transistors in their construction to optimize response. As a result, they must be properly compensated to ensure stable closed-loop operation. Their compensation can be upset by stray capacitance and line inductance of an improper layout. Circuit lead lengths should be held to a minimum, and external bypass capacitors in particular should be located as close as possible to the regulator control circuit.

Figure 1.18a illustrates a typical layout of the components of our supply, and figure 1.18b details the areas that can cause problems. Improper placement of the input capacitor can induce unwanted ripple on the output voltage. This occurs when the current flowing in the input circuit influences the common ground line of the regulator. The voltage drop produced across R2' will cause the output of the regulator to fluctuate in the same manner as the voltage trim circuit we discussed previously. The peak currents in the input circuit (which consists of the rectifier and filter capacitor) can be tens of amperes during charge cycles. These high-current spikes can cause substantial voltage drops on long-lead lengths or thin-wire connections. They can also degrade performance to the point that proper input voltage to the regulator cannot be maintained except during low-current operation.

The output current loop is also susceptible to circuit layout. In a three-terminal regulator, the fixed-output voltage $V_{OUT(REG)}$ is referenced between “out” and “common” of the chip. Because the load current flows through R2', R3', and R4', as well as the load itself, these combined voltage losses may reduce $V_{OUT}$ to an intolerable level. Notice that the ground for this circuit is at point C while the present R load is between points A and B. If another load, more memory for example, is connected to this supply between points A and C, it would have a different $V_{OUT}$. Adjusting the trim setting of such a seesaw supply can be dangerous; it’s possible to have one load completely within tolerance and another over or under voltage. One last point to consider is that R4' serves to negate the purpose of the regulator because it continually reduces $V_{OUT}$ as the load current increases.

![Diagram](image)

**Figure 1.18** A typical layout of the power supply components and associated problems.
a) A typical layout.
b) Errors contributed by the layout in figure 1.18a.
Figure 1.19 is the block diagram of a proper layout. All high-current paths should use heavy wire to minimize resistance and resultant voltage drops. You'll notice now that the input and output circuit current paths are separated effectively. Note that the wires from the rectifier go directly to the capacitor and that two wires from the capacitor send power to the rest of the circuit. If you follow this convention and use two separate pairs of leads, you can eliminate input-circuit induced errors.

Finally, we need to discuss the concept of the single-point ground. One point in the power supply must be designated as ground; the grounds of all other supplies and loads are connected to it. In practical terms, the best way to implement this ground connection is to use a metal strip or several lengths of heavy wire soldered together. The strip is a ground bus with such a low resistance that a voltage measured between point A and any place along the bus will be virtually undetectable. Another +5 V bus should be connected to the output of the supply so that voltage distribution throughout the circuit is consistent. Use thick wire in power supplies. Even if zero-resistance wire isn't easily obtainable, always remember—there is no such thing as wire that is too thick!

![Block Diagram](image)

**Figure 1.19** A block diagram of a proper layout for the power supply components.

**THERMAL CONSIDERATIONS**

You've just built the power supply I've outlined, flipped on the power, and everything works. After a few minutes, something happens and the computer suddenly stops running. Naturally, you start looking around and touching things. Eventually, your fingers will end up on the regulator chip. Immediately you scream, jump back, and in the process knock over the computer and your celebration martini. If you are lucky, your fingers will be the only thing burned!

When not properly cooled, the regulators will protect themselves from destruction by reducing their output or completely shutting off. In this case, the system could cease to function. A more catastrophic problem arises from ICs that use all three voltages for normal operation. Loss of one or more of these voltages could permanently damage the device. This will never happen if power dissipation is limited and the proper cooling methods are employed.

The first step is to check the power dissipation of our design with the ratings of the particular devices. In practical terms, power, expressed in watts, is volts times amperes:

\[ P_D = E \times I \]

In our 5 V regulator we have \( V_c = 10 \) V and \( V_{PEAK} = 12.5 \) V at 5 A.
\[ P_{D(NOM)} = (V_C - V_{OUT}) \times 5 \, A \]
\[ = (10 - 5) \times 5 \]
\[ = 25 \, W \]
\[ P_{D(PEAK)} = (V_{PEAK} - V_{OUT}) \times 5 \, A \]
\[ = (12.5 - 5) \times 5 \]
\[ = 37.5 \, W \]
\[ P_{D(AVERAGE)} = \frac{37.5 + 25}{2} = 31.25 \, W \]

This means that under full load conditions, about 30 W of heat will be produced by the 78H05. The device is fortunately rated for 50 W at 25°C and is still capable of handling 30 W up to 75°C.

Although the internal power dissipation is limited, the junction temperature must be kept below the maximum specified temperature (125°C) in order for the device to function at all. To calculate the heat sink required, there are specific equations to solve.

The required thermal data and calculations follow:

- Typical \( \theta_{JC} = 2.0 \)
- Maximum \( \theta_{JC} = 2.5 \)
- Typical \( \theta_{JA} = 32 \)
- Maximum \( \theta_{JA} = 38 \)

\[ P_{D(MAX)} = \frac{T_{J(MAX)} - T_A}{\theta_{JC} + \theta_{CA}} \quad \text{for} \quad \theta_{CA} = \theta_{CS} + \theta_{SA} \]

Solving for \( T_J \),

\[ T_J = T_A + P_D(\theta_{JC} + \theta_{CA}) \]

or without a heat sink,

\[ P_{D(MAX)} = \frac{T_{J(MAX)} - T_A}{\theta_{JA}} \]

\[ T_J = T_A + P_D\theta_{JA} \]

where
- \( T_J \) = junction temperature
- \( T_A \) = ambient temperature
- \( P_D \) = power dissipation
- \( \theta_{JC} \) = junction to case thermal resistance
- \( \theta_{JA} \) = junction to ambient thermal resistance
- \( \theta_{CA} \) = case to ambient thermal resistance
- \( \theta_{CS} \) = case to heat sink thermal resistance
- \( \theta_{SA} \) = heat sink to ambient thermal resistance

\[ \theta_{JA} = \frac{T_J - T_A}{P_D} = \frac{125°C - 25°C}{31.25 \, W} = 3.2°C/W \]

Because \( \theta_{JA} \) as calculated is less than \( \theta_{JA} \) from the specification sheet, a heat sink is definitely required, and a TO-3 type heat sink of 3.2°C/W is the minimum desired.

Before you size a heat sink for the 78H05, realize that there are two more regulators and two bridge rectifiers that will need heat sinking. Each 12 V regulator will average about 5 W dissipation. The diode bridge associated with the +5 V supply (remember the 2 V drop) dissipates about 10 W while the other is good for 2 W. Therefore, any heat sinks in the power supply must handle more than 50 W.

**WHAT IS THE PRACTICAL METHOD FOR CHOOSING HEAT SINKS?**

Choosing a heat sink can be easy or hard depending upon your outlook on rule of
thumb measures. We already know that we need a 50 W heat sink. It's easy to assume that buying one "rated for 50 W" from a local electronics supply will solve the problem. What this rating usually means, however, is that if 50 W is applied through a transistor to this sink, and the ambient temperature is 25°C, the surface temperature of the sink will climb to 100°C. Fried eggs anyone?

We must not forget that manufacturers' specs always refer to limiting maximum junction temperature, not to keeping the case cool enough to touch. Personally, I hate red-hot power supplies. To get a heat sink that would take our 50 W and stay about 60-70°C would probably mean getting one rated for 200-300 W! Remember that heat sinks are expensive—and big.

The simplest solution is best. I prefer forced air cooling. Put the 50 W on an economical heat sink of, say, a 100 W rating and put your money into a good fan. You can still run through all the calculations and determine how many square inches you need, but the effect of blowing a little air over a heat sink multiplies its capabilities enormously.

OVERVOLTAGE PROTECTION

The final area to be addressed in the power supply is overvoltage protection. As designed by manufacturers, regulators protect themselves by reducing output voltage or complete shut off. The chances of computer component damage from low voltage is miniscule by comparison to overvoltage. It is unlikely to happen, but if the 78H05 were to accidentally short out, as much as 12.5 V would be applied to the +5 V bus. You could then kiss the computer good-bye!

+5 volt OVP

| D1 | 5.6 V | 1N4734 |
| SCR1 | 50 V 25 A | 2N662 |
| Fuse | 6 amp | fast-blow |

12 volt OVP

| D1 | 13 V | 1N4743 |
| SCR1 | 50 V 8 A | 2N441 |
| Fuse | 1.5 amp | fast-blow |

The semiconductor components of this 12 volt OVP are reversed in polarity for the -12 volt OVP.

Figure 1.20 A simple overvoltage protection circuit.

The circuit of figure 1.20 is a simple OVP (over-voltage protector). It can be used as shown on the 5 V and 12 V supplies. The appropriate components are listed in the tables of figure 1.20. You'll notice that the fuses are rated higher than the output we've previously discussed. The fuse is for the OVP and not to protect the regulators. Unfortunately, the nature of fast-blow fuses is not to pass 5 A, if it is a 5 A fuse, but to open at 5 A. The fuse must have a higher rating in order to allow circuit operation at 5 A.
Figure 1.21 A schematic diagram of a more complex overvoltage protection circuit. The crowbar section of the OVP can be located next to the fuse while the OVP sensor $Z_1$ is located at the regulator output. This is a preferred placement of the parts if the sensor and clamp can be adequately separated. Low-current sensor $Z_1$ fires SCR1, in an overvoltage condition. SCR1, in turn fires high-current SCRb. The combination of SCRs allows considerable leeway in the choice of SCRb since the question of gate current becomes less relevant.

Because the short-circuit current of the 78H05 is 7 A, the 25 A silicon-controlled rectifier (SCR) will certainly make short work of the fuse if it triggers. Figures 1.21 and 1.22 are slightly more complex OVP circuits and can also be used.

Figure 1.22 Schematic diagrams of adjustable-voltage overvoltage protection circuits.

a) An adjustable-voltage OVP circuit with an internal current amplifier to drive the SCR gate.

b) An alternate circuit for a simple adjustable-voltage OVP circuit.
What does an OVP (often called an "overvoltage crowbar") do? It monitors a particular bus voltage and shuts it down if it goes above a predetermined level. OVP circuits can be designed to trigger 1 mV above our 5% tolerance band. Such circuits are not only complicated, but they may also create additional problems through accidental triggerings. The failure modes that are most likely to occur concern a regulator short or accidentally tying two buses together, for example the +5 V and +12 V. In either case, the result is a rapid voltage rise on the output lines. As voltage rises above the zener value, current flows into the SCR gate. At a certain point, usually below where any components would have been damaged, the SCR fires and shorts the output line to ground. The excessive current blows the fuse, eliminating the problem regulator or regulators (both fuses would blow if the +5 V and +12 V were connected). All this occurs very fast. The test circuit of figure 1.23 demonstrates what happens when the +5 V OVP suddenly has +12 V applied. Test circuits are the only way you ever want to see the action of an OVP. If your power supply functions properly, it should never trigger. The SCR never allows the line to go to 12 V before clamping it to ground. Replacing the fuse with a 220 ohm resistor allows multiple applications of the push button without replacing fuses.

![Diagram of an OVP circuit](image)

**Figure 1.23** A test circuit to demonstrate the action of the overvoltage protector.
CHAPTER 2
CENTRAL PROCESSOR
BASICS

There are many different microprocessors on the market and while instruction
nomenclature is somewhat different for each one, the basic logical computing processes
are similar in all devices. The rule to remember the next time a discussion turns to the
capabilities of two computers is that “a computer is a computer.” I don’t wish to imply
that they are all the same, but similarities abound and I would not like to spend a life-
time analyzing instruction sets and interfacing details before choosing one.

I once had lunch with the designer of one of the largest selling personal computer sys-
tems on the market. Thousands of computers had been sold, generating immense prof-
its for the manufacturer. Our conversation eventually centered on the cost-effectiveness
of his design. I had fanciful thoughts of a design team spending months reducing
component count and analyzing instruction sets to determine minimum memory re-
quirements. In actuality, my designer friend was given two months to come up with a
manufacturable design. The investors’ only question was the price and availability of
the particular components he had chosen. Being an avid personal computer enthusiast,
he simply built a computer around the microprocessor he already owned. The eventual
advertising for his system touted the advanced architecture embodied in the central
processor, but no machine-language programming facility was available to the user. It
had only a high-level language BASIC interpreter and was, from an engineering point
of view, simply a black-box computer. He could have used any microprocessor. So
much for textbook engineering design.

Unfortunately, the hobbyist who is building a microcomputer from scratch, and
who won’t be making a black box, has to try to pick a device that is somewhere in the
middle of the performance and capability spectrum. The general rule that all computers
perform similar functions is true, but a printed-circuit board is a luxury. The hobbyist
who has to do all the wiring by hand will surely be interested in efficient design. It’s a
fact that some of the more esoteric microprocessors require very expensive peripheral
circuitry. Even devices that seem quite straightforward, with limited instruction sets,
can require 50 or more ICs as interface elements. The ultimate configuration should be
a trade-off between circuit complexity, ease of testing, and component price.

MICROPROCESSOR ARCHITECTURE

The internal architecture of the microprocessor determines the support devices re-
quired to make a microcomputer system. Perhaps the best place to start is to briefly
discuss the major architectural differences.

Definition: A microcomputer is a logical machine that manipulates binary numbers
(data) and processes this information by following an organized sequence of program
steps referred to as instructions.

All microcomputers, like all computers, have the following features:

1. Input — Facilities must exist to allow the entrance of data or instructions.
2. Memory — The program sequence must be stored before and after execution, and
   resources must be available to store the result of any computations.
3. Arithmetic logic unit — Performs arithmetic operations on input or stored data.
4. **Control section** — Makes decisions regarding program flow and process control based on internal states of the results of arithmetic computations.

5. **Output** — The results are delivered to the user or stored in an appropriate medium.

The microprocessor is the single integrated circuit around which a microcomputer is constructed. *The microprocessor is a device; the microcomputer is a system.* In their least complex form, microprocessors include only the functions of items three and four and must rely on external devices attached to buses to perform the other tasks. Figure 2.1 is the basic block diagram of an 8-bit microcomputer and shows the interconnection of these buses and support elements. The computer in figure 2.1 uses six separate buses: memory address, memory data in and out, I/O address, and data input and output. The microprocessor contains a central processor that consists of the circuitry required to access the appropriate memory and I/O locations and interpret the resulting instructions that are also executed in this unit. The central processor also contains the ALU (Arithmetic and Logic Unit), which is a combination network that performs arithmetic and logical operations on the data. Additionally, the central processor includes a control section that governs the operations of the computer, and the various data registers used for manipulation and storage of data and instructions.

![Figure 2.1](image-url)  
*Figure 2.1 A basic block diagram of a microcomputer illustrating the data busing concept. Numbers in parentheses are the usual required quantity of physical wires to perform bus functions for an 8-bit microprocessor.*

Actually few microprocessors support six separate buses. The number of pins that would be required on the IC is out of the question. Instead, to reduce pinouts, component manufacturers often combine the data input and output buses and make them "bidirectional." During an output instruction, data flows from the microprocessor to the output device and vice versa during an input instruction. To further cut the number of pins required on the central processor, the memory address bus can also serve as the address bus for input and output devices. During input/output instructions, the address present on the address lines references a particular input/output device(s). The resulting reduced configuration is shown in figure 2.2.

The concept of two buses is easy to understand and, from a hardware point of view, easy to utilize. The buses are time and function multiplexed. That is, during memory operations, the bits on the address bus refer to a memory location, and data on the data bus represent the content of memory. The direction of the data flow (to or from the central processor) is controlled within the microprocessor. Activities with input/output devices are performed in a similar fashion. During those instructions, input or output data and device addresses occupy the buses.
Figure 2.2 A block diagram of a microcomputer utilizing multiplexed bi-directional busing techniques to reduce pinout.

The number of bus wires can be further reduced by combining both data and address on the same lines and time multiplexing the data transfer along them. Figure 2.3 illustrates this final configuration. This method requires additional circuit elements to demultiplex and store pertinent data. The additional external components necessary to use this architectural feature defeat its purpose and make its use inadvisable for the hobbyist. There are other microprocessors that are simpler to use.

Figure 2.3 A block diagram of a microcomputer utilizing a single multiplexed bi-directional bus for both memory and input/output functions.

When building rather than buying a personal computer, the following criteria must be carefully considered:

1. Circuit complexity — Keep components to a reasonable minimum. The more components in a design, the more likelihood of wiring errors and faulty devices.
2. Cost — While cost is important, it should not be the primary consideration. Any microprocessor function could be simulated by using small scale integrated logic; however, indirect costs resulting from using 200 chips to replace 3 or 4 LSI (large scale integration) devices would negate the value of using cheaper parts initially. On the other hand, in the semiconductor industry, density means dollars. The more functions a device can provide, and the fewer components necessary to ac-
complish these tasks, the higher the price. The level of integration incorporated in a homebrew computer should fit somewhere in the middle. The ZAP computer outlined in this book is a prime example of this philosophy. It uses a combination of cost-effective LSI (large scale integration) and inexpensive SSI (small scale integration) to produce a computer that the hobbyist can truly build, test, and use.

3. **Software compatibility and availability** — Building the hardware of a microcomputer is only half the job. It must be programmed to perform useful work. Initially, the builder will by necessity hand code and assemble his own programs. Eventually, however, the need may arise for the computer to do a task requiring a very large program which cannot be easily hand assembled. The user must rely upon an assembler program in a larger machine. The assembler program would, of course, have to be compatible with the instruction set of the microcomputer.

A further consideration is that personal computer enthusiasts are forever exchanging software. It is possible to convert programs to run on any central processor, but the effort would be the same as writing the entire program from scratch. This defeats the purpose of exchanging software. The personal computer owner should choose a microprocessor that is somewhat compatible with the computers already on the market. My statement that all computers are alike is theoretically true, but a book on how to build an esoteric one-of-a-kind computer is of little practical value.

Each criterion could be analyzed and answered individually, but we must give some credit to the manufacturers of personal computers for doing some of the thinking for us already. The fact that so many personal computers are in use has established *de facto* standardization of central processor choice. To be compatible with existing software and to have sufficient documentation available, the builder should consider choosing among those central processors in commercial use. The four most used microprocessors are

1. Intel 8080A
2. Motorola 6800
3. MOS Technology 6502
4. Zilog Z80

As a result of each device's wide following, documentation and software are readily available. The availability of 8080A compatible software is highest; cost is low, but its circuit complexity is also the greatest of the above. The 8080A, while described as a "single-chip computer," relies on various external drivers and support devices. Its minimum functional configuration consists of three chips as shown in figure 2.4. Its central processor bus structure is similar to figure 2.3, but when combined with the 8224 and 8228 support chips, it emulates the more desirable bus architecture outlined in figure 2.2.

![Figure 2.4](image-url) *Figure 2.4 A minimum three-chip 8080A configuration illustrating the necessary support devices. The control bus contains the timing functions necessary to decode the contents of the data and address buses.*

24 CENTRAL PROCESSOR BASICS
The best of both worlds is incorporated within the Z80. Not only does it execute the complete instruction set of the 8080A, but it also has additional instructions that serve to make it a very powerful processor. The Z80 bus structure is illustrated in figure 2.5. The Z80 is slightly more expensive than the other processors listed. However, its reduced external circuitry results in an effective cost comparison. Further, the ease of interfacing the Z80 makes it the natural choice when building a microcomputer from scratch.

![Figure 2.5 A block diagram of the Zilog Z80 bus structure.](image-url)
CHAPTER 3
THE Z80
MICROPROCESSOR

Many books have been written on the software and hardware attributes of the Z80. Although I am not attempting to duplicate the efforts of other authors, any book dedicated to the construction of a microcomputer would be incomplete without a section describing the processor in some detail. By completely understanding the internal logic and external control functions of the central processor, you will be able to understand better the way I've designed the rest of the system hardware. You have many options when constructing a computer from scratch. The deeper your degree of understanding, the greater your confidence in the outcome, and it is more likely that you will add enhancements to your own design.

The ZAP computer allows considerable latitude in the selection of peripheral interfacing. The choice depends primarily upon the design philosophy of the system, which starts with the central processor.

CENTRAL PROCESSOR ARCHITECTURE

The Z80 is a register-oriented microprocessor. Eighteen 8-bit and four 16-bit registers within the central processor are accessible to the programmer and function as static programmable memory. These registers are divided into two sets, main and alternate, each of which contains six general purpose 8-bit registers that may be used either individually, or as three pairs of 16-bit registers. Also included are two sets of accumulators and flag registers. Figure 3.1 illustrates the internal architecture of the Z80 central processor. Figure 3.2 shows that within the Z80 there are accumulators and flag registers, along with general and special purpose registers.

![Z80 CPU Block Diagram](image)

Figure 3.1 A block diagram of the internal architecture of the Z80 central processor.
Figure 3.2 Z80 central processor register configuration.

The following is a description of the function and structure of the major components of the central processor.

I. Registers
   A. Accumulators and Flag Registers
      The central processor contains two independent accumulator and flag-register pairs, one in the main register set and the other in the alternate register set. The accumulator receives the results of all 8-bit arithmetic and logical operations, whereas the flag register indicates the occurrence of specific logical or arithmetic conditions in the processor such as parity, zero, sign, carry, and overflow. A single exchange instruction allows the programmer to select either accumulator or flag-register pair.

   B. General Purpose Registers
      There are two similar sets of general purpose registers. The main register set contains six 8-bit registers called B, C, D, E, H, and L; the alternate register set also contains six 8-bit registers referred to as B', C', D', E', H', and L'. For 16-bit operations, these registers can be grouped in 16-bit pairs (BC, DE, HL or BC', DE', HL'). A single exchange instruction allows the programmer to alternately choose between the register-pair sets.

   C. Special Purpose Registers
      1. PC (program counter)
         The program counter contains a 16-bit address in memory from which the current instruction will be fetched. Following execution of the instruction, the PC counter is either incremented, if the program is to proceed to the next byte in memory, or the present PC contents are replaced with a new value, if a jump or call instruction is to be executed.

      2. SP (stack pointer)
         The Z80 allows several levels of subroutine nesting through use of a "stack" and a "stack pointer"; when certain instructions are executed, or when calls to subroutines are made, the PC counter and other pertinent data can be temporarily stored on a stack. A stack is a reserved area of several memory locations, the top of which is indicated by the contents of the stack pointer. That is to say, the stack pointer shows the address of the most recently made entry, because the memory locations are organized as a last-in, first-out file. By looking at particular entries in the stack,
the central processor returns to a main program regardless of the depth of nested subroutines. Theoretically, the stack could be 64 K bytes long; however, program space must not be overwritten by an expanding stack.

D. IX and IY Index Registers

These registers facilitate table data manipulation. They are two independent 16-bit registers that hold the base addresses used in indexed addressing modes, and point to locations in memory where pertinent data is to be stored or retrieved. Incorporated within the indexed instructions is a two's complement signed integer that specifies displacement from this base address.

E. Interrupt Page Address Register (I)

This is an 8-bit register that can be loaded with a page address of an interrupt service routine. During a mode 2 interrupt program, control will vector to this page address.

F. Memory Refresh Register (R)

To enable dynamic memories for the Z80, a 7-bit memory refresh register is automatically incremented after each instruction fetch.

II. Arithmetic and Logic Unit

Arithmetic manipulations and logical operations are handled eight bits at a time in the Z80 ALU (arithmetic and logic unit). The ALU communicates internally to the central processor registers and is not directly accessible by the programmer. The ALU performs the following operations:

LEFT or RIGHT SHIFT
INCREMENT
DECREMENT
ADD
SUBTRACT
AND
OR
EXCLUSIVE OR
COMPARE
SET BIT
RESET BIT
TEST BIT

III. Instruction Register and Central Processor Control

The instruction register holds the contents of the memory location addressed by the PC (program counter) and is loaded during the fetch cycle of each instruction. The central processor control unit executes the functions defined by the instruction in the instruction register and generates all control signals necessary to transmit the results to the proper registers.

IV. Central Processor Hardware

A. Figure 3.3 details the pinout of the Z80. It comes in an industry standard 40 pin dual in-line package. The following is a listing and explanation of the pin functions:

\( A_0 - A_{15} \) (Address Bus)

Three-state output, active high. \( A_0 - A_{15} \) constitute a 16-bit address bus. These signals provide the address for memory data exchanges (up to 64 K bytes) and for I/O device data exchanges. I/O addressing uses the eight lower address bits to allow the user to directly select up to 256 input or 256 output ports. \( A_0 \) is the least significant address bit. During refresh time, the lower seven bits contain a valid refresh address.

\( D_0 - D_7 \) (Data Bus)

Three-state input/output, active high. \( D_0 - D_7 \) constitute an 8-bit bi-directional data bus which is used for data exchanges with memory and I/O devices.

\( M \) (Machine)

Output, active low. \( M \) indicates that the current machine cycle is the operation-code fetch cycle of an in-
Cycle One) Instruction execution. Note that during execution of 2-byte opcodes, \( M_T \) is generated as each opcode byte is fetched. These 2-byte opcodes always begin with \( CBH, DDH, EDH, \) or \( FDH. \( M_T \) also occurs with \( IORQ \) to indicate an interrupt acknowledge cycle.

**MREQ**
(Memory Request)

Three-state output, active low. The memory request signal indicates that the address bus holds a valid address for a memory-read or memory-write operation.

**IORQ**
(Input/Output Request)

Three-state output, active low. The \( IORQ \) signal indicates that the lower half of the address bus holds a valid I/O address for an I/O read or write operation. An \( IORQ \) signal is also generated with an \( M_T \) signal when an interrupt is being acknowledged to indicate that an interrupt response vector can be placed on the data bus. Interrupt acknowledge operations may occur during \( M_T \) time while I/O operations are prohibited.

**RD**
(Memory Read)

Three-state output, active low. \( RD \) indicates that the central processor wants to read from memory or an I/O device. The addressed I/O device or memory should use this signal to gate data onto the central processor data bus.

**WR**
(Memory Write)

Three-state output, active low. \( WR \) indicates that the central processor data bus holds valid data to be stored in the addressed memory or I/O device.

**RFSH**
(Refresh)

Output, active low. \( RFSH \) indicates that the lower seven bits of the address bus contain a refresh address for dynamic memories and the current \( MREQ \) signal should be used to do a refresh read to all dynamic memories.

**HALT**
(Halt State)

Output, active low. \( HALT \) indicates that the central processor has executed a \( HALT \) instruction and is awaiting either a nonmaskable or a maskable interrupt (with the mask enabled) before operation can resume. While halted, the central processor executes NOPs (no operation) to maintain memory refresh activity.

**WAIT**
(Wait)

Input, active low. \( WAIT \) indicates to the Z80 central processor that the addressed memory or I/O devices are not ready for a data transfer. The central processor continues to enter wait states as long as \( WAIT \) is active; this signal allows memory of I/O devices to be synchronized to the central processor.

**INT**
(Interrupt)

Input, active low. The Interrupt request signal is generated by I/O devices. A request will be honored at the end of the current instruction if the internal software controlled interrupt enable flip-flop is enabled and if the \( BUSRQ \) signal is not active. When the central processor accepts the interrupt, an acknowledge signal (\( IORQ \) during \( M_T \) time) is sent out at the beginning of the next instruction cycle. The central processor can respond to an interrupt in the three different modes.

**NMI**
(Non-Maskable)

Input, negative edge triggered. The nonmaskable interrupt request line has a higher priority than \( INT \) and is always recognized at the end of the current instruction,
Interrupt) regardless of the status of the interrupt-enable flip-flop. NMI forces the Z80 central processor to restart to location 006616. The program counter is automatically saved in the external stack so that the user can return to the program that was interrupted. Note that continuous WAIT cycles can prevent the current instruction from ending, and that a BUSRQ will override an NMI.

![Diagram](image)

**Figure 3.3** Pin configuration for the Z80 microprocessor.

The actual timing of these signals will be discussed in the hardware sections.

V. Z80 Instruction Types
The Z80 can execute 158 separate instructions including all 78 of the 8080A. They can be grouped as follows:

A. LOAD AND EXCHANGE
Load instructions move data between registers or between registers and memory. The source and destination of this data is specified within the instruction. Exchange instructions swap the contents of two registers.

B. ARITHMETIC AND LOGICAL
These instructions operate on data in the accumulator, a register, or a designated memory location. Results are placed in the accumulator and flags are set accordingly. Arithmetic operations include 16-bit addition and subtraction between register pairs.

C. BLOCK TRANSFER AND SEARCH
The Z80 uses a single instruction to transfer any size block of memory to any other group of contiguous memory locations. The block search uses a single command to examine a block of memory for a particular 8-bit character.

D. ROTATE AND SHIFT
Data can be rotated and shifted in the accumulator, a central processor register, or memory. These instructions also have binary-coded
decimal (BCD) handling facilities.

E. BIT MANIPULATION
   Bit manipulation includes set, reset, and test functions. Individual bits
   may be modified or tested in the accumulator, a central processor, or
   memory. The results of the test operations are indicated in the flag
   register.

F. JUMP, CALL AND RETURN
   A jump is a branch to a program location specified by the contents of
   the program counter. The program counter contents can come from
   three addressing modes: immediate, extended, or register indirect. A
   call is a special form of jump where the address following the call in-
   struction is pushed onto the stack before the jump is made. A return is
   the reverse of the call. This category includes special restart instruc-
   tions.

G. INPUT AND OUTPUT
   These instructions transfer data between register and memory to ex-
   ternal I/O devices. There are 256 input and 256 output ports avail-
   able. Special instructions provide for moving blocks of 256 bytes to or
   from I/O ports and memory.

H. CPU CONTROL
   These instructions include halting the CPU or causing a NOP (no
   operation) to be executed. The ability to enable or disable interrupt in-
   puts is a further control capability.

VI. Instruction and Data Formats
   Memory for the Z80 is organized into 8-bit quantities called bytes (see figure
   3.4). Each program byte is stored in a unique memory position and is referenced
   by a 16-bit binary address.

   Total direct addressing capability is 65,536 bytes (64 K) of memory, which
   may be any combination of ROM (read-only memory), EPROM (erasable-pro-
   grammable read-only memory), or programmable memory. Data is stored in
   the formats of figure 3.5.

![Figure 3.4 Organization of a data byte in the Z80.](image)

![Figure 3.5 Machine-language instruction formats for the Z80.](image)
VII. Z80 Status Flags
The flag register (F and F') supplies information to the user regarding the status of the central processor at any given time. There are four testable and two nontestable flag bits in each register. Figure 3.6 shows the position and identity of these flag bits.

![Flag register diagram]

**Figure 3.6** Position and identity of status flag bits in the flag register.

Instructions set (flag bit = 1) or reset (flag bit = 0) flags in a manner relevant to the particular operation being executed.

VIII. The Z80 Instruction Set
The following symbols and abbreviations are used in the subsequent description of the Z80 instructions:

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>accumulator</td>
<td>Register A</td>
</tr>
<tr>
<td>address</td>
<td>A 16-bit address quantity</td>
</tr>
<tr>
<td>high-order address</td>
<td>The most significant 8 bits of the 16-bit address</td>
</tr>
<tr>
<td>low-order address</td>
<td>The least significant 8 bits of the 16-bit address</td>
</tr>
<tr>
<td>data</td>
<td>An 8- or 16-bit quantity</td>
</tr>
<tr>
<td>high-order data</td>
<td>The most significant 8 bits of the 16-bit data</td>
</tr>
<tr>
<td>low-order data</td>
<td>The least significant 8 bits of the 16-bit data</td>
</tr>
<tr>
<td>port</td>
<td>An 8-bit address of an I/O device</td>
</tr>
<tr>
<td>r, r'</td>
<td>One of the registers A, B, C, D, E, H, or L</td>
</tr>
<tr>
<td>n</td>
<td>A 1-byte expression in the range of 0 thru 255</td>
</tr>
<tr>
<td>nn</td>
<td>A 2-byte expression in the range of 0 thru 65,535</td>
</tr>
<tr>
<td>d</td>
<td>A 1-byte expression in the range of -128 to 127</td>
</tr>
<tr>
<td>b</td>
<td>An expression in the range of 0 thru 7</td>
</tr>
<tr>
<td>e</td>
<td>A 1-byte expression in a range of -126 to 129</td>
</tr>
<tr>
<td>cc</td>
<td>The state of the flags for conditional JR and JP instructions:</td>
</tr>
<tr>
<td></td>
<td>Condition</td>
</tr>
<tr>
<td>000</td>
<td>NZ non zero</td>
</tr>
<tr>
<td>001</td>
<td>Z zero</td>
</tr>
<tr>
<td>010</td>
<td>NC non carry</td>
</tr>
<tr>
<td>011</td>
<td>C carry</td>
</tr>
<tr>
<td>100</td>
<td>PO parity odd</td>
</tr>
<tr>
<td>101</td>
<td>PE parity even</td>
</tr>
<tr>
<td>110</td>
<td>P sign positive</td>
</tr>
<tr>
<td>111</td>
<td>M sign negative</td>
</tr>
<tr>
<td>XXH</td>
<td>Denotes hexadecimal address value</td>
</tr>
<tr>
<td>qq</td>
<td>Any one of the register pairs BC, DE, HL, or AF</td>
</tr>
<tr>
<td>ss</td>
<td>Any one of the register pairs BC, DE, HL, or SP</td>
</tr>
</tbody>
</table>

*The Z80 MICROPROCESSOR 33*
pp  Any one of the register pairs BC, DE, IX, or SP
rr  Any one of the register pairs BC, DE, IY, or SP
s   Any of r, n, (HL), (IX+d), or (IY+d)
dd  Any one of the register pairs BC, DE, HL, or SP
m   Any of r, (HL), (IX+d), or (IY+d)
(HL) Specifies the contents of memory at the location addressed
      by the contents of the register pair HL
(nn) Specifies the contents of memory at the location addressed
      by the 2-byte expression in nn
PC  Program counter
SP  Stack pointer
 t  An expression in the range of 0 thru 7.
C,N,P/V,H,Z,S Condition flags:
   C  Carry
   N  Add/Subtract
   P/V Parity/Overflow
   H  Half-Carry
   Z  Zero
   S  Sign

-    "is transferred to"
^    Logical AND
@    Exclusive OR
\    Inclusive OR
+    Addition
-    Subtraction
\=   "is exchanged with"

EIGHT-BIT LOAD GROUP

LD r, r'
    r ← r'
    The contents of any register r' are loaded into any other register r.

| Cycles: 1 |
| States: 4 |
| Flags: none |

LD r, n
    r ← n
    The 8-bit integer n is loaded into any register r.

| Cycles: 2 |
| States: 7 |
| Flags: none |

LD r, (HL)
    r ← (HL)
    The 8-bit contents of memory location (HL) are loaded into register r.

| Cycles: 1 |
| States: 4 |
| Flags: none |
Cycles: 2
States: 7
Flags: none

LD r, (IX+d)
r ← (IX+d)
The operand (IX+d) (the contents of the Index Register IX summed with a displacement integer d) is loaded into register r.

Cycles: 5
States: 19
Flags: none

LD r, (IY+d)
r ← (IY+d)
The operand (IY+d) (the contents of the Index Register IY summed with a displacement integer d) is loaded into register r.

Cycles: 5
States: 19
Flags: none

LD (HL), r
(HL) ← r
The contents of register r are loaded into the memory location specified by the contents of the HL register pair.

Cycles: 2
States: 7
Flags: none

LD (IX+d), r
(IX+d) ← r
The contents of register r are loaded into the memory address specified by the contents of Index Register IX summed with d, which is a two's complement displacement integer.

Cycles: 5
States: 19
Flags: none
LD (IY+d), r
(IY+d) — r
The contents of register r are loaded into the memory address specified by the
sum of the contents of the Index Register IY and d, a two’s complement
displacement integer.

Cycles: 5
States: 19
Flags: none

LD (HL), n
(HL) — n
Integer n is loaded into the memory address specified by the contents of the
HL register pair.

Cycles: 3
States: 10
Flags: none

LD (IX+d), n
(IX+d) — n
The n operand is loaded into the memory address specified by the sum of the
contents of the Index Register IX and the two’s complement displacement
operand d.

Cycles: 5
States: 19
Flags: none

LD (IY+d), n
(IY+d) — n
Integer n is loaded into the memory location specified by the contents of the
Index Register IY summed with a displacement integer d.

Cycles: 5
States: 19
Flags: none
LD A, (BC)
A ← (BC)
The contents of the memory location specified by the contents of the BC register pair are loaded into the Accumulator.

Cycles: 2
States: 7
Flags: none

LD A, (DE)
A ← (DE)
The contents of the memory location specified by the register pair DE are loaded into the Accumulator.

Cycles: 2
States: 7
Flags: none

LD A, (nn)
A ← (nn)
The contents of the memory location specified by the operands nn are loaded into the Accumulator. The first n operand is the low-order byte of a 2-byte memory address.

Cycles: 4
States: 13
Flags: none

LD (BC), A
(BC) ← A
The contents of the Accumulator are loaded into the memory location specified by the contents of the register pair BC.

Cycles: 2
States: 7
Flags: none

LD (DE), A
(DE) ← A
The contents of the Accumulator are loaded into the memory location specified by the DE register pair.

Cycles: 2
States: 7
Flags: none
LD (nn), A
(nn) — A
The contents of the Accumulator are loaded into the memory address
specified by the operands nn. The first n operand is the low-order byte of
operand nn.

Cycles: 4
States: 13
Flags: none

LD A, I
A — I
The contents of the Interrupt Vector Register I are loaded into the
Accumulator.

Cycles: 2
States: 9
Flags: S, Z, H, N, P/V
S: set if I < 0; reset otherwise
Z: set if I=0; reset otherwise
H, N: reset
P/V: contains contents of IFF2

LD A, R
A — R
The contents of Memory Refresh Register R are loaded into the Accumulator.

Cycles: 2
States: 9
Flags: S, Z, H, N, P/V
S: set if R < 0; reset otherwise
Z: set if R=0; reset otherwise
H, N: reset
P/V: contains contents of IFF2

LD I, A
I — A
The contents of the Accumulator are loaded into the Interrupt Control Vec-
tor Register I.

Cycles: 2
States: 9
Flags: none
LD R, A
R — A
The contents of the Accumulator are loaded into the Memory Refresh Register R.

Cycles: 2
States: 9
Flags: none

SIXTEEN-BIT LOAD INSTRUCTIONS

LD dd, nn
dd — nn
The 2-byte integer nn is loaded into the dd register pair, where dd defines the BC, DE, HL, or SP register pairs, assembled as follows in the object code:

<table>
<thead>
<tr>
<th>Pair</th>
<th>dd</th>
</tr>
</thead>
<tbody>
<tr>
<td>BC</td>
<td>00</td>
</tr>
<tr>
<td>DE</td>
<td>01</td>
</tr>
<tr>
<td>HL</td>
<td>10</td>
</tr>
<tr>
<td>SP</td>
<td>11</td>
</tr>
</tbody>
</table>

Cycles: 3
States: 10
Flags: none

LD IX, nn
IX — nn
Integer nn is loaded into the Index Register IX.

Cycles: 4
States: 14
Flags: none

LD IY, nn
IY — nn
Integer nn is loaded into the Index Register IY.

Cycles: 4
States: 14
Flags: none
LD HL, (nn)
\[ H \rightarrow (nn+1), \ L \rightarrow (nn) \]
The contents of memory address nn are loaded into register L, and the contents of the next highest memory location (nn+1) are loaded into register H.

Cycles: 5
States: 16
Flags: none

LD dd, (nn)
\[ dd_H \rightarrow (nn+1), \ dd_L \rightarrow (nn) \]
The contents of address nn are loaded into the low-order portion of register pair dd, and the contents of the next highest memory address (nn+1) are loaded into the high portion of dd.

Cycles: 6
States: 20
Flags: none

LD IX, (nn)
\[ IX_H \rightarrow (nn+1), \ IX_L \rightarrow (nn) \]
The contents of the address nn are loaded into the low-order portion of Index Register IX, and the contents of the next highest memory address (nn+1) are loaded into the high-order portion of IX.

Cycles: 6
States: 20
Flags: none

LD IY, (nn)
\[ IY_H \rightarrow (nn+1), \ IY_L \rightarrow (nn) \]
The contents of address nn are loaded into the low-order portion of Index Register IY, and the contents of the next highest memory address (nn+1) are loaded into the high-order portion of IY.
LD (nn), HL
(nn+1) ← H, (nn) ← L
The contents of register L are loaded into memory address nn, and the contents of register H are loaded into the next highest address location nn+1.

LD (nn), dd
(nn+1) ← dd₆₈, (nn) ← dd₄₈
The low-order byte of register pair dd is loaded into memory address nn; the upper byte is loaded into memory address nn+1.

LD (nn), IX
(nn+1) ← IX₆₈, (nn) ← IX₄₈
The low-order byte in Index Register IX is loaded into memory address nn; the upper-order byte is loaded into the next highest address nn+1.

LD (nn), IY
(nn+1) ← IY₆₈, (nn) ← IY₄₈
The low-order byte in Index Register IY is loaded into memory address nn; the upper-order byte is loaded into memory location nn+1.
LD SP, HL
SP ← HL
The contents of the register pair HL are loaded into the SP (stack pointer).

Cycles: 6
States: 20
Flags: none

LD SP, IX
SP ← IX
The 2-byte contents of Index Register IX are loaded into the SP (stack pointer).

Cycles: 2
States: 10
Flags: none

LD SP, IY
SP ← IY
The 2-byte contents of Index Register IY are loaded into the SP (stack pointer).

Cycles: 2
States: 10
Flags: none

PUSH qq
(SP − 2) ← qH, (SP − 1) ← qL
The contents of the register pair qq are pushed into the external memory LIFO (last-in, first-out) Stack. The Stack Pointer (SP) register pair holds the 16-bit address of the current "top" of the Stack. This instruction first decrements the SP and loads the high order byte of register pair qq into the memory address now specified by the SP; then decrements the SP again and loads the low order byte of qq into the memory location corresponding to this new address in the SP.

Cycles: 3
States: 11
Flags: none
PUSH IX
(SP - 2) → IX_L, (SP - 1) → IX_H
The contents of the Index Register IX are pushed into the Stack. This instruction first decrements the SP and loads the high-order byte of IX into the memory address now specified by the SP; it then decrements the SP again and loads the low-order byte into the memory location corresponding to this new address in the SP.

Cycles: 3
States: 15
Flags: none

PUSH IY
(SP - 2) → IY_L, (SP - 1) → IY_H
The contents of the Index Register IY are pushed into the Stack. This instruction first decrements the SP and loads the high-order byte of IY into the memory address now specified by the SP; it then decrements the SP again and loads the low-order byte into the memory location corresponding to this new address in the SP.

Cycles: 4
States: 15
Flags: none

POP qq
qq_H ← (SP + 1), qq_L ← (SP)
The top 2 bytes of the Stack are popped into register pair qq. This instruction first loads into the low-order portion of qq the byte at the memory location corresponding to the contents of SP; then SP is incremented and the contents of the corresponding adjacent memory location are loaded into the high-order portion of qq, and the SP is now incremented again.

Cycles: 3
States: 10
Flags: none

POP IX
IX_H ← (SP + 1), IX_L ← (SP)
The top 2 bytes of the Stack are popped into Index Register IX. This instruction first loads into the low-order portion of IX the byte at the memory location corresponding to the contents of SP; the SP is incremented and the contents of the corresponding adjacent memory location are loaded into the high-order portion of IX. The SP is now incremented again.

Cycles: 4
States: 14
Flags: none
**POP IY**

$IY_H \leftarrow (SP+1)$, $IY_L \leftarrow (SP)$

The top 2 bytes of the stack are popped into index register IY. This instruction first loads into the low-order portion of IY the byte at the memory location corresponding to the contents of SP; then the SP is incremented and the contents of the corresponding adjacent memory location are loaded into the high-order portion of IY. The SP is now incremented again.

Cycles: 4
States: 14
Flags: none

---

**EXCHANGE, BLOCK TRANSFER AND SEARCH GROUP**

**EX DE, HL**

$DE \leftarrow HL$

The 2-byte contents of register pairs DE and HL are exchanged.

Cycles: 1
States: 4
Flags: none

---

**EX AF, AF'**

$AF \leftarrow AF'$

The 2-byte contents of the register pairs AF and AF' are exchanged.

Cycles: 1
States: 4
Flags: none

---

**EXX**

$(BC) \leftarrow (BC')$, $(DE) \leftarrow (DE')$, $(HL) \leftarrow (HL')$

Each 2-byte value in register pairs BC, DE, and HL is exchanged with the 2-byte value in BC', DE', and HL' respectively.

Cycles: 1
States: 4
Flags: none
EX (SP), HL
H ← (SP+1), L ← (SP)
The low-order byte contained in register pair HL is exchanged with the contents of the memory address specified by the contents of register pair SP, and the high-order byte of HL is exchanged with the next highest memory address (SP+1).

Cycles: 5
States: 19
Flags: none

EX (SP), IX
IXH ← (SP+1), IXL ← (SP)
The low-order byte in the Index Register IX is exchanged with the contents of the memory address specified by the contents of register pair SP, and the high-order byte of IX is exchanged with the next highest address (SP+1).

Cycles: 6
States: 23
Flags: none

EX (SP), IY
IYH ← (SP+1), IYL ← (SP)
The low-order byte in Index Register IY is exchanged with the contents of the memory address specified by the contents of register pair SP, and the high-order byte of IY is exchanged with the next highest memory address.

Cycles: 6
States: 23
Flags: none

LDI
(DE) ← (HL), DE ← DE+1, HL ← HL+1, BC ← BC−1
A byte of data is transferred from the memory location addressed by the contents of the HL register pair to the memory location addressed by the contents of the DE register pair. Then both register pairs are incremented and the BC (byte counter) register pair is decremented.

Cycles: 4
States: 16
Flags: H, N, P/V
H, N: reset
P/V: set if BC−1 ≠ 0; reset otherwise
LDIR

(DE) ← (HL), DE ← DE + 1, HL ← HL + 1, BC ← BC - 1
This 2-byte instruction transfers a byte of data from the memory location addressed by the contents of the HL register pair to the memory location addressed by the DE register pair. Then, both register pairs are incremented and the BC (byte counter) register pair is decremented. If decrementing causes the BC to go to 0, the instruction is terminated. If BC is not 0, the program counter is decremented by 2 and the instruction is repeated. Note: if BC is set to 0 prior to instruction execution, the instruction will loop through 64 K bytes. Also, interrupts will be recognized after each data transfer.

```
1 1 1 1 1 1 1 1
1 0 1 1 1 1 0 1
```

For BC ≠ 0:
Cycles: 5
States: 21

For BC = 0:
Cycles: 4
States: 16
Flags: H, N, P/V: reset

LDD

(DE) ← (HL), DE ← DE - 1, HL ← HL - 1, BC ← BC - 1
This 2-byte instruction transfers a byte of data from the memory location addressed by the contents of the HL register pair to the memory location addressed by the contents of the DE register pair. Then both register pairs including the BC (byte counter) register pair are decremented.

```
1 1 1 1 1 1 1 1
1 0 1 0 1 0 1 0
```

Cycles: 4
States: 16
Flags: H, N, P/V
H, N: reset
P/V: set if BC - 1 ≠ 0; reset otherwise

LDDR

(DE) ← (HL), DE ← DE - 1, HL ← HL - 1, BC ← BC - 1
This 2-byte instruction transfers a byte of data from the memory location addressed by the contents of the HL register pair to the memory location addressed by the contents of the DE register pair. Then both registers, as well as the BC (byte counter), are decremented. If decrementing causes the BC to go to 0, the instruction is terminated. If BC is not 0, the program counter is decremented by 2 and the instruction is repeated. Note: if BC is set to 0 prior to instruction execution, the instruction will loop through 64 K bytes. Also, interrupts will be recognized after each data transfer.
CPI

A − (HL), HL ← HL + 1, BC ← BC − 1
The contents of the memory location addressed by the HL register pair are compared with the contents of the Accumulator. In case of a true compare, a condition bit is set. Then HL is incremented and the byte counter (register pair BC) is decremented.

CPIR

A − (HL), HL ← HL + 1, BC ← BC − 1
The contents of the memory location addressed by the HL register pair are compared with the contents of the Accumulator. In case of a true compare, a condition bit is set. The HL is incremented and the BC is decremented. If decrementing causes the BC to go to 0 or if A = (HL), the instruction is terminated. If BC is not 0 and if A ≠ (HL), the program counter is decremented by two, and the instruction is repeated. Note: if BC is set to 0 before instruction execution, the instruction will loop through 64 K bytes, if no match is found. Also, interrupts will be recognized after each data comparison.
States: 16
Flags: $S, Z, H, N, P/V$

$S$: set if result is negative; reset otherwise
$Z$: set if $A=(HL)$; reset otherwise
$H$: set if no borrow from bit 4; reset otherwise
$N$: set
$P/V$: set if $BC-1\neq 0$; reset otherwise

**CPD**

$A-(HL)$, $HL-HL-1$, $BC-BC-1$

The contents of the memory location addressed by the $HL$ register pair are compared with the contents of the Accumulator. In case of a true compare a condition bit is set. The $HL$ and the $BC$ are decremented.

Cycles: 4
States: 16
Flags: $S, Z, H, N, P/V$

$S$: set if result is negative; reset otherwise
$Z$: set if $A=(HL)$; reset otherwise
$H$: set if no borrow from bit 4; reset otherwise
$N$: set
$P/V$: set if $BC-1\neq 0$; reset otherwise

**CPDR**

$A-(HL)$, $HL-HL-1$, $BC-BC-1$

The contents of the memory location addressed by the $HL$ register pair are compared with the contents of the Accumulator. In case of a true compare a condition bit is set. The $HL$ and $BC$ register pairs are decremented. If decrementing causes the $BC$ to go to 0 or if $A=(HL)$, the instruction is terminated. If $BC$ is not 0 and $A\neq (HL)$, the program counter is decremented by 2 and the instruction is repeated. Note: if $BC$ is set to 0 prior to instruction execution, the instruction will loop through 64 K bytes if no match is found. Also, interrupts will be recognized after each data comparison.

Cycles: 5
States: 21

For $BC\neq 0$ and $A\neq (HL)$:

For $BC=0$ or $A=(HL)$:

Cycles: 4
States: 16
Flags: $S, Z, H, N, P/V$

$S$: set if result is negative; reset otherwise
$Z$: set if $A=(HL)$; reset otherwise
$H$: set if no borrow from bit 4; reset otherwise
$N$: set
$P/V$: set if $BC-1\neq 0$; reset otherwise
EIGHT-BIT ARITHMETIC AND LOGICAL GROUP

ADD A, r
A ← A+r
The contents of register r are added to the contents of the Accumulator, and the result is stored in the Accumulator.

Cycles: 1
States: 4
Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set if carry from bit 3; reset otherwise
N: reset
C: set if carry from bit 7; reset otherwise
P/V: set if overflow; reset otherwise

ADD A, n
A ← A+n
The integer n is added to the contents of the Accumulator, and the results are stored in the Accumulator.

Cycles: 2
States: 7
Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set if carry from bit 3; reset otherwise
N: reset
C: set if carry from bit 7; reset otherwise
P/V: set if overflow; reset otherwise

ADD A, (HL)
A ← A+(HL)
The byte at the memory address specified by the contents of the HL register pair is added to the contents of the Accumulator, and the result is stored in the Accumulator.

Cycles: 2
States: 7
Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set if carry from bit 3; reset otherwise
N: reset
C: set if carry from bit 7; reset otherwise
P/V: set if overflow; reset otherwise
ADD A, (IX+d)

A ← A+(IX+d)
The contents of the Index Register IX are added to a displacement d to point to an address in memory. The contents of this address are then added to the contents of the Accumulator, and the result is stored in the Accumulator.

Cycles: 5
States: 19
Flags: S, Z, H, N, C, P/V
  S: set if result is negative; reset otherwise
  Z: set if result is 0; reset otherwise
  H: set if carry from bit 3; reset otherwise
  N: reset
  C: set if carry from bit 7; reset otherwise
  P/V: set if overflow; reset otherwise

ADD A, (IY+d)

A ← A+(IY+d)
The contents of the Index Register IY are added to a displacement d to point to an address in memory. The contents of this address are then added to the contents of the Accumulator, and the result is stored in the Accumulator.

Cycles: 5
States: 19
Flags: S, Z, H, N, C, P/V
  S: set if result is negative; reset otherwise
  Z: set if result is 0; reset otherwise
  H: set if carry from bit 3; reset otherwise
  N: set
  C: set if carry from bit 7; reset otherwise
  P/V: set if overflow; reset otherwise
ADC A, s
A ← A+s+CY
The s operand is any of r, n, (HL), (IX+d), or (IY+d) as defined for the analogous ADD instruction. These various possible opcode operand combinations are assembled in the object code as follows:

ADC A, r
1 0 0 0 1 ← r →
ADC A, n
1 1 0 0 1 1 1 0
          n
ADC A, (HL)
1 0 0 0 1 1 1 0
ADC A, (IX+d)
1 1 0 1 1 1 0 1
          d
1 0 0 0 1 1 1 0
ADC A, (IY+d)
1 1 1 1 1 1 0 1
          d
1 0 0 0 1 1 1 0

The s operand, along with the Carry Flag ("C" in the F register) is added to the contents of the Accumulator, and the result is stored in the Accumulator.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC A, r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>ADC A, n</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>ADC A, (HL)</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>ADC A, (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
<tr>
<td>ADC A, (IY+d)</td>
<td>5</td>
<td>19</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set if carry from bit 3; reset otherwise
N: reset
C: set if carry from bit 7; reset otherwise
P/V: set if overflow; reset otherwise
SUB s
A ← A−s
The s operand is subtracted from the contents of the Accumulator, and the result is stored in the Accumulator.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>SUB r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>SUB n</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>SUB (HL)</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>SUB (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
<tr>
<td>SUB (IY+d)</td>
<td>5</td>
<td>19</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set if no borrow from bit 4; reset otherwise
N: set
C: set if no borrow; reset otherwise
P/V: set if overflow; reset otherwise
SBC A, s
A ← A − s − CY
The s operand, along with the Carry Flag ("C" in the F register) is subtracted from the contents of the Accumulator, and the result is stored in the Accumulator.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>SBC A, r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>SBC A, n</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>SBC A, (HL)</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>SBC A, (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
<tr>
<td>SBC A, (IY+d)</td>
<td>5</td>
<td>19</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set if no borrow from bit 4; reset otherwise
N: set
C: set if no borrow; reset otherwise
P/V: set if overflow; reset otherwise
AND s

A = A^s

A logical AND operation, bit by bit, is performed between the byte specified by the s operand and the byte contained in the Accumulator; the result is stored in the Accumulator.

\[
\begin{align*}
\text{AND } r & \quad 10100 \quad r \\
\text{AND } n & \quad 11100110 \\
\text{AND (HL)} & \quad 10100110 \\
\text{AND (IX+d)} & \quad 110111101 \\
\text{AND (IY+d)} & \quad 111111101 \\
\end{align*}
\]

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>AND r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>AND n</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>AND (HL)</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>AND (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
<tr>
<td>AND (IY+d)</td>
<td>5</td>
<td>19</td>
</tr>
</tbody>
</table>

Flags:   S, Z, H, N, C, P/V

S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set
N: reset
C: reset
P/V: set if parity even; reset otherwise

54 THE Z80 MICROPROCESSOR
OR s

A - A ∨ s

A logical OR operation, bit by bit, is performed between the byte specified by the s operand and the byte contained in the Accumulator; the result is stored in the Accumulator.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>OR r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>OR n</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>OR (HL)</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>OR (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
<tr>
<td>OR (IY+d)</td>
<td>5</td>
<td>19</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set
N: reset
C: reset
P/V: set if parity even; reset otherwise
XOR s

A → A ⊕ s

A logical exclusive-OR operation, bit by bit, is performed between the byte specified by the s operand and the byte contained in the Accumulator; the result is stored in the Accumulator.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>XOR r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>XOR n</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>XOR (HL)</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>XOR (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
<tr>
<td>XOR (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result if 0; reset otherwise
H: set
N: reset
C: reset
P/V: set if parity even; reset otherwise
A - s
The contents of the s operand are compared with the contents of the Accumulator. If there is a true compare, a flag is set.

\[
\begin{array}{c}
\text{CP r} \\
101111 \text{---} r \\
\text{CP n} \\
111111110 \text{---} n \\
\text{CP (HL)} \\
101111110 \\
\text{CP (IX+d)} \\
110111101 \\
101111110 \\
\text{CP (IY+d)} \\
111111101 \\
101111110 \\
\end{array}
\]

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>CP r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>CP n</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>CP (HL)</td>
<td>2</td>
<td>7</td>
</tr>
<tr>
<td>CP (IX+d)</td>
<td>5</td>
<td>19</td>
</tr>
<tr>
<td>CP (IY+d)</td>
<td>5</td>
<td>19</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V
- S: set if result is negative; reset otherwise
- Z: set if result is 0; reset otherwise
- H: set if no borrow from bit 4; reset otherwise
- N: set
- C: set if no borrow; reset otherwise
- P/V: set if overflow; reset otherwise
INC r
\[ r \rightarrow r + 1 \]
Register r is incremented.

Cycles: 1
States: 4
Flags: S, Z, H, N, P/V
   S: set if result is negative; reset otherwise
   Z: set if result is 0; reset otherwise
   H: set if carry from bit 3; reset otherwise
   N: reset
   P/V: set if r was 7FH before operation; reset otherwise

INC (HL)
\[(HL) \rightarrow (HL) + 1\]
The byte contained in the address specified by the contents of the HL register pair is incremented.

Cycles: 3
States: 11
Flags: S, Z, H, N, P/V
   S: set if result is negative; reset otherwise
   Z: set if result is 0; reset otherwise
   H: set if carry from bit 3; reset otherwise
   N: reset
   P/V: set if (HL) was 7FH before operation; reset otherwise

INC (IX+d)
\[(IX+d) \rightarrow (IX+d) + 1\]
The contents of the Index Register IX are added to a two’s complement displacement integer d to point to an address in memory. The contents of this address are then incremented.

Cycles: 6
States: 23
Flags: S, Z, H, N, P/V
   S: set if result is negative; reset otherwise
   Z: set if result is 0; reset otherwise
   H: set if carry from bit 3; reset otherwise
   N: reset
   P/V: set if (IX+d) was 7FH before operation; reset otherwise

INC (IY+d)
\[(IY+d) \rightarrow (IY+d) + 1\]
The contents of the Index Register IY are added to a two’s complement
displacement integer \( d \) to point to an address in memory. The contents of this address are then incremented.

\[
\begin{array}{c}
1 \ 1 \ 1 \ 1 \ 1 \ 1 \ 1 \ 1 \\
0 \ 0 \ 1 \ 1 \ 0 \ 1 \ 0 \ 0 \\
\end{array}
\]

Cycles: 6
States: 23
Flags: \( S, Z, H, N, P/V \)

- \( S \): set if result is negative; reset otherwise
- \( Z \): set if result is 0; reset otherwise
- \( H \): set if carry from bit 3; reset otherwise
- \( N \): reset
- \( P/V \): set if \((Y+d)\) was \(7FH\) before operation; reset otherwise

**DEC m**

\( m \rightarrow m - 1 \)

The byte specified by the \( m \) operand is decremented.

\[
\begin{array}{c}
\text{DEC } r \\
0 \ 0 \leftarrow r \rightarrow 1 \ 0 \ 1 \\
\end{array}
\]

\[
\begin{array}{c}
\text{DEC (HL)} \\
0 \ 0 \ 1 \ 1 \ 0 \ 1 \ 0 \ 1 \\
\end{array}
\]

\[
\begin{array}{c}
\text{DEC (IX+d)} \\
1 \ 1 \ 0 \ 1 \ 1 \ 1 \ 0 \ 1 \\
0 \ 0 \ 1 \ 1 \ 0 \ 1 \ 0 \ 1 \\
\end{array}
\]

\[
\begin{array}{c}
\text{DEC (IY+d)} \\
1 \ 1 \ 1 \ 1 \ 1 \ 1 \ 1 \ 0 \\
0 \ 0 \ 1 \ 1 \ 0 \ 1 \ 0 \ 1 \\
\end{array}
\]

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>DEC r</td>
<td>1</td>
<td>4</td>
</tr>
<tr>
<td>DEC (HL)</td>
<td>3</td>
<td>11</td>
</tr>
<tr>
<td>DEC (IX+d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>DEC (IY+d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

Flags: \( S, Z, H, N, P/V \)

- \( S \): set if result is negative; reset otherwise
- \( Z \): set if result is 0; reset otherwise
- \( H \): set if no borrow from bit 4; reset otherwise
- \( N \): set
- \( P/V \): set if \( m \) was \(80H\) before operation; reset otherwise
GENERAL PURPOSE ARITHMETIC AND CPU CONTROL GROUPS

CPL

A → $\overline{A}$

Contents of the Accumulator are inverted (1's complement).

Cycles: 1
States: 4
Flags: H, N
H: set
N: set

NEG

A → 0−A

The contents of the Accumulator are negated (two's complement). This is the same as subtracting the contents of the Accumulator from 0.

Cycles: 2
States: 8
Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: set if no borrow from bit 4; reset otherwise
N: set
C: set if Accumulator was not 00H before operation; reset otherwise
P/V: set if Accumulator was 80H before operation; reset otherwise

CCF

CY → $\overline{CY}$

The C flag in the F register is inverted.

Cycles: 1
States: 4
Flags: H, N, C
H: previous carry will be copied
N: reset
C: set if CY was 0 before operation; reset otherwise

SCF

CY → 1

The C flag in the F register is set.

Cycles: 1
States: 4
Flags: H, N, C
H: reset
N: reset
C: set

NOP

The central processor performs no operation during this machine cycle.

0 0 0 0 0 0 0 0

Cycles: 1
States: 4
Flags: none

DAA

This instruction conditionally adjusts the Accumulator for BCD addition and subtraction operations. For addition (ADD, ADC, INC) or subtraction (SUB, SBC, DEC, NEG), the following table indicates the operation performed:

<table>
<thead>
<tr>
<th>OPERATION</th>
<th>C BEFORE DAA</th>
<th>HEX VALUE IN UPPER DIGIT (bit 7-4)</th>
<th>H BEFORE DAA</th>
<th>HEX VALUE IN LOWER DIGIT (bit 3-0)</th>
<th>NUMBER ADDED TO BYTE</th>
<th>C AFTER DAA</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD</td>
<td>0</td>
<td>0-9</td>
<td>0</td>
<td>0-9</td>
<td>00</td>
<td>0</td>
</tr>
<tr>
<td>ADC</td>
<td>0</td>
<td>0-8</td>
<td>0</td>
<td>A-F</td>
<td>06</td>
<td>0</td>
</tr>
<tr>
<td>INC</td>
<td>0</td>
<td>0-9</td>
<td>1</td>
<td>0-3</td>
<td>06</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>A-F</td>
<td>0</td>
<td>0-9</td>
<td>60</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>A-F</td>
<td>1</td>
<td>0-3</td>
<td>66</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>0-2</td>
<td>0</td>
<td>0-9</td>
<td>60</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>0-2</td>
<td>0</td>
<td>A-F</td>
<td>66</td>
<td>1</td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>0-3</td>
<td>1</td>
<td>0-3</td>
<td>66</td>
<td>1</td>
</tr>
<tr>
<td>SUB</td>
<td>0</td>
<td>0-9</td>
<td>0</td>
<td>0-9</td>
<td>00</td>
<td>0</td>
</tr>
<tr>
<td>SBC</td>
<td>0</td>
<td>0-8</td>
<td>1</td>
<td>6-F</td>
<td>FA</td>
<td>0</td>
</tr>
<tr>
<td>DEC</td>
<td>1</td>
<td>7-F</td>
<td>0</td>
<td>0-9</td>
<td>A0</td>
<td>1</td>
</tr>
<tr>
<td>NEG</td>
<td>1</td>
<td>6-F</td>
<td>1</td>
<td>6-F</td>
<td>9A</td>
<td>1</td>
</tr>
</tbody>
</table>

M CYCLES: 1  T STATES: 4  4 MHZ E.T.: 1.00

Cycles: 1
States: 4
Flags: S,Z,H,C, P/V
S: set if most significant bit of Accumulator is 1 after operation; reset otherwise
Z: set if Accumulator is 0 after operation; reset otherwise
H: see instruction
C: see instruction
P/V: set if Accumulator is even parity after operation; reset otherwise
HALT

The HALT instruction suspends the central processor operation until a subsequent interrupt or reset is received. While in the halt state, the processor will execute NOPs to maintain memory refresh logic.

Cycles: 1
States: 4
Flags: none

DI

IFF = 0
DI disables the maskable interrupt by resetting the interrupt enable flip-flops (IFF1 and IFF2). Note: this instruction disables the maskable interrupt during its execution.

Cycles: 1
States: 4
Flags: none

EI

IFF = 1
EI enables the maskable interrupt by setting the interrupt enable flip-flops (IFF1 and IFF2). Note: this instruction disables the maskable interrupt during its execution.

Cycles: 1
States: 4
Flags: none

IM 0

The IM 0 instruction sets interrupt mode 0. In this mode the interrupting device can insert any instruction on the data bus and allow the central processor to execute it.

Cycles: 2
States: 8
Flags: none

IM 1

The IM 1 instruction sets interrupt mode 1. In this mode the processor will respond to an interrupt by executing a restart of location 0038H.
IM 2

The IM 2 instruction sets interrupt mode 2. This mode allows an indirect call to any location in memory. With this mode, the central processor forms a 16-bit memory address. The upper 8 bits are the contents of the Interrupt Vector Register I and the lower 8 bits are supplied by the interrupting device.

SIXTEEN-BIT ARITHMETIC GROUP

ADD HL, ss
HL ← HL + ss
The contents of register pair ss are added to the contents of register pair HL and the result is stored in HL.

ADC HL, ss
HL ← HL + ss + CY
The contents of register pair ss are added with the Carry Flag to the contents of the register pair HL, and the result is stored in HL.
SBC HL, ss
HL ← HL−ss−CY
The contents of the register pair ss and the Carry Flag are subtracted from the contents of register pair HL, and the result is stored in HL.

Cycles: 4
States: 15
Flags: S, Z, H, N, C, P/V
- S: set if result is negative; reset otherwise
- Z: set if result is 0; reset otherwise
- H: set if no borrow from bit 12; reset otherwise
- N: set
- C: set if no borrow; reset otherwise
- P/V: set if overflow; reset otherwise

ADD IX, pp
IX ← IX+pp
The contents of register pair pp are added to the contents of the Index Register IX, and the results are stored in IX.

Cycles: 4
States: 15
Flags: H, N, C
- H: set if carry out of bit 11; reset otherwise
- N: reset
- C: set if carry from bit 15; reset otherwise

ADD IY, rr
IY ← IY+rr
The contents of register pair rr are added to the contents of Index Register IY, and the result is stored in IY.

Cycles: 4
States: 15
Flags: H, N, C
- H: set if carry out of bit 11; reset otherwise
- N: reset
- C: set if carry from bit 15; reset otherwise

INC ss
ss ← ss+1
The contents of register pair ss are incremented.
Cycles: 1
States: 6
Flags: none

**INC IX**

IX ← IX+1
The contents of the Index Register IX are incremented.

Cycles: 2
States: 10
Flags: none

**INC IY**

IY ← IY+1
The contents of the Index Register IY are incremented.

Cycles: 2
States: 10
Flags: none

**DEC ss**

ss ← ss−1
The contents of register pair ss are decremented.

Cycles: 1
States: 6
Flags: none

**DEC IX**

IX ← IX−1
The contents of the Index Register IX are decremented.

Cycles: 2
States: 10
Flags: none

**DEC IY**

IY ← IY−1
The contents of the Index Register IY are decremented.

Cycles: 2
States: 10
Flags: none
Cycles: 2
States: 10
Flags: none

ROTATE AND SHIFT GROUP

RLCA

The contents of the Accumulator are rotated left. The content of bit 7 is copied into the Carry Flag, and also into bit 0.

Cycles: 1
States: 4
Flags: H, N, C
H: reset
N: reset
C: data from bit 7 of Accumulator

RLA

The contents of the Accumulator are rotated left. The content of bit 7 is copied into the Carry Flag, and the previous content of the Carry Flag is copied into bit 0.

Cycles: 1
States: 4
Flags: H, N, C
H: reset
N: reset
C: data from bit 7 of Accumulator.

RRCA

The contents of the Accumulator are rotated right. The content of bit 0 is copied into bit 7 and also into the Carry Flag.

Cycles: 1
States: 4
Flags: H, N, C
H: reset
N: reset
C: data from bit 0 of Accumulator.

RRA

The contents of the Accumulator are rotated right. The content of bit 0 is copied into the Carry Flag, and the previous content of the Carry Flag is
copied into bit 7.

\[ \begin{array}{cccccccc}
0 & 0 & 0 & 1 & 1 & 1 & 1 & 1 \\
\end{array} \]

Cycles: 1
States: 4
Flags: H, N, C
   H: reset
   N: reset
   C: data from bit 0 of Accumulator.

\[
\begin{array}{c}
\text{RLC } r \\
\end{array}
\]

The 8-bit contents of register \( r \) are rotated left. The content of bit 7 is copied into the Carry Flag and also into bit 0.

\[ \begin{array}{cccccccc}
1 & 1 & 0 & 0 & 1 & 0 & 1 & 1 \\
\end{array} \]

Cycles: 2
States: 8
Flags: S, Z, H, N, C, P/V
   S: set if result is negative; reset otherwise
   Z: set if result is 0; reset otherwise
   H: reset
   N: reset
   C: data from bit 7 of source register
   P/V: set if parity even; reset otherwise

\[
\begin{array}{c}
\text{RLC (HL)} \\
(\text{HL}) \\
\end{array}
\]

The contents of the memory address specified by the contents of register pair HL are rotated left. The content of bit 7 is copied into the Carry Flag and also into bit 0.

\[ \begin{array}{cccccccc}
1 & 1 & 0 & 0 & 1 & 0 & 1 & 1 \\
\end{array} \]

\[ \begin{array}{cccccccc}
0 & 0 & 0 & 0 & 0 & 1 & 1 & 0 \\
\end{array} \]

Cycles: 4
States: 15
Flags: S, Z, H, N, C, P/V
   S: set if result is negative; reset otherwise
   Z: set if result is 0; reset otherwise
   H: reset
   N: reset
   C: data from bit 7 of source register
   P/V: set if parity even; reset otherwise

\[
\begin{array}{c}
\text{RLC (IX+d)} \\
(\text{IX+d}) \\
\end{array}
\]

The contents of the memory address, specified by the sum of the contents of the Index Register IX and a two's complement displacement integer \( d \), are rotated left. The content of bit 7 is copied into the Carry Flag and also into bit 0.
Cycles: 6
States: 23
Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: reset
N: reset
C: data from bit 7 of source register
P/V: set if parity even; reset otherwise

**RLC (IY+d)**

The contents of the memory address, specified by the sum of the contents of the Index Register IY and a two's complement displacement integer d, are rotated left. The content of bit 7 is copied into the Carry Flag and also into bit 0.

Cycles: 6
States: 23
Flags: S, Z, H, N, C, P/V
S: set if result is negative; reset otherwise
Z: set if result is 0; reset otherwise
H: reset
N: reset
C: data from bit 7 of source register
P/V: set if parity even; reset otherwise

**RL m**

The contents of the m operand are rotated left. The content of bit 7 is copied into the Carry Flag and the previous content of the Carry Flag is copied into bit 0.
**RL r**

```
  1 1 0 0 1 0 1 1
  0 0 0 1 0
```

**RL (HL)**

```
  1 1 0 0 1 0 1 1
  0 0 0 1 0 1 1 0
```

**RL (IX+d)**

```
  1 1 0 1 1 1 0 1
  1 1 0 0 1 0 1 1
  0 0 0 1 0 1 1 0
```

**RL (IY+d)**

```
  1 1 1 1 1 1 0 1
  1 1 0 0 1 0 1 1
```

---

**Instruction**

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>RL r</td>
<td>2</td>
<td>8</td>
</tr>
<tr>
<td>RL (HL)</td>
<td>4</td>
<td>15</td>
</tr>
<tr>
<td>RL (IX+d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>RL (IY+d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

**Flags:**
- **S**: set if result is negative; reset otherwise
- **Z**: set if result is 0; reset otherwise
- **H**: reset
- **N**: reset
- **C**: data from bit 7 of source register
- **P/V**: set if parity even; reset otherwise

**RRC m**

```
  7
  0
```

The contents of the operand m are rotated right. The content of bit 0 is copied into the Carry Flag and also into bit 7.

**RRC r**

```
  1 1 0 0 1 0 1 1
  0 0 0 0 1
```

**RRC (HL)**

```
  1 1 0 0 1 0 1 1
  0 0 0 1 0 1 1 0
```

**RRC (IX+d)**

```
  1 1 0 1 1 1 0 1
```
RRC (IY+d)

---

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>RRC r</td>
<td>2</td>
<td>8</td>
</tr>
<tr>
<td>RRC (HL)</td>
<td>4</td>
<td>15</td>
</tr>
<tr>
<td>RRC (IX+d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>RRC (IY+d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V
- S: set if result is negative; reset otherwise
- Z: set if result is 0; reset otherwise
- H: reset
- N: reset
- C: data from bit 0 of source register
- P/V: set if parity even; reset otherwise

RR m

The contents of operand m are rotated right. The content of bit 0 is copied into the Carry Flag, and the previous content of the Carry Flag is copied into bit 7.

RR r

RR (HL)

RR (IX+d)
### Instruction

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>RR r</td>
<td>2</td>
<td>8</td>
</tr>
<tr>
<td>RR (HL)</td>
<td>4</td>
<td>15</td>
</tr>
<tr>
<td>RR (IX + d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>RR (IY + d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

### Flags:

- **S**: set if result is negative; reset otherwise
- **Z**: set if result is 0; reset otherwise
- **H**: reset
- **N**: reset
- **C**: data from bit 0 of source register
- **P/V**: set if parity even; reset otherwise

### SLA m

![SLA m diagram]

An arithmetic shift left is performed on the contents of operand m. Bit 0 is reset. The content of bit 7 is copied into the Carry Flag.
### Instruction

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>SLA r</td>
<td>2</td>
<td>8</td>
</tr>
<tr>
<td>SLA (HL)</td>
<td>4</td>
<td>15</td>
</tr>
<tr>
<td>SLA (IX+d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>SLA (IY+d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

### Flags:

- **S, Z, H, N, C, P/V**
  - S: set if result is negative; reset otherwise
  - Z: set if result is 0; reset otherwise
  - H: reset
  - N: reset
  - C: data from bit 7
  - P/V: set if parity even; reset otherwise

### SRA m

An arithmetic shift right is performed on the contents of operand m. The content of bit 0 is copied into the Carry Flag, and the previous content of bit 7 is unchanged.

### SRA r

An arithmetic shift right is performed on the contents of operand r. The content of bit 0 is copied into the Carry Flag, and the previous content of bit 7 is unchanged.
SRA (IX+d)

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRA r</td>
<td>2</td>
<td>8</td>
</tr>
<tr>
<td>SRA (HL)</td>
<td>4</td>
<td>15</td>
</tr>
<tr>
<td>SRA (IX+d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>SRA (IX+d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

Flags:  
S: set if result is negative; reset otherwise  
Z: set if result is 0; reset otherwise  
H: reset  
N: reset  
C: data from bit 0 of source register  
P/V: set if parity even; reset otherwise

SRL m

The contents of operand m are shifted right. The content of bit 0 is copied into the Carry Flag and bit 7 is reset.
SRL (IY + d)

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>SRL r</td>
<td>2</td>
<td>8</td>
</tr>
<tr>
<td>SRL (HL)</td>
<td>4</td>
<td>15</td>
</tr>
<tr>
<td>SRL (IX + d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>SRL (IY + d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

Flags: S, Z, H, N, C, P/V

- S: set if result is negative; reset otherwise
- Z: set if result is 0; reset otherwise
- H: reset
- N: reset
- C: data from bit 0 of source register
- P/V: set if parity even; reset otherwise

RLD

The contents of the low-order 4 bits of memory location (HL) are copied into the high-order 4 bits of that same memory location. The previous contents of those high-order 4 bits are copied into the low-order 4 bits of the Accumulator, and the previous contents of the low-order 4 bits of the Accumulator are copied into the low-order 4 bits of the memory location (HL). The contents of the high-order 4 bits of the Accumulator are unaffected.

<table>
<thead>
<tr>
<th>Cycles: 5</th>
<th>States: 18</th>
</tr>
</thead>
</table>

Flags: S, Z, H, N, P/V

- S: set if Accumulator is negative after operation; reset otherwise
- Z: set if Accumulator is 0 after operation; reset otherwise
- H: reset
- N: reset
- P/V: set if parity of Accumulator is even after operation; reset otherwise
The contents of the low-order 4 bits of memory location (HL) are copied into the low-order 4 bits of the Accumulator. The previous contents of the low-order 4 bits of the Accumulator are copied into the high-order 4 bits of location (HL), and the previous contents of the high-order 4 bits of (HL) are copied into the low-order 4 bits of (HL). The contents of the high-order 4 bits of the Accumulator are unaffected.

Cycles: 5
States: 18
Flags: S, Z, H, N, P/V
S: set if Accumulator is negative after operation; reset otherwise
Z: set if Accumulator is 0 after operation; reset otherwise
H: set
N: reset
P/V: set if parity of Accumulator is even after operation; reset otherwise

BIT SET, RESET AND TEST GROUP

BIT b, r

\[ Z = \overline{r}_b \]

After execution of this instruction, the Z flag in the F register will contain the complement of the indicated bit within the indicated register.

Cycles: 2
States: 8
Flags: S, Z, H, N, P/V
S: unknown
Z: set if specified bit is 0; reset otherwise
H: set
N: reset
P/V: unknown

BIT b, (HL)

\[ Z = (HL)_b \]

After the execution of this instruction, the Z flag in the F register will contain the complement of the indicated bit within the contents of the HL register pair.

Cycles: 3
States: 12
Flags: S, Z, H, N, P/V
S: unknown
Z: set if specified bit is 0; reset otherwise
H: set
N: reset
P/V: unknown
BIT b, (IX+d)
\[ Z \leftarrow (IX+d) \]

After the execution of this instruction, the Z flag in the F register will contain the complement of the indicated bit within the contents of the memory location pointed to by the sum of the contents of register pair IX and the two's complement displacement integer d.

Cycles: 5
States: 20
Flags: S, Z, H, N, P/V
   S: unknown
   Z: set if specified bit is 0; reset otherwise
   H: set
   N: reset
   P/V: unknown

BIT b, (IY+d)
\[ Z \leftarrow (IY+d) \]

After the execution of this instruction, the Z flag in the F register will contain the complement of the indicated bit within the contents of the memory location pointed to by the sum of the contents of register pair IY and the two's complement displacement integer d.

Cycles: 5
States: 20
Flags: S, Z, H, N, P/V
   S: unknown
   Z: set if specified bit is 0; reset otherwise
   H: set
   N: reset
   P/V: unknown

SET b, r
\[ r_s \leftarrow 1 \]

Bit b (any bit, 7 thru 0) in register r is set.

Cycles: 2
States: 8
Flags: none
SET b, (HL)
   (HL)_b = 1
Bit b in the memory location addressed by the contents of register pair HL is set.

Cycles:  4
States:  15
Flags:   none

SET b, (IX+d)
   (IX+d)_b = 1
Bit b in the memory location addressed by the sum of the contents of the IX register pair and the two's complement displacement integer d is set.

Cycles:  6
States:  23
Flags:   none

SET b, (IY+d)
   (IY+d)_b = 1
Bit b in the memory location addressed by the sum of the contents of the IY register pair and the two's complement displacement integer d is set.

Cycles:  6
States:  23
Flags:   none
RES b, m
s, − 0
Bit b in operand m is reset.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Cycles</th>
<th>States</th>
</tr>
</thead>
<tbody>
<tr>
<td>RES b, r</td>
<td>4</td>
<td>8</td>
</tr>
<tr>
<td>RES b, (HL)</td>
<td>4</td>
<td>15</td>
</tr>
<tr>
<td>RES b, (IX+d)</td>
<td>6</td>
<td>23</td>
</tr>
<tr>
<td>RES b, (IY+d)</td>
<td>6</td>
<td>23</td>
</tr>
</tbody>
</table>

Flags: none

JUMP GROUP

 JP nn
PC − nn
Operand nn is loaded into register pair PC (program counter) and points to the address of the next program instruction to be executed.
JP cc, nn

IF cc TRUE, PC ← nn
If condition cc is true, the instruction loads operand nn into register pair PC, and the program continues with the instruction beginning at address nn. If condition cc is false, the program counter is incremented as usual, and the program continues with the next sequential instruction.

JR e

PC ← PC + e
This instruction provides for unconditional branching to other segments of a program. The value of the displacement e is added to the PC and the next instruction is fetched from the location designated by the new contents of the PC. This jump is measured from the address of the instruction opcode and has a range of −126 to +129 bytes.
JR C, e
If C = 0, continue
If C = 1, PC ← PC + e
This instruction provides for conditional branching to other segments of a program depending on the results of a test on the Carry Flag. If the flag is set, the value of the displacement e is added to the PC, and the next instruction is fetched from the location designated by the new contents of the PC. If the flag is reset the next instruction is taken from the location following this instruction.

If the condition is met:
Cycles: 3
States: 12
If the condition is not met:
Cycles: 2
States: 7
Flags: none

JR NC, e
If C = 1, continue
If C = 0, PC ← PC + e
This instruction provides for conditional branching to other segments of a program depending on the results of a test on the Carry Flag. If the flag is reset, the value of the displacement e is added to the PC, and the next instruction is fetched from the location designated by the new contents of the PC. If the flag is set, the next instruction to be executed is taken from the location following this instruction.

If the condition is met:
Cycles: 3
States: 12
If the condition is not met:
Cycles: 2
States: 7
Flags: none

JR Z, e
If Z = 0, continue
If Z = 1, PC ← PC + e
If the Zero Flag is set, the value of the displacement e is added to the PC and the next instruction is fetched from the location designated by the new contents of the PC. If the Zero Flag is reset, the next instruction to be executed is taken from the location following this instruction.
If the condition is met:
Cycles: 3
States: 12

If the condition is not met:
Cycles: 2
States: 7
Flags: none

JR NZ, e
If Z = 1, continue
If Z = 0, PC ← PC + e
If the Zero Flag is reset, the value of the displacement e is added to the PC, and the next instruction is fetched from the location designated by the new contents of the PC. If the Zero Flag is set, the next instruction to be executed is taken from the location following this instruction.

If the condition is met:
Cycles: 3
States: 12

If the condition is not met:
Cycles: 2
States: 7
Flags: none

JP (HL)
PC ← HL
The PC is loaded with the contents of the HL register pair. The next instruction is fetched from the location designated by the new contents of the PC.

Cycles: 1
States: 4
Flags: none

JP (IX)
PC ← IX
The PC is loaded with the contents of the IX Register Pair. The next instruction is fetched from the location designated by the new contents of the PC.
Cycles: 2
States: 8
Flags: none

**JP (IY)**

PC ← IY

The PC is loaded with the contents of the IY Register Pair. The next instruction is fetched from the location designated by the new contents of the PC.

Cycles: 2
States: 8
Flags: none

**DJNZ, e**

The B register is decremented, and if a non 0 value remains, the value of the displacement e is added to the PC. The next instruction is fetched from the location designated by the new contents of the PC. If the result of decrementing leaves B with a 0 value, the next instruction to be executed is taken from the location following this instruction.

If B ≠ 0:
Cycles: 3
States: 13

If B = 0:
Cycles: 2
States: 8
Flags: none

**CALL AND RETURN GROUP**

**CALL nn**

(SP−1) ← PCₜₜ, (SP−2) ← PCₜₑ, PC ← nn

After pushing the current contents of the PC onto the top of the external memory stack, the operands nn are loaded into PC to point to the address in memory where the first opcode of a subroutine is to be fetched. Note: because this is a 3-byte instruction, the PC will have been incremented by three before the push is executed.
CALL cc, nn
If cc TRUE: (SP - 1) - PC\textsubscript{n}, (SP - 2) - PC\textsubscript{L}, PC - nn
If condition cc is true, this instruction pushes the current contents of the PC onto the top of the external memory stack, then loads the operands nn into PC to point to the address in memory where the first opcode of a subroutine is to be fetched.

If cc is true:
Cycles: 5
States: 17
If cc is false:
Cycles: 3
States: 10
Flags: none

RET
PC\textsubscript{L} - (SP), PC\textsubscript{H} - (SP + 1)
Control is returned to the original program flow by popping the previous contents of the PC off the top of the external memory stack, where they were pushed by the CALL instruction. On the following machine cycle, the central processor will fetch the next program opcode from the location in memory now pointed to by the PC.

Cycles: 3
States: 10
Flags: none

RET cc
If cc TRUE: PC\textsubscript{L} - (SP), PC\textsubscript{H} - (SP + 1)
If condition cc is true, control is returned to the original program flow by popping the previous contents of the PC off the top of the external memory stack where they were pushed by the CALL instruction. On the following machine cycle, the central processor will fetch the next program opcode from
the location in memory now pointed to by the PC. If condition cc if false, the
PC is simply incremented as usual, and the program continues with the next
sequential instruction.

| 1 1 | cc | 0 0 0 |

If cc is true:
Cycles: 3
States: 11

If cc is false:
Cycles: 1
States: 5
Flags: none

RETI

Return from interrupt
This instruction is used at the end of an interrupt service routine to
1. Restore the contents of the PC.
2. Signal an I/O device that the interrupt routine has been completed.

The RETI instruction facilitates the nesting of interrupts allowing higher
priority devices to suspend service of lower priority service routines. This in-
struction also resets the IFF1 and IFF2 flip-flops.

| 1 1 1 0 1 1 0 1 |
| 0 1 0 0 1 1 0 1 |

Cycles: 4
States: 14
Flags: none

RETN

Return from nonmaskable interrupt
Used at the end of a service routine for a nonmaskable interrupt, the instruc-
tion executes an unconditional return which functions identically to the RET
instruction. Control is now returned to the original program flow; on the
following machine cycle the central processor will fetch the next opcode from
the location in memory now pointed to by the PC. Also, the state of IFF2 is
copied back into IFF1 to the state it had prior to the acceptance of the NMI.

| 1 1 1 0 1 1 0 1 |
| 0 1 0 0 0 1 0 1 |

Cycles: 4
States: 14
Flags: none

RST p

(SP - 1) ← PC_H, (SP - 2) ← PC_L, PC_H ← 0, PC_L ← p
The current PC contents are pushed onto the external memory stack, and the
page zero memory location given by operand p is loaded into the PC. Program execution then begins with the opcode in the address now pointed to by PC. The restart instruction allows for a jump to one of 8 addresses as shown in the table below. The operand p is assembled into the object code using the corresponding t state.

<table>
<thead>
<tr>
<th>p</th>
<th>t</th>
</tr>
</thead>
<tbody>
<tr>
<td>00H</td>
<td>000</td>
</tr>
<tr>
<td>08H</td>
<td>001</td>
</tr>
<tr>
<td>10H</td>
<td>010</td>
</tr>
<tr>
<td>18H</td>
<td>011</td>
</tr>
<tr>
<td>20H</td>
<td>100</td>
</tr>
<tr>
<td>28H</td>
<td>101</td>
</tr>
<tr>
<td>30H</td>
<td>110</td>
</tr>
<tr>
<td>38H</td>
<td>111</td>
</tr>
</tbody>
</table>

Cycles: 3  
States: 11  
Flags: none

**INPUT AND OUTPUT GROUP**

**IN A, (n)**

A ← (n)
The operand n is placed on the bottom half of the address bus to select the I/O device at one of 256 possible ports. The contents of the Accumulator also appear on the top half of the address bus at this time. One byte from the selected port is then placed on the data bus and written into the Accumulator in the central processor.

\[
\begin{array}{cccccccc}
1 & 1 & 0 & 1 & 1 & 0 & 1 & 1 \\
\hline
n & & & & & & & \\
\end{array}
\]

Cycles: 3  
States: 11  
Flags: none

**IN r, (C)**

r ← (C)
The contents of register C are placed on the bottom half of the address bus to select the I/O device at one of 256 possible ports. The contents of register B are placed on the top half of the address bus at this time. One byte from the selected port is then placed on the data bus and written into register r in the central processor.

\[
\begin{array}{cccccccc}
1 & 1 & 1 & 0 & 1 & 1 & 0 & 1 \\
\hline
0 & 1 & r & 0 & 0 & 0 & & \\
\end{array}
\]

Cycles: 3  
States: 12  
Flags: S, Z, H, N, P/V
S: set if input data is negative; reset otherwise
Z: set if input data is 0; reset otherwise
H: reset
N: reset
P/V: set if parity is even; reset otherwise

INI

\[(HL) \rightarrow (C), \ B \rightarrow B-1, \ HL \rightarrow HL+1\]

The contents of register C are placed on the bottom half of the address bus to select the I/O device at one of 256 possible ports. Register B may be used as a byte counter, and its contents are placed on the top half of the address bus. One byte from the selected port is then placed on the data bus and written to the central processor. The contents of the HL register pair are then placed on the address bus, and the input byte is written into the corresponding location of memory. Finally, the byte counter is decremented, and register pair HL is decremented.

\[
\begin{array}{cccccc}
1 & 1 & 1 & 0 & 1 & 1 \\
0 & 1 & 0 & 0 & 0 & 1 \\
\end{array}
\]

Cycles: 4
States: 16
Flags: S, Z, H, N, P/V

S: unknown
Z: set if B-1=0; reset otherwise
H: unknown
N: set
P/V: unknown

INIR

\[(HL) \rightarrow (C), \ B \rightarrow B-1, \ HL \rightarrow HL+1\]

The contents of register C are placed on the bottom half of the address bus to select the I/O device at one of 256 possible ports. Register B is used as a byte counter, and its contents are placed on the top half of the address bus. One byte is selected and is placed on the data bus and written into the central processor. The contents of the HL register pair are placed on the address, and the input byte is written into the corresponding memory location. The byte counter is then decremented and the HL register pair is incremented. If decrementing causes B to go to 0, the instruction is terminated. If B is not 0, the PC is decremented by two and the instruction repeated. Interrupts will be recognized after each data transfer.

\[
\begin{array}{cccccc}
1 & 1 & 1 & 0 & 1 & 1 \\
0 & 1 & 1 & 0 & 0 & 1 \\
\end{array}
\]

If B ≠ 0:
Cycles: 5
States: 21

If B = 0:
Cycles: 4
States: 16
Flags: S, Z, H, N, P/V
S: unknown
Z: set
H: unknown
N: set
P/V: unknown

IND

(HL) - (C), B = B - 1, HL = HL - 1
The contents of register C are placed on the bottom half of the address bus to select the I/O device. Register B may be used as a byte counter, and its contents are placed on the top half of the address bus. One byte from the selected port is placed on the data bus and written to the central processor. The contents of the HL register pair are placed on the address bus, and the input byte is written into the corresponding memory location. Finally, the byte counter and register pair HL are decremented.

\[
\begin{array}{c}
11101101 \\
10101010
\end{array}
\]

Cycles: 4
States: 16
Flags: S, Z, H, N, P/V
S: unknown
Z: set if B - 1 = 0; reset otherwise
H: unknown
N: set
P/V: unknown

INDR

(HL) - (C), B = B - 1, HL = HL - 1
The contents of register C are placed on the bottom half of the address bus to select the I/O device. Register B is used as a byte counter, and its contents are placed on the top half of the address bus. One byte from the selected port is placed on the data bus and written to the central processor. The contents of the HL register pair are placed on the address bus and the input byte is written into the corresponding memory location. The HL register pair and the byte counter are then decremented. If decrementing causes B to go to 0, the instruction is terminated. If B is not 0, the PC is decremented by 2, and the instruction is repeated. Interrupts will be recognized after each data transfer.

\[
\begin{array}{c}
11101101 \\
10111010
\end{array}
\]

If B ≠ 0:
Cycles: 5
States: 21

If B = 0:
Cycles: 4
States: 16
Flags: S, Z, H, N, P/V
S: unknown
Z: set
H: unknown
N: set
P/V: unknown

THE Z80 MICROPROCESSOR 87
OUT (n), A

(n) ← A

The operand n is placed on the bottom half of the address bus to select the I/O device. The contents of the Accumulator appear on the top half of the address bus. Then the byte contained in the Accumulator is placed on the data bus and written into the selected peripheral device.

Cycles: 3
States: 11
Flags: none

OUT (C), r

(C) ← r

The contents of register C are placed on the bottom half of the address bus to select the I/O device. The contents of register B are placed on the top half of the address bus. The byte contained in register r is placed on the data bus and written into the selected peripheral device.

Cycles: 3
States: 12
Flags: none

OUTI

(C) ← (HL), B ← B−1, HL ← HL+1

The contents of the HL register pair are placed on the address bus to select a location in memory. The byte contained in this memory location is temporarily stored in the central processor. After the byte counter (B) is decremented, the contents of register C are placed on the bottom half of the address bus to select the I/O device. Register B may be used as a byte counter, and its decremented value is placed on the top half of the address bus. The byte to be output is placed on the data bus and written into the selected peripheral device. Finally, the register pair HL is incremented.

Cycles: 4
States: 16
Flags: S, Z, H, N, P/V

S: unknown
Z: set if B−1=0; reset otherwise
H: unknown
N: set
P/V: unknown
OTIR

(C) − (HL), B − B−1, HL − HL+1
The contents of the HL register pair are placed on the address bus to select a location in memory. The byte contained in this memory location is temporarily stored in the central processor. After the byte counter (B) is decremented, the contents of register C are placed on the bottom half of the address bus to select the I/O device. Register B may be used as a byte counter, and its decremented value is placed on the top half of the address bus at this time. The byte to be output is placed on the data bus and written into the selected peripheral device. Then register pair HL is incremented. If the decremented B register is not 0, the PC is decremented by two and the instruction is repeated. If B is 0, the instruction is terminated. Interrupts will be recognized after each data transfer.

If B ≠ 0:
Cycles: 5
States: 21

If B = 0:
Cycles: 4
States: 16
Flags: S, Z, H, N, P/V
S: unknown
Z: set
H: unknown
N: set
P/V: unknown

OUTD

(C) − (HL), B − B−1, HL − HL−1
The contents of the HL register pair are placed on the address bus to select a location in memory. The byte contained in this memory location is temporarily stored in the central processor. Then, after the byte counter (B) is decremented, the contents of register C are placed on the bottom half of the address bus to select the I/O device. Register B may be used as a byte counter, and its decremented value is placed on the top half of the address bus. The byte to be output is placed on the data bus written into the selected peripheral device. Finally, the register pair HL is decremented.

Cycles: 4
States: 16
Flags: S, Z, H, N, P/V
S: unknown
Z: set if B−1=0; reset otherwise
H: unknown
N: set
P/V: unknown
OTDR

(C) ← (HL), B ← B - 1, HL ← HL - 1
The contents of the HL register pair are placed on the address bus to select a location in memory. The byte contained in this memory location is temporarily stored in central processors. Then, after the byte counter (B) is decremented, the contents of register C are placed on the bottom half of the address bus to select the I/O device. Register B may be used as a byte counter, and its decremented value is placed on the top half of the address bus. The byte to be output is then placed on the data bus and written into the selected peripheral device. Register pair HL is then decremented. If the decremented B register is not 0, the PC is decremented by 2, and the instruction is repeated. If register B is 0, then the instruction is terminated. Interrupts will be recognized after each data transfer.

If B ≠ 0:
Cycles: 5
States: 21

If B = 0:
Cycles: 4
States: 16

Flags: S, Z, H, N, P/V
S: unknown
Z: set
H: unknown
N: set
P/V: unknown
CHAPTER 4
BUILD YOUR OWN
COMPUTER—Start With
the Basics

The computer to be built from the design described in this book is called ZAP, for Z80 Applications Processor. Building a computer from scratch is both educational and utilitarian (and it saves money). I explain each section of the construction process in detail. Ideally, each step should be tested before proceeding on to the next stage. While this is not possible in all cases, there is a beneficial side effect in taking this route. Often good designs fail to work because the level of construction is beyond the ability of the builder.

I've made the assumption that most hobbyists do not possess sophisticated test equipment, such as oscilloscopes or logic analyzers, and as a result, I've kept testing procedures as simple as possible. By dividing ZAP into logical milestones for checkout and test (and using proven components), problems can be identified at earlier stages and rectified more easily.

The initial implementation of ZAP will constitute a minimum operable configuration. It is important that this works before you attempt to add any of the optional peripherals. Every effort will be made to familiarize the reader with the components of each section and the philosophy of design. While it is necessary to assemble all the components of this minimum configuration completely in order to check proper central processor operation, comprehensive subassembly pretesting should (I hope) correct any wiring errors.

The basic ZAP is divided into four major subassemblies: Z80 busing and control, memory and I/O chip select decoding, memory, and input/output registers. These major divisions are further divided at the component level. Schematics include a complete explanation of their logical function, and test procedures are outlined after each construction presentation.

The Processor

Figure 4.1 is a detailed block diagram of the basic ZAP computer.

I. Z80 Busing and Control Logic

A. Clock Generation

The ZAP computer runs on a 2.5 MHz TTL clock. Unlike the 8080A, the Z80 requires only a single-phase clock and can be driven from DC to 2.5 MHz (the Z80A runs to 4 MHz). Figure 4.2 illustrates the basic timing cycle of the computer.

Each basic operation (M_n) of the computer is completed in three or six clock periods. Figure 4.2 shows a typical instruction cycle which consists of three machine cycles: fetch, memory read, and memory write. After the opcode of the instruction is fetched during M1, the subsequent cycles move the data between memory and the central processor.

Figures 4.3a and 4.3b illustrate two possible clock designs for the Z80. Both clock circuits have a 330 ohm pull-up to +5 V. This will satisfy both the AC and DC clock signal requirements, but it is best to use a separate inverter gate.
section to drive the pull-up whatever the oscillation technique.

The crystal controlled circuit of figure 4.3a is preferred if consistent execution time is to be maintained. Thus, the circuit of figure 4.3b, though otherwise acceptable, should be avoided if the computer is to be used as an event timer. It can serve a very useful purpose in the development stages, however, by allowing the user to slow the clock down (by increasing the values of R and C) to a rate where it is possible to directly monitor the central processor operation. Should it ever be necessary to single-step the clock, the circuit in figure 4.4 should be used. Given the multiple clock cycles necessary to execute a single instruction, it would take a lot of button pushes to follow a program through execution.

A much easier diagnostic method would be to use an instruction single-stepping circuit. The circuit, shown in figure 4.5, is not part of the finished schematic of ZAP because it is necessary only if the builder has a problem and needs to follow the execution of a program instruction by instruction. This single-stepping function is accomplished by using the control signals generated by the Z80 during program execution. The two particular signals of concern are MI and WAIT. MI is an output, and WAIT is an input. As shown in figure 4.6, MI goes to a logic 0 level at the beginning of every instruction fetch cycle. MI signifies that the computer has completed one instruction and is starting on the next. The objective is to stop the microprocessor before it executes this next instruction.

The WAIT input to the Z80 does just that. A logic 0 level applied to this input will suspend the program execution of the computer and indefinitely hold it in the MI cycle. During T1, the central processor samples the WAIT input line with the trailing edge of the clock. If, at this time, WAIT is at a logic 0 level, an additional wait state will be entered, and the line will be sampled again. The central processor will hang in this mode until WAIT is raised to a logic 1. It should be noted that this is not a computer halt command.

The real purpose behind these signals is to allow the relatively slow memory and peripherals to be used with a very fast central processor. Extra wait states should be inserted only when necessary for the central processor to access these devices. The effect is to synchronize the timing between the central processor and its I/O devices. The circuit of figure 4.5 allows us to control the WAIT state and to execute only one instruction with each press of the button. The output at IC 1, pin 8 (the WAIT input) is normally low, causing an indefinite wait. When the button is pushed, a single debounced pulse clocks IC 2, which is a D-type flip-flop. The duration of this pulse (the time you hold the button down) is irrelevant, because the flip-flop is edge triggered and is only concerned with the leading edge. Pressing the button sets IC 2 and raises the WAIT line. No longer told to wait, the central processor executes the instruction at full clock speed. As it is about to start the next instruction fetch cycle, MI goes low as before, and triggers the one-shot. When it fires, IC 3 resets IC 2 and returns the central processor to a wait condition until the next time the button is pushed.

The single-step feature isn't of much use in a computer unless there is some way to monitor the contents of all the registers and to determine what the computer is trying to do at any one time. To accomplish this, ZAP must be completely operational and be running a breakpoint-monitor program which allows the user to single-step with a software routine. We'll discuss such programs later.

This fact is of small consolation to a person with a partially debugged computer or hardware error that keeps side-tracking large programs. While it would be nice to see all the register contents, it is virtually impossible to do so without having a central processor that can run a dump and display routine. This cannot be done using the hardware stepping circuit of figure 4.5. It is possible, however, to look at the contents of the address and data buses while the central processor is stopped. This should give a good indication as to
whether the computer is operating properly.

Many instruments can be used to read the TTL levels on the buses. A scope or high-impedance voltmeter can be used, but a visible display of the bus contents is a better idea. The circuits in figure 4.7 show simple methods to display the contents of the address and data buses. The circuits are included as aids and are not necessary for the operation of ZAP.

Basically, the circuit of figure 4.7a is a simple LED driver that is duplicated 16 times for the address bus and 8 times for the data bus. Because the Z80 should drive only one TTL load from each output pin (bus driver inputs are already attached), any display drivers of this type must be attached on the output side of the bus drivers. This circuit will serve as a rudimentary front panel for any builders who feel a computer isn’t complete without flashing lights.

Sometimes the need arises to monitor a single point in a circuit and watch for level changes. While the LED driver of figure 4.7a would detect a slowly changing level, it would miss short pulses such as M1. To monitor the occurrence of such events, especially if no oscilloscope is available for testing purposes, it is advisable to build the circuit in figure 4.7b. This simple logic probe is adequate for most applications, but care must be taken in its use. It cannot detect an open circuit and the pulse detector only triggers on the negative edge of any transition. Should that present any problems, add the optional circuit using the 7486; that will allow it to detect either edge.

The logic probe or similar logic level detector (scope, DVM, VOM, etc.) is necessary to statically test the subassemblies.

Figure 4.1 A block diagram of a minimum ZAP system.

Figure 4.2 An example of timing during a typical instruction cycle.
Figure 4.3 Typical 2.5 MHz clock circuits for the Z80.
   a) With crystal control.
   b) With a variable-frequency oscillator.

Figure 4.4 A single-cycle clock-generator circuit.
**Figure 4.5** An instruction single-stepping circuit.

**Figure 4.6** Instruction operation-code fetch ($\bar{M}_1$) timing.
Figure 4.7 Typical LED drivers and a simple logic probe to monitor logic level changes.

a) Visible logic level indicators that can be attached to the address and data buses to provide a display.

b) A simple logic probe.
B. Reset Circuit

Often ignored, the reset function is one of the most necessary controls of a computer. Its importance is immediately recognized when running an incorrectly executing program. The reset command on the Z80 stops execution and loads the program counter with 00 hexadecimal (the lowest memory address). This allows the programmer to restart the program. When combined with the instruction single-stepping circuit previously outlined, programs may be started, stopped, and started again at any time.

A reset input can be manual, automatic, or a combination of both. Figure 4.8a is a standard push-to-reset circuit. Its output is normally high until the button is pushed, and then it goes low. The Z80 will remain reset for as long as the button is held and will only begin to execute again when released. Manual reset is a necessity for initial program checkout, and this circuit is employed in the basic ZAP.

When computers are used in applications where no human attendant is present, such as a traffic light controller, the manual reset cannot be used; an automatic reset must be employed instead. Figure 4.8b is the circuit of a totally automatic power-on reset. When power is first applied to the computer, the 10 mF capacitor will be completely discharged. The resultant logic 0 level on the input of the 7404 pin 1 will be maintained for approximately 50 ms, long after the +5 V supply has powered up the rest of the computer. The long charging rate of the capacitor will, in turn, generate a logic 0 (a reset condition) to the computer until the input level rises to approximately 2 V (a TTL logic 1). Once full power is applied, the time it takes the reset circuit to reach 2 V will constitute about a 35 ms power-on Reset pulse. Resetting the machine would require turning the power off.

Manual and automatic reset are combined in figure 4.9. This circuit allows the computer to start program execution immediately after power is turned on. The program can be stopped and restarted by pressing the reset button. Slightly different components and additional functions are included in this diagram. Schmitt-triggered inverters (7414s) increase the reliability of the design. When the power is turned off, the use of a diode to discharge the capacitor quickly assures that a pulse will be generated if power is suddenly reapplied. Because power line glitches are usually short in duration, the discharge rate of the capacitor has to be fast enough not to miss generating a reset pulse once power is restored.

While this reset circuit is not necessary for initial computer check-out, it should eventually be employed if ZAP is to be expanded to include any of the options outlined later. To synchronize the central processor and peripherals, they should be tied into the reset signal from this circuit.

![Figure 4.8](image)

**Figure 4.8** Reset circuits.

a) A manual reset circuit.

b) An automatic power-on reset circuit.
C. Address Bus and Control Output Buffering

The Z80 has the ability to directly address 65,536 (often called 64 K) individual bytes of program memory and 256 individual input and output ports. Because the microprocessor is a binary device, it is only natural that this address be binary. There are 16 binary address lines labeled A0 thru A15. A0 is the LSB (least significant bit), and A15 is the MSB (most significant bit).

The logic levels on this bus are not arbitrary. The control section of the central processor sets the program counter to the next instruction to be executed, and on the fetch cycle, it places the program counter contents on the address bus. During I/O instructions, additional timing cycles place the I/O device address on the 8 least significant bits (A0 thru A7). Because this bus has to drive the inputs of many parallel devices, all of which draw some input power, the address bus must have an output current that will meet the load demand. The Z80 by itself can sink 1.8 mA maximum or one TTL load on each pin. This is no problem if the designer uses low power memories and peripheral interface chips. These are expensive devices, and their use would not necessarily serve to educate the builder in the same way as configurations of less complex circuits.

Using lower density ICs and TTL devices for decoding functions is less expensive but requires considerably more power from the bus. The following table lists the input loading of various devices:

<table>
<thead>
<tr>
<th>Device</th>
<th>Worst case input current</th>
</tr>
</thead>
<tbody>
<tr>
<td>Standard TTL (7404, 7442, etc)</td>
<td>1.6 mA</td>
</tr>
<tr>
<td>Low-power Schottky TTL (74LS04, etc)</td>
<td>0.18 mA</td>
</tr>
<tr>
<td>2708 (1K×8 EPROM)</td>
<td>10 μA</td>
</tr>
<tr>
<td>2114 (1K×4 programmable memory)</td>
<td>10 μA</td>
</tr>
<tr>
<td>2716 (2K×8 EPROM)</td>
<td>10 μA</td>
</tr>
<tr>
<td>2102 (1K×1 programmable memory)</td>
<td>10 μA</td>
</tr>
<tr>
<td>8212 (8-bit latch)</td>
<td>0.25 mA</td>
</tr>
<tr>
<td>8T97 (6-bit driver)</td>
<td>1.0 mA</td>
</tr>
</tbody>
</table>

It is easy to see that the real power eaters are TTL devices. Low-power Schottky TTL (LSTTL) devices can be substituted throughout the ZAP computer. They save power at slightly additional cost, but the circuit has sufficient power to support straight TTL. If LSTTL is substituted, it must be substituted throughout.

The loading caused by memory, especially with only 2 K bytes in the basic ZAP unit, is insignificant. With 1.8 mA drive current available from the Z80, we could use LSTTL for the I/O and memory address decoding but would have to limit the fanout (total input connections) on each address line to 9 LSTTL inputs. This is sufficient for the basic ZAP and would probably be an
acceptable procedure, but it is not recommended.

The first time a user attaches the logic probe (figure 4.7b) to an unbuffered address line, the computer may die. The load presented by the probe, as well as by the other circuitry, will exceed the drive capability of the bus. It's important that the monitoring devices not impede circuit operation.

Rather than try to optimize the design to a degree that forces the user to be aware of every μA (microampere) consumed by test probes and LED drivers, it's easier to add buffering that increases the bus output power to a point where loading is not an important factor. This is the philosophy behind ZAP busing, and as a side benefit, it will provide enough power to expand ZAP to 64 K should the user ever desire to do so. It also allows the user to add his own TTL circuitry without becoming overly concerned with bus loading.

To achieve high power output from the address bus, a buffering device (called a non-inverting bus driver) is used. The A0 thru A15 outputs of the Z80 make only one connection: to the drivers' input. All other devices that use the address are attached to the output of the drivers.

Figure 4.10 is the diagram and truth table of the 8T97 bus driver. (An equivalent bus driver is the 74367.) This three-state device is capable of sinking 48 mA and can accommodate any combination of TTL, LSTTL, and memory connections a user would want to make. The final address bus configuration is shown in figure 4.11.

The three-state function of the 8T97 is controlled by the BUSAK signal. This signal turns over control of the address bus to an external device during direct memory access operations. In a non-DMA situation, BUSAK is high and the 8T97 passes all outputs from the Z80. When a DMA request is acknowledged, BUSAK goes low, putting the 8T97 in a high impedance output mode. This facility allows memory to be written into or read by an external device and is usually reserved for high-speed operations that are faster than the central processor can achieve.

![Figure 4.10 The pinout and truth table of an 8T97/74367 bus driver.](image-url)
D. Data and Control Bus

The fourth and last area of direct central processor connections is the data bus and the remaining lines of the control bus. The reason for buffering the data bus is similar to the argument for the address bus with one exception—the data bus is bi-directional.

A bi-directional bus means, of course, that data flows in both directions. When the Z80 is writing a byte of data into a memory location, the data flows from the central processor to memory. When the central processor is reading a memory byte, data flows from memory to the central processor. The bi-directional nature of the data bus requires that the bus drivers be either bi-directional internally, or attached in such a way that the same function is performed.

One way of making this bi-directional driver is to use two 8212s. The 8212 (figure 4.12) was originally conceived and produced by Intel as an 8-bit latched input or output port. The 8212 can be latched continuously so that data flows through it, or it can be turned off to block the flow. It is well suited to this application because it has a three-state output.

Two 8212s (figure 4.13) are wired in opposite directions. IC 6 directs data from the central processor toward memory, while IC 7 channels data into the Z80. Control is exercised through a single line connected to the RD control signal of the central processor. RD is normally low except during write operations. This causes IC 6 to be off, in a three-state mode, and IC 7 on, which allows data from memory or I/O devices to reach the central processor. When RD goes high during a write operation, the process is reversed; IC 6 turns on and IC 7 turns off. It is only necessary to use the RD line to control data direction. We're assuming, of course, that when the central processor isn't writing data, it must be reading it. While not exactly true, the concept
works well enough in practice, and the two 8212s are connected schematically as in figure 4.14.

It is not absolutely necessary to use 8212s to perform this function. Either 8T97s or 74367s work equally well but take 4 IC packages. If you don't mind the extra wiring and have a source for 8T97s, they can be wired as illustrated in figure 4.15.

The final connections to the central processor to be discussed are the control bus signals, shown in figure 4.16. They coordinate peripherals and channel data and addresses into and out of the central processor at the proper times. Each was briefly explained on the Z80 pinout. Exact timing will be detailed when we discuss attachments of memory, I/O, and enhancements to ZAP. For the time being, unused control inputs are tied high (through resistors) to inhibit false triggering.

The output lines are buffered for the same reasons as was the address bus. Furthermore, because this is a development computer, with expansion in mind, both the inverted and noninverted control signals are brought out to the user.

The areas discussed thus far are combined into a single diagram (figure 4.17) called the Z80 bus and control diagram.

**Figure 4.12** The pinout and logic diagram of the 8212 8-bit input/output port.
Figure 4.13 Two 8212s configured as bi-directional data bus drivers.

Figure 4.14 A schematic diagram of two 8212 8-bit latches configured as bi-directional data bus drivers.
Figure 4.15 A schematic diagram of a data bus driver configured with 8T97s.

Figure 4.16 Control input connections and output buffering of the basic ZAP design.
Figure 4.17 Z80 bus and control diagram.
E. Testing

Insert all ICs except the Z80 and turn on the power. Each section is then individually tested as follows:

**Clock** — Testing the 2.5 MHz clock of figure 4.3a will require an oscilloscope or frequency counter to register the exact clock rate. Using the logic probe from figure 4.7b to monitor this clock rate would light all three LEDs. This indicates that the clock functions, but it will not indicate the rate. A similar test can be performed on figure 4.3b.

**Single Cycle** — The logic probe (without the addition of the 7486 edge detector) is perfect for checking the single-cycle circuit of figure 4.4. With the probe on section C pin 8, the indication should be low. Pressing and holding the button down should change the indication to a high level and cause the “pulse” LED to flash once. Releasing the button should not flash the pulse indicator as it returns to its initial logic condition.

**Single Step** — With the switch in the single-step mode position (figure 4.5), take a clip lead and momentarily ground IC 3, pin 3. The output at IC 1, pin 8 should be low. Pressing the single-step button will cause this output to go high. It will stay high until IC 3, pin 3 is momentarily grounded again. Check out the pushbutton debouncing circuit (which consists of IC 1 sections a and b) in the same manner as you did the single-cycle test. Finally, with the switch on the run mode, IC 1, pin 8 should always be high.

**Power-on Reset** — The circuits of figures 4.8a and 4.8b should have a normally high output. When power is first applied to figure 4.8b, or the button pressed in figure 4.8a, the output should go low. Either situation will cause a logic low level to occur from the circuit of figure 4.9.

**Address Bus Drivers** — *The Z80 should not be inserted!* With IC 9, pin 5 grounded, all outputs of ICs 3, 4, and 5 on schematic figure 4.11 should appear high. In actuality, this will be the three-state output mode and the proper test equipment will register them as open circuits. Tying IC 9, pin 5 to +5 V through a 2.2 K resistor will turn on all the bus drivers. Their outputs will all be logic high levels. Successively grounding the A0 thru A15 lines at the Z80 connector should result in a low-level indication on the respective buffered output line. When all 16 lines can do this successfully, the address bus checks out.

**Bi-directional Data Bus** — The data bus is tested in a similar manner except that the procedure is done twice—for data flow in either direction. Grounding IC 8, pin 1 (figure 4.14) simulates a read condition. Data should flow from right to left. Applying ground and +5 V (through a 2.2 K resistor) alternately to the data input pins of IC 6 should produce similar levels on DO1 thru DO8 of IC 6. Raising IC 8, pin 1 to +5 V allows similar data transfer, but only from left to right this time.

**Control Bus** — Referring to the schematic of figure 4.16, testing is simply a case of applying a known logic level to the input side of the series inverters and noting the output levels one gate at a time. For example, if Z80 pin 19 was a logic low, IC 9, pin 2 would be a logic high and conversely, IC 9, pin 4 would be low. Each inverter section which the signal passes through inverts the signal.

II. Memory and I/O Decoding

Before we can utilize the memory or I/O devices we must learn how the Z80 addressing works. Remember, the address FF hexadecimal could refer to memory, or an input or an output port. The computer must have the ability to differentiate among the three
possible meanings.

The control outputs of the Z80 contain the necessary routing information, and by properly gating them together, the correct signals are obtained. For basic I/O and memory operations, the four signals of particular interest are MREQ, IORQ, RD, and WR. Their definitions are as follows:

A. **MREQ**
   Memory Request. Whenever a transaction occurs between the central processor and memory, the MREQ line goes to a logic 0.

B. **IORQ**
   Input/Output Request. Whenever a transaction occurs between the central processor and either an input port or an output port, the IORQ line goes to a logic 0.

C. **RD**
   Read Request. Whenever the central processor reads input data from either memory or an input port, the RD line goes to a logic 0.

D. **WR**
   Write Request. Whenever the central processor is writing data to either memory or an output port, the WR line goes to a logic 0.

To differentiate between input and output ports during I/O instructions, IORQ, RD, and WR are gated together as shown in figure 4.18. In a similar manner, MREQ, RD and WR are gated during memory transfers as shown in figure 4.19. Unlike the I/O decoding, but similar to the address bus driver discussed earlier, a memory-read condition does not have to be decoded. It is assumed that when the memory is not in a write mode, it is in the read state.

The resulting three decoded strobes define the operations of Input Port Read (IORD), Output Port Write (IOWR), and Memory Write (MEMWR). If only three functions were required in your particular computer configuration, then no other decoding would be necessary. Such a computer would have one input port, one output port, and one bank of memory. To alleviate this problem, additional decoding of I/O and memory is necessary so that these control strobes can serve more than a single device. With the extra circuitry, the Z80 can independently address 256 input and output ports and 64 K bytes of memory.

During an I/O request (either input or output), the 8-bit binary address of the particular I/O port appears on lines A0 thru A7 of the address bus. An explanation of address coding is shown in figure 4.20. Additional examples are illustrated in figure 4.21.

Using this information, if an instruction were to designate output port 7 as its destination, then the circuitry of figure 4.22 could be used. When a code of 007 octal (07 hexadecimall or 00000111 binary) appears on the address lines with an IOWR strobe, the signals present on the data bus would be stored in an 8-bit register as output data.

![Diagram of I/O decoding](image)

**Figure 4.18** Input/output read and write decoding.

106 BUILD YOUR OWN COMPUTER
Figure 4.19 Memory read and write decoding.

Figure 4.20 An explanation of input/output address codes.

Figure 4.21 Address decoding logic.
   a) For address FF16.
   b) For address 0016.
Figure 4.22 A possible method for decoding a single 8-bit output port address. The circuit is for a 007 device code.

I/O Decoding

Of course, ZAP needs more than 1 port, even as a basic system. In fact, if it is expanded to include some of the optional peripherals, it will require 6 or 8 ports. Decoding these additional ports need not require 8 separate circuits like figures 4.20 or 4.21. By incorporating a 4 to 10 line demultiplexer into the design, 8 port strobes can be derived. The circuit of figure 4.23 can be used for either input or output port decoding (by selecting RD or WR) and is addressed for 000 octal to 007 octal. It works by selecting either of the two unconnected outputs (IC 3, pin 9 or 10) when an undecodable address is presented on the address bus. A3 thru A7 still must be treated in the same manner as that presented in figure 4.20, but A0 thru A2 serve as the 7442 address inputs. These 3 bits will designate 1 of 8 possible lines when IC 1's output goes low.

Duplicating this circuit to provide 8 separate input and output stobes (addressed 000 thru 007) would require a total of 7 chips. The number of chips can be reduced to 3 if we take a little poetic license with the design. So far, we have decoded all 8 bits of the I/O portion of the address bus, making our decoder select 1 of 256 or, as in the previous circuit, 8 of 256. In either case, only the designated addresses are of any importance; all others are meaningless. For all practical purposes we could decode lines A0 thru A2 and ignore the rest. A circuit that does just that is shown in figure 4.24.

The difference between this circuit and those previously described, besides having fewer chips, is that this one requires an intelligent user to recognize the advantages and disadvantages of taking such liberties. As in figure 4.23, this circuit decodes ports 000 octal thru 007 octal. What the user should realize, however, is that it also decodes 010 thru 017 and 020 thru 027, etc. The 3 LSB (least significant bits) repeat every 8 ad-
dresses. This is not a problem as long as the user is aware of repetitive addressing and watches his programming. Should more than 8 stobes be required, the 7442 can be replaced with a 74154 (4 to 16 decoders). This will give 16 I/O port stobes that repeat every 16 addresses.

Figure 4.23 A formal input/output port address decoding method that decodes all 8 address lines.

Figure 4.24 A method for decoding input/output stobes with a reduced amount of circuity.
Memory Decoding

Decoding the memory address bus is accomplished in a similar manner. It is inadvisable to take the same tack and allow repetitive memory addressing because there is more likelihood of error. Even though 16 lines are involved, in actual application, memory decoding turns out to be less complicated. ZAP uses 1 K × 8-bit banks of programmable memory and 1 K-byte erasable read-only memory. Both of these devices require 10 address lines to define the 1 of 1024 locations in each bank. This leaves only 6 lines that have to be individually decoded to define any 1 K block of memory. Figure 4.25 illustrates how this can be accomplished. A 7442 (4- to 10-line decoder) is used to generate 8 separate chip-select lines. Because the address lines of the 7442 are tied to A10 thru A12, each strobe pulse will have a boundary of 1 K. It is not by chance that 1 K × 8 was chosen as the memory capacity of each bank.

Figure 4.25 Memory bank decoding for 8 K of memory.

While the basic configuration of ZAP provides decoding for 8 K of memory and 8 input and output ports, not all of these chip selects and port strobes are used. The extra lines are left for expansion. Figure 4.26 is a completed schematic of the I/O and memory decoder for the builder to add to the circuit in figure 4.17.
Testing

After you have added the components of figure 4.26 to figure 4.17, you are ready to test the memory and I/O decoding. Insert ICs 10, 11, 12, 13, and 14, but don't insert IC 20 yet. ICs 1, 3, and 9 should remain inserted from the previous test. The Z80 should still be left out. The logic level at the D address input of each of the 7442s (ICs 12, 13, and 14) should be high. Pulling out ICs 8 and 9 (with power off) will cause this input to immediately change to a logic low level.

Next, ground pins 30, 31, and 32 and tie 23 high on the Z80 socket. With the address bus buffers enabled, and a 000 address jumpered on A0 thru A2, a chip-select low should appear on the lowest strobe address. In this case, pin 1 of ICs 13 and 14 should be low and the other strobe lines high. Changing the 3 jumpers on A0 thru A2 will enable other device chip-select strobes. The memory bank decoder works the same way except that the jumpering should be applied to address lines A10 thru A12.

After testing, insert all chips except the Z80.

Figure 4.26 The memory and input/output decoding section of ZAP.

a) Memory bank chip-select strobes.

b) Input/output device chip-select strobes.
III. Memory

Of course, a major consideration for any computer system is memory. Both program instructions and data must be stored and recalled at the appropriate time so the computer can perform its function. Even though the Z80 central processor has a quantity of 8-bit storage registers, these can be only used for temporary manipulation of data and cannot store program instructions. Program instructions must be stored in external memory elements.

The external memory may be divided into two broad classes: ROM (read-only memory) and RWMM (read/write memory). ROM is used to store specific, unchanging program steps or data. The contents of these memory locations are considered permanent and cannot be easily changed. Read/write memory, on the other hand, is used to store data that changes while the computer is operating. Examples would be the results of calculations or programs that change frequently. For either type of memory, the ultimate function is still the same: to provide, on demand, either an instruction for execution or a location where data may be stored.

Read-Only Memory

ROM (read-only memory) is an important part of the computer system. ROM functions as a memory array whose contents, once set by special programming techniques, cannot be altered by the central processor. There are few exceptions to this rule.

By its nature, ROM is non-volatile. When power is turned off, the program contents are not lost. Reapplication of power allows immediate program execution.

Within this basic category of ROMs there are three subcategories — ROM, PROM, and EPROM — which are defined more by usage and application than their names might imply.

ROM — Read-Only Memory
This is storage which can be written into only once. The information is fixed and cannot be changed. A ROM is usually mask programmed by the manufacturer and is bought with a preset bit pattern. These types of ROMs are considered to be custom programmed.

PROM — (User) Programmable Read-Only Memory
This storage can also be written into only once and the information is fixed. These devices are typically bipolar fusible link PROMs, which are programmed by the user rather than the manufacturer. ROMs and PROMs do not generally use the same semiconductor construction technology. Storage is much denser on a ROM than on a PROM, and cost-per-bit is generally lower on a ROM.

EPROM — Erasable-Programmable Read-Only Memory
This device combines the best parts of a ROM and a PROM. When received from a manufacturer, all storage locations are unprogrammed. Using a special interface, the EPROM can be programmed by the user as a PROM would be, with the result utilized as a ROM. If the EPROM content must be changed, it can be erased and reprogrammed. Depending upon the particular device, an EPROM can be either electronically alterable (often differentiated by the separate abbreviation EAROM) or ultraviolet erasable. The latter is sometimes called a UVEPROM, but is more often just called an EPROM. They are easily recognizable because they have a quartz window over the integrated circuit. This window is transparent to ultraviolet light and facilitates erasure.

While there can be considerable discussion as to the merits of each option, all ROMs perform the same ultimate function. For each independently addressable location, there is specific stored-bit pattern. Only the processor can determine whether this is data or an instruction. The method of storage is the same in either case. Figure 4.27 details the block diagram of a ROM.

A ROM is simply a logical block which, under program control, provides a preset
pattern. Figure 4.28 is a 3-bit read-only memory. When switch SW1 is closed (the position it would take when the central processor wanted the stored information), the 3-bit code of "101" would appear at the outputs. The diode grounds the input signals to the 7404 inverters when SW1 is closed. Expanding to more than 3 bits is simply a matter of adding more diodes, resistors and buffer stages. Such a circuit is referred to as a diode-matrix ROM and in this case would be a 1-line by n-bit ROM.

A 3-bit memory is not much use. This concept can easily be expanded to 16 bytes by adding an address decoder as diagrammed in figure 4.29. A completed schematic with the diodes specifically arranged to perform a simple 9-byte program is illustrated in figure 4.30. This short test program will be used later during the checkout phase.

The diode-matrix ROM is presented for its educational value only. This is not a method that should be employed in the ZAP computer. Realizing that there are integrated circuits that would successfully fulfill the requirements in each of three categories, we must analyze our needs a little more closely.

The pertinent questions are: memory size, and the cost and ease of programming. The size of a ROM is determined by the user. When power is first applied, how much effort does the user want to expend to make the computer execute a specific program? ZAP has no front panel and no banks of address and data switches to toggle in instructions. Being the case, ZAP must have a program that executes immediately (when power is applied or the reset button is pushed), and that allows the central processor to communicate with its peripherals and set itself in a mode that is directly programmable through these devices. Once power is applied, a simple 50- to 100-byte program can be written, which facilitates keyboard to memory loading. But perhaps we need to enter a large program in memory? Are we to enter it all through the keyboard?

High-speed data entry can be accommodated through a serial interface. This can be added at the expense of another 100 or 200 bytes. Another consideration is the necessity for some operator address and data display to ease program development.

In conclusion, to incorporate all the functions necessary for a single-board development system, the ROM can easily require 500 to 1,000 bytes of storage. Many computer systems use a 64- to 256-byte ROM to store a bootstrap program. A bootstrap program that coordinates the minimum amount of necessary peripherals to load a larger program into the computer. In most personal computer systems, this bootstrap controls a cassette interface, and the program that is subsequently loaded is called a monitor.

A monitor (explained in Chapter 6) is a very important piece of software that requires about 1 K of program storage. Our decision is whether to make the monitor totally resident in ROM (ready for immediate execution), or to reduce ROM to the barest minimum and load the monitor from either a keyboard or a cassette storage system.

This is an important consideration for someone building a computer from scratch. When given a choice, I feel, you should almost always opt for the solution that calls for the fewest components and you should include the ROM monitor in the hardware. It's like putting the cart before the horse to require that a cassette interface be used to load all the diagnostic software. It's quite possible that the monitor program, resident in a 1 K ROM, would be required to troubleshoot and align the serial interface and cassette modem sections. A further consideration is that the ZAP computer can be brought on line sooner. With a ROM monitor, useful programs can be entered via the keyboard without having to build a serial interface.

I suggest that the preferred ROM memory size for ZAP be 1 K. As previously mentioned, ROM is mask-programmed by the manufacturer. However, let's not forget that for a home-built computer, you are the manufacturer. Fusible link PROMs are an expensive proposition when configured in a 1 K block. As a 64-byte bootstrap loader they are ideal.

The suggested alternative for the ZAP read-only memory is to use an EPROM that is programmed by the user. A 1 K EPROM such as the 2708 (or the 2 K 2716) is cost-effective for the home-built computer. The Intel 2708 ultraviolet erasable read-only memory is recommended for this application. (The 2716 is a 2 K EPROM with a single +5 V power supply.)
**Figure 4.27** A block diagram of a read-only memory.

**Figure 4.28** A simple 3-bit read-only memory (1 × 3 bits).

**Figure 4.29** A block diagram of a 16-byte read-only memory.
Figure 4.30 A diode-matrix read-only memory with a test program.

EPROMs

The EPROM is a read-mostly memory. It is used as a ROM for extended periods of time, erased occasionally and reprogrammed as necessary. Erasure is accomplished by exposing the chip substrate, covered by a transparent quartz window, to ultraviolet light. The EPROM memory element used by Intel in the 2708 is a stored-charge type called a FAMOS transistor (Floating-gate Avalanche injection Metal Oxide Semiconductor storage device). It is similar to a p-channel silicon gate field-effect transistor with the lower or "floating" gate totally surrounded by an insulator of silicon dioxide. The 1 or 0 storage value of the FAMOS cell is a function of the charge on the floating gate. A charged cell will have the opposite storage output of an uncharged cell. By applying a 25 V charging voltage to selectively addressed cells, particular bit patterns that constitute the program can be written into the EPROM. Surrounded by insulating material, the charge can last for years. When this silicon dioxide insulator is exposed to intense ultraviolet light it becomes somewhat conductive and bleeds off the charge on the floating gate. The result is erasure of all programmed information.

Appendices C1 and C2 detail the pin layout and electrical specifications of the 2708 and the 2716 respectively. Chapter 7 explores various methods to program and test the chip.
Read/Write Memory

Read/write memory is just what its name implies. Such memory allows data to be written into it as well as be read from it. Read/write memory for microcomputers is generally configured from semiconductor programmable memory devices that retain data only while the power is on.

ROMs are technically random access devices; however, read/write memory, which is composed of semi-conductor devices and is primarily intended for use in microcomputers, has come to be called RAM (random access memory). From this point on, we shall refer to RAM as programmable memory.

There are two classes of programmable memories: static and dynamic. Static programmable memory stores each bit of information in a bi-stable storage cell such as a flip-flop. This information is retained as long as the power is supplied to the circuit. Dynamic programmable memories have a simpler internal structure, smaller size, dissipate less power, and are inherently faster. They store information as an electric charge on the gate to substrate of a MOS transistor. This charge lasts only a few milliseconds and must be refreshed. This necessity to refresh the stored information is one of the major distinctions between static and dynamic programmable memories.

Refreshing dynamic memories can be bothersome, however. The process requires that all storage cells be addressed at least once every few (usually 2) milliseconds. A counter circuit is usually incorporated to exercise the memory address lines when the computer is not accessing memory. In most systems, memory refresh requires additional external circuitry. The Z80 contains this circuitry within the central processor chip and greatly facilitates the use of dynamic memory. However, this facility is lost when the Z80 is reset. Therefore, extra refresh circuitry is necessary.

The choice between dynamic and static programmable memory technology is predicated on cost and convenience. Even with the expense of external refresh circuitry, dynamic memory is less costly. In a prototype system such as ZAP, however, dynamic memory is more trouble than it is worth. Once built and operational, dynamic memory might well be the best answer to memory expansion. But at this point in the building process, the inclusion of dynamic memory would over-complicate the design. This book, which emphasizes getting a beginner on-line, deals exclusively with semiconductor static programmable memory applications.

Static Programmable Memory

Figure 4.31 is a block diagram of a static programmable memory element typical of the type used in the ZAP computer. There are five basic components of a programmable memory: 1) address input lines, 2) data input, 3) data output, 4) chip select, and 5) a read/write- or write-enable strobe line. The address input lines are connected to the address bus of the computer. In the case of a N by M bit programmable memory, where N is the number of words and M is the length of each word, there must be enough address lines to address all N bytes. For example, in a 1 K programmable memory it would take 10 bits to address all 1024 bytes within this memory (eg: $2^{10} = 1024$). Static programmable memory chips that contain fewer bytes of data, such as a 64-byte programmable memory, would obviously require fewer address lines. For a 64-byte memory, only 6 bits of address are necessary.

Because the function of a static programmable memory device is to allow storage and retrieval of data, provisions must be made for data input and data output from the device. The data input and data output lines (shown in figure 4.31) are designated as separate functions.

During the read function, the stored data within the addressed memory cell is available on the data output lines. During the write function, data that is placed upon the data input lines would be stored at the address designated by the code on the address input lines. It is not necessary that static programmable memory devices have independent data input and data output lines.

In most cases, these devices are configured with three-state outputs. Data input and data output can be attached together to a bi-directional data bus, or they can be the
same lines and time multiplexed. Figure 4.31 illustrates a three-state method of data busing. During a read function, the data input lines are disabled internally within the memory device. The contents of the memory cell addressed by the address input lines are available on data out and are fed directly to the bi-directional data bus. During a write function, the opposite is true. The data output lines are set in the three-state mode (which you may recall is effectively an open circuit), and draw no current from the bi-directional data bus. The contents of the bi-directional data bus are stored at the designated memory cell.

All of these multiplexing functions are dependent upon the read/write and chip-select lines. No operation can occur without the memory device being selected through the chip-select line. To select a particular bank, as outlined earlier, it is necessary to have decoding logic that enables these banks through the chip-select lines. Once a chip or bank of chips has been selected, the computer determines whether data should be read from or written into these memory locations. Under normal operation all static programmable memory is left in the read state, and only enabled during a write command by setting a level 0 on the write enable. This is called a write-enable strobe.

Figure 4.32 is a detailed timing diagram of the memory read and write cycles. The write/enable is a combination of memory request and write. A read/enable is a combination of memory request and read. Proper decoding of these signals and the chip select were discussed previously. In its basic form, ZAP has 8 chip-select lines, each addressing a 1 K bank of memory.

Figure 4.33 illustrates the memory map of the basic ZAP computer. As initially configured, ZAP contains 3 K bytes of memory. Location 0 thru 3FF is a 1 K EPROM. Locations 400 thru BFF are static programmable memory locations. The 1 K EPROM is configured to reside in locations 0 thru 3FF so that ZAP can be easily started with a power-on reset. Programmable memory located at locations 400 and above is considered to be user programmable memory. At least 2 K is recommended for satisfactory operation. ZAP will work with 1 K, but 2 K is recommended for basic peripheral expansion.

Figure 4.33 also shows how memory is attached to the computer. All three banks of memory are attached in parallel between the address and data buses. Each bank has a separate decoded chip-select. When the EPROM is enabled and MCS0 is at a logic level 0, EPROM data is impressed upon the data bus lines. The other two banks of memory are in the three-state mode and have no effect on the bus. When the computer accesses programmable memory, the chip for that particular bank of memory is set to a logic 0, and only that bank of memory has access to the data bus.

While all banks of memory would have the same address applied to them, only the selected bank would be in the active mode. The logic flow is similar for the computer to write into a bank of memory. You will notice that there are write-enable lines leading to each of the 1 K static programmable memory banks, but not to the 1 K EPROM. A 1 K EPROM can only be written into with a special interface. Therefore, the write-enable strobe is only attached to the programmable memories.

If, for example, the computer were to write into location 400, the chip-select for bank 1 and the write enable for bank 1 would both have to be at a logic 0 to allow data on the data bus to be stored into location 400. This type of programmable memory configuration is both multiplexed and three-state. In the read mode, data flows from the programmable memory chip; in the write mode it flows into it, and when not selected it's three-state.

Up to this point, we have discussed block diagrams of static programmable memory. To produce an operational computer, it's necessary to configure this memory with actual parts. Unfortunately, single chip 1 K by 8-bit programmable memories were extremely expensive when ZAP was designed. Therefore, these 1 K blocks are designed from multiple components. Two relatively inexpensive and popular static programmable memory chips are the Intel 2102A (Appendix C3) and the Intel 2114 programmable memory (Appendix C4).

The 2102A is a 1 K × 1 static programmable memory. Configuring a 1 K × 8 block of memory requires eight 2102s attached in parallel. By comparison, configuring a 1 K × 8 block with 2114s would require only two chips. This is because the 2114 has a higher internal density than the 2102. Because the objective of any hand-wired comput-
er project is to get the device on line easily, 2114s are the recommended programmable memory devices for ZAP. While 2102s will work, the added wiring necessary to use these devices far outweighs the additional cost of the 2114s.

Figure 4.34 illustrates how two 2114s are attached together to produce a $1 \times 8$ programmable memory bank. They share a common chip-select line. The data input lines are divided so that 4 bits of data are stored on each chip. Because each has a 1024-byte address capability, the 10-bit address lines are commonly shared. To build the basic ZAP, two circuits of the type illustrated in figure 4.34 should be constructed. The total memory for the basic computer is 3 K. It can be expanded to 8 K without additional address decoding. It is not absolutely necessary to have 2 K of programmable memory if the user wishes only to check the operation of the system. At a minimum, the EPROM must be wired as 1 bank of memory.

The 1 K EPROM contains the monitor which allows ZAP to function. This monitor contains many smaller programs that are called subroutines. When the main program calls a subroutine, it places the return address on a software stack located in programmable memory. At the conclusion of the subroutine, the central processor pulls this address from the stack and returns to the main program. Usually the stack requires no more than 64 bytes. However, it is no less trouble to wire two 2114s for a full $1 \times 8$ bank of memory than to try to wire a 64-byte memory.

An additional bank of 1 K, designated as bank 2, could be added at the user's discretion. This bank is necessary if you plan to write programs that will occupy more than 1 K of memory including the stack. As the computer is presently configured, 1 K may appear adequate; however, for the additional programs outlined in this book, 2 K is recommended. This is especially true when a buffer area is required to communicate with external peripherals. The schematic for the final memory configuration is shown in figure 4.35. It should be added to the circuitry of figures 4.17 and 4.26.

Unlike the other sections of the computer, the memory cannot be checked except under program control. Theoretically, the address lines can be preset and data read or stored, but it's not worth the effort. Memory checks will occur after the input/output section is wired. Basically, it will be checked first with EPROM alone, then with the addition of the programmable memory. I mentioned previously that EPROM and programmable memory are related yet operate independently. While a program is often stored in PROM, it usually requires programmable memory for proper execution.

In a short program that loads the accumulator, writes to an output port, and jumps back to itself again, with no subroutine calls, programmable memory is not necessary. It can be completely located on EPROM. The exact procedure for this test will be outlined at the end of the I/O section.

---

**Figure 4.31** A block diagram of a static programmable memory element of $N \times M$ bits.
Figure 4.32 A timing diagram of the memory read or write cycles for the Z80. This diagram does not include 'WAIT' states.

Figure 4.33 A block diagram of the memory map for the ZAP computer.
**Figure 4.34** A 1 K x 8 programmable memory bank constructed by using two 2114 1 K x 4-bit programmable memory chips.

**Figure 4.35** A schematic diagram of the final memory configuration for the basic ZAP computer.
IV. Input/Output

Thus far we have discussed the central processor control and memory decoding. The input and output functions are equally important. For the computer to display useful information, it must be "interfaced" to peripherals. "Interface" is an overworked term that refers to a capability of communicating with external devices such as keyboards, video or LED displays, and memory storage systems. Communication can be either data input or output.

Input data can come from keyboards, audio cassette mass storage, or special data acquisition interfaces. Similarly, output data flows from the computer to peripherals (e.g., video displays, numeric readouts, printers, and external control interfaces). The function and format of the data communication between the central processor and the peripherals might vary considerably, but the internal routing of the data is fundamentally the same.

The Z80 microprocessor provides both an input and output instruction. An output from the processor is logically the same as writing to memory, and receiving an input from an external device is similar to a memory-read command. They are differentiated from memory operations by gating the read and write status lines with the I/O request control line. Logical concurrence of an I/O request and a read or write status output designates the direction of the communication with the peripheral device. Simultaneously with the control signals, the address code (1 of 256) of the subject device is placed on the address bus. A timing diagram of these signals is shown in figure 4.36. The decoding logic was detailed in section II of this chapter.

Wiring the I/O ports for ZAP is a two-stage process. When hand wiring a computer, the most important consideration is to see that the input/output function works by the least complicated method. A successful test of the ZAP I/O section also indirectly tests memory. This is so because input and output instructions cannot be exercised except by a program stored in memory.

Z80 input and output is handled 8 bits at a time. It does not matter whether the external interface configuration is serial or parallel. Data transfer between the central processor and I/O is 8 bits parallel and basically occurs as follows.

![Timing diagram of input or output cycles for the Z80.](image)

Figure 4.36 A timing diagram of input or output cycles for the Z80.
Output Instruction

\[ \text{OUT}(n), A \]

When this instruction is executed, the contents of the accumulator A are placed on the data bus and written into device n. The address of device n is located on address lines A0 thru A7.

If the accumulator contains 40 hexadecimal when the instruction OUT 23, A is executed, 40 hexadecimal will be written into the peripheral device (also called "port number") decoded as 23 hexadecimal.

While there are other more complicated output instructions available in the Z80 instruction set, they all pass data through the data bus to the external device. Because the data bus is used for transfer of information between the central processor and memory as well as I/O, the computer must be allowed to continue executing its program. Data cannot remain on the data bus waiting for the peripheral (the central processor can be made to do this but such abstract configurations would be confusing at this time). The data is valid for only a few clock cycles and must be stored if needed for a longer period.

Figure 4.37 diagrams a typical 8-bit storage register. It consists of 8 individual storage elements with a common "store enable" input. In its simplest form, the single storage cells can be D-type flip-flops such as shown in figure 4.38. Input data (i.e. the data bus) is attached to the D input lines and is only clocked onto the output lines (Q and \( \overline{Q} \)) during an I/O write strobe. Using 7474s would require 4 chips for an 8-bit word. A better method is to use the improved circuits of figure 4.39.

Input Instruction

\[ \text{IN} A, (n) \]

When this instruction is executed, the data from the selected port (n) is placed on the data bus and loaded into the accumulator.

If the subject external device reads 10 hexadecimal when the instruction \( \text{IN} A, 20 \) is executed, the value 10 hexadecimal read from device number 20 hexadecimal would be loaded into the accumulator.

There are other more complicated input instructions but as was the case with output instructions, the route for all data is still the data bus. To keep the data bus from being dominated by a single device attached to it, all input devices (i.e. the output from them) must be three-state. This can be accomplished either by using interface logic such as UARTs and peripheral interface adapters that are designed to be three-state, or by adding three-state input buffers such as illustrated in figure 4.40 (the block diagram of the typical 8-bit, parallel-input port).

Whatever is on input lines B9 thru B1 during an I/O read instruction will be directed to the central processor. Using these direct read instructions there is no interaction between the central processor and the external hardware attached to the input port. Additional logic is required to coordinate the exact timing between the computer and an external peripheral. The solution is called "handshaking." Such a capability requires either more sophisticated input port hardware, connection to the central processor, interrupt logic, or additional I/O ports to coordinate the timing.

Checking out the basic ZAP hardware is best accomplished by using the least complicated hardware. A simple input port is illustrated in figure 4.41 and consists of 2 quad three-state buffers. Should there be any brave experimenters who wish to have full handshaking on I/O ports or need more than the 8 mA output drive capabilities of a LSTTL device, input and output ports can easily be configured using Intel 8212s. The specifications described in Appendix C5 demonstrate its versatility.

Input/Output Checkout

Ultimately, ZAP could have a keyboard, RS232 serial CRT terminal, audio cassette interface, and analog, as well as digital I/O capabilities. Trying to attach all these pe-
ripherals together and checking everything simultaneously is a monumental undertaking. A more methodical approach is to construct the minimum hardware and software that proves operational and then build upon it. That is the route taken thus far.

With the exception of memory, we have attempted to eliminate any potential problems by static testing where possible. The simple I/O devices of figures 4.39 and 4.41 lend themselves easily to this situation. To test I/O fully requires one input port and one output port. It should be wired as shown in figure 4.42. Only port 0 need be connected at this time. The additional circuitry included in this diagram can be ignored. Only ICs 21 thru 23 are of concern presently. The other devices are enhancements to the basic ZAP and will be discussed later.

**Static Test**

With power off, remove all ICs previously installed. Insert ICs 20, 21, 22, and 23. Turn on power. Temporarily ground DSOWR and DSORD. This maneuver, impossible under direct computer control, allows data bus access to both input port 0 and output port 0 at the same time. With the two ports connected in this manner applied input data should be available immediately at the output port. With the input lines of ICs 21 and 22 open and power applied, the outputs of IC 23 should be at a high level. Sequential grounding of input lines B3 thru B7 should be reflected on lines B3 thru B7 of IC 23. A final test is to disconnect the temporary ground on DSOWR while one of the input lines of IC 21 and 22 is grounded. The logic 0 output of IC 23 should remain low even when the input line is no longer grounded. The result is that the data is "latched." It will remain until updated by another write strobe.

---

![Diagram](image)

**Figure 4.37** A block diagram of a typical latched parallel output port configured with an 8-bit storage register.
Figure 4.38 A block diagram of a latched parallel output port using D-type flip-flops as a storage register.

Figure 4.39 Schematic diagrams of 8-bit latched parallel output ports.

a) Using two 4-bit LSTTL latches.

b) Using a traditional 8-bit TTL latch. Note that non-LSTTL devices can be substituted but care should be taken to observe the total bus loading.

c) Using a newer 8-bit LSTTL latch.
Figure 4.40 A block diagram of a typical 8-bit parallel input port.

Figure 4.41 A schematic diagram of an 8-bit parallel input port for the ZAP computer.
Figure 4.42  A schematic diagram of a parallel input/output ports of the basic ZAP computer with additional enhancements required for use with the ZAP monitor software.
V. Dynamic Checkout of the Basic Computer

All systems, with the exception of memory, should have successfully passed the static checkout procedures. The memory wiring should be checked for continuity. Because ZAP has no front panel or indicator (unless you wish to add one), the full system can only be tested by executing a program that dynamically exercises all the system hardware. This is easier than it sounds. For the computer to output a number to a specific port address, the central processor must be operational and have reset properly to execute the instruction. The memory read must work or the central processor wouldn’t know what to do. The memory and I/O decoding must work for the data stored in memory to arrive at the right output port. And finally, for the data to be read at the port, the output port must function as well. In short, if you can execute a program, the computer works.

We can make the process simpler by using the fewest program steps possible and by initially eliminating the necessity for programmable memory. Remember, ZAP has both EPROM and programmable memory. With no monitor or front panel, programmable memory cannot be loaded directly to run a test program. The test program must be already loaded in ROM (in our case EPROM). By carefully selecting the instructions used in the test program, programmable memory can be left out entirely when we run the first test. Why complicate matters by having more hardware than is necessary?

Few instructions are required to test the operation of the processor, reset, memory and I/O. Usually the central processor either works or it doesn’t. Central processor failure is rarely a case of one of the instructions executing improperly. If ZAP can read in data at port 0 and output the same value to output port 0, we can assume it all works. For the data to reach output port 0, it must travel through the central processor (assuming you have removed the temporary grounds on the I/O strobe lines) under program control.

Such a test program is:

<table>
<thead>
<tr>
<th>OCTAL</th>
<th>HEXADECIMAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>IN A, 0</td>
<td>333 000</td>
</tr>
<tr>
<td>OUT 0, A</td>
<td>323 000</td>
</tr>
<tr>
<td>JP NN</td>
<td>303 000 000</td>
</tr>
</tbody>
</table>

This 7-byte program will read input port 0 data into the accumulator and then write this same data to output port 0. The jump instruction will cause the program to repeat this action continuously. The program requires no programmable memory to store either intermediate data or the stack pointer. Because only the accumulator is affected, the 7-byte program can be completely contained in ROM. In this case, ROM can be either a 2708 EPROM programmed manually as described in Chapter 7 or a simulated ROM as shown in Figure 4.30. If you use a simulated ROM, it may be necessary to reduce the 2.5 MHz clock rate to compensate for the capacitance of the external circuitry. Figure 4.30 also includes an output to port 5 that tests a data display to be added later. Rather than rewrite the EPROM or rewire the pseudo-ROM, you may wish to add this instruction now.

The final test of the basic ZAP is to exercise a program that uses both programmable memory and EPROM. Again, the philosophy is that if it can store and retrieve 1 byte from programmable memory, then all 1 K of that bank should work. A slightly longer program is used this time. The following program is stored in EPROM and the programmable memory is used by the central processor to store the stack:

<table>
<thead>
<tr>
<th>OCTAL</th>
<th>HEXADECIMAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>LD SP, nn</td>
<td>061 000 006</td>
</tr>
<tr>
<td>IN A, 0</td>
<td>333 000</td>
</tr>
<tr>
<td>CALL TEST</td>
<td>315 014 000</td>
</tr>
<tr>
<td>OUT 0, A</td>
<td>323 000</td>
</tr>
<tr>
<td>JP nn</td>
<td>303 000 000</td>
</tr>
<tr>
<td>TEST RET</td>
<td>311</td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</tbody>
</table>
When assembled, the 14-byte program would be loaded as follows (in hexadecimal):

<table>
<thead>
<tr>
<th>Location</th>
<th>Program</th>
</tr>
</thead>
<tbody>
<tr>
<td>00/00</td>
<td>31 00 06</td>
</tr>
<tr>
<td>03</td>
<td>DB 00</td>
</tr>
<tr>
<td>05</td>
<td>CD 0D 00</td>
</tr>
<tr>
<td>08</td>
<td>D3 00</td>
</tr>
<tr>
<td>0A</td>
<td>C3 00 00</td>
</tr>
<tr>
<td>0D</td>
<td>C9</td>
</tr>
</tbody>
</table>

The operation of this program is similar to the previous example. A byte is read from input port 0 and then read back out to output port 0. In between these operations there is a call to a subroutine that is just a return instruction. When the call is executed, the location where the program is to resume operation after the call is put on the stack in programmable memory. At the conclusion of the call (the return instruction), the address is popped off the stack and placed in the program counter so that the program can resume where it left off. The only way for the input data from input port 0 to get to output port 0 is for this call to be executed properly. Of course, this requires that programmable memory work properly.

Many other programs that would further enhance the diagnostic checkout procedures can be written. In my experience, however, if it executes these two programs, you can count on everything running.

Once these milestones are reached, the experimenter has a truly operational computer. The next step is to expand this basic unit and make ZAP somewhat more versatile by adding address and data displays, a hexadecimal keyboard, a serial interface, along with an operating system that coordinates the activities of these peripherals. While the present system is a computer, these additions are necessary to move beyond an experimenter's breadboard project.
CHAPTER 5

THE BASIC PERIPHERALS

Once the basic ZAP computer has been constructed and tested, we are ready to add a few necessary peripherals that will greatly increase the system's utility. External peripherals facilitate the input and output capabilities of the computer. They include such items as printers, cathode-ray tubes (CRTs), tape drives, and disks. Peripherals of this magnitude, however, are usually used on larger systems. For our Z80-based ZAP, useful peripherals include a keyboard to ease data and program entry; a visual display to allow the computer to indicate a logical conclusion in readable form; a serial communications interface, which allows ZAP to "talk" to another computer; and an interface to an audio cassette mass storage device. These four ingredients are the difference between an experimental breadboard and a useful personal computer.

The keyboard can be either a small keypad for limited data entry or an alpha-numeric "typewriter"-style ASCII (American Standard Code for Information Interchange) keyboard for text editing and high-level language programming. The visual display could range from a hexadecimal LED readout to a full 24-line by 80-character CRT terminal. The serial port, in conjunction with the audio cassette interface, could be used to cold start the computer and load application programs.

As with the previous circuits in this book, I've tried to provide various alternative designs so that you, the builder, may construct a truly personal system. Each of the four peripheral devices will be explained in detail and numerous design examples will be provided; both limited function hexadecimal input and full ASCII keyboards will be addressed. In the case of the visual display, we will discuss a rudimentary LED octal and a hexadecimal readout for ZAP. For more sophisticated visual interaction, a CRT terminal is required. Because this unit is much more complicated than a keyboard or an LED display, an entire chapter has been dedicated to it. My basic premise is to start with the essentials, provide a thorough understanding of their applications, then move to more complex, more useful add-ons.

The expansion of the basic ZAP into an interactive microcomputer system requires the addition of a software program to synchronize and exercise the new peripherals. This software is called a monitor and is discussed in a later chapter. Peripherals merely provide the means for added data entry and display capability.

I. KEYBOARDS

The only way the Z80 can communicate to an external device is through the input/output bus structure previously described. (While more esoteric methods such as direct memory access exist, they will be ignored for the present.) When the processor wishes to signal the user that an event has occurred, it can do so by changing the output level on one bit of a parallel-output port. For example, the end of program execution can be designated by bit 7 on port 0 going from a logic 0 to a logic 1. Using this concept, 8 separate elements could be individually designated and controlled from the 8 bits of output provided on the single "basic ZAP" port.

Information input is just as simple. The numbers 0 thru 7 could correspond to 8 switches on the 8 input bits of port 0. This is shown graphically in figure 5.1. When
bit-7 switch is pressed, grounding the input, the logic level transition can signify a numeric entry of 7 to the computer; many microprocessor applications require only these few bits of I/O. A traffic light controller, for example, with a single red, yellow, and green light would need only three bits of output.

The program to control the lights would have been written, assembled, and programmed into some type of non-volatile storage. However, ZAP must interact with a human operator in such a way that programs can be developed and tested. The major difference between the traffic light controller and ZAP would be the peripherals and not the microprocessor’s capabilities.

In our example, we could put 8 switches on an input port. To enter information, we have only to write a short program that reads the data on port 0 into the accumulator and then stores or acts upon it. The chapter on monitor software will address these manipulations, but one problem must be solved first: synchronizing peripherals to the computer.

How does the computer know when the data on the switches is or is not valid? And, could we make a timer in software or hardware that reads the port every second, on the second? Can you, for example, see yourself trying to flip all the switches in time or to make the computer wait?

Figure 5.1 A parallel input/output interface with LED readout and switch input.

The most popular method of synchronizing a peripheral that has slow data input to a computer with fast program execution is to use "data ready" strobe pulses. (Interrupts may also be used but they involve complicated programming and will not be considered here.) The program is written to read and check the logic level of one bit only. By substituting a push button for one of the eight switches, say bit 7, we can simulate the strobe. To accomplish this, first set data on the other seven switches; then, with the program sitting in a loop checking bit 7, press the push button to generate a logic transition. The program, sensing that a "data ready" strobe is present, reads in the entire port and uses the other 7 bits of data.

Frequently, it is not practical to limit ourselves to just 7 symbolic interpretations when using 7 bits of input. A more logical approach is to code the input and let the 7 bits represent up to 128 individual symbols. The choice between a coded versus a straight parallel input is governed by the application. If the computer is part of a burglar alarm, with each input bit representing a door or window switch, then it is important to know individual and simultaneous bit transitions. In this application, it is necessary to have parallel signal input. On the other hand, alpha-numeric entry from a typewriter keyboard is by nature serial, one letter at a time. Therefore, nothing is gained by using 128 parallel input bits for a 128-key keyboard. A 7-bit code is more cost-effective.
The most widely used keyboard code is ASCII (American Standard Code for Information Interchange). Appendix B lists the code and the characters it represents. Any homebrew keyboard should reflect this coding to be compatible with commercially available software such as BASIC.

There are a number of methods that can be used to generate suitable key codes. Figures 5.2 and 5.3 reflect hardware and software approaches, respectively. The block diagram outlined in figure 5.2 is a hardware scanning system suitable for a 64-key keyboard. A 6-bit counter progressively enables each column while scanning all rows in each step. Should any key be pressed, a logic 0 will be routed through the 8-input multiplexer to the scan control logic. This signal is used to generate a key-pressed strobe (also called data-ready strobe) to the computer. The row and column address lines from the counter are read and indicate the binary matrix address of the pressed key. Compatibility with the ASCII code is simply a matter of placing the proper key at the correct address within the matrix.

Another suitable encoding method is outlined in figure 5.3. This technique, which uses software logic to scan the matrix, should be used only when computer program execution speed is not critical. While reducing the circuitry to one chip, the trade-off in this approach requires both an input and output port. It functions in the same way as figure 5.2. The computer sets a 4-bit column counter code on the decoder. Then it searches the parallel input port for the row with the logic level 0 signifying a pressed key. While this may seem to be an easy way to decode 128 keys, there are certain software considerations.

Figure 5.2 A matrix keyboard scanner for a 64-key keyboard.
The key-pressed or data-ready strobe in any keyboard serves two purposes: it signifies that data is present and ready, and it is timed so the strobe is not generated until after a mechanical debounce time period has elapsed. The reason for the delay is obvious. Remember, these microprocessors can execute 200,000 instructions a second. A program written to look for a strobe and read the data would run a hundred times on a single keypress because of contact bounce. The mechanical making and breaking of the contact could appear like 100 data-ready strobes if we aren’t careful. A true data-ready strobe is not generated until after a debounce time-out and then it should be fast-rise-time (<200 ns) pulse with a rate exceeding the cycle time of the computer. The duration of the pulse should be long enough to allow the scanning program to catch it even if it is off doing some other task, and short enough so that the central processor doesn’t see the same strobe twice.

There are two techniques to combat the problem of strobe duration. One is to set a flip-flop with the rising edge of the strobe and tie the clear line of the flip-flop to an output bit. After reading in the data, the program can clear the “data-ready” condition by resetting the flip-flop. This is usually employed in cases where the response time to a keyboard or other device is variable. This method also guarantees that an event will be registered and not missed due to time delays. Of course, most keyboard encoders do not latch their output data. If a key is released, even if the strobe has been set in a flip-flop, no data will be present when the computer reads the keyboard. There are ways to get around this but they all involve additional hardware.

Usually the experimenter’s problem is reading a strobe twice rather than not waiting long enough to acknowledge it. Instead of using a hardware flip-flop, most programmers employ a software flag, the second technique in dealing with strobe duration. When a key-pressed strobe is sensed, the program sets a flag in a memory location, reads the data, then checks the strobe again. If the strobe is high, the flag is checked and the data is not read. Only when the strobe returns to a logic zero is the flag reset, enabling data input the next time.

It’s not easy to construct keyboard encoders for 64- or 128-key ASCII keyboards. It’s simpler to use a commercially available, scanning, read-only memory encoder such as the one documented in Appendix C6.

As far as ZAP is concerned, it is important to learn to walk before we run. Most people would consider ZAP to be a learning tool that could be eventually expanded into a full-blown microcomputer system. A full 128-key ASCII keyboard could prove to be as expensive as the entire ZAP computer. To minimize expense and retain the experimen-
tal qualities of this endeavor, a limited keyboard, suitable for hexadecimal entry, is suggested as the first level of expansion. With a limited number of keys to encode, hardwired TTL circuitry offers a reasonable cost advantage over expensive encoder read-only memories.

Figure 5.4 is a hexadecimal keyboard interface designed specifically for the ZAP software monitor. A hexadecimal keyboard allows data and instruction entry as 2 digit hexadecimal numbers. In addition to the 16 numeric keys, there are 3 command keys designated “EXEC” (for execute), “NEXT,” and “SHIFT.” EXEC and NEXT will be explained in the monitor section. The SHIFT is similar to a regular keyboard and is used to double the number of key codes by allowing a SHIFT 1, SHIFT 2, etc. The particular significance of each code will be explained later.

Figure 5.4 A hexadecimal keyboard interface.
The keyboard required to support the ZAP software monitor has 19 keys. The encoder in figure 5.4 is a combination scanner and hard-wired parallel output. Encoding depends upon the particular key pressed. The hexadecimal keys 0 thru F are sensed through a multiplexed scanner, IC 2 and IC 3. As IC 2 counts, it sequentially places a logic 0 on each of the 16 output lines of IC 3. If any key is pressed, that low level is routed back to IC 4 and stops the clock. The counter is then locked on the address of the particular key being pressed. The same action that stops the clock also triggers a one-shot IC 5 which generates a key-pressed strobe. The output lines B0 thru B3 will contain the binary value of the pressed key while bit 7 is reserved for the strobe. The three function keys are directly tied to input bits 4, 5, and 6. Three sections of IC 1 serve to dampen contact bounce. The EXEC and NEXT are tied in so they will generate a key-pressed strobe when activated. Because the shift key is always used in conjunction with another key, it is not connected to the strobe circuit.

It is important to recognize that the coding of this 19-key circuit is not ASCII. An ASCII keyboard cannot be used directly with the software monitor outlined in this book, unless you use only those ASCII keys that correspond to the coding of figure 5.4, or rewrite the software monitor to accept ASCII rather than binary codes for each key.

II. ADDING A VISUAL DISPLAY

Once a keyboard has been added to ZAP, we are ready for program development. The other key ingredient is a visual display that allows the programmer to examine instruction statements and data. The least costly configuration is an LED display, preferably hexadecimal because the software monitor is written that way. For the octal diehards, I’ve also included an octal display.

Hexadecimal displays may seem a trivial addition to an expensive computer system, but it is sometimes these little helpful add-ons that make program debugging easier. I don’t intend that it should replace a CRT, but it’s a necessary tool when debugging a program and a necessity for using the ZAP monitor. It will never replace a stepper or a break-point-monitor program, but it’s great to display keyboard or I/O data quickly with a single output instruction.

There are many ways to display hexadecimal on a 7-segment LED. Figure 5.5 is an
<table>
<thead>
<tr>
<th>INPUT CODE</th>
<th>82S23 PROGRAM</th>
<th>7-SEGMENT DISPLAY</th>
</tr>
</thead>
<tbody>
<tr>
<td>D C B A</td>
<td>D7D6D5D4D3D2D1D0</td>
<td>0</td>
</tr>
<tr>
<td>0 0 0 0</td>
<td>0 1 1 1 0 1 1 1</td>
<td>0</td>
</tr>
<tr>
<td>0 0 0 1</td>
<td>0 1 0 0 0 0 0 1</td>
<td>1</td>
</tr>
<tr>
<td>0 0 1 0</td>
<td>0 1 1 0 1 1 1 0</td>
<td>2</td>
</tr>
<tr>
<td>0 0 1 1</td>
<td>0 1 1 0 1 0 1 1</td>
<td>3</td>
</tr>
<tr>
<td>0 1 0 0</td>
<td>0 1 1 0 1 0 0 1</td>
<td>4</td>
</tr>
<tr>
<td>0 1 0 1</td>
<td>0 0 1 1 1 0 1 1</td>
<td>5</td>
</tr>
<tr>
<td>0 1 1 0</td>
<td>0 0 1 1 1 1 1 1</td>
<td>6</td>
</tr>
<tr>
<td>0 1 1 1</td>
<td>0 1 1 0 0 0 0 1</td>
<td>7</td>
</tr>
<tr>
<td>1 0 0 0</td>
<td>0 1 1 1 1 1 1 1</td>
<td>8</td>
</tr>
<tr>
<td>1 0 0 1</td>
<td>0 1 1 1 1 0 0 1</td>
<td>9</td>
</tr>
<tr>
<td>1 0 1 0</td>
<td>0 1 1 1 1 1 0 1</td>
<td>A</td>
</tr>
<tr>
<td>1 0 1 1</td>
<td>0 0 0 1 1 1 1 1</td>
<td>b</td>
</tr>
<tr>
<td>1 1 0 0</td>
<td>0 0 1 1 0 1 1 0</td>
<td>C</td>
</tr>
<tr>
<td>1 1 0 1</td>
<td>0 1 0 0 1 1 1 1</td>
<td>d</td>
</tr>
<tr>
<td>1 1 1 0</td>
<td>0 0 1 1 1 1 1 0</td>
<td>E</td>
</tr>
<tr>
<td>1 1 1 1</td>
<td>0 0 1 1 1 1 0 0</td>
<td>F</td>
</tr>
</tbody>
</table>

Figure 5.5 A possible method for a hexadecimal latch/decoder/driver using a standard 7-segment LED.

a) This entire circuit would be needed to replace one HP7340. **CS** on the 82S23 can perform the blanking function.

b) The program for the 82S23 (IC 2).

example of the usual brute force method using a PROM as a hexadecimal decoder. (A method of programming the 82S23 was described in the article in the November 1975 issue of BYTE magazine entitled “A Versatile Read-Only Memory Programmer,” if you choose to use this circuit.)

However, this approach uses an excessive number of components and most people would not want to program a PROM. One alternative is to allow the computer to perform the decoding and drive the 7-segment display through the transistors directly from a latched 8-bit output port. Another way puts additional logic around a standard 7-segment decoder driver for the extra requirements. The former case necessitates a computer program while the latter can involve as many components as figure 5.5.

Fortunately, there is a product on the market that can solve the problem. It is the HP7340 hexadecimal LED display (from Hewlett Packard; equivalent displays are available from other manufacturers). These hexadecimal digits depart from the standard 7-segment format by using dots instead of bars and being capable of displaying a capital “B” and “D” in hexadecimal. This is accomplished by controlling the corner dots, which gives the appearance of “rounding.” This ability discriminates a “B” from an “8” or a “D” from a “0.” There are 16 distinctly different characters.

An additional feature of the HP7340 is that each display circuit contains a 4-bit latch and decoder/driver. This allows the display to be attached directly to the data bus. The result is a single 8-pin hexadecimal display that successfully accomplishes the function of all the circuitry of figure 5.5. The specifications of the individual pins are given in figure 5.6.

### 5080-7340 Pin Connections

**Rear View**

<table>
<thead>
<tr>
<th>PIN</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>INPUT B</td>
</tr>
<tr>
<td>2</td>
<td>INPUT C</td>
</tr>
<tr>
<td>3</td>
<td>INPUT D</td>
</tr>
<tr>
<td>4</td>
<td>BLANK CONTROL (BLANK +5V)</td>
</tr>
<tr>
<td>5</td>
<td>LATCH ENABLE (LATCH +0V)</td>
</tr>
<tr>
<td>6</td>
<td>GROUND</td>
</tr>
<tr>
<td>7</td>
<td>+5 VOLTS</td>
</tr>
<tr>
<td>8</td>
<td>INPUT A</td>
</tr>
</tbody>
</table>

Figure 5.6 The pin layout and functions for the HP7340 BCD to hexadecimal display. Similar displays are produced by Diallite and Texas Instruments.
Figures 5.7 and 5.8 demonstrate how the HP7340 can be configured to function as a 2-digit hexadecimal output port or a 3-digit octal port. An 8-bit latch is not required because it already contains one. The HP7340s can be attached to the data bus as simply as any other parallel output port and are strobed from the chip-select decoder outlined earlier in the section on I/O decoding.

To utilize the software monitor properly, 6 hexadecimal displays (separated into 3 single byte displays) are necessary. Three bytes are required to display a particular H and L address and the data contents of that location. The 6 hexadecimal displays should have the following decoded strobes:

<table>
<thead>
<tr>
<th>Output Port #</th>
<th>Logic Line</th>
<th>Display Parameter</th>
<th>IC#</th>
</tr>
</thead>
<tbody>
<tr>
<td>5</td>
<td>DS5WR</td>
<td>MSD address field</td>
<td>30, 31</td>
</tr>
<tr>
<td>6</td>
<td>DS6WR</td>
<td>LSD address field</td>
<td>28, 29</td>
</tr>
<tr>
<td>7</td>
<td>DS7WR</td>
<td>data field</td>
<td>26, 27</td>
</tr>
</tbody>
</table>

MSD — Most Significant Digit
LSD — Least Significant Digit

A more complete description of each display function is described within the monitor section, and a completed schematic showing how the 6 displays are attached to the data bus is illustrated in figure 5.9.

Figure 5.7 An HP7340 hexadecimal latch/decoder/driver display.

Figure 5.8 An HP7340 octal latch/decoder/driver display. The HP5082-7300 can be substituted for the HP5082-7340 in octal display applications. The HP7300 displays numerics only.
III. SERIAL INTERFACE

A serial communication capability is not absolutely necessary to make ZAP work, although the software monitor supplied in this book supports a serial interface.

First a word about concept before we pursue the design details. Why would ZAP need to communicate? When we discuss the serial cassette interface, you will understand that there are more advantages to it than appear presently. If future expansion is in mind or commercially made peripherals such as a CRT or printer are ever added, their interface will most likely be serial.

This last sentence is significant. Realize that I said nothing about communicating with another computer. While talking to another computer over telephone lines requires a serial link, in general, standard peripherals such as CRTs and printers also "talk" serially. Therefore, by designing a serial port to accommodate a printer, we also gain the ability to talk with another computer.

Communication is simply the transfer of information from one device to another. In the case of a CRT display unit, the computer sends character information for screen display while the keyboard relays the user's input to the computer. Each end of the full-duplex communication line must have a transmitter and a receiver. In both cases, the information being transferred is ASCII data probably consisting of a 7-bit code and, in some cases, an additional parity bit for error checking. This 7-bit data (ignoring the parity bit) will appear on the lines of a parallel port. These 7 lines plus a ground reference and a strobe (remember we have to tell the receiver when the data is valid) can be brought out to the CRT input. Keeping that as a dedicated line from the computer to the CRT, we now want a similar line between the keyboard output and an 8-bit parallel port on the computer. This requires an additional 9 lines. To further complicate matters, let's separate the terminal and the computer by 300 to 400 feet, as might happen in some commercial computer systems. The result is that 400 feet of 18 lead (17 if you combine ground references) cable will cost more than the terminal. Also realize that the TTL parallel output should not be used to drive lines longer than 20 feet without special buffers/drivers; otherwise data errors could occur.

The solution to this costly wiring problem is to use serial rather than parallel communication. The parallel data is converted to serial and sent one bit at a time down a single twisted pair wire. If buffers/drivers are needed for long distances, less are required with the serial approach. Specially encoded "start" and "stop" bits included in the serial transmission notify the receiver that valid data is being sent. For the above example, only two pairs of wire are needed to perform "full-duplex" interaction (see figure 5.10). In "half-duplex" mode this can be reduced to a single twisted pair, but synchronization of the shared communication line is more complicated. All serial transmission references I shall make will be limited to full-duplex operation.

Figure 5.10 A block diagram of a full-duplex RS-232C communication link.
Now that we agree that the communication should be serial, how do we accomplish the parallel to serial conversion? The answer is a device called a UART (Universal Asynchronous Receiver/Transmitter). Appendix C7 gives the specification information for the SMC COM2017 UART which is equivalent in function to the AY-5-1013A (General Instruments). To minimize power supply requirements, a single +5 V AY-3-1015 or TR1602 (Western Digital) can be substituted as I have done. The only change from the specification sheet is that pin #2 is no longer tied to −12 V. A UART’s internal structure consists of a separate parallel-to-serial transmitter and serial-to-parallel receiver joined by common programming pins. This means that the two sections of the UART can be used independently, provided they adhere to the same bit format that is hard-wire or software selectable on the chip.

The transmission from the computer to the CRT is done asynchronously and in one direction only. The computer likewise receives data directly from the keyboard through a dedicated line. As far as the computer is concerned, after reconversion to parallel in the UART, this input device is communicating parallel data.

Actual data transmission follows the asynchronous serial format illustrated in figure 5.11. Using the keyboard as an example, when no data is being transmitted, the data line is sitting at a mark (or “1” level) waiting for a key-pressed strobe. A key-pressed strobe is a 1 to 5 ms positive pulse (it can be as short as 200 ns) indicating that a keyboard key has been pressed, and that an ASCII code of that key is available for transmission. This key-pressed strobe, which is attached to the data strobe of the UART, causes the ASCII data to be loaded into a parallel storage buffer and starts the UART transmission cycle. The serial output will then make a transition from a 1 to a 0. This mark-to-0 start bit is 1 clock period long and indicates the beginning of a serially transmitted word. Following the start bit, up to 8 bits of data follow, each data bit taking 1 clock period. At the conclusion of the data bits, parity and stop bits are output by the UART to signify the end of transmission. If another key is pressed, the process repeats itself.

![Figure 5.11 A single data byte as it is transmitted in asynchronous serial format.](image)

On the receiving end, the UART is continuously monitoring the serial input line for the start bit. Upon its occurrence, the 8 bits of data are slipped into a register and the parity checked. At the completion of the serial entry, an output signifying data available is set by the UART and can be used as an input strobe to the computer. The UART will not process additional serial inputs unless the data available flag is acknowledged, and the data available reset line is strobed. Actual transmission can include or exclude parity, have 1 or 2 stop-bits, and data can be in 5- to 8-bit words. These options are pin selectable.

The following is a pin function description for the AY-5-1013, COM2017, or AY-3-1015.

<table>
<thead>
<tr>
<th>Pin #</th>
<th>NAME</th>
<th>SYMBOL</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Vcc Power Supply</td>
<td>Vcc</td>
<td>+5 V Supply</td>
</tr>
<tr>
<td>2</td>
<td>Vcc Power Supply</td>
<td>Vcc</td>
<td>−12 V Supply (not connected on AY-3-1015)</td>
</tr>
<tr>
<td>3</td>
<td>Ground</td>
<td>GND</td>
<td>Ground</td>
</tr>
<tr>
<td>4</td>
<td>Received Data Enable</td>
<td>RDE</td>
<td>A logic “0” on the receiver enable line places the received data onto the output</td>
</tr>
<tr>
<td></td>
<td>Received Data Bits</td>
<td></td>
<td>Parity Error</td>
</tr>
<tr>
<td>---</td>
<td>-------------------</td>
<td>---</td>
<td>--------------</td>
</tr>
<tr>
<td>5</td>
<td>RD8 thru</td>
<td>12</td>
<td>RD1</td>
</tr>
<tr>
<td></td>
<td>lines.</td>
<td></td>
<td>These are the eight data output lines. Received characters are right justified; the LSB always appears on RD1. These lines have three-state outputs.</td>
</tr>
</tbody>
</table>
23 Data Strobe  

Register may be loaded with another character. Three-state.

A strobe on this line will enter the data bits into the data bits holding register. Initial data transmission is initiated by the rising edge of DS. Data must be stable during entire strobe.

24 End of Character  

EOC

This line goes to a logic “1” each time a full character is transmitted. It remains at this level until the start of transmission of the next character.

25 Serial Output  

SO

This line will serially, bit by bit, provide the entire transmitted character. It will remain at logic “1” when no data is being transmitted.

26 Data Bit Inputs  

BD1 thru BD8

There are up to eight data bit input lines available.

34 Control Strobe  

CS

A logic “1” on this lead will enter the control bits (EFS, NB1, NB2, TSB, NP) into the control bits holding register. This line can be strobed or hard-wired to a logic “1” level.

35 No Parity  

NP

A logic “1” on this lead will eliminate the parity bit from the transmitted and received character (no PE indication). The stop bit(s) will immediately follow the last data bit. If not used, this lead must be tied to a logic “0.”

36 Number of Stop Bits  

TSB

This lead will select the number of stop bits, one or two, to be appended immediately after the parity bit. A logic “0” will insert 2 stop bits. A logic “1” inserts 1 stop bit.

37 Number of Bits/Characters  

NB2, NB1

These two leads will be internally decoded to select either 5, 6, 7 or 8 data bits/character.

<table>
<thead>
<tr>
<th>NB2</th>
<th>NB1</th>
<th>Bits/Character</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>5</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>6</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>8</td>
</tr>
</tbody>
</table>
The logic level on this pin selects the type of parity that will be appended immediately after the data bits. It also determines the parity that will be checked by the receiver. A logic ‘0’ will insert odd parity, and a logic ‘1’ will insert even parity.

This line should have as an input a clock whose frequency is 16 times (16 ×) the desired transmitter data rate.

The final serial interface configuration is shown in figure 5.12. Because a UART is a three-state device, it can be attached directly to the data bus. Data is written into or read from it 8 bits parallel as any other I/O port manipulation. To the computer, the UART appears as one output and two input registers: status, transmitted data, and received data. As with all data bus manipulations, data transfers are synchronized through decoded strobes. The ZAP software monitor uses three port addresses to coordinate the hardware and software. To be compatible, they should be wired as follows:

<table>
<thead>
<tr>
<th>Port #</th>
<th>Logic Line</th>
<th>Signal</th>
</tr>
</thead>
<tbody>
<tr>
<td>02 INPUT</td>
<td>DS2RD</td>
<td>READ DATA</td>
</tr>
<tr>
<td>03 INPUT</td>
<td>DS3RD</td>
<td>READ STATUS</td>
</tr>
<tr>
<td>02 OUTPUT</td>
<td>DS2WR</td>
<td>WRITE DATA</td>
</tr>
</tbody>
</table>

The primary focus of this chapter is the hardware section of the serial interface. When connected directly to the data bus in this manner, there is no way to operate the UART except under program control. Explanation of the protocol and the significance of each UART register can be found in the section on the ZAP monitor.

There are two remaining hardware considerations: data rate and transmission signal level. Data rate can be loosely termed as bits per second and refers to the transmission speed along the twisted pair. Keep in mind that at lower data rates, only 8 of 11 bits of each transmitted word are data; 1 start bit and 2 stop bits are used. While any transmission frequency can be set on a UART, by adjusting the clock rate there are eight frequently used standard asynchronous transmission rates:

- 110 bps
- 150 bps
- 300 bps
- 600 bps
- 1200 bps
- 2400 bps
- 4800 bps
- 9600 bps

Using a special data rate generator chip and switch selector network shown in figure 5.12, ZAP can accommodate any of these specific frequencies. In normal operation, most teletypes run at 110 bps, printers such as the DECwriter II at 300 bps, acoustic telephone modems at 300 bps, and video terminals from 1200 to 19,200 bps. As you can see, in theory, we can communicate with them.

Transmission rate is only part of inter-communication prerequisites. A computer could be all TTL level logic while a peripheral used 15 V CMOS. They would be completely incompatible. Therefore, it is necessary to have one additional standard that governs the signal level of the transmissions. The most widely accepted and generally
Figure 5.12 The final serial interface configuration.
used standard is EIA RS-232C.

Although TTL levels could be used for communication, they are not suitable for carrying signals more than 10 or 20 feet. The problem stems from the fact that only 2 V separates a logic 1 or 0 rather than speed or drive capabilities. With only 2 V immunity to noise, communication would be susceptible to interference from motors and switches.

An industrial committee agreed to a standard interface to solve this problem as well as to suggest standards for the industry. Modem equipment uses EIA RS-232C. This specification applies not only to the specific voltages assigned to logic 0 and 1, but also to the type of plug, pin assignments, source and load impedances, as well as to a variety of other related functions.

The signal levels of RS-232C are bipolar and use a negative voltage between −3 and −15 V to represent a logic 1 and a positive 3 to 15 V to represent a logic 0. The region between −3 V and +3 V helps our noise immunity and is a dead region. Even though +3 V and −15 V would provide optimum transmission, +3 V and −7 V are also acceptable. However, try to maintain equal bipolar levels over long distances.

The basic ZAP computer requires +12, +5, and −12 V (−5 V is necessary for the EPROM memory and is derived from the −12 V supply) supplies for operation. We can use the positive and negative supplies to generate RS-232C voltage levels in a number of ways. Figure 5.13 illustrates some RS-232C drivers, and figure 5.14 shows a couple of receiver circuits. One from each selection would have to be attached to the serial I/O pins of the UART for it to have complete RS-232C compatibility.

**Figure 5.13** TTL to RS-232C drivers.

a) Using two transistors as a level shifter.

b) Using an opto-isolator as a level shifter.

c) Using a standard RS-232C line driver.
IV. CASSETTE STORAGE INTERFACE

The last but by no means least of the enhancements we should add to ZAP is a cassette interface. With the keyboard and display, an operator will be able to write some elaborate programs but, unless they are transferred into read-only memory storage, they will be lost when power is turned off. Of course, the computer's power can be left on constantly. But what if you want to develop a second program that must occupy the same memory address space? The preferable solution is to have some medium that temporarily stores large memory blocks.

In large computer systems, this capability is achieved through hard-disk and 9-track magnetic tape systems. These high-speed, high-volume media are beyond the personal computing budget, but their value in large systems is obvious. A low price, lower performance alternative is an audio cassette storage system.

In general, a cassette storage interface consists of three major subsystems: a serial transmitter/receiver; a hardware assembly that converts serial TTL data so it's audio cassette compatible, and an application program that keeps track of what's going out to tape and can load it back into the correct place. The basic configuration is illustrated in block diagram form in figure 5.15.

---

Figure 5.14 RS-232C to TTL receivers.
   a) Using a transistor.
   b) Using a standard RS-232C line receiver.

Figure 5.15 A block diagram of an audio cassette storage system.
The serial transmitter/receiver section is nothing more than the UART serial interface which we have already added. With MC1488 and 89 converters on its serial lines, it communicates via a RS-232C. However, if you attach a cassette interface to these lines, it can double as a storage device. An additional benefit is that serial data generated by the UART will offer some compatibility between personal computing systems; standard data rates and standard serial communication protocol will promote this.

The output of the UART is TTL. Even with the RS-232C drivers, the logic output is still a DC level. Because audio recorders cannot record DC, the UART output must be converted in some way. The solution is FSK (frequency shift keying). The TTL output from the UART is converted into audio tones. One frequency represents a logic 0, and a second represents a logic 1.

Figure 5.16 shows a circuit that will produce frequency shift keyed tones. A 4800 Hz reference frequency is derived from the MC14411 data rate generator previously installed. IC 2A and 2B function as a programmable divider chain. With a TTL logic 1 on the input IC 2 divides the 4800 Hz by 2, giving a 2400 Hz output. When the input level is changed to logic 0, it divides by 4, producing a 1200 Hz output. The FSK frequencies are generated at a serial output rate of 300 bps and connected directly to the recorder through the microphone or auxiliary input. (These frequencies and data rate are often referred to as the Kansas City Standard.)

![Diagram of a 300 bps serial output driver to an audio recorder.](image)

Figure 5.16 A 300 bps serial output driver to an audio recorder.

Getting the recorded tones off the audio tape requires the circuit shown in figure 5.17. In general, it consists of a pair of band-pass filters and a voltage comparator. The recorder is set to an output level of approximately 1 V peak to peak. This level is not critical because it is amplified and limited as it passes through IC 1. IC 2 and IC 3 are band-pass filters with center frequencies of 2400 Hz and 1200 Hz, respectively. The output of IC 1 is fed into both of them, but should be passed by only one. IC 4 compares the outputs of the two filters and generates a TTL logic 1 when a 2400 Hz tone is received and a logic 0 with a 1200 Hz tone. Tuning the interface will be explained later.

The choice of the FSK frequencies and data rate are not left to chance. They are a function of receiver response speed and recorder bandwidth. Most cassette recorders have a frequency response of around 8 kHz. Less expensive units can be as low as 5 or 6 kHz. It is unwise to try to record tones at this upper limit. The center of the frequency range offers more reliability, so the logic "1" FSK tone should be set less than 3 kHz (2400 Hz in our case). In addition, it takes time for the receiver to recognize a particular frequency. The circuit of figure 5.17 takes 2 or 3 cycles to respond. This means that at the low frequency of 1200 Hz, each logic 0 bit will need 3 cycles at 1200 Hz to be recognized.
Figure 5.17 A 300 bps serial input receiver from an audio cassette.
If we consider a worst case condition of sending all zeros, the transmission rate would have to be slower than 400 bps to be accurately received. The closest standard data rate to this value is 300 bps. Raising the 1200 Hz tone to increase the transmission speed only complicates the filter design the closer it is to 2400 Hz. This interface has been tested at 600 bps but it requires precise alignment to achieve faster speeds. The low frequencies and moderate data rate are chosen specifically to increase the probability of successful construction rather than to compete with high speed data storage systems.

The final point to consider is the software that runs the hardware. The ZAP monitor, as it now stands, does not directly support a cassette interface even though it does handle all the serial housekeeping. Until you write the cassette driver into an EPROM, you will have to type in a short "bootstrap" program. To read the cassette, the logic of the program would follow the flow diagram in figure 5.18.

First, a pointer is set in the H and L registers to designate where the cassette data will be stored in programmable memory and an address where it will end. Next, taking advantage of the serial communication routine in the ZAP monitor, we simply call "SERIAL IN" which returns a byte of data from the UART. This byte is stored in memory, and the HL register pair is decremented and compared to a predetermined stop address. If not equal, it repeats the process of getting another byte of data.

Storing memory is equally straightforward and is diagrammed in figure 5.19. Again, a pointer is set to the beginning and the memory area to be written to tape. Next, the "SERIAL OUT" routine is called from the ZAP monitor, which sends the byte of data to the cassette. Finally, the pointer is decremented and compared to the end address to see if more data is to be written.

These are relatively easy routines to write and short enough that they may be squeezed into the few empty bytes within the ZAP monitor EPROM. Whatever the case, you will soon realize the versatility and capability that such a simple interface adds to a computer system. The 2 K of programmable memory on the basic ZAP will become resident program space while the cassette will be a potential megabyte file storage system for it.

![Flowchart of software to read a cassette.](image)

**Figure 5.18** A flowchart of software to read a cassette.
TUNING THE CASSETTE INTERFACE

To test the cassette interface, it is necessary first to construct the circuit from figure 5.16. Use a frequency counter to determine that the input to IC 1, pin 5 is 4800 Hz. With no UART installed, the frequency at pin 1 of IC 2b should be 2400 Hz. Grounding IC 2b, pin 1 should change this output to 1200 Hz. In both cases, voltages of 1 and 0.1 V should be present on the cassette auxiliary and microphone inputs respectively.

The receiver uses the frequencies generated by the output section previously described to set the calibration. With the output section set to 2400 Hz, attach a jumper from the output interface to the input of the receiver circuit (figure 5.17). Using an oscilloscope, check that the waveform at IC 1, pin 6 is a square wave of 2400 Hz. Next, with the scope attached to IC 2, pin 6, adjust R1 until the voltage at that point is maximum. Moving the scope probe to IC 3, pin 6, and changing the input frequency to 1200 Hz, repeat the procedure by adjusting R2 until the voltage peaks.

R3 sets the point at which the comparator switches between logic levels when the input frequencies change. The proper way to set this is to use a function generator on the input and set R3 to switch at exactly 1800 Hz. The result should be clean logic level switching at IC 4, pin 6, as the frequency is cycled between 1200 Hz and 2400 Hz. Generally speaking, the comparator setting is not especially critical.
CHAPTER 6
THE ZAP MONITOR SOFTWARE

The function of an operating system is to provide the programmer with a set of tools to help him in developing, debugging and executing a program. In general, the operating system assists the programmer by managing the resources of the computer, and by eliminating his involvement with repetitive machine-code manipulations. Operating systems span a broad spectrum of complexity. Small systems, for example, provide only a rudimentary means for a programmer to enter and read 8-bit data from memory; large systems, on the other hand, can dynamically manage the allocation of all memory and peripherals.

Large systems allocate computer resources to more than one user in a multiprogramming, multitasking, or a time sharing environment. A system of this magnitude far exceeds the capabilities of the computer described in this book. This being the case, what would be a suitable operating system for the ZAP computer? As previously stated, the objective of an operating system is to manage the resources of the computer. The ZAP computer described in the previous chapters, and enhanced with the minimum peripherals, contains the following resources:

- Z80 microprocessor
- 1024 bytes of EPROM memory
- 1024 bytes of programmable memory (2048 optional)
- Nineteen-key keyboard
- Two-character data display
- Four-character address display
- UART for serial I/O

The operating system must provide access to these resources and give the user a way to manage them during execution of programs. The operating system designed for ZAP will include the following facilities and functions:

1. Cold start
2. Warm start
3. Memory display and replace
4. Register display and replace
5. Execute (begin program execution at a designated point)
6. Serial input and output

Each will be explained in detail concerning its functions and program implementation.

I. OPERATING SYSTEM FUNCTIONS

Cold Start Operation

The operating system must be available immediately after power is applied to
the computer. In the past, some systems provided this capability by storing, in read-only memory, a small “bootstrap” routine. This bootstrap routine was then used to load the operating system into memory from another device, such as a paper-tape reader or a cassette recorder. New technology eliminates this tedious step. The operating system for your computer resides permanently on the EPROM (erasable-programmable read-only memory) chip and is ready to be executed as soon as power is applied and the “RESET” button is pressed. The depression and release of the “RESET” button sets the Z80 PC (program counter) to zero.

With the next machine cycle, the processor begins execution of the instruction located at 00₁₆ (location 00 hexadecimal) in memory. The operating system of the Z80 microprocessor provides the instructions to begin execution. This particular series of program instructions constitutes a “cold start” procedure and establishes the required start up conditions for the operating system. The operating system then initializes the SP (stack pointer) to an area in programmable memory for maintaining the “push-down/pop-up” stack. This stack is required for execution of any of the “RESTART” and “CALL” instructions provided by the Z80 instruction set. If it were not initialized before the execution of a “CALL” or “RESTART” instruction, the effects of the instruction would be unpredictable. In this operating system, the stack pointer is set to programmable memory location 07C4₁₆.

**Warm Start Operation**

After initializing the SP address, the operating system enters a command recognition module. Before discussing this feature of the operating system, some of the other restart features should be explained. The Z80 gives the user eight address-vectored “RESTART” instructions (see Chapter 3 for a description of the instructions). For example, the execution of a RST 08₁₆ will store the current PC on the “STACK” and program execution will begin at location 08₁₆.

The following “RESTART” instructions are available within the operating system:

RST 10₁₆  
RST 18₁₆  
RST 20₁₆  
RST 28₁₆  
RST 30₁₆  
RST 38₁₆

The execution of any of these instructions causes the operating system to jump to a location in programmable memory. At that location the user executes a jump instruction to vector the computer to a new location.

RST 00₁₆ and RST 08₁₆ have been reserved for use by the operating system for special functions and will not result in a jump to a location in programmable memory. These two RST instructions can be utilized in the debugging of programs. RST 00₁₆ will perform the same function as pressing the “RESET” button; or it will reinitialize the stack pointer and enter the command recognition module through execution of the “cold start” routine.

The execution of a RST 08₁₆ by the Z80 will result in the “warm start” module being entered. This module saves the existing data in all the registers in the “register save area” located in programmable memory (see the listing of the ZAP operating system in Appendix D). The module will also extract from the stack the user’s restart address and save this in the register save area. The operating system then enters the command recognition mode to wait for the next command. The use of this feature allows the programmer to save register, pointer, flag, and program counter data, prior to using any additional debugging features in the operating system. A detailed description of the “warm start” module is provided in section II.2 of this chapter.
Program Development and Debugging Services

The cold start and warm start procedures exit to the command input sequence. With these command procedures, the programmer is able to examine and replace data in memory or registers, and to begin execution at a user-specified location. Upon entry to the command input module, the operating system displays “FFFF” on the address section, and “FF” on the data section of the six character hexadecimal LED display. The user then implements one of the three command functions by holding down the “SHIFT” key and pressing the “0,” “1,” or “2” keys. A “SHIFT 0” (the SHIFT key and 0 key are pressed simultaneously) tells the operating system to enter the memory display and replace function; “SHIFT 1” enters the register display and replace function, and a “SHIFT 2” enters the execute module.

Memory Display and Replace

The memory display and replace function allows the user to examine the contents of both read-only memory and programmable memory. During operation the address and the contents of that location are shown on the respective displays.

The memory display and replace function is entered by executing a “SHIFT 0” when the system is in the command recognition mode (address display = FFFF and data display = FF). At this time, the operating system is waiting for the user to enter an address of one to four hexadecimal digits from the keyboard. As entered, these shift into the display area sequentially. If more than four digits are entered, only the last 4-digit value (shown in the address display) will be used as the address. Inputting of address data is terminated by pressing the “NEXT” key. This causes the contents of the indicated address to be displayed on the two digit hexadecimal data display. If the user wishes to display subsequent memory locations, he need only continue pressing the “NEXT” key. This will step the memory display program to the next higher memory location and display the new address and memory contents. If the user wishes to change the contents of a displayed memory location, he may enter new data by typing a two-digit value for that location before hitting the next key. This new value is loaded into the indicated address when the “NEXT” key is pressed. Pressing the “NEXT” key continues the sequential display of address and data.

Termination of this function is accomplished by pressing the “RESET” or “EXEC” buttons. Control is returned to the command recognition portion of the operating system.

### Display Memory Example

<table>
<thead>
<tr>
<th>Key</th>
<th>Address Display</th>
<th>Data Display</th>
</tr>
</thead>
<tbody>
<tr>
<td>FFFF</td>
<td>FF</td>
<td></td>
</tr>
<tr>
<td>“SHIFT 0”</td>
<td>0000</td>
<td>FF</td>
</tr>
<tr>
<td>1</td>
<td>0001</td>
<td>FF</td>
</tr>
<tr>
<td>A</td>
<td>001A</td>
<td>FF</td>
</tr>
<tr>
<td>F</td>
<td>01AF</td>
<td>FF</td>
</tr>
<tr>
<td>“NEXT”</td>
<td>01AF</td>
<td>01</td>
</tr>
<tr>
<td>“NEXT”</td>
<td>01B0</td>
<td>1C</td>
</tr>
<tr>
<td>“RESET”</td>
<td>FFFF</td>
<td>FF</td>
</tr>
</tbody>
</table>

### Memory Replace Example

<table>
<thead>
<tr>
<th>Key</th>
<th>Address Display</th>
<th>Data Display</th>
</tr>
</thead>
<tbody>
<tr>
<td>FFFF</td>
<td>FF</td>
<td></td>
</tr>
<tr>
<td>“SHIFT 0”</td>
<td>0000</td>
<td>FF</td>
</tr>
<tr>
<td>4</td>
<td>0004</td>
<td>FF</td>
</tr>
<tr>
<td>0</td>
<td>0040</td>
<td>FF</td>
</tr>
<tr>
<td>0</td>
<td>0400</td>
<td>FF</td>
</tr>
</tbody>
</table>
"NEXT" 0400 01
2 0400 02
1 0400 21
"NEXT" 0401 05
6 0401 06
A 0401 6A
"EXEC"

The results will be:

<table>
<thead>
<tr>
<th>Address</th>
<th>Data</th>
</tr>
</thead>
<tbody>
<tr>
<td>0400</td>
<td>21</td>
</tr>
<tr>
<td>0401</td>
<td>6A</td>
</tr>
</tbody>
</table>

Register Display and Replace

The register display and replace function allows the user to examine and change the contents of the saved Z80 registers. This is accomplished by executing a RST 1 (warm start) during the execution of the program. During execution of this function, the contents of the registers are shown on the address display. Eight-bit registers will be displayed on the lower two digits of the address display. (The upper two digits will be zeros during the display of 8-bit registers.) A code that indicates which register is being displayed is shown on the data display. Table 6.1 describes the codes that have been assigned to the register display and replace function, as well as the key that initiates a particular register display sequence.

<table>
<thead>
<tr>
<th>Code (shown on data display)</th>
<th>Z80 Register (shown on address display)</th>
<th>Initiating Key</th>
</tr>
</thead>
<tbody>
<tr>
<td>02</td>
<td>IX</td>
<td>2</td>
</tr>
<tr>
<td>03</td>
<td>IY</td>
<td>3</td>
</tr>
<tr>
<td>04</td>
<td>SP</td>
<td>4</td>
</tr>
<tr>
<td>05</td>
<td>PC</td>
<td>5</td>
</tr>
<tr>
<td>06</td>
<td>I</td>
<td>6</td>
</tr>
<tr>
<td>07</td>
<td>R</td>
<td>7</td>
</tr>
<tr>
<td>08</td>
<td>L</td>
<td>8</td>
</tr>
<tr>
<td>09</td>
<td>H</td>
<td>9</td>
</tr>
<tr>
<td>0A</td>
<td>A</td>
<td>A</td>
</tr>
<tr>
<td>0B</td>
<td>B</td>
<td>B</td>
</tr>
<tr>
<td>0C</td>
<td>C</td>
<td>C</td>
</tr>
<tr>
<td>0D</td>
<td>D</td>
<td>D</td>
</tr>
<tr>
<td>0E</td>
<td>E</td>
<td>E</td>
</tr>
<tr>
<td>0F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>40</td>
<td>L'</td>
<td>&quot;SHIFT 0&quot;</td>
</tr>
<tr>
<td>41</td>
<td>H'</td>
<td>&quot;SHIFT 1&quot;</td>
</tr>
<tr>
<td>42</td>
<td>A'</td>
<td>&quot;SHIFT 2&quot;</td>
</tr>
<tr>
<td>43</td>
<td>B'</td>
<td>&quot;SHIFT 3&quot;</td>
</tr>
<tr>
<td>44</td>
<td>C'</td>
<td>&quot;SHIFT 4&quot;</td>
</tr>
<tr>
<td>45</td>
<td>D'</td>
<td>&quot;SHIFT 5&quot;</td>
</tr>
<tr>
<td>46</td>
<td>E'</td>
<td>&quot;SHIFT 6&quot;</td>
</tr>
<tr>
<td>47</td>
<td>F'</td>
<td>&quot;SHIFT 7&quot;</td>
</tr>
</tbody>
</table>

Table 6.1 Display code/Z80 register/Initiating key correspondence.

The register display and replace function is entered by pressing a "SHIFT 1" when the system is in the command recognition mode (address display = FFFF and data display = FF). At this time the operating system is waiting for the programmer to enter the one-digit register code (see table 6.1). If more than one digit is entered, only the last code indicated on the data display will be used as the reg-
ister identifier. When the central processor detects that the “NEXT” key has been depressed, the contents of the indicated register are displayed on the address display.

If the user wishes to display subsequent registers he need only press the “NEXT” key. This causes the next register to come up with the register code and its contents. To change the contents of a displayed register the value is entered and loaded when the “NEXT” key is pressed. For 16-bit registers, the last four hexadecimal digits will be accepted if more than four characters have been entered. For 8-bit registers the last two hexadecimal digits will be accepted. When replacing register data, the “NEXT” key also causes the register code to be indexed to the next register (see table 6.1) and its contents to be displayed.

The user may terminate this function by pressing the “EXEC” key. Control is returned to the command recognition portion of the operating system.

### Display Register Example

<table>
<thead>
<tr>
<th>Key</th>
<th>Data Display (register code)</th>
<th>Address Display (register contents)</th>
</tr>
</thead>
<tbody>
<tr>
<td>“SHIFT 1”</td>
<td>FF</td>
<td>FFFF</td>
</tr>
<tr>
<td>A</td>
<td>00</td>
<td>FFFF</td>
</tr>
<tr>
<td>“NEXT”</td>
<td>0A</td>
<td>FFFF</td>
</tr>
<tr>
<td>“NEXT”</td>
<td>0B</td>
<td>005C</td>
</tr>
<tr>
<td>“RESET”</td>
<td>FF</td>
<td>FFFF</td>
</tr>
</tbody>
</table>

### Register Replace Example

<table>
<thead>
<tr>
<th>Key</th>
<th>Data Display (register code)</th>
<th>Address Display (register contents)</th>
</tr>
</thead>
<tbody>
<tr>
<td>“SHIFT 1”</td>
<td>FF</td>
<td>FFFF</td>
</tr>
<tr>
<td>5</td>
<td>05</td>
<td>FFFF</td>
</tr>
<tr>
<td>“NEXT”</td>
<td>05</td>
<td>043A</td>
</tr>
<tr>
<td>4</td>
<td>05</td>
<td>0004</td>
</tr>
<tr>
<td>2</td>
<td>05</td>
<td>0042</td>
</tr>
<tr>
<td>C</td>
<td>05</td>
<td>042C</td>
</tr>
<tr>
<td>“NEXT”</td>
<td>06</td>
<td>00FF</td>
</tr>
<tr>
<td>“NEXT”</td>
<td>07</td>
<td>0003</td>
</tr>
<tr>
<td>“EXEC”</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Go Execute (“EXEC”)

The “go execute” (“EXEC”) function allows the user to change the contents of the PC (program counter) register in order to direct execution of instructions at the user-selected address.

The “go execute” function is entered by pressing a “SHIFT 2” when the system is in the command recognition mode. Now the user must enter an address of one to four hexadecimal digits. If more than four digits are entered, only the value shown in the address display is used as the address to begin program execution. Execution begins when the “NEXT” or “EXEC” keys are pressed. This causes the Z80 registers to be stored in the register save area (see the operating system listing in Appendix D) and execution begins at the user-specified address.
GO EXECUTE Example

<table>
<thead>
<tr>
<th>Key</th>
<th>Address Display</th>
<th>Data Display</th>
</tr>
</thead>
<tbody>
<tr>
<td>&quot;SHIFT 2&quot;</td>
<td>0000</td>
<td>FF</td>
</tr>
<tr>
<td>1</td>
<td>0001</td>
<td>FF</td>
</tr>
<tr>
<td>A</td>
<td>001A</td>
<td>FF</td>
</tr>
<tr>
<td>C</td>
<td>01AC</td>
<td>FF</td>
</tr>
<tr>
<td>F</td>
<td>1ACF</td>
<td>FF</td>
</tr>
<tr>
<td>&quot;NEXT&quot;</td>
<td>or</td>
<td></td>
</tr>
<tr>
<td></td>
<td>&quot;EXEC&quot;</td>
<td></td>
</tr>
</tbody>
</table>

Serial I/O Services

The ZAP computer includes a serial input/output capability that is implemented with a UART. This interface allows serial communication between the computer and peripheral devices such as a printer or a CRT. To aid the user in utilizing this capability, the operating system has a UART diagnostic module, a serial input module, and a serial output module. The input and output modules are set up as subroutines that can be called during program execution and that are not necessarily keyboard and display limited.

UART Diagnostic Module

The UART diagnostic module provides a means for checking the performance of the UART. To utilize this feature the user must first attach the serial output and input lines together so that data output from the UART may be read by the same device. The serial diagnostic subroutine is initiated by using the "go execute" function. Execution starts at 032D16.

Once started, the diagnostic module (UATST) begins by sending data to the UART and waiting for data to become available. The status of the UART is checked to verify that no fault conditions are present. In the event that a fault is detected, the status of the UART is displayed on the two low-order digits of the address display. (See table 6.2 for error codes.) If there are no errors, the data is read and displayed on the two-digit-data display. A comparison is made between the input and output data. If the 2 bytes are equal, the output character is incremented and another byte is sent to the UART to continue the sequence. This procedure continues until the "RESET" button is pressed, or until an error is detected. In the event that the input character does not equal the output character, a 0F16 is displayed in the two lower digits of the address display and the diagnostic is halted. Figure 6.1 details the logic flow of this software routine.

<table>
<thead>
<tr>
<th>Displayed Code</th>
<th>Error</th>
</tr>
</thead>
<tbody>
<tr>
<td>1216 or 1316</td>
<td>Parity Error</td>
</tr>
<tr>
<td>0A16 or 0B16</td>
<td>Framing Error</td>
</tr>
<tr>
<td>0616 or 0716</td>
<td>Overrun Error</td>
</tr>
<tr>
<td>00</td>
<td>Transmitter Buffer Not Empty</td>
</tr>
<tr>
<td>0F16</td>
<td>Input Character ≠ Output Character</td>
</tr>
</tbody>
</table>

Table 6.2 UART error codes.
Figure 6.1 A flowchart of the UART diagnostic module (UATST).

Serial Input Module

The serial input module has been included so the user can read serial data from external devices. To utilize this capability, the user must set aside a programmable memory buffer where the input data is to be stored, and designate the number of input characters expected. The input buffer address is stored at address 07F9₁₆ in memory (see Appendix D), and the number of characters is stored at address 07FD₁₆. The communication reception begins when the TTYINP module is called.

Serial Input Initiation Example

<table>
<thead>
<tr>
<th>TTYINP</th>
<th>EQU 035F₁₆</th>
<th>Address of input module</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUFFER</td>
<td>EQU 07F9₁₆</td>
<td>Input buffer address</td>
</tr>
<tr>
<td>NCHAR</td>
<td>EQU 80</td>
<td>Number of characters to be received</td>
</tr>
<tr>
<td>TTYIBU</td>
<td>EQU 07F9₁₆</td>
<td>Operating system address constant</td>
</tr>
<tr>
<td>TTYIC</td>
<td>EQU 07FD₁₆</td>
<td>Operating system address constant</td>
</tr>
<tr>
<td>LD</td>
<td>HL, BUFFER</td>
<td>Set buffer for operating system</td>
</tr>
<tr>
<td>LD</td>
<td>(TTYIBU), HL</td>
<td></td>
</tr>
</tbody>
</table>

THE ZAP MONITOR SOFTWARE 157
LD A, NCHAR       Set character count for operating system
LD (TTYIC), A     Call UART serial input routine
CALL TTYINP

The data read by the serial input module will be stored in the user-specified buffer until the input sequence is terminated. When this occurs, control is returned to the user's program at the next instruction. Termination of the input process may be due to any of the following conditions:

- A status error is detected
- The number of characters read equals preset count
- The receipt of a carriage return as an input character (ASCII 0D₁₆)

In the event that a status error is detected, the A register will be equal to 80₁₆ when control is returned to the user. If termination results from filling the character buffer correctly, the A register will be equal to 00₁₆. However, if termination is the result of a carriage return, the A register will be equal to the number of characters remaining to be input. Figure 6.2 details the logic flow of the TTYINP software module.

---

**Figure 6.2** A serial input module (TTYINP) flowchart.
Serial Output Module

The serial output module is provided to assist the user in communicating serial output data to external devices. To use this module, the operator designates an output data buffer address and the number of characters (bytes) to be transmitted. The output buffer address must be stored at 07FB$_{16}$ in memory (see Appendix D) and the number of characters to be sent is stored at address 07FE$_{16}$. Data transmission starts when TTYOUT is called.

Serial Output Initiation Example

TTYOUT EQU 039E$_{16}$ Address of output module
BUFFER EQU 07FB$_{16}$ Output buffer address
NCHAR EQU 35 Number of characters to be transmitted
TTYOBF EQU 07FB$_{16}$ Operating system address constant
TTYOC EQU 07FE$_{16}$ Operating system address constant
LD HL, BUFFER Set buffer address for operating system
LD (TTYOBF), HL
LD A, NCHAR Set character count for operating system
CALL TTYOUT Call UART serial output routine

Control will be returned to the user when

- The output buffer is empty
- The transmit buffer does not become available, indicating an error

In the event that a normal termination occurs, the A register will be equal to 00$_{16}$ when control is returned to the user. However, if a premature termination and return are required, the A register will be equal to 01$_{16}$. Figure 6.3 details the logic flow of the serial output software module.

Figure 6.3 A serial output module (TTYOUT) flowchart.
II. Operating System Module Description

II.1 Warm Start Module

The warm start module (WARM1) is responsible for saving all Z80 registers in the register save area allocated in the reserved portion of programmable memory (see Appendix D). Upon entry, the user's A, H, and L registers are saved to provide working registers for the remainder of the module operation. Next, the user's PC is removed from the stack and is saved in the memory locations reserved for it.

The AF register pair is pushed onto the stack and popped off into the HL register pair. This procedure enables the flag register to be saved in the register save area. The remainder of the user's working and alternate registers are examined and transferred to the register save area. Upon completion of this task, the module exits to the command recognition module. (See Appendix D for additional details.) Figure 6.4 details the logic flow of the warm start module.

Figure 6.4 A flowchart of the warm start module (WARM1).
II.2 Command Recognition Module

The command recognition module (WARM2) is entered after the completion of a cold or warm start sequence. When initiated, the module clears the keyboard input buffer and the keyboard flags. This removes ambiguity for future operations. The module will set the data display to FF and the address display to FFFF. When completed, the module enters the KEYIN subroutine to get an input character from the keyboard. Any input character is checked to see if it corresponds to one of the three allowable functions. If so, control is transferred to the proper function; otherwise, the input is ignored and the module waits for the next input from the keyboard. (See Appendix D for additional details.) Figure 6.5 illustrates the logic flow of the command recognition module.

Figure 6.5 A flowchart of the command recognition module (WARM2).
II.3 Restart Module

The restart module (RESTRT) takes the values stored in the programmable memory register save area. It then restores the user's 8- and 16-bit registers before returning control to the location specified in the PC save area. This procedure restores the alternate registers, and then the working registers. In either instance, the flag registers are restored by pushing the data onto the stack and then popping if off to the F register. In order to exit to the user's restart address, the saved PC is pushed onto the stack and a "RET" (return instruction) is executed. (See Appendix D for additional details.) Figure 6.6 details the logic flow of the restart module.

![Flowchart of the restart module (RESTRT)](image)

**Figure 6.6** A flowchart of the restart module (RESTRT).
II.4 Keyboard Input Module

The keyboard input module (KEYIN) provides the primary interface between the computer and the user. Upon entry, it begins to read data from the keyboard input port. It stays in a loop, checking the MSB (most significant bit) of the data. The MSB is the key-pressed strobe. When it goes to a logic one level, the seven LSBs (least significant bits) of the keyboard input port are retained as the desired input character. The module then returns to the user’s program with the keyboard character in the accumulator. (See Appendix D for additional details.) Figure 6.7 details the logic flow of the keyboard input module.

![Flowchart of the keyboard input module (KEYIN).](image)

**Figure 6.7** A flowchart of the keyboard input module (KEYIN).
II.5 One Character Input Module

The function of this module (ONECAR) is to input one or more characters from the keyboard. This module also indicates the last character and whether it was accompanied by a "NEXT" or "EXEC" key.

Upon entry, the input buffer and keyboard flags are cleared. (The data display may or may not be cleared depending on the requirements of the calling module.) The module waits for an input character to be passed to it. When it receives a character, it checks to see if it is a "NEXT" or "EXEC", or valid data. In the event that the input is a "NEXT" or "EXEC", the appropriate keyboard flag is set along with the no data flag and control returned to the user (see figure 6.8).

If an invalid data character is received, the module is reinitialized. Upon receipt of valid data, the data is stored in a 1-byte input buffer, and the module waits for the next input character. This character is processed in a manner similar to the one just described with the following exception: in the event that the input character is a "NEXT" or "EXEC", only the appropriate flag is set before returning control to the user. (See Appendix D for additional details.) Figure 6.9 shows the logic flow of the one character input module.

![Diagram of keyboard flags]

**Figure 6.8** The configuration of the keyboard flags.
II.6 Two Character Input Module

The function of this module (TWOCAR) is to input one or more characters from the keyboard and transfer to the user the last two characters when a "NEXT" or "EXEC" key is pressed. The module also notifies the user of the type of termination that took place.

Upon entry, the input buffer and keyboard flags are cleared. (The data display may or may not be cleared depending on the requirements of the calling module.) This module calls the keyboard input module to obtain its input data. The first character is checked to determine if it is a "NEXT" or "EXEC"; the appropriate keyboard flag is set along with the no data flag, and control is returned to the user (see figure 6.8). If an invalid character is received, the module is reinitiated.
The receipt of valid data will cause the module to format the data as a two-digit value in the keyboard input buffer. It then returns to the user with the appropriate flags set. (See Appendix D for additional details.) Figure 6.10 details the logic flow of the two character input module.

Figure 6.10 A flowchart of the two character input module (TWOCAR).

II.7 Four Character Input Module

The function of this module (FORCAR) is to input one or more characters from the keyboard and to transfer to the user the last four characters when a "NEXT"
or "EXEC" key is pressed. In the event that less than four characters are input, the higher order digits will be set to zero. The module also notifies the user via the keyboard flags (see figure 6.8).

The operation of this module is very similar to the two character input module. The main difference lies in the manner in which the new data (input from the keyboard) is merged into previous input data from the keyboard. (See Appendix D for additional details.) Figure 6.11 shows the logic flow of the four character input module.

Figure 6.11 A flowchart of the four character input module (FORCAR).
II.8 Memory Display and Replace Module

The memory display and replace function is one of the three major modules of the operating system. Upon entry (see command recognition module), this module (MEMORY) makes a call to FORCAR (four character input module) to get the base memory address at which to begin displaying the memory contents. When it returns from FORCAR, the keyboard flags are examined to determine if the "EXEC" flag is set (=1). In the event that the "EXEC" flag is set, control is transferred to the restart module (RESTRT). If the "EXEC" flag is not set (=0), the address location and memory contents are output to the appropriate displays. The TWOCAR (two character input module) is called to obtain new data from the displayed memory location.

Figure 6.12 A flowchart of the memory display and replace module (MEMORY).
When control is returned from TWOCAR, the module checks the "no data" flag in the keyboard flag word. If this flag is set (=1), the "EXEC" flag is examined. If that is set, control is transferred to the command recognition module (WARM2). If, on the other hand, the "EXEC" flag is reset (=0), the user's memory address is incremented, displayed on the address display, and its contents are displayed on the data display.

If, on return from TWOCAR, the "no data" flag is reset (=0), the new data is extracted from the keyboard input buffer and stored in the displayed memory location. At this time, the module determines if TWOCAR was exited via an "EXEC" or "NEXT" directive. In the event that the "EXEC" flag is set (=1), control is transferred to the command recognition module (WARM2). If, however, the flag is reset (=0), the user's memory address is incremented, displayed on the address display, and its contents are displayed on the data display. Then the two character input module is called to get the next directive for the memory display and replace module. (See Appendix D for additional details.) Figure 6.12 shows the logic flow of the memory display and replace module.

II.9 Register Display and Replace Module

The register display and replace module (REGIST) is one of the three major modules of the operating system. This module calls the ONECAR (one character input module) to get the initial register display code from the user (see table 6.1). Upon return from ONECAR, the "EXEC" flag is checked. If this flag is set (=1), control is transferred to the command recognition module (WARM2). If the "EXEC" flag is reset (=0), the base register display index is calculated from the user's register display code.

At this time, the register index is checked to see if the register request is an 8- or 16-bit register. If the user requests a 16-bit register, the appropriate register code is displayed in the data display and the requested register data is obtained from the register save area and displayed in the address display. The module then makes a call to the FORCAR (four character input module) to get new data for the register. Upon return, the "no data" flag is checked. If this flag is set and the "EXEC" flag is set, control is transferred to the RESTRT (restart module). If the "no data" and "NEXT" flags are set, the register display index is incremented and displayed in the data display. The new register data is obtained from the register save area and displayed on the address display.

If an 8-bit register has been requested, the register code (see table 6.1) is displayed in the data display, and the appropriate data is obtained from the register save area and displayed on the address display. At this time, the module calls TWOCAR to get new data from the displayed register. When the two character input module returns control, the module determines the mode of execution by examining the keyboard flags. If the "no data" and "EXEC" flags are set, control is transferred to the command recognition module (WARM2). If the "no data" and "NEXT" flags are set, the register index is incremented and the register contents channeled to the appropriate display.

If the "no data" flag is reset, the new register data is obtained from the keyboard input buffer and stored in the appropriate register save location. At this time the "EXEC" flag is checked and, if set, control is transferred to the command recognition module (WARM2). If the "EXEC" flag is reset, the register data is displayed and the user directive processed. (See Appendix D for additional details.) Figure 6.13 details the logic flow of the register display and replace module.
Figure 6.13 A flowchart of the register display and replace module (REGIST).
II.10 Go Execute Module

The go execute module (GOREQ) is the last of the three major functions of the operating system. Upon entry (see command recognition module), this module calls FORCAR to get the address where execution is to begin. Upon return from FORCAR, the "no data" flag is examined to determine the mode of execution. If this flag is set (=1), control is immediately transferred to RESTRT. This restores the Z80 registers and resumes execution at the PC address currently contained from the keyboard input buffer and stored in the PC save location in the register save area. Control is then transferred to the command recognition module (WARM2) which will restore the registers with the saved data, and begin execution of the user's program at the specified address. (See Appendix D for additional details.) Figure 6.14 details the logic flow of the go execute module.

![Flowchart of the go execute module (GOREQ).](image)

Figure 6.14 A flowchart of the go execute module (GOREQ).
CHAPTER 7
PROGRAMMING AN EPROM

The ZAP computer has been designed to be inexpensive, reliable, and easy to construct. To keep costs and complexity to a minimum, some computer features that could be helpful to a beginner have been eliminated. The most visible of the missing features are a front panel and display. While this in no way detracts from the operation of the computer, its inclusion would make initial checkout and program development easier.

To properly test ZAP, a program must be in memory. This program does not have to be very long—only a few instructions are necessary to determine whether the computer runs at all. The problem arises when the user wishes to run a program of 50 or 100 bytes in length. We end up with a "catch-22" situation. To effectively enter machine code into ZAP's programmable memory, a program that coordinates this activity must be running in EPROM. Such a program is called a monitor and is outlined in Chapter 6. The catch is that writing the monitor software into an EPROM automatically requires the monitor to be running the programmer. Fortunately, if one has an alternate way of writing the 1 K ZAP monitor into EPROM, this is no longer a problem.

Rather than leaving the experimenter to his own devices, this section includes information on programming EPROMs. To solve the startup situation, I've outlined a design for a couple of manual EPROM programmers. Loading programs on a manual programmer is tedious. They are primarily intended for much shorter routines such as checking basic system operations. However, one manual unit can be modified to load the full 1 K monitor software. When ZAP is fully operational, you can use it in conjunction with an automatic programmer. This will help in writing a number of EPROMs. In the event that you do not wish to write your own EPROM, consult Appendix A for the availability of preprogrammed EPROMs.

A Quick Review of EPROMs

It is often desirable to have the non-volatility of ROMs but the read/write capabilities of semiconductor programmable memories. An effective compromise is the EPROM. This is a read-mostly memory. It is used as a ROM for extended periods of time, occasionally erased and reprogrammed as necessary. Erasure is accomplished by exposing the chip substrate, covered by a transparent quartz window, to ultraviolet light. We'll cover erasure at the end of this chapter.

The EPROM memory element used by Intel and most other manufacturers is a stored charge type called a FAMOS transistor (Floating-gate Avalanche injection Metal Oxide Semiconductor) storage device. By selectively applying a 25 V charging voltage to addressed cells, particular bit patterns that constitute the program can be written into the EPROM. This charge, because it is surrounded by insulating material, can last for years. Exposure to intense ultraviolet light drains the charge and results in the erasure of all programmed information.

There are many EPROMs on the market—2708s, 2716s, and 2732s are the major ones. For the most part, computerists have moved away from the very difficult-to-program 1702s and have opted for the more easily programmed 2708s and 2716s. An added benefit is their greater storage density. The newer EPROMs on the market are considerably more expensive than the 2708. All things considered, the 2708 is the best
buy for the money. At slightly greater expense, you could use the 2758 for a single supply operation. For these reasons, the EPROM programmer outlined in this chapter is the 2708.

Figure 7.1 is the circuit for a manual 2708 programmer. IC 5 and two sections of IC 3 provide the +25 V program pulse to the EPROM. IC 5 is set for a duration of 1 ms and is triggered by a logic 0 to 1 transition at its input. The EPROM both sources and sinks current through programming pin 18. A combination of devices rather than a simple open-collector driver is necessary. In the write mode, when CS/WE pin 20 is at +12 V and between programming pulses, pin 18 has to be pulled down by an active device because it sources a small amount of current. The programming pulse itself is about 30 mA and cannot easily be accommodated without emitter-follower configured Q1. This pulse should be between 25 and 27 V at pin 18. Three 9 V batteries will suffice. (An alternative is to use a commercial encapsulated 24 V, 50 mA power supply. The encapsulated supply can be resistor trimmed to produce the desired 25 to 27 V.)

To write a byte into the EPROM, a 10-bit address designating which of the 1024 bytes will receive the data is preset on switches SW 1 thru SW 10. To start at location 0, all switches will be in the closed position. Next, the 8 bits that are to be stored are set on switches SW 12 thru SW 19. This data byte should be reflected on the output display LED 1 thru LED 8. Finally, to get the programmer in the write mode, switch SW 11 is set open. Actual insertion of the data occurs when the write pulse pushbutton PB 1 is pressed. This fires a 1 ms pulse of 25 V into the 2708 program pin. According to manufacturer’s specifications, no single programming pulse should be longer than 1 ms. For maximum data retention, 100 of these programming pulses are recommended (totalling 100 ms per byte).

Unfortunately, 100 ms cannot be applied to a single address all at once. Manufacturers specify that it should be done sequentially and should consist of 100 1-ms applications. In short, it means that for a 25-byte program, each address should be written with one pulse and then the loop repeated up to 100 times. I have never tried to lengthen the pulse and program a 2708 faster than called for. Experience has shown, however, that some EPROMs are completely written with as few as 2 or 3 loops. Obviously, for full retention each address should be rewritten on an automatic programmer.

Reading back the stored contents of a 2708 is easy on the same manual programmer. First, all data input switches SW 12 thru SW 19 are opened to the “1” state and then “read/write” switch SW 11 is set in the closed or “read” mode. No other pulsing or clocking is necessary. The output display will show the contents of the byte pointed to by the address input switches SW 1 thru SW 10. It will remain constant until set to another address. Reading out the contents is simply a matter of incrementing this 10-bit address through the range of program addresses.

A slightly more complex manual programmer is demonstrated in figure 7.2. Three presettable counters are inserted between the address input switches and the EPROM. Instead of changing the switch positions for each address, they are now used only to preset the counters to some beginning address. If we want to program an EPROM starting at hexadecimal 3AA, the switches would be set to that address and the “address preset” switch pressed. The 10 LEDs, LED A0 thru LED A9, would read 3AA as the address. The data to be programmed is set on SW 12 thru SW 19. Pressing the “write data” push button PB1 (the renamed “address increment”) stores the data from the switches. Successive memory locations are programmed by setting SW 12 thru SW 19 and pressing PB1. Resetting the address counter to zero is accomplished by pressing the clear button.

It is easy to see how this manual programmer, while not greatly improving programming time, facilitates reading memory. Put all the data input switches to the logic 1 level, set the interface to the read mode, and preset and load a start address. Readout is accomplished simply by repeated operation of the address increment button.

An Automatic Programmer

You will need an operational ZAP computer to build an automatic programmer. The
Figure 7.2 A schematic diagram of a self-incrementing manual 2708 programmer. Light-emitting diodes (LEDs) are to be connected to all 10 address-input lines of the 2708. For clarity, only one LED (connected to address line A9) is shown in the diagram. The other LEDs are to be wired in the same way.
complexity of design can be reduced considerably by taking advantage of decoded, but to this point unused, I/O strobes provided in the basic ZAP. The circuit shown in figure 7.3 takes three less chips than the manual programmer in figure 7.2. Its operations, while similar in operation, are quite different in detail.

Four I/O strobes (input and output port 1, and input and output port 4) synchronize the hardware and software. Figure 7.4 shows the logic flow for writing an EPROM. With the EPROM connected directly to the data bus, only the strobes, rather than full-latched registers, are necessary for this interface.

To write data, the sequence should be as follows: first, an OUT 04 pulses the address counter clear lines, setting them to 0. Next, the EPROM is set to the program mode, and the first byte is written into the EPROM with an OUT 01 instruction.

Figure 7.5 shows how the 2708 program mode is selected. The significance of this circuit is that its output is wired as a 2-bit digital-to-analog converter to control the chip-select line of the 2708.

When an OUT 04 is executed, the CS pin will see 0 volts enabling the read mode. When an OUT 01 is executed, this voltage will be 12 V for program mode. When no strobe is present, CS will be at +5 V and the 2708 will be three-state.

An OUT 01 fires the 25 V program pulse for 1 ms while the pertinent data is on the data bus. After that, an INP 01 is executed, which increments the address counter to the next address position. We are not actually doing any input function, but instead we are using the decoded strobe of the INP 01 instruction to mean “increment address register.”

The hardware automatically keeps track of the address, but the software must implement its own counters to keep track of the 0 to 1023 positions as well as the number of times the complete 1024 bytes have been programmed. Remember, the manufacturer suggests 100 1-ms loops.

Reading the EPROM automatically is also very simple. A flow diagram of the logic is shown in figure 7.6. The address counter is cleared again by doing an OUT 04. Data is read by executing an INP 04. This data can be stored and analyzed. Finally, the address counter is incremented again with an INP 01, and the process is repeated to read the next byte.

While discussion has centered on the Intel 2708 EPROM as the most cost-effective choice, there are many other EPROMs on the market. Two devices of particular importance (should their price and availability improve by the time you read this) are the Intel 2758 and 2716. These are 1 K and 2 K single supply (+5 V) EPROMs, respectively. The significance for the experimenter is that these parts can be programmed with a single, 50 ms, 25 V program pulse to each address rather than successive 1-ms loops. The three programmer circuits presented are set up for 2708s but can be easily reconfigured for these other devices. Changing the one-shot timing pulse from 1 ms to 50 ms and rewiring a few pins will allow complete programming with just a single run through the addresses (they don’t have to be successively programmed, either).

Erasing An EPROM

EPROMs bought directly from a manufacturer come completely erased. If you plan on writing an EPROM program once, and you either don’t want to modify it or you don’t make mistakes, forget about erasing. The majority of computerists will want to reprogram EPROMs. It then becomes necessary to know how to erase them. We all know that EPROMs are ultraviolet erasable. However, duration, distance from the light source, and intensity determine the quality of the erasure.

People concerned about maintaining a manufacturer’s specifications during the programming sequence should also be advised of the proper erasing methods. Unlike the test read-after-write-loop method for programming, EPROMs are usually removed from the circuit during erasing. Therefore, it is advisable to perform the procedure correctly, or it will have to be repeated.

The typical 2708 EPROM can be erased by exposure to high intensity shortwave ultraviolet light, with a wave length of 2537 Å. The recommended integrated dose (UV intensity × exposure time) is 12.5 watt-seconds per square centimeter (Ws/cm²). The time required to produce this exposure is a function of the ultraviolet light intensity.
Cost and safety, equally emphasized, should be the guiding factors when selecting an ultraviolet eraser. A commercial unit not only specifies its intensity (that allows computation of exposure time), but also includes important interlocks. It is conceivable that some homebrew erasers might have improper shielding that could allow the ultraviolet light to escape or be accidentally turned on while being viewed. Such possibilities can lead to permanent eye damage.

One of the more cost-effective erasers on the market is the UVS-11E by Ultra-Violet Products, Inc, San Gabriel CA, 91776. This unit is made especially for the home computer market and includes some important safety features. The lamp will not operate unless properly seated, and if lifted from its holding tray, it will automatically shut off. At the standard exposure distance of 1 inch, the UVS-11E produces an intensity of 5,000 \( \mu \text{W/cm}^2 \) per square centimeter (\( \mu \text{W/cm}^2 \)). Exposure time for the 2708 is easily calculated.

\[
T_e = J + I
\]

Where

\[
J = \text{required erasure density of device}
\]

\[
I = \text{incident power density of eraser}
\]

For a 2708 which requires 12.5 Ws/cm\(^2\)

\[
J = 5000 \, \mu \text{W/cm}^2
\]

\[
I = 12.5 \, \text{Ws/cm}^2
\]

\[
T_e = \frac{12.5}{5000 \times 10^{-6}} = 2500 \text{ seconds}
\]

or \( T_e = 41.6 \text{ minutes for complete erasure} \)
Figure 7.3 A schematic diagram of an automatic 2708 programmer.
Figure 7.4 A flowchart of an automatic EPROM programmer write cycle.

Figure 7.5 Programmable control of an EPROM CS line in an automatic EPROM programmer.
Figure 7.6 A flowchart of an automatic EPROM programmer read cycle.
CHAPTER 8
CONNECTING ZAP TO THE REAL WORLD

It's now obvious that the ZAP computer can be configured in a number of ways. Depending on your needs, you can go far beyond the basic system I have outlined. If you want a personal computer that is the equivalent of large commercial microcomputer systems, then you must add considerably more memory and peripherals. Accommodations must be made for a more powerful operating system and most probably a high-level language such as BASIC or Pascal. If you intend to use the ZAP computer as a word processing system, then a video display and printer will be required. This, in turn, necessitates adding more parallel and serial ports. Whatever the eventual configuration, the design considerations that went into constructing the ZAP computer do not change.

The ZAP computer is intended as a trainer. This book is structured in such a way that you should be able to lay out a system configuration and build it. I have not discussed what it takes to design a word processing system, or to add floppy disk storage, because it is beyond the scope of this introductory text. The support material necessary to adequately cover such an undertaking would be enough for another book. This does not mean, however, that everything is finished once the ZAP computer is constructed and you learn how to write and execute a short program. Quite the contrary; a more significant application of ZAP is to connect it to something considered part of the "real world" and have it perform some constructive task. ZAP's "power to weight" ratio makes it a natural for intelligent control applications. The real key to using ZAP effectively is learning how to connect it to the real world.

Within the framework of the direct examples I have outlined, the ZAP computer created from this book should be a single-board computer suitable for use in a variety of applications. Because it includes a serial port, two parallel ports, PROM monitor, and programmable memory, ZAP is in many respects equivalent to commercial digital controllers costing hundreds of dollars more.

Small single-board computers are most often used in data acquisition and intelligent control applications. Their function is usually to digest certain input parameters and compute a result. For example, in a 100 HP electric motor control, the inputs would be voltage, current, and RPM, and the control output would be a load factor correction voltage.

In all probability, a few of these "intelligent controllers" were used by the press that printed this book. A likely place is the electronic control unit that monitors print density and automatically adjusts ink flow. The computer "reads" the print and decides whether to increase or decrease the ink flow to the paper. This decision must take into account various input parameters such as humidity, temperature, paper velocity, and specific gravity of the ink. The control algorithm written in machine code and stored in ROM shifts through all the input data and generates its conclusion in the form of a proportional output to an ink-flow valve.

In most cases, computerized functions do not stop with simple control. In any process where repeatability and quality control are important, significant process parameters are constantly monitored for deviation from preset limits and an alarm is set if the limits are exceeded. To aid in long-term analysis, the data acquisition function often includes recording raw-process data from the input sensors at specific intervals and gen-
erating a permanent log.

THE REAL WORLD

I don't want to confuse you by discussing too many commercial applications of single-board controllers. I doubt there are many web presses hidden in closets to which you want to add computer control. There are, however, many equally challenging and less esoteric applications for computer controls around the home. For example, a few that come to mind include energy management, security, and environmental monitoring. I refer to such systems as real world systems, as opposed to the TTL digital world of computers.

Because real world is anything outside of the computer, it is generally an analog environment. The metamorphosis of ZAP into an intelligent controller is dependent primarily upon effective analog interfacing. For this reason, the rest of this chapter is dedicated to the design and construction of an economical analog I/O interface.

But first let's review the basics of D/A (digital-to-analog) conversion and then discuss a method to use a D/A to perform A/D (analog-to-digital) conversion. In data acquisition systems, there is often a need to acquire high resolution multiple channels, and AC as well as DC inputs. This being the case, I will also discuss a circuit which, in effect, allows ZAP to function as an 8-channel digital voltmeter. Finally, because the temporal relationship of so many events is significant, ZAP will be configured with a real-time clock that defines the time at which control operations occur.

DIGITAL-TO-ANALOG CONVERTERS

The D/A (digital-to-analog) converter can be thought of as a digitally controlled programmable potentiometer that produces an analog output. This output value \( V_{\text{out}} \) is the product of a digital signal (D) and an analog reference \( V_{\text{ref}} \) and is expressed by the following equation:

\[
V_{\text{out}} = D \times V_{\text{ref}}
\]

To a large extent, no D/A or A/D converter is very useful without specifying the type of code used to represent digital magnitude. Converters work with either unipolar or bipolar digital codes. Unipolar includes straight binary and binary coded decimal (BCD). Offset binary, one's or two's complement and Gray code, is usually reserved for bipolar operation. However, we will limit our discussion to straight and offset binary.

It is important to remember that the binary quantity presented by the computer is a representation of a fractional value to be multiplied by a reference voltage. In binary fractions, the MSB (most significant bit) has a value of 1/2 or 2\(^{-1}\), the next MSB is 1/4 or 2\(^{-2}\), and LSB (least significant bit) is 1/2\(n\) or 2\(n\) (where n is the number of binary places to the right of the binary point). Adding up all the bits produces a value that approaches 1. (The more bits, the closer that value is to 1.) The algebraic difference between the binary value that approaches 1, and 1, is the quantization error of the digital system (to be discussed later).

Offset binary is similar to straight binary except that the binary number 0 is set to represent the maximum negative analog quantity; the MSB is a 0 for negative analog values, and a 1 for positive analog values.

The conversion of digital values to proportional analog values is accomplished by either of two basic conversion techniques: the weighted-resistor D/A converter and the R-2R D/A converter. The weighted-resistor D/A converter is by far the simplest and most straightforward. This parallel decoder requires only one resistor per bit and works as follows: switches are driven directly from the signals that represent the digital number D; currents with magnitudes of 1/2, 1/4, 1/8, ..., 1/(2\(n\)) are generated by resistors with magnitudes of R, 2R, 4R, ..., 2\(n\)R, that are connected by means of switches between a reference voltage, \( -V_{\text{ref}} \), and the summing point of an operational amplifier. The various currents are summed and converted to a voltage by an operational amplifier (see figure 8.1).

While this may appear to be a simple answer to an otherwise complex problem, this method has some potentially hazardous ramifications. The accuracy of this converter
is a function of the combined accuracies of the resistors, switches (all switches have some resistance), and the output amplifier. In conversion systems of greater than 10-bits resolution, the magnitudes of the resistors become exceptionally large and the resultant current flow is reduced to such a low value as to be lost in circuit thermal noise.

A reasonable alternative to the weighted-resistor D/A converter is the R-2R converter. This is often referred to as a resistor-ladder D/A converter and is the most widely used type even though it uses more components. This circuit (see figure 8.2) also contains a reference voltage, a set of binary switches, and an output amplifier. The basis of this converter is a ladder network constructed with two resistor values, R and 2R.

One resistor (2R) is in series with the bit switch, while the other (R) is in the summing line, so that the combination forms a “pi” network. This suggests that the impedances of the three branches of any node are equal, and that a current I, flowing into a node through one branch flows out as I/2 through the other two branches. In other words, a current produced by closing a bit switch is cut by half as it passes through each node on the way to the end of the ladder. Simply stated, the position of a switch, with respect to the point where the current is measured, determines the binary significance of the particular switch closure.

**Figure 8.1** A 4-bit weighted-resistor digital-to-analog converter. A 4-bit word is used to control four single-pole single-throw switches. Each of these switches is in series with a resistor. The resistor values are related as powers of 2, as shown. The other sides of the switches are connected together at the summing point of an operational amplifier. Currents with magnitudes inversely proportional to the resistors are generated when the switches are closed. They are summed by the op amp and converted to a corresponding voltage.

**Figure 8.2** A 4-bit R-2R resistor-ladder digital-to-analog converter. This type of D/A converter makes use of a resistor-ladder network constructed with resistors of value R and 2R. The topology of this network is such that the current flowing into any branch of a 3-branch node will divide itself equally through the two remaining branches. Because of this, the current will divide itself in half as it passes through each node on its way to the end of the ladder. The four switches are again related as powers of 2. The position of each switch with respect to its distance from the end of the ladder determines its binary significance.
This type of converter is easy to manufacture because only two resistor values are needed; in fact, one value, R, will suffice if three components are used for each bit. Keeping matched resistor values with the same temperature coefficients contributes to a very stable design. Certain trade-offs are required between ladder resistance values and current flow to balance accuracy and noise.

One form of the R-2R ladder circuit is the multiplying D/A converter and is available with either a fixed or an externally variable reference. Multiplying D/A converters that utilize external variable analog references produces outputs that are directly proportional to the product of the digital input multiplied by this variable reference. These devices have either current or voltage output. The current output devices are much faster because they do not have output amplifiers that limit the bandwidth; therefore, they tend to cost less than voltage types.

An economical 8-bit multiplying D/A is the Motorola MC1408-8 (see figure 8.3). As previously mentioned, this monolithic converter contains an R-2R ladder network and current switching logic. Each binary bit controls a switch that regulates the current flowing through the ladder. If an 8-bit digital input of 11000000 (192 decimal) is applied to the control lines of the illustrated converter, the output current would be equal to (192/256)(2 mA) or 1.50 mA. Note that when binary 11111111 (255 decimal) is applied, there is always a remainder current that is equal to the LSB. This current is shunted to ground, and the maximum output current is 255/256 of the reference amplifier current, or 1.992 mA for a 2.0 mA reference current. The relative accuracy for the MC1408-8 version is ±1/2 the LSB, or 0.19% of full scale (see figure 8.4). This is more than adequate for most home computer analog control applications.

The final circuit (figure 8.5) is an 8-bit MC1408-8 multiplying D/A converter. As previously outlined, "multiplying" means that it uses an external variable reference voltage. In this case, a 6.8 V zener-diode regulated voltage is passed through a resistor that sets the current flowing into pin 14 to approximately 2 mA.

Figure 8.3 A typical 8-bit current-output monolithic multiplying D/A converter. This Motorola integrated circuit contains an R-2R network like the one in figure 8.2, plus additional current-switching logic.
Figure 8.4 Output characteristics of a digital-to-analog converter showing least significant quantization.

Figure 8.5 A final 8-bit MC1408-B multiplying digital-to-analog converter with span and offset adjustments.
An additional resistor, R1 (also in this current leg), allows the current to be varied by a small percentage and provides the ability to adjust the full-scale range of the D/A converter. The output is a current that is equivalent to the product of this reference current and the binary data on the control lines. The current is converted to a voltage through IC 9 and can be zero offset through the use of the offset adjustment pot, R2.

Using this circuit with the ZAP computer is simply a matter of connecting the input lines of IC 1 to a convenient parallel output port on ZAP. Any 8-bit value sent to that port will be converted to a voltage proportioned to that output.

The digital code presented to the D/A converter must be in offset binary. A binary value of 00 hexadecimal produces an output of −5 V while FF hexadecimal is equivalent to +5 V. In offset binary, if the MSB is a 0, the output is negative, and if the MSB is a 1, the output is positive. Because the converter has a range of 10 V, and is an 8-bit device, the resolution of the converter is 1/256 of 10 V, or approximately 40 mV. This means that the smallest output increments will be in 40 mV steps. To change this to finer increments requires a shorter range, such as +2.56 V to −2.56 V. By adjusting the span and zero pots, any reasonable range may be chosen, but the resolution will always be equal to the LSB or 1/256 of the range, and accuracy is estimated to be ±1/2 the LSB.

Calibration is fairly straightforward. Apply the power, and with a short program that outputs a value from the accumulator, send a binary 10000000 to the port address corresponding to the D/A interface board. Using a meter to monitor the output of the LM301A, adjust the zero pot R2 until the output is 0 V. With the same program, load in binary 11111111 to the port address and adjust the span pot R1 for a meter reading of +5.12 V. A binary setting of 00000000 should produce −5.12 V. If you are unsuccessful at this point, turn the power off and remove the MC1408-8 and the LM301A; then reapply power and verify that the binary output is correct on the parallel output port. Nine times out of ten, problems like this can be attributed to choosing an incorrect output code.

If the test is successful, you are now ready to generate analog outputs under program control. A simple test is to designate a section of memory and sequentially output the values to the D/A. If the table is 256 bytes long with the values ranging from 0 to FF hexadecimal in 01 increments, the result will be a sawtooth-waveform output. If the samples are sent to the output rapidly enough, and it is connected to a speaker, the waveform will be audible. The exact frequency will be a function of the update timing loop.

The following is a short program that exercises the D/A in such a manner:

```
START EQU 0400 Memory table start HL address
END EQU 05 Memory table end H address
OPORT EQU 07 D/A output port number
SAMP EQU A0 Sample rate time constant
AGAIN
  LD HL, START Load table start address
  LD A, (HL) Table value to accumulator
  OUT OPORT, A Output byte to D/A
  CALL DELY Sample time delay
  INC HL
  LD A, H
  CP END Test to see if at end of table
  JP NZ, AGAIN If not, output the next sample
HALT

DELY
  LD B, SAMP Sample rate timing loop
  DCR B
  JP NZ, DCR
  RET
```

The table can be set to any length. Values in the table can be calculated to produce any shape waveform.
ANALOG-TO-DIGITAL CONVERTERS

It’s always a good idea to discuss D/A converters first. They are rather straightforward and there are not an overwhelming number of conversion methods. By introducing them first, you will become aware of the process of binary conversion and appreciate the concepts of resolution and accuracy. Practically speaking, however, if you were going to set up the ZAP computer to serve in a data acquisition mode—say, reading and recording temperatures—you would need an A/D (analog-to-digital) converter before a D/A (digital-to-analog).

An A/D does what its name implies. It converts analog voltages into a digital representation compatible with the computer input. As in the case of an 8-bit D/A, an A/D is subject to the same conversion rules. If you are trying to read a 10 V signal with an 8-bit converter, the resolution will be 1/256 of 10 V (or 40 mV) and the accuracy will be ±1/2 the LSB.

For greater resolution more bits are necessary. The number of bits does not set the range of a converter; it only determines how finely the value is represented. An 8-bit converter (either A/D or D/A) can be set up just as easily to cover a range of 0 to 1 V or 0 to 1000 V. Often the same circuitry is used, but a final amplification stage or resistor-divider network is changed. Understand, of course, that with a range of 1000 V and an 8-bit converter, the resolution is 4 V. Such a unit would be useless on 0 to 10 V signals. The problem can be reconciled in a number of ways, but the easiest solution is to use a converter with more bits. A 16-bit converter that has 65,536 (2^16) steps instead of 256 (2^8) would cover the same 1000 V range in 15 mV increments.

For the ZAP computer, the question becomes more one of reasonable price performance than nth degree accuracy.

Analog-to-digital conversion is considerably more expensive than D/A—the price is directly related to resolution and accuracy. There are many ways that A/D conversion can be accomplished. The range varies from very slow, inexpensive techniques to ultrafast, expensive ones. An A/D converter can cost as little as $5 or as much as $10,000. An A/D converter that scans thermistor probes and provides data to control the temperature in a large supermarket may cost $4.75, but it cannot encode video information from an optical scanner.

The objective of this book, of course, is to help you to build your own computer; little is served by presenting designs that are beyond a reasonable budget and average construction abilities. For those reasons, I have sifted through a multitude of techniques to select four designs that can easily be built and attached through the ZAP computer’s parallel interface. One of them should meet your basic data acquisition requirements.

1. Basic analog to pulse width converter
2. Low cost and low speed 8-bit binary-ramp counter converter
3. High speed 8-bit successive approximation converter
4. Eight-channel 3½-digit 0—200 V AC/DC interface

PULSE WIDTH AND BINARY COUNTER CONVERTERS

Analog to Pulse Width Converter

This converter is one of the most popular open-loop encoders because of its simplicity. A basic block diagram is shown in figure 8.6. This device uses a fixed oscillator in combination with a circuit that generates a pulse width that is a linear function of the analog input voltage.

To obtain this variable linear pulse width, designers frequently use a ramp generator and a Schmitt-trigger circuit. A gating pulse is started at the beginning of the ramp and a counting circuit starts incrementing at a fixed frequency. When the linear ramp reaches the same value as the input voltage, the counting is terminated. The value left in the register at that point is representative of the analog input.

Figure 8.7 is a schematic of a unipolar analog to pulse width converter that operates on this principle. IC 1 is configured as a gate controlled linear ramp generator and IC 2 is the input comparator. The process starts when the 7.5 KHz clock signal fires IC 3 (a 74121 one-shot), and starts its 35 ms period, which is the gate time. At the beginning of this gate period, a pulse that clears the two 7493s and the ramp generator is generated.
Figure 8.6 A block diagram of an analog to pulse width encoder.

Figure 8.7 A schematic diagram of a unipolar analog to pulse width converter.
This, in turn, enables the clock signal to the counter. The slew rate of the ramp generator is set to be approximately 10 V per 35 ms. IC 2 continuously compares the input and ramp voltages. When they are equal, the clock signal to the counter is stopped and the ramp generator is reset. At the conclusion of the 35 ms gate time, whatever value is in the counter is transferred to an 8-bit storage register. The value stored in this register is an 8-bit number proportional to the input voltage. The entire process starts again on the next clock pulse.

By properly selecting the gate times and the clock rate, you can change the span and resolution of the circuit. With a gate time of 35 ms and a clock rate of approximately 7500 Hz, 256 clock pulses should be counted during the gate time. The ramp timing adjustment pot should be set so that the counter reaches maximum count when 2.56 V is applied to the input of IC 2. A 10:1 divider attached to this input will allow the same 8-bit count to represent 25.6 V.

This circuit is simple, but its accuracy depends on the stability of the individual sections of the circuit. To use it, connect the register output to a parallel input port. Simply read the port when you want the latest value. The circuit automatically updates 28 times a second, hence no reading is older than 35 ms.

**Binary-Ramp Counter Converter**

The above A/D technique is most often used in slow sampling rate, high-accuracy measurements. Achieving these results, however, hinges on the use of precision components and proper construction. The next most productive approach to consider is the binary-ramp counter method. In my opinion, this is the best type if you plan to construct an A/D for ZAP. It uses fewer components and, in practice, is much faster and easier to build than linear-ramp circuits.

Figure 8.8 illustrates the basic block diagram for the binary-ramp counter converter. The linear-ramp generator of the previous technique has been replaced by a D/A converter. In this case, the D/A is used to reconvert the digital output of the binary counter back to analog for comparison against the analog input. If they are equal, then whatever code is presently set on the D/A input is also our A/D output.

---

**Figure 8.8** A block diagram of a basic binary-ramp counter A/D converter.
The simplest way to operate the system is to start the counter initially at 0 and to allow it to count until the D/A equals or exceeds the analog input. The only critical consideration in designing this circuit is that the clock rate cannot be faster than the response of the comparator and D/A. If it takes 100 μs for these components to do their job, then the maximum clock rate should be 10 KHz. For an 8-bit converter (counting from 0 to 256 each sample period), the maximum sample rate is 10,000/256 or some 39 samples a second. In practice, however, 5 μs is a more reasonable settling time, resulting in about 750 samples per second. For still higher speeds, we use a different kind of A/D (more on this later).

Figure 8.9 shows a schematic of a binary-ramp counter converter that uses a MC1408-8 multiplying D/A converter chip. The counter output is connected to the MC1408-8 to provide a direct analog feedback comparison of the value set on the counter. Initially, ICs 4 and 5 are cleared and the D/A output should equal the minimum input voltage. For a 0 to 5.12 V converter, this would be 0 V. For a -2.56 to +2.56 V unit, it would be -2.56 V. If the output of IC 1 is less than V_in, the clock pulses are allowed to reach the counter. As each pulse increments the counter, the output of the D/A keeps rising until eventually it equals or just exceeds V_in on the comparator. When this happens, additional clock pulses are inhibited. At the end of the sample period, the count value of ICs 4 and 5 is stored in a separate register. For ZAP to read this data, it just requires connecting this register to an input port and reading it directly.

![Schematic diagram of a binary-ramp counter A/D converter]

**Figure 8.9** A schematic diagram of an 8-bit binary-ramp counter A/D converter.
Using the Computer to Replace the Counter

Figure 8.9 is a stand-alone circuit. It does not require the computer for operation. The A/D updates itself at a preselected sample rate and loads this value into an 8-bit latch. As far as the computer is concerned, there is a steady state reading from the converter. Every function required to perform the A/D conversion is constructed from hardware components.

There are certain advantages to this approach. The A/D can be independently assembled and tested without a computer. For example, a voltage can be applied to the input and the 8-bit value can be displayed on 8 LEDs. The ability to test each subsystem independently is the way I’ve tried to present all the hardware in this book. If, on the other hand, you feel you’ve mastered the art of programming and would rather not build elaborate interfaces, much of the hardware of figure 8.9 can be replaced with software subroutines.

Consider for a moment the major elements of this design. This 8-bit A/D has four sections: D/A, analog comparator, 8-bit counter, and timing logic. The resistor ladder and analog comparator are necessary components, but the last two sections are prime candidates for synthesis through the computer. The combined function of these devices is to increment an 8-bit count and check the output of the comparator.

The ZAP computer has parallel input and output ports. By incrementing a central processor register and outputting the value after each increment, the 8 lines from the port will have all the appearances of a standard 8-bit counter made with 7493s and so on. By using one bit of an input port to read the status of the comparator, we can also replace the rest of the timing logic.

The resulting interface has fewer components and is shown in figure 8.10. The D/A remains essentially the same except that rather than being driven from two 4-bit counters, it is connected to an 8-bit parallel output port. The analog output of the D/A will be whatever value is sent to the output port. Instead of hardwired logic to detect when the D/A and input voltage are equal, we attach the comparator output to bit 0 of an available input port.

Figure 8.10 A software-driven 8-bit analog-to-digital converter.
The conversion process is not unlike the hardware version. First, we clear a register (B, for example) and then output the register value to the port attached to the D/A. This will set the D/A to its minimum output. Next, we read the input port that has the comparator attached to it and check bit 0 (a logic 1 indicates that the input and D/A voltages are equal). If the comparator is low (the voltages are not equal), the register is then incremented and the process is repeated. Eventually, the register will be incremented to the point where the D/A output and the unknown input voltage are equal. The comparator will then switch. At this point the program is halted and the value of the B register is the digital equivalent of the input voltage. The program to accomplish this follows:

```
MVI B Clear B register
OUT 0, B Output B register
AGAIN INC B Increment B register
OUT 0, B Output B register
IN 04 Read comparator port
ANA 01 Isolate bit 0
JNZ AGAIN Continue if voltages not equal
HLT A/D value is in B register
```

The above program should be repeated each time a new reading is needed and the sample rate can be adjusted within broad limits. Remember, however, that we still have to wait for the D/A circuitry to settle and it should not be incremented any faster than 5 μs. Using the 2.5 MHz Z80 should not present a problem. Using a 4 MHz crystal the central processor might necessitate a few NOPs in the loop.

There are many variations on this circuit. As described, it takes up to 255 iterations of the program to find an answer. On a computer with a 2 μs average instruction time, the program could take 3 μs to finish, limiting us to about 300 samples a second. Add the other tasks that the computer must perform and you might be limited to 100 samples a second. Executing counting routines takes time; it will not, however, be a problem if you are merely monitoring a temperature probe that has a 30-second time constant.

If you should want to track and record fast changing signals, such as an acoustic waveform, then a much faster conversion algorithm is required. One method that speeds up the process is called successive approximation (more later).

The capabilities of this circuit can be expanded in other ways. An additional CMOS multiplexor can be connected to 3 bits of another output port to turn this simple circuit into an 8-channel A/D. Also, because this circuit includes a D/A, its output is available as well.

Successive Approximation Converters

More than likely one of the three converters presented thus far will suffice for non-critical data acquisition. Slowly changing signals can be handled accurately and efficiently. However, there are occasions when the signal in question is not slow or it carries a particular transient that must be captured. For example, detecting a 100 μs event requires a converter with a capability of 20,000 samples per second. In such cases we need a much faster conversion method.

Figure 8.11 is the schematic of a general purpose high-speed, 8-bit converter. It is capable of sample rates in excess of 200,000 samples per second. To attain these speeds, a technique called successive approximation is used. Like the binary-ramp counter converter, this A/D also incorporates a D/A in a feedback loop but replaces the counters with a special SAR (Successive Approximation Register). The circular logic of successive approximation is best explained in the block diagram of figure 8.12.

Initially the output of the SAR and mutually connected D/A are at a zero level. After a start conversion pulse, the SAR enables the bits of the D/A one at a time starting with the MSB. As each bit is enabled, the comparator gives an output signifying that the input signal is greater or less in amplitude than the output of the D/A. If the D/A output is greater than the input signal, a "0" is set on that particular bit. If it is less than the input signal, it will set that bit to "1". The register successively moves to the next least
Figure 8.11 A schematic diagram of an 8-bit successive approximation A/D converter.
significant bit (retaining the setting on the previously tested bits) and performs the same test. After all the bits of the D/A have been tried, the conversion cycle is complete. As opposed to the 256 clock pulses of the binary counter method, the entire conversion period takes only 8 clock cycles. Another conversion would commence on the next clock cycle when it’s in the free-run mode. To retain the 8-bit value between conversions, an 8-bit storage register IC 3 has been added. To use this A/D, simply connect the output of this latch to an 8-bit input port.

The components of the D/A circuit are changed slightly from previous implementations to increase the speed, and a faster comparator is used. With a clock rate of 800,000 Hz, the circuit will do 100,000 conversions a second. Because they are automatically loaded into the 8-bit-holding register IC 3, the update is transparent to the computer and can be read at any speed. The sample rate is a function of the clock rate. If it is unnecessary to have such a high sample rate, it may be reduced by increasing the value of C1. High speed A/D converters are susceptible to layout and component selection. While 200,000 samples per second is attainable, 20,000 samples per second might be more practical.

A Unique Application for a Fast A/D

When we first considered adding an A/D to ZAP, our thoughts centered on monitoring some process or turning ZAP into an intelligent controller. In most cases, this requires one of the simpler A/D converters I’ve outlined. However, with the addition of a high speed A/D peripheral, a few more experiments come to mind.

Most often when we think of high speed analog, we want to capture video or other high bandwidth phenomena that have a voltage level within the range of the A/D. Of course, the audio frequencies, while much lower than video, may also require a high performance A/D for proper representation.

The bandwidth of the human voice is about 4000 Hz. These analog signals, when spoken into a microphone and fed to an A/D, can be digitized just like any other waveform. And, if our voice samples are taken quickly enough and stored, the accumulated data can be used to reconstruct the same voice. This reconstructed voice is called digitized speech.

In essence, digitized speech is simply the result of a standard data acquisition technique. When speaking into a microphone and amplifier, your voice results in a fluctu-
ating waveform, whose frequency rate varies. If this signal is applied to the input of a high speed A/D, and the conversions stored in memory, the computer couldn’t care whether the source was speech or a nuclear reaction. The analog fluctuations would be digitized at discrete sampling intervals and stored. If the stored samples are output to a D/A at the same rate they were taken, speech will be reproduced. The fidelity of this reconversion is a function of the sampling rate.

Most of the intelligence or information content of human speech occurs in the frequency region below 1500 Hz. Obviously, sampling this waveform at 25 samples per second would be useless. It must be sampled very rapidly to retain anything of significance.

There is a specific law known as the “Nyquist criterion” that is used to determine the optimal sampling rate. In theory, this law states that at the very minimum, the sample rate must be twice the frequency of the input waveform. Thus, if the human voice extends to 4 Hz, then the minimum rate should be 8000 samples per second. This also assumes an ideal filter on the output, the existence of which is about as ephemeral as perpetual motion. In actuality, the sampling rate should be 3 or 4 times the highest input frequency. To digitize voice accurately requires a sampling rate of 12 Hz to 16 Hz. If, on the other hand, we shoot for just the lower frequencies, we can get by with 3 Hz or 4 Hz.

The possibility of using this speech technique has to be considered in light of the availability of large amounts of memory. At a 4 Hz sample rate, one second of speech takes 4000 bytes of memory. If you have added more than the 2 K of memory in the original configuration of ZAP, then perhaps you’ll want to experiment with digitized speech. Even with just 2 K you should hear something.

A fairly simple program is needed to coordinate the digitization process and store the data:

```
START EQU 400 Memory table start HL address
END EQU C00 Memory table end H address
TRIG EQU A8 Input start conversion level
IPORT EQU 04 A/D input port
SAMP EQU 38 Sample-rate time constant

INP IN IPORT Read A/D input value
CP TRIG Compare input to trigger level
JP NZ, INP Loop again if below trigger level
LD HL, START Load table start address
AGAIN IN IPORT Take a sample
LD (HL), A Store sample in memory
CALL DELY Delay between samples
INC HL
LD A, H
CP END Test to see if at end of table
JP NZ, AGAIN If not, take another sample
HALT

DELY LD B, SAMP Start delay timer
DCR DEC B
JP NZ, DCR
RET
```

When the program is executed, it will scan the A/D input port and compare the reading to A8 hexadecimal (about 65% of full scale). When speech is present, the audio level will presumably exceed this trigger level. When this happens, the program sets the address of the storage table and starts dumping data samples into it at a rate of about 4000 per second. The rate is determined by the value of “SAMP.” The higher the number, the lower the sampling frequency. When the table is filled, the program stops and the memory will contain a digitized representation of whatever was spoken during the sample time. For 2 K of memory, only ½ second of speech will be captured.

To hear this stored data, use the program outlined in the section on D/A converters.
Set the limits to be the area of the memory table, then choose a time constant that results in putting out the samples at the same rate that they were taken. (It is also possible to create a digital reverberation system using this hardware, but for decent fidelity 12- or 14-bit converters are required.)

Because digitized speech is a specialized application, the D/A circuit is modified slightly to include a low-pass filter. This will improve the sound quality. The modified circuit is shown in figure 8.13.

![Diagram of a 8-bit D/A converter with a low-pass filter.](image)

**Figure 8.13 An 8-bit D/A converter with a low-pass filter.**

**Using ZAP for High Resolution Data Acquisition**

Up to this point our discussion has concerned experimenting with ZAP. Some aspects of these designs are useful in noneducational applications, but for the most part they are intended more as teaching aids than as replacements for expensive monitoring equipment. However, it is possible to add more specialized interfacing to ZAP which allows it to be used in such a manner.

The 8-bit A/D converters presented thus far have limited resolution and are single-channel devices. They are adequate for measuring temperature in a solar heating system, but it is doubtful that they have the resolution to monitor the temperature gradient along a length of heating duct. The sensors used to measure such parameters would need to have a higher resolution than ambient air temperature sensors. For a range of $-20$ to $108^\circ$C, an 8-bit A/D could provide $0.5^\circ$ resolution. In a solar heating application, considering the variations in air movement, cloud cover, and general weather patterns, this is as much resolution as you would need. Within the system, however, there are areas that will require closer measurement.

A solar system is a typical example. After installation the next step is usually to investigate how to increase its efficiency. Nine times out of ten this requires cutting heat losses in the pipes and ducts. One way to determine such loss is to place temperature sensors along the heat distribution path and look for cold spots. The measured differences between sensors may be very small, a few tenths of a degree or so, but the overall losses could be significant. Measuring temperatures to tenths or hundredths of a degree and maintaining the same dynamic range requires more than 8-bit resolution. Something between 10 and 12 bits is needed.

The situation is further complicated by the large number of points that may need monitoring within a system. It's rare to find only one temperature indicator in the system. At the very least there would be six: inside air, outside air, storage tank top, storage tank bottom, collector, and distribution air temperature.
Very few commercial data acquisition systems use a single channel. Usually they come with either eight or 16 multiplexed channels. The input of one A/D converter is switched (usually on a demand basis) between the channels and the results are compiled and averaged by the computer. This information can be logged on recording tape, transmitted serially to another system, or used to run a real-time display. What one does with the data is a function of the application program.

There are various ways to configure ZAP for high-resolution data acquisition. One is to simply to replace the 8-bit A/D with a 12-bit binary converter. When the conversion is finished, 12 bits of parallel data are available. Depending upon the converter chosen, many outboard analog components might still be required, but the process is straightforward. Unfortunately, these converters are not what you would call inexpensive. Although they are becoming cheaper every day, at this writing they are still considerably more expensive than 8-bit converters of similar speed.

Most 12-bit binary converters are expensive because they are designed to give the appearance of parallel converters. Toggle the convert enable line and zip, there's 12 bits of answer. When the computer wants this data, it scans, manipulates, and stores it in a table for use by other programs. Making the hardware section of an A/D interface less expensive involves doing less in parallel. Taking the alternative serial approach generally requires more time and additional data manipulation. We can opt for the lowest expense and let our computer do most of the work. We have already demonstrated how to eliminate counters and timing logic by doing these functions in software.

An 8-Channel 3½-Digit AC/DC Interface for ZAP

The solution to the high resolution versus expense question comes in the form of a 3½-digit multiplexed A/D converter chip. The MC14433 CMOS integrated circuit is intended primarily for use in digital voltmeters (DVMs) but enjoys a variety of other applications because of its versatility. It is a single-channel 11-bit converter, but it is called 3½ digits. The output is BCD (binary-coded decimal) and it specifically covers a range of \(-1999\) to \(+1999\) counts. Basic chip specifications are as follows:

**MC14433 3½-Digit A/D Converter**

- Accuracy: \(\pm 0.05\% \) of reading \(\pm 1\) count
- Two voltage ranges: \(1.999\) V and \(199.9\) mV
- 25 conversions per second
- 1000 MΩ input impedance
- Auto zero
- Auto polarity
- Over, under, and auto ranging signals available

The MC14433 is a modified dual-ramp integrating A/D converter and is outlined in figure 8.14. The conversion sequence is divided into two integration periods: unknown and reference. During the \(V_{\text{IN}}\) (unknown input) integration sequence, the unknown voltage is applied to an integrator with a defined integration time constant for a predetermined time limit. The voltage output of the integrator then becomes a function of the unknown input. The more positive the input, the higher the integrator output.

During the second cycle of the integration sequence, a reference signal of \(2.000\) V is connected to \(V_{\text{IN}}\). This causes the integrator to move toward zero while the digital circuitry of the chip keeps track of the time it takes to reach zero. The time difference between the two integration sequences is then a function of their voltage difference. If \(2.000\) V were the applied \(V_{\text{IN}}\), then \(t_2\) would equal \(t_1\). The unknown voltage is equivalent to the ratio of the periods times the voltage reference \(V_{\text{REF}}\). This is also known as a ratiometric converter. The full scale of the converter is determined by \(V_{\text{REF}}\). Changing \(V_{\text{REF}}\) to \(0.200\) V will make the \(1999\) count output represent \(199.9\) mV instead of \(1.999\) V full scale.
Figure 8.14 A simplified representation of a dual-ramp A/D converter.

The output of the DVM chip is a combination of serial and parallel data. There are 4 digit-select and 4 BCD data lines:

**BCD Output Lines**

<table>
<thead>
<tr>
<th>Pin</th>
<th>BCD</th>
</tr>
</thead>
<tbody>
<tr>
<td>23</td>
<td>Q3 (MSB)</td>
</tr>
<tr>
<td>22</td>
<td>Q2</td>
</tr>
<tr>
<td>21</td>
<td>Q1</td>
</tr>
<tr>
<td>20</td>
<td>Q0</td>
</tr>
</tbody>
</table>

**Digit-Select Outputs**

<table>
<thead>
<tr>
<th>Pin</th>
<th>Digit-Select</th>
</tr>
</thead>
<tbody>
<tr>
<td>19</td>
<td>DS1 (MSD)</td>
</tr>
<tr>
<td>18</td>
<td>DS2</td>
</tr>
<tr>
<td>17</td>
<td>DS1</td>
</tr>
<tr>
<td>16</td>
<td>DS0</td>
</tr>
</tbody>
</table>
With respect to what the computer sees through 74LS04 output buffers, the digit select output is low when the respective digit is selected. The most significant digit (½ DS1) goes low immediately after an EOC (end-of-conversion) pulse and is followed by the remaining digits in a sequence from MSD to LSD. The multiplex clock rate is the system clock divided by 80; two clock periods are inserted between digit outputs.

During DS1, the polarity and certain status bits are available. The polarity is on Q2 and the ½ digit value is at Q3. If Q2 is a "1", then the input voltage is negative, and if Q3 is a "0", then the ½ digit is a 0.

Figure 8.15 details the schematic of the 8-channel interface board. As shown, it has the following capabilities:

- ZAP 3½-Digit DVM Interface
  - 8 programmable-input channels
  - AC or DC input capability
  - Programmable gain of 1, 10, or 100
  - Ranges of 0–200 mV, 0–2 V, 0–20 V, or 0–200 V
  - Input overvoltage protection

IC 1 is the MC14433 DVM chip. It is set for approximately 25 conversions a second and all outputs are buffered. IC 2 is a precision voltage reference chip that supplies the $V_{\text{REF}}$ signal. It is nominally 2.5 V and is trimmed to 2.000 V and 0.200 V with two potentiometers. While a zener diode might provide the same voltage, the temperature drift associated with such components makes them undesirable in this application.

IC 5 is configured as a set/reset flip-flop. When the conversion is finished, an EOC signal sets IC 5, indicating to the computer that data is available. When the computer finishes reading the data, it resets this flip-flop and awaits the next conversion.

ICs 1, 2, 3, and 4 constitute a single-channel 3½-digit converter. It has a range of either 0.200 V or 2.000 V determined by $V_{\text{REF}}$. To achieve multichannel operation and AC capability, it is necessary to place an input multiplexer and AC to DC converter in front of IC 1.

**Figure 8.15** An 8-channel 3½-digit 0–200 V AC/DC DVM interface (continued on next page).
Figure 8.15 continued
Figure 8.16 shows the voltage reference and range selection setup of this interface. The MC14433 can cover either 0–199.9 mV or 0–1.999 V. The ranges depend upon the level of \( V_{\text{ref}} \). When BS of port 1 is low, switches 5 and 6 are in the positions shown. This would apply 2.000 V to \( V_{\text{ref}} \) input and set the integration time constant with an 82 k\( \Omega \) resistor. With BS=0, \( V_{\text{ref}} \) is 0.200 V, and the integration resistor is 10 k\( \Omega \).

Figure 8.17 illustrates the input subsystem in simplified terms. SW1 and SW2 represent the gain selection section. As shown, the gain is 1 and no divider network is enabled. When an input relay is closed (controlled through IC 9), the input voltage of that channel is sent directly to the input of IC 1 through a 1 M\( \Omega \) resistor. If the interface is set for DC and a gain of 1, a 1.400 V input signal at channel 3 would be read directly as 1.400 V by the DVM chip. If, however, 150 V were suddenly applied, it would be shunted through Z1 and Z2, which protect IC 1. The data read by the computer will indicate an out of range condition because the input would be shunted to 4 V.

Closing SW1 or SW2 forms a divider network that allows the computer to read these higher voltages. A 10:1 divider is formed by closing SW1. The result is a divider network consisting of the 1 M\( \Omega \) resistor R1, and a 111 k\( \Omega \) resistor R2 to ground. An 8 V input signal would be read as 0.800 V at the input of IC 1. The programmer should keep in mind that a divider was used on that channel and multiply the answer by 10 when recording it.

Closing SW 2 forms a 100:1 divider. The mathematics is the same except that the resistor (R3) is now 11.11 k\( \Omega \). An 8 V input would become 0.080 V and a 150 V input would become 1.500 V. Obviously, proper range selection is necessary to maximize resolution.

An additional feature of this interface is the ability to accommodate AC inputs. This is accomplished by simply converting the AC signal to DC after the divider section output. IC 6 and IC 7 function as single-pole, double-throw switches to gate the converter in or out of the signal path. The actual AC-to-DC converter is shown in figure 8.18.

This device is known as an average RMS (Root Mean Square) converter. If you apply a 1.0 V peak AC signal to it, it will output 0.707 VDC. This is the technique used in most digital multimeters. This is also the way we commonly express AC voltages. For example, household 115 VAC is 115 V average RMS. The peak is about 176 V. The converter passes both AC and DC because there is no blocking capacitor on the input. If it is inadvertently switched into a DC signal, it will multiply the reading by 1.414.

\[\text{Figure 8.16 Voltage reference and integration time-constant modification circuitry for the digital voltmeter.}\]
Figure 8.17  DVM input conditioning sections.

Figure 8.18  A schematic diagram of an AC-to-DC converter.
Exercising the Interface with a Software Driver

The interface is attached to ZAP through I/O ports. It takes 10 input bits and 8 output bits for full operation. They are arbitrarily chosen as ports 1 and 4 for this description. The actual choice will depend on what addresses you wire when you are configuring ZAP. These ports are not used for anything in the original description and will require the proper port hardware to be added. Summarizing the I/O requirements for the DVM (digital voltmeter) interface:

**Command Output Byte (port 1 output)**

- B7  EOC enable or disable  Disable=1; Enable=0
- B6  AC or DC select  AC=0; DC=1
- B5  2.0 V or 0.2 V range  2.0 V=0; 0.2 V=1
- B4  gain code  0, 0=X1
- B3  0, 1=X10
- B2  1, 0=X100
- B1  channel code  channels 0-7 binary
- B0

**Status Input Byte (port 4 input)**

- B7
- B6
- B5  not used
- B4
- B3
- B2
- B1  out of range
- B0  end of conversion

**Data Input Byte (port 1 input)**

- B7  1st digit
- B6  2nd digit
- B5  3rd digit
- B4  4th digit
- B3
- B2
- B1  BCD value
- B0

when B7=0 then: B6
- B5  not used
- B4
- B3  1/2 digit value
- B2  polarity
- B1  not used
- B0  autoranging status bit

This interface uses a software driver to reduce hardware complexity. The program is not unlike a communications driver. To obtain data from the interface effectively, the computer must be synchronized with the DVM chip and must perform a specific sequence of operations to demultiplex the input data stream.

The actual program that interfaces to and stores the values from the DVM chip is written as a subroutine. All the information necessary for proper execution of the driver is provided in the DE register pair at the time of the call. Its contents will tell the interface which channel to set, whether it should be AC or DC, and which \( V_{\text{ref}} \) and gain to use. One channel is converted every time the driver routine is called.

The information set in the DE register pair at the time of the call is the command out-
put byte (port 1 output), and each bit has the designations previously listed. The only difference is that bit 7 (the enable/disable bit to the A/D converter) is sent as a logic 0 when doing a call. The driver will set it to an enable condition after it has pulled in the proper relay and allowed a 1.3 ms bounce delay.

Demultiplexing the output of the DVM chip is fairly straightforward. Following the call, the outputs to the interface close the proper switches, and the central processor hangs in a loop waiting for an end-of-conversion signal. When this happens, the program knows that the next 4 digits of data are what it wants. The DVM chip sets each of the digit select lines successively, and the program records the values of the 4 BCD data lines each time. It strips the status and polarity bits from the MSD ½-digit byte and reformats and stores the voltage input value in 4 bytes of memory. The 3 whole digits are stored in BCD notation and occupy 3 of the bytes. The ½ digit, polarity, and out of range indication are located in the fourth byte. Polarity is indicated by setting the MSB. A positive reading is a logic 1 and a negative input is a logic 0. The ½-digit value can only be a 0 or 1 and occupies the LSB of the quantity. Out of range is handled with a little program manipulation. If the driver detects that the incoming reading is not within range, it sets the equivalent of +2 in the ½-digit byte. Obviously, this is an illegal condition for a DVM only capable of counting to 1999. The programmer using this stored data should check the limits of the data before acting upon it.

When the driver completes its operation, it has acquired a 3½-digit reading and stored it as 4 bytes in a special table in memory. The 8 channels of data constitute a 32-byte table. The location of a particular channel's data is found by a simple expression:

The 4-byte data starts at memory location \( L + 4(N-1) \)

where \( L \) = starting address of memory table  
\( N \) = channel number (1 to 8)

Figure 8.19 is the assembly listing of the program that exercises this DVM interface. When assembled, it occupies less than a page of memory.

Note: One caution should be kept in mind when measuring AC signals with this interface. The ground on the DVM interface is the same as the computer's and a potential short circuit exists unless either the computer power supply or the measured voltage is isolated.

```
0100 *
0110 *** MC14433 3 1/2 DIGIT A/D CONVERTER DRIVER
0120 *
0125 * REV. 1.9
0130 *
0140 DIP EQU 1 DATA INPUT PORT NUMBER
0150 SIP EQU 4 STATUS INPUT PORT NUMBER
0160 COP EQU 1 COMMAND OUTPUT PORT NUMBER
0170 EEOC EQU 200 ENABLE EOC INPUT
0180 DEOC EQU 000 DISABLE EOC INPUT
0190 *
0200 *
0210 * CONVERTED CHANNEL DATA BUFFERS
0220 *
0230 CHAN0 DW 000000
0240 DW 000000
0250 CHAN1 DW 000000
0260 DW 000000
0270 CHAN2 DW 000000
0280 DW 000000
0290 CHAN3 DW 000000
0300 DW 000000
0310 CHAN4 DW 000000
0320 DW 000000
0330 CHAN5 DW 000000
0340 DW 000000
```

**Figure 8.19** A listing of the assembly-language program that exercises the digital voltmeter.
0350   CHAN6  DW   000000
0360   DW   000000
0370   CHAN7  DW   000000
0380   DW   000000
0390   *
0400   *  INTERMEDIATE DATA BUFFERS
0410   *
0430   CHAN  DB   000  CURRENT CHANNEL NUMBER
0440   CCP  DW   000000  COMMAND CHANNEL PARAMETER
0450   *
0470   *
0480   ***  START A/D CONVERTER
0490   *
0510   *
0560   START  LD   A, E
0570   LD   (CCP), A
0580   AND   007
0590   LD   (CHAN), A
0600   LD   IX, CHAN0
0610   LD   D, 0
0620   LD   E, A
0630   SLA   E  CALCULATE BUFFER OFFSET
0640   SLA   E
0650   ADD   IX, DE
0660   *
0670   *  SELECT CHANNEL AND START CONVERSION
0680   *
0695   LD   B, 3  SET CYCLE COUNT
0699   SCSC  LD   A, (CCP)
0700   OUT   COP  SELECT CHANNEL
0705   CALL   DELAY
0710   OR    EE0C  ENABLE EOC OUTPUT
0720   OUT   COP  COMMAND A/D CONVERTER
0730   *
0740   1040   *  WAIT FOR EOC
0750   *
0760   1060   WE0C  IN   SIP  READ CONVERTER STATUS
0770   BIT   0, A  TEST FOR EOC
0780   JR    Z, WE0C  JUMP IF NOT READY
0785   DJNZ  SCSC
0790   BIT   1, A  TEST FOR OVERANGE
0795   JR    NZ, OVER JUMP IF TRUE
0800   *
0810   1120   *  CONVERSION DONE; PROCESS FIRST (MSD) DIGIT
0820   *
0830   1140   MSD0  LD   B, 200  SELECT DIGIT 1
0840   CALL   RDIG  WAIT AND READ DIGIT 1
0850   CPL
0860   RRCA  RIGHT  JUSTIFY DIGIT VALUE
0870   RRCA
0880   RRCA
0890   AND   1   ISOLATE
0900   1210   LD   E, 0  INITIALIZE STATUS BYTE
0910   BIT   2, D  TEST POLARITY
0920   JR    NZ, MSD3  JUMP IF POSITIVE
0930   1240   LD   E, 200  LOAD POLARITY SIGN
0940   *
0950   1440   *  SAVE MSD AND CURRENT POLARITY
0960   *
0970   1470   MSD3  OR    E  ADD POLARITY SIGN TO MSD
0980   1480   LD   (IX+0), A  SAVE IN DATA BUFFER
0990   *
1000   1510   *  PROCESS 2ND DIGIT
1010   *
1020   1530   RRC  B  SELECT DIGIT 2
CALL RDIG  WAIT AND READ DIGIT
AND 017  ISOLATE
LD (IX+1)*A STORE SECOND DIGIT
*
* PROCESS 3RD DIGIT
*
RRC B  SELECT 3RD DIGIT
CALL RDIG  WAIT AND READ DIGIT
AND 017  ISOLATE
LD (IX+2)*A STORE
*
* PROCESS 4TH DIGIT
*
RRC B  SELECT 4TH DIGIT
CALL RDIG  WAIT AND READ DIGIT
AND 017  ISOLATE
LD (IX+3)*A STORE
RAPUF RET
*
LOAD 2,000 OVERRANGE VALUE INTO DATA BUFFER
*
OVER LD A*2 LOAD MSD VALUE
LD (IX+0)*A
XOR A
LD (IX+1)*A LOAD LSD VALUES
LD (IX+2)*A
LD (IX+3)*A
JR RAPUF
*
READ DIGIT ROUTINE
*
RDIG IN DIP READ DATA BYTE
CPL CONVERT TO HIGH TRUE LOGIC
LD D,A SAVE COPY
AND B TEST FOR GIVEN DIGIT READY
JR ZRDIG JUMP IF NOT
LD A,D RESTORE A REGISTER
RET RETURN TO CALLER
DELAY LD C*377
DEL1 DEC C
RET Z
JR DEL1

Figure 8.19 continued

Potential Applications
I feel that data acquisition is a natural application for ZAP. The interface outlined above can be used in a solar heating system to monitor and record pertinent data. Using the facilities of the ZAP monitor and the DVM interface routine, an 8-channel data logger is practical. In general, all that would be required is a supervisory program that calls the DVM 8 times to obtain the 8 sensor inputs. It then sets the limits of the memory table to a serial output subroutine and stores the readings on a cassette. This could be done continuously or at regular intervals. The ultimate system would include a real-time clock so that these readings, as well as the times at which they were taken, could be recorded.

Real-Time Clock
If ZAP is going to be used for critical data acquisition or control functions, consideration should be given to real-time synchronization with process events. A simple definition of a real-time system is one that responds to the need for action in a period of
time proportional to the urgency of the need. It boils down to the fact that the computer must be capable of performing a specific action at a specific time. For this to happen, the computer must be able to "tell time."

We can accomplish this by using either software or hardware applications. The simplest technique is to use a clock circuit (figure 8.20) to provide a time tick to the central processor's nonmaskable interrupt line. It can be every 60th, 10th, or 1 second, as suggested in the schematic. When the computer acknowledges the interrupt, it first saves all the registers from the program it was executing, and then services the real-time interrupt. Frequently, the first action is to increment an internal counter that keeps track of elapsed time. Usually it's a value equivalent to the total number of clock ticks, whether in seconds or milliseconds. Once this regular interval has been established, it is easy for the computer to perform real-time functions.

Clock resolutions down to milliseconds sound great and make interval timing extremely accurate. However, I doubt most ZAP builders would want to use such an interface in light of the complex software involved. I much prefer an interface that is easier to implement and more likely to be used.

Essentially, the kind of real-time system most appealing to ZAP owners has a resolution of perhaps 1 minute rather than 1 ms. Also, it's best if it can be read directly in hours and minutes rather than as a total clock count. A direct benefit is reduced overhead. The computer does not have to acknowledge the clock update or scan status flags as often. At first glance, it may not seem like much of a saving, but some routines can use up to 10 percent of the processor time handling a millisecond clock interrupt.

![Figure 8.20](image)

**Figure 8.20** A simple time-base generator for an interrupt-driven real-time clock.

**An Old Clock Chip to the Rescue**

The easiest way to provide an hourly and minute-by-minute input is to interface the computer to an MOS/LSI clock chip similar to that found on most digital clocks or watches. There are two approaches to the design of a clock interface: one method is to let the clock circuit operate independently from the computer, attached in such a way that the computer can monitor the output lines and extract a time value on the fly. The software necessary for this approach would be very much like the DVM interface described previously. The other method, which I prefer because it involves less software, is to give the computer complete control over the information flow of the clock in a synchronous manner.
Figure 8.21 shows such a clock interface. This circuit, manually preset to keep it simple, is computer directed. The basic 4-chip circuit consists of an MM5312 4-digit BCD/7-segment output digital clock chip, an MM5369 time-base generator, and two MOS-to-TTL buffers to send data to the processor.

Time is set on the chip by grounding the slow and fast set lines, pins 14 and 15. To know what is being set you must read the interface at the same time, and display the time on the 4-digit hexadecimal address display, already part of the expanded ZAP. Time is read from the interface as 4 binary-coded decimal numbers. The 8 input lines to the computer are attached to an 8-bit parallel input port, and are divided between 4 digit-enable lines, and 4 BCD digit-value lines. Data appear as a digit enable and an associated BCD number. The tens of minutes data is read on B0 thru B3 when B5 is high (B4, B6, and B7 are low). Similarly, B0 thru B3 will hold the tens of hours quantity when B7 is high. The interface logic will stay on a particular digit until it is instructed to proceed to the next digit. Sequencing is under program control and uses one output bit of a convenient parallel port.

**Figure 8.21** A schematic diagram of a real-time clock interface.

a) Using a MOS digital clock chip.

b) With battery backup.
Figure 8.22 shows how the multiplexer line is controlled in this application. One bit of an output port is used to pulse multiplexer input pin 22. (All that is required is a 1 ms pulse. As an alternative, a one-shot could be triggered from a decoded strobe line of an unwired port.) At any time, 1 of the 4 digit-enable lines will be low and a digit’s value will be on the BCD output lines. Just determine which digit it is and store the value. Next we pulse the multiplexer input to enable the next digit and save it as well. Conceivably, it takes only 4 iterations of this procedure to obtain a complete 4-digit reading. If you prefer a more orderly approach, you can follow the program flow outlined in figure 8.23. The only difference is that it waits until the chip cycles to the beginning before storing the readings.

**Figure 8.22** The multiplex timing sequence for the display in the circuit of figure 8.21.

**Figure 8.23** A flowchart of a program for the circuit in figure 8.21.

CONNECTING ZAP TO THE REAL WORLD 211
CHAPTER 9
BUILD A CRT TERMINAL

LOW COST VERSATILE CRT TERMINAL

This chapter describes the design of a low-cost features-oriented cathode-ray tube (CRT) terminal. Two MOS/LSI devices from Standard Microsystems Corporation reduce the number of parts required for a CRT terminal yet enhance its capabilities.

The two devices, the CRT 5027 video timer and controller and the CRT 8002 video display attributes controller, provide virtually all of the circuitry for the display portion of the CRT terminal. (See Appendices C8 and C9 for specifications.)

The terminal is designed to stand alone and communicate via an RS-232C interface with any computer system. If, in the expanded ZAP, the 6-character hexadecimal display proves inadequate, then the experimenter has only to construct this unit and attach it to the serial port already assembled.

Device Description

The CRT 5027 contains the logic required to generate all of the timing signals (vertical and horizontal synchronization, page refresh memory address, etc.) required by a CRT terminal. The entire display format including interlace/non-interlace, characters per row, rows per frame, scans per row, horizontal synchronization pulse width, and timing are user programmable for all standard and most nonstandard formats.

Although the CRT 5027 is basically structured for use with its own microprocessor, this design describes a "dumb terminal" using a low-cost PROM and standard TTL logic to replace the microprocessor control. While increasing the number of the parts, this design results in a low-cost, high quality alphanumeric/graphics terminal.

The CRT 8002 provides a $7 \times 11$ dot matrix, 128 character generator ROM, and a high-speed video shift register cursor. It includes logic to generate such functions as underline, blinking, reverse video, blanking, and strike-through. Additional wide and thin graphics modes allow the creation of line drawings, forms and unique graphic symbols.

Terminal Description

As with most electronic designs, a CRT terminal involves a large number of performance and cost trade-offs. A screen format of 16 rows of 64 characters per row was selected to minimize memory requirements (1 K bytes) and keep the video frequency within the limits of lower cost video monitors. An 80-character line would have not only increased the video frequency beyond the bandwidth of many low-cost monitors, but also would have increased the memory requirements. Similarly, more rows per page would have increased the memory requirement unless the characters per line were reduced.

In many microprocessor applications, the page memory is shared with the processor via a data bus. In this application, the page memory is used strictly by the CRT with data input synchronously, character-by-character, into the cursor position.

Full graphics or attributes may be selected on a character-by-character basis using
control words on the input data bus. A block diagram of the terminal is shown in figure 9.1.

![Block Diagram of a Low-Cost Cathode-Ray Tube Terminal](image)

Figure 9.1 A block diagram of a low-cost cathode-ray tube terminal.

Character Format

The CRT 8002 requires a minimum 8 × 12 character block to form its basic 7 × 11 character and to provide line and character spacing. However, in order to allow framing a character fully for a reverse video presentation, the horizontal character block must be increased to 9 or 10 dots. For the same reason, allocating 13 lines per character allows top and bottom framing as well.

With the standard TV sweep rates of 60 Hz (vertical) and 15,750 Hz (horizontal), there are 15,750 ÷ 60 = 262.5 lines per frame. As non-interlaced operation requires an even number of lines, a horizontal frequency of 15,720 Hz is used. The 16 rows × 13 scan lines per row result in 208 lines of displayed data. The remaining 54 lines will be automatically blanked by the CRT 5027 and will provide upper and lower margins.

To allow for left and right margins as well as for retrace time, a total 80 character times are allocated per line. A good rule of thumb is that the total number of character
times is 25% greater than the actual number of displayed characters.

The video clock frequency is calculated as follows: 10 (dots per character) \( \times 80 \) (character times per line) \( \times 15,720 \) Hz (horizontal sweep frequency) = 12.576 MHz. See the worksheet in table 9.1.

1. H CHARACTER MATRIX (No. of Dots): 7
2. V CHARACTER MATRIX (No. of Horiz. Scan Lines): 11
3. H CHARACTER BLOCK (Step 1 + Desired Horiz. Spacing = No. in Dots): 10
4. V CHARACTER BLOCK (Step 2 + Desired Vertical Spacing = No. in Horiz. Scan Lines): 13
5. VERTICAL FRAME (REFRESH) RATE (Freq. in Hz): 60
6. DESIRED NO. OF DATA ROWS: 16
7. TOTAL NO. OF ACTIVE “VIDEO DISPLAY” SCAN LINES (Step 4 x Step 6 = No. in Horiz. Scan Lines): 208
8. VERT. SYNC DELAY (No. in Horiz. Scan Lines): 26
9. VERT. SYNC (No. in Horiz. Scan Lines; T = \( \frac{190.8}{\mu s^*} \)): 3
10. VERT. SCAN DELAY (No. in Horiz. Scan Lines; T = \( \frac{1.59}{ms^*} \)): 25
11. TOTAL VERTICAL FRAME (Add steps 7 thru 10 = No. in Horiz. Scan Lines): 262
12. HORIZONTAL SCAN LINE RATE (Step 5 x Step 11 = Freq. in KHz): 15.720
13. DESIRED NO. OF CHARACTERS PER HORIZ. ROW: 64
14. HORIZ. SYNC DELAY (No. in Character Time Units; T = \( \frac{4.77}{\mu s^{**}} \)): 6
15. HORIZ. SYNC (No. in Character Time Units; T = \( \frac{5.57}{\mu s^{**}} \)): 7
16. HORIZ. SCAN DELAY (No. in Character Time Units; T = \( \frac{2.38}{ms^{**}} \)): 3
17. TOTAL CHARACTER TIME UNITS IN (1) HORIZ. SCAN LINE (Add Steps 13 thru 16): 80
18. CHARACTER RATE (Step 12 x Step 17 = Freq. in MHz): \( \frac{12576}{12.576} \)
19. CLOCK (DOT) RATE (Step 3 x Step 18 = Freq. in MHz): \( \frac{12576}{12.576} \)

*Vertical Interval
**Horizontal Interval

Table 9.1 A CRT 5027 worksheet for a 64 characters per row, 16 row, noninterlaced screen format.

Programming the VTAC

The CRT 5027 VTAC (Video Timer and Controller) is user programmable for all timing and format requirements. The programming data is stored in 9 on-chip registers. Although a microprocessor can easily provide the programming data, a low-cost PROM is used in this application. The 9 registers are programmed as follows (see table 9.2):

Register 0: This register contains the number of character times for one horizontal period, and is normally 1.25 times the number of characters per line, in this case 64 \( \times 1.25 = 80 \). As the internal counters are initialized at zero, the actual number in the register is 80 \(-\ 1 = 79\).

```
0 1 0 0 1 1 1 1
```

Register 0

Register 1: This has 3 fields:
1) bit 7 — one for interlace, zero for non-interlace. In this example, noninterlaced operation is selected.
2) bits 3 thru 6 program the number of character times for the width of the horizontal synchronization pulse. This parameter is monitor dependent and is typically
5 µs. Because there are 80 character times for a 63.6 µs horizontal scan time (1 ÷ 15,720), each character time is 0.801 µs; 7 character times will be used to generate a 5.56 µs pulse.

3) bits 0 thru 2 set the horizontal “front porch.” This essentially positions the data horizontally. The monitor’s specification will determine initial programming although some experimentation may be required to center the display exactly. Six character times were selected for the front porch.

\[
\begin{array}{cccccc}
0 & 0 & 1 & 1 & 1 & 1 \\
\end{array}
\]

Register 1

<table>
<thead>
<tr>
<th>REG.</th>
<th>ADDRESS</th>
<th>FUNCTION</th>
<th>BIT ASSIGNMENT</th>
<th>HEX.</th>
<th>DEC.</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0000</td>
<td>HORIZ. LINE COUNT</td>
<td>01001111</td>
<td>4F</td>
<td>79</td>
</tr>
<tr>
<td>1</td>
<td>0001</td>
<td>INTERLACE</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>H SYNC WIDTH</td>
<td>00111110</td>
<td>3E</td>
<td>62</td>
</tr>
<tr>
<td></td>
<td></td>
<td>H SYNC DELAY</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>0010</td>
<td>SCANS/DATA ROW</td>
<td>1X100111</td>
<td>63</td>
<td>99</td>
</tr>
<tr>
<td></td>
<td></td>
<td>CHARACTERS/ROW</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>64</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>0011</td>
<td>SKEW CHARACTERS</td>
<td>10001111</td>
<td>8F</td>
<td>143</td>
</tr>
<tr>
<td></td>
<td></td>
<td>DATA ROWS</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>16</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>0100</td>
<td>SCANS/FRAME</td>
<td>00000011</td>
<td>03</td>
<td>3</td>
</tr>
<tr>
<td></td>
<td></td>
<td>X = 3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>0101</td>
<td>VERTICAL DATA START</td>
<td>00011110</td>
<td>1C</td>
<td>28</td>
</tr>
<tr>
<td></td>
<td></td>
<td>= 3 + VERTICAL SCAN DELAY:</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>SCAN DELAY</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>25</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>DATA START</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>29</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>0110</td>
<td>LAST DISPLAYED DATA ROW</td>
<td>XX01111</td>
<td>OF</td>
<td>15</td>
</tr>
<tr>
<td></td>
<td></td>
<td>(= DATA ROWS)</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 9.2 A CRT 5027 register-programming worksheet for a 16 x 64 screen format.

Register 2: This has two fields:

1) bits 3 thru 6 (bit 7 is not used) set the number of scans per character. In this case, we have defined the character as 10 x 13, so the binary equivalent of 13 - 1 = 12 is used (all CRT 5027 counters start at zero, not one, so programming of counters is always one less than the number).

2) bits 0 thru 2 contain a 3-bit code for the number of characters per line. From the data sheet the code for 64 is 011.

\[
\begin{array}{cccc}
0 & 1 & 1 & 0 \\
\end{array}
\]

Register 2

Register 3: This has two fields:

1) bits 6 and 7 delay the blanking cursor and synchronization timing to allow for character generator and programmable memory propagation delays. Generally, one character time will allow for these delays.

2) bits 0 thru 5 define the number of data rows, once again starting with binary zero for one line. 16 - 1 = 15 will be programmed.

\[
\begin{array}{cccc}
1 & 0 & 0 & 0 \\
\end{array}
\]

Register 3

Register 4: Register 4 sets the number of raster lines per frame. For the noninterlaced mode this is derived by the formula (N - 256) ÷ 2 = 3.
Register 4

Register 5: This contains the number of raster lines between the start of the vertical synchronization pulse and the start of data (vertical synchronization + back porch). This time must be long enough to allow for the full retrace time of the monitor and to allow vertical positioning of the display. We will use 28 here. The front porch will be calculated by the CRT 5027 as 262 - (13 × 16) - 28 = 26.

Register 6

Register 6: Register 6, the scrolling register, is programmed with the number of the last data row to be displayed. Since we want to initialize the CRT 5027, this will be programmed the same as Register 3 (bits 6 and 7 are not used).

Register 7 and Register 8: These registers contain the cursor character number and row number respectively. Since the cursor is to be initially positioned at the top left corner, both registers will be initialized with all zeros. Subsequent cursor position changes will be entered as described under “circuit operation.”

Circuit Description

Referring to figure 9.2, IC 1A, IC 1B, IC 4 provide the video dot clock (12.58 MHz) and the character clock DCC, which is the dot clock ÷ 10 (each character is 10 dots wide). The video dot clock determines the actual video data rate. The character clock determines the speed each character is addressed. IC 6A buffers the dot clock input of the CRT 8002. A pull-up resistor is used on the output to guarantee the logic one requirement of the VDC input.

The LOAD command loads the register information required for programming the CRT 5027 from the PROM IC 7 to the CRT 5027. The “self-load” capability of the CRT 5027 is used to automatically scan the PROM addresses. LOAD is automatically generated on power-on by IC 1D.

Because of the bus structure of the CRT 5027, cursor position information is loaded on the same bus as the register data. Three-state data selectors IC 14 and IC 15 select cursor X position data from counter IC 8 and IC 7 or cursor Y position data from IC 1D. IC 12 and IC 13 select the address mode for the CRT 5027. Three modes are used: “nonprocessor self-load” for register loading, load cursor X position, and load cursor Y position.

IC 16 thru IC 21 decode attribute mode and cursor controls from the ASCII data bus. If graphics or special attributes are not desired, IC 16, 17, and 21 are not required. Similarly, if cursor controls are directly available, decoding them is not necessary.

IC 19 and IC 20 are 256 × 4 PROMs. Their exact programming can be suited to the user needs. The programming used in this terminal is shown in table 9.3. When a key designated as an attribute or mode key is depressed, the appropriate control word is latched in IC 21; all subsequent data entries will have that word loaded in the upper 4 bits of programmable memory. This allows the attribute or mode to be changed on a character-by-character basis. IC 18, a 2 to 4 decoder, is enabled when a cursor control backspace, carriage return/line feed, or † is decoded and provides the appropriate cursor movement.

TTL or low power TTL can be used throughout. Shottky TTL is recommended for IC 6 due to the fast rise time requirements of the clock input.
Figure 9.2 A schematic diagram of a low-cost versatile CRT terminal using the CRT 5027 and CRT 8002 chips (continued on next page).

218 BUILD A CRT TERMINAL
Operation

After power-on, Control Q should be depressed to latch the system in the “normal” mode. Depressing the space key and the erase key simultaneously will then blank the screen. All further character entries will be displayed normally. If other attributes or graphics are desired, the appropriate control code is entered. This character will not be displayed or cause cursor movement, but will latch the new command. Modes may be changed for every character desired. Cursor movement may be decoded from the ASCII input by the control key as indicated in table 9.3.

PROM Programming

<table>
<thead>
<tr>
<th>Keyboard Entry</th>
<th>Function</th>
<th>Address</th>
<th>PROM 1 Output</th>
<th>PROM 2 Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>Return</td>
<td>Carriage Return</td>
<td>00011011</td>
<td>0011</td>
<td>1000</td>
</tr>
<tr>
<td>LF</td>
<td>Line Feed</td>
<td>00010101</td>
<td>1011</td>
<td>1000</td>
</tr>
<tr>
<td>Control H</td>
<td>Cursor Left</td>
<td>00010001</td>
<td>0111</td>
<td>1000</td>
</tr>
<tr>
<td>RS</td>
<td>Cursor Up</td>
<td>00111101</td>
<td>1111</td>
<td>1000</td>
</tr>
<tr>
<td>US</td>
<td>Cursor Right</td>
<td>00111111</td>
<td>1111</td>
<td>1010</td>
</tr>
<tr>
<td>Control Q</td>
<td>Normal Attribute</td>
<td>00100011</td>
<td>1111</td>
<td>1011</td>
</tr>
<tr>
<td>Control W</td>
<td>Blink</td>
<td>00101111</td>
<td>1011</td>
<td>1011</td>
</tr>
<tr>
<td>Control E</td>
<td>Underline</td>
<td>00001011</td>
<td>0111</td>
<td>1011</td>
</tr>
<tr>
<td>Control R</td>
<td>Reverse Video</td>
<td>00100101</td>
<td>0011</td>
<td>1011</td>
</tr>
<tr>
<td>Control T</td>
<td>External Mode</td>
<td>00101001</td>
<td>1101</td>
<td>1011</td>
</tr>
<tr>
<td>Control Y</td>
<td>Wide Graphics</td>
<td>00110011</td>
<td>1100</td>
<td>1011</td>
</tr>
<tr>
<td>Control U</td>
<td>Thin Graphics</td>
<td>00101011</td>
<td>1110</td>
<td>1011</td>
</tr>
<tr>
<td>Balance of PROM</td>
<td></td>
<td>0011</td>
<td></td>
<td>1110</td>
</tr>
</tbody>
</table>

Table 9.3 PROM programming for the circuit of figure 9.2.

The Rest of the System

Figure 9.3 illustrates the balance of the circuitry required to implement a full RS-232C compatible serial I/O terminal. Utilization of MOS/LSI reduces the package count to a bare minimum.

A KR2376 keyboard encoder, IC 1, encodes and de-bounces the keyboard switches and provides an ASCII data word to the COM 2017 UART (see Appendices C6 and C7). The UART, in turn, provides the serial receive/transmit interface. The data rate is programmable by means of the switch controlled input code to a COM 8046 data rate generator (see Appendix C10).

TERMINAL VARIATIONS

The terminal described can easily be modified for a wide variety of other screen formats. The following changes are required for an 80-characters per row, 24-row format:

1. Horizontal sweep rate — to allow for the increased number of displayed lines (312), the horizontal sweep rate is increased to 20,220 Hz.
2. The video oscillator frequency is calculated as 9 (dots per character) × 100 (character times per row) × 20,220 = 18.198 MHz. Notice that 9 dots per character was selected instead of 10, as 10 would have resulted in a clock frequency of 20.2 MHz, which is beyond the CRT 8002A’s top frequency. IC 4, therefore, must be set for divide by 9 rather than 10.
3. An additional 1 K bytes of page memory is required. Figure 9.4 shows the revised address connections.
4. Register programming for the CRT 5027 follows the worksheet shown in tables 9.4 and 9.5.
Figure 9.3 A schematic diagram of a RS-232C interface for a terminal.

Figure 9.4 A memory-mapping system for a 24 × 80 screen format.
1. H CHARACTER MATRIX (No. of Dots): 7
2. V CHARACTER MATRIX (No. of Horiz. Scan Lines): 11
3. H CHARACTER BLOCK (Step 1 + Desired Horiz. Spacing = No. in Dots): 9
4. V CHARACTER BLOCK (Step 2 + Desired Vertical Spacing = No. in Horiz. Scan Lines): 13
5. VERTICAL FRAME (REFRESH) RATE (Freq. in Hz): 60
6. DESIRED NO. OF DATA ROWS: 24
7. TOTAL NO. OF ACTIVE "VIDEO DISPLAY" SCAN LINES (Step 4 x Step 6 = No. in Horiz. Scan Lines): 312
8. VERT. SYNC DELAY (No. in Horiz. Scan Lines): 3
9. VERT. SYNC (No. in Horiz. Scan Lines; \( T = \frac{148.3}{\mu s} \)): 3
10. VERT. SCAN DELAY (No. in Horiz. Scan Lines; \( T = \frac{902.2}{\mu s} \)): 18
11. TOTAL VERTICAL FRAME (Add steps 7 thru 10 = No. in Horiz. Scan Lines): 336
12. HORIZONTAL SCAN LINE RATE (Step 5 x Step 11 = Freq. in KHz): 202.20
13. DESIRED NO. OF CHARACTERS PER HORIZ. ROW: 80
14. HORIZ. SYNC DELAY (No. in Character Time Units; \( T = \frac{148}{\mu s} \)): 3
15. HORIZ. SYNC (No. in Character Time Units; \( T = \frac{494}{\mu s} \)): 10
16. HORIZ. SCAN DELAY (No. in Character Time Units; \( T = \frac{346}{\mu s} \)): 7
17. TOTAL CHARACTER TIME UNITS IN (1) HORIZ. SCAN LINE (Add Steps 13 thru 16): 100
18. CHARACTER RATE (Step 12 x Step 17 = Freq. in MHz): 2.022
19. CLOCK (DOT) RATE (Step 3 x Step 18 = Freq. in MHz): 18.198

*Vertical Interval  **Horizontal interval

**Table 9.4** A CRT 5027 worksheet for an 80 characters per row, 24 row, noninterlaced screen format.

<table>
<thead>
<tr>
<th>REG. #</th>
<th>ADDRESS</th>
<th>FUNCTION</th>
<th>BIT ASSIGNMENT</th>
<th>HEX.</th>
<th>DEC.</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0000</td>
<td>HORIZ. LINE COUNT</td>
<td>01100011</td>
<td>63</td>
<td>99</td>
</tr>
<tr>
<td>1</td>
<td>0001</td>
<td>INTERLACE</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>H SYNC WIDTH</td>
<td>10</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>H SYNC DELAY</td>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>0010</td>
<td>SCANS/DATA ROW</td>
<td>13</td>
<td>X11001011</td>
<td>65</td>
</tr>
<tr>
<td></td>
<td></td>
<td>CHARACTERS/ROW</td>
<td>80</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>0011</td>
<td>SKEW CHARACTERS</td>
<td>2</td>
<td>1001011</td>
<td>97</td>
</tr>
<tr>
<td></td>
<td></td>
<td>DATA ROWS</td>
<td>24</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>0100</td>
<td>SCANS/FRAME</td>
<td>336</td>
<td>00101000</td>
<td>28</td>
</tr>
<tr>
<td></td>
<td></td>
<td>X = 40</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>0101</td>
<td>VERTICAL DATA START</td>
<td>18 + VERTICAL SCAN DELAY:</td>
<td>0001010101</td>
<td>15</td>
</tr>
<tr>
<td></td>
<td></td>
<td>DATA START</td>
<td>21</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>0110</td>
<td>LAST DISPLAYED DATA ROW</td>
<td>( = DATA ROWS)</td>
<td>X10111</td>
<td>17</td>
</tr>
</tbody>
</table>

**Table 9.5** A CRT 5027 register-programming worksheet for a 24 x 80 screen format.
Appendix A

Construction Techniques

CONSTRUCTION TIPS

As a result of building a project every month for my "Ciarcia's Circuit Cellar" column in BYTE magazine and of constructing every circuit in this book, I feel I can speak as an authority on the subject of prototype construction. A prototype is a nice term that describes the one-of-a-kind kluge that you build from a schematic. This is opposed to the kit or semi-assembled project that includes a printed circuit board which only requires plugging in components.

Prototyping a circuit is not easy. There are many dos and don'ts, but successful prototyping is primarily a function of experience. And experience comes only by building something.

The text is purposely laid out with this philosophy in mind. I suggest that you start with the power supply. Not only is the rest of the computer useless without it, but it has built-in protective circuitry that is very forgiving if you make mistakes. Also, by constructing the power supply first, there is less likelihood of destroying the rest of the computer as you are testing the power supply.

In general, the cardinal rule of prototyping is: be neat. The ZAP computer has high frequencies. Wiring should be the shortest distance between two connections. The longer the wire, the more of an antenna it becomes. In extreme cases, the computer can actually cease to function because of induced electrical noise. With the relatively slower digital signals carried by the wiring attached to external input and output ports, the situation is less critical. Short pulses and high-speed data, such as the signals on the central processor control and address lines, are more critical. In these cases, it is always a good idea to use additional protective circuitry such as buffers.

To a certain degree, the ZAP computer can be laid out as you see fit. Figure A.1 suggests one approach: it can be wirewrapped or hand soldered. Almost any board large enough to accommodate all the chips should suffice. A good choice is a standard S-100 prototyping card available at most computer stores. There is no particular bus other than the standard Z80 signals designated for ZAP because it is primarily intended as a single-board system. The 100-pin connector provides a convenient I/O and power connector. Care should be taken if you decide to split the computer schematic and assemble the computer on more than one board. The separation should be between logical subsystems; for maximum success, all signals should be buffered in and out of the board, e.g., all the memory could be put on a separate card. As outlined in the text, the address and data lines necessary to this function are already properly buffered.

The question of wirewraping versus soldering is the builder's prerogative. Personally, I prefer point-to-point hardwiring because it's easier to modify when troubleshooting. Wirewraping might be easier where the ZAP circuit has already been tested and refined.

Long power-supply daisy chains should be avoided. Rather than running a single +5 V and ground wire, it is better to use a double-sided prototyping board so that the top and bottom sides of the board can be set to ground and +5 V respectively. With this approach, each chip can be plugged in (using IC sockets) and the power leads soldered directly to the copper planes. Wirewrapping or not, it is a good idea to solder the power leads to reduce the potential of intermittent connections. Using the ground
plane for wiring is one of the best ways to reduce noise in computers. If you don’t have a ground plane, then solder heavy wire around the perimeter of the circuit board and run short jumpers to it.

Decoupling capacitors are another must for computer prototyping. Digital-integrated circuits, while being virtually burn-out proof in most applications, are unfortunately susceptible to noise carried along the power lines. Often, it will cause them to
go into oscillation. By placing a 0.01\(\mu\)F to 0.1\(\mu\)F capacitor between +5V and ground about every third IC, the problem is eliminated. Another good idea is to place an electrolytic capacitor at the entrance of any DC power connection to the board. Generally, capacitors are tantalum and three pieces would be required for ZAP's three supplies.

Finally, if you like the concept of ZAP but would rather spend more time applying the finished product than testing your construction techniques, you can look into purchasing EPROMs programmed for the ZAP monitor. The monitor for the ZAP computer is available in a 2708 or single-volt 2716 EPROM for $25. Please specify the type you want when ordering. These are available from The Micromint, Inc., 917 Midway, Woodmere, NY 11598. Telephone (516) 374-6793.
## Appendix B
### ASCII Codes

<table>
<thead>
<tr>
<th>Dec</th>
<th>Octal</th>
<th>Hex</th>
<th>Parity</th>
<th>Space</th>
<th>or</th>
<th>Character</th>
<th>Control</th>
<th>Keybd.</th>
<th>Equivalent</th>
<th>Alternate Code Names</th>
</tr>
</thead>
<tbody>
<tr>
<td>000</td>
<td>000</td>
<td>00</td>
<td>Even</td>
<td>NUL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>NULL, CTRL SHIFT P, TAPE LEADER</td>
</tr>
<tr>
<td>001</td>
<td>001</td>
<td>01</td>
<td>Odd</td>
<td>SOH</td>
<td></td>
<td></td>
<td>A</td>
<td></td>
<td></td>
<td>START OF HEADER, SOM</td>
</tr>
<tr>
<td>002</td>
<td>002</td>
<td>02</td>
<td>Odd</td>
<td>STX</td>
<td></td>
<td></td>
<td>B</td>
<td></td>
<td></td>
<td>START OF TEXT, EOA</td>
</tr>
<tr>
<td>003</td>
<td>003</td>
<td>03</td>
<td>Even</td>
<td>ETX</td>
<td></td>
<td></td>
<td>C</td>
<td></td>
<td></td>
<td>END OF TEXT, EOM</td>
</tr>
<tr>
<td>004</td>
<td>004</td>
<td>04</td>
<td>Odd</td>
<td>EOT</td>
<td></td>
<td></td>
<td>D</td>
<td></td>
<td></td>
<td>END OF TRANSMISSION, END</td>
</tr>
<tr>
<td>005</td>
<td>005</td>
<td>05</td>
<td>Even</td>
<td>ENQ</td>
<td></td>
<td></td>
<td>E</td>
<td></td>
<td></td>
<td>ENQUIRY, WRU, WHO ARE YOU</td>
</tr>
<tr>
<td>006</td>
<td>006</td>
<td>06</td>
<td>Even</td>
<td>ACK</td>
<td></td>
<td></td>
<td>F</td>
<td></td>
<td></td>
<td>ACKNOWLEDGE, RU, ARE YOU</td>
</tr>
<tr>
<td>007</td>
<td>007</td>
<td>07</td>
<td>Odd</td>
<td>BEL</td>
<td></td>
<td></td>
<td>G</td>
<td></td>
<td></td>
<td>BELL</td>
</tr>
<tr>
<td>008</td>
<td>010</td>
<td>08</td>
<td>Odd</td>
<td>BS</td>
<td></td>
<td></td>
<td>H</td>
<td></td>
<td></td>
<td>BACKSPACE, FE0</td>
</tr>
<tr>
<td>009</td>
<td>011</td>
<td>09</td>
<td>Even</td>
<td>HT</td>
<td></td>
<td></td>
<td>I</td>
<td></td>
<td></td>
<td>HORIZONTAL TAB, TAB</td>
</tr>
<tr>
<td>010</td>
<td>012</td>
<td>0A</td>
<td>Even</td>
<td>LF</td>
<td></td>
<td></td>
<td>J</td>
<td></td>
<td></td>
<td>LINE FEED, NEW LINE, NL</td>
</tr>
<tr>
<td>011</td>
<td>013</td>
<td>0B</td>
<td>Odd</td>
<td>VT</td>
<td></td>
<td></td>
<td>K</td>
<td></td>
<td></td>
<td>VERTICAL TAB, VTAB</td>
</tr>
<tr>
<td>012</td>
<td>014</td>
<td>0C</td>
<td>Even</td>
<td>FF</td>
<td></td>
<td></td>
<td>L</td>
<td></td>
<td></td>
<td>FORM FEED, FORM, PAGE</td>
</tr>
<tr>
<td>013</td>
<td>015</td>
<td>0D</td>
<td>Odd</td>
<td>CR</td>
<td></td>
<td></td>
<td>M</td>
<td></td>
<td></td>
<td>CARRIAGE RETURN, EOL</td>
</tr>
<tr>
<td>014</td>
<td>016</td>
<td>0E</td>
<td>Odd</td>
<td>SO</td>
<td></td>
<td></td>
<td>N</td>
<td></td>
<td></td>
<td>SHIFT OUT, RED SHIFT</td>
</tr>
<tr>
<td>015</td>
<td>017</td>
<td>0F</td>
<td>Even</td>
<td>SI</td>
<td></td>
<td></td>
<td>O</td>
<td></td>
<td></td>
<td>SHIFT IN, BLACK SHIFT</td>
</tr>
<tr>
<td>016</td>
<td>020</td>
<td>10</td>
<td>Odd</td>
<td>DLE</td>
<td></td>
<td></td>
<td>P</td>
<td></td>
<td></td>
<td>DATA LINK ESCAPE, DC0</td>
</tr>
<tr>
<td>017</td>
<td>021</td>
<td>11</td>
<td>Even</td>
<td>DC1</td>
<td></td>
<td></td>
<td>Q</td>
<td></td>
<td></td>
<td>XON, READER ON</td>
</tr>
<tr>
<td>018</td>
<td>022</td>
<td>12</td>
<td>Even</td>
<td>DC2</td>
<td></td>
<td></td>
<td>R</td>
<td></td>
<td></td>
<td>TAPE, PUNCH ON</td>
</tr>
<tr>
<td>019</td>
<td>023</td>
<td>13</td>
<td>Odd</td>
<td>DC3</td>
<td></td>
<td></td>
<td>S</td>
<td></td>
<td></td>
<td>XOFF, READER OFF</td>
</tr>
<tr>
<td>020</td>
<td>024</td>
<td>14</td>
<td>Even</td>
<td>DC4</td>
<td></td>
<td></td>
<td>T</td>
<td></td>
<td></td>
<td>TAPE, PUNCH OFF</td>
</tr>
<tr>
<td>021</td>
<td>025</td>
<td>15</td>
<td>Odd</td>
<td>NAK</td>
<td></td>
<td></td>
<td>U</td>
<td></td>
<td></td>
<td>NEGATIVE ACKNOWLEDGE, ERR</td>
</tr>
<tr>
<td>022</td>
<td>026</td>
<td>16</td>
<td>Odd</td>
<td>SYN</td>
<td></td>
<td></td>
<td>V</td>
<td></td>
<td></td>
<td>SYNCHRONOUS IDLE, SYNC</td>
</tr>
<tr>
<td>023</td>
<td>027</td>
<td>17</td>
<td>Even</td>
<td>ETB</td>
<td></td>
<td></td>
<td>W</td>
<td></td>
<td></td>
<td>END OF TEXT BUFFER, LEM</td>
</tr>
<tr>
<td>024</td>
<td>030</td>
<td>18</td>
<td>Even</td>
<td>CAN</td>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td>CANCEL, CANCL</td>
</tr>
<tr>
<td>025</td>
<td>031</td>
<td>19</td>
<td>Odd</td>
<td>EM</td>
<td></td>
<td></td>
<td>Y</td>
<td></td>
<td></td>
<td>END OF MEDIUM</td>
</tr>
<tr>
<td>026</td>
<td>032</td>
<td>1A</td>
<td>Odd</td>
<td>SUB</td>
<td></td>
<td></td>
<td>Z</td>
<td></td>
<td></td>
<td>SUBSTITUTE</td>
</tr>
<tr>
<td>027</td>
<td>033</td>
<td>1B</td>
<td>Even</td>
<td>ESC</td>
<td></td>
<td></td>
<td>[</td>
<td></td>
<td></td>
<td>ESCAPE, PREFIX</td>
</tr>
<tr>
<td>028</td>
<td>034</td>
<td>1C</td>
<td>Odd</td>
<td>FS</td>
<td></td>
<td></td>
<td>\</td>
<td></td>
<td></td>
<td>FILE SEPARATOR</td>
</tr>
<tr>
<td>029</td>
<td>035</td>
<td>1D</td>
<td>Even</td>
<td>GS</td>
<td></td>
<td></td>
<td>]</td>
<td></td>
<td></td>
<td>GROUP SEPARATOR</td>
</tr>
<tr>
<td>030</td>
<td>036</td>
<td>1E</td>
<td>Even</td>
<td>RS</td>
<td></td>
<td></td>
<td>^</td>
<td></td>
<td></td>
<td>RECORD SEPARATOR</td>
</tr>
<tr>
<td>031</td>
<td>037</td>
<td>1F</td>
<td>Odd</td>
<td>US</td>
<td></td>
<td></td>
<td>_</td>
<td></td>
<td></td>
<td>UNIT SEPARATOR</td>
</tr>
<tr>
<td>032</td>
<td>040</td>
<td>20</td>
<td>Odd</td>
<td>SP</td>
<td></td>
<td></td>
<td>SPACE, BLANK</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>033</td>
<td>041</td>
<td>21</td>
<td>Even</td>
<td>!</td>
<td></td>
<td></td>
<td>&quot;</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>034</td>
<td>042</td>
<td>22</td>
<td>Even</td>
<td>&quot;</td>
<td></td>
<td></td>
<td>#</td>
<td></td>
<td></td>
<td>#</td>
</tr>
<tr>
<td>035</td>
<td>043</td>
<td>23</td>
<td>Odd</td>
<td>$</td>
<td></td>
<td></td>
<td>%</td>
<td></td>
<td></td>
<td>%</td>
</tr>
<tr>
<td>036</td>
<td>044</td>
<td>24</td>
<td>Even</td>
<td>$</td>
<td></td>
<td></td>
<td>&amp;</td>
<td></td>
<td></td>
<td>&amp;</td>
</tr>
<tr>
<td>037</td>
<td>045</td>
<td>25</td>
<td>Odd</td>
<td>%</td>
<td></td>
<td></td>
<td>'</td>
<td></td>
<td></td>
<td>APOSTROPHE</td>
</tr>
<tr>
<td>038</td>
<td>046</td>
<td>26</td>
<td>Odd</td>
<td>(</td>
<td></td>
<td></td>
<td>)</td>
<td></td>
<td></td>
<td>(</td>
</tr>
<tr>
<td>039</td>
<td>047</td>
<td>27</td>
<td>Even</td>
<td>)</td>
<td></td>
<td></td>
<td>+</td>
<td></td>
<td></td>
<td>+</td>
</tr>
<tr>
<td>040</td>
<td>050</td>
<td>28</td>
<td>Even</td>
<td>+</td>
<td></td>
<td></td>
<td>.</td>
<td></td>
<td></td>
<td>COMMA</td>
</tr>
<tr>
<td>041</td>
<td>051</td>
<td>29</td>
<td>Odd</td>
<td>.</td>
<td></td>
<td></td>
<td>-</td>
<td></td>
<td></td>
<td>MINUS</td>
</tr>
<tr>
<td>042</td>
<td>052</td>
<td>2A</td>
<td>Odd</td>
<td>-</td>
<td></td>
<td></td>
<td>/</td>
<td></td>
<td></td>
<td>/</td>
</tr>
<tr>
<td>043</td>
<td>053</td>
<td>2B</td>
<td>Even</td>
<td>/</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>044</td>
<td>054</td>
<td>2C</td>
<td>Odd</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>045</td>
<td>055</td>
<td>2D</td>
<td>Even</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>046</td>
<td>056</td>
<td>2E</td>
<td>Even</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>047</td>
<td>057</td>
<td>2F</td>
<td>Odd</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

APPENDIX B 229
<table>
<thead>
<tr>
<th>Dec</th>
<th>Octal</th>
<th>Hex</th>
<th>Parity</th>
<th>Space</th>
<th>Character</th>
<th>Control Keybd.</th>
<th>Alternate Code Names</th>
</tr>
</thead>
<tbody>
<tr>
<td>048</td>
<td>060</td>
<td>30</td>
<td>Even</td>
<td>0</td>
<td>0</td>
<td>NUMBER ZERO</td>
<td></td>
</tr>
<tr>
<td>049</td>
<td>061</td>
<td>31</td>
<td>Odd</td>
<td>1</td>
<td>1</td>
<td>NUMBER ONE</td>
<td></td>
</tr>
<tr>
<td>050</td>
<td>062</td>
<td>32</td>
<td>Odd</td>
<td>2</td>
<td>2</td>
<td></td>
<td></td>
</tr>
<tr>
<td>051</td>
<td>063</td>
<td>33</td>
<td>Even</td>
<td>3</td>
<td>3</td>
<td></td>
<td></td>
</tr>
<tr>
<td>052</td>
<td>064</td>
<td>34</td>
<td>Odd</td>
<td>4</td>
<td>4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>053</td>
<td>065</td>
<td>35</td>
<td>Even</td>
<td>5</td>
<td>5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>054</td>
<td>066</td>
<td>36</td>
<td>Even</td>
<td>6</td>
<td>6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>055</td>
<td>067</td>
<td>37</td>
<td>Odd</td>
<td>7</td>
<td>7</td>
<td></td>
<td></td>
</tr>
<tr>
<td>056</td>
<td>068</td>
<td>38</td>
<td>Odd</td>
<td>8</td>
<td>8</td>
<td></td>
<td></td>
</tr>
<tr>
<td>057</td>
<td>069</td>
<td>39</td>
<td>Even</td>
<td>9</td>
<td>9</td>
<td></td>
<td></td>
</tr>
<tr>
<td>058</td>
<td>070</td>
<td>3A</td>
<td>Even</td>
<td>:</td>
<td>:</td>
<td></td>
<td></td>
</tr>
<tr>
<td>059</td>
<td>071</td>
<td>3B</td>
<td>Odd</td>
<td>;</td>
<td>;</td>
<td></td>
<td></td>
</tr>
<tr>
<td>060</td>
<td>072</td>
<td>3C</td>
<td>Even</td>
<td>&lt;</td>
<td>&lt;</td>
<td>LESS THAN</td>
<td></td>
</tr>
<tr>
<td>061</td>
<td>073</td>
<td>3D</td>
<td>Odd</td>
<td>=</td>
<td>=</td>
<td></td>
<td></td>
</tr>
<tr>
<td>062</td>
<td>074</td>
<td>3E</td>
<td>Odd</td>
<td>&gt;</td>
<td>&gt;</td>
<td>GREATER THAN</td>
<td></td>
</tr>
<tr>
<td>063</td>
<td>075</td>
<td>3F</td>
<td>Even</td>
<td>?</td>
<td>?</td>
<td></td>
<td></td>
</tr>
<tr>
<td>064</td>
<td>100</td>
<td>40</td>
<td>Odd</td>
<td>@</td>
<td>@</td>
<td>SHIFT P</td>
<td></td>
</tr>
<tr>
<td>065</td>
<td>101</td>
<td>41</td>
<td>Even</td>
<td>A</td>
<td>A</td>
<td></td>
<td></td>
</tr>
<tr>
<td>066</td>
<td>102</td>
<td>42</td>
<td>Even</td>
<td>B</td>
<td>B</td>
<td></td>
<td></td>
</tr>
<tr>
<td>067</td>
<td>103</td>
<td>43</td>
<td>Odd</td>
<td>C</td>
<td>C</td>
<td></td>
<td></td>
</tr>
<tr>
<td>068</td>
<td>104</td>
<td>44</td>
<td>Even</td>
<td>D</td>
<td>D</td>
<td></td>
<td></td>
</tr>
<tr>
<td>069</td>
<td>105</td>
<td>45</td>
<td>Odd</td>
<td>E</td>
<td>E</td>
<td></td>
<td></td>
</tr>
<tr>
<td>070</td>
<td>106</td>
<td>46</td>
<td>Odd</td>
<td>F</td>
<td>F</td>
<td></td>
<td></td>
</tr>
<tr>
<td>071</td>
<td>107</td>
<td>47</td>
<td>Even</td>
<td>G</td>
<td>G</td>
<td></td>
<td></td>
</tr>
<tr>
<td>072</td>
<td>110</td>
<td>48</td>
<td>Even</td>
<td>H</td>
<td>H</td>
<td></td>
<td></td>
</tr>
<tr>
<td>073</td>
<td>111</td>
<td>49</td>
<td>Odd</td>
<td>I</td>
<td>I</td>
<td>LETTER I</td>
<td></td>
</tr>
<tr>
<td>074</td>
<td>112</td>
<td>4A</td>
<td>Odd</td>
<td>J</td>
<td>J</td>
<td></td>
<td></td>
</tr>
<tr>
<td>075</td>
<td>113</td>
<td>4B</td>
<td>Even</td>
<td>K</td>
<td>K</td>
<td></td>
<td></td>
</tr>
<tr>
<td>076</td>
<td>114</td>
<td>4C</td>
<td>Odd</td>
<td>L</td>
<td>L</td>
<td></td>
<td></td>
</tr>
<tr>
<td>077</td>
<td>115</td>
<td>4D</td>
<td>Even</td>
<td>M</td>
<td>M</td>
<td></td>
<td></td>
</tr>
<tr>
<td>078</td>
<td>116</td>
<td>4E</td>
<td>Even</td>
<td>N</td>
<td>N</td>
<td></td>
<td></td>
</tr>
<tr>
<td>079</td>
<td>117</td>
<td>4F</td>
<td>Odd</td>
<td>O</td>
<td>O</td>
<td>LETTER O</td>
<td></td>
</tr>
<tr>
<td>080</td>
<td>120</td>
<td>50</td>
<td>Even</td>
<td>P</td>
<td>P</td>
<td></td>
<td></td>
</tr>
<tr>
<td>081</td>
<td>121</td>
<td>51</td>
<td>Odd</td>
<td>Q</td>
<td>Q</td>
<td></td>
<td></td>
</tr>
<tr>
<td>082</td>
<td>122</td>
<td>52</td>
<td>Odd</td>
<td>R</td>
<td>R</td>
<td></td>
<td></td>
</tr>
<tr>
<td>083</td>
<td>123</td>
<td>53</td>
<td>Even</td>
<td>S</td>
<td>S</td>
<td></td>
<td></td>
</tr>
<tr>
<td>084</td>
<td>124</td>
<td>54</td>
<td>Odd</td>
<td>T</td>
<td>T</td>
<td></td>
<td></td>
</tr>
<tr>
<td>085</td>
<td>125</td>
<td>55</td>
<td>Even</td>
<td>U</td>
<td>U</td>
<td></td>
<td></td>
</tr>
<tr>
<td>086</td>
<td>126</td>
<td>56</td>
<td>Even</td>
<td>V</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>087</td>
<td>127</td>
<td>57</td>
<td>Odd</td>
<td>W</td>
<td>W</td>
<td></td>
<td></td>
</tr>
<tr>
<td>088</td>
<td>130</td>
<td>58</td>
<td>Odd</td>
<td>X</td>
<td>X</td>
<td></td>
<td></td>
</tr>
<tr>
<td>089</td>
<td>131</td>
<td>59</td>
<td>Even</td>
<td>Y</td>
<td>Y</td>
<td></td>
<td></td>
</tr>
<tr>
<td>090</td>
<td>132</td>
<td>5A</td>
<td>Even</td>
<td>Z</td>
<td>Z</td>
<td></td>
<td></td>
</tr>
<tr>
<td>091</td>
<td>133</td>
<td>5B</td>
<td>Odd</td>
<td>[</td>
<td>[</td>
<td>SHIFT K</td>
<td></td>
</tr>
<tr>
<td>092</td>
<td>134</td>
<td>5C</td>
<td>Even</td>
<td>\</td>
<td>\</td>
<td>SHIFT L</td>
<td></td>
</tr>
<tr>
<td>093</td>
<td>135</td>
<td>5D</td>
<td>Odd</td>
<td>]</td>
<td>]</td>
<td>SHIFT M</td>
<td></td>
</tr>
<tr>
<td>094</td>
<td>136</td>
<td>5E</td>
<td>Odd</td>
<td>^</td>
<td>^</td>
<td>I, SHIFT N</td>
<td></td>
</tr>
<tr>
<td>095</td>
<td>137</td>
<td>5F</td>
<td>Even</td>
<td>_</td>
<td>_</td>
<td>--, SHIFT O, UNDERSCORE</td>
<td></td>
</tr>
<tr>
<td>096</td>
<td>140</td>
<td>60</td>
<td>Even</td>
<td>`</td>
<td>`</td>
<td>ACCENT GRAVE</td>
<td></td>
</tr>
<tr>
<td>097</td>
<td>141</td>
<td>61</td>
<td>Odd</td>
<td>a</td>
<td>a</td>
<td></td>
<td></td>
</tr>
<tr>
<td>098</td>
<td>142</td>
<td>62</td>
<td>Odd</td>
<td>b</td>
<td>b</td>
<td></td>
<td></td>
</tr>
<tr>
<td>099</td>
<td>143</td>
<td>63</td>
<td>Even</td>
<td>c</td>
<td>c</td>
<td></td>
<td></td>
</tr>
<tr>
<td>100</td>
<td>144</td>
<td>64</td>
<td>Odd</td>
<td>d</td>
<td>d</td>
<td></td>
<td></td>
</tr>
<tr>
<td>101</td>
<td>145</td>
<td>65</td>
<td>Even</td>
<td>e</td>
<td>e</td>
<td></td>
<td></td>
</tr>
<tr>
<td>102</td>
<td>146</td>
<td>66</td>
<td>Even</td>
<td>f</td>
<td>f</td>
<td></td>
<td></td>
</tr>
<tr>
<td>103</td>
<td>147</td>
<td>67</td>
<td>Odd</td>
<td>g</td>
<td>g</td>
<td></td>
<td></td>
</tr>
<tr>
<td>104</td>
<td>150</td>
<td>68</td>
<td>Odd</td>
<td>h</td>
<td>h</td>
<td></td>
<td></td>
</tr>
<tr>
<td>105</td>
<td>151</td>
<td>69</td>
<td>Even</td>
<td>i</td>
<td>i</td>
<td></td>
<td></td>
</tr>
<tr>
<td>106</td>
<td>152</td>
<td>6A</td>
<td>Even</td>
<td>j</td>
<td>j</td>
<td></td>
<td></td>
</tr>
<tr>
<td>107</td>
<td>153</td>
<td>6B</td>
<td>Odd</td>
<td>k</td>
<td>k</td>
<td></td>
<td></td>
</tr>
<tr>
<td>108</td>
<td>154</td>
<td>6C</td>
<td>Even</td>
<td>l</td>
<td>l</td>
<td></td>
<td></td>
</tr>
<tr>
<td>109</td>
<td>155</td>
<td>6D</td>
<td>Odd</td>
<td>m</td>
<td>m</td>
<td></td>
<td></td>
</tr>
<tr>
<td>110</td>
<td>156</td>
<td>6E</td>
<td>Odd</td>
<td>n</td>
<td>n</td>
<td></td>
<td></td>
</tr>
<tr>
<td>111</td>
<td>157</td>
<td>6F</td>
<td>Even</td>
<td>o</td>
<td>o</td>
<td></td>
<td></td>
</tr>
<tr>
<td>112</td>
<td>160</td>
<td>70</td>
<td>Odd</td>
<td>p</td>
<td>p</td>
<td></td>
<td></td>
</tr>
<tr>
<td>113</td>
<td>161</td>
<td>71</td>
<td>Even</td>
<td>q</td>
<td>q</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Dec</td>
<td>Octal</td>
<td>Hex</td>
<td>Parity</td>
<td>Character</td>
<td>Control Keybd. Equiv.</td>
<td>Alternate Code Names</td>
<td></td>
</tr>
<tr>
<td>-----</td>
<td>-------</td>
<td>-----</td>
<td>--------</td>
<td>-----------</td>
<td>----------------------</td>
<td>----------------------</td>
<td></td>
</tr>
<tr>
<td>114</td>
<td>162</td>
<td>72</td>
<td>Even</td>
<td>r</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>115</td>
<td>163</td>
<td>73</td>
<td>Odd</td>
<td>s</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>116</td>
<td>164</td>
<td>74</td>
<td>Even</td>
<td>t</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>117</td>
<td>165</td>
<td>75</td>
<td>Odd</td>
<td>u</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>118</td>
<td>166</td>
<td>76</td>
<td>Odd</td>
<td>v</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>119</td>
<td>167</td>
<td>77</td>
<td>Even</td>
<td>w</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>120</td>
<td>170</td>
<td>78</td>
<td>Even</td>
<td>x</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>121</td>
<td>171</td>
<td>79</td>
<td>Odd</td>
<td>y</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>122</td>
<td>172</td>
<td>7A</td>
<td>Odd</td>
<td>z</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>123</td>
<td>173</td>
<td>7B</td>
<td>Even</td>
<td>{</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>124</td>
<td>174</td>
<td>7C</td>
<td>Odd</td>
<td></td>
<td></td>
<td>VERTICAL SLASH</td>
<td></td>
</tr>
<tr>
<td>125</td>
<td>175</td>
<td>7D</td>
<td>Even</td>
<td>}</td>
<td></td>
<td>ALT MODE</td>
<td></td>
</tr>
<tr>
<td>126</td>
<td>176</td>
<td>7E</td>
<td>Even</td>
<td>~</td>
<td></td>
<td>(ALT MODE)</td>
<td></td>
</tr>
<tr>
<td>127</td>
<td>177</td>
<td>7F</td>
<td>Odd</td>
<td>DEL</td>
<td></td>
<td>DELETE, RUBOUT</td>
<td></td>
</tr>
</tbody>
</table>
Appendix C  Manufacturers’ Specification Sheets
Appendix C1

2708
8K (1K x 8) UV ERASABLE PROM

<table>
<thead>
<tr>
<th></th>
<th>Max. Power</th>
<th>Max. Access</th>
</tr>
</thead>
<tbody>
<tr>
<td>2708</td>
<td>800mW</td>
<td>450ns</td>
</tr>
<tr>
<td>2708L</td>
<td>425mW</td>
<td>450ns</td>
</tr>
<tr>
<td>2708-1</td>
<td>800mW</td>
<td>350ns</td>
</tr>
<tr>
<td>2708-6</td>
<td>800mW</td>
<td>550ns</td>
</tr>
</tbody>
</table>

- Low Power Dissipation — 425 mW Max. (2708L)
- Fast Access Time — 350 ns Max. (2708-1)
- Static — No Clocks Required
- Data Inputs and Outputs TTL Compatible during both Read and Program Modes
- Three-State Outputs — OR-Tie Capability

The Intel® 2708 is an 8192-bit ultraviolet light erasable and electrically reprogrammable EPROM, ideally suited where fast turnaround and pattern experimentation are important requirements. All data inputs and outputs are TTL compatible during both the read and program modes. The outputs are three-state, allowing direct interface with common system bus structures.

The 2708L at 425mW is available for systems requiring lower power dissipation than from the 2708. A power dissipation savings of over 50% without any sacrifice in speed is obtained with the 2708L. The 2708L has high input noise immunity and is specified at 10% power supply tolerance. A high-speed 2708-1 is also available at 350ns for microprocessors requiring fast access times.

The 2708 family is fabricated with the N-channel silicon gate FAMOS technology and is available in a 24-pin dual in-line package.

Reprinted by permission of Intel Corporation Copyright © 1980

APPENDIX C 235
2708 FAMILY

PROGRAMMING
The programming specifications are described in the Data Catalog PROM-ROM Programming Instructions Section.

Absolute Maximum Ratings*
- Temperature Under Bias ........................................ -25°C to +85°C  
- Storage Temperature ........................................... -65°C to +125°C  
- VDD With Respect to VBB ................................+20V to -0.3V  
- VCC and VEE With Respect to VBB ....................+15V to -0.3V  
  All Input or Output Voltages With Respect  
  to VBB During Read ........................................... +15V to -0.3V  
- CS/WE Input With Respect to VBB  
  During Programming ......................................... +20V to -0.3V  
- Program Input With Respect to VBB ...................... +35V to -0.3V  
- Power Dissipation ............................................. 1.5W

D.C. AND A.C. OPERATING CONDITIONS DURING READ

<table>
<thead>
<tr>
<th></th>
<th>2708</th>
<th>2708-1</th>
<th>2708-6</th>
<th>2708L</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Temperature Range</strong></td>
<td>0°C to 70°C</td>
<td>0°C to 70°C</td>
<td>0°C to 70°C</td>
<td>0°C to 70°C</td>
</tr>
<tr>
<td>VCC Power Supply</td>
<td>5V ± 5%</td>
<td>5V ± 5%</td>
<td>5V ± 5%</td>
<td>5V ± 10%</td>
</tr>
<tr>
<td>VDD Power Supply</td>
<td>12V ± 5%</td>
<td>12V ± 5%</td>
<td>12V ± 5%</td>
<td>12V ± 10%</td>
</tr>
<tr>
<td>VBB Power Supply</td>
<td>-5V ± 5%</td>
<td>-5V ± 5%</td>
<td>-5V ± 5%</td>
<td>-5V ± 10%</td>
</tr>
</tbody>
</table>

READ OPERATION
D.C. AND OPERATING CHARACTERISTICS

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>2708, 2708-1, 2708-6 Limits</th>
<th>2708L Limits</th>
<th>Units</th>
<th>Test Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>ICH</td>
<td>Address and Chip Select Input Sink Current</td>
<td>1</td>
<td>10</td>
<td>1</td>
<td>10</td>
</tr>
<tr>
<td>ILO</td>
<td>Output Leakage Current</td>
<td>1</td>
<td>10</td>
<td>1</td>
<td>10</td>
</tr>
<tr>
<td>ICO[2]</td>
<td>VCC Supply Current</td>
<td>6</td>
<td>10</td>
<td>2</td>
<td>4</td>
</tr>
<tr>
<td>ISB[2]</td>
<td>VBB Supply Current</td>
<td>30</td>
<td>45</td>
<td>10</td>
<td>14</td>
</tr>
<tr>
<td>VIL</td>
<td>Input Low Voltage</td>
<td>VSS</td>
<td>0.65</td>
<td>VSS</td>
<td>0.65</td>
</tr>
<tr>
<td>VIH</td>
<td>Input High Voltage</td>
<td>3.0</td>
<td>VCC+1</td>
<td>2.2</td>
<td>VCC+1</td>
</tr>
<tr>
<td>VOL</td>
<td>Output Low Voltage</td>
<td>0.45</td>
<td>0.4</td>
<td>V</td>
<td>IOL = 1.6mA (2708, 2708-1, 2708-6)</td>
</tr>
<tr>
<td>VOH1</td>
<td>Output High Voltage</td>
<td>3.7</td>
<td>3.7</td>
<td>V</td>
<td>VOH = -100µA</td>
</tr>
<tr>
<td>VOH2</td>
<td>Output High Voltage</td>
<td>2.4</td>
<td>2.4</td>
<td>V</td>
<td>VOH = -1mA</td>
</tr>
<tr>
<td>PD</td>
<td>Power Dissipation</td>
<td>800</td>
<td>325</td>
<td>mW</td>
<td>TA = 70°C</td>
</tr>
<tr>
<td></td>
<td></td>
<td>425</td>
<td>425</td>
<td>mW</td>
<td>TA = 0°C</td>
</tr>
</tbody>
</table>

NOTES:
1. VBB must be applied prior to VCC and VDD. VBB must also be the last power supply switched off.
2. Typical values are for TA = 25°C and nominal supply voltages.
3. The total power dissipation is not calculated by summing the various currents (IOP, ICO, and ISB) multiplied by their respective voltages since current paths exist between the various power supplies and VBB. The IOP, ICO, and ISB currents should be used to determine power supply capacity only.
4. ISB for the 2708L is specified in the programmed state and is 18mA maximum in the unprogrammed state.

2708 FAMILY

**2708L RANGE OF SUPPLY CURRENTS VS. TEMPERATURE**

**2708, 2708-1, AND 2708-6 RANGE OF SUPPLY CURRENTS VS. TEMPERATURE**

**ACCESS TIME VS. TEMPERATURE**

236 APPENDIX C
A.C. CHARACTERISTICS

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>2708, 2708L Limits</th>
<th>2708-1 Limits</th>
<th>2708-8 Limits</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{ACD}$</td>
<td>Address to Output Delay</td>
<td>450</td>
<td>350</td>
<td>550</td>
<td></td>
</tr>
<tr>
<td>$t_{DCO}$</td>
<td>Chip Select to Output Delay</td>
<td>120</td>
<td>120</td>
<td>160</td>
<td></td>
</tr>
<tr>
<td>$t_{DF}$</td>
<td>Chip Deselect to Output Float</td>
<td>0</td>
<td>120</td>
<td>0</td>
<td>120</td>
</tr>
<tr>
<td>$t_{OH}$</td>
<td>Address to Output Hold</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

CAPACITANCE [1] $T_A = 25^\circ C, f = 1$ MHz

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit.</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C_{IN}$</td>
<td>Input Capacitance</td>
<td>4</td>
<td>6</td>
<td>pF</td>
<td>$V_{IN} = 0V$</td>
</tr>
<tr>
<td>$C_{OUT}$</td>
<td>Output Capacitance</td>
<td>8</td>
<td>12</td>
<td>pF</td>
<td>$V_{OUT} = 0V$</td>
</tr>
</tbody>
</table>

NOTE: 1. This parameter is periodically sampled and is not 100% tested.

A.C. WAVEFORMS [2]

NOTES:
1. ALL TIMES SHOWN IN PARENTHESES ARE MINIMUM AND ARE NSEC UNLESS OTHERWISE SPECIFIED.
2. CS MAY BE DELAYED UP TO $t_{ACD}$ AFTER ADDRESSES ARE VALID WITHOUT IMPACT ON $t_{ACD}$.
3. IF OR IF SPECIFIED FROM CS OR ADDRESS CHANGE, WHICHEVER OCCURS FIRST.

ERASURE CHARACTERISTICS

The erasure characteristics of the 2708 family are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ($\AA$). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the 3000–4000$\AA$ range. Data show that constant exposure to room level fluorescent lighting could erase the typical device in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 2708 is to be exposed to these types of lighting conditions for extended periods of time, opaque labels are available from Intel which should be placed over the 2708 window to prevent unintentional erasure.

The recommended erasure procedure (see Data Catalog PROM/ROM Programming Instructions Section) for the 2708 family is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms ($\AA$). The integrated dose (i.e., UV intensity X exposure time) for erasure should be a minimum of 15 W-sec/cm$^2$. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a 12000 $\mu$W/cm$^2$ power rating. The device should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.
Appendix C2

2716
16K (2K × 8) UV ERASABLE PROM

■ Fast Access Time
  — 350 ns Max. 2716-1
  — 390 ns Max. 2716-2
  — 450 ns Max. 2716
  — 490 ns Max. 2716-5
  — 650 ns Max. 2716-6

■ Pin Compatible to Intel® 2732 EPROM

■ Simple Programming Requirements
  — Single Location Programming
  — Programs with One 50 ms Pulse

■ Single + 5V Power Supply

■ Low Power Dissipation
  — 525 mW Max. Active Power
  — 132 mW Max. Standby Power

■ Completely Static

The Intel® 2716 is a 16,384 bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 2716 operates from a single 5-volt power supply, has a static standby mode, and features fast single address location programming. It makes designing with EPROMs faster, easier and more economical.

The 2716, with its single 5-volt supply and an access time up to 350 ns, is ideal for use with the newer high performance +5V microprocessors such as Intel's 8085 and 8086. A selected 2716-5 and 2716-6 is available for slower speed applications. The 2716 is also the first EPROM with a static standby mode which reduces the power dissipation without increasing access time. The maximum active power dissipation is 525 mW while the maximum standby power dissipation is only 132 mW, a 75% savings.

The 2716 has the simplest and fastest method yet devised for programming EPROMs -- single curve TTL level programming. No need for high voltage pulsing because all programming controls are handled by TTL signals. Program any location at any time -- either individually, sequentially or at random, with the 2716's single address location programming. Total programming time for all 16,384 bits is only 100 seconds.

PIN CONFIGURATION

<table>
<thead>
<tr>
<th>PIN</th>
<th>2716</th>
<th>2732</th>
</tr>
</thead>
<tbody>
<tr>
<td>A1</td>
<td>37</td>
<td>37</td>
</tr>
<tr>
<td>A0</td>
<td>36</td>
<td>36</td>
</tr>
<tr>
<td>A5</td>
<td>35</td>
<td>35</td>
</tr>
<tr>
<td>A4</td>
<td>34</td>
<td>34</td>
</tr>
<tr>
<td>A3</td>
<td>33</td>
<td>33</td>
</tr>
<tr>
<td>A2</td>
<td>32</td>
<td>32</td>
</tr>
<tr>
<td>A1</td>
<td>31</td>
<td>31</td>
</tr>
<tr>
<td>A0</td>
<td>30</td>
<td>30</td>
</tr>
<tr>
<td>A5</td>
<td>29</td>
<td>29</td>
</tr>
<tr>
<td>A4</td>
<td>28</td>
<td>28</td>
</tr>
<tr>
<td>A3</td>
<td>27</td>
<td>27</td>
</tr>
<tr>
<td>A2</td>
<td>26</td>
<td>26</td>
</tr>
<tr>
<td>A1</td>
<td>25</td>
<td>25</td>
</tr>
<tr>
<td>A0</td>
<td>24</td>
<td>24</td>
</tr>
<tr>
<td>16K</td>
<td>23</td>
<td>23</td>
</tr>
<tr>
<td>CE</td>
<td>22</td>
<td>22</td>
</tr>
<tr>
<td>CE</td>
<td>21</td>
<td>21</td>
</tr>
<tr>
<td>CE</td>
<td>20</td>
<td>20</td>
</tr>
<tr>
<td>CE</td>
<td>19</td>
<td>19</td>
</tr>
<tr>
<td>CE</td>
<td>18</td>
<td>18</td>
</tr>
<tr>
<td>CE</td>
<td>17</td>
<td>17</td>
</tr>
<tr>
<td>D10</td>
<td>16</td>
<td>16</td>
</tr>
<tr>
<td>D11</td>
<td>15</td>
<td>15</td>
</tr>
<tr>
<td>D12</td>
<td>14</td>
<td>14</td>
</tr>
<tr>
<td>D13</td>
<td>13</td>
<td>13</td>
</tr>
<tr>
<td>D14</td>
<td>12</td>
<td>12</td>
</tr>
<tr>
<td>D15</td>
<td>11</td>
<td>11</td>
</tr>
<tr>
<td>D16</td>
<td>10</td>
<td>10</td>
</tr>
<tr>
<td>D17</td>
<td>9</td>
<td>9</td>
</tr>
<tr>
<td>D18</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>D19</td>
<td>7</td>
<td>7</td>
</tr>
<tr>
<td>D20</td>
<td>6</td>
<td>6</td>
</tr>
<tr>
<td>D21</td>
<td>5</td>
<td>5</td>
</tr>
<tr>
<td>D22</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>D23</td>
<td>3</td>
<td>3</td>
</tr>
<tr>
<td>D24</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>D25</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>GND</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

†Refer to 2732 data sheet for specifications

MODE SELECTION

<table>
<thead>
<tr>
<th>PIN</th>
<th>CE</th>
<th>EPROM</th>
<th>OE</th>
<th>VCC</th>
<th>OUTPUT</th>
</tr>
</thead>
<tbody>
<tr>
<td>V1L</td>
<td>VIL</td>
<td>+5</td>
<td>+5</td>
<td>OUT</td>
<td></td>
</tr>
<tr>
<td>Power</td>
<td>VIL</td>
<td>VIL</td>
<td>VIL</td>
<td>+5</td>
<td>OUT</td>
</tr>
<tr>
<td>Program</td>
<td>VIL</td>
<td>VIL</td>
<td>VIL</td>
<td>+5</td>
<td>OUT</td>
</tr>
<tr>
<td>Program Inputs</td>
<td>VIL</td>
<td>VIL</td>
<td>VIL</td>
<td>+5</td>
<td>OUT</td>
</tr>
</tbody>
</table>

Reprinted by permission of Intel Corporation Copyright © 1980

APPENDIX C 239
PROGRAMMING
The programming specifications are described in the Data Catalog PROM/ROM Programming Instructions Section.

Absolute Maximum Ratings*
Temperature Under Bias .......................... -10°C to +80°C
Storage Temperature .............................. -65°C to +125°C
All Input or Output Voltages with
Respect to Ground ................................. +6V to -0.3V
Vpp Supply Voltage with Respect
to Ground During Program ......... +26.5V to -0.3V

"COMMENT: Stress above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

DC and AC Operating Conditions During Read

<table>
<thead>
<tr>
<th></th>
<th>2716</th>
<th>2716-1</th>
<th>2716-2</th>
<th>2716-5</th>
<th>2716-6</th>
</tr>
</thead>
<tbody>
<tr>
<td>Temperature Range</td>
<td>0°C - 70°C</td>
<td>0°C - 70°C</td>
<td>0°C - 70°C</td>
<td>0°C - 70°C</td>
<td>0°C - 70°C</td>
</tr>
<tr>
<td>VCC Power Supply[1,2]</td>
<td>5V ±5%</td>
<td>5V ±10%</td>
<td>5V ±5%</td>
<td>5V ±5%</td>
<td>5V ±5%</td>
</tr>
</tbody>
</table>

READ OPERATION
D.C. and Operating Characteristics

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Limits (Min., Typ.[3], Max.)</th>
<th>Unit</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>IIL</td>
<td>Input Load Current</td>
<td>10 µA</td>
<td>V IN = 5.25V</td>
<td></td>
</tr>
<tr>
<td>IOL</td>
<td>Output Leakage Current</td>
<td>10 µA</td>
<td>V OUT = 5.25V</td>
<td></td>
</tr>
<tr>
<td>IP[2]</td>
<td>Vpp Current</td>
<td>5 mA</td>
<td>VPP = 5.25V</td>
<td></td>
</tr>
<tr>
<td>ICC1[2]</td>
<td>VCC Current (Standby)</td>
<td>10 mA</td>
<td>CE = VIL, OE = VIL</td>
<td></td>
</tr>
<tr>
<td>ICC2[2]</td>
<td>VCC Current (Active)</td>
<td>57 µA</td>
<td>100 mA</td>
<td></td>
</tr>
<tr>
<td>VIL</td>
<td>Input Low Voltage</td>
<td>-0.1 V</td>
<td>0.8 V</td>
<td></td>
</tr>
<tr>
<td>VIH</td>
<td>Input High Voltage</td>
<td>2.0 V</td>
<td>VCC+1 V</td>
<td></td>
</tr>
<tr>
<td>VOL</td>
<td>Output Low Voltage</td>
<td>0.45 V</td>
<td>IOL = 2.1 mA</td>
<td></td>
</tr>
<tr>
<td>VOH</td>
<td>Output High Voltage</td>
<td>2.4 V</td>
<td>IOH = -400 µA</td>
<td></td>
</tr>
</tbody>
</table>

NOTES:
1. VCC must be applied simultaneously or before VPP and removed simultaneously or after VPP.
2. VPP may be connected directly to VCC except during programming. The supply current would then be the sum of ICC1 and ICC2.
3. Typical values are for TA = 25°C and nominal supply voltages.
4. This parameter is only sampled and is not 100% tested.

Typical Characteristics

- ICC CURRENT vs TEMPERATURE
- ACCESS TIME vs CAPACITANCE
- ACCESS TIME vs TEMPERATURE
A.C. Characteristics

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Limits (ns)</th>
<th>Test Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>2716</td>
<td>2716-1</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Min.</td>
<td>Max.</td>
</tr>
<tr>
<td>tACC</td>
<td>Address to Output Delay</td>
<td>450</td>
<td>350</td>
</tr>
<tr>
<td>tCE</td>
<td>CE to Output Delay</td>
<td>450</td>
<td>350</td>
</tr>
<tr>
<td>tOE</td>
<td>Output Enable to Output Delay</td>
<td>120</td>
<td>120</td>
</tr>
<tr>
<td>tOF</td>
<td>Output Enable High to Output Float</td>
<td>0</td>
<td>100</td>
</tr>
<tr>
<td>tOH</td>
<td>Output Hold from Addresses, CE or OE whichever occurred first</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

Capacitance [4] $T_A = 25^\circ C$, $f = 1$ MHz

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>CIN</td>
<td>Input Capacitance</td>
<td>4</td>
<td>6</td>
<td>pF</td>
<td>$V_{IN} = 0V$</td>
</tr>
<tr>
<td>COUT</td>
<td>Output Capacitance</td>
<td>8</td>
<td>12</td>
<td>pF</td>
<td>$V_{OUT} = 0V$</td>
</tr>
</tbody>
</table>

A.C. Test Conditions:
- Output Load: 1 TTL gate and $C_L = 100$ pF
- Input Rise and Fall Times: $\leq 20$ ns
- Input Pulse Levels: 0.8V to 2.2V
- Timing Measurement Reference Level:
  - Inputs 1V and 2V
  - Outputs 0.8V and 2V

A. C. Waveforms [1]

NOTE:
1. $V_{CC}$ must be applied simultaneously or before $V_{pp}$ and removed simultaneously or after $V_{pp}$.
2. $V_{pp}$ may be connected directly to $V_{CC}$ except during programming. The supply current would then be the sum of $I_{CC}$ and $I_{PP}$.
3. Typical values are for $T_A = 25^\circ C$ and nominal supply voltages.
4. This parameter is only sampled and is not 100% tested.
5. OE may be delayed up to $t_{ACC} - t_{OE}$ after the falling edge of CE without impact on $t_{ACC}$.
6. $t_{PP}$ is specified from OE or CE, whichever occurs first.

APPENDIX C 241
ERASURE CHARACTERISTICS

The erasure characteristics of the 2716 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms (Å). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the 3000–4000å range. Data show that constant exposure to room level fluorescent lighting could erase the typical 2716 in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 2716 is to be exposed to these types of lighting conditions for extended periods of time, opaque labels are available from Intel which should be placed over the 2716 window to prevent unintentional erase.

The recommended erasure procedure (see Data Catalog PROM/ROM Programming Instruction Section) for the 2716 is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms (Å). The integrated dose (i.e., UV intensity X exposure time) for erasure should be a minimum of 15 Wsec/cm². The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a 1200 μW/cm² power rating. The 2716 should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.

DEVICE OPERATION

The five modes of operation of the 2716 are listed in Table I. It should be noted that all inputs for the five modes are at TTL levels. The power supplies required are a +5V VCC and a Vpp. The Vpp power supply must be at 25V during the three programming modes, and must be at 5V in the other two modes.

<table>
<thead>
<tr>
<th>MODE</th>
<th>INPUTS</th>
<th>CE (pin 18)</th>
<th>OE (pin 20)</th>
<th>Vpp (pin 21)</th>
<th>Vcc (pin 24)</th>
<th>OUTPUTS (pins 11, 13, 17)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Read</td>
<td>Vpp</td>
<td>VIL</td>
<td>VIL</td>
<td>+5</td>
<td>+5</td>
<td>0 or 1</td>
</tr>
<tr>
<td>Standby</td>
<td>Vih</td>
<td>Don't Care</td>
<td>+5</td>
<td>+5</td>
<td>0 or 1</td>
<td></td>
</tr>
<tr>
<td>Program</td>
<td>Pulled</td>
<td>VIL</td>
<td>VIL</td>
<td>+5</td>
<td>+5</td>
<td>D IN</td>
</tr>
<tr>
<td>Program Verify</td>
<td>VIL</td>
<td>VIL</td>
<td>+5</td>
<td>+5</td>
<td>0 or 1</td>
<td></td>
</tr>
<tr>
<td>Program Input</td>
<td>VIL</td>
<td>VIL</td>
<td>125</td>
<td>+5</td>
<td>Vpp, E</td>
<td></td>
</tr>
</tbody>
</table>

READ MODE

The 2716 has two control functions, both of which must be logically satisfied in order to obtain data at the outputs. Chip Enable (CE) is the power control and should be used for device selection. Output Enable (OE) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time tACC is equal to the delay from CE to output (tOE). Data is available at the outputs 120 ns (tOE) after the falling edge of CE, assuming that CE has been low and addresses have been stable for at least tACC = tOE.

STANDBY MODE

The 2716 has a standby mode which reduces the active power dissipation by 75%, from 525 mW to 132 mW. The 2716 is placed in the standby mode by applying a TTL high signal to the CE input. When in standby mode, the outputs are in a high impedance state, independent of the OE input.

OUTPUT OR-TIEING

Because 2716's are usually used in larger memory arrays, Intel has provided a 2 line control function that accommodates this use of multiple memory connections. The two line control function allows for:

a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.

To most efficiently use these two control lines, it is recommended that CE (pin 18) be decoded and used as the primary device selecting function, while OE (pin 20) be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby mode and that the output pins are only active when data is desired from a particular memory device.

PROGRAMMING

Initially, and after each erasure, all bits of the 2716 are in the "1" state. Data is introduced by selectively programming "0's" into the desired bit locations. Although only "0's" will be programmed, both "1's" and "0's" can be presented in the data word. The only way to change a "0" to a "1" is by ultraviolet light erasure.

The 2716 is in the programming mode when the Vpp power supply is at 25V and CE is at Vih. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.

When the address and data are stable, a 50 msec, active high, TTL program pulse is applied to the CE/PGM input. A program pulse must be applied at each address location to be programmed. You can program any location at any time -- either individually, sequentially, or at random. The program pulse has a maximum width of 55 msec. The 2716 must not be programmed with a DC signal applied to the CE/PGM input.

Programming of multiple 2716s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled 2716s may be connected together when they are programmed with the same data. A high level TTL pulse applied to the CE/PGM input programs the paralleled 2716s.

PROGRAM INHIBIT

Programming of multiple 2716s in parallel with different data is also easily accomplished. Except for CE/PGM, all like inputs (including OE) of the parallel 2716s may be common. A TTL level program pulse applied to a 2716's CE/PGM input with Vpp at 25V will program that 2716. A low level CE/PGM input inhibits the other 2716 from being programmed.

PROGRAM VERIFY

A verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed with Vpp at 25V. Except during programming and program verify, Vpp must be at 5V.
Appendix C3

`intel`

2102A, 2102AL/8102A-4*
1K x 1 BIT STATIC RAM

<table>
<thead>
<tr>
<th>P/N</th>
<th>Standby Pwr. (mW)</th>
<th>Operating Pwr. (mW)</th>
<th>Access (ns)</th>
</tr>
</thead>
<tbody>
<tr>
<td>2102AL-4</td>
<td>35</td>
<td>174</td>
<td>450</td>
</tr>
<tr>
<td>2102AL</td>
<td>35</td>
<td>174</td>
<td>350</td>
</tr>
<tr>
<td>2102AL-2</td>
<td>42</td>
<td>342</td>
<td>250</td>
</tr>
<tr>
<td>2102A-2</td>
<td>342</td>
<td>350</td>
<td>250</td>
</tr>
<tr>
<td>2102A</td>
<td>---</td>
<td>289</td>
<td>350</td>
</tr>
<tr>
<td>2102A-4</td>
<td>---</td>
<td>289</td>
<td>450</td>
</tr>
</tbody>
</table>

- Single +5 Volts Supply Voltage
- Directly TTL Compatible: All Inputs and Output
- Standby Power Mode (2102AL)
- Three-State Output: OR-Tie Capability
- Inputs Protected: All Inputs Have Protection Against Static Charge
- Low Cost Packaging: 16 Pin Dual-In-Line Configuration

The Intel® 2102A is a high speed 1024 word by one bit static random access memory element using N-channel MOS devices integrated on a monolithic array. It uses fully DC stable (static) circuitry and therefore requires no clocks or refreshing to operate. The data is read out nondestructively and has the same polarity as the input data.

The 2102A is designed for memory applications where high performance, low cost, large bit storage, and simple interfacing are important design objectives. A low standby power version (2102AL) is also available. It has all the same operating characteristics of the 2102A with the added feature of 35mW maximum power dissipation in standby and 174mW in operations.

It is directly TTL compatible in all respects: inputs, output, and a single +5 volt supply. A separate chip enable (CE) lead allows easy selection of an individual package when outputs are OR-tied.

The Intel® 2102A is fabricated with N-channel silicon gate technology. This technology allows the design and production of high performance easy to use MOS circuits and provides a higher functional density on a monolithic chip than either conventional MOS technology or P-channel silicon gate technology.

---

*All 8102A-4 specifications are identical to the 2102A-4 specifications.*

Reprinted by permission of Intel Corporation Copyright © 1978

APPENDIX C 243
2102A FAMILY

Absolute Maximum Ratings*

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
</tr>
</thead>
<tbody>
<tr>
<td>Ambient Temperature Under Bias</td>
<td>-10°C</td>
<td></td>
<td>80°C</td>
</tr>
<tr>
<td>Storage Temperature</td>
<td>-65°C</td>
<td></td>
<td>+150°C</td>
</tr>
<tr>
<td>Voltage On Any Pin With Respect To Ground</td>
<td>-0.5V</td>
<td></td>
<td>+7V</td>
</tr>
<tr>
<td>Power Dissipation</td>
<td>1 Watt</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*COMMENT:
Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

D. C. and Operating Characteristics

\( T_A = 0°C \) to 70°C, \( V_{CC} = 5V \pm 5% \) unless otherwise specified.

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>2102A, 2102A-4 Limits</th>
<th>2102AL, 2102AL-4 Limits</th>
<th>2102A-2, 2102AL-2 Limits</th>
<th>Unit</th>
<th>Test Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>I_{LH}</td>
<td>Input Load Current</td>
<td>1</td>
<td>10</td>
<td></td>
<td>1</td>
<td>10</td>
</tr>
<tr>
<td>I_{LOH}</td>
<td>Output Leakage Current</td>
<td>1</td>
<td>5</td>
<td></td>
<td>1</td>
<td>5</td>
</tr>
<tr>
<td>I_{LOL}</td>
<td>Output Leakage Current</td>
<td>-1</td>
<td>-10</td>
<td></td>
<td>-1</td>
<td>-10</td>
</tr>
<tr>
<td>I_{CC}</td>
<td>Power Supply Current</td>
<td>33</td>
<td>Note 2</td>
<td>45</td>
<td>65</td>
<td></td>
</tr>
<tr>
<td>V_{IL}</td>
<td>Input Low Voltage</td>
<td>-0.5</td>
<td>0.8</td>
<td>-0.5</td>
<td>0.8</td>
<td></td>
</tr>
<tr>
<td>V_{IH}</td>
<td>Input High Voltage</td>
<td>2.0</td>
<td>( V_{CC} )</td>
<td>2.0</td>
<td>( V_{CC} )</td>
<td></td>
</tr>
<tr>
<td>V_{OL}</td>
<td>Output Low Voltage</td>
<td>0.4</td>
<td></td>
<td>0.4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>V_{OH}</td>
<td>Output High Voltage</td>
<td>2.4</td>
<td></td>
<td>2.4</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Typical values are for \( T_A = 25°C \) and nominal supply voltage.
2. The maximum \( I_{CC} \) value is 55mA for the 2102A and 2102A-4, and 33mA for the 2102AL and 2102AL-4.

Standby Characteristics 2102AL, 2102AL-2, and 2102AL-4 (Available only in the Plastic Package)

\( T_A = 0°C \) to 70°C

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>2102AL, 2102AL-4 Limits</th>
<th>2102AL-2 Limits</th>
<th>Unit</th>
<th>Test Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>V_{PD}</td>
<td>( V_{CC} ) in Standby</td>
<td>1.5</td>
<td></td>
<td>1.5</td>
<td></td>
</tr>
<tr>
<td>V_{CES}[2]</td>
<td>CE Bias in Standby</td>
<td>2.0</td>
<td></td>
<td>2.0</td>
<td></td>
</tr>
<tr>
<td>I_{PD1}</td>
<td>Standby Current</td>
<td>15</td>
<td>23</td>
<td></td>
<td>20</td>
</tr>
<tr>
<td>I_{PD2}</td>
<td>Standby Current</td>
<td>20</td>
<td>30</td>
<td></td>
<td>25</td>
</tr>
<tr>
<td>I_{CP}</td>
<td>Chip Deselect to Standby</td>
<td>0</td>
<td></td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>t_{RA}[3]</td>
<td>Standby Recovery Time</td>
<td>( t_{RC} )</td>
<td></td>
<td>( t_{RC} )</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Typical values are for \( T_A = 25°C \).
2. Consider the test conditions as shown: If the standby voltage \( (V_{PD}) \) is between 5.25V \((V_{CC} \) Max.\) and 2.0V, then \( CE \) must be held at 2.0V Min. \((V_{CC})\). If the standby voltage is less than 2.0V but greater than 1.5V \((V_{PD} \) Min.), then \( CE \) and standby voltage must be at least the same value or, if they are different, \( CE \) must be the more positive of the two.
3. \( t_{RA} = t_{RC} \) (READ CYCLE TIME).

STANDBY WAVEFORMS

NOTES:
1. Typical values are for \( T_A = 25°C \).
2. Consider the test conditions as shown: If the standby voltage \( (V_{PD}) \) is between 5.25V \((V_{CC} \) Max.\) and 2.0V, then \( CE \) must be held at 2.0V Min. \((V_{CC})\). If the standby voltage is less than 2.0V but greater than 1.5V \((V_{PD} \) Min.), then \( CE \) and standby voltage must be at least the same value or, if they are different, \( CE \) must be the more positive of the two.
3. \( t_{RA} = t_{RC} \) (READ CYCLE TIME).
2102A FAMILY

A. C. Characteristics $T_A = 0^\circ\text{C} \text{ to } 70^\circ\text{C}, V_{cc} = 5V \pm 5\%$ unless otherwise specified

### READ CYCLE

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>2102A-2, 2102AL-2 Limits (ns)</th>
<th>2102A, 2102AL-2 Limits (ns)</th>
<th>2102A-4, 2102AL-4 Limits (ns)</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{RC}$</td>
<td>Read Cycle</td>
<td>250</td>
<td>350</td>
<td>450</td>
</tr>
<tr>
<td>$t_A$</td>
<td>Access Time</td>
<td>250</td>
<td>350</td>
<td>450</td>
</tr>
<tr>
<td>$t_{CO}$</td>
<td>Chip Enable to Output Time</td>
<td>130</td>
<td>180</td>
<td>230</td>
</tr>
<tr>
<td>$t_{OH1}$</td>
<td>Previous Read Data Valid with Respect to Address</td>
<td>40</td>
<td>40</td>
<td>40</td>
</tr>
<tr>
<td>$t_{OH2}$</td>
<td>Previous Read Data Valid with Respect to Chip Enable</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

### WRITE CYCLE

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>250</th>
<th>350</th>
<th>450</th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_{WC}$</td>
<td>Write Cycle</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{AW}$</td>
<td>Address to Write Setup Time</td>
<td>180</td>
<td>250</td>
<td>300</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WP}$</td>
<td>Write Pulse Width</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WR}$</td>
<td>Write Recovery Time</td>
<td>180</td>
<td>250</td>
<td>300</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{DH}$</td>
<td>Data Hold Time</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{OW}$</td>
<td>Chip Enable to Write Setup Time</td>
<td>180</td>
<td>250</td>
<td>300</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Capacitance $^{[2]}$ $T_A = 25^\circ\text{C}, f = 1\text{MHz}$

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>TEST</th>
<th>LIMITS (pF)</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C_{IN}$</td>
<td>INPUT CAPACITANCE (ALL INPUT PINS) $V_{IN} = 0V$</td>
<td>3  5</td>
</tr>
<tr>
<td>$C_{OUT}$</td>
<td>OUTPUT CAPACITANCE $V_{OUT} = 0V$</td>
<td>7 10</td>
</tr>
</tbody>
</table>

---

Waveforms

### READ CYCLE

- **ADDRESS**
- **CHIP ENABLE**
- **DATA OUT**
  - 15 VOLTS
  - 2.0 VOLTS
  - 0.8 VOLTS

### WRITE CYCLE

- **ADDRESS**
- **CHIP ENABLE**
- **DATA IN**
- **DATA CAN CHANGE**
- **DATA STABLE**
- **DATA CAN CHANGE**

**NOTES:**
1. Typical values are for $T_A = 25^\circ\text{C}$ and nominal supply voltage.
2. This parameter is periodically sampled and is not 100% tested.

APPENDIX C 245
Typical D. C. and A. C. Characteristics

POWER SUPPLY CURRENT VS. AMBIENT TEMPERATURE

POWER SUPPLY CURRENT VS. SUPPLY VOLTAGE

V_IN LIMITS VS. TEMPERATURE

OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE

ACCESS TIME VS. AMBIENT TEMPERATURE

ACCESS TIME VS. LOAD CAPACITANCE
Appendix C4

2114A
1024 X 4 BIT STATIC RAM

<table>
<thead>
<tr>
<th>Max. Access Time (ns)</th>
<th>2114AL-1</th>
<th>2114AL-2</th>
<th>2114AL-3</th>
<th>2114AL-4</th>
<th>2114A-4</th>
<th>2114A-5</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>100</td>
<td>120</td>
<td>150</td>
<td>200</td>
<td>200</td>
<td>250</td>
</tr>
<tr>
<td>Max. Current (mA)</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>40</td>
<td>70</td>
<td>70</td>
</tr>
</tbody>
</table>

- HMOS Technology
- Low Power, High Speed
- Identical Cycle and Access Times
- Single +5V Supply ±10%
- High Density 18 Pin Package
- Completely Static Memory - No Clock or Timing Strobe Required
- Directly TTL Compatible: All Inputs and Outputs
- Common Data Input and Output Using Three-State Outputs
- 2114 Upgrade

The Intel® 2114A is a 4096-bit static Random Access Memory organized as 1024 words by 4-bits using HMOS, a high performance MOS technology. It uses fully DC stable (static) circuitry throughout, in both the array and the decoding, therefore it requires no clocks or refreshing to operate. Data access is particularly simple since address setup times are not required. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided.

The 2114A is designed for memory applications where the high performance and high reliability of HMOS, low cost, large bit storage, and simple interfacing are important design objectives. The 2114A is placed in an 18-pin package for the highest possible density.

It is directly TTL compatible in all respects: inputs, outputs, and a single +5V supply. A separate Chip Select (CS) lead allows easy selection of an individual package when outputs are or-tied.

PIN CONFIGURATION

PIN NAMES

<table>
<thead>
<tr>
<th>A1-A4</th>
<th>ADDRESS INPUTS</th>
<th>Vcc</th>
<th>POWER (+5V)</th>
</tr>
</thead>
<tbody>
<tr>
<td>WE</td>
<td>WRITE ENABLE</td>
<td>Vcc</td>
<td>GND/GROUND</td>
</tr>
<tr>
<td>CS</td>
<td>CHIP SELECT</td>
<td></td>
<td></td>
</tr>
<tr>
<td>I/O</td>
<td>DATA INPUT/OUTPUT</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Reprinted by permission of Intel Corporation Copyright © 1980
ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias .............................................. -10°C to 80°C
Storage Temperature ................................................. -65°C to 150°C
Voltage on any Pin .................................................. -3.5V to +7V
Power Dissipation ................................................... 1.0W
D.C. Output Current .................................................. 5mA

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

D.C. AND OPERATING CHARACTERISTICS

$T_A = 0^\circ C$ to 70°C, $V_{CC} = 5V \pm 10\%$, unless otherwise noted.

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>PARAMETER</th>
<th>2114AL-1/L-2/L-3/L-4</th>
<th>2114A-4/-5</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td>Min. Typ. 11 Max.</td>
<td>Min. Typ. 11 Max.</td>
</tr>
<tr>
<td>$I_{LI}$</td>
<td>Input Load Current (All Input Pins)</td>
<td>10</td>
<td>10</td>
</tr>
<tr>
<td>$I_{IO1}$</td>
<td>I/O Leakage Current</td>
<td>10</td>
<td>10</td>
</tr>
<tr>
<td>$I_{CC}$</td>
<td>Power Supply Current</td>
<td>25</td>
<td>40</td>
</tr>
<tr>
<td>$V_{IL}$</td>
<td>Input Low Voltage</td>
<td>-3.0</td>
<td>0.8</td>
</tr>
<tr>
<td>$V_{IH}$</td>
<td>Input High Voltage</td>
<td>2.0</td>
<td>6.0</td>
</tr>
<tr>
<td>$I_{OL}$</td>
<td>Output Low Current</td>
<td>2.1</td>
<td>9.0</td>
</tr>
<tr>
<td>$I_{OH}$</td>
<td>Output High Current</td>
<td>-1.0</td>
<td>-2.5</td>
</tr>
<tr>
<td>$I_{OS[2]}$</td>
<td>Output Short Circuit Current</td>
<td>40</td>
<td>40</td>
</tr>
</tbody>
</table>

NOTE: 1. Typical values are for $T_A = 25^\circ C$ and $V_{CC} = 5.0V$.
2. Duration not to exceed 30 seconds.

CAPACITANCE

$T_A = 25^\circ C, f = 1.0$ MHz

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>TEST</th>
<th>MAX</th>
<th>UNIT</th>
<th>CONDITIONS</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C_{VO}$</td>
<td>Input/Output Capacitance</td>
<td>5</td>
<td>pF</td>
<td>$V_{IO} = OV$</td>
</tr>
<tr>
<td>$C_{IN}$</td>
<td>Input Capacitance</td>
<td>5</td>
<td>pF</td>
<td>$V_{IN} = OV$</td>
</tr>
</tbody>
</table>

NOTE: This parameter is periodically sampled and not 100% tested.

A.C. CONDITIONS OF TEST

Input Pulse Levels ................................................. 0.8 Volt to 2.0 Volt
Input Rise and Fall Times ....................................... 10 nsec
Input and Output Timing Levels .................................. 1.5 Volts
Output Load ....................................................... 1 TTL Gate and $C_L = 100$ pF
A.C. CHARACTERISTICS  \( T_a = 0^\circ C \) to \( 70^\circ C \), \( V_{CC} = 5V \pm 10\% \), unless otherwise noted.

## READ CYCLE [1]

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>PARAMETER</th>
<th>2114AL-1</th>
<th>2114AL-2</th>
<th>2114AL-3</th>
<th>2114A-4/L-4</th>
<th>2114A-5</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{AC} )</td>
<td>Read Cycle Time</td>
<td>100</td>
<td>120</td>
<td>150</td>
<td>200</td>
<td>250</td>
</tr>
<tr>
<td>( t_A )</td>
<td>Access Time</td>
<td>100</td>
<td>120</td>
<td>150</td>
<td>200</td>
<td>250</td>
</tr>
<tr>
<td>( t_{CS} )</td>
<td>Chip Selection to Output Valid</td>
<td>70</td>
<td>70</td>
<td>70</td>
<td>70</td>
<td>85</td>
</tr>
<tr>
<td>( t_{CSA} )</td>
<td>Chip Selection to Output Active</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
<td>10</td>
</tr>
<tr>
<td>( t_{D0} )</td>
<td>Output 3-state from Deselection</td>
<td>30</td>
<td>35</td>
<td>40</td>
<td>50</td>
<td>60</td>
</tr>
<tr>
<td>( t_{D0A} )</td>
<td>Output Hold from Address Change</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
<td>15</td>
</tr>
</tbody>
</table>

## WRITE CYCLE [2]

<table>
<thead>
<tr>
<th>SYMBOL</th>
<th>PARAMETER</th>
<th>2114AL-1</th>
<th>2114AL-2</th>
<th>2114AL-3</th>
<th>2114A-4/L-4</th>
<th>2114A-5</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{wC} )</td>
<td>Write Cycle Time</td>
<td>100</td>
<td>120</td>
<td>150</td>
<td>200</td>
<td>250</td>
</tr>
<tr>
<td>( t_w )</td>
<td>Write Time</td>
<td>75</td>
<td>75</td>
<td>90</td>
<td>120</td>
<td>135</td>
</tr>
<tr>
<td>( t_{wr} )</td>
<td>Write Release Time</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>( t_{0W} )</td>
<td>Output 3-state from Write</td>
<td>30</td>
<td>35</td>
<td>40</td>
<td>50</td>
<td>60</td>
</tr>
<tr>
<td>( t_{0W} )</td>
<td>Data to Write Time Overlap</td>
<td>70</td>
<td>70</td>
<td>90</td>
<td>120</td>
<td>135</td>
</tr>
<tr>
<td>( t_{0X} )</td>
<td>Data Hold from Write Time</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

**NOTES:**
1. A Read occurs during the overlap of a low \( CS \) and a high \( WE \).
2. A Write occurs during the overlap of a low \( CS \) and a low \( WE \). \( t_{AC} \) is measured from the latter of \( CS \) or \( WE \) going low to the earlier of \( CS \) or \( WE \) going high.

## WAVEFORMS

### READ CYCLE

- ADDRESS
- \( CS \)
- \( D_{OUT} \)

**NOTES:**
3. \( WE \) is high for a Read Cycle.
4. If the \( CS \) low transition occurs simultaneously with the \( WE \) low transition, the output buffers remain in a high impedance state.
5. \( WE \) must be high during all address transitions.

### WRITE CYCLE

- ADDRESS
- \( CS \)
- \( WE \)
- \( D_{OUT} \)

**NOTES:**
4. If the \( CS \) low transition occurs simultaneously with the \( WE \) low transition, the output buffers remain in a high impedance state.
Appendix C5

**8212**

8-BIT INPUT/OUTPUT PORT

- Fully Parallel 8-Bit Data Register and Buffer
- Service Request Flip-Flop for Interrupt Generation
- Low Input Load Current — .25mA Max.
- Three State Outputs
- Outputs Sink 15mA
- 3.65V Output High Voltage for Direct Interface to 8008, 8080A, or 8085A CPU
- Asynchronous Register Clear
- Replaces Buffers, Latches and Multiplexers in Microcomputer Systems
- Reduces System Package Count

The 8212 input/output port consists of an 8-bit latch with 3-state output buffers along with control and device selection logic. Also included is a service request flip-flop for the generation and control of interrupts to the microprocessor. The device is multimode in nature. It can be used to implement latches, gated buffers or multiplexers. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with this device.

---

**PIN CONFIGURATION**

- D7, D6, D5, D4, D3, D2, D1, D0
- M0, M1
- IN, OUT
- DQ, DQ2
- INT
- 24 VCC
- 23 NC
- 22 L
- 21 L
- 20 L
- 19 L
- 18 L
- 17 DQ2
- 16 DQ2
- 15 DQ2
- 14 CLR
- 13 OS2
- 12 GND

**LOGIC DIAGRAM**

---

**PIN NAMES**

- D0, D1, D2, D3, D4, D5, D6, D7: DATA IN
- DQ, DQ2: DATA OUT
- M0, M1: DEVICE SELECT
- IN, OUT: MODE
- ST: STROBE
- INT: INTERRUPT (ACTIVE LOW)
- CLR: CLEAR (ACTIVE LOW)

---

Reprinted by permission of Intel Corporation Copyright © 1980

**APPENDIX C 251**
FUNCTIONAL DESCRIPTION

Data Latch
The 8 flip-flops that make up the data latch are of a "D" type design. The output (Q) of the flip-flop will follow the data input (D) while the clock input (C) is high. Latching will occur when the clock (C) returns low.
The latched data is cleared by an asynchronous reset input (CLR). (Note: Clock (C) Overrides Reset (CLR)).

Output Buffer
The outputs of the data latch (Q) are connected to 3-state, non-inverting output buffers. These buffers have a common control line (EN); this control line either enables the buffer to transmit the data from the outputs of the data latch (Q) or disables the buffer, forcing the output into a high impedance state. (3-state)
The high-impedance state allows the designer to connect the 8212 directly onto the microprocessor bi-directional data bus.

Control Logic
The 8212 has control inputs DS1, DS2, MD and STB. These inputs are used to control device selection, data latching, output buffer state and service request flip-flop.

DS1, DS2 (Device Select)
These 2 inputs are used for device selection. When DS1 is low and DS2 is high (DS1 · DS2) the device is selected. In the selected state the output buffer is enabled and the service request flip-flop (SR) is asynchronously set.

MD (Mode)
This input is used to control the state of the output buffer and to determine the source of the clock input (C) to the data latch.
When MD is high (output mode) the output buffers are enabled and the source of clock (C) to the data latch is from the device selection logic (DS1 · DS2).
When MD is low (input mode) the output buffer state is determined by the device selection logic (DS1 · DS2) and the source of clock (C) to the data latch is the STB (Strobe) input.

STB (Strobe)
This input is used as the clock (C) to the data latch for the input mode MD = 0) and to synchronously reset the service request flip-flop (SR).
Note that the SR flip-flop is negative edge triggered.

Service Request Flip-Flop
The (SR) flip-flop is used to generate and control interrupts in microcomputer systems. It is asynchronously reset by the CLR input (active low). When the (SR) flip-flop is set it is in the non-interrupting state.
The output of the (SR) flip-flop (Q) is connected to an inverting input of a "NOR" gate. The other input to the "NOR" gate is non-inverting and is connected to the device selection logic (DS1 · DS2). The output of the "NOR" gate (INT) is active low (interrupting state) for connection to active low input priority generating circuits.

8212 Applications — For Microcomputer Systems

1. Basic Schematic Symbol

2. Gated Buffer

3. Bi-Directional Bus Driver

4. Interrupting Input Port

5. Interrupt Instruction Port

VI. Output Port

VII. 8080A Status Latch

VIII. 8085A Address Latch

Two examples of ways to draw the 8212 on system schematics — (1) the top being the detailed view showing pin numbers, and (2) the bottom being the symbolic view showing the system input or output as a system bus (bus containing 8 parallel lines). The output to the data bus is symbolic in referencing 8 parallel lines.
II. Gated Buffer (3-State)

The simplest use of the 8212 is that of a gated buffer. By tying the mode signal low and the strobe input high, the data latch is acting as a straight through gate. The output buffers are then enabled from the device selection logic DS1 and DS2.

When the device selection logic is false, the outputs are 3-state.

When the device selection logic is true, the input data from the system is directly transferred to the output. The input data load is 250 micro amps. The output data can sink 15 milli amps. The minimum high output is 3.65 volts.

III. Bi-Directional Bus Driver

A pair of 8212's wired (back-to-back) can be used as a symmetrical drive, bi-directional bus driver. The devices are controlled by the data bus input control which is connected to DS1 on the first 8212 and to DS2 on the second. One device is active, and acting as a straight through buffer the other is in 3-state mode. This is a very useful circuit in small system design.
IV. Interrupting Input Port

This use of an 8212 is that of a system input port that accepts a strobe from the system input source, which in turn clears the service request flip-flop and interrupts the processor. The processor then goes through a service routine, identifies the port, and causes the device selection logic to go true—enabling the system input data onto the data bus.

V. Interrupt Instruction Port

The 8212 can be used to gate the interrupt instruction, normally RESTART instructions, onto the data bus. The device is enabled from the interrupt acknowledge signal from the microprocessor and from a port selection signal. This signal is normally tied to ground. (DS1 could be used to multiplex a variety of interrupt instruction ports onto a common bus).

VI. Output Port (With Hand-Shaking)

The 8212 can be used to transmit data from the data bus to a system output. The output strobe could be a handshaking signal such as "reception of data" from the device that the system is outputting to. It in turn, can interrupt the system signifying the reception of data. The selection of the port comes from the device selection logic (DS1:DS2)
VII. 8080A Status Latch

Here the 8212 is used as the status latch for an 8080A microcomputer system. The input to the 8212 latch is directly from the 8080A data bus. Timing shows that when the SYNC signal is true, which is connected to the DS2 input and the phase 1 signal is true, which is a TTL level coming from the clock generator; then, the status data will be latched into the 8212.

Note: The mode signal is tied high so that the output on the latch is active and enabled all the time.

It is shown that the two areas of concern are the bi-directional data bus of the microprocessor and the control bus.

---

VIII. 8085A Low-Order Address Latch

The 8085A microprocessor uses a multiplexed address/data bus that contains the low order 8-bits of address information during the first part of a machine cycle. The same bus contains data at a later time in the cycle. An address latch enable (ALE) signal is provided by the 8085A to be used by the 8212 to latch the address so that it may be available through the whole machine cycle. Note: In this configuration, the MODE input is tied high, keeping the 8212's output buffers turned on at all times.

---

APPENDIX C 235
ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias Plastic ............ 0°C to +70°C
Storage Temperature ..................... -65°C to +160°C
All Output or Supply Voltages ............ -0.5 to +7 Volts
All Input Voltages ...................... -1.0 to +5.5 Volts
Output Currents ........................ 100mA

"COMMENT
Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

D.C. CHARACTERISTICS  \( T_A = 0°C \) to +75°C, \( V_{CC} = +5V \pm 5% \)

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Limits</th>
<th>Unit</th>
<th>Test Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>( I_F )</td>
<td>Input Load Current, ACK, DS2, CR, DI1-DI3 Inputs</td>
<td>Min.</td>
<td>Typ.</td>
<td>Max.</td>
</tr>
<tr>
<td>( I_F )</td>
<td>Input Load Current MD Input</td>
<td>-2.5 mA</td>
<td>( V_F = ) .45V</td>
<td></td>
</tr>
<tr>
<td>( I_F )</td>
<td>Input Load Current DS1 Input</td>
<td>-1.0 mA</td>
<td>( V_F = ) .45V</td>
<td></td>
</tr>
<tr>
<td>( I_L )</td>
<td>Input Leakage Current, ACK, DS, CR, DI1-DI3 Inputs</td>
<td>10 ( \mu A )</td>
<td>( V_L \leq V_{CC} )</td>
<td></td>
</tr>
<tr>
<td>( I_L )</td>
<td>Input Leakage Current MO Input</td>
<td>30 ( \mu A )</td>
<td>( V_L \leq V_{CC} )</td>
<td></td>
</tr>
<tr>
<td>( I_L )</td>
<td>Input Leakage Current DS1 Input</td>
<td>40 ( \mu A )</td>
<td>( V_L \leq V_{CC} )</td>
<td></td>
</tr>
<tr>
<td>( V_C )</td>
<td>Input Forward Voltage Clamp</td>
<td>-1 V</td>
<td>( I_C = -5mA )</td>
<td></td>
</tr>
<tr>
<td>( V_{IL} )</td>
<td>Input &quot;Low&quot; Voltage</td>
<td>.85 V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( V_{IH} )</td>
<td>Input &quot;High&quot; Voltage</td>
<td>2.0 V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( V_{OL} )</td>
<td>Output &quot;Low&quot; Voltage</td>
<td>.45 V</td>
<td>( I_{OL} = 15mA )</td>
<td></td>
</tr>
<tr>
<td>( V_{OH} )</td>
<td>Output &quot;High&quot; Voltage</td>
<td>3.65 V</td>
<td>( I_{OH} = 1mA )</td>
<td></td>
</tr>
<tr>
<td>( I_{SC} )</td>
<td>Short Circuit Output Current</td>
<td>-15 mA</td>
<td>-75 mA</td>
<td>( V_O = 0V, V_{CC} = 5V )</td>
</tr>
<tr>
<td>( I_{OL} )</td>
<td>Output Leakage Current High Impedance State</td>
<td>20 ( \mu A )</td>
<td>( V_O = .45V/5.25V )</td>
<td></td>
</tr>
<tr>
<td>( I_{CC} )</td>
<td>Power Supply Current</td>
<td>90 mA</td>
<td>130 mA</td>
<td></td>
</tr>
</tbody>
</table>

TYPICAL CHARACTERISTICS

INPUT CURRENT VS. INPUT VOLTAGE

OUTPUT CURRENT VS. OUTPUT "LOW" VOLTAGE

OUTPUT CURRENT VS. OUTPUT "HIGH" VOLTAGE

DATA TO OUTPUT DELAY VS. LOAD CAPACITANCE

256 APPENDIX C
A.C. CHARACTERISTICS  \( T_A = 0^\circ C \) to \(+70^\circ C\), \( V_{CC} = +5V \pm 5\%\)

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Limits</th>
<th>Unit</th>
<th>Test Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{PW} )</td>
<td>Pulse Width</td>
<td>Min. 30</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>( t_{PD} )</td>
<td>Data to Output Delay</td>
<td>Typ. 30</td>
<td>ns</td>
<td>Note 1</td>
</tr>
<tr>
<td>( t_{WE} )</td>
<td>Write Enable to Output Delay</td>
<td>Max. 40</td>
<td>ns</td>
<td>Note 1</td>
</tr>
<tr>
<td>( t_{SET} )</td>
<td>Data Set Up Time</td>
<td>Min. 15</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>( t_{H} )</td>
<td>Data Hold Time</td>
<td>Max. 20</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>( t_{R} )</td>
<td>Reset to Output Delay</td>
<td>Min. 40</td>
<td>ns</td>
<td>Note 1</td>
</tr>
<tr>
<td>( t_{S} )</td>
<td>Set to Output Delay</td>
<td>Max. 30</td>
<td>ns</td>
<td>Note 1</td>
</tr>
<tr>
<td>( t_{E} )</td>
<td>Output Enable/Disable Time</td>
<td>Min. 45</td>
<td>ns</td>
<td>Note 1</td>
</tr>
<tr>
<td>( t_{C} )</td>
<td>Clear to Output Delay</td>
<td>Max. 55</td>
<td>ns</td>
<td>Note 1</td>
</tr>
</tbody>
</table>

CAPACITANCE*  \( F = 1MHz, V_{BIAS} = 2.5V, V_{CC} = +5V, T_A = 25^\circ C\)

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Test</th>
<th>Limits</th>
</tr>
</thead>
<tbody>
<tr>
<td>( C_{IN} ) DS1, MD Input Capacitance</td>
<td>Typ. 9pF Max. 12pF</td>
<td></td>
</tr>
<tr>
<td>( C_{IN} ) DS2, CK, ACK, DI1-DI8 Input Capacitance</td>
<td>Typ. 5pF Max. 9pF</td>
<td></td>
</tr>
<tr>
<td>( C_{OUT} ) DO1-DO8 Output Capacitance</td>
<td>Max. 8pF</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*This parameter is sampled and not 100% tested.

SWITCHING CHARACTERISTICS

Conditions of Test
Input Pulse Amplitude = 2.5V
Input Rise and Fall Times 5ns
Between 1V and 2V Measurements made at 1.5V
with 15mA and 30pF Test Load

Note 1:

<table>
<thead>
<tr>
<th>Test</th>
<th>( C_L^* )</th>
<th>( R_1 )</th>
<th>( R_2 )</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{PD}, t_{WS}, t_s, t_c )</td>
<td>30pF</td>
<td>300( \Omega )</td>
<td>600( \Omega )</td>
</tr>
<tr>
<td>( t_e, ENABLE )</td>
<td>30pF</td>
<td>10( \Omega )</td>
<td>1( K\Omega )</td>
</tr>
<tr>
<td>( t_e, ENABLE )</td>
<td>30pF</td>
<td>300( \Omega )</td>
<td>600( \Omega )</td>
</tr>
<tr>
<td>( t_e, DISABLE )</td>
<td>30pF</td>
<td>300( \Omega )</td>
<td>600( \Omega )</td>
</tr>
<tr>
<td>( t_e, DISABLE )</td>
<td>5pF</td>
<td>300( \Omega )</td>
<td>600( \Omega )</td>
</tr>
<tr>
<td>( t_e, DISABLE )</td>
<td>5pF</td>
<td>10( K\Omega )</td>
<td>1( K\Omega )</td>
</tr>
</tbody>
</table>

*Includes probe and jig capacitance.
TIMING DIAGRAM

DATA  1.5V    1.5V
       tPw   tH

STB = DS1 + DS2  1.5V    1.5V
               tE    tG

OUTPUT    1.5V

DS1 + DS2  1.5V    1.5V
(SEE NOTE BELOW)

OUTPUT    1.5V    1.5V
               tPw

CLR        1.5V    1.5V
               tC

DO         1.5V

DATA  1.5V    1.5V
       tSET    tH

STB = DS1 + DS2  1.5V

OUTPUT    1.5V

STB         1.5V

DS1 + DS2  1.5V    1.5V
               tPw    tG

INT

NOTE: ALTERNATIVE TEST LOAD

VCC 10k

OUT 1k

Copyrighted material
Appendix C6

KR2376-XX

Keyboard Encoder Read Only Memory

FEATURES
- Outputs directly compatible with TTL/DTL or MOS logic arrays.
- External control provided for output polarity selection.
- External control provided for selection of odd or even parity.
- Two key roll-over operation.
- N-key lockout.
- Programmable coding with a single mask change.
- Self-contained oscillator circuit.
- Externally controlled delay network provided to eliminate the effect of contact bounce.
- One integrated circuit required for complete keyboard assembly.
- Static charge protection on all input and output terminals.
- Entire circuit protected by a layer of glass passivation.

PIN CONFIGURATION

<table>
<thead>
<tr>
<th>PIN</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Vcc</td>
</tr>
<tr>
<td>2</td>
<td>Frequency Control B</td>
</tr>
<tr>
<td>3</td>
<td>Frequency Control C</td>
</tr>
<tr>
<td>4</td>
<td>Shift Input</td>
</tr>
<tr>
<td>5</td>
<td>Control Input</td>
</tr>
<tr>
<td>6</td>
<td>Parity Invert Input</td>
</tr>
<tr>
<td>7</td>
<td>Parity Output</td>
</tr>
<tr>
<td>8</td>
<td>Data Output B8</td>
</tr>
<tr>
<td>9</td>
<td>Data Output B7</td>
</tr>
<tr>
<td>10</td>
<td>Data Output B6</td>
</tr>
<tr>
<td>11</td>
<td>Data Output B5</td>
</tr>
<tr>
<td>12</td>
<td>Data Output B4</td>
</tr>
<tr>
<td>13</td>
<td>Data Output B3</td>
</tr>
<tr>
<td>14</td>
<td>Data Output B2</td>
</tr>
<tr>
<td>15</td>
<td>Strobe Output</td>
</tr>
<tr>
<td>16</td>
<td>Strobe Control Input</td>
</tr>
<tr>
<td>17</td>
<td>Data &amp; Strobe Invert Input</td>
</tr>
<tr>
<td>18</td>
<td>Strobe &amp; Signal Output</td>
</tr>
<tr>
<td>19</td>
<td>Strobe &amp; Signal Output</td>
</tr>
<tr>
<td>20</td>
<td>Ground</td>
</tr>
<tr>
<td>21</td>
<td>Vss</td>
</tr>
</tbody>
</table>

PACKAGE: 40-Pin DIP

GENERAL DESCRIPTION

The SMC KR2376-XX is a 2376-bit Read Only Memory with all the logic necessary to encode single pole single throw keyboard closures into a usable 9-bit code. Data and strobe outputs are directly compatible with TTL/DTL or MOS logic arrays without the use of any special interface components.

The KR2376-XX is fabricated with low threshold, P-channel technology and contains 2942 P-channel enhancement mode transistors on a single monolithic chip, available in a 40 pin dual-in-line package.

TYPICAL CONNECTION OF KR2376-XX

Reprinted by permission of SMC Microsystems Corporation Copyright © 1980
MAXIMUM GUARANTEED RATINGS†

Operating Temperature Range ..................................................... 0° C to +70° C
Storage Temperature Range ...................................................... -65° C to +150° C
GND and Vcc, with respect to Vcc ........................................... -20V to +0.3V
Logic Input Voltages, with respect to Vcc ................................. -20V to +0.3V

† Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

ELECTRICAL CHARACTERISTICS

(Ta = 0° C to +70° C, Vcc = +5V ±0.5V, Vcc = -12V ±1.0V, unless otherwise noted)

<table>
<thead>
<tr>
<th>Characteristics</th>
<th>Min</th>
<th>Typ</th>
<th>Max</th>
<th>Unit</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLOCK</td>
<td></td>
<td></td>
<td></td>
<td>KHz</td>
<td>see fig.1 footnote (**) for typical R-C values</td>
</tr>
<tr>
<td>DATA INPUT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Logic &quot;0&quot; Level</td>
<td></td>
<td></td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Logic &quot;1&quot; Level</td>
<td></td>
<td></td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Input Capacitance</td>
<td></td>
<td>Vcc-1.5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>INPUT CURRENT</td>
<td></td>
<td></td>
<td></td>
<td>μA</td>
<td></td>
</tr>
<tr>
<td>*Control, Shift &amp; Y0</td>
<td></td>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>thru Y10</td>
<td></td>
<td></td>
<td></td>
<td>140</td>
<td></td>
</tr>
<tr>
<td>*Control, Shift &amp; Y0</td>
<td></td>
<td>100</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>thru Y10</td>
<td></td>
<td></td>
<td></td>
<td>50</td>
<td></td>
</tr>
<tr>
<td>Data Invert, Parity Invert</td>
<td></td>
<td>50</td>
<td>50</td>
<td></td>
<td></td>
</tr>
<tr>
<td>DATA OUTPUT &amp; X OUTPUT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Logic &quot;0&quot; Level</td>
<td></td>
<td></td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Logic &quot;1&quot; Level</td>
<td></td>
<td></td>
<td></td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>POWER CONSUMPTION</td>
<td></td>
<td>Vcc-1.0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SWITCH CHARACTERISTICS</td>
<td></td>
<td></td>
<td></td>
<td>mW</td>
<td></td>
</tr>
<tr>
<td>Minimum Switch Closure</td>
<td></td>
<td>140</td>
<td></td>
<td></td>
<td>see timing diagram-fg. 2</td>
</tr>
<tr>
<td>Contact Closure Resistance between X1 and Y1</td>
<td></td>
<td>300</td>
<td></td>
<td></td>
<td>Ohm</td>
</tr>
<tr>
<td>Contact Open Resistance between X1 and Y1</td>
<td></td>
<td>1 x 10⁷</td>
<td>300</td>
<td></td>
<td>Ohm</td>
</tr>
</tbody>
</table>

*Inputs with Internal Resistor to Vcc

DESCRIPTION OF OPERATION

The KR2376-XX contains (see Fig. 1), a 2376-bit ROM, 8-stage and 11-stage ring counters, an 11-bit comparator, an oscillator circuit, an externally controllable delay network for eliminating the effect of contact bounce, and TTL/DTL/MOS compatible output drivers.

The external outputs of the 8-stage ring counter and the external inputs to the 11-bit comparator are wired to the keyboard to form an X-Y matrix with the 88-keyboard switches as the crosspoints. In the standby condition, when no key is depressed, the two ring counters are clocked and sequentially address the ROM; the absence of a Strobe Output indicates that the Data Outputs are "not valid" at this time.
When a key is depressed, a single path is completed between one output of the 8-stage ring counter (X0 thru X7) and one input of the 11-bit comparator (Y0-Y10). After a number of clock cycles, a condition will occur where a level on the selected path to the comparator matches a level on the corresponding comparator input from the 11-stage ring counter. When this occurs, the comparator generates a signal to the clock control and to the Strobe Output (via the delay network). The clock control stops the clocks to the ring counters and the Data Outputs (B1-B9) stabilize with the selected 9-bit code, indicated by a 'valid' signal on the Strobe Output. The Data Outputs remain stable until the key is released.

As an added feature two inputs are provided for external polarity control of the Data Outputs. Parity Invert (pin 6) provides polarity control of the Parity Output (pin 7) while the Data and Strobe Invert Input (pin 20) provides for polarity control of Data Outputs B1 thru B9 (pins 8 thru 15) and the Strobe Output (pin 16).

**SPECIAL PATTERNS**

Since the selected coding of each key is defined during the manufacture of the chip, the coding can be changed to fit any particular application of the keyboard. Up to 254 codes of up to 8 bits (plus one parity bit) can be programmed into the KR2376-XX ROM covering most popular codes such as ASC11, EBCD1C, Selectric, etc., as well as many special codes. The ASC11 code is available as a standard pattern. For special patterns, use Fig. 9.

---

**TIMING DIAGRAM**

**Fig. 2**

**POWER SUPPLY CONNECTIONS FOR TTL/DTL OPERATION**

**Fig. 3**

**OUTPUT DRIVER & "X" OUTPUT STAGE TO KEYBOARD**

**Fig. 4**

**POWER SUPPLY CONNECTIONS FOR MOS OPERATION**

**"Y" INPUT STAGE FROM KEYBOARD**

APPENDIX C 261
FLOW CHART—TRANSMITTER

1. TURN POWER ON
2. PULSE EXTERNAL RESET
3. SELECT BAUD RATE = 16 x CLK

1. TEMP = 1
2. EOC = 1
3. STOP BIT

SET CONTROL BITS = PULSE CS

SET DATA BIT

NO

HAS TEMPERATURE BEEN PULSED?

YES

1. TEMP = 0

NO

TRANSMITTER SHIFT REGISTER

SELECTED BAUD RATE

16 x EOC

1. LOAD TRANSMITTER SHIFT REGISTER
2. SD = 0 (START BIT)
3. EOC = 0

1. TEMP = 1

NO

1. BIT TIME ELAPSED?
2. 16 x EOC

YES

SHIFT BIT RIGHT IN THE TRANSMITTER SHIFT REGISTER

TRANSMIT START BIT DATA BITS. SELECTED PARITY MODE AND STOP BITS

NO

HAS THE START BIT BEEN SEEN ON THE LINE FOR 1 BIT TIME?

YES

EDC = 1
SD = 1

NO

AND THREE CONTROL BITS

YES

FLOW CHART—RECEIVER

1. TURN POWER ON
2. PULSE EXTERNAL RESET
3. SELECT BAUD RATE = 16 x CLK
4. SET CONTROL BITS

1. DATA = 0
2. DATA = 0
3. DATA = 0

NO

HAS THE LINE CHANGED FROM MARKING TO SPACING?

YES

HAS START BIT BEEN VERIFIED 8 x EOC?

YES

LOAD START BIT INTO RECEIVER SHIFT REGISTER

NO

1. BIT TIME ELAPSED?
2. 16 x EOC

1. SHIFT AND LOAD DATA BIT INTO RECEIVER SHIFT REGISTER
2. SELECTED NUMBER OF DATA BITS RECEIVED

NO

SET PARITY ERROR REGISTER TO 1

YES

NO

HAS THE PROPER PARITY BIT BEEN RECEIVED?

YES

SET PARITY ERROR REGISTER TO 0

NO

BIT TIME ELAPSED?

YES

NO

SELECTED NUMBER OF DATA BITS RECEIVED?

YES

NO

SET FRAMING ERROR REGISTER TO 1

YES

NO

HAS A START BIT BEEN RECEIVED?

YES

SET FRAMING ERROR REGISTER TO 0

NO

SET OVER-RUN ERROR REGISTER TO 1

YES

NO

TRANSFER DATA BITS FROM SHIFT REGISTER TO DATA BITS HOLDING REGISTER

DATA = 0

NO

1. STROBE STATUS WORD ENABLE
2. STROBE DATA ENABLE

YES

RESET DATA AVAILABLE = DA x 0

Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.
Appendix C8

CRT Video Timer and Controller
VTAC®

FEATURES

☐ Fully Programmable Display Format
  Characters per data row (1-200)
  Data rows per frame (1-64)
  Raster scans per data row (1-16)

☐ Programmable Monitor Sync Format
  Raster Scans/Frame (256-1023)
  "Front Porch"
  "Back Porch"
  Interface/Non-Interface
  Vertical Blanking

☐ Lock Line Input (CRT 5057)
☐ Direct Outputs to CRT Monitor
  Horizontal Sync
  Vertical Sync
  Composite Sync (CRT 5027, CRT 5037)
  Blanking
  Cursor coincidence

☐ Programmed via:
  Processor data bus
  External PROM
  Mask Option ROM

☒ Standard or Non-Standard CRT Monitor Compatible
☐ Refresh Rate: 60Hz, 50Hz, ....
☐ Scrolling
  Single Line
  Multi-Line

☐ Cursor Position Registers
  Character Format: 5x7, 7x9, ....
☐ Programmable Vertical Data Positioning
☒ Balanced Beam Current Interface (CRT 5037)
☐ Graphics Compatible

PIN CONFIGURATION

<table>
<thead>
<tr>
<th>PIN</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>A2</td>
<td>1</td>
</tr>
<tr>
<td>A3</td>
<td>2</td>
</tr>
<tr>
<td>C6</td>
<td>3</td>
</tr>
<tr>
<td>R3</td>
<td>4</td>
</tr>
<tr>
<td>R2</td>
<td>5</td>
</tr>
<tr>
<td>GND</td>
<td>6</td>
</tr>
<tr>
<td>R1</td>
<td>7</td>
</tr>
<tr>
<td>R6</td>
<td>8</td>
</tr>
<tr>
<td>D5</td>
<td>9</td>
</tr>
<tr>
<td>LLI/CSYN</td>
<td>10</td>
</tr>
<tr>
<td>VSYN</td>
<td>11</td>
</tr>
<tr>
<td>DCC</td>
<td>12</td>
</tr>
<tr>
<td>VCC</td>
<td>13</td>
</tr>
<tr>
<td>VCC</td>
<td>14</td>
</tr>
<tr>
<td>HSYNC</td>
<td>15</td>
</tr>
<tr>
<td>CRV</td>
<td>16</td>
</tr>
<tr>
<td>BL</td>
<td>17</td>
</tr>
<tr>
<td>DB7</td>
<td>18</td>
</tr>
<tr>
<td>DB6</td>
<td>19</td>
</tr>
<tr>
<td>DB5</td>
<td>20</td>
</tr>
</tbody>
</table>

☐ Split-Screen Applications
  Horizontal
  Vertical
  TTL Compatibility
  BUS Oriented
  High Speed Operation
  COPLAMOS® N-Channel Silicon
  Gate Technology
☐ Compatible with CRT 6002 VDAC™
☐ Compatible with CRT 7004

GENERAL DESCRIPTION

The CRT Video Timer and Controller (VTAC)® is a user programmable 40-pin COPLAMOS® n-channel MOS/LSI device containing the logic functions required to generate all the timing signals for the presentation and formatting of interlaced and non-interlaced video data on a standard or non-standard CRT monitor.

With the exception of the dot counter, which may be clocked at a video frequency above 25 MHz and therefore not recommended for MOS implementation, all frame formatting, such as horizontal, vertical, and composite sync, characters per data row, data rows per frame, and raster scans per data row and per frame are totally user programmable. The data row counter has been designed to facilitate scrolling.

Programming is effected by loading seven 8 bit control registers directly off an 8 bit bidirectional data bus. Four register address lines and a chip select line provide complete microprocessor compatibility for program controlled setup. The device can be "self loaded" via an external PROM tied on the data bus as described in the OPERATION section. Formatting can also be programmed by a single mask option.

In addition to the seven control registers two additional registers are provided to store the cursor character and data row addresses for generation of the cursor video signal. The contents of these two registers can also be read out onto the bus for update by the program.

Three versions of the VTAC® are available. The CRT 5027 provides non-interlaced operation with an even or odd number of scan lines per data row, or interlaced operation with an even number of scan lines per data row. The CRT 5037 may be programmed for an odd or even number of scan lines per data row in both interlaced and non-interlaced modes. Programming the CRT 5037 for an odd number of scan lines per data row eliminates character distortion caused by the uneven beam current normally associated with odd field/even field interfacing of alphanumeric displays.

The CRT 5057 provides the ability to lock a CRT's vertical refresh rate, as controlled by the VTAC® vertical sync pulse, to the 50 Hz or 60 Hz line frequency thereby eliminating the so-called "swim" phenomenon. This is particularly well suited for European system requirements. The line frequency waveform, processed to conform to the VTAC® specified logic levels, is applied to the line lock input. The VTAC® will inhibit generation of vertical sync until a zero to one transition on this input is detected. The vertical sync pulse is then initiated within one scan line after this transition rises above the logic threshold of the VTAC®.

To provide the pin required for the lock line input, the composite sync output is not provided in the CRT 5057.

*FOR FUTURE RELEASE

Reprinted by permission of SMC Microsystems Corporation Copyright © 1980
### Description of Pin Functions

<table>
<thead>
<tr>
<th>Pin No.</th>
<th>Symbol</th>
<th>Name</th>
<th>Input/Output</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>25-18</td>
<td>DB₈-7</td>
<td>Data Bus</td>
<td>I/O</td>
<td>Data bus. Input bus for control words from microprocessor or PROM. Bidirectional bus for cursor address.</td>
</tr>
<tr>
<td>3</td>
<td>CS</td>
<td>Chip Select</td>
<td></td>
<td>Signals chip that it is being addressed</td>
</tr>
<tr>
<td>39, 40, 1, 2</td>
<td>A⑷-3</td>
<td>Register Address</td>
<td>I</td>
<td>Register address bits for selecting one of seven control registers or either of the cursor address registers</td>
</tr>
<tr>
<td>9</td>
<td>D₅</td>
<td>Data Strobe</td>
<td>I</td>
<td>Strobes DB₈-7 into the appropriate register or outputs the cursor character address or cursor line address onto the data bus</td>
</tr>
<tr>
<td>12</td>
<td>DCC</td>
<td>DOT Counter Carry</td>
<td>I</td>
<td>Carry from off chip dot counter establishing basic character clock rate. Character clock.</td>
</tr>
<tr>
<td>38-32</td>
<td>Hｆ-6</td>
<td>Character Counter Outputs</td>
<td></td>
<td>Character counter outputs.</td>
</tr>
<tr>
<td>7, 5, 4</td>
<td>R₁-3</td>
<td>Scan Counter Outputs</td>
<td>O</td>
<td>Three most significant bits of the Scan Counter; row select inputs to character generator.</td>
</tr>
<tr>
<td>31</td>
<td>H7/DR5</td>
<td>H7/DR5</td>
<td>O</td>
<td>Pin definition is user programmable. Output is MSB of Character Counter if horizontal line count (REG.⑶) is ≥128; otherwise output is MSB of Data Row Counter.</td>
</tr>
<tr>
<td>8</td>
<td>Rｆ</td>
<td>Scan Counter LSB</td>
<td>O</td>
<td>Least significant bit of the scan counter. In the interlaced mode with an even number of scans per data row, R6 will toggle at the field rate; for an odd number of scans per data row in the interlaced mode, R8 will toggle at the data row rate.</td>
</tr>
<tr>
<td>26-30</td>
<td>DRｆ-4</td>
<td>Data Row Counter Outputs</td>
<td></td>
<td>Data Row counter outputs.</td>
</tr>
<tr>
<td>17</td>
<td>BL</td>
<td>Blank</td>
<td>O</td>
<td>Defines non active portion of horizontal and vertical scans.</td>
</tr>
<tr>
<td>15</td>
<td>HSYN</td>
<td>Horizontal Sync</td>
<td>O</td>
<td>Initiates horizontal retrace.</td>
</tr>
<tr>
<td>11</td>
<td>VSYN</td>
<td>Vertical Sync</td>
<td>O</td>
<td>Initiates vertical retrace.</td>
</tr>
<tr>
<td>10</td>
<td>CSYN/</td>
<td>Composite Sync Output/</td>
<td>O/I</td>
<td>Composite sync is provided on the CRT 5027 and CRT 5037. This output is active in non-interlaced mode only. Provides a true RS-170 composite sync wave form. For the CRT 5057, this pin is the Line Lock Input. The line frequency waveform, processed to conform to the VTAC's specified logic levels, is applied to this pin.</td>
</tr>
<tr>
<td>LLI</td>
<td></td>
<td>Line Lock Input</td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>CRV</td>
<td>Cursor Video</td>
<td>O</td>
<td>Defines cursor location in data field.</td>
</tr>
<tr>
<td>14</td>
<td>Vcc</td>
<td>Power Supply</td>
<td>PS</td>
<td>+5 volt Power Supply</td>
</tr>
<tr>
<td>13</td>
<td>Vcc</td>
<td>Power Supply</td>
<td>PS</td>
<td>+12 volt Power Supply</td>
</tr>
</tbody>
</table>

![Block Diagram](image)
Operation

The design philosophy employed was to allow the device to interface effectively with either a microprocessor based or hardware logic system. The device is programmed by the user in one of two ways; via the processor data bus as part of the system initialization routine, or during power up via a PROM tied on the data bus and addressed directly by the Row Select outputs of the chip. (See figure 4). Seven 8 bit words are required to fully program the chip. Bit assignments for these words are shown in Table 1. The information contained in these seven words consists of the following:

<table>
<thead>
<tr>
<th>Horizontal Formatting:</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Characters/Data Row</td>
<td>A 3 bit code providing 8 mask programmable character lengths from 20 to 132. The standard device will be masked for the following character lengths; 20, 32, 40, 64, 72, 80, 96, and 132.</td>
</tr>
<tr>
<td>Horizontal Sync Delay</td>
<td>3 bits assigned providing up to 8 character times for generation of “front porch”.</td>
</tr>
<tr>
<td>Horizontal Sync Width</td>
<td>4 bits assigned providing up to 15 character times for generation of horizontal sync width.</td>
</tr>
<tr>
<td>Horizontal Line Count</td>
<td>8 bits assigned providing up to 256 character times for total horizontal formatting.</td>
</tr>
<tr>
<td>Skew Bits</td>
<td>A 2 bit code providing for a 0 to 2 character skew (delay) between the horizontal address counter and the blank and sync (horizontal, vertical, composite) signals to allow for retiming of video data prior to generation of composite video signal. The Cursor Video signal is also skewed as a function of this code.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Vertical Formatting:</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Interlaced/Non-interlaced</td>
<td>This bit provides for data presentation with odd/even field formatting for interlaced systems. It modifies the vertical timing counters as described below. A logic 1 establishes the interface mode.</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Scans/Frame</th>
<th>8 bits assigned, defined according to the following equations: Let X = value of 8 assigned bits.</th>
</tr>
</thead>
<tbody>
<tr>
<td>1) in interlaced mode—scans/frame = 2X + 513. Therefore for 525 scans, program X = 6 (00000110). Vertical sync will occur precisely every 262.5 scans, thereby producing two interlaced fields. Range = 513 to 1023 scans/frame, odd counts only.</td>
<td></td>
</tr>
<tr>
<td>2) in non-interlaced mode—scans/frame = 2X + 256. Therefore for 262 scans, program X = 3 (00000011). Range = 256 to 766 scans/frame, even counts only.</td>
<td></td>
</tr>
<tr>
<td>Vertical Data Start</td>
<td>8 bits defining the number of raster scans from the leading edge of vertical sync until the start of display data. At this raster scan the data row counter is set to the data row address at the top of the page.</td>
</tr>
<tr>
<td>Data Rows/Frame</td>
<td>6 bits assigned providing up to 64 data rows per frame.</td>
</tr>
<tr>
<td>Last Data Row</td>
<td>6 bits to allow up or down scrolling via a preload defining the count of the last displayed data row.</td>
</tr>
<tr>
<td>Scans/Data Row</td>
<td>4 bits assigned providing up to 16 scan lines per data row.</td>
</tr>
</tbody>
</table>

Additional Features

Device Initialization:

Under microprocessor control—The device can be reset under system or program control by presenting a 1011B address on A3-9. The device will remain reset at the top of the even field page until a start command is executed by presenting a 1111B address on A3-9.

Via “Self Loading”—In a non-processor environment, the self loading sequence is effected by presenting and holding the 1111 address on A3-9, and is initiated by the receipt of the strobe pulse (DS). The 1111 address should be maintained long enough to insure that all seven registers have been loaded (in most applications under one millisecond). The timing sequence will begin one line scan after the 1111 address is removed. In processor based systems, self loading is initiated by presenting the 1111 address to the device. Self loading is terminated by presenting the start command to the device which also initiates the timing chain.

Scrolling—In addition to the Register 6 storage of the last displayed data row a “scroll” command (address 1f11) presented to the device will increment the first displayed data row count to facilitate up scrolling in certain applications.
Control Registers Programming Chart

Horizontal Line Count: Total Characters/Line = N + 1, N = 0 to 255 (DB0 = LSB)

Characters/Data Row:
- DB2  DB1  DB0
- 0 0 0 = 20 Active Characters/Data Row
- 0 0 1 = 32
- 0 1 0 = 40
- 0 1 1 = 64
- 1 0 0 = 72
- 1 0 1 = 80
- 1 1 0 = 96
- 1 1 1 = 132

Horizontal Sync Delay: = N, from 1 to 7 character times (DB0 = LSB) (N = 0 Disallowed)
Horizontal Sync Width: = N, from 1 to 15 character times (DB3 = LSB) (N = 0 Disallowed)

Sync/Blank Delay   Cursor Delay

Skew Bits
- DB7  DB8
  - 0 0 0 0
  - 1 0 1 0
  - 0 1 2 1
  - 1 1 2 2

(Characteristic Times)

Scans/Frame
8 bits assigned, defined according to the following equations:
Let X = value of 8 assigned bits. (DB0 = LSB)
1) in interfaced mode—scans/frame = 2X + 513. Therefore for 525 scans, program X = 6 (000000110). Vertical sync will occur precisely every 262.5 scans, thereby producing two interfaced fields.
Range = 513 to 1023 scans/frame, odd counts only.
2) in non-interfaced mode—scans/frame = 2X + 256. Therefore for 262 scans, program X = 3 (000000111).
Range = 256 to 766 scans/frame, even counts only.
In either mode, vertical sync width is fixed at three horizontal scans (=3H).

Vertical Data Start:
N = number of raster lines delay after leading edge of vertical sync of vertical start position. (DB0 = LSB)

Data Rows/Frame:
Number of data rows = N + 1, N = 0 to 63 (DB0 = LSB)

Last Data Row:
N = Address of last displayed data row, N = 0 to 63, i.e.; for 24 data rows, program N = 23. (DB0 = LSB)

Mode:
Register, 1, DB7 = 1 establishes Interface.

Scans/Data Row:
Interlace Mode
CRT 5027: Scans per Data Row = N + 1 where N = programmed number of data rows. N = 0 to 15. Scans per data row must be even counts only.
CRT 5037, CRT 5057: Scans per Data Row = N + 2. N = 0 to 14, odd or even counts.

Non-Interface Mode
CRT 5027, CRT 5037, CRT 5057: Scans per Data Row = N + 1. odd or even count. N = 0 to 15.

---

274 APPENDIX C
Register Selects/Command Codes

<table>
<thead>
<tr>
<th>A3</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
<th>Select/Command</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Load Control Register 0</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>Load Control Register 1</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Load Control Register 2</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Load Control Register 3</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Load Control Register 4</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Load Control Register 5</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Load Control Register 6</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Processor Initiated Self Load</td>
<td>Command from processor instructing VTAC® to enter Self Load Mode (via external PROM)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Read Cursor Line Address</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>Read Cursor Character Address</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Reset</td>
<td>Resets timing chain to top left of page. Reset is latched on chip by DS and counters are held until released by start command.</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Load Cursor Character Address*</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Load Cursor Line Address*</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Start Timing Chain</td>
<td>Receipt of this command after a Reset or Processor Self Load command will release the timing chain approximately one scan line later. In applications requiring synchronous operation of more than one CRT 5027 the dot counter carry should be held low during the DS for this command.</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Non-Processor Self Load</td>
<td>Device will begin self load via PROM when DS goes low. The 1111 command should be maintained on A3-Ø long enough to guarantee self load. (Scan counter should cycle through at least once). Self load is automatically terminated and timing chain initiated when the all-&quot;1's&quot; condition is removed, independent of DS. For synchronous operation of more than one VTAC®, the Dot Counter Carry should be held low when the command is removed.</td>
</tr>
</tbody>
</table>

*NOTE: During Self-Load, the Cursor Character Address Register (REG 7) and the Cursor Row Address Register (REG 8) are enabled during states Ø111 and 1000 of the R3-R8 Scan Counter outputs respectively. Therefore, Cursor data in the PROM should be stored at these addresses.

TABLE 1

<table>
<thead>
<tr>
<th>BIT ASSIGNMENT CHART</th>
</tr>
</thead>
<tbody>
<tr>
<td>HORIZONTAL LINE COUNT</td>
</tr>
<tr>
<td>REG 7</td>
</tr>
<tr>
<td>REG 2</td>
</tr>
<tr>
<td>MODE INTERLACED</td>
</tr>
<tr>
<td>NON INTERLACED</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>SKEW BITS</th>
<th>DATA ROWS/FRAME</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG 3</td>
<td></td>
</tr>
<tr>
<td>REG 1</td>
<td></td>
</tr>
<tr>
<td>REG 0</td>
<td></td>
</tr>
</tbody>
</table>

| SCAN/DATA ROW CHARACTERS/DATA ROW |
| REG 6 |
| REG 5 |
| REG 4 |

| VERTICAL DATA START |
| REG 7 |

| SCAN LINES/FRAME |
| REG 6 |
| REG 5 |
| REG 4 |

| CURSOR CHARACTER ADDRESS |
| REG 5 |
| REG 4 |

| CURSOR ROW ADDRESS |
| REG 5 |
| REG 0 |

| LAST DISPLAYED DATA ROW |
| REG 5 |
| REG 0 |

APPENDIX C 275
AC TIMING DIAGRAMS

FIGURE 1 VIDEO TIMING

DOT COUNTER CARRY

PW_L

PW_H

HSync, Vsync, Blank, Cursor Video, Composite Sync

FIGURE 2 LOAD/READ TIMING

ADDRESS, CHIP SELECT

DB#7 LOADING IN OF DATA

DB#7 READING OUT OF DATA

DS

FIGURE 3 SCAN AND DATA ROW COUNTER TIMING

HSync

R8-3
D8-5

*R8-3 and D8-5 may change prior to the falling edge of H sync
MAXIMUM GUARANTEED RATINGS

Operating Temperature Range .............................................. 0°C to + 70°C
Storage Temperature Range .................................................. -55°C to + 150°C
Lead Temperature (soldering, 10 sec) ...................................... +325°C
Positive Voltage on any Pin, with respect to ground ..................... +18.0V
Negative Voltage on any Pin, with respect to ground ................... -0.3V

*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. For example, the bench power supply programmed to deliver +12 volts may have large voltage transients when the AC power is switched on and off. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS (Ta = 0°C to 70°C, Vcc = +5V ±5%, Voo = +12V ±5%, unless otherwise noted)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>D.C. CHARACTERISTICS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>INPUT VOLTAGE LEVELS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low Level, Vih</td>
<td>0.8</td>
<td>V</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>High Level, Vih</td>
<td>Vcc - 1.5</td>
<td>V</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OUTPUT VOLTAGE LEVELS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low Level—Voh for RS-3</td>
<td>0.4</td>
<td>V</td>
<td>IoL = 3.2mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low Level—Voh, all others</td>
<td>0.4</td>
<td>V</td>
<td>IoL = 1.6mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>High Level—Voh for RS-3, DB7-7</td>
<td>2.4</td>
<td>V</td>
<td>IoH = 60µA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>High Level—Voh, all others</td>
<td>2.4</td>
<td>V</td>
<td>IoH = 40µA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>INPUT CURRENT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low Level, Ii, (Address, CS only)</td>
<td>250</td>
<td>µA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Leakage, Ii, (All Inputs except Address, CS)</td>
<td>10</td>
<td>µA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>INPUT CAPACITANCE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Bus, Cw</td>
<td>10</td>
<td>pF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DS, Clock, Cw</td>
<td>25</td>
<td>pF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>All other, Cw</td>
<td>10</td>
<td>pF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DATA BUS LEAKAGE in INPUT MODE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IoC</td>
<td>10</td>
<td>µA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>POWER SUPPLY CURRENT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IoC</td>
<td>80</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>A.C. CHARACTERISTICS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DOT COUNTER CARRY</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>frequency</td>
<td>0.2</td>
<td>MHz</td>
<td></td>
<td>Figure 1</td>
<td></td>
</tr>
<tr>
<td>PWL</td>
<td>35</td>
<td>ns</td>
<td></td>
<td>Figure 1</td>
<td></td>
</tr>
<tr>
<td>PLL</td>
<td>215</td>
<td>ns</td>
<td></td>
<td>Figure 1</td>
<td></td>
</tr>
<tr>
<td>fr, f</td>
<td>10</td>
<td>50</td>
<td>ns</td>
<td>Figure 1</td>
<td></td>
</tr>
<tr>
<td>DATA STROBE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PW50</td>
<td>150ns</td>
<td></td>
<td></td>
<td>Figure 2</td>
<td></td>
</tr>
<tr>
<td>ADDRESS, CHIP SELECT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Set-up time</td>
<td>125</td>
<td>ns</td>
<td></td>
<td>Figure 2</td>
<td></td>
</tr>
<tr>
<td>Hold time</td>
<td>50</td>
<td>ns</td>
<td></td>
<td>Figure 2</td>
<td></td>
</tr>
<tr>
<td>DATA BUS—LOADING</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Set-up time</td>
<td>125</td>
<td>ns</td>
<td></td>
<td>Figure 2</td>
<td></td>
</tr>
<tr>
<td>Hold time</td>
<td>75</td>
<td>ns</td>
<td></td>
<td>Figure 2</td>
<td></td>
</tr>
<tr>
<td>DATA BUS—READING</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Ttot1</td>
<td>5</td>
<td>ns</td>
<td></td>
<td>Figure 2, CL = 50pF</td>
<td></td>
</tr>
<tr>
<td>Ttot2</td>
<td>125</td>
<td>ns</td>
<td></td>
<td>Figure 2, CL = 50pF</td>
<td></td>
</tr>
<tr>
<td>OUTPUTS: H7, HS, VS, BL, CRV, CS-Tot1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>OUTPUTS: RS, 6, 5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*RS-3 and DR6-5 may change prior to the falling edge of H sync

Restrictions

1. Only one pin is available for strobing data into the device via the data bus. The cursor X and Y coordinates are therefore loaded into the chip by presenting one set of addresses and outputted by presenting a different set of addresses. Therefore the standard WRITE and READ control signals from most microprocessors must be "NORed" externally to present a single strobe (DBS) signal to the device.

2. In interfaced mode the total number of character slots assigned to the horizontal scan must be even to insure that vertical sync occurs precisely between horizontal sync pulses.

APPENDIX C 277
General Timing

Composite Sync Timing

Vertical Sync Timing

Start-up, CRT 5027

When employing microprocessor controlled loading of the CRT 5027’s registers, the following sequence of instructions is necessary:

<table>
<thead>
<tr>
<th>ADDRESS</th>
<th>COMMAND</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 1 1 0</td>
<td>Start Timing Chain</td>
</tr>
<tr>
<td>1 0 1 0</td>
<td>Reset</td>
</tr>
<tr>
<td>0 0 0 0</td>
<td>Load Register 0</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
</tr>
<tr>
<td>0 1 1 0</td>
<td>Load Register 6</td>
</tr>
<tr>
<td>1 1 1 0</td>
<td>Start Timing Chain</td>
</tr>
</tbody>
</table>

The sequence of START RESET LOAD START is necessary to insure proper initialization of the registers.

This sequence is not required if register loading is via either of the Self Load modes. This sequence is optional with the CRT 5037 or CRT 5057.

Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications. Consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.
Appendix C9

CRT 8002

CRT Video Display Attributes Controller
Video Generator
VDAC™

FEATURES

☐ On chip character generator (mask programmable)
  128 Characters (alphabetic and graphic)
  7 x 11 Dot matrix block
☐ On chip video shift register
  Maximum shift register frequency
  CRT 8002A 20MHz
  CRT 8002B 15MHz
  CRT 8002C 10MHz
  Access time 400ns
☐ On chip horizontal and vertical retrace video blanking
☐ No descender circuitry required
☐ Four modes of operation (intermixable)
  Internal character generator (ROM)
  Wide graphics
  Thin graphics
  External inputs (fonts/dot graphics)
☐ On chip attribute logic—character, field
  Reverse video
  Character blank
  Character blink
  Underline
  Strike-thru
☐ Four on chip cursor modes
  Underline
  Blinking underline
  Reverse video
  Blinking reverse video
☐ Programmable character blink rate
☐ Programmable cursor blink rate

PIN CONFIGURATION

VIDEO 28 RETBL
LD/SR 27 CURSOR
VDC 32 26 MS⁰
A0 4 25 MS¹
A1 5 24 BLINK
A2 6 23 V SYNC
A3 7 22 CHABL
A4 8 21 REVID
A5 9 20 UNDLN
A6 10 19 STKRU
A7 11 18 ATTBE
VCC 12 17 GND
R2 13 16 R¹
R3 14 15 R¹

General Description

The SMC CRT 8002 Video Display Attributes Controller (VDAC) is an N-channel COPLAMOS® MOS/LSI device which utilizes CLASP® technology. It contains a 7X11X128 character generator ROM, a wide graphics mode, a thin graphics mode, an external input mode, character address/data latch, field and/or character attribute logic, attribute latch, four cursor modes, two programmable blink rates, and a high speed video shift register. The CRT 8002 VDAC™ is a companion chip to SMC's CRT 5027 VTAC. Together these two chips comprise the circuitry required for the display portion of a CRT video terminal.

The CRT 8002 video output may be connected directly to a CRT monitor video input. The CRT 5027 blanking output can be connected directly to the CRT 8002 retrace blank input to provide both horizontal and vertical retrace blanking of the video output.

Four cursor modes are available on the CRT 8002. They are: underline, blinking underline, reverse video block, and blinking reverse video block. Any one of these can be mask programmed as the cursor function. There is a separate cursor blink rate which can be mask programmed to provide a 15Hz to 1Hz blink rate.

The CRT 8002 attributes include: reverse video, character blank, blink, underline, and strike-thru. The character blink rate is mask programmable from 7.5Hz to 0.5Hz and has a duty cycle of 75/25. The underline and strike-thru are similar but independently controlled functions and can be mask programmed to any number of raster lines at any position in the character block. These attributes are available in all modes.

In the wide graphic mode the CRT 8002 produces a graphic entity the size of the character block. The graphic entity contains 8 parts, each of which is associated with one bit of a graphic byte, thereby providing for 256 unique graphic symbols. Thus, the CRT 8002 can produce either an alphanumeric symbol or a graphic entity depending on the mode selected. The mode can be changed on a per character basis.

The thin graphic mode enables the user to create single line drawings and forms.

The external enable enables the user to extend the on-chip ROM character set and/or the on-chip graphics capabilities by inserting external symbols. These external symbols can come from either RAM, ROM or PROM.

Reprinted by permission of SMC Microsystems Corporation Copyright © 1980
MAXIMUM GUARANTEED RATINGS:

- Operating Temperature Range: 0°C to +70°C
- Storage Temperature Range: -55°C to +150°C
- Lead Temperature (soldering, 10 sec.): +325°C
- Positive Voltage on any Pin, with respect to ground: +8.0V
- Negative Voltage on any Pin, with respect to ground: -0.3V

*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS (TA=0°C to 70°C, Vcc = +5V ± 5%, unless otherwise noted)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>D.C. CHARACTERISTICS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>INPUT VOLTAGE LEVELS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low-level, VIL</td>
<td></td>
<td></td>
<td>2.0</td>
<td></td>
<td>excluding VDC</td>
</tr>
<tr>
<td>High-level, VIH</td>
<td></td>
<td></td>
<td>0.8</td>
<td></td>
<td>excluding VDC</td>
</tr>
<tr>
<td>INPUT VOLTAGE LEVELS-CLOCK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low-level, VIL</td>
<td></td>
<td></td>
<td>4.3</td>
<td></td>
<td>excluding VDC</td>
</tr>
<tr>
<td>High-level, VIH</td>
<td></td>
<td></td>
<td>0.8</td>
<td></td>
<td>excluding VDC</td>
</tr>
<tr>
<td>OUTPUT VOLTAGE LEVELS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low-level, VIL</td>
<td></td>
<td></td>
<td>2.4</td>
<td></td>
<td>excluding VDC</td>
</tr>
<tr>
<td>High-level, VIH</td>
<td></td>
<td></td>
<td>0.4</td>
<td></td>
<td>excluding VDC</td>
</tr>
<tr>
<td>INPUT CURRENT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Leakage, IL (Except CLOCK)</td>
<td>10</td>
<td></td>
<td></td>
<td>µA</td>
<td>0 ≤ Vih ≤ Vcc</td>
</tr>
<tr>
<td>Leakage, IC (CLOCK Only)</td>
<td>50</td>
<td></td>
<td></td>
<td>µA</td>
<td>0 ≤ Vin ≤ Vcc</td>
</tr>
<tr>
<td>INPUT CAPACITANCE</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data</td>
<td>10</td>
<td></td>
<td></td>
<td>pF</td>
<td>@ 1 MHz</td>
</tr>
<tr>
<td>LD/SH</td>
<td>20</td>
<td></td>
<td></td>
<td>pF</td>
<td>@ 1 MHz</td>
</tr>
<tr>
<td>CLOCK</td>
<td>25</td>
<td></td>
<td></td>
<td>pF</td>
<td>@ 1 MHz</td>
</tr>
<tr>
<td>POWER SUPPLY CURRENT</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ICC</td>
<td>100</td>
<td></td>
<td></td>
<td>mA</td>
<td></td>
</tr>
</tbody>
</table>

A.C. CHARACTERISTICS

See Figure 6, 7

PRELIMINARY

Symbol | Parameter | CRT 8002A | CRT 8002B | CRT 8002C | UNITS |
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>VDC</td>
<td>Video Dot Clock Frequency</td>
<td>MIN.</td>
<td>MAX.</td>
<td>MIN.</td>
<td>MAX.</td>
</tr>
<tr>
<td>PWH</td>
<td>VDC—High Time</td>
<td>1.0</td>
<td>20</td>
<td>1.0</td>
<td>15</td>
</tr>
<tr>
<td>PWL</td>
<td>VDC—Low Time</td>
<td>15.0</td>
<td>23</td>
<td>40</td>
<td>23</td>
</tr>
<tr>
<td>tCYC</td>
<td>LD/SH cycle time</td>
<td>400</td>
<td>533</td>
<td>800</td>
<td></td>
</tr>
<tr>
<td>tr, tf</td>
<td>Rise, fall time</td>
<td>10</td>
<td></td>
<td>10</td>
<td></td>
</tr>
<tr>
<td>ts, tu</td>
<td>Input set-up time</td>
<td>≦0</td>
<td></td>
<td>≦0</td>
<td></td>
</tr>
<tr>
<td>thold</td>
<td>Input hold time</td>
<td>15</td>
<td></td>
<td>15</td>
<td></td>
</tr>
<tr>
<td>tPD, tPC</td>
<td>Output propagation delay</td>
<td>15</td>
<td>50</td>
<td>15</td>
<td>65</td>
</tr>
<tr>
<td>ts1</td>
<td>LD/SH set-up time</td>
<td>15</td>
<td></td>
<td>15</td>
<td></td>
</tr>
<tr>
<td>ts2</td>
<td>LD/SH hold time</td>
<td>15</td>
<td></td>
<td>15</td>
<td></td>
</tr>
</tbody>
</table>

280 APPENDIX C
### DESCRIPTION OF PIN FUNCTIONS

<table>
<thead>
<tr>
<th>PIN NO.</th>
<th>SYMBOL</th>
<th>NAME</th>
<th>INPUT/OUTPUT</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>VIDEO</td>
<td>Video Output</td>
<td>0</td>
<td>The video output contains the data stream for the selected row of the alphanumeric, wide graphic, thin graphic, or external character after processing by the attribute logic, and the receive blank and cursor inputs. In the alphanumeric mode, the characters are ROM programmed into the 72 chips (TX11) allocated for each of the 128 available characters (A7 = X). The external mode, A8 - A9 are internally decoded to address 1 of the 128 available ROM characters. The addressed character along with the decoded row will be defined by a 7 bit output from the ROM to be loaded into the shift register via the attribute logic. The first bit serially shifted out is C7 (A zero; or one in REVID). It is followed by C6, C5, through C0. The timing of the Load/Shift pulse will determine the number of additional (— —, zero to N) backfill zeros (or ones if in REVID) shifted out. See figure 4. When the next Load/Shift pulse appears the next character's row of the ROM, via the attribute logic, is parallel loaded into the 8-bit shift-register. The first bit serially shifted out is C7 (A zero; or one in REVID). It is followed by C6, C5, through C0. The timing of the Load/Shift pulse will determine the number of additional (— —, zero to N) backfill zeros (or ones if in REVID) shifted out. See figure 4. When the next Load/Shift pulse appears the next character's row of the ROM, via the attribute logic, is parallel loaded into the shift register and the cycle repeats.</td>
</tr>
<tr>
<td>2</td>
<td>LD/SH</td>
<td>Load/Shift</td>
<td>I</td>
<td>The 8-bit shift-register parallel-in load or serial-out shift modes are established by the Load/Shift input. When low, this input enables the shift register for serial shifting with each Video Dot Clock pulse. When high, the shift register parallel (broadcast) data inputs are enabled and synchronous loading occurs on the next Video Dot Clock pulse. During parallel loading, serial data flow is inhibited. The Address/Data inputs (A8-A7) are latched on the negative transition of the Load/Shift input. See timing diagram, figure 7.</td>
</tr>
<tr>
<td>3</td>
<td>VDC</td>
<td>Video Dot Clock</td>
<td>I</td>
<td>Frequency at which video is shifted.</td>
</tr>
<tr>
<td>4-11</td>
<td>A8-A7</td>
<td>Address/Data</td>
<td>I</td>
<td>In the Alphanumeric Mode the 7 bits on inputs (A8-A6) are internally decoded to address one of the 128 available characters (A7 = X). In the External Mode, A8-A9 (used to insert an 8 bit word from a user defined external ROM, PROM or RAM into the on-chip Attribute logic. In the wide Graphic Modes A8-A7 is used to define one of 256 graphic entities. In the thin Graphic Mode A8-A2 is used to define the 3 line segments.</td>
</tr>
<tr>
<td>12</td>
<td>Vcc</td>
<td>Power Supply</td>
<td>PS</td>
<td>+5 volt power supply</td>
</tr>
<tr>
<td>13,14,15,16,17,R3,R5,R8</td>
<td>GND Ground</td>
<td>GND Ground</td>
<td>These 4 binary inputs define the row address in the current character block.</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>ATBTE</td>
<td>Attribute Enable</td>
<td>I</td>
<td>A positive level on this input enables data from the Reverse Video, Character Blank, Underline, Strike-Thru, Blink, Mode Select B, and Mode Select 1 inputs to be switched into the on-chip attribute latch at the negative transition of the Load/Shift pulse. The latch loading is disabled when this input is low. The latched attributes will remain fixed until this input becomes high again. To facilitate attribute latching on a character by character basis, tie ATBTE high. See timing diagram, figure 7.</td>
</tr>
<tr>
<td>19</td>
<td>STKRU</td>
<td>Strike-Thru</td>
<td>I</td>
<td>When this input is high and RETBL = 0, the parallel inputs to the shift register are forced segment through the character block. The operation of strike-thru is modified by Reverse Video (see table 1). In addition, an on-chip ROM programmable decoder is available to decode the line count on which strike-thru is to be placed as well as to program the strike-thru to be 1 to N raster lines high. Actually, the strike-thru decoder (mask programmable) logic allows the strike-thru to be any number or arrangement of horizontal lines in the character block. The standard strike-thru will be a double line on rows R5 and R6.</td>
</tr>
<tr>
<td>20</td>
<td>UNDLN</td>
<td>Underline</td>
<td>I</td>
<td>When this input is high and RETBL = 0, the parallel inputs to the shift register are forced high (SRB-SRT7), providing a solid line segment throughout the character block. The operation of underline is modified by Reverse Video (see table 1). In addition, an on-chip ROM programmable decoder is available to decode the line count on which underline is to be placed as well as to program the underline to be 1 to N raster lines high. Actually, the underline decoder (mask programmable) logic allows the underline to be any number or arrangement of horizontal lines in the character block. The standard underline will be a single line on row R11.</td>
</tr>
<tr>
<td>21</td>
<td>REVID</td>
<td>Reverse Video</td>
<td>I</td>
<td>When this input is low and RETBL = 0, data into the Attribute Logic is presented directly to the shift register parallel inputs. When reverse video is high data into the Attribute Logic is inverted and then presented to the shift register parallel inputs. This operation reverses the data and field video. See table 1.</td>
</tr>
<tr>
<td>22</td>
<td>CHABL</td>
<td>Character Blank</td>
<td>I</td>
<td>When this input is high, the parallel inputs to the shift register are all set low, providing a blank character line segment. Character blank will override blink. The operation of Character Blank is modified by the Reverse Video input. See table 1.</td>
</tr>
<tr>
<td>23</td>
<td>V SYNC</td>
<td>V SYNC</td>
<td>I</td>
<td>This input is used as the clock input for the two on-chip mask programmable blink rate dividers. The cursor blink rate (50/50 duty cycle) will be twice the character blink rate (75/25 duty cycle). The divisors can be programmed from +4 to +30 for the cursor (— 8 to —60 for the character).</td>
</tr>
<tr>
<td>24</td>
<td>BLINK</td>
<td>Blink</td>
<td>I</td>
<td>When this input is high and RETBL = 0 and CHABL = 0, the character will blink at the programmed character blink rate. Blinking is accomplished by blanking the character block with the Internal Character Blink clock. The standard character blink rate is 1.875Hz.</td>
</tr>
<tr>
<td>25</td>
<td>MS1</td>
<td>Mode Select 1</td>
<td>I</td>
<td>These 2 inputs define the four modes of operation of the CRT 8002 as follows: Alphanumeric Mode — In this mode the addresses A9-A8, (A7 = X) are internally decoded to address 1 of the 128 available ROM characters. The addressed character along with the decoded row will be defined by a 7 bit output from the ROM to be loaded into the shift register via the attribute logic.</td>
</tr>
<tr>
<td>26</td>
<td>MS8</td>
<td>Mode Select 2</td>
<td>I</td>
<td>Thin Graphics Mode — In this mode A9-A2, (A3-A7 = X) will be loaded into the thin graphic logic along with the row addresses. This logic will define the segments of a graphic entity as defined in figure 2. The top of the entity will begin on row 8000 and will end on a mask programmable row.</td>
</tr>
</tbody>
</table>

282 APPENDIX C
DESCRIPTION OF PIN FUNCTIONS

<table>
<thead>
<tr>
<th>PIN NO.</th>
<th>SYMBOL</th>
<th>NAME</th>
<th>INPUT/OUTPUT</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>25</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>(cont.)</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>27</td>
<td>CURSOR</td>
<td>Cursor</td>
<td>1</td>
<td>When this input is enabled 1 of the 4 pre-programmed cursor modes will be activated. The cursor mode is on-chip mask programmable. The standard cursor will be a blinking (at 37.5 Hz) reverse video block. The 4 cursor modes are: Underline—in this mode an underline (1 to N raster lines) at the programmed underline position occurs. Blinking Underline—in this mode the underline blinks at the cursor rate. Reverse Video Block—in this mode the Character Block is set to reverse video. Blinking Reverse Video Block—in this mode the Character Block is set to reverse video at the cursor blink rate. The Character Block will alternate between normal video and reverse video. The cursor functions are listed in table 1.</td>
</tr>
<tr>
<td>28</td>
<td>RETBL</td>
<td>Retrace Blank</td>
<td>1</td>
<td>When this input is latched high, the shift register parallel inputs are unconditionally cleared to all zeros and loaded into the shift register on the next Load/Shift pulse. This blanks the video, independent of all attributes, during horizontal and vertical retrace time.</td>
</tr>
</tbody>
</table>

### TABLE 1

<table>
<thead>
<tr>
<th>CURSOR</th>
<th>RETBL</th>
<th>REVID</th>
<th>CHABL</th>
<th>UNDLN*</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>1</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>&quot;0&quot;</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>D</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>D(S.R.) All others</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>&quot;0&quot;</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>D(S.R.) All others</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>Underline*</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>X</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>Underline*</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>Underline*</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>&quot;0&quot;</td>
</tr>
<tr>
<td>Underline*</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>X</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>Blinking** Underline*</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>X</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>Blinking** Underline*</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>Blinking** Underline*</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>X</td>
<td>&quot;0&quot;</td>
</tr>
<tr>
<td>Blinking** Underline*</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>X</td>
<td>&quot;0&quot;</td>
</tr>
<tr>
<td>REVID Block</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>D(S.R.) All</td>
</tr>
<tr>
<td>REVID Block</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>&quot;0&quot;</td>
</tr>
<tr>
<td>REVID Block</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>X</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>REVID Block</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>D(S.R.) All others</td>
</tr>
<tr>
<td>REVID Block</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>X</td>
<td>&quot;1&quot;</td>
</tr>
<tr>
<td>REVID Block</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>X</td>
<td>&quot;0&quot;</td>
</tr>
<tr>
<td>Blink** REVID Block</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Alternate Normal Video/REVID At Cursor Blink Rate</td>
</tr>
<tr>
<td>Blink** REVID Block</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>Blink** REVID Block</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>Blink** REVID Block</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>X</td>
<td></td>
</tr>
</tbody>
</table>

*At Selected Row Decode  **At Cursor Blink Rate

Note: If Character is Blinking at Character Rate, Cursor will change it to Cursor Blink Rate.
FIGURE 5
ROM CHARACTER BLOCK FORMAT

(ALL ZEROS) →

0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0

77 BITS (7 x 11 ROM)

0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0

(ALL ZEROS)

0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0

*COLUMN 7 IS ALL ZEROS (REVID = 0)
COLUMN 7 IS SHIFTED OUT FIRST

ROWS | R3 | R2 | R1 | R0
-----|----|----|----|----
0    | 0  | 0  | 0  | 0  
0    | 0  | 0  | 0  | 0  
0    | 0  | 0  | 0  | 0  
0    | 0  | 0  | 0  | 0  
0    | 0  | 0  | 0  | 0  
0    | 0  | 0  | 0  | 0  
0    | 0  | 0  | 0  | 0  
0    | 0  | 0  | 0  | 0  

*EXTENDED ZEROS (BACK FILL) FOR INTERCHARACTER SPACING (NUMBER CONTROLLED BY LD/SH, VCC TIMING)

CONSULT FACTORY FOR CUSTOM FONT AND OPTION PROGRAMMING FORMS.
Appendix C10

Baud Rate Generator
Programmable Divider

FEATURES
☐ On chip crystal oscillator or external frequency input
☐ Single +5v power supply
☐ Choice of 32 output frequencies
☐ 32 asynchronous/synchronous baud rates
☐ Direct UART/USRT/ASTRO/USYNRT compatibility
☐ Re-programmable ROM via CLASP® technology allows generation of other frequencies
☐ TTL, MOS compatible
☐ 1X Clock via fo/16 output
☐ Crystal frequency output via fx and fx/4 outputs
☐ Output disable via FENA

PIN CONFIGURATION

<table>
<thead>
<tr>
<th>PIN</th>
<th>DESCRIPTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>16 fo</td>
</tr>
<tr>
<td>2</td>
<td>15 A</td>
</tr>
<tr>
<td>3</td>
<td>14 B</td>
</tr>
<tr>
<td>4</td>
<td>13 C</td>
</tr>
<tr>
<td>5</td>
<td>12 D</td>
</tr>
<tr>
<td>6</td>
<td>11 ST</td>
</tr>
<tr>
<td>7</td>
<td>10 fx/4</td>
</tr>
<tr>
<td>8</td>
<td>9 NC</td>
</tr>
<tr>
<td>9</td>
<td>NC</td>
</tr>
</tbody>
</table>

BLOCK DIAGRAM

Reprinted by permission of SMC Microsystems Corporation Copyright © 1980

APPENDIX C 287
General Description

The Standard Microsystems COM 8048 is an enhanced version of the COM 5046 Baud Rate Generator. It is fabricated using SMC’s patented COPLAMOS® and CLASP® technologies and employs depletion mode loads, allowing operation from a single +5V supply.

The standard COM 8046 is specifically dedicated to generating the full spectrum of 16 asynchronous/synchronous data communication frequencies for 1X, 16X and 32X UART/USRT/ASTRO/USYNRT devices.

The COM 8046 features an internal crystal oscillator which may be used to provide the master reference frequency. Alternatively, an external reference may be supplied by applying complementary TTL level signals to pins 1 and 2. Parts suitable for use only with an external TTL reference are marked COM 8046T. TTL outputs used to drive the COM 8046 or COM 8046T should not be used to drive other TTL inputs, as noise immunity may be compromised due to excessive loading.

The reference frequency (fx) is used to provide two high frequency outputs: one at fx and the other at fx/4. The fx/4 output will drive one standard 7400 load, while the fx output will drive two 74LS loads.

The output of the oscillator/buffer is applied to the divider for generation of the output frequency fo. The divider is capable of dividing by any integer from 6 to 2^16 + 1, inclusive. If the divisor is even, the output will be square; otherwise the output will be high longer than it is low by one fx clock period. The output of the divider is also divided internally by 16 and made available at the fo/16 output pin. The fo/16 output will drive one and the fo output will drive two standard 7400 TTL loads. Both the fo and fo/16 outputs can be disabled by supplying a low logic level to the FENA input pin. Note that the FENA input has an internal pull-up which will cause the pin to rise to approximately VCC if left unconnected.

The divisor ROM contains 32 divisors, each 19 bits wide, and is fabricated using SMC’s unique CLASP® technology. This process permits reduction of turn-around-time for ROM patterns.

The five divisor select bits are held in an externally strobed data latch. The strobe input is level sensitive; while the strobe is high, data is passed directly through to the ROM. Initiation of a new frequency is effected within 3.5μs of a change in any of the five divisor select bits; strobe activity is not required. This feature may be disabled through a CLASP® programming option causing new frequency initiation to be delayed until the end of the current fo half-cycle. All five data inputs have pull-ups identical to that of the FENA input, while the strobe input has no pull-up.

### Description of Pin Functions

<table>
<thead>
<tr>
<th>Pin No.</th>
<th>Symbol</th>
<th>Name</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>XTAL/EXT1</td>
<td>Crystal or External Input 1</td>
<td>This input is either one pin of the crystal package or one polarity of the external input.</td>
</tr>
<tr>
<td>2</td>
<td>XTAL/EXT2</td>
<td>Crystal or External Input 2</td>
<td>This input is either the other pin of the crystal package or the other polarity of the external input.</td>
</tr>
<tr>
<td>3</td>
<td>VCC</td>
<td>Power Supply</td>
<td>+5 volt supply</td>
</tr>
<tr>
<td>4</td>
<td>fo</td>
<td>Ground</td>
<td>Crystal/clock frequency reference output</td>
</tr>
<tr>
<td>5</td>
<td>GND</td>
<td>Ground</td>
<td>1X clock output</td>
</tr>
<tr>
<td>6</td>
<td>fo/16</td>
<td>fo/16</td>
<td>A low level at this input causes the fo and fo/16 outputs to be held high. An open or a high level at the FENA input enables the fo and fo/16 outputs.</td>
</tr>
<tr>
<td>7</td>
<td>FENA</td>
<td>Enable</td>
<td>Most significant divisor select data bit. An open at this input is equivalent to a logic high.</td>
</tr>
<tr>
<td>8</td>
<td>E</td>
<td>E</td>
<td>No connection</td>
</tr>
<tr>
<td>9</td>
<td>NC</td>
<td>NC</td>
<td>¼ crystal/clock frequency reference output</td>
</tr>
<tr>
<td>10</td>
<td>fo/4</td>
<td>fo/4</td>
<td>Divisor select data strobe. Data is sampled when this input is high, preserved when this input is low.</td>
</tr>
<tr>
<td>11</td>
<td>ST</td>
<td>Strobe</td>
<td>Divisor select data bits. A = LSB. An open circuit at these inputs is equivalent to a logic high.</td>
</tr>
<tr>
<td>12-15</td>
<td>D,C,B,A</td>
<td>D,C,B,A</td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>fo</td>
<td>fo</td>
<td>16X clock output</td>
</tr>
</tbody>
</table>
ELECTRICAL CHARACTERISTICS COM8046, COM8046T, COM8116, COM8116T, COM8126, COM8126T, COM8136, COM8136T, COM8146, COM8146T

MAXIMUM GUARANTEED RATINGS*

- Operating Temperature Range: 0°C to +70°C
- Storage Temperature Range: -55°C to +150°C
- Lead Temperature (soldering, 10 sec.): +325°C
- Positive Voltage on any Pin, with respect to ground: +8.0V
- Negative Voltage on any Pin, with respect to ground: -0.3V

*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or “glitches” on their outputs when the AC power is switched on and off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

ELECTRICAL CHARACTERISTICS (T_A = 0°C to 70°C, VCC = +5V ±5%, unless otherwise noted)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>D.C. CHARACTERISTICS</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>INPUT VOLTAGE LEVELS</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low-level, V_in</td>
<td>2.0</td>
<td>0.8</td>
<td>V</td>
<td></td>
<td>excluding XTAL inputs</td>
</tr>
<tr>
<td>High-level, V_in</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>OUTPUT VOLTAGE LEVELS</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Low-level, V_out</td>
<td>0.4</td>
<td>0.4</td>
<td>V</td>
<td>1.6mA</td>
<td>for f_C/4, f_C/16</td>
</tr>
<tr>
<td>High-level, V_out</td>
<td>3.5</td>
<td></td>
<td></td>
<td>-0.1</td>
<td>mA</td>
</tr>
<tr>
<td><strong>INPUT CURRENT</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>All inputs, I_in</td>
<td>5</td>
<td>10</td>
<td>pF</td>
<td></td>
<td>V_in = GND, excluding XTAL inputs</td>
</tr>
<tr>
<td><strong>INPUT CAPACITANCE</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>All inputs, C_in</td>
<td>8</td>
<td>10</td>
<td>pF</td>
<td></td>
<td>Series 7400 equivalent loads</td>
</tr>
<tr>
<td><strong>EXT INPUT LOAD</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>POWER SUPPLY CURRENT</strong></td>
<td>50</td>
<td></td>
<td></td>
<td>mA</td>
<td></td>
</tr>
<tr>
<td><strong>A.C. CHARACTERISTICS</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td><strong>CLOCK FREQUENCY, f_C</strong></td>
<td>0.01</td>
<td>7.0</td>
<td>MHz</td>
<td></td>
<td>T_A = ±25°C</td>
</tr>
<tr>
<td><strong>STROBE PULSE WIDTH, t_s</strong></td>
<td>150</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td><strong>INPUT SET-UP TIME</strong></td>
<td>200</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td><strong>INPUT HOLD TIME</strong></td>
<td>50</td>
<td></td>
<td></td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td><strong>STROBE TO NEW FREQUENCY DELAY</strong></td>
<td>3.5</td>
<td></td>
<td></td>
<td>μs</td>
<td>@ f_C = 5.0 MHz</td>
</tr>
</tbody>
</table>

**TIMING DIAGRAM**

- V_in: Strobe
- V_out: Data
- t_s: Strobe pulse width
- t_C: Strobe to new frequency delay

APPENDIX C 289
For ROM re-programming SMC has a computer program available whereby the customer need only supply the input frequency and the desired output frequencies. The ROM programming is automatically generated.

Crystal Specifications
User must specify termination (in, wire, other)
Prefer: HC-18/U or HC-25/U
Frequency — 5.0688 MHz AT cut
Temperature range 0 C to 70 C
Series resistance 50 Ω
Series Resonant
Overall tolerance ± 0.1% or as required

Crystal manufacturers (Partial List)
Northern Engineering Laboratories
357 Beloit Street
Burlington, Wisconsin 53105
(414) 763-3591
Bulova Frequency Control Products
61-20 Woodside Avenue
Woodside, New York 11377
(212) 335-6000
CTS Knights Inc.
101 East Church Street
Sandwich, Illinois 60548
(815) 786-8411
Crystek Crystals Corporation
1000 Crystal Drive
Fort Myers, Florida 33901
(813) 936-2109
## Table 2
### Reference Frequency = 5.068800 MHz

<table>
<thead>
<tr>
<th>Select</th>
<th>Desired Baud Rate</th>
<th>Desired Clock Factor</th>
<th>Desired Frequency (KHz)</th>
<th>Divisor</th>
<th>Actual Baud Rate</th>
<th>Actual Frequency (KHz)</th>
<th>Deviation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000</td>
<td>50.00</td>
<td>32X</td>
<td>1.60000</td>
<td>3168</td>
<td>50.00</td>
<td>1.60000</td>
<td>0.0000*</td>
</tr>
<tr>
<td>0001</td>
<td>75.00</td>
<td>32X</td>
<td>2.40000</td>
<td>2112</td>
<td>75.00</td>
<td>2.40000</td>
<td>0.0000*</td>
</tr>
<tr>
<td>0010</td>
<td>110.00</td>
<td>32X</td>
<td>3.20000</td>
<td>1440</td>
<td>110.00</td>
<td>3.20000</td>
<td>0.0000*</td>
</tr>
<tr>
<td>0011</td>
<td>134.50</td>
<td>32X</td>
<td>4.00000</td>
<td>1177</td>
<td>134.50</td>
<td>4.00000</td>
<td>0.0591%</td>
</tr>
<tr>
<td>0010</td>
<td>150.00</td>
<td>32X</td>
<td>4.80000</td>
<td>1056</td>
<td>150.00</td>
<td>4.80000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0011</td>
<td>200.00</td>
<td>32X</td>
<td>6.00000</td>
<td>792</td>
<td>200.00</td>
<td>6.00000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0010</td>
<td>300.00</td>
<td>32X</td>
<td>9.00000</td>
<td>528</td>
<td>300.00</td>
<td>9.00000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0011</td>
<td>600.00</td>
<td>32X</td>
<td>19.20000</td>
<td>264</td>
<td>600.00</td>
<td>19.20000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0100</td>
<td>1200.00</td>
<td>32X</td>
<td>38.40000</td>
<td>132</td>
<td>1200.00</td>
<td>38.40000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0101</td>
<td>1800.00</td>
<td>32X</td>
<td>57.60000</td>
<td>88</td>
<td>1800.00</td>
<td>57.60000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0110</td>
<td>2400.00</td>
<td>32X</td>
<td>76.80000</td>
<td>66</td>
<td>2400.00</td>
<td>76.80000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0111</td>
<td>3600.00</td>
<td>32X</td>
<td>115.20000</td>
<td>44</td>
<td>3600.00</td>
<td>115.20000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0110</td>
<td>4800.00</td>
<td>32X</td>
<td>153.60000</td>
<td>33</td>
<td>4800.00</td>
<td>153.60000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0111</td>
<td>7200.00</td>
<td>32X</td>
<td>230.40000</td>
<td>22</td>
<td>7200.00</td>
<td>230.40000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0110</td>
<td>9600.00</td>
<td>32X</td>
<td>345.60000</td>
<td>16</td>
<td>9600.00</td>
<td>345.60000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>0111</td>
<td>19200.00</td>
<td>32X</td>
<td>691.20000</td>
<td>8</td>
<td>19200.00</td>
<td>691.20000</td>
<td>3.1250%</td>
</tr>
<tr>
<td>1010</td>
<td>50.00</td>
<td>16X</td>
<td>0.80000</td>
<td>6336</td>
<td>50.00</td>
<td>8000000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1011</td>
<td>75.00</td>
<td>16X</td>
<td>1.20000</td>
<td>4224</td>
<td>75.00</td>
<td>1.20000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1100</td>
<td>110.00</td>
<td>16X</td>
<td>1.76000</td>
<td>2880</td>
<td>110.00</td>
<td>1.76000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1101</td>
<td>134.50</td>
<td>16X</td>
<td>2.56000</td>
<td>2355</td>
<td>134.50</td>
<td>2.56000</td>
<td>0.0166%</td>
</tr>
<tr>
<td>1110</td>
<td>150.00</td>
<td>16X</td>
<td>2.70000</td>
<td>2112</td>
<td>150.00</td>
<td>2.70000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1111</td>
<td>300.00</td>
<td>16X</td>
<td>5.40000</td>
<td>1056</td>
<td>300.00</td>
<td>5.40000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1010</td>
<td>600.00</td>
<td>16X</td>
<td>9.60000</td>
<td>528</td>
<td>600.00</td>
<td>9.60000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1011</td>
<td>1200.00</td>
<td>16X</td>
<td>19.20000</td>
<td>264</td>
<td>1200.00</td>
<td>19.20000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1100</td>
<td>1800.00</td>
<td>16X</td>
<td>28.80000</td>
<td>176</td>
<td>1800.00</td>
<td>28.80000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1101</td>
<td>2400.00</td>
<td>16X</td>
<td>38.40000</td>
<td>132</td>
<td>2400.00</td>
<td>38.40000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1110</td>
<td>3600.00</td>
<td>16X</td>
<td>57.60000</td>
<td>88</td>
<td>3600.00</td>
<td>57.60000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1111</td>
<td>4800.00</td>
<td>16X</td>
<td>76.80000</td>
<td>66</td>
<td>4800.00</td>
<td>76.80000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1110</td>
<td>7200.00</td>
<td>16X</td>
<td>115.20000</td>
<td>44</td>
<td>7200.00</td>
<td>115.20000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1111</td>
<td>9600.00</td>
<td>16X</td>
<td>153.60000</td>
<td>33</td>
<td>9600.00</td>
<td>153.60000</td>
<td>0.0000%</td>
</tr>
<tr>
<td>1111</td>
<td>19200.00</td>
<td>16X</td>
<td>307.20000</td>
<td>16</td>
<td>19200.00</td>
<td>307.20000</td>
<td>3.1250%</td>
</tr>
</tbody>
</table>
Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.
Appendix D

ZAP Operating System

FILE 3000 7323
READY
ASSH

7324  0100 *
7324  0110 *
7324  0120 *THE FOLLOWING EQUATES ARE USED
7324  0130 *AS OPERATING SYSTEM CONSTANTS
7324  0140 *
7324  0150 ZERO EQU 0
7324  0160 ONE EQU 1
7324  0170 TWO EQU 2
7324  0180 THREE EQU 3
7324  0190 FOUR EQU 4
7324  0200 FIVE EQU 5
7324  0210 EIGHT EQU 8D
7324  0220 ADDIS1 EQU 5  *MSDS ADDRESS DISPLAY PORT
7324  0230 ADDIS2 EQU 6  *LSDS ADDRESS DISPLAY PORT
7324  0240 DATDIS EQU 7  *DATA DISPLAY PORT
7324  0250 EXECC EQU 16D  *EXEC KEY
7324  0260 NEXTC EQU 32D  *NEXT KEY
7324  0270 UARTIO EQU 2  *UART I/O PORT
7324  0280 UARTST EQU 3  *UART STATUS PORT
7324  0290 KEYPT EQU 0  *KEYBOARD INPUT PORT
7324  0300 *
7324  0310 *
0000  0320 ST 0
0000  0330 *
0000  0340 *
0000  0350 *COLD SETS THE OPERATING SYSTEM STACK POINTER
0000  0360 *AND ENTERS THE COMMAND RECOGNITION MODULE
0000  0370 *
0000  0380 *
0000  0390 COLD LD SP,SPSTRT *INITIALIZE STACK POINTER
0003  0400 JP WARM01
0006  0410 DS 2
0008  0420 WARM JP WARM01 *RST 1 OR WARM START
000B  0430 DS 5
0010  0440 RST2E JP RST2V *RST 2 TRANSFER
0013  0450 DS 5
0018  0460 RST3E JP RST3V *RST 3 TRANSFER
001B  0470 DS 5
0020  0480 RST4E JP RST4V *RST 4 TRANSFER
0023  0490 DS 5
0028  0500 RST5E JP RST5V *RST 5 TRANSFER
002B  0510 DS 5
0030  0520 RST6E JP RST6V *RST 6 TRANSFER
0033  0530 DS 5
0038  0540 RST7E JP RST7V *RST 7 TRANSFER
003B  0550 DS 5
0040 ED 73 DB 07 0551 WARM01 LD (SPSLAV),SP

APPENDIX D 295
**0044 C3 89 00 0552 JP WARM2 *GO TO COMMAND RECOGNITION**

**0047 0560 **
**0047 0570 **
**0047 0580 **
**0047 0590 **WARM START SAVES THE USERS REGISTERS AND D
**0047 0600 **ENTERS THE COMMAND RECOGNITION MODE WITH
**0047 0610 **FS DISPLAYED ON THE DATA AND ADDRESS DISPLAYS
**0047 0620 **

**0047 32 E3 07 0630 WARM1 LD (ASAV),A *SAVE USERS A**

**004A E1 0640 POP HL *GET USERS PC FROM STACK**

**004B 22 DD 07 0650 LD (PCLSAV),H*L SAVE USERS PC IN SAVE AREA**

**004E F5 0660 PUSH AF**

**004F E1 0670 POP HL *GET USERS FLAGS**

**0050 22 E7 07 0680 LD (ESAV),H*L SAVE USERS FLAGS**

**0053 DD 22 D7 07 0690 LD (IXLSAV),IX *SAVE USERS IX**

**0057 FD 22 D9 07 0700 LD (IYLSAV),IY *SAVE USERS IY**

**005B ED 73 DB 07 0710 LD (SPLSAV),SP *SAVE USERS SP**

**005F ED 57 0720 LD A,I *SAVE USERS I**

**0061 32 DF 07 0730 LD (ISAV),A *SAVE USERS R**

**0066 32 E0 07 0750 LD (RSAV),A**

**0069 21 E4 07 0760 LD HL,BSAV**

**006C 70 0770 LD (HL),B *SAVE USERS B**

**006D 23 0780 INC HL**

**006E 71 0790 LD (HL),C *SAVE USERS C**

**006F 23 0800 INC HL**

**0070 72 0810 LD (HL),D *SAVE USERS D**

**0071 23 0820 INC HL**

**0072 73 0830 LD (HL),E *SAVE USERS E**

**0073 08 0840 EX AF,AF *SAVE ALTERNATE REGISTERS**

**0074 F5 0850 PUSH AF**

**0075 32 EB 07 0860 LD (AASAV),A *SAVE ALT A**

**0076 22 E9 07 0870 LD (ALSAC),HL *SAVE ALT H&L**

**0076 E1 0880 POP HL**

**007C 22 EF 07 0890 LD (AESAV),HL *SAVE ALT FLAGS**

**007F 21 EC 07 0900 LD HL,BSAV**

**0082 70 0910 LD (HL),B *SAVE ALT B**

**0083 23 0920 INC HL**

**0084 71 0930 LD (HL),C *SAVE ALT C**

**0085 23 0940 INC HL**

**0086 72 0950 LD (HL),D *SAVE ALT D**

**0087 23 0960 INC HL**

**0088 73 0970 LD (HL),E *SAVE ALT E**

**0089 0880 **

**0089 0990 **

**0089 1000 **COMMAND RECOGNITION MODULE
**0089 1010 **

**0089 CD F1 00 1020 WARM2 CALL CLDIS *CLEAR DISPLAY**

**008C 3E FF 1030 LD A,255D *DISPLAY FFFF FF**

**008E D3 05 1040 OUT ADDIS**

**0090 D3 06 1050 OUT ADDIS2**

**0092 D3 07 1060 OUT DATDIS**

**0094 CD 03 01 1070 CALL KEYIN *GET INPUT CHARACTER**

**0097 06 40 1080 LD B,mem**

**0099 BB 1090 CP B**

**009A CA F1 01 1100 JP Z,MEMORY *JUMP IF MEMORY REQUEST**

**009D 04 1110 INC B**

**009E BB 1120 CP B**

**009F CA 4B 02 1130 JP Z,REGIST *JUMP IF REGISTER REQUEST**

**00A2 04 1140 INC B**

**00A3 BB 1150 CP B**

**00A4 CA 10 03 1160 JP Z,GOREQ**

**00A7 C3 89 00 1170 JP WARM2**

**00AA 1180 **

**00AA 1190 MEM EQU 64D *MEMORY KEY**

**00AA 1200 **

**00AA 1210 **

**00AA 1220 **RESTART RESTORES THE USERS REGISTERS

**00AA 1230 **AND RETURNS CONTROL TO THE ADDRESS**
00AA 1240 *SPECIFIED IN THE PC SAVE LOCATION IN THE
00AA 1250 *REGISTER SAVE AREA
00AA 1260 *
00AA 3A EC 07 1270 RESTR T LD A,(ABS A) *RESTORE ALT REGISTERS
00AD 47 1280 LD B,A
00AE 3A ED 07 1290 LD A,(ACSAV)
00B1 4F 1300 LD C,A
00B2 3A EE 07 1310 LD A,(ABS A)
00B5 57 1320 LD D,A
00B6 3A EF 07 1330 LD A,(AESAV)
00B9 5F 1340 LD E,A
00BA 3A F0 07 1350 LD A,(AFSAV)
00BD 6F 1360 LD H,A
00BE E5 1370 PUSH HL
00BF F1 1380 POP AF
00C0 3A EB 07 1390 LD A,(AASAV)
00C3 2A E9 07 1400 LD HL,(ALSAV)
00C6 B9 1410 EXX
00C7 FD 2A D9 07 1420 LD IY,(IYLSAV) *RESTORE IY
00CB DD 2A D7 07 1430 LD IX,(IXLSAV) *RESTORE IX
00CF 21 DF 07 1440 LD HL,ISAV
00D2 7E 1450 LD A,(HL)
00D3 ED 47 1460 LD I,A
00D5 23 1470 INC HL
00D6 7E 1480 LD A,(HL)
00D7 ED 4F 1490 LD R,A
00D9 21 E3 07 1500 LD HL,ASAV
00DC 7E 1510 LD A,(HL) *RESTORE A
00DD 23 1520 INC HL
00DE 46 1530 LD B,(HL) *RESTORE B
00DF 23 1540 INC HL
00E0 4E 1550 LD C,(HL) *RESTORE C
00E1 23 1560 INC HL
00E2 56 1570 LD D,(HL) *RESTORE D
00E3 23 1580 INC HL
00E4 5E 1590 LD E,(HL) *RESTORE E
00E5 ED 7B DB 07 1600 LD SP,(SPLSAV) *RESTORE STACK POINTER
00E9 2A DD 07 1610 LD HL,(PCLSAV) *REPLACE PC ON STACK
00EC E5 1620 PUSH HL
00ED 2A E1 07 1630 LD HL,(LSAV) *RESTORE H&L
00F0 C9 1640 RET *RETURN TO USER
00F1 1650 *
00F1 1660 **
00F1 1670 *
00F1 1680 *CLDIS CLEAR THE DATA AND ADDRESS DISPLAYS
00F1 1690 *SETS THE KEYBOARD BUFFER=0 AND clears the
00F1 1700 *KEYBOARD FLAGS
00F1 1710 *
00F1 3E 00 1720 CLDIS LD A,ZERO *CLEAR FLAGS
00F3 32 F1 07 1730 LD (KFLAGS),A
00F6 32 F2 07 1740 LD (KDATA1),A *CLEAR BUFFER
00F9 32 F3 07 1750 LD (KDATA2),A
00FC D3 07 1760 OUT DATDIS *CLEAR DATA FIELD DISPLAY
00FE D3 05 1770 OUT ADDIS1 *CLEAR ADDRESS FIELD DISPLAY
0100 D3 06 1780 OUT ADDIS2
0102 C9 1790 RET
0103 1800 *
0103 1810 *
0103 1820 *KEYIN WAITS FOR INPUT FROM THE KEYBOARD
0103 1830 *UPON DETECTING DATA AT THE INPUT PORT (0)
0103 1840 *VIA THE STROBE BIT (7) BEING SET THE DATA
0103 1850 *IS INPUT, THE STROBE BIT CLEARED, AND THE INPUT
0103 1860 *CHARACTER IS RETURNED TO THE USER IN A
0103 1870 *
0103 1880 *
0103 DB 00 1890 KEYIN IN KEYP INPUT DATA
0105 CB 7F 1900 BIT 7,A
0107 CA 03 01 1910 JP Z,KEYIN *LOOP IF NO DATA
010A 32 F4 07 1911 LD (TEMP),A *SAVE CHARACTER

APPENDIX D 297
**O10D DB 00** 1912 KEYIN1 IN KEYPT
**O10F CB 7F** 1913 BIT 7\*A
**O111 C2 0D 01** 1914 JP NZ,KEYIN1 *JUMP IF STROBE PRESENT
**O114 3A F4 07** 1915 LB A,(TEMP)
**O117 CB BF** 1920 RES 7\*A *CLEAR STROBE
**O119 C9** 1930 RET

**O11A 1940 \***
**O11A 1950 \***
**O11A 1960 **KFLG02 SETS THE NEXT(0) AD NO DATA(2) KEYBOARD FLAGS**
**O11A 1970 \***
**O11A 1980 \***
**O11A 21 F1 07** 1990 KFLG02 LD HL,KFLAGS
**O11D CB C6** 2000 SET 0,(HL) *SET NEXT FLAG
**O11F CB D6** 2010 SET 2,(HL)
**O121 E1** 2020 POP HL *CLEAR RETURN
**O122 C9** 2030 RET
**O123** 2040 \*
**O123 2050 \***
**O123 2060 **KFLG0 SETS THE NEXT(0) KEYBOARD FLAG**
**O123 2070 \***
**O123 2080 \***
**O123 21 F1 07** 2090 KFLG0 LD HL,KFLAGS
**O126 CB C6** 2100 SET 0,(HL) *SET NEXT FLAG
**O128 E1** 2110 POP HL *CLEAR RETURN
**O129 C9** 2120 RET
**O12A 2130 \***
**O12A 2140 \***
**O12A 2150 **KFLG12 SETS THE EXEC(1) AND NO DATA(2) KEYBOARD FLAG**
**O12A 2160 \***
**O12A 2170 \***
**O12A 2180 KFLG12 LD HL,KFLAGS**
**O12D CB CE** 2190 SET 1,(HL)
**O12F CB D6** 2200 SET 2,(HL)
**O131 E1** 2210 POP HL *CLEAR RETURN
**O132 C9** 2220 RET
**O133** 2230 \*
**O133 2240 \***
**O133 2250 **KFLG1 SETS THE EXEC(1) KEYBOARD FLAG**
**O133 2260 \***
**O133 2270 \***
**O133 2280 KFLG1 LD HL,KFLAGS**
**O136 CB CE** 2290 SET 1,(HL) *SET EXEC FLAG
**O138 E1** 2300 POP HL *CLEAR RETURN
**O139 C9** 2310 RET
**O13A** 2320 \*
**O13A 2330 \***
**O13A 2340 \***
**O13A 2350 **ONECAR INPUTS ONE CHARACTER FOLLOWED BY A NEXT OR EXEC**
**O13A 2360 **FROM THE KEYBOARD, VALIDATES IT, AND RETURNS IT TO**
**O13A 2370 \*THE USER IN KDATA2**
**O13A 2380 \***
**O13A 2390 \***
**O13A CD F1 00** 2400 ONECAR CALL CLDIS *CLEAR DISPLAY, BUFFER, &FLAGS
**O13D CD 03 01** 2410 CALL KEYIN *GET CHARACTER
**O140 D3 07** 2420 OUT DATDIS *DISPLAY CHARACTER
**O142 CD 5D 01** 2430 CALL CARCK1 *CHECK CHARACTER
**O145 CB 77** 2440 BIT 6,A
**O147 C2 51 01** 2450 JP NZ,ONECA1 *JUMP IF SHIFT
**O14A D6 10** 2460 SUB 16D *CHARACTER=0-F
**O14C F2 3A 01** 2470 JP P,ONECAR *JUMP IF NOT 0-F
**O14F CB 10** 2480 ADD 16D
**O151 32 F3 07** 2490 ONECA1 LD (KDATA2),A *SAVE CHARACTER
**O154 CD 03 01** 2500 CALL KEYIN *GET NEXT CHARACTER
**O157 CD 6A 01** 2510 CALL CARCK2
**O15A C3 51 01** 2520 JP ONECA1 *GO DO AGAIN NOT EXEC OR NEXT
**O15D 2530 \***
**O15D 2540 \***
**O15D 2550 **CARCK1 CHECKS FOR A NEXT OR EXEC ON AN INITIAL**
**O15D 2560 \*CHARACTER, IF NEXT THE ROUTINE RETURNS TO CALLER VIA**
2570 *KFLG02* IF EXEC THE ROUTINE RETURNS TO THE CALLER
2580 *VIA KFLG12
2590 *
2600 *
2610 CARCK1 LD B,NEXC *CHECK FOR NEXT
2620 CP B
2630 JP Z,KFLG02 *IF NEXT JUMP
2640 LD B,EXEC C *CHECK FOR EXEC
2650 CP B
2660 JP Z,KFLG12 *IF EXEC JUMP
2670 RET *ELSE RETURN
2680 *
2690 *
2700 *CARCK2 CHECKS FOR NEXT OR EXEC, SETS THE PROPER
2710 *FLAG VIA KFLG0 OR KFLG1 AND RETURNS TO THE USER
2720 *IF NOT NEXT OR EXEC THE ROUTINE RETURNS TO
2730 *THE ORIGINATOR OF THE REQUEST
2740 *
2750 *
2760 CARCK2 LD B,NEXC *CHECK FOR NEXT
2770 CP B
2780 JP Z,KFLG0 *IF NEXT JUMP
2790 LD B,EXEC C *CHECK FOR EXEC
2800 CP B
2810 JP Z,KFLG1
2820 RET
2830 *
2840 *
2850 *TWOCAR INPUTS 2 CHARACTERS FROM THE KEYBOARD
2860 *FOLLOWED BY A NEXT OR EXEC AND RETURNS THEM TO THE
2870 *USER IN KDATA2
2880 *
2890 *
2900 TWOCAR CALL CLDAT *CLEAR BUFFER,FLAGS, AND DISPLAY
2910 CALL KEYIN *GET CHARACTER
2920 CAL CARCK1 *CHECK FOR NEXT OR EXEC
2930 *
2940 TWODA1 SUB 16D *CHARACTER=0-F
2950 JP P,TWOCAR *JUMP IF NOT 0-F
2960 ADD 16D
2970 LD HL,KDATA2
2980 LD B,(HL) *GET OLD DATA
2990 RLC B
3000 RLC B
3010 RLC B
3020 RLC B
3030 ADD A,B *A=OLD&NEW
3040 OUT DATDIS *DISPLAY INPUT
3050 LD (HL),A *SAVE NEW DATA
3060 CALL KEYIN *GET NEXT CHARACTER
3070 CALL CARCK2 *CHECK FOR TERMINATION
3080 JP TWODA1 *JUMP IF NO TERMINATION
3090 *
3100 *CLDAT CLEARS THE INPUT BUFFER, FLAGS, AND DATA DIS
3110 *
3120 *
3130 CLDAT LD A,ZERO
3140 LD (KFLAGS),A *CLEAR FLAGS
3150 LD (KDATA2),A *CLEAR BUFFER
3160 LD (KDATA1),A
3170 RET
3180 *
3190 *
3200 *
3210 *FORCAR INPUTS FOUR CHARACTERS FROM THE KEYBOARD
3220 *FOLLOWED BY A NEXT OR EXEC AND RETURNS THEM
3230 * TO THE USER IN KDATA1 AND KDATA2
01B3 3240 *
01B3 3250 *
01B3 CD A0 01 3260 FORCAR CALL CLDAT * CLEAR FLAGS AND BUFFER
01B6 CD 03 01 3270 CALL KEYIN * GET INPUT CHARACTER
01B9 CD 5D 01 3280 CALL CARCK1 * CHECK FOR NEXT OR EXEC
01BC B6 10 3290 FORCA1 SUB 16D * CHARACTER=0-F
01BE F2 B3 01 3300 JP P+FORCAR * JUMP IF NOT 0-F
01C1 C6 10 3310 ADD 16D
01C3 32 F4 07 3320 LD (TEMP)+A * SAVE CHARACTER
01C6 3A F2 07 3330 LD A,(KDATA1) * A=MSD
01C9 21 F3 07 3340 LD HL,KDATA2
01CC ED 67 3350 RRD * ADJUST DATA FOR NEW CHARACTER
01CE 07 3360 RLCA
01CF 07 3370 RLCA
01D0 07 3380 RLCA
01D1 07 3390 RLCA
01D2 E6 F0 3400 AND 240D * MASK OFF OLD IDGIT
01D4 21 F4 07 3410 LD HL,TEMP
01D7 B6 3420 ADD A,(HL) * ADD IN NEW DIGIT
01DB 2A F3 07 3430 LD HL,(KDATA2) * SAVE NEW LSDS
01DB 22 F2 07 3440 LD (KDATA1)+HL * SAVE NEW MSDS
01DE 32 F3 07 3450 LD (KDATA2)+A * SAVE NEW MSDS
01E1 D3 06 3460 OUT ADDIS2 * DISPLAY LSDS
01E3 3A F2 07 3470 LD A,(KDATA1)
01E6 D3 05 3480 OUT ADDIS1
01EB CD 03 01 3490 CALL KEYIN * GET NEXT CHARACTER
01EB CD 6A 01 3500 CALL CARCK2 * CHECK FOR NEXT OR EXEC
01EE C3 BC 01 3510 JP FORCA1 * JUMP IF NOT NEXT OR EXEC
01F1 3520 *
01F1 3530 *
01F1 3540 *
01F1 3550 *
01F1 3560 * MEMORY INPUTS AN ADDRESS FROM THE KEYBOARD FOLLOWED
01F1 3570 * BY DATA AS DEFINED BY THE SEQUENCE
01F1 3580 * MEM(ADDRESS)NEXT,(DATA)NEXT,...,(DATA)EXEC
01F1 3590 * IF DATA IS TO BE DISPLAYED
01F1 3600 * MEM(ADDRESS)NEXT,...NEXT,EXEC
01F1 3610 * EXEC WILL RETURN CONTROL TO THE COMMAND RECOGNITION
01F1 3620 *
01F1 3630 *
01F1 3E 00 3640 MEMORY LD A,ZERO * CLEAR MEMORY BASE ADDRESS
01F3 32 F6 07 3650 LD (MBASE1)+A
01F6 32 F7 07 3660 LD (MBASE2)+A
01FC CD AC 01 3661 CALL CLADD
01FC CD B3 01 3670 CALL FORCAR * GET BASE ADDRESS
01FF 3A F1 07 3680 LD A,(KFLAGS)
0202 CB 4F 3690 BIT 1,A
0204 C2 89 00 3700 JP NZ,WARM2 * JUMP IF EXEC FLAG SET
0207 3A F2 07 3710 LD A,(KDATA1) * SAVE MEMORY ADDRESS
020A 32 F7 07 3720 LD (MBASE2)+A
020D 3A F3 07 3730 LD A,(KDATA2)
0210 32 F6 07 3740 LD (MBASE1)+A
0213 2A F6 07 3750 LD HL,(MBASE1) * SET MEM BASE ADDRESS
0216 7E 3760 MEM1 LD A,(HL) * GET MEMORY DATA
0217 D3 O7 3770 OUT ADDIS * DISPLAY MEMORY DATA
0219 CD 77 01 3780 CALL TWDACR * GET NEW DATA
021C 3A F1 07 3790 LD A,(KFLAGS)
021F CB 57 3800 BIT 2,A
0221 C2 43 02 3810 JP NZ,MEM2 * JUMP IF NO DATA
0224 2A F6 07 3820 LD HL,(MBASE1) * GET MEM ADDRESS
0227 3A F3 07 3830 LD A,(KDATA2) * GET NEW DATA
022A 77 3840 LD (HL)+A * REPLACE OLD DATA
022B 3A F1 07 3850 LD A,(KFLAGS)
022E CB 4F 3860 BIT 1,A
0230 C2 89 00 3870 JP NZ,WARM2 * JUMP IF EXEC FLAG SET
0233 2A F6 07 3880 MEM12 LD HL,(MBASE1) * INC BASE MEM ADD
0236 23 3890 INC HL
0237 22 F6 07 3900 LD (MBASE1)+HL

300 APPENDIX D
02B4 C2 89 00 4413 JP NZ,WARM2 *JUMP IF EXEC FLAG SET
02B7 3A F5 07 4420 REGI3 LD A, (TEMP2) *INCREMENT INDEX
02B9 3C 00 4421 INC A
02BB 32 F5 07 4422 LD (TEMP2), A
02BE 3A F8 07 4423 LD A,(REGINX) *INCREMENT INDEX
02C1 3C 00 4430 INC A
02C2 FE 1A 4440 CP 1AH
02C4 FA 6E 02 4450 JP M,REGI2 *JUMP IF INDEX, LT 1A
02C7 3E 02 4460 REGI4 LD A,TH *SET INITIAL INDEX
02C9 C3 59 02 4470 JP REGI0
02CB D6 4B 00 4480 REGISA SUB 48H
02CE FA 4B 02 4490 JP M,REGIST *JUMP IF INVALID REGISTER
02D1 C6 12 4500 ADD 12H
02D3 C3 6E 02 4510 JP REGI2
02D6 21 D7 07 4520 XYSP LD HL, IXLSAV
02D9 4F 00 4530 LD C, A
02DA A6 00 4540 LD 0, ZERO
02DC 09 00 4550 ADD HL, BC *HL=REG SAVE ADDRESS
02DD 22 F6 07 4560 LD (MBASE1), HL *DISPLAY REGISTER DATA
02E0 7E 00 4570 LD A, (HL) *DISPLAY REGISTER DATA
02E1 D3 06 4580 OUT ADDIS2
02E3 23 00 4590 INC HL
02E4 7E 00 4600 LD A, (HL)
02E5 D3 05 4610 OUT ADDIS1
02E7 3A F8 07 4620 LD A, (REGINX)
02EA 3C 00 4630 INC A
02EB 32 F8 07 4640 LD A, (REGINX), A
02EE CD B3 01 4650 CALL FORCAR *GET NEW DATA
02F1 3A F1 07 4660 LD A, (KFLAGS)
02F4 CB 57 00 4670 BIT 2, A
02F6 C2 08 03 4680 JP NZ, REGIS5 *JUMP IF NO DATA
02F9 2A F6 07 4710 LD HL, (MBASE1) *REPLACE OLD DATA
02FC 3A F3 07 4720 LD A, (KDATA2)
02FF 77 00 4730 LD (HL), A
0300 3A F2 07 4740 LD A, (KDATA1)
0303 23 00 4750 INC HL
0304 77 00 4760 LD (HL), A
0305 3A F1 07 4761 LD A, (KFLAGS)
0308 CB 4F 00 4762 REGIS BIT 1, A
030A C2 89 00 4763 JP NZ, WARM2 *JUMP IF EXEC FLAG SET
030D C3 B7 02 4770 JP REGI3
0310 4780 00 4800 *
0310 4790 00 4810 *
0310 4800 00 4820 *GO RESETS THE USERS RESTART ADDRESS IN THE
0310 4830 *REGISTER SAVE AREA AND EXITS TO THE RESTART
0310 4840 *MODULE
0310 4850 *
0310 4860 *
0310 CD AC 01 4870 GOREQ CALL CLADD
0313 CD B3 01 4871 CALL FORCAR *GET RESTART ADDRESS
0316 3A F1 07 4880 LD A, (KFLAGS)
0319 CB 57 00 4890 BIT 2, A
031B C2 89 00 4900 JP NZ,WARM2 *IF NO DATA EXIT
031E 3A F3 07 4910 LD A, (KDATA2) *SAVE NEW ADDRESS
0321 32 DD 07 4920 LD (PCHSAVE), A
0324 3A F2 07 4930 LD A, (KDATA1)
0327 32 DE 07 4940 LD (PCHSAVE), A
032A C3 AA 00 4950 JP RESTRT
032D 4960 *
032D 4970 *
032D 4980 *
032D 4990 *UART ST IS A UART LOOP CHECK ROUTINE
032D 5000 *IT UTILIZES A LOOP WITH THE OUTPUT
032D 5010 *PORT PATCHED TO THE INPUT PORT
032D 5020 *IF AN ERROR IS DETECTED THE ERROR IS
032D 5030 *DISPLAYED ON THE ADDRESS DISPLAY AND
032D  5040 *THE CHARACTER IS DISPLAYED ON THE DATA DISPLAY
032D  5050 *THE OUTPUT CHARACTE IS DISPLAYED ON THE MSD
032D  5060 *OF THE ADDRESS DISPLAY
032D  5070 *
032D  06 00  5080 UARTST LD B,ZERO  *
032F  DB 03  5090 IN UARTST  *GET STATUS
0331  CB 47  5100 BIT 0,A
0333  CA 53 03  5110 JP Z,UAER1  *JUMP IF XMIT BUFFER NOT EMPTY
0336  78  5120 UARTST0 LD A,B  *GET OUTPUT CHARACTER
0337  D3 05  5130 OUT ADDIS1
0339  D3 02  5140 OUT UARTIO
0338  DB 03  5150 UART1 IN UARTST
033D  CB 4F  5160 BIT 1,A
033E  CA 3B 03  5170 JP Z,UARTST1  *JUMP IF NO DATA AVAILABLE
0342  E6 1C  5180 AND 1CH
0344  C2 53 03  5190 JP NZ,UAER1  *JUMP IF PARITY ERROR
0347  DB 02  5240 IN UARTIO  *GET INPUT CHARACTER
0349  D3 07  5250 OUT DATDIS
0348  B8  5260 CP B
034C  C2 5A 03  5270 JP NZ,UAER2  *JUMP IF INPUT,NE.OUTPUT
034F  04  5280 INC B
0350  C3 36 03  5290 JP UARTST0
0353  D3 06  5300 UAER1 OUT ADDIS2  *DISPLAY UART STATUS
0355  DB 02  5310 IN UARTIO  *GET INPUT DATA
0357  D3 07  5320 OUT DATDIS
0359  76  5330 HALT
035A  3E 0F  5340 UAER2 LD A,0FH
035C  ED 79  5350 OUT (ADDIS2),A
035E  76  5360 HALT
035F  5370 *
035F  5380 *
035F  5390 **TTYINPUT DRIVER
035F  5400 **INPUTS DATA INTO THE SPECIFIED BUFFER
035F  5410 **INPUT IS TERMINATED WHEN A CARRIAGE RETURN
035F  5420 **IS DETECTED OR THE NUMBER OF SPECIFIED CHARACTERS
035F  5430 **HAVE BEEN INPUTED FROM THE TRANSMITTING DEVICE
035F  5440 *
035F  2A F9 07  5450 TTYINP LD HL,(TTYIBF)  *GET BUFFER ADDRES
0362  3A FD 07  5460 LD A,(TTYIC)  *GET NMBER OF CHARACTERS
0365  47  5470 LD B,A
0366  DB 03  5480 TTYIN1 IN UARTST  *GET UART STATUS
0368  CB 4F  5490 BIT 1,A
036A  CA 66 03  5500 JP Z,TTYIN1  *JUMP IF NO DATA
036D  E6 1C  5510 AND 1CH
036F  C2 9B 03  5520 JP NZ,TTYERR  *JUMP IF PARITY ERROR
0372  DB 02  5570 IN UARTIO  *GET INPUT CHARACTER
0374  77  5580 LD (HL),A  *SAFE CHARACTER IN USERS BUF
0375  FE 0D  5590 CP A,0DH
0376  CA 91 03  5600 JP Z,TTYIN2  *JUMP IF CARRIAGE RETURN
0379  3E 01  5810 LD A,ONE  *GET OUTPUT CHARACTER COUNT
037B  22 FB 07  5620 TTYIN3 LD (TTYOBF),HL  *GET OUTPUT BUFFER ADDRESS
037E  32 FE 07  5630 LD (TTYOC),A
0381  78  5631 LD A,B
0382  32 F4 07  5632 LD (TEMP),A
0385  CD 9E 03  5640 CALL TTYOUT  *GO OUTPUT CHARACTER
0388  3A F4 07  5641 LD A,(TEMP)
038B  47  5642 LD B,A
038C  05  5650 DEC B
038D  CB  5660 RET Z  *RETURN IF ALL CHARACTERS IN
038E  C3 66 03  5670 JP TTYIN1
0391  21 9C 03  5680 TTYIN2 LD HL,LF  *GET LINE FEED ADDRESS
0394  3E 02  5690 LD A,THW0
0396  06 01  5700 LD B,ONE
039B  C3 7B 03  5710 JP TTYIN3
039B  C9  5720 TTYERR RET  *RETURN WITH ERROR CODE IN A
039C  0D 0A  5730 LF DB 0DH,0AH  *LINE FEED/CARRIAGE RETURN
039E  5740 *
039E  5750 **TTY OUTPUT DRIVER

APPENDIX D 303
039E 5760 *TTYOUT OUTPUTS DATA FROM THE SPECIFIED
039E 5770 *USERS BUFFER TO THE UART. THE NUMBER OF
039E 5780 *USER SPECIFIED CHARACTERS ARE OUTPUT
039E 5790 *AND CONTROL RETURNED TO THE USER
039E 5800 *
039E 2A FB 07 5810 TTYOUT LD HL, (TTYOB)  *GET BUFFER ADDRESS
03A1 3A FE 07 5820 LD A, (TTYOC)  *GET NUMBER OF CHARACTERS
03A4 47 5830 LD B, A
03A5 0E 00 5840 TTYOU1 LD C, ZERO
03A7 11 00 00 5850 LD DE, ZERO
03AA DB 03 5860 TTYO1 IN UARTST  *GET STATUS
03AC CB 47 5870 BIT 0, A
03AE CA BC 03 5880 JP Z, TTYOU2  *JUMP IF BUFFER NOT EMPTY
03B1 7E 5890 LD A, (HL)  *GET CHARACTER
03B2 D3 02 5900 OUT UARTIO  *OUTPUT CHARACTER
03B4 05 5910 DEC B
03B5 3E 00 5920 LD A, ZERO
03B7 CB 5930 RET Z  *RETURN IF BUFFER EMPTY
03B9 23 5931 INC HL
03BC 13 5940 JP TTYOU1
03BD 7B 5950 TTYOU2 INC DE  *TRY AGAIN DELAY
03BE FE 00 5960 LD A, E
03C0 C2 BC 03 5970 CP ZERO
03C3 7A 5980 JP NZ, TTYOU2
03C4 FE 00 5990 LD A, D
03C6 C2 BC 03 6000 CP ZERO
03C9 0C 6010 JP NZ, TTYOU2
03CA FE 05 6020 INC C
03CC C2 AA 03 6030 CP FIVE
03CF 3E 01 6040 JP NZ, TTYO1  *JUMP IF .LT.5 TRYS
03D1 C9 6050 LD A, ONE  *ELSE RETURN WITH A=1
03D2 6060 RET
07C4 6080 ST 7C4H
07C4 6090 *
07C4 6100 *PAGE 2 CONSTANTS, JUMP AREAS, AND REGISTER
07C4 6110 *SAVE AREAS
07C4 6120 *
07C4 6130 SPSTRT DB 0  *STACK AREA
00 07C5 6140 *
07C5 6150 *USER RESTART AREA
07C5 6160 *
07C5 6170 RST2V DS 3  *USER BRANCH AREA FOR RST 2
07C8 6180 RST3V DS 3  *USER BRANCH AREA FOR RST 3
07C8 6190 RST4V DS 3  *USER BRANCH AREA FOR RST 4
07CE 6200 RST5V DS 3  *USER BRANCH AREA FOR RST 5
07D1 6210 RST6V DS 3  *USER BRANCH AREA FOR RST 6
07D4 6220 RST7V DS 3  *USER BRANCH AREA FOR RST 7
07D7 6230 *
07D7 6240 *REGISTER SAVE AREA
07D7 6250 *
07D7 6260 IXLSAV DB 0
00 07D8 6270 IXHSAV DB 0
00 07D9 6280 IYLSAV DB 0
00 07DA 6290 IYHSAV DB 0
00 07DB 6300 SPLSAV DB 0
00 07DC 6310 SPHSAV DB 0
00 07DD 6320 PCLSAV DB 0
00 07DE 6330 PCHSAV DB 0
00 07DF 6340 ISAV DB 0
07E0  6350 RSAVE DB 0
07E1  6360 LSAVE DB 0
07E2  6370 HSAVE DB 0
07E3  6380 ASAVE DB 0
07E4  6390 BS SAVE DB 0
07E5  6400 CSAVE DB 0
07E6  6410 DSAVE DB 0
07E7  6420 ES SAVE DB 0
07E8  6430 FSAVE DB 0
07E9  6440 ALSAVE DB 0
07EA  6450 AHSAVE DB 0
07EB  6460 AASAVE DB 0
07EC  6470 ABSAVE DB 0
07ED  6480 ACSAVE DB 0
07EE  6490 ABSAVE DB 0
07EF  6500 AESAVE DB 0
07F0  6510 AFSAVE DB 0
07F1  6520 *
07F1  6530 *DATA STORAGE AREA
07F1  6540 *
07F1  6550 KFLAGS DB 0 *KEYBOARD FLAGS
07F2  6560 KD ATA1 DB 0 *KEYBOARD INPUT BUFFER
07F3  6570 KD ATA2 DB 0
07F4  6580 TEMP DB 0
07F5  6581 TEMP2 DB 0
07F6  6590 MBASE1 DB 0 *BASE MEMORY ADDRESS
07F7  6600 MBASE2 DB 0
07F8  6610 REGINX DB 0 *REGISTER INDEX
07F9  6620 TTYIBF DS 2 *TTY INPUT BUFFER ADDRESS
07FB  6630 TTYOBF DS 2 *TTYOUTPUT BUFFER ADDRESS
07FD  6640 TTYIC DB 0 *TTY INPUT CHARACTER COUNT
07FE  6650 TTYOC DB 0 *TTY OUTPUT CHARACTER COUNT
07FF  6660 *
07FF  6670 END

FILE 3000 7323
READY
Appendix E1  Electrical Specifications

Absolute Maximum Ratings

Temperature Under Bias Specifications
-65°C to +150°C

Storage Temperature
-20°C to +70°C

Voltage On Any Pin with Respect to Ground
-0.3V to +7V

Power Dissipation
1.5W

*Comment
Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Note: For Z80-CPU all AC and DC characteristics remain the same for the military grade parts except Icc

Icc = 200 mA

Z80-CPU D.C. Characteristics

$T_A = 0^\circ C$ to $70^\circ C$, $V_{cc} = 5V \pm 5\%$ unless otherwise specified

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit</th>
<th>Test Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>VILC</td>
<td>Clock Input Low Voltage</td>
<td>-0.3</td>
<td>0.45</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VICH</td>
<td>Clock Input High Voltage</td>
<td>VCC -0.6</td>
<td>0.45</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VIL</td>
<td>Input Low Voltage</td>
<td>-0.3</td>
<td>0.8</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VIH</td>
<td>Input High Voltage</td>
<td>2.0</td>
<td>VCC</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VOUT</td>
<td>Output Low Voltage</td>
<td>0.4</td>
<td>V</td>
<td>IOL = 1.8mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VOH</td>
<td>Output High Voltage</td>
<td>2.4</td>
<td>V</td>
<td>IOH = 250µA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ICC</td>
<td>Power Supply Current</td>
<td>150</td>
<td>mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ILI</td>
<td>Input Leakage Current</td>
<td>10 µA</td>
<td>0.1mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ILOH</td>
<td>Tri-State Output Leakage Current in Float</td>
<td>10 µA</td>
<td>0.1mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IOL</td>
<td>Tri-State Output Leakage Current in Float</td>
<td>-10 µA</td>
<td>0.1mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ID</td>
<td>Data Bus Leakage Current in Input Mode</td>
<td>≤10 µA</td>
<td>0 &lt; VIN &lt; VCC</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Z80-CPU Ordering Information

$T_A = 25^\circ C$, $f = 1$ MHz, unmeasured pins returned to ground

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Max.</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>CΦ</td>
<td>Clock Capacitance</td>
<td>35 pF</td>
<td></td>
</tr>
<tr>
<td>CIN</td>
<td>Input Capacitance</td>
<td>5 pF</td>
<td></td>
</tr>
<tr>
<td>COUT</td>
<td>Output Capacitance</td>
<td>10 pF</td>
<td></td>
</tr>
</tbody>
</table>

Z80A-CPU D.C. Characteristics

$T_A = 0^\circ C$ to $70^\circ C$, $V_{cc} = 5V \pm 5\%$ unless otherwise specified

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Unit</th>
<th>Test Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>VILC</td>
<td>Clock Input Low Voltage</td>
<td>-0.3</td>
<td>0.45</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VICH</td>
<td>Clock Input High Voltage</td>
<td>VCC -0.6</td>
<td>0.45</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VIL</td>
<td>Input Low Voltage</td>
<td>-0.3</td>
<td>0.8</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VIH</td>
<td>Input High Voltage</td>
<td>2.0</td>
<td>VCC</td>
<td>V</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VOUT</td>
<td>Output Low Voltage</td>
<td>0.4</td>
<td>V</td>
<td>IOL = 1.8mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VOH</td>
<td>Output High Voltage</td>
<td>2.4</td>
<td>V</td>
<td>IOH = 250µA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ICC</td>
<td>Power Supply Current</td>
<td>90</td>
<td>200</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ILI</td>
<td>Input Leakage Current</td>
<td>10 µA</td>
<td>0.1mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ILOH</td>
<td>Tri-State Output Leakage Current in Float</td>
<td>10 µA</td>
<td>0.1mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IOL</td>
<td>Tri-State Output Leakage Current in Float</td>
<td>-10 µA</td>
<td>0.1mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ID</td>
<td>Data Bus Leakage Current in Input Mode</td>
<td>≤10 µA</td>
<td>0 &lt; VIN &lt; VCC</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Z80A-CPU Ordering Information

$T_A = 25^\circ C$, $f = 1$ MHz, unmeasured pins returned to ground

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter</th>
<th>Max.</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>CΦ</td>
<td>Clock Capacitance</td>
<td>35 pF</td>
<td></td>
</tr>
<tr>
<td>CIN</td>
<td>Input Capacitance</td>
<td>5 pF</td>
<td></td>
</tr>
<tr>
<td>COUT</td>
<td>Output Capacitance</td>
<td>10 pF</td>
<td></td>
</tr>
</tbody>
</table>

Reprinted by permission of Zilog, Inc. Copyright © 1977

APPENDIX E 309
A.C. Characteristics  Z80-CPU

$$T_A = 0^\circ C \text{ to } 70^\circ C, \ V_{cc} = +5V \pm 5\%, \text{ Unless Otherwise Noted.}$$

<table>
<thead>
<tr>
<th>Signal</th>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
<th>Test Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>$\phi$</td>
<td>$\phi$</td>
<td>Clock Period</td>
<td>4</td>
<td>1121</td>
<td>$\mu s$</td>
<td></td>
</tr>
<tr>
<td>$\phi$</td>
<td>$w_{(4H)}$</td>
<td>Clock Pulse Width, Clock High</td>
<td>180</td>
<td></td>
<td>$\mu s$</td>
<td></td>
</tr>
<tr>
<td>$\phi$</td>
<td>$w_{(4L)}$</td>
<td>Clock Pulse Width, Clock Low</td>
<td>180</td>
<td></td>
<td>$\mu s$</td>
<td></td>
</tr>
<tr>
<td>$\phi$</td>
<td>$t_{s, f}$</td>
<td>Clock Rise and Fall Time</td>
<td>30</td>
<td></td>
<td>$\mu s$</td>
<td></td>
</tr>
</tbody>
</table>

| $\alpha, \beta$ | $\phi$ | Address Output Delay | 145 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Delay to Float | 110 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Address Stable Prior to $\text{MREQ}(\text{Memory Cycle})$ | | | | $t_{acm}$ = $t_{w(4H)} + t_f < 75$ |
| $\alpha, \beta$ | $\phi$ | Address Stable Prior to IORD, RD or WR (I/O Cycle) | | | | $t_{ac}$ = $t_{w(4L)} + t_f < 40$ |
| $\alpha, \beta$ | $\phi$ | Address Stable From RD or WR During Float | | | | $t_{caf}$ = $t_{w(4L)} + t_f < 80$ |

| $\alpha, \beta$ | $\phi$ | Data Output Delay | 230 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Delay to Float During Write Cycle | 90 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Data Setup Time to Rising Edge of Clock During M$1$ Cycle | 50 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Data Setup Time to Falling Edge of Clock During M$2$ to M$5$ | 60 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Data Stable Prior to $\text{WR}(\text{Memory Cycle})$ | 15 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Data Stable Prior to WR (I/O Cycle) | 16 | | $\mu s$ | $C_L = 50pF$ |
| $\alpha, \beta$ | $\phi$ | Data Stable From WR | 17 | | $\mu s$ | $C_L = 50pF$ |

| $t_H$ | Any Hold Time for Setup Time | 0 | | $\mu s$ | $C_L = 50pF$ |

| $\text{MREQ}$ | $\phi$ | MREQ Delay From Falling Edge of Clock, MREQ Low | 100 | | $\mu s$ | $C_L = 50pF$ |
| $\text{MREQ}$ | $\phi$ | MREQ Delay From Rising Edge of Clock, MREQ High | 100 | | $\mu s$ | $C_L = 50pF$ |
| $\text{MREQ}$ | $\phi$ | MREQ Delay From Falling Edge of Clock, MREQ J High | 100 | | $\mu s$ | $C_L = 50pF$ |
| $\text{MREQ}$ | $\phi$ | Pulse Width, MREQ Low | 18 | | $\mu s$ | $C_L = 50pF$ |
| $\text{MREQ}$ | $\phi$ | Pulse Width, MREQ High | 18 | | $\mu s$ | $C_L = 50pF$ |

| $\text{IORD}$ | $\phi$ | IORD Delay From Rising Edge of Clock, IORD Low | 90 | | $\mu s$ | $C_L = 50pF$ |
| $\text{IORD}$ | $\phi$ | IORD Delay From Falling Edge of Clock, IORD Low | 110 | | $\mu s$ | $C_L = 50pF$ |
| $\text{IORD}$ | $\phi$ | IORD Delay From Rising Edge of Clock, IORD High | 100 | | $\mu s$ | $C_L = 50pF$ |
| $\text{IORD}$ | $\phi$ | IORD Delay From Falling Edge of Clock, IORD High | 110 | | $\mu s$ | $C_L = 50pF$ |

| $\text{RD}$ | $\phi$ | RD Break From Rising Edge of Clock, RD Low | 100 | | $\mu s$ | $C_L = 50pF$ |
| $\text{RD}$ | $\phi$ | RD Break From Falling Edge of Clock, RD Low | 130 | | $\mu s$ | $C_L = 50pF$ |
| $\text{RD}$ | $\phi$ | RD Break From Rising Edge of Clock, RD High | 100 | | $\mu s$ | $C_L = 50pF$ |
| $\text{RD}$ | $\phi$ | RD Break From Falling Edge of Clock, RD High | 110 | | $\mu s$ | $C_L = 50pF$ |

| $\text{WR}$ | $\phi$ | WR Break From Rising Edge of Clock, WR Low | 80 | | $\mu s$ | $C_L = 50pF$ |
| $\text{WR}$ | $\phi$ | WR Break From Falling Edge of Clock, WR Low | 90 | | $\mu s$ | $C_L = 50pF$ |
| $\text{WR}$ | $\phi$ | WR Break From Rising Edge of Clock, WR High | 100 | | $\mu s$ | $C_L = 50pF$ |
| $\text{WR}$ | $\phi$ | Pulse Width, WR Low | 110 | | $\mu s$ | $C_L = 50pF$ |

| $\text{MT}$ | $\phi$ | MT Delay From Rising Edge of Clock, MT Low | 130 | | $\mu s$ | $C_L = 50pF$ |
| $\text{MT}$ | $\phi$ | MT Delay From Rising Edge of Clock, MT High | 130 | | $\mu s$ | $C_L = 50pF$ |

| $\text{RFSH}$ | $\phi$ | RFSH Delay From Rising Edge of Clock, RFSH Low | 180 | | $\mu s$ | $C_L = 50pF$ |
| $\text{RFSH}$ | $\phi$ | RFSH Delay From Rising Edge of Clock, RFSH High | 150 | | $\mu s$ | $C_L = 50pF$ |

| $\text{WAIT}$ | $\phi$ | WAIT Setup Time to Falling Edge of Clock | 70 | | $\mu s$ | $C_L = 50pF$ |

| $\text{HALT}$ | $\phi$ | HALT Delay Time From Falling Edge of Clock | 300 | | $\mu s$ | $C_L = 50pF$ |

| $\text{INT}$ | $\phi$ | INT Setup Time to Rising Edge of Clock | 80 | | $\mu s$ | $C_L = 50pF$ |

| $\text{NMI}$ | $\phi$ | NMI Setup Time to Rising Edge of Clock | 80 | | $\mu s$ | $C_L = 50pF$ |

| $\text{BUSHQ}$ | $\phi$ | BUSHQ Setup Time to Rising Edge of Clock | 80 | | $\mu s$ | $C_L = 50pF$ |

| $\text{BUSAK}$ | $\phi$ | BUSAK Delay From Rising Edge of Clock, BUSAK Low | 120 | | $\mu s$ | $C_L = 50pF$ |
| $\text{BUSAK}$ | $\phi$ | BUSAK Delay From Rising Edge of Clock, BUSAK High | 110 | | $\mu s$ | $C_L = 50pF$ |

| $\text{RFSET}$ | $\phi$ | RFSET Setup Time to Rising Edge of Clock | 90 | | $\mu s$ | $C_L = 50pF$ |

| $\text{F(C)}$ | $\phi$ | Delay to Float (MREQ, IORD, RD and WR) | 100 | | $\mu s$ | $C_L = 50pF$ |

| $\text{t_{ms}}$ | $\phi$ | MT Stable Prior to IORD (Interrupt Ack.) | 111 | | $\mu s$ | $C_L = 50pF$ |

---

**Notes:**

A. Data should be enabled onto the CPU data bus when $\text{RD}$ is active. During interrupt acknowledge data should be enabled when $\text{MI}$ and $\text{IORD}$ are both active.

B. All control signals are internally synchronized, so they may be totally asynchronous with respect to the clock.

C. The $\text{RESET}$ signal must be active for a minimum of 3 clock cycles.

D. Output Delay vs. Loaded Capacitance

$$T_A = 70^\circ C \quad V_{cc} = +5V \pm 5\%$$

Add 10-resistance delay for each 50pf increase in load up to a maximum of 200pf for the data bus & 100pf for address & control lines.

- Although static by design, testing guarantees $t_{w(4H)}$ of 200 $\mu$s maximum.

---

310 APPENDIX E
A.C. Timing Diagram

Timing measurements are made at the following voltages, unless otherwise specified:

<table>
<thead>
<tr>
<th></th>
<th>&quot;1&quot;</th>
<th>&quot;0&quot;</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLOCK</td>
<td>V_{cc}=6V</td>
<td>.45V</td>
</tr>
<tr>
<td>OUTPUT</td>
<td>2.0 V</td>
<td>.8 V</td>
</tr>
<tr>
<td>INPUT</td>
<td>2.0 V</td>
<td>.8 V</td>
</tr>
<tr>
<td>FLOAT</td>
<td>\Delta V</td>
<td>\pm 0.5 V</td>
</tr>
</tbody>
</table>

\( T \)

\( W \)

\( D_0-7 \)

\( M1 \)

\( RFSR \)

\( MREQ \)

\( RD \)

\( WR \)

\( IORD \)

\( RD \)

\( WR \)

\( WAIT \)

\( HALT \)

\( INT \)

\( NMI \)

\( BUSRO \)

\( BUSAK \)

\( RESET \)

APPENDIX E 311
### A.C. Characteristics

$T_A = 0^\circ C$ to $70^\circ C$, $V_{CC} = +5V \pm 5\%$, Unless Otherwise Noted.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Symbol</th>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
<th>Test Condition</th>
</tr>
</thead>
<tbody>
<tr>
<td>$\phi$</td>
<td>$t_c$</td>
<td>Clock Period</td>
<td>25</td>
<td>1121</td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PH}$</td>
<td>Clock Pulse Width, Clock High</td>
<td>110</td>
<td>11</td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PL}$</td>
<td>Clock Pulse Width, Clock Low</td>
<td>110</td>
<td>2000</td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{R}$</td>
<td>Clock Rise and Fall Time</td>
<td>.30</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$\alpha$-15</td>
<td>$t_{OPD}$</td>
<td>Address Output Delay</td>
<td>110</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{DF}$</td>
<td>Delay to Float</td>
<td>90</td>
<td></td>
<td>nsec</td>
<td>$t_{DF} = t_c$</td>
</tr>
<tr>
<td></td>
<td>$t_{PR}$</td>
<td>Address Stable Prior to MREQ (Memory Cycle)</td>
<td>12</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PDR}$</td>
<td>Address Stable Prior to IORD, RD or WR (I/O Cycle)</td>
<td>2</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PRD}$</td>
<td>Address Stable from RD, WR, IORD or MREQ</td>
<td>4</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PRFD}$</td>
<td>Address Stable From RD or WR During Float</td>
<td>1</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$\theta$-7</td>
<td>$t_{OPD}$</td>
<td>Data Output Delay</td>
<td>150</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{DF}$</td>
<td>Delay to Float During Write Cycle</td>
<td>90</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{SOP}$</td>
<td>Data Setup Time to Rising Edge of Clock During M1 Cycle</td>
<td>35</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{SDM}$</td>
<td>Data Setup Time to Falling Edge of Clock During M2 to M5</td>
<td>50</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PWR}$</td>
<td>Data Stable Prior to WR (Memory Cycle)</td>
<td>5</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{SOPR}$</td>
<td>Data Stable Prior to WR (I/O Cycle)</td>
<td>6</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{DSPR}$</td>
<td>Data Stable From WR</td>
<td>7</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$H$</td>
<td>$t_{STH}$</td>
<td>Any Hold Time for Setup Time</td>
<td>0</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$MREQ$</td>
<td>$t_{DRL}$</td>
<td>MREQ Delay From Falling Edge of Clock, MREQ Low</td>
<td>85</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{DRL}$</td>
<td>MREQ Delay From Rising Edge of Clock, MREQ Low</td>
<td>85</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{DRL}$</td>
<td>MREQ Delay From Falling Edge of Clock, MREQ High</td>
<td>85</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{DRL}$</td>
<td>MREQ Delay From Rising Edge of Clock, MREQ High</td>
<td>85</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PWL}$</td>
<td>Pulse Width, MREQ Low</td>
<td>81</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{PWH}$</td>
<td>Pulse Width, MREQ High</td>
<td>91</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$IORD$</td>
<td>$t_{DRL}$</td>
<td>IORD Delay From Rising Edge of Clock, IORD Low</td>
<td>75</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{DRL}$</td>
<td>IORD Delay From Falling Edge of Clock, IORD Low</td>
<td>85</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{DRL}$</td>
<td>IORD Delay From Rising Edge of Clock, IORD High</td>
<td>85</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{DRL}$</td>
<td>IORD Delay From Falling Edge of Clock, IORD High</td>
<td>85</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$W$</td>
<td>$t_{WRL}$</td>
<td>WR Delay From Rising Edge of Clock, WR Low</td>
<td>65</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{WRL}$</td>
<td>WR Delay From Falling Edge of Clock, WR Low</td>
<td>80</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{WRL}$</td>
<td>WR Delay From Rising Edge of Clock, WR High</td>
<td>80</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td></td>
<td>$t_{WRL}$</td>
<td>WR Delay From Falling Edge of Clock, WR High</td>
<td>80</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$R$</td>
<td>$t_{RRL}$</td>
<td>Pulse Width, WR Low</td>
<td>110</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$RIT$</td>
<td>$t_{RIT}$</td>
<td>M1 Delay From Rising Edge of Clock, M1 Low</td>
<td>100</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{RIT}$</td>
<td>M1 Delay From Rising Edge of Clock, M1 High</td>
<td>100</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$RFSH$</td>
<td>$t_{RFH}$</td>
<td>RFSH Delay From Rising Edge of Clock, RFSH Low</td>
<td>130</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{RFH}$</td>
<td>RFSH Delay From Rising Edge of Clock, RFSH High</td>
<td>120</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$W$</td>
<td>$t_{WIT}$</td>
<td>WAIT Setup Time to Falling Edge of Clock</td>
<td>70</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$HALT$</td>
<td>$t_{HIT}$</td>
<td>HALT Delay Time From Falling Edge of Clock</td>
<td>300</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td>$INF$</td>
<td>$t_{INF}$</td>
<td>INF Setup Time to Rising Edge of Clock</td>
<td>80</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$NM1$</td>
<td>$t_{NM1}$</td>
<td>Pulse Width, NM1 Low</td>
<td>80</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$BUSRO$</td>
<td>$t_{BUSO}$</td>
<td>BUSRO Setup Time to Rising Edge of Clock</td>
<td>50</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$BUSAK$</td>
<td>$t_{BUSAK}$</td>
<td>BUSAK Delay From Rising Edge of Clock, BUSAK Low</td>
<td>100</td>
<td></td>
<td>nsec</td>
<td>$C_L = 50pF$</td>
</tr>
<tr>
<td></td>
<td>$t_{BUSAK}$</td>
<td>BUSAK Delay From Rising Edge of Clock, BUSAK High</td>
<td>100</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$RE$</td>
<td>$t_{REET}$</td>
<td>RESET Setup Time to Rising Edge of Clock</td>
<td>60</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$F/C$</td>
<td>$t_{F/C}$</td>
<td>Delay to Float (MREQ, IORD, RD and WR)</td>
<td>80</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
<tr>
<td>$M1$</td>
<td>$t_{MR}$</td>
<td>M1 Stable Prior to IORD (Interrupt Ack.)</td>
<td>111</td>
<td></td>
<td>nsec</td>
<td></td>
</tr>
</tbody>
</table>

### Notes:

A. Data should be enabled onto the CPU data bus when RD is active. During interrupt acknowledge data should be enabled when M1 and IORD are both active.

B. All control signals are internally synchronized, so they may be totally synchronous with respect to the clock.

C. The RESET signal must be active for a minimum of 3 clock cycles.

D. Output Delay vs. Loaded Capacitance

\[ TA = 70^\circ C \quad VCC = +5V \pm 5\% \]

Add 10 nsec delay for each 50pf increase in load up to maximum of 200pF for data bus and 100pF for address & control lines.

E. Although static by design, testing guarantees $t_{PH}$ of 200 nsec maximum

### Diagram:

[Diagram showing output and test point]

\[ t_{w} = 2t_c + t_{PH} + t_c = 65 \]

\[ t_{w} = t_{DF} + t_{PH} = 70 \]

\[ t_{w} = t_{DRL} + t_c = 50 \]

\[ t_{w} = t_{DRL} + t_c = 45 \]

\[ t_{OCD} = t_c = 170 \]

\[ t_{OCD} = t_c = 170 \]

\[ t_{OCD} = t_c = 70 \]

\[ t_{w} = t_{PH} + t_c = 30 \]

\[ t_{w} = t_{PH} + t_c = 20 \]

\[ t_{w} = t_{PH} + t_c = 30 \]

\[ t_{w} = t_{PH} + t_c = 30 \]

\[ t_{w} = t_{PH} + t_c = 30 \]
Appendix E2 CPU Timing

The Z-80 CPU executes instructions by stepping through a very precise set of a few basic operations. These include:

- Memory read or write
- I/O device read or write
- Interrupt acknowledge

All instructions are merely a series of these basic operations. Each of these basic operations can take from three to six clock periods to complete or they can be lengthened to synchronize the CPU to the speed of external devices. The basic clock periods are referred to as T cycles and the basic operations are referred to as M (for machine) cycles. Figure 0 illustrates how a typical instruction will be merely a series of specific M and T cycles. Notice that this instruction consists of three machine cycles (M1, M2 and M3). The first machine cycle of any instruction is a fetch cycle which is four, five or six T cycles long (unless lengthened by the wait signal which will be fully described in the next section). The fetch cycle (M1) is used to fetch the OP code of the next instruction to be executed. Subsequent machine cycles move data between the CPU and memory or I/O devices and they may have anywhere from three to five T cycles (again they may be lengthened by wait states to synchronize the external devices to the CPU). The following paragraphs describe the timing which occurs within any of the basic machine cycles.

![BASIC CPU TIMING EXAMPLE](image)

**FIGURE 0**

All CPU timing can be broken down into a few very simple timing diagrams as shown in figure 1 through 7. These diagrams show the following basic operations with and without wait states (wait states are added to synchronize the CPU to slow memory or I/O devices).

1. Instruction OP code fetch (M1 cycle)
2. Memory data read or write cycles
3. I/O read or write cycles
4. Bus Request/Acknowledge Cycle
5. Interrupt Request/Acknowledge Cycle
6. Non maskable Interrupt Request/Acknowledge Cycle
7. Exit from a HALT instruction

Reprinted by permission of Zilog, Inc. Copyright © 1977
INSTRUCTION FETCH

Figure 1 shows the timing during an M1 cycle (OP code fetch). Notice that the PC is placed on the address bus at the beginning of the M1 cycle. One half clock time later the MREQ signal goes active. At this time the address to the memory has had time to stabilize so that the falling edge of MREQ can be used directly as a chip enable clock to dynamic memories. The RD line also goes active to indicate that the memory read data should be enabled onto the CPU data bus. The CPU samples the data from the memory on the data bus with the rising edge of the clock of state T3 and this same edge is used by the CPU to turn off the RD and MRQ signals. Thus the data has already been sampled by the CPU before the RD signal becomes inactive. Clock state T3 and T4 of a fetch cycle are used to refresh dynamic memories. (The CPU uses this time to decode and execute the fetched instruction so that no other operation could be performed at this time). During T3 and T4 the lower 7 bits of the address bus contain a memory refresh address and the RFSH signal becomes active to indicate that a refresh read of all dynamic memories should be accomplished. Notice that a RD signal is not generated during refresh time to prevent data from different memory segments from being gated onto the data bus. The MREQ signal during refresh time should be used to perform a refresh read of all memory elements. The refresh signal can not be used by itself since the refresh address is only guaranteed to be stable during MREQ time.

![Diagram of instruction fetch](image)

INSTRUCTION OF CODE FETCH
FIGURE 1

Figure 1A illustrates how the fetch cycle is delayed if the memory activates the WAIT line. During T2 and every subsequent Tw, the CPU samples the WAIT line with the falling edge of \( \Phi \). If the WAIT line is active at this time, another wait state will be entered during the following cycle. Using this technique the read cycle can be lengthened to match the access time of any type of memory device.
MEMORY READ OR WRITE

Figure 2 illustrates the timing of memory read or write cycles other than an OP code fetch (M1 cycle). These cycles are generally three clock periods long unless wait states are requested by the memory via the WAIT signal. The MREQ signal and the RD signal are used the same as in the fetch cycle. In the case of a memory write cycle, the MREQ also becomes active when the address bus is stable so that it can be used directly as a chip enable for dynamic memories. The WR line is active when data on the data bus is stable so that it can be used directly as a R/W pulse to virtually any type of semiconductor memory. Furthermore the WR signal goes inactive one half T state before the address and data bus contents are changed so that the overlap requirements for virtually any type of semiconductor memory type will be met.
Figure 2A illustrates how a **WAIT** request signal will lengthen any memory read or write operation. This operation is identical to that previously described for a fetch cycle. Notice in this figure that a separate read and a separate write cycle are shown in the same figure although read and write cycles can never occur simultaneously.

![Diagram](image)

**MEMORY READ OR WRITE CYCLES WITH WAIT STATES**

**FIGURE 2A**

**INPUT OR OUTPUT CYCLES**

Figure 3 illustrates an I/O read or I/O write operation. Notice that during I/O operations a single wait state is automatically inserted. The reason for this is that during I/O operations, the time from when the IORQ signal goes active until the CPU must sample the WAIT line is very short and without this extra state sufficient time does not exist for an I/O port to decode its address and activate the WAIT line if a wait is required. Also, without this wait state it is difficult to design MOS I/O devices that can operate at full CPU speed. During this wait state time the WAIT request signal is sampled. During a read I/O operation, the RD line is used to enable the addressed port onto the data bus just as in the case of a memory read. For I/O write operations, the WR line is used as a clock to the I/O port, again with sufficient overlapping timing automatically provided so that the rising edge may be used as a data clock.

Figure 3A illustrates how additional wait states may be added with the **WAIT** line. The operation is identical to that previously described.

**BUS REQUEST/ACKNOWLEDGE CYCLE**

Figure 4 illustrates the timing for a Bus Request/Acknowledge cycle. The **BUSRQ** signal is sampled by the CPU with the rising edge of the last clock period of any machine cycle. If the **BUSRQ** signal is active, the CPU will set its address, data and tri-state control signals to the high impedance state with the rising edge of the next clock pulse. At that time any external device can control the buses to transfer data between memory and I/O devices. (This is generally known as Direct Memory Access [DMA] using cycle stealing). The maximum time for the CPU to respond to a bus request is the length of a machine cycle and the external controller can maintain control of the bus for as many clock cycles as is desired.

Note, however, that if very long DMA cycles are used, and dynamic memories are being used, the external controller must also perform the refresh function. This situation only occurs if very large blocks of data are transferred under DMA control. Also note that during a bus request cycle, the CPU cannot be interrupted by either a NMI or an INT signal.
* Automatically inserted WAIT state

APPENDIX E 317
INTERRUPT REQUEST/ACKNOWLEDGE CYCLE

Figure 5 illustrates the timing associated with an interrupt cycle. The interrupt signal (INT) is sampled by the CPU with the rising edge of the last clock at the end of any instruction. The signal will not be accepted if the internal CPU software controlled interrupt enable flip-flop is not set or if the BUSRQ signal is active. When the signal is accepted a special M1 cycle is generated. During this special M1 cycle the IORQ signal becomes active (instead of the normal MREQ) to indicate that the interrupting device can place an 8-bit vector on the data bus. Notice that two wait states are automatically added to this cycle. These states are added so that a ripple priority interrupt scheme can be easily implemented. The two wait states allow sufficient time for the ripple signals to stabilize and identify which I/O device must insert the response vector.
Figures 5A and 5B illustrate how a programmable counter can be used to extend interrupt acknowledge time. (Configured as shown to add one wait state)

EXTENDING INTERRUPT ACKNOWLEDGE TIME WITH WAIT STATE
FIGURE 5A

REQUEST/ACKNOWLEDGE CYCLE WITH ONE ADDITIONAL WAIT STATE
FIGURE 5B
NON MASKABLE INTERRUPT RESPONSE

Figure 6 illustrates the request/acknowledge cycle for the non maskable interrupt. This signal is sampled at the same time as the interrupt line, but this line has priority over the normal interrupt and it can not be disabled under software control. Its usual function is to provide immediate response to important signals such as an impending power failure. The CPU response to a non maskable interrupt is similar to a normal memory read operation. The only difference being that the content of the data bus is ignored while the processor automatically stores the PC in the external stack and jumps to location 0060H. The service routine for the non maskable interrupt must begin at this location if this interrupt is used.

HALT EXIT

Whenever a software halt instruction is executed the CPU begins executing NOP’s until an interrupt is received (either a non maskable or a maskable interrupt while the interrupt flip flop is enabled). The two interrupt lines are sampled with the rising clock edge during each T4 state as shown in figure 7. If a non maskable interrupt has been received or a maskable interrupt has been received and the interrupt enable flip-flop is set, then the halt state will be exited on the next rising clock edge. The following cycle will then be an interrupt acknowledge cycle corresponding to the type of interrupt that was received. If both are received at this time, then the non maskable one will be acknowledged since it has highest priority. The purpose of executing NOP instructions while in the halt state is to keep the memory refresh signals active. Each cycle in the halt state is a normal M1 (fetch) cycle except that the data received from the memory is ignored and a NOP instruction is forced internally to the CPU. The halt acknowledge signal is active during this time to indicate that the processor is in the halt state.

NON MASKABLE INTERRUPT REQUEST OPERATION

FIGURE 6

HALT EXIT

FIGURE 7
## Appendix E3  Instruction Set Summary

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADC HL, ss</td>
<td>Add with Carry Reg. pair ss to HL</td>
</tr>
<tr>
<td>ADC A, s</td>
<td>Add with carry operand s to Acc.</td>
</tr>
<tr>
<td>ADD A, n</td>
<td>Add value n to Acc.</td>
</tr>
<tr>
<td>ADD A, r</td>
<td>Add Reg. r to Acc.</td>
</tr>
<tr>
<td>ADD A, (HL)</td>
<td>Add location (HL) to Acc.</td>
</tr>
<tr>
<td>ADD A, (IX+d)</td>
<td>Add location (IX+d) to Acc.</td>
</tr>
<tr>
<td>ADD A, (IY+d)</td>
<td>Add location (IY+d) to Acc.</td>
</tr>
<tr>
<td>ADD HL, ss</td>
<td>Add Reg. pair ss to HL</td>
</tr>
<tr>
<td>ADD IX, pp</td>
<td>Add Reg. pair pp to IX</td>
</tr>
<tr>
<td>ADD IY, rr</td>
<td>Add Reg. pair rr to IY</td>
</tr>
<tr>
<td>AND s</td>
<td>Logical ‘AND’ of operand s and Acc.</td>
</tr>
<tr>
<td>BIT b, (HL)</td>
<td>Test BIT b of location (HL)</td>
</tr>
<tr>
<td>BIT b, (IX+d)</td>
<td>Test BIT b of location (IX+d)</td>
</tr>
<tr>
<td>BIT b, (IY+d)</td>
<td>Test BIT b of location (IY+d)</td>
</tr>
<tr>
<td>BIT b, r</td>
<td>Test BIT b of Reg. r</td>
</tr>
<tr>
<td>CALL cc, nn</td>
<td>Call subroutine at location nn if condition cc if true</td>
</tr>
<tr>
<td>CALL nn</td>
<td>Unconditional call subroutine at location nn</td>
</tr>
<tr>
<td>CCF</td>
<td>Complement carry flag</td>
</tr>
<tr>
<td>CP s</td>
<td>Compare operand s with Acc.</td>
</tr>
<tr>
<td>CPD</td>
<td>Compare location (HL) and Acc. decrement HL and BC</td>
</tr>
<tr>
<td>CPDR</td>
<td>Compare location (HL) and Acc. decrement HL and BC, repeat until BC=0</td>
</tr>
<tr>
<td>CPI</td>
<td>Compare location (HL) and Acc. increment HL and decrement BC</td>
</tr>
<tr>
<td>CPIR</td>
<td>Compare location (HL) and Acc. increment HL, decrement BC repeat until BC=0</td>
</tr>
<tr>
<td>CPL</td>
<td>Complement Acc. (1’s comp)</td>
</tr>
<tr>
<td>DAA</td>
<td>Decimal adjust Acc.</td>
</tr>
<tr>
<td>DEC m</td>
<td>Decrement operand m</td>
</tr>
<tr>
<td>DEC IX</td>
<td>Decrement IX</td>
</tr>
<tr>
<td>DEC IY</td>
<td>Decrement IY</td>
</tr>
<tr>
<td>DEC ss</td>
<td>Decrement Reg. pair ss</td>
</tr>
<tr>
<td>DI</td>
<td>Disable interrupts</td>
</tr>
<tr>
<td>DJNZ e</td>
<td>Decrement B and Jump relative if B≠0</td>
</tr>
<tr>
<td>EI</td>
<td>Enable interrupts</td>
</tr>
<tr>
<td>EX (SP), HL</td>
<td>Exchange the location (SP) and HL</td>
</tr>
<tr>
<td>EX (SP), IX</td>
<td>Exchange the location (SP) and IX</td>
</tr>
<tr>
<td>EX (SP), IY</td>
<td>Exchange the location (SP) and IY</td>
</tr>
<tr>
<td>EX AF, AF'</td>
<td>Exchange the contents of AF and AF'</td>
</tr>
<tr>
<td>EX DE, HL</td>
<td>Exchange the contents of DE and HL</td>
</tr>
<tr>
<td>EXX</td>
<td>Exchange the contents of BC, DE, HL with contents of BC', DE', HL' respectively</td>
</tr>
<tr>
<td>HALT</td>
<td>HALT (wait for interrupt or reset)</td>
</tr>
<tr>
<td>IM 0</td>
<td>Set interrupt mode 0</td>
</tr>
<tr>
<td>IM 1</td>
<td>Set interrupt mode 1</td>
</tr>
<tr>
<td>IM 2</td>
<td>Set interrupt mode 2</td>
</tr>
<tr>
<td>IN A, (n)</td>
<td>Load the Acc. with input from device n</td>
</tr>
<tr>
<td>IN r, (C)</td>
<td>Load the Reg. r with input from device (C)</td>
</tr>
<tr>
<td>INC (HL)</td>
<td>Increment location (HL)</td>
</tr>
<tr>
<td>INC IX</td>
<td>Increment IX</td>
</tr>
</tbody>
</table>

Reprinted by permission of Zilog, Inc. Copyright © 1977
<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>INC (IX+d)</td>
<td>Increment location (IX+d)</td>
</tr>
<tr>
<td>INC IY</td>
<td>Increment IY</td>
</tr>
<tr>
<td>INC (IY+d)</td>
<td>Increment location (IY+d)</td>
</tr>
<tr>
<td>INC r</td>
<td>Increment Reg. r</td>
</tr>
<tr>
<td>INC ss</td>
<td>Increment Reg. pair ss</td>
</tr>
<tr>
<td>IND</td>
<td>Load location (HL) with input from port (C), decrement HL and B</td>
</tr>
<tr>
<td>INDR</td>
<td>Load location (HL) with input from port (C), decrement HL and decrement B, repeat until B=0</td>
</tr>
<tr>
<td>INI</td>
<td>Load location (HL) with input from port (C); and increment HL and decrement B</td>
</tr>
<tr>
<td>INIR</td>
<td>Load location (HL) with input from port (C), increment HL and decrement B, repeat until B=0</td>
</tr>
<tr>
<td>JP (HL)</td>
<td>Unconditional Jump to (HL)</td>
</tr>
<tr>
<td>JP (IX)</td>
<td>Unconditional Jump to (IX)</td>
</tr>
<tr>
<td>JP (IY)</td>
<td>Unconditional Jump to (IY)</td>
</tr>
<tr>
<td>JP cc, nn</td>
<td>Jump to location nn if condition cc is true</td>
</tr>
<tr>
<td>JP nn</td>
<td>Unconditional jump to location nn</td>
</tr>
<tr>
<td>JP C, e</td>
<td>Jump relative to PC+e if carry=1</td>
</tr>
<tr>
<td>JR e</td>
<td>Unconditional Jump relative to PC+e</td>
</tr>
<tr>
<td>JP NC, e</td>
<td>Jump relative to PC+e if carry=0</td>
</tr>
<tr>
<td>JR NZ, e</td>
<td>Jump relative to PC+e if non zero (Z=0)</td>
</tr>
<tr>
<td>JR Z, e</td>
<td>Jump relative to PC+e if zero (Z=1)</td>
</tr>
<tr>
<td>LD A, (BC)</td>
<td>Load Acc. with location (BC)</td>
</tr>
<tr>
<td>LD A, (DE)</td>
<td>Load Acc. with location (DE)</td>
</tr>
<tr>
<td>LD A, I</td>
<td>Load Acc. with I</td>
</tr>
<tr>
<td>LD A, (nn)</td>
<td>Load Acc. with location nn</td>
</tr>
<tr>
<td>LD A, R</td>
<td>Load Acc. with Reg. R</td>
</tr>
<tr>
<td>LD (BC), A</td>
<td>Load location (BC) with Acc.</td>
</tr>
<tr>
<td>LD (DE), A</td>
<td>Load location (DE) with Acc.</td>
</tr>
<tr>
<td>LD (HL), n</td>
<td>Load location (HL) with location n</td>
</tr>
<tr>
<td>LD dd, nn</td>
<td>Load Reg. pair dd with value nn</td>
</tr>
<tr>
<td>LD HL, (nn)</td>
<td>Load HL with location (nn)</td>
</tr>
<tr>
<td>LD (HL), r</td>
<td>Load location (HL) with Reg. r</td>
</tr>
<tr>
<td>LD I, A</td>
<td>Load I with Acc.</td>
</tr>
<tr>
<td>LF IX, nn</td>
<td>Load IX with value nn</td>
</tr>
<tr>
<td>LD IX, (nn)</td>
<td>Load IX with location (nn)</td>
</tr>
<tr>
<td>LD (IX+d), n</td>
<td>Load location (IX+d) with value n</td>
</tr>
<tr>
<td>LD (IX+d), r</td>
<td>Load location (IX+d) with Reg. r</td>
</tr>
<tr>
<td>LD IY, nn</td>
<td>Load IY with value nn</td>
</tr>
<tr>
<td>LD IY, (nn)</td>
<td>Load IY with location (nn)</td>
</tr>
<tr>
<td>LD (IY+d), n</td>
<td>Load location (IY+d) with value n</td>
</tr>
<tr>
<td>LD (IY+d), r</td>
<td>Load location (IY+d) with Reg. r</td>
</tr>
<tr>
<td>LD (nn), A</td>
<td>Load location (nn) with Acc.</td>
</tr>
<tr>
<td>LD (nn), dd</td>
<td>Load location (nn) with Reg. pair dd</td>
</tr>
<tr>
<td>LD (nn), HL</td>
<td>Load location (nn) with HL</td>
</tr>
<tr>
<td>LD (nn), IX</td>
<td>Load location (nn) with IX</td>
</tr>
<tr>
<td>LD (nn), IY</td>
<td>Load location (nn) with IY</td>
</tr>
<tr>
<td>LD R, A</td>
<td>Load R with Acc.</td>
</tr>
<tr>
<td>LD r, (HL)</td>
<td>Load Reg. r with location (HL)</td>
</tr>
<tr>
<td>LD r, (IX+d)</td>
<td>Load Reg. r with location (IX+d)</td>
</tr>
<tr>
<td>LD r, (IY+d)</td>
<td>Load Reg. r with location (IY+d)</td>
</tr>
<tr>
<td>LD r, n</td>
<td>Load Reg. r with value n</td>
</tr>
<tr>
<td>LD r, r'</td>
<td>Load Reg. r with Reg. r'</td>
</tr>
<tr>
<td>LD SP, HL</td>
<td>Load SP with HL</td>
</tr>
<tr>
<td>LD SP, IX</td>
<td>Load SP with IX</td>
</tr>
<tr>
<td>LD SP, IY</td>
<td>Load SP with IY</td>
</tr>
<tr>
<td>LDD</td>
<td>Load location (DE) with location (HL), decrement DE, HL and BC</td>
</tr>
<tr>
<td>LDDR</td>
<td>Load location (DE) with location (HL), decrement DE, HL and BC; repeat until BC=0</td>
</tr>
<tr>
<td>LDI</td>
<td>Load location (DE) with location (HL), increment DE, HL, decrement BC</td>
</tr>
<tr>
<td>LDIR</td>
<td>Load location (DE) with location (HL), increment DE, HL, decrement BC and repeat until BC=0</td>
</tr>
<tr>
<td>NEG</td>
<td>Negate Acc. (2's complement)</td>
</tr>
<tr>
<td>NOP</td>
<td>No operation</td>
</tr>
</tbody>
</table>
OR s   Logical ‘OR’ or operand s and Acc.
OTDR  Load output port (C) with location (HL) decrement HL and B, repeat until B=0
OTIR  Load output port (C) with location (HL), increment HL, decrement B, repeat until B=0
OUT (C), r Load output port (C) with Reg. r
OUT (n), A Load output port (n) with Acc.
OUTD  Load output port (C) with location (HL)
OUTI  Load output port (C) with location (HL), increment HL and decrement B
POP IX Load IX with top of stack
POP IY Load IY with top of stack
POP qq Load Reg. pair qq with top of stack
PUSH IX Load IX onto stack
PUSH IY Load IY onto stack
PUSH qq Load Reg. pair qq onto stack
RES b, m Reset Bit b of operand m
RET  Return from subroutine
RET cc Return from subroutine if condition cc is true
RETI  Return from interrupt
RETN  Return from non maskable interrupt
RL m  Rotate left through carry operand m
RLA  Rotate left Acc. through carry
RLC (HL) Rotate location (HL) left circular
RLC (IX+d) Rotate location (IX+d) left circular
RLC (IY+d) Rotate location (IY+d) left circular
RLC r  Rotate Reg. r left circular
RLCA Rotate left circular Acc.
RLD  Rotate digit left and right between Acc. and location (HL)
RR m  Rotate right through carry operand m
RRA  Rotate right Acc. through carry
RRC m  Rotate operand m right circular
RRCA Rotate right circular Acc.
RRD Rotate digit right and left between Acc. and location (HL)
RST p Restart to location p
SBC A, s Subtract operand s from Acc. with carry
SBC HL, ss Subtract Reg. pair ss from HL with carry
SCF  Set carry flag (C=1)
SET b, (HL) Set Bit b of location (HL)
SET b, (IX+d) Set Bit b of location (IX+d)
SET b, (IY+d) Set Bit b of location (IY+d)
SET b, r Set Bit b of Reg. r
SLA m  Shift operand m left arithmetic
SRA m  Shift operand m right arithmetic
SRL m  Shift operand m right logical
SUB s Subtract operand s from Acc.
XOR s  Exclusive ‘OR’ operand s and Acc.
GLOSSARY

Accumulator  A temporary register where results of calculations may be stored by the central processor. One or more accumulators may be part of the arithmetic-logical unit.

Acoustical coupler  A device that permits a terminal to be connected to the computer via a telephone line. It connects to the telephone handset.

Address  An identifying number or label for locations in the memory.

Algorithm  A step-by-step solution to a problem in a finite number of steps. A specific procedure for accomplishing a desired result.

ASCII  American Standard Code for Information Interchange. Widely used 7-bit standard code. Also known as USASCII; IBM uses EBCDIC, which has 8 bits.

Assembler  A program that converts symbolic instructions into machine macro-instructions.

Backplane  A board equipped with plugs interconnected by buses into which the modules that make up a computer may be inserted. Also known as a motherboard.

BASIC  Beginner's All-purpose Symbolic Instruction Code. Algebraic language developed at Dartmouth College. The language is easy to learn and use.

Binary  A numbering system based on multiples of two using the digits 0 and 1.

Bit  Abbreviation of binary digit. A single element in a binary number—either a 0 or a 1. Bits are represented in a microcomputer by the status of electronic switches that can be either on or off. Four bits equal a nibble; eight bits equal a byte.

Byte  A group of adjacent bits, usually eight bits, which is operated upon as a unit by the central processor.

CMOS  Complementary Metal-Oxide Semiconductor. Technology that combines the component density of p-channel MOS (PMOS) and the speed of n-channel MOS (NMOS). Power consumption is very low.

Clock  A device that generates regular pulses that synchronize events throughout a microcomputer.

Central processor  The central processor controls the operation of a microcomputer. The central processor can fetch and store data and instructions from memory.

CRT  Cathode-Ray Tube. An electronic vacuum tube that can be used for graphic display. Also refers to a terminal incorporating a CRT.

Compiler  A program that translates high-level programming language into machine language. May produce numerous macro-instructions for each high-level instruction, unlike an assembler which translates item for item. When using a compiler, one cannot change a program without recompilation.

Development system  A microcomputer system having all the related equipment necessary for hardware and software development.

Digital  Pertaining to discrete integral numbers in a given base which may express all
the variables occurring in a problem. Represented electronically by 2 (binary) to 16 (hexadecimal) states at the present time. Contrasts with analog, which refers to a continuous range of voltage or current quantities.

**Double density** Method of doubling bit density on magnetic storage mediums.

**Dynamic memory** Storage of data on dynamic chips in which storage of a small charge indicates a bit. Because the charge leaks over time, dynamic memory must be periodically refreshed.

**EBCDIC** IBM's 8-bit code, similar to ASCII.

**Editor** A program that rearranges text. Permits the addition or deletion of symbols and changes of format.

**EIA-RS-232C** Interface standard for data transmitted sequentially that is not synchronous with the central processor.

**EPROM** Erasable-Programmable Read-Only Memory. A PROM that can be erased and reprogrammed. Some EPROMs have a quartz window over the chip; data can be erased by exposure to intense ultraviolet light; other EPROMs may be erased electrically.

**File** A set of related records treated as a unit.

**Flag** A bit attached to a word for identification or for the purpose of signaling some condition. Typical microprocessors include carry, zero, sign, overflow and half-carry status flags.

**Floating-point package** A set of software routines that allows some microcomputers to perform floating-point arithmetic without the addition of extra hardware.

**FSK** Frequency Shift Keying. Technique of transforming bits into two different frequencies representing 0 and 1 for transmission over telephone or radio lines. The interface device is called a modem.

**Ground** Electrical reference point of a circuit.

**Hard-copy** Printed output on paper.

**Hardware** The physical components, peripherals, or other equipment that make up a computer system. Contrast with software.

**Hexadecimal** A numbering system based on multiples of 16 using the character 0 thru 9 and A thru F. For example, 0B hexadecimal equals 0000 1011 binary. One byte may be encoded in exactly 2 hexadecimal symbols.

**High-level language** A programming language that is relatively independent of assembler or machine language. The grammar often resembles English and requires a compiler or interpreter to convert to executable code. Examples: BASIC, FORTRAN, COBOL, ALGOL, PL/M, APL.

**Instruction** A step in a program that defines an operation together with the address(es) of any data needed for the operation.

**Interface** A common boundary between two systems or devices. The hardware or software necessary to interconnect two parts of a system.

**Interrupt** A break in the execution of a program usually caused by a signal from an
external device.

**Kansas City standard** Refers to a standard for cassette tape recordings of EIA-RS-232C data. Eight cycles of 2400 Hz equals 1, and 4 cycles of 1200 Hz equals 0.

**Least significant bit** The binary digit occupying the right-most position in a number or word, ie: 2⁰ or 1.

**LIFO** Last-In, First-Out. Method of accessing the most recent entry, then the next most recent, and so on.

**Light pen** Photosensitive device that can be used to change the display on a CRT by generating a pulse at the point of contact.

**Machine language** Sets of binary integers that may be directly executed as instructions by the microcomputers without prior interpretation.

**Mass storage** Floppy disks, cassettes or tapes used to store large amounts of data. Less accessible, but larger than main storage.

**Memory** Storage device for binary information.

**Microcomputer** A small computer system capable of performing a basic repertoire of instructions. Includes a central processor, often contained on a single chip, memory, I/O devices, and power supply.

**Microprocessor** A central processor on a chip. A complete processor on a single chip, manufactured using microminiature manufacturing techniques, known as LSI (large scale integration).

**Modem** MOdulator—DEModulator. Device that transforms binary data into frequencies suitable for transmission over telephone lines and back again.

**Monitor** A program that controls the operation of basic routines to optimize computer time.

**Most significant bit** The binary digit occupying the left-most position in a number or word, usually 2¹ or 128.

**Octal** A numbering system based on multiples of eight using digits 0 thru 7. Now largely superseded by the hexadecimal system.

**Operating system** Software that operates the hardware resources of a microcomputer. The operating system may do scheduling, debugging, I/O control, accounting, compilation, storage assignment, and data management.

**Parity** An extra bit that indicates whether a computer word has an odd or even number of 1s. Used to detect errors.

**Peripheral** Any piece of equipment, usually an I/O device, attached to the central processor.

**Programmable memory** Storage in which access to new information is independent of the address previously examined.

**Read-only memory (ROM)** Storage that cannot be altered. The information is written at the time of manufacture.

**Register** A memory device directly accessible by the central processor used for the
temporary storage of a computer word during arithmetic, logical, or input/output operations.

S-100  A 100-pin bus used in the popular 8080/Z80 system.

Software  Programs that translate high-level languages into machine language, such as compilers, operating systems, assemblers, generators, library routines, and editors.

Stack  A technique of presenting programs sequentially. A stack is a LIFO structure controlled by PUSH and POP instructions.

Tiny BASIC  The BASIC programming language reduced to a simple form that permits integer arithmetic and some string operations. Tiny BASIC usually occupies 4 K or less bytes of memory.

Three-state  Capable of existing in three logical states—0 (low), 1 (high), or undefined (high-impedance), ie: floating.

UART  Universal Asynchronous Receiver Transmitter. A transmitter that converts serial to parallel and vice versa.

Word  A set of bits that occupies one storage location and is treated as a unit. May have any number of bits, but usually 4, 8, or 16.

Word processor  A text editor that allows the user to modify text: formats, books, letters, and reports.
INDEX

Accumulators, 27, 33
ADC, 51, 63
ADD, 49, 63
Addressing, 29, 32-33, 98, 105
   capability, 32
   high-order, 32
   low-order, 32
AND, 34, 54
Arithmetic and Logic Unit (ALU), 21-22, 29
ASCII, 129, 131, 134, 138, 220
BASIC, 131, 183
Binary-coded decimal (BCD), 31, 61, 184
BIT, 75
Bits:
   flag, 33
   least significant (LSB), 184
   manipulation, 32, 75
   most significant (MSB), 184
   start and stop, 139
Branching:
   conditional, 80
   unconditional, 79
Buffering, 98
   address bus, 99
   data bus, 100
Buses, 22
   address, 29, 85, 98, 105, 110
   architecture, 24
   buffering, 98
   control, 100
   signals, 101
   testing, 105
   data, 22, 29, 85, 100, 116
      bi-directional, 22, 100, 105
   drivers, 93, 99-100
      testing, 105
   power, 98
   structures, 22
   voltage, 19
Bytes, 32
CALL, 82, 152
Capacitance, 14
Capacitors, 2, 5-6, 97
   bypass, 14
   charging time, 5
   filter, 2, 4, 14
   ripple factor of, 4
   input, 14
   sizing, 5
   time constants of, 6
Carry, 28
   flag, 51, 80
Cassettes, 121, 129, 145
   interface, 113, 145, 148-149
   Kansas City Standard, 146
   software, 148
CCF, 60
Central processors (see also Microprocessors), 21-22, 27
   architecture, 27
   control, 29, 32
   registers, 27-29
   status, 33
   synchronizing, 97
   testing, 122
   timing, 92
Characters, 213
   format, 214
Chip select, 116
Circuits:
   complexity, 21, 23
   integrated, 10, 22
   layouts, 14
   protective, 10
   reset, 97
Clocks, 91, 209
   periods, 91
   real-time, 208
   single-stepping, 92, 105
   testing, 105
COM 8046, 220
COM 2017, 220
Communication, 138
   asynchronous, 139, 142
   parallel and serial, 138
   software, 148
   signal levels, 142
      standard, 144
Cooling, 17
Control section, 22
Controllers, intelligent, 183
Converters:
   analog-to-digital, 184, 189
      analog to pulse width, 189
      binary-ramp counter, 191
      successive approximation, 194
      3½-digit AC/DC, 199
      software, 205
   digital-to-analog, 184
      calibration, 188
      multiplying, 186
      R-2R, 184
      weighted-resistor, 184
Cost, 23
CPU, 57
CPD, 48
CPDR, 48
CPI, 47
CPIR, 47
CPL, 60
CRT 8002, 213
CRT 5027, 213
Currents:
   continuous, 6
   regulator, 5
   surge, 6
DAA, 61
Data, 22, 33, 112, 116
   acquisition, 198, 208
   ASCII, 138
   communication, 138
   formats, 32
   high- and low-order, 33
   rates, 142, 148, 220
DEC, 59, 65
Decoding:
   hexadecimal, 135
   I/O, 91, 105-106, 108
   memory, 91, 105-106, 110
   testing, 111
Demultiplexers, 108, 206

INDEX 329
DI, 62
Diodes, 3, 5-6, 97
bridges, 5-6, 16
silicon, 3
zener, 8, 10
Direct memory access (DMA), 99, 129
Displays:
cathode-ray tube (CRT), 129, 138, 213
hexadecimal, 134
light-emitting diode (LED), 93, 121, 129, 134, 153
octal, 134
video, 121, 183, 213
visual, 129, 134
DJNZ, 82
Drivers:
bus, 93
display, 93
LED, 93
EI, 62
8080A, 24, 31, 91
8212, 100
EX, 44
EXX, 44
Fanout, 98
Farads, 5
Flags, 33
carry (C), 51, 80
condition, 33-34
status, 33
zero (Z), 75, 80
Flip-flops, 92, 132
Frequency shift keying (FSK), 146
Full-wave bridges (see also Rectifiers), 3, 5
Fuses, 17
Grounds, 15
buses, 15
common, 14
references, 11
single-point, 15
HALT, 30, 62
Heat sinks, 16
HP7340, 135
IM, 62
IN, 85, 122
INC, 58, 64
IND, 87
INDR, 87
Inductance, 14
INI, 86
INIR, 86
Input, 21, 85, 122
filters, 2-3
Input/output, 121, 129
decoding, 91, 105
testing, 111
instructions, 32, 85
ports, 98, 105, 108
read, 106
registers, 91
request, 30, 106
testing, 122, 127
write, 106
Instructions, 21
arithmetic and logical, 31
8-bit, 49
general purpose, 60
16-bit, 63
bit manipulation, 32, 75
block transfer and search, 31, 44
call and return, 32, 82, 152
CPU control, 32, 60
cycle, 91
exchange, 28, 31, 44
execution, 92
fetch cycle, 29, 91-92
formats, 32
input and output, 32, 85, 88, 122
jump, 32, 78
load, 31
8-bit, 34
16-bit, 39
pop, 43
push, 42
restart, 152
rotate and shift, 31, 66
sets, 33
single-stepping, 92
testing, 105
types, 31
Interfaces:
cassette, 145
tuning, 149
clock, 209
RS-232C, 213
serial, 129, 138, 142
3½-digit AC/DC, 199
testing, 205
Interrupts, 30, 62, 84
non-maskable, 30, 84
page address, 29
JP, 78
JR, 79
Kansas City Standard, 146
Keyboards, 113, 121, 129
ASCII, 129, 134
bounce, 132
encoders, 131-132, 220
hexadecimal, 133
input software, 163
KR2376, 220
LD, 34
LDD, 46
LDDR, 46
LDI, 45
LDIR, 46
Light-emitting diodes (LED), 93, 121
drivers, 93
Loads, 7, 99
TTL, 93
Logic analyzers, 91, 93, 99
Low-power Schottky TTL (LSTTL), 98
Machine cycles, 29, 91
Memory, 21, 32, 91, 112
addresses, 32, 97, 110
banks, 110, 117
contents, 34
decoding, 91, 105, 110
testing, 111
direct memory access (DMA), 99
display and replace, 151, 153
dynamic, 116
erasable-programmable read-only (EPROM), 112, 115, 152
erasers, 177
programmers, 173
automatic, 174
manual, 173
locations, 28
map, 117
page, 213
programmable, 27, 110
debugging, 153
development, 153
PUSH, 42
Rectifiers (see also Full-wave bridges), 6, 14
bridge, 2, 5, 16
full-wave, 3, 5
silicon-controlled (SCR), 18-19
Refresh, 29-30, 116
Registers, 27-28
accumulator (A), 27-28, 33
contents, 34
display and replace, 151, 154
8-bit (B, C, D, E, H, L), 27, 112
flag (F), 27-28, 33
general purpose, 28
index (IX, IY), 29
instruction, 29
interrupt page address (I), 29
main and alternate, 28-29
memory refresh (R), 29
pairs, 28, 33, 39
program counter (PC), 28, 32, 78, 82, 152
sets, 27-28
16-bit (BC, DE, HL), 27
special purpose, 28
stack pointers (SP), 28, 42, 152
Regulators, voltage (see Voltages, regulators)
Requests, 106
input/output, 106
memory, 106
read, 106
write, 106
RES, 78
Resets, 62, 97, 152
automatic, 97
manual, 97
testing, 105, 127
Resistance, 4, 6, 15
series, 6, 8
thermal, 16
Resistors, 19, 185
ladder, 185
variable, 8
Resolution, 184, 187, 198
RET, 83
RETI, 84
RETN, 84
Ripple factor, 4
RL, 68
RIA, 66
RLC, 67
RLCA, 66
RLD, 74
RR, 70
RRA, 66
RRC, 69
RRCA, 66
RRD, 75
RS-232C, 144, 213
RST, 84, 152
Sample rates, 194, 197
SBC, 53, 64
SCF, 60
SET, 76
78H05, 10, 16
78L2, 12
79L2, 12
Short-circuits, 18
Sign, 28
Sine waves, 3

INDEX 331
busing and control logic, 91
pinout, 29
Z80 Applications Processor (ZAP), vii, 1, 91
testing, 123, 127
Zero, 28
flag, 75, 80

SLA, 71
Software (see also Monitors), 24
monitor, 151
single-stepping, 92
SRA, 72
SRL, 73
Stacks, 28, 32, 42, 82, 152
Strobes:
data-ready, 130
duration, 132
key-pressed, 139
SUB, 52
Subroutines, 28, 82, 118
Surge currents, 6
Terminals, 213
Testing:
dynamic, 127
static, 123
Thermal considerations, 15
Timers, 130
Transformers, 1, 6
primary input to, 3
secondary output from, 3-4
Transistor-transistor logic (TTL), 93, 98, 217
levels, 142
loads, 93
low-power Schottky (LSTTL), 98, 217
outputs, 138, 146
Transistors, 8, 17
FAMOS, 115, 173
series-pass, 10
wide-band, 14
2114, 117
2102A, 117
2708, 113, 173
2716, 113, 173
Universal synchronous receiver/transmitter (UART), 139, 220
diagnostic, 156
output, 146
pinout, 139
Voltages:
alternating current, 1
comparators, 7-8
control element, 7
direct current (DC), 1
drops, 3, 6, 11, 14
input and output, 7, 14
loads, 5
peak, 4, 15
peak inverse (PIV), 6
reference, 7, 10
regulators, 1, 3-4, 7, 10, 16
choosing, 10
overloads, 10
series, 8
three-terminal, 9-10
ripple, 4-5, 14
root mean square (RMS), 3, 6
sine waves, 2
transients, 6
translators, 7-8
VAC, 1, 3
waveforms, 3-4
Voltmeters, 93, 184, 199
Waits, 30, 92
XOR, 56
Z80, 24, 27
bus structure, 25
BY THE SAME AUTHOR

CIARCIA'S CIRCUIT CELLAR
1979, 128 pages
This volume provides a wealth of imaginative and practical microcomputer projects. Selected from the popular series in BYTE magazine, topics included D/A conversion, programming EPROMS, AC remote-controlled appliances, digitized speech, and touch input video display.

CIARCIA'S CIRCUIT CELLAR, VOLUME II
1981, 224 pages
Presented in the same easy-going style and sprinkled with amusing anecdotes, this second volume offers more practical uses for the home computer. Focused on how microcomputers can be uniquely interfaced to our environment, projects cover building a computer-controlled home security system, computerizing appliances, transmitting digital information over a beam of light, building the Intel 8086 microprocessor system design kit, and input/output expansion for the TRS-80.

ALSO FROM BYTE BOOKS

THREADED INTERPRETIVE LANGUAGES
Ronald Loeliger, Senior Analyst with Intermetrics, Inc.
1981, 272 pages
This text on threaded languages (such as FORTH) develops an interactive, extensible language with specific routines for the Zilog Z80 microprocessor.

BEGINNER'S GUIDE FOR THE UCSD PASCAL SYSTEM
Kenneth L. Bowles, Director of the Institute for Information Systems, University of California, San Diego
1980, 204 pages
Written by the originator of the UCSD Pascal System for users of microcomputers and minicomputers, this book is both an orientation guide to the System and an invaluable reference tool for creating advanced applications.

THE BYTE BOOK OF PASCAL
Blaise W Lifick, Editor
1980, 334 pages
Written for both potential and experienced computer users, this valuable software resource introduces the Pascal language and examines its merits and possible implementations.
Build Your Own Z80 Computer:
Design Guidelines and Application Notes

"There is a major need for a book such as this. The information is not readily available elsewhere. Or anywhere. There are dozens (hundreds?) of microprocessor books, but nearly all deal with software and treat hardware as abstractions or block diagrams. Ciarcia's book is literally filled with very useful and practical "hands-on" hardware advice, tips and techniques....The book will do for the reader what no other microprocessor book or manufacturer's literature I know of does: It will enable a person to actually buy individual parts and assemble them into a working microcomputer—with peripherals and options! That's very important. Too bad we couldn't have had such a book years ago."

—Forrest Mims, III
Contributing Editor of POPULAR ELECTRONICS

"To my knowledge the material covered in this book is not available elsewhere. There is sufficient detail to enable an individual with previous experience to assemble a working Z80-based microcomputer from the component level. The design trade-offs, the circuits, the software, and the test circuits and procedures are discussed at a level sufficient for the book to have educational value even if one did not actually construct a Z80-based system."

—Joseph Nichols
Digital Analysis Corporation

About the Author
Steve is a computer consultant, electrical engineer, author of BYTE magazine's most popular column, "Ciarcia's Circuit Cellar," and a "national technological treasure."