# Microcomputer Interfacing and Programming ## **Preface** In 1971, the first microprocessor chips became commercially available. These were the Intel Corporation 4004 four-bit microprocessor chips which, while somewhat difficult to use in real computer applications, nevertheless did lead the way in control applications where they are still widely used today. The Intel 8008 eight-bit microprocessor followed quickly, and permitted the user to configure a small general-purpose "computer." At the time, several companies started to offer standard logic cards that had the necessary control logic, memory, and input/output buffers so that real applications could be tackled. After the announcement of the 8008 chip, many semiconductor companies scrambled to get on the mciroprocessor bandwagon. Intel followed with their powerful 8080, Motorola with the 6800, Fairchild with the F-8, and so on through dozens of companies and microprocessor chips. Early in 1977, we witnessed a surge of "computer-on-a-chip" devices that contain, in a single integrated-circuit chip package, all the necessary logic, memory, and I/O capability to construct a small micro- computer. Not only are microcomputers finding widespread use in control and instrumentation applications, they have also spawned the hobby computer market. Five years ago, some hobbyists may have dreamed of having their own computers, but few had one. Now, thousands of ameteurs have small computers that are being used for general programming applications, playing games, providing real estate listings, maintaining inventories, and saving energy in the home. The publication of the Mark 8 construction article in *Radio-Electronics* in July 1974 started the flood. Based upon the 8008 microprocessor chip, the Mark 8 provided computer hobbyists with the means of having their own computer. Later followed by commercial models manufactured by MITS, Inc., Southwest Technical Products Corp., Cromemco, Inc., IMSAI Manufacturing Corp., and many other companies, thousands of microcomputers can now be found in homes in the United States. This is just the beginning. We can safely predict that home entertainment/communication centers based upon the marriage of television sets, LSI game chips, and microcomputers will be sold by the millions as a major consumer product within several years. If Congress and the FCC can come to grips with the communications revolution spawned by LSI technology and optical fibers, the next step will be expanded digital communications between homes, offices, and libraries. Inexpensive microcomputers will eventually penetrate every facet of life. Today, they can be found in automobiles, sewing machines, microwave ovens, TV games, vending machines, gasoline pumps, taxi meters, and so on. Tomorrow, they will be in phones, washers, driers, typewriters, elevators, heating and cooling systems, children's toys, New industries will be created, and some existing ones threatened. How about a moment of silence for the slide rule? The objective of this book is to teach you the four fundamental tasks of microcomputer interfacing: - Device select pulse generation - Microcomputer outputMicrocomputer input - Interrupt servicing in the context of 8080-based microcomputers. We hope to give you the basic concepts of microcomputer interfacing and the associated microcomputer I/O programming so that you can develop your own interfaces to other digital devices, including teletypes, crt displays, panel meters, analog-to-digital converters, digital-to-analog converters, laboratory instruments, and the like. Chapter 1 discusses the future role of microcomputers, the four fundamental tasks of microcomputer interfacing, and summarizes the digital concepts that you will require to make proper use of this book. Chapter 2 describes a small 8080-based microcomputer and discusses the concept of microcomputer input/output in greater detail, especially from the point of view of the use of device select pulses to strobe digital integrated-circuit chips. Chapter 3 provides an introduction to 8080 microcomputer programming. The entire 8080 instruction set is discussed in some detail. Specific attention is focused on data transfer operations, arithmetic and logical operations, branch instructions, input and output instructions, and register decoding. The 8080 instruction set is summarized in a variety of ways. Chapter 4 treats the very important topic of device select pulse generation. A variety of practical and experimental decoder circuits are provided that can generate one, sixteen, or as many as 256 different device select pulses. Chapter 5 describes an extremely useful technique for counting the number of clock cycles required for the execution of segments of microcomputer programs. The technique permits you to verify the theoretical number of clock cycles for every instruction in the 8080 instruction set. Standard programs are provided that generate time delays that are multiples of either 0.5 ms or 0.2 s. Chapter 6, perhaps the most difficult one in this book, provides a description of the internal operation of the 8080 microprocessor chip. The timing behavior of the 8080 is discussed in terms of states, machine cycles, and instruction cycles. Circuits are provided to demonstrate how the IN and OUT control signals can be generated. Chapter 7 discusses the important topic of microcomputer input/output, both the latching of output data and the input of three-state buffered data into the 8080. Circuits and programs are provided that teach you how to detect a specific key on an ASCII keyboard, how to output data to a multiplexed display, and how to log digital data. Chapter 8 discusses in considerable detail several modes of micro- Chapter 8 discusses in considerable detail several modes of microcomputer operation, including polled operation and interrupt operation. The subjects of subroutines, interrupts, external flags, masking, the stack, and the strategy of interrupt servicing and priority interrupt software and hardware are all treated. Finally, an appendix summarizes the entire 8080 instruction set with the aid of Intel instruction-byte diagrams Basically, this book is a revised and expanded version of an earlier book entitled, The Bugbook III: Microcomputer Interfacing Experiments Using the Mark 80 Microcomputer, an 8080 System, marketed by E&L Instruments, Inc., Derby, Connecticut. Experiments present in the original Bugbook III have been either rewritten as examples, incorporated into the text material, or eliminated. The chapter on interrupts and external flags has been expanded considerably over its previous length. Numerous editorial changes have been made to improve the clarity of the material. In this book, we assume that you have a knowledge of the basic concepts of digital electronics, including gates, flip-flops, latches, decoders, multiplexers, three-state and open-collector bussing, memories, shift registers, displays, counters, arithmetic/logic units, and the like. Many such concepts are used in our discussions of microcomputer interfacing. Bugbooks I & II: Logic & Memory Experiments Using TTL Integrated Circuits [E&L Instruments, Inc., 61 First Street, Derby, Connecticut 06418, 706 pages, \$16.95] provide such information. If you wish to interface a microcomputer to a Teletype or crt display, you will need to know some of the basic principles of asynchronous serial digital data communications. To our knowledge, the only book that treats such material in a systematic fashion is Bugbook IIA: Interfacing & Scientific Data Communication Experiments Using the Universal Asynchronous Receiver/Transmitter (UART) and 20 mA Current Loops [E&L Instru- ments, Inc., 70 pages, \$4.95]. ments, Inc., 70 pages, \$4.95]. The authors and Dr. Christopher A. Titus are quite active in microcomputer education and system development and design in Blacksburg. Short courses on digital electronics and microcomputer interfacing are available both on an in-house and a scheduled basis from Tychon, Inc. [call (703) 951-9030] or from the Continuing Education Center and Extension Division of Virginia Polytechnic Institute & State University [call Dr. Norris Bell at (703) 951-6328]. To be placed on the mailing list for future Bugbooks on microcomputer programming, analog electronics, and digital electronics, send your name and address to BUGBOOKS, P.O. Box 715, Blacksburg, Virginia 24060. Finally, we wish to acknowledge the consistent support of Mr. Murray Gallant and E&L Instruments, Inc., in all of our educational efforts in the electronics area. in the electronics area. PETER R. RONY DAVID G. LARSEN JONATHAN A. TITUS # **Contents** ### CHAPTER 1 | What Is a Microcomputer? Introduction to This Chapter—Objectives—Definitions—Review of Digital Electronics—What Is Useful?—Some Helpful References—Data Processor vs. Microprocessor vs. Microcomputer—Hardware vs. Software—Computer vs. Digital Computer—What Is a Controller?—A Typical 8080 Microcomputer—Test—What Have You Accomplished in This Chapter? | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--| | CHAPTER 2 | | | | | | A SMALL 8080 MICROCOMPUTER Objectives—Definitions—The 8080 Microcomputer Chip—The 8224 Clock Generator/Driver Chip—An 8080-Based Microcomputer—What Is Interfacing?—What Is an I/O Device?—Uses for Device Select Pulses—Use of a Microcomputer to Strobe Integrated-Circuit Chips—What Have You Accomplished in This Chapter? | 39 | | | | | CHAPTER 3 | | | | | | AN INTRODUCTION TO MICROCOMPUTER PROGRAMMING Objectives—Definitions—What Is a Computer Program?—What Is an Instruction?—What Is an Operation?—Machine Language—Octal and Hexadecimal Machine Codes—Mnemonic Code—How Do I Go About the Task of Learning Computer Programming—Bit, Byte, Word, and Address—Multibyte Instructions—Instructions vs. Data: How Does the | 93 | | | | Computer Know?—8080 Microprocessor Registers—What Types of Operations Does the 8080 Microprocessor Perform?—8080 Mnemonic Instructions—Octal/Hexadecimal Listing of the 8080 Instruction Set—An Example of Instruction Decoding—Register Decoding—Arithmetic and Logic Operation Decoding—Immediate Operation Decoding—Branch Operation Decoding—Conditional Branch Instructions—Condition Flag Decoding—Register Pair Decoding—Increment and Decrement Operation Decoding—Data and Memory Addressing Modes—Accumulator Instructions—8080 Instruction Summary—Assembly Language—Machine Language vs. Assembly Language Programs—Introduction to the Examples—Example No. 1—Example No. 2—Example No. 3—Example No. 4—Example No. 5—Example No. 10—Example No. 11—Example No. 12—Test—What Have You Accomplished in This Chapter? ### CHAPTER 4 ### CHAPTER 5 ### CHAPTER 6 ### CHAPTER 7 | MICROCOMPUTER INPUT/OUTPUT Objectives—Definitions—Input/Output—Microcomputer Output Circuits -Microcomputer Input Circuits—Input/Output Instructions—Input/Output Programs—Microcomputer Output to a Multiplexed Display—Data Logging With an 8080 Microcomputer—What Have You Accomplished in This Chapter? | 275 | | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|--|--| | CHAPTER 8 | | | | | | SUBROUTINES, INTERRUPTS, EXTERNAL FLAGS, AND STACKS Objectives—Definitions—What Is a Subroutine?—Use of the Stack for Data and Status Storage—When Is a Subroutine Used?—Hardware Integration: SSI, MSI, LSI, and VLSI—Software Integration: SSP, MSP, LSP, and VLSP—The 8080 Subroutine Instructions—The 8080 Stack Instructions—Memory Allocation—Modes of Microcomputer Operation—Basic Types of Interrupts—Enable and Disable Interrupt Instructions—External Flags—Interrupt Mask—Interfacing a Keyboard—Priority Interrupts—Hardware Priority Interrupts—Priority Interrupt Software—Test—What Have You Accomplished in This Chapter? | | | | | | References | 349 | | | | | APPENDIX 2 | | | | | | THE 8080A Instruction Set | | | | | | APPENDIX 3 | | | | | | The 8080 Instruction Set | . 409 | | | | | Index | . 411 | | | | ### **CHAPTER 1** # What Is a Microcomputer? In this book, you will study real examples that demonstrate the principles, concepts, and applications of an 8-bit microcomputer that is based upon the 8080 microprocessor integrated-circuit chip. In doing so, you will be able to participate in a remarkable electronics revolution in which the computer will be transformed from a large, expensive, and rather esoteric machine into a compact, inexpensive, and common device that will be used by millions of individuals. Before very long, you will find small computers in your home, automobile, lawn mower, office, and perhaps even in some of your recreational equipment. These small computers will be everywhere—millions of them! They will have a profound influence upon everyday life. Already, a cousin of the microprocessor chip, the calculator chip, has essentially made the slide rule obsolete. What has happened with the slide rule will happen with other mechanical devices. Large computers will continue to perform complicated mathematical calculations, and small hand-held electronic calculators will perform the simpler ones. Since the common view of the computer is as a calculating machine, one might ask: Where does the microcomputer fit? After all, if the large computers do all of the more difficult calculations and the electronic calculators all of the simple ones, is there anything left for the microcomputer to do? The answer to this seeming dilemma resides in the fact that computers have at least two important functions: As number- and information-crunching machines in which digitally coded information is manipulated at high speeds. As programmable digital controllers that control machines and processes by passing digital signals to and from the computer. The major use of microcomputers will be as controllers, not as information-crunching machines. We could estimate the possible market for microcomputers if we knew how many machines that could be controlled by a microcomputer exist per capita in the United States. The telephone could use a microcomputer, as could an electric type-writer, a television set, a sophisticated child's game, a stereo set, a dishwasher, an electric range, a clothes washer, etc. When one includes homes, offices, industry, and laboratories, there may be between three and ten machines or devices per capita that can be automated with the aid of microcomputers. With 200 million individuals in the U.S., this translates to 600 million to 2 billion microcomputers. The market, for electronic calculators may be no more than 100 million, which is still a large number. The subject of computers is vast, and a series of textbooks can be written to cover the general scope of computer architecture, operation, and applications. This is not the intention with this book, which differs from most texts written on computers in the respect that the primary emphasis will be on the use of a computer as a controller rather than as a number-crunching machine. You will learn how to *interface* a microcomputer, where the word "interface" means the joining of the microcomputer to an instrument, device, or machine in a way such that both operate in a compatible and coordinated fashion. You will focus your attention only on a computer built around an 8080 microprocessor chip. The reasons for doing so are as follows: - Based upon the number of manufacturers who are or will be manufacturing the 8080 microprocessor chip, it is likely that 8080-based microcomputers will be very common. - 2. By the end of 1977, the 8080 microprocessor chip will probably be sold at a price of \$10 in quantities of one, and even less for considerably larger quantities. Such a low price should ensure the popularity of 8080-based microcomputers. - The 8080 microprocessor instruction set is quite powerful. Programs are relatively easy to write. - 4. The 8080 microprocessor is relatively fast. It can execute an arithmetic instruction such as add or subtract in only 2 μs. With improvements in the state of the art, even faster 8080 chips are now available. - An 8080 microcomputer can directly access up to 65,536 different 8-bit memory locations and can generate 256 different input strobe signals and 256 different output strobe signals. <sup>\*</sup>See Appendix 1 for references in the text denoted by superscripts. Owing to the popularity of the 8080 chip, a wide variety of programs will be readily available. Thus the authors believe that your time will best be spent learning the principles, concepts, and applications of a computer of the future, such as the 8080, rather than a computer of the past, such as the PDP-8. This book is concerned with the four fundamental tasks of computer interfacing: - 1. The generation of device select signals. - 2. The latching of output data. - 3. The acquisition of input data. - 4. The servicing of interrupt signals. An extensive series of examples will provide you with the concepts and techniques necessary for developing your own circuits and the writing of your own programs to accomplish one or more of the four fundamental tasks. Once you have mastered these tasks, the world of microcomputer controls will be yours. ### INTRODUCTION TO THIS CHAPTER In the chapters that follow this one, you will encounter a series of examples that will help you to develop competence in *microcomputer* interfacing. Before you do so, however, it would be useful for you to develop an understanding of what a computer is and what the distinctions are between *microcomputers*, *minicomputers*, *computers*, *controllers*, *data processors*, and *logic processors*. In addition, it would be useful for you to gain some insight into the characteristics of the principal "bug" in this book, the 8080 microprocessor chip. This chip, first marketed by Intel Corporation in 1974, is a complete 8-bit parallel central processing unit (CPU), also abbreviated MPU, that is fabricated on a single LSI chip. Simple instructions can be performed in as little as 2 µs, which compares to the 1.2-µs instruction time for similar operations in the Digital Equipment Corp. PDP-8/E minicomputer. The 8080 chip is being "second sourced" by Texas Instruments, Inc., National Semiconductor Corp., NEC, and several other chip manufacturers. Such actions signify that the semiconductor industry is betting that the 8080 will become an important force in the microprocessor market. Any discussion of the 8080 can be subdivided into the following topics: - The pin configuration and pin functions of the 8080 chip. - The organization of a typical microcomputer that employs the 8080 chip. - The internal operation of the 8080 microprocessor. - The instruction set of the 8080 microprocessor. Starting in this chapter and continuing in several chapters, we shall discuss each of these topics. The detail with which we shall do so will vary from topic to topic. The objective is not to bombard you with a fusillade of timing diagrams and machine cycle descriptions, but rather to help you develop the skills that you will need to use an 8080-based breadboard microcomputer system. For the interested reader, the authors recommend the following sources for additional information on the characteristics and operation of the 8080 chip: - Robert H. Cushman, "The Intel 8080: First of the second-generation microprocessors," Electronic Design News 19 (9), p. 30 (May 5, 1974). - Masatoshi Shima and Federico Faggin, "In switch to n-MOS, microprocessor gets a 2-µs cycle time," Electronics 47 (8), p. 95 (April 18, 1974). - Intel Corp., Intel Intellec 8/Mod 80 Microcomputer Development System Reference Manual, Santa Clara, California, 1975. - Intel Corp. Intel 8080 Microcomputer System Manual, Santa Clara, California, September, 1976. - Adam Osborne, An Introduction to Microcomputers. Volume II. Some Real Products, Osborne Associates, Berkeley, California, 1976. - Adam Osborne, 8080 Programming for Logic Design, Osborne Associates, Berkeley, California, 1976. - W. J. Weller, A. V. Shatzel, and H. Y. Nice, Practical Microcomputer Programming. The Intel 8080, Northern Technology Books, 1976. ### **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Explain the difference between a microprocessor and a micro- - Define the terms: computer, digital computer, data processor, controller, hardware, software, memory, memory word, memory address, memory data, read, write, random access memory, read-only - memory, interfacing, device select pulse, and interrupt. Describe different types of computers and controllers on the basis of the following characteristics: word length, complexity, application, cost, memory size, program, speed constraints, input/output, design, and manufacturing volume. • Describe the operation of a typical 8080 microcomputer system. ### MICROPROCESSORS AS MICROCONTROLLERS AND LOGIC PROCESSORS Microprocessor applications tend to fall into the following categories: Table 1-1. The Spectrum of Computer-Equipment Complexity, from Simple Hard-Wired Logic Systems to High-Performance General Data Processing Equipment. This Table Is Based on Pro-Log Corp. Material and Is Adapted From an Article by Wallace B. Riley in the October 17, 1974, Issue of Electronics. | Word Length<br>(Bits) | - | 7 | 4 | æ | 16 | 32 | 2 | |---------------------------------|---------------------------------------|-------------------------|-------------|--------------------------|--------------------|----------------------------------------|--------------------------------------------------------| | Complexity | Hard-Wired | Programmed | Calculator | Microprocessor | Minicomputer | Large ( | Large Computer | | Application | a a a a a a a a a a a a a a a a a a a | Control | <u> </u> | Dedicated<br>Computation | ed<br>tion | Low-Cost<br>General<br>Data-Processing | High-Performance<br>General<br>Data Processing | | \$5<br>0<br>0<br>0<br>0<br>0 | Under<br>\$100<br>(1974) | | | \$1000<br>(1974) | | \$10,000<br>(1974) | \$100,000<br>and Up<br>(1974) | | Memory Size | Very Small<br>0-4 Words | Small<br>2-10 Words | II<br>/ords | Medium<br>10-1000 Words | Lan<br>1000–1 Mill | Large<br>1000–1 Million Words | Very large<br>More Than<br>1 Million Words | | Program<br>Speed<br>Constraints | Read-Only<br>Real Time | Slow | 3 | Medium | E | | Reloadable<br>Throughput-<br>Oriented | | Input-Output | Integrated | Few Simple<br>Devices | mple<br>ces | Some Complex<br>Devices | omplex<br>es | | Roomful of<br>Equipment | | Design | Logic | Logic +<br>Microprogram | -+<br>ogram | | Microp | Microprogram<br>Macroprogram | Macroprogram<br>High-Level Language<br>Software System | | Manufacturing<br>Volume | Large | · | į | | | | Small | - Controllers - Consumer products - Communications - Terminals - Microcomputers Each of these categories is discussed in some detail in the *Microprocessor Handbook*.<sup>3</sup> As shown in Table 1-1 and Fig. 1-1, microprocessor applications fall between relay logic and discrete random logic (gates and flip-flops) on one hand and inexpensive minicomputers such as the LSI-11 and PDP-8/A on the other. Microcomputers fabricated from microprocessors are not as sophisticated as some of the popular minicomputers and cannot easily perform data processing problems. They are simply not set up at this moment to run FOR-TRAN, COBOL, or other high-level languages. The computer power inherent in many of today's 8-bit and 16-bit microcomputers would allow them to do so, but the software support is simply not yet available for them. At the moment, it would be more appropriate to call systems constructed from microprocessor chips by the terms microcontrollers or logic processors. They are excellent programmable sequencers, and can process logic data and make decisions upon such data. Thus, they can sequence events in response to decisions upon input data. ### WHERE MICROCOMPUTERS FIT Fig. 1-1. Applications foreseen for microcomputers. Microcomputers will carve out their own niche between discrete logic and inexpensive minicomputers. When it was first introduced, the Intel 8080 microprocessor chip sold for \$360 in quantities of one. By the end of 1977 the price should drop to \$10 in quantities of one. The price of a piece of equipment containing such a microprocessor will then reflect primarily the mechanical aspects of the equipment, i.e., the housing and electromechanical devices. In this book the emphasis is on control and logic processing applications. The authors don't foresee many 8080-based microcomputers being tied to \$5000 worth of input/output equipment and used in competition with the PDP-11 and competitive minicomputers. Rather, we foresee minicomputer-microcomputer hierarchies in which one to ten instruments and devices containing 8080 chips are all tied to a single minicomputer. An example of such a computer hierarchy is shown in Fig. 1-2. Instruments A through G all communicate directly to the much larger minicomputer through an 8080-based microcomputer contained within each instrument. The instruments are controlled by the 8080 computers, and the minicomputer oversees such control and logs important instrument parameters. The minicomputer might also pro- Fig. 1-2. An example of a computer hierarchy. The individual instruments or machines A through G are controlled by built-in 8080 microprocessors. These microprocessors also communicate back and forth with the minicomputer, which monitors the operation of the entire system. vide the microcomputer control set points at the beginning of each day. Each microcomputer might contain only 2K to 8K of memory, whereas the minicomputer might have a minimum of 16K or 32K of memory to permit it to handle a higher-level language such as FORTRAN or APL. Please keep in mind that future microcomputers will be quite inexpensive, perhaps no more than several hundred dollars for a complete microcomputer system. The more venturesome individuals in the electronics industry predict full microcomputer systems for a cost of \$10 to \$20 in quantities of 100. At such prices, microcomputers will be everywhere. ### **DEFINITIONS** accumulator—The register and associated digital electronic circuitry in the arithmetic unit of a computer in which arithmetic and logical operations are performed. bidirectional-Responsive in opposite directions.4 bidirectional data bus-A data bus in which digital information can be transferred in either direction. bus-A path over which digital information is transferred, from any of several sources to any of several destinations. Only one transfer of information can take place at any one time. While such transfer is taking place, all other sources that are tied to the bus must be disabled. clock-(a) Any device that generates at least one clock pulse, or (b) a timing device in a system that provides a continuous series of timing pulses.4 computer-Any device, usually electronic, capable of accepting information, comparing, adding, subtracting, multiplying, dividing, and integrating this information, and then supplying the results of these processes in acceptable form. The major elements of a computer usually include memory, control, arithmetic, logical, and input and output facilities.4 computer interfacing—The synchronization of digital data transmission between a computer and one or more external input/output devices. controller—An instrument that holds a process or condition at a desired level or status as determined by comparison of the actual value with the desired value.4 data processor-A digital device that processes data. It may be a computer, but in a larger sense it may gather, distribute, digest, analyze, and perform other organization or smoothing operations on data. These operations, then, are not necessarily computational. Data processor is a more inclusive term than computer.2 device select pulse-A synchronization pulse generated by a computer to synchronize the operation of a specific input or output device. digital computer—An electronic instrument capable of accepting, storing and arithmetically manipulating information, which includes both data and the controlling program. The information is handled in the form of coded binary digits (0 and 1) represented by dual voltage levels.<sup>6</sup> digital controller—A controller that acquires the actual value of the condition in digital form and compares it to the desired value contained within the controller. If there is any difference between the two, a digital signal is sent out by the controller to reduce this dif- ference direct address—An address that specifies the location within memory of an instruction or data byte. external device addressing—A device name, expressed as a digital code, that is generated by the CPU to address a specific external device. Both input and output devices can be addressed. fixed-program computer—A computer in which the sequence of instructions is permanently stored or wired. The computer program is not subject to change either by the computer or the programmer except by rewiring or changing the storage input.<sup>5</sup> general-purpose computer—A computer designed to solve a large variety of problems; a stored-program computer which may be adapted to any of a large class of operations.5 hardware—The mechanical, magnetic, electronic, and electrical devices from which a computer or computer system is fabricated; the assembly of material forming a computer system.<sup>2</sup> input/output, input-output—General term for the equipment used to communicate with a computer and the data involved in the communication.<sup>5</sup> interfacing—The joining of members of a group (such as people, instruments, etc.) in such a way that they are able to function in a com- patible and coordinated fashion.1 interrupt—In a computer, a break in the normal execution of a computer program such that the program can be resumed from that point at a later time. The source of the interrupt can be external or internal. memory—Any device that can store logic 1 and logic 0 bits in such a manner that a single bit or group of bits can be accessed and retrieved 10 memory address—The storage location of a memory word. memory cell—A single storage element of memory, capable of storing one bit of digital information. memory data—The memory word occupying a specific location in memory, or the memory words collectively located in memory. memory word—A group of bits occupying one storage location in a computer. This group is treated by the computer circuits as an en- tity, by the control unit as an instruction, and by the arithmetic unit as a quantity. Each bit is stored in a single memory cell. microcomputer—A fully operational computer system based upon a microprocessor chip. microcontroller—A small controller, most likely one based upon a microprocessor chip. microprocessor—A single integrated-circuit chip that contains at least 75 percent of the power of a very small computer. monostable multivibrator—A circuit having only one stable state, from which it can be triggered to change the state, but only for a predetermined interval, after which it returns to the original state. programmable read-only memory—A read-only memory that is field programmable by the user.<sup>10</sup> pulser-A logic switch that generates a clock pulse. random access memory—A semiconductor memory into which logic 0 and logic 1 states can be written (stored) and then read out again (retrieved).<sup>10</sup> read—To transmit data from a memory to some other digital device. read-only memory—A semiconductor memory from which digital data can be repeatedly read out, but cannot be written into, as is the case for a random access memory.<sup>10</sup> software—The totality of programs and routines used to extend the capabilities of computers, such as compilers, assemblers, narrators, routines, and subroutines.<sup>5</sup> special-purpose computer—A computer designed to solve a specific class or narrow range of problems.<sup>5</sup> stored-program computer—A computer capable of performing sequences of internally stored instructions, usually capable of modifying those instructions as directed by the instructions.<sup>5</sup> volatile memory—In computers, any memory which can return information only as long as power is applied to the memory. The opposite of nonvolatile memory. wired-program computer—A computer in which nearly all instructions are determined by the placement of interconnecting wires held in a removable plugboard. This arrangement allows for changes of operations by simply changing plugboards. If the wires are held in permanently soldered connections, the computer is called a fixed-program type.<sup>4</sup> write—To transmit data into a memory from some other digital electronic device. A synonym is store. ### REVIEW OF DIGITAL ELECTRONICS: WHAT IS USEFUL? Two previous Bugbooks, Bugbooks I and II: Logic & Memory Experiments Using TTL Integrated Circuits, provide the background that you will need to use for this book. Some of the more important chips and digital concepts that you should understand include the fol- - The logic operations and, or, nand, nor, and exclusive or. - The gating characteristics of the four basic logic gates: AND, NAND, or, and nor. - The 7400, 7402, 7408, and 7432 integrated-circuit chips. - Decoders, especially the 7442 four-line-to-ten-line and the 74154 four-line-to-sixteen-line integrated-circuit chips. Latches, including the 7474, 7475, 74100, 74175, 74192, 74193, and - 74198 integrated-circuit chips. The 74192 and 74193 chips are counters, and the 74198 chip is an 8-bit shift register. J-K flip-flops, including the 7470, 7473, 7476, and 74106 integrated- - circuit chips. - Counters, including the 7490, 7493, 74192, and 74193 integratedcircuit chips. - Three-state bussing. - Input/output devices such as logic switches, pulsers, clocks, lamp monitors, and seven-segment LED displays. The terms strobe, enable, and disable. - Monostable multivibrators, such as the 74121, 74122, 74123, and 555 integrated-circuit chips. - Clocked logic. - Registers, including the 74198 8-bit shift register. - Arithmetic operations, such as addition and subtraction, and the use of carry bits in binary systems. • Multiplexing, including the 74153 four-line-to-one-line multiplexer. - The function of strobe or chip enable inputs on 7400-series integrated-circuit chips. - Binary, binary-coded decimal, octal, hexadecimal, and ASCII codes. ### SOME HELPFUL REFERENCES While the authors would like to discuss the subjects of computers, minicomputers, and microcomputers in great detail, they will not be able to do so owing to the limitations of space in this chapter. For those readers who are interested, the following books are recommended. They approach the subject of computers in ways that are quite useful to the novice: - 1. The Value of Power, General Automation, Inc., 1055 South East Street, Anaheim, California 92805, 1973. - An excellent paperback book that describes the characteristics of minicomputers. May be out of print. 2. Douglas Lewin, Theory and Design of Digital Computers, John Wiley & Sons, Inc., New York, 1972. A more advanced book. The author pays particular attention to the jargon in the field of digital computers. 3. David Hagelbarger and Saul Fingerman, CARDIAC: A Cardboard Illustrative Aid to Computation, Bell Telephone Laboratories, Inc., A 52-page Bell System Educational Aid that presents a simplified view of what a computer is. Very well written, and quite useful for teaching purposes. 4. The Microprocessor Handbook, Texas Instruments, Inc., P. O. Box 5012, Dallas, Texas 75222. A nicely written text that provides you with a good overview of micro-processor applications, architecture, and chip fabrication technologies. Worth having. 5. D. J. Woollons, Introduction to Digital Computer Design, McGraw-Hill, Inc., New York, 1972. A more advanced book, one that becomes more useful as you develop an understanding of computers and computer operation. 6. A series of six texts: (1) Binary Arithmetic, (2) Microcomputer Architecture, (3) The 4-Bit Microcomputer, (4) The 8-Bit Microcomputer, (5) Assemblers and Prototyping Systems, and (6) 8-Bit Assemblers and Compilers, Iasis, Inc., 770 Welch Road, Suite 154 ED, Palo Alto, California 94304. At \$124.50 for the set of six books, this material is only for the wealthy among you. They are quite well written and worth having. Very little affiong you. They are quite went written and worth having. Very index information on interfacing is provided, however. 7. Jules Finkel, Computer Aided Experimentation: Interfacing to Minicomputers, John Wiley & Sons, Inc., New York, 1975. Provides general descriptions of the various facets of minicomputer interfacing, but lacks details. Does not describe UARTs, RS-232C, 20-mA current loops, or microprocessors. 8. Intel 8080 Microcomputer Systems User's Manual, Intel Corporation, 3065 Bowers Avenue, Santa Clara, California 95051, July If you are working with the 8080 microprocessor chip, you must have this reference manual. Individual chapters include the following: Chapter 1. The Functions of a Computer Chapter 2. The 8080 Central Processing Unit Chapter 3. Interfacing the 8080 Chapter 4. Instruction Set Chapter 5. 8080 Microcomputer System Components Standard CPU Interface RAMs I/O Peripherals Coming soon Chapter 6. Packaging Information 9. An Introduction to Microcomputers, Volume 1: Basic Concepts, Adam Osborne and Associates, Inc., P. O. Box 2036, Berkeley, California 94702. An excellent book at a very reasonable price. - 10. 8080 Programming for Logic Design, Adam Osborne and Associates, Inc., P. O. Box 2036, Berkeley, California 94702. Another excellent book. - 11. Software Design for Microprocessors, Texas Instruments, Inc., Dallas, Texas 75222. Describes software associated with the different TI microcomputer systems. Section 5.2 provides a description of a badge-reading system based upon the 8080 microprocessor chip. ### DATA PROCESSOR VS. MICROPROCESSOR VS. MICROCOMPUTER It is difficult to find a good definition for the term digital computer. The perspective on what is a computer given by Donald Eadie in his book Introduction to the Basic Computer is quite appealing "This chapter serves as a general introduction to the field of digital devices, with particular emphasis on those devices called computers, or more properly, data processors. The name data processor is more inclusive because modern machines in this general classification not only compute in the usual sense, but also perform other functions with the data which flow to and from them. For example, data processors may gather data from various incoming sources, sort it, rearrange it, and then print it. None of these operations involves the arithmetic operations normally associated with a computing device, but the term computer is often applied anyway. "Therefore, for our purpose a computer is really a data processor. Even such data processing operations as rearranging data may require simple arithmetic such as addition. This explains why a certain amount of imprecision has entered our language and why confusion exists between the terms computer and data processor. The two terms are so loosely used at present that often one has to inquire further to determine exactly what is meant."2 Eadie thus defined the term data processor as follows: data processor-A digital device that processes data. It may be a com- puter, but in a larger sense it may gather, distribute, digest, analyze, and perform other organization or smoothing operations on data. ### Comments This program requires an 8-bit output latch and display to permit you to observe the results of the arithmetic and logical operations that you perform on the accumulator contents. Refer to the circuits described in Chapter 7. The subroutine starting at HI = 000 and LO = 100 generates time delays ranging from 0.200 second to 51.2 seconds through variations in the timing byte for register C at LO memory address 005. If you execute the program as it stands, you will observe that the output display quickly fills up with logic 1's, starting from right to left. At memory addresses 011 through 015, you have five program bytes with which you can perform different types of accumulator operations. Thus, with the program segment: | 011 | 076 | MVI A | Load the following byte into the | |-----|-----|-------|----------------------------------------------------------------------| | 012 | 360 | 360 | accumulator Data byte corresponding to the | | 013 | 346 | ANI | binary word 11110000 <sub>2</sub> And the data that follows with the | | 014 | 252 | 252 | contents of the accumulator Data byte corresponding to the | | 015 | 000 | NOP | binary word 10101010 <sub>2</sub> No operation | you should observe that the AND operation between the byte 11110000 and the byte 10101010 produces the logical result 10100000, an operation that proceeds bit by bit. By changing the logical instruction at LO=013, you can demonstrate the behavior of the or and exclusive-or instructions on the same initial data. If you execute the following program segment contained within the main program: | 011 | 074 | INR A | Increment the contents of the accu- | |-----|-----|-------|-------------------------------------| | | | | mulator by one | | 012 | 067 | STC | Set the carry flag to logic one | | 013 | 077 | CMC | Complement the carry flag | | 014 | 047 | DAA | Decimal adjust the accumulator | | 015 | 000 | NOP | No operation | you should observe a decimal output count from 0 to 99 on the output display. The $\bf 047$ instruction is the decimal adjust accumulator instruction, which converts the result of adding two bcd numbers in binary back to a pair of packed bcd numbers. It is $\it not$ a binary-to-bcd conversion instruction as such. ### EXAMPLE NO. 10 ### Purpose The purpose of this example is to demonstrate the BCD Input and Direct Conversion to Binary Routine, which is No. 80-147 in the Intel "In short, if a minicomputer is a 1-horsepower unit, the microprocessor plus supporting circuitry is a ¼-hp unit. But as LSI technology improves, it will become more powerful. Already single-chip bipolar and CMOS-on-sapphire processors are being developed that have almost the capability of the minicomputer." ### HARDWARE VS. SOFTWARE $\it Hardware$ and $\it software$ are important terms that will be used repeatedly in this chapter. It is appropriate, therefore, to define them early. hardware—The mechanical, magnetic, electronic, and electrical devices from which a computer is fabricated; the assembly of material forming a computer.<sup>2</sup> software—The totality of programs and routines used to extend the capabilities of computers, such as compilers, assemblers, narrators, routines, and subroutines. Contrasted with hardware.<sup>5</sup> The specific 8080-based microcomputer ssytem that you will use, along with any integrated-circuit chips, wire, breadboarding aids, and peripheral devices, are all considered to be the hardware. The programs and subroutines that you use and write are the software. In this book, you will first develop hardware skills in interfacing an 8080-based microcomputer. Once you acquire such skills, you will then develop software skills that will allow you to apply your hardware interfacing capability to a variety of instruments and machines. As you gain experience with microcomputers, you will learn that it can often take considerable amounts of time to write microcomputer programs that contain hundreds of program steps. ### COMPUTER VS. DIGITAL COMPUTER It is instructive to define the terms computer and digital computer. Good definitions are difficult to find, as was mentioned previously. computer—Any device, usually electronic, capable of accepting information, comparing, adding, subtracting, multiplying, dividing, and integrating this information, and then supplying the results of these processes in acceptable form. The major elements of a computer usually include memory, control, arithmetic, logical, and input and output facilities.<sup>4</sup> A device capable of accepting information, applying prescribed processes to that information, and supplying the results of these processes. It usually consists of input and output devices, storage, arithmetic and logical units, and a control unit.<sup>5</sup> digital computer-An electronic instrument capable of accepting, storing, and arithmetically manipulating information, which includes both data and the controlling program. The information is handled in the form of coded binary digits (0 and 1), represented by dual voltage levels.6 A computer which processes information represented by combinations of discrete or discontinuous data as compared with an analog computer for continuous data. A device for performing sequences of arithmetic and logical operations, not only on data but its own program. A stored program digital computer capable of performing sequences of internally stored instructions, as opposed to such calculators as card-programmed calculators, on which the sequence is impressed manually. An electronic calculator that operates with numbers expressed directly as digits, as opposed to the directly measurable quantities (voltage, resistance, etc.) in an analog computer.<sup>4</sup> Several subsidiary definitions include the following: fixed-program computer-Computer in which the sequence of instructions are permanently stored or wired. The computer program is not subject to change either by the computer or the programmer except by rewiring or changing the storage input.<sup>5</sup> general-purpose computer-Computer designed to solve a large variety of problems; a stored program computer which may be adapted to any of a very large class of operations.5 special-purpose computer-A computer designed to solve a specific class or narrow range of problems.5 stored-program computer-A computer capable of performing sequences of internally stored instructions, usually capable of modifying those instructions as directed by the instructions.<sup>5</sup> wired-program computer-A computer in which instructions that specify the operations are specified by the placement and interconnection of wires. Wires are usually held by a removable control panel, allownently wired machines which are then called fixed-program computers. $^5$ ing flexibility of operation, but the term is also applied to perma- A computer in which nearly all instructions are determined by the placement of interconnecting wires held in a removable plugboard. This arrangement allows for changes of operations by simply changing plugboards. If the wires are held in permanently soldered connections, the computer is called a fixed-program type.4 ### WHAT IS A CONTROLLER? Graf has defined a controller as follows: controller—An instrument that holds a process or condition at a desired level or status as determined by comparison of the actual value with the desired value.<sup>4</sup> Controllers can be analog or digital, and can be electronic, mechanical, or even pneumatic, or perhaps some combination of these. A digital controller acquires the actual value of the condition in digital form and compares it to the desired value contained within the controller. If there is any difference between the two, a digital signal is sent out to the device, machine, or process to initiate actions to reduce this difference. The digital controller itself consists either of integrated-circuit chips and discrete components that are hard-wired to a printed-circuit board, or else a computer of any size with a limited number of chips to serve as an interface between the computer and the external world. The question of cost becomes an important factor when one considers the use of computers as controllers. One would not control 100 devices, each with a value of \$500, with a \$1,000,000 computer; the use of such a large computer to control \$50,000 worth of equipment is a form of overcontrol. On the other hand, such a computer would be useful in the control of a \$20,000,000 chemical plant. It would appear that one could justify the cost of a computer controller if it represents only a modest percentage of the cost of operating a process or producing a product. The tradeoffs in costs constantly change as the prices of computers decrease. With the advent of microcomputers, the costs of controlling equipment should decrease. ### A TYPICAL 8080 MICROCOMPUTER A typical microcomputer constructed from the 8090 chip is shown in Fig. 1-3. This microcomputer processes all of the minimum requirements for a computer. For example: - It can input and output data. - It contains an arithmetic/logic unit (ALU), located within the 8080 chip, that performs arithmetic and logical operations. - It contains "fast" memory (the authors believe that speed is an important requirement for a functional computer these days). - It is programmable, with the data and program instructions capable of being arranged in any sequence desired. - It is digital. Fig. 1-3 shows the important data paths of the microcomputer. In the sections below, we shall dissect this diagram and discuss the individual naths Fig. 1-3. A typical 8080 microcomputer system, in which the significant data paths are shown ### Memory Consider first the data communication between the 8080 central processing unit (CPU) and memory. You will require some definitions, which will be useful in the ensuing discussion: memory—Any device that can store logic 1 and logic 0 bits in such a manner that a single bit or group of bits can be accessed and retrieved 10 memory address—The storage location of a memory word. memory cell—A single storage element of memory. memory data—The memory word occupying a specific storage location in memory, or the memory words collectively located in memory. memory word—A group of bits occupying one storage location in a computer. This group is treated by the computer circuits as an entity, by the control unit as an instruction, and by the arithmetic unit as a quantity. Each bit is stored in a single memory cell. programmable read-only memory (PROM)-A read-only memory that is field programmable by the user.10 read/write memory—A semiconductor memory into which logic 0 and logic 1 states can be written (stored) and then read out again (retrieved). 10 Sometimes called RAM. read-only memory (ROM)—A semiconductor memory from which digital data can be repeatedly read out, but cannot be written into, as in the case for read/write memory.<sup>10</sup> read—To transmit data from a memory to some other digital electronic device. volatile memory.—In computers, any memory that can return information only as long as power is applied to the memory. The opposite of nonvolatile memory.<sup>4</sup> write—To transmit data into a memory from some other digital electronic device. A synonym is store. The 8080 microprocessor employs 8-bit words that are stored in memory and are addressed with a 16-bit memory address bus. With a quick calculation, we conclude that there exist $2^{16} = 65,536$ different memory locations that can be accessed by the microprocessor. This access to memory is direct, which means that you don't have to engage in any special tricks or digital electronic gimmicks to access any given memory location within the 65,536 possible locations. Forty-pin integrated-circuit chips do have their advantages, and having one pin for each of the sixteen address lines is one of them. The total memory capacity of the 8080 microprocessor is known in the trade as 64K. This is far more memory than you will ever need for most applications, but it is nice to know that you have such power in reserve. A given memory location is addressed with the aid of a 16-bit memory address bus that is shown in Fig. 1-3. It takes only 1 $\mu$ s to accomplish such addressing. The memory address bus is shown in Fig. 1-4. Data is transferred between the 8080 CPU and memory over 8-bit Data is transferred between the 8080 CPU and memory over 8-bit data input and data output busses, both of which are shown in Fig. 1-3 and Fig. 1-5. In most recent 8080 microcomputers, these two busses are combined into a single 8-bit bidirectional data bus. By input, we mean input into the CPU. By output, we mean output from the CPU. The point of reference is always the CPU. Data leaving the CPU is Fig. 1-4. The 16-bit memory address bus between the 8080 CPU and memory. Fig. 1-5. Data transfer between the 8080 CPU and memory. In most 8080 systems there is a single bidirectional data bus. always considered to be *output data*; data entering the CPU is always *input data*. In some cases, the input and output data are transferred between the *accumulator* and memory. The term *accumulator* is defined in the following way: accumulator—The register and associated digital electronic circuitry in the arithmetic unit of a computer, in which arithmetic and logical operations are performed. Data can also be transferred to other internal registers within the 8080 chip. A register is defined as: register—A short-term digital electronic storage circuit, the capacity of which is usually one computer word.<sup>4</sup> Other registers, besides the accumulator register, include the *instruction register*, from which the decoding of the instruction occurs; six general-purpose registers, which are classified by the letters B, C, D, E, H, and L; a program counter register; a stack pointer register; and at least three temporary registers to which you have no access. All of these registers are discussed in subsequent chapters. They are pointed out here so that you will not get the false impression that data from memory is only transferred to the accumulator register. The authors regard the accumulator register to be the heart of the entire microcomputer: Arithmetic and logic operations are always performed to or on the eight bits of data present within the accumulator. For extracted, and, ored, or compared to the contents of the accumulator register. It is not possible to add the contents of one memory location to the contents of another memory location. You must always proceed in such additions through the accumulator register. The accumulator register is also important because all input and output data passes through the accumulator whenever you use the two computer instructions IN and OUT. Between the 8080 CPU and memory there exists a single output line, shown in Fig. 1-3, called memory read/write. When this line is at logic 1, you are able to read data into the CPU either from memory or from an external device. When this line is at logic 0, you are able to write data from the CPU into memory or an external output device. In some systems separate read and write lines are used. As a final point, you can employ any type of "fast" digital electronic memory device, including read/write (R/W) memory, read-only memory (ROM), and programmable read-only memory (PROM). "Fast" memory means simply that the memory can perform either a read or a write operation during a single microcomputer instruction. A typical 8080 microcomputer system operates at a clock rate of 2 MHz, and a read or write operation takes only 650 ns. Thus, R/W memory, ROM, and PROM all need an access time of 650 nanoseconds to allow you to take full advantage of the maximum clock speed. Slower semiconductor memories can be employed, but the microcomputer will have to "wait" while a read or write operation takes place. ### Data Outpu The 8-bit output data bus between the 8080 CPU and memory also serves as the output data bus to an external output device. This is shown in Figs. 1-3 and 1-6. Fig. 1-6. Data transfer between the 8080 CPU and an output device. When you output data to an external device, there are several important requirements that you must meet: - You must select the specific output device that will receive eight bits of data from the accumulator register in the CPU. - You must indicate to this device the precise instant of time when output data is available on the output data bus. • The device must "capture" or "latch" this output data in a very - short period, typically 500 ns. All three of the preceding requirements are accomplished at the same time with a single output pulse, which is generated by the 8080 chip with the aid of some extra digital circuitry external to the 8080 chip. We call such a pulse a device select pulse. It synchronizes the 8080 CPU and the output device so that when the CPU is ready to provide output data, the output device is ready to receive it. Keep in mind that the microcomputer is operating at a clock rate of 2 MHz. Each computer instruction is executed in a very short period, which ranges from $2 \mu s$ to $9 \mu s$ . Thus, accumulator data designated as *data output* is not available for very long. You must capture this data within 500 ns, or else it will disappear. We cannot emphasize enough how important this rapid "capture" of output data is to the successful operation of a complete microcomputer system that includes input/output devices. We will consider these points in greater detail when we discuss the topic of microcomputer interfacing in this chapter. If you are interested in how the function pulse OUT, which is used to generate device select pulses, is created by the 8080 microcomputer, please jump to the section titled "Machine Cycle Identification" in Chapter 6. ### **Data Input** The 8-bit input data bus between the 8080 CPU and memory also serves as the input data bus from an external input device. This is shown in Figs. 1-3 and 1-7. The basic considerations that apply to data output also apply to data input. Thus: - You must select the specific input device that will transmit eight bits of data to the accumulator register within the CPU. - You must indicate to this device the precise instant of time when the input data bus is ready to acquire the input data and transfer it to the accumulator register. - The accumulator register must "capture" this data in a very short period, typically 500 ns. All three of these tasks are accomplished at the same time with a single output pulse, which is generated by the 8080 chip with the aid of some extra digital circuitry external to the chip. Such a pulse is also called a device select pulse. It synchronizes the 8080 CPU and the input Fig. 1-7. Data transfer between an input device and the 8080 CPU. device so that when the CPU is ready to receive input data, the input device is ready to transmit it. ### Other Input/Output Techniques There is an alternative and very exciting technique for transferring data directionally between the microcomputer general-purpose registers B, C, D, E, H, and L and an input/output device. The technique is called memory mapped I/O and the chips used are in a family of interface chips recently marketed by Intel Corporation and others. Included in this family is the 8255 programmable peripheral interface chip, which turns an input/output device into a pseudo-memory location that is addressed not with an IN or OUT instruction, but rather with memory instructions such as MOV, STA, LDA, and the like. The advantage of doing so is the savings of several microseconds per 8-bit data transfer. The computer programming may be easier as well. This technique is particularly well adapted for the acquisition or transfer of blocks of data in short intervals of time. We will not discuss the technique to any degree in this book. ### **External Device Addressing** External device addressing can be defined as the use of computer software to generate input/output synchronization pulses, called device select pulses, to synchronize the transfer of data between the CPU and an external input or output device. This is one of the most important tasks of microcomputer interfacing, and must be learned well. The basic objective of external device addressing is to generate a single unique clock pulse at a precise instant of time to a specific ex- ternal input or output device. The clock pulse can either be a positive or negative clock pulse. With the 8080 microcomputer, negative clock pulses are generated most easily. This is done by decoding an 8-bit device code that appears for about 1.5 $\mu$ s on the memory address bus and using an I/O function or synchronization pulse, called $\overline{\text{IN}}$ or $\overline{\text{OUT}}$ , that appears for 500 ns during the 1.5- $\mu$ s interval associated with the 8-bit device code. The two function pulses and the 8-bit address for external I/O device addressing are shown in Figs. 1-3 and 1-8. The details of how individual device select pulses are generated are provided in Chapter 4. Briefly, here is how this is done. The computer instructions for transferring data between the accumulator and input/output devices specify the specific device desired. For an output computer instruction, you have your choice of any one device among 256 different devices. The same is true for the input computer instruction. Thus, you have the ability to address, i.e., send device select pulses to, 256 different input devices and 256 different output devices. How is this done? Each input or output computer instruction contains an 8-bit device code. We can calculate that an 8-bit binary number can specify $2^8 = 256$ different devices. We use a pair of 4-line-to-16-line decoder chips, such as the 74154 decoder, to decode the 8-bit device code into a single output pulse. Seventeen 74154 decoders can generate 256 different pulses, as will be shown in Chapter 4. The remaining details can be discussed with the aid of Fig. 1-9. Fig. 1-9 provides timing diagrams for the accumulator register contents, the memory address bus, and the OUT pulse that is generated Fig. 1-8. During an 8080 input or output instruction, the 8-bit device code appears on the address bus, and an 1/O synchronization pulse appears on the control bus. Such signals are used to gate the transfer of input/output data. Fig. 1-9. Timing diagram indicating the logic states existing on the memory address bus, within the accumulator, and at the OUT signal line during an OUT instruction. by the OUT computer instruction and some digital circuitry external to the 8080 chip. Note the following: $\frac{1}{2} \frac{1}{2} \frac{$ - The accumulator register contents are available for at least several microseconds, and perhaps much longer. The 8-bit device code appears at the eight least-significant bits of the 16-bit memory address bus for a period of 1.3 µs. In the figure, the device code is 11010001<sub>2</sub>, or 321<sub>8</sub> in octal code. The OUT synchronization pulse lasts for only 500 ns. It is during this 500 ns that data is transferred between the accumulator register and the output device. - ister and the output device. Both the 8-bit device code and the $\overline{OUT}$ synchronization pulse are connected to 74154 decoders to generate a single device code for device 321<sub>8</sub> for a period of only 500 ns. Thus, the use of the term, "capture," is entirely appropriate for data transfers between the accumulator and input/output devices. The input of eight bits of data to the accumulator with the aid of an IN computer instruction proceeds along lines similar to those shown in Fig. 1-9. The only difference is that you should substitute the term buffer data for accumulator and $\overline{\text{IN}}$ for $\overline{\text{OUT}}$ in the figure. The transfer of data to the accumulator occurs in only 500 ns. ### Interrupt Servicing The final data path that we shall discuss is associated with the technique of *interrupt servicing*. The term *interrupt* can be defined in the following way: interrupt—In a computer, a break in the normal execution of a computer program such that the program can be resumed from that point at a later time. The source of the interrupt can be internal or external The important question is: Why would we want to interrupt program execution? The answer is that this is the most efficient way to operate a microcomputer or, for that matter, any computer. Until an external input/output device requests assistance, or "servicing," from the microcomputer, it is most efficient for the microcomputer to completely ignore the device. In fact, the microcomputer can be programmed so that it ignores all input/output devices; it idles in a "wait loop" while it waits for an interrupt signal from one of the devices. If many I/O devices require servicing at essentially the same time, the microcomputer has a protocol in hardware or software and knows which device is the most important. It will assign a priority to each device, and will always service the higher-priority devices first. When a program interrupt is generated, the following sequence of events usually occurs: - The computer stores the memory address of the instruction following the one that it is currently executing. - The computer stores any temporary information—flags, the contents of the accumulator register, and the contents of other registers—that may be important when the interrupted program resumes operation. - The computer goes to a well-defined location within memory and executes a series of program steps to "service" the interrupting device. 4. Once it has finished "servicing" the device, the computer recalls the temporary information and returns to the program step following that step at which the interrupt occurred. This is similar to what you would do if you were interrupted while reading this book. You would mark your place, remember any special information, and then devote your attention to the "interrupt." After servicing the interrupt, you would restore the remembered information, locate the bookmark, and continue reading. If more than one input/output device requires servicing, the microcomputer must make a decision which one to handle first. Once it has made this decision, it remembers which remaining devices have generated the interrupt requests, and then procedes to the service subroutine. In the 8080 microcomputer, an 8-bit instruction is jammed into the CPU at the time of the interrupt to tell the computer where to go in memory to "service" the interrupt. Only eight different memory addresses are provided for this purpose, certainly not a large number. There are a variety of tricks that can be employed to handle interrupts. The schematic diagram shown in Fig. 1-10 indicates the important signals during an interrupt request: an interrupt pulse, an interrupt acknowledge control signal, $\overline{\text{INTA}}$ , and an 8-bit instruction that is jammed into the instruction register. ### TEST This test probes your understanding of the microcomputer and digital electronic concepts described in this chapter. Please write your answers on a separate piece of paper. Fig. 1-10. On receiving an <u>"interrupt"</u> request, the 8080 CPU generates an "interrupt acknowledge" control signal, INTA, that is used to gate an 8-bit instruction into the instruction register within the CPU. - 1-1. Explain the difference between a microprocessor and a microcomputer. - 1-2. Draw a diagram and show the important data paths in a typical 8080based microcomputer. - 1-3. What are the minimum requirements for a computer circa 1977? - 1-4. List and describe the four fundamental tasks of computer interfacing. - 1-5. In your own words, define the following terms: data processor controller bus accumulator flag memory address memory cell memory word hardware software read write computer interfacing interrupt device select pulse clock bidirectional data bus read/write memory read-only memory (ROM) Your performance on this test will be acceptable if you can answer all of the above questions correctly in a 90-minute closed-book examination. You will repeatedly encounter the above concepts in this book. ## WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? It was stated in the introduction to this chapter that at the end you would be able to do the following: - Explain the difference between a microprocessor and a microcomputer. - A microprocessor is a single IC chip, whereas a microcomputer is a fully operational computer system. This distinction has been discussed, with quotes from the literature, early in this chapter. - Define the terms: computer, digital computer, data processor, controller, hardware, software, memory, memory word, memory address, memory data, read, write, read/write memory, read-only memory, interfacing, device select pulse, and interrupt. Definitions for these terms have been provided in this chapter. - Describe the operation of a typical 8080 microcomputer system. This was done in modest detail. You should be able to do as well. Focus upon the signal lines and data paths within the system. ## **CHAPTER 2** # **A Small 8080** Microcomputer In this chapter, you will see how an 8080 (or 8080A) microprocessor In this chapter, you will see how an 8080 (or 8080A) microprocessor chip can be used to configure a small 8080-based microcomputer. We will examine the signals entering and leaving the 8080 chip, how auxiliary chips such as the 8224 are used to control the operation of the microcomputer, and the development of the address, data, and control buses, which are vital in interfacing applications. The microcomputer has been previously described in the May, June, and July, 1976, issues of Radio-Electronics magazine. You may refer to these articles for additional details on the assembly and operation of the microcomputer. ditional details on the assembly and operation of the microcomputer. ## **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Identify the memory address bus, data bus, control inputs, control outputs, and power inputs on the 40-pin 8080A microprocessor - Describe the function of each pin on the 8080A microprocessor chip. - Describe in some detail the various component sections of a small 8080A microcomputer system. • List the general principles of computer interfacing that apply to - most digital computers. - Explain what an I/O device is. - List three important uses for device select pulses. List the inputs to the common 7400-series chips that can be strobed with device select pulses from a microcomputer. #### DEFINITIONS - bit—Abbreviation for binary digit. A unit of information equal to one binary decision. - bootstrap—A technique or device designed to bring itself into a desired state by means of its own action, e.g., a machine routine whose first few instructions are sufficient to bring the rest of itself into the computer from an input device.<sup>4</sup> - bus driver—Generally refers to a specially designed integrated circuit that is added to the data bus system to facilitate proper drive from the CPU when several memories are tied to the data bus line. Any semiconductor device that improves the current sinking characteristics of each line on a bus.<sup>14</sup> - byte—A sequence of adjacent binary digits, which may be equal to or shorter than a word, operated on as a unit. For the 8080A a byte is a group of eight contiguous bits occupying a single memory location. - computer interfacing—The synchronization of digital data transmission between a computer and one or more external input/output devices. flag—In a computer an indication that a particular operation has been completed. A flag is typically a flip-flop that can be either set or cleared in response to operations occurring in the microcomputer - or computer system. HI memory address—For the 8080A microprocessor chip the eight most significant bits, which comprise a single byte, in the 16-bit memory address word. Abbreviated H or HI. - interfacing—The joining of members of a group (such as people, instruments, etc.) in such a way that they are able to function in a compatible and coordinated fashion.<sup>1</sup> - I/O-Abbreviation for input/output.4 - I/O device—Input/output device. A card reader magnetic tape unit, printer, or similar device that transmits data to or receives data from a computer or secondary storage device. Any digital device, including a single integrated-circuit chip, that transmits data to or receives data or strobe pulses from a computer. - latch—A simple logic storage element, such as a flip-flop, used to retain a logic state. - LO memory address—For the 8080A microprocessor chip, the eight least significant bits, which comprise a single byte, in the 16-bit memory address word. Abbreviated L or LO. - memory address—For the 8080A microprocessor, the 16-bit binary number that specifies the precise memory location of a memory word among the 65,536 different possible memory locations. status bit-A single bit of output information that is placed on the external data bus early during the execution of a machine cycle and is latched by an integrated-circuit chip called a status latch. Since this bit is acquired early by the latch, it can be used to control external events that occur later in the machine cycle. status byte-An 8-bit byte that contains eight different status bits. status latch-An integrated-circuit chip, such as, for example, the 74174 6-bit latch, that latches status bits when they appear on the external sync-Short for synchronous, synchronization, synchronizing, etc.4 synchronize-To lock one element of a system into step with another.4 synchronization pulses-Pulses originated by the transmitting equipment and introduced into the receiving equipment to keep the equipment at both locations operating in step.4 synchronous-In step or in phase, as applied to two devices or machines. A term applied to a computer, in which the performance of a sequence of operations is controlled by clock signals or pulses.4 synchronous computer-A digital computer in which all ordinary opera- tions are controlled by signals from a master clock.4 synchronous inputs-Those inputs of a flip-flop that do not control the output directly, as do those of a gate, but only when the clock permits and commands.4 synchronous logic-The type of digital logic used in a system in which logical operations take place in synchronism with clock pulses.4 synchronous operation-Operation of a system under the control of clock pulses.4 three-state device-A semiconductor logic device in which there exist three possible output states: (1) a logic 0 state, (2) a logic 1 state, or (3) a high-impedance state in which the output is, in effect, disconnected from the rest of the circuit and consequently has no in- fluence upon it. two-phase clock-A two-output timing device that provides two continuous series of timing pulses that are synchronized together, with a single clock pulse from the second series always following a single clock pulse from the first series. Depending on the type of two-phase clock, the pulses in the first and second series may or may not overlap each other. The 8080A chip uses a nonoverlapping two-phase clock. word—A group of contiguous bits occupying one or more storage loca- tions in a computer. For the 8080A microprocessor chip, a word is defined as a group of eight contiguous bits occupying a single mem- word length-The number of contiguous bits that are handled as a unit and that normally can be stored in one or more locations in memory. A greater word length implies higher precision and more intricate instructions.4 ## THE 8080 MICROPROCESSOR CHIP The 8080 microprocessor is a 40-pin LSI integrated-circuit chip that contains sixteen address lines, eight data lines, ten control lines, four power connections, and a pair of clock inputs. The pin configuration and the block diagram of the chip are shown in Figs. 2-1 and 2-2. If you are not familiar with reading pin numbers on integrated-circuit chips, the numbering always starts from pin 1 and proceeds counter-clockwise from the notch or index mark on one end of the chip. Chips are always shown as top views. Forty pins are quite a few with which to contend, so it would be useful to divide the pin functions into the following categories: power, memory address, data input/output, controls, and clocks. #### Power The voltage tolerances are $\pm$ 5 percent with respect to ground potential. Any popular power supply that provides voltages of $\pm$ 15 and $\pm$ 5 volts and sufficient current can be adapted to the 8080 chip with the aid of suitable voltage regulators. #### Clacks The 8080 chip requires a two-phase clock. Recall that a clock is any device that generates at least one clock pulse, or is a timing device in a system that provides a continuous series of timing pulses. A two-phase clock is a two-output timing device that provides two continuous series Fig. 2-1. Pin configuration of the 40-pin 8080 microprocessor chip. Fig. 2-2. Block diagram of the 8080 chip that clearly shows the 16-bit address bus and 8-bit bidirectional data bus. This is a more useful representation of the 8080 microprocessor chip. of timing pulses that are synchronized together, with a single clock pulse from the second series always following a single clock pulse from the first series. The use of a timing diagram, shown in Fig. 2-3, is helpful in explaining how a two-phase clock operates. The frequency can vary from 500 kHz to 4 MHz depending upon the particular 8080 chip. The clock frequency cannot be reduced to zero owing to the fact that the internal operation of the chip is dynamic rather than static. Note that the leading edge of the do series of clock pulse almost Note that the leading edge of the $\phi_2$ series of clock pulse almost overlaps the trailing edge of the $\phi_1$ series of pulses. In the 8080 specifications, it is stated that the minimum pulse width for the $\phi_1$ clock phase is 60 ns, whereas for the $\phi_2$ clock phase it is 220 ns. The pin locations for the two input clock signals are: $\begin{array}{ll} pin 22 & clock \ phase \ \phi_1 \\ pin 15 & clock \ phase \ \phi_2 \end{array}$ We call this type of clock device a two-phase nonoverlapping clock. This is not a TTL-level clock; rather, it swings from 0 volts to +12 volts. Such a clock can be easily generated with an 8224 clock generator chip, which is available from Intel and other manufacturers. ## Memory Address The 8080 microprocessor can directly address up to 65,536 eight-bit words of memory through the use of 16 three-state output address lines called the $address\ bus$ . The pin locations can be summarized as follows: Fig. 2-3. Waveforms of the two-phase clock inputs. ``` Address bit A<sub>0</sub>, the least significant bit (LSB) pin 25 pin 26 Address bit A<sub>1</sub> pin\ 27 Address bit A2 pin 29 Address bit A<sub>3</sub> LO ADDRESS BYTE pin \, 30 Address bit A<sub>4</sub> Address bit A<sub>5</sub> pin 31 pin\ 32 Address bit A<sub>6</sub> Address bit A<sub>7</sub>, the MSB in the LO byte Address bit A<sub>8</sub>, the LSB in the HI byte pin 33 pin 34 pin 35 Address bit A<sub>9</sub> Address bit A<sub>10</sub> pin 1 pin 40 Address bit A<sub>11</sub> HI ADDRESS BYTE pin 37 pin 38 pin 39 Address bit A<sub>12</sub> Address bit A<sub>13</sub> Address bit A_{14} Address bit A_{15}, the most significant bit (MSB) pin 36 ``` Either address bits $A_0$ through $A_7$ or address bits $A_8$ through $A_{15}$ can be used to provide the I/O device number for up to 256 input and 256 output devices. The address lines are fed into decoders, which provide one with the opportunity of selecting any single input or output device among $2^8$ different ones. ## **Bidirectional Data Bus** The 8080 microprocessor chip is an 8-bit device, which means that there exist an 8-bit accumulator, several additional 8-bit registers, and an 8-bit input/output data bus. The data bus is bidirectional, so data can be both input into the chip and output from the chip. The data bus is the main communication bus between the central processing unit in the microprocessor, memory, and input/output devices. It is a three-state input/output bus. The pin locations are: | pin 10 | Data bit $D_0$ , the least significant data bus bit | |--------|-----------------------------------------------------| | pin 9 | Data bit D <sub>1</sub> | | pin 8 | Data bit D <sub>2</sub> | | pin 7 | Data bit $D_3$ | | pin 3 | Data bit D4 | | pin 4 | Data bit D <sub>5</sub> | | pin 5 | Data bit D <sub>6</sub> | | pin 6 | Data bit D7, the most significant data bus bit | | | | #### **Controls** The control pins determine how the microprocessor functions in a microcomputer system. In discussing the functions of these pins, it is not possible to sidestep a variety of jargon, such as $T_1$ , $T_2$ , $T_3$ , $T_4$ , $T_4$ , $T_5$ , $T_4$ , $T_5$ You will not see either an IN or out output control pin in the list below. The reason is that these two functions are generated as *status bits*, which are then externally latched and used to generate the IN and OUT synchronization pulses mentioned previously. If you are curious about how this is done, you can skip to Chapter 6. The four control input pins on the 8080 microprocessor chip are: pin 21 (input) RESET. A logic 1 at this input will clear the program counter register and allow the program to start at memory location HI = 000<sub>8</sub> and LO = 000<sub>8</sub>. The INTE and HLDA flags are also reset, but the condition flags, accumulator register, stack pointer register, and general-purpose registers are not cleared. pin 14 (input) INT, or interrupt request. A logic 1 at this input will generate an interrupt request that the CPU recognizes at the end of the current instruction or while halted. If the CPU is in the HOLD state or if the interrupt enable flip-flop is reset, i.e., at logic 0, the interrupt request will not be honored. pin 23 (input) READY. A logic 1 indicates to the 8080 that valid memory or input data is available on the data bus, $D_0$ through $D_7$ . This signal, according to the Intel literature, is used to synchronize the CPU with slower memory or with I/O devices. If, after sending an address out on the address bus, the 8080 doesn't receive a logic 1 READY input, the micro- processor chip will enter a WAIT state for as long as the READY line is at logic 0. This input can also be used to single step the CPU. pin 13 (input) HOLD. This input pin requests the CPU to enter the HOLD state, which allows an external device to gain control of the 8080 address and data busses as soon as the 8080 has completed its use of these busses for the current machine cycle. Once the CPU enters the HOLD state, the address bus and the data bus will be in their high-impedance state. The CPU acknowledges the HOLD state with the HLDA, or HOLD ACKNOWLEDGE, output pin. HOLD is recognized under two conditions: (1) the CPU is in the HALT state, or (2) the CPU is in the $T_2$ or $T_{w}$ state and the READY signal is at logic 1. So much for the control inputs. Now the control outputs, many of which are flags. The term flag can be defined as follows: flag—In a computer, an indication that a particular operation has been completed.<sup>4</sup> A flag is typically a flip-flop that can be either set or cleared in response to operations occurring in the microprocessor system. The six control output pins on the 8080 microprocessor chip are: pin 24 (output) WAIT. The wait output signal acknowledges that the central processing unit is in a WAIT state. When in a WAIT state, this pin is at logic 1. pin 18 (output) WR, or WRITE. This output pin is used for memory Write and I/O control. When this pin is at logic 0, the data on the data bus is stable and can be written into a memory location or to an output device. pin 21 (output) HLDA, or HOLD ACKNOWLEDGE. This pin goes to a logic 1 state in response to a HOLD input signal. It indicates that the data and address busses are in their high-impedance states. The HLDA signal begins at either of two times: (1) at T<sub>3</sub> of read memory or input, or (2) the clock period following T<sub>3</sub> for write memory or output operations. pin 16 (output) INTE, or INTERRUPT ENABLE. This pin indicates the state of the interrupt enable flip-flop. This flip-flop may be set or cleared by the enable and disable interrupt instructions (373, and 363, respectively) and inhibits interrupts from being accepted by the CPU when the flip-flop is cleared. The flip-flop is automatically cleared (thus disabling 46 further interrupts) when an interrupt is accepted. The flip-flop is also cleared by the RESET input signal. pin 19 (output) SYNC, or SYNCHRONIZING SIGNAL. The SYNC pin provides a logic 1 signal to indicate the begin- pin 17 (output) ning of each machine cycle. DBIN, or DATA BUS IN. When this pin goes to a logic 1, it indicates to external circuits that the data bus is in the input mode. This pin is used to enable the gating of data onto the 8080 data bus from memory and I/O devices. Some of the preceding characteristics of the control pins will become clearer in Chapter 6, where the WR, SYNC, DBIN, and READY control pins are discussed. ## THE 8224 CLOCK GENERATOR/DRIVER CHIP In early 8080 microcomputer systems, the clock inputs were provided by transistor driver circuits, MOS clock driver chips, or even opencollector TTL buffer chips. All worked reasonably well, but they complicated the design. A recent 8080A interface chip, the 8224 clock generator and driver, contains an internal oscillator and a clock generator/driver. All you need to provide is the appropriate crystal and power supply voltages of +5 and +12 volts. Since the 8224 will divide the crystal frequency by nine, you will require an 18-MHz crystal to produce a 2-MHz clock output from the clock generator. In the system described in this chapter, the microcomputer frequency is 750 kHz; a 6.750-MHz crystal is required. The Intel specification sheets for the 8224 clock generator/driver are shown on the following pages. The functional description of the chip is excellent, so there is no need to repeat it here. Observe how the divide-by-nine counter circuit within the 8224 chip is used to generate the individual clock phases $\phi_1$ and $\phi_2$ , which "swing" between +12 volts and ground. The inputs to and outputs from the 8224 chip can be summarized as follows: XTAL1 and XTAL2. The crystal is connected at pin 15, pin 14 these two pins. TANK. Used for overtone mode crystals, which have pin 13 much lower gain than crystals that operate on the fundamental frequency. RESIN. With the aid of a Schmitt trigger circuit, pin 2 (input) internal to the chip, and an external RC network, this input converts a slow transition in the power ## Schottky Bipolar 8224 ## THE CLOCK GENERATOR AND DRIVER FOR 8080A CPU - Single Chip Clock Generator/Driver for 8080A CPU Power-Up Reset for CPU Ready Synchronizing Flip-Flop Advanced Status Strobe - Oscillator Output for External System Timing Crystal Controlled for Stable System Operation Reduces System Package Count The 8224 is a single chip clock generator/driver for the 8080A CPU. It is controlled by a crystal, selected by the designer, to meet a variety of system speed requirements. Also included are circuits to provide power-up reset, advance status strobe and synchronization of ready. The 8224 provides the designer with a significant reduction of packages used to generate clocks and timing for 8080A. ## PIN CONFIGURATION ## BLOCK DIAGRAM ## SCHOTTKY BIPOLAR 8224 ## FUNCTIONAL DESCRIPTION #### General The 8224 is a single chip Clock Generator/Driver for the 8080A CPU. It contains a crystal-controlled oscillator, a "divide by nine" counter, two high-level drivers and several auxiliary logic functions. #### Oscillator The oscillator circuit derives its basic operating frequency from an external, series resonant, fundamental mode crystal. Two inputs are provided for the crystal connections (XTAL1, XTAL2). The selection of the external crystal frequency depends mainly on the speed at which the 8080A is to be run at. Basically, the oscillator operates at 9 times the desired processor speed. A simple formula to guide the crystal selection is: Crystal Frequency = $$\frac{1}{t_{CY}}$$ times 9 Example 1: (500ns t<sub>CY</sub>) 2mHz times 9 = 18mHz\* Example 2: (800ns t<sub>CY</sub>) 1.25mHz times 9 = 11.25mHz Another input to the oscillator is TANK. This input allows the use overtone mode crystals. This type of crystal generally has much lower "gain" than the fundamental type so an external LC network is necessary to provide the additional "gain" for proper oscillator operation. The external LC network is connected to the TANK input and is AC coupled to ground. See Figure 4. The formula for the LC network is: $$F = \frac{1}{2\pi \sqrt{LC}}$$ The output of the oscillator is buffered and brought out on OSC (pin 12) so that other system timing signals can be derived from this stable, crystal-controlled source. \*When using crystels above 10mHz a small amount of frequency "trimming" may be necessary. The addition of a small capacitance (3pF - 10pF) in series with the crystal will accomplish this function. The Clock Generator consists of a synchronous "divide by nine" counter and the associated decode gating to create the waveforms of the two 8080A clocks and auxiliary timing signals. The waveforms generated by the decode gating follow a simple 25-2 digital pattern. See Figure 2. The clocks generated; phase 1 and phase 2, can best be thought of as consisting of "units" based on the oscillator frequency. Assume that one "unit" equals the period of the oscillator frequency. By multiplying the number of "units" that are contained in a pulse width or delay, times the period of the oscillator frequency, the approximate time in nanoseconds can be derived. quency, the approximate time in nanosecontactal use delivery. The outputs of the clock generator are connected to two high level drivers for direct interface to the 8080A CPU. A TTL level phase 2 is also brought out \$2 (TTL) for external timing purposes. It is especially useful in DMA dependant activities. This signal is used to get the requesting device on the bus once the 8080A CPU issues the Hold Acknowledgement (HLDA). Several other signals are also generated internally so that optimum timing of the auxiliary flip-flops and status strobe (STSTB) is achieved. ## SCHOTTKY BIPOLAR 8224 ## STSTB (Status Strobe) STSTB (Status Strobe) At the beginning of each machine cycle the 8080A CPU issues status information on its data bus. This information tells what type of action will take place during that machine cycle. By bringing in the SYNC signal from the CPU, and gating it with an internal timing signal (s1A), an active low strobe can be derived that occurs at the start of each machine cycle at the earliest possible moment that status data is stable on the bus. The STSTB signal connects directly to the 8228 System Controller. The power-on Reset also generates STSTB, but of course, for a longer period of time. This feature allows the 8228 to be automatically reset without additional pins devoted for this function. #### Power-On Reset and Ready Flip-Flops A common function in 8080A Microcomputer systems is the generation of an automatic system reset and start-up upon initial power-on. The 8224 has a built in feature to accomplish this feature. lish this feature. An external RC network is connected to the RESIN input. The slow transition of the power supply rise is sensed by an internal Schmitt Trigger. This circuit convers the slow transition into a clean, fast degle when its input level reaches a predetermined value. The output of the Schmitt Trigger is connected to a "O" type flije-flop that is clocked with 92D (an internal timing signal). The flije-flop is synchronously rest and an active high level that complies with the 880A input spec is generated. For manual switch type system Rest circuits, an active low switch closing can be connected to the RESIN input in addition to the power-on RC net-network. The READY input to the 8080A CPU has certain timing specifications such as "set-up and hold" thus, an external synchronizing flip-flop is required. The 8224 has this feature built-in. The RDVIN input presents the asynchronous "wait request" to the "D" type flip-flop. By clocking the flip-flop with #2D, a synchronized READY signal at the correct input level, can be connected directly to the 8080A. The reason for requiring an external flip-flop to synchronize the "wait request" rather than internally in the 8080 CPU is that due to the relatively long delays of MOS logic such an implementation would "rob" the designer of about 200ns during the time his logic is determining if a "wait" is necessary. An external bipolar circuit built into the clock generator eliminates most of this delay and has no effect on component count. supply to a clean, fast edge that resets the 8080A microprocessor chip when the RESET output signal is connected to the 8080A chip. A manual reset switch may also be connected to RESIN. RESET. A logic 0 output that is applied at the pin 1 (output) RESET input of the 8080A chip to reset it. RDYIN. Accepts an asynchronous wait request and pin 3 (input) synchronizes it to produce a READY signal that is output to the 8080A chip. READY. A logic 1 indicates to the 8080A that valid pin 4 (output) memory or input data is available on the data bus. SYNC. The SYNC pin on the 8080A chip provides a pin 5 (input) synchronizing output to the 8224 chip to indicate the beginning of each machine cycle. $\phi_1$ and $\phi_2$ . The two-phase clock that is output to the pin 11 (output), 8080A chip. Each of these two outputs swing bepin 10 (output) tween +12 volts and ground; they are not normal TTL outputs. $\phi_2(\text{TTL})$ . This is a TTL clock output that has the pin 6 (output) same frequency and timing characteristics as does $\phi_2$ . It is used for external timing purposes, such as those described in Chapter 5. STSTB. Status strobe output. This output is used to pin 7 (output) latch the status bits that appear on the bidirectional data bus. OSC. Buffered crystal oscillator output that can be pin 12 (output) used to generate other system timing signals. It should be clear that the 8224 clock generator/driver chip is well designed for its particular function. Connections between it and the 8080A microprocessor chip are direct, and require no intermediate inverters, gates, or flip-flops. There is little incentive to use transistor driver circuits, MOS clock driver chips, or open-collector TTL buffer chips. The power to the 8224 chip is already available since both +5 volts and +12 volts are required by the 8080A. ## AN 8080-BASED MICROCOMPUTER Fig. 2-4 shows the central processor section of a small 8080A-based microcomputer. The figure is provided by *Radio-Electronics* magazine, which described the microcomputer in the May, June, and July, 1976, issues. We will now examine the component chips in the circuit as well as the signal flow between them. The objective here is to demonstrate that a microcomputer is a very straightforward and reasonable device, and that you should not feel intimidated by it. Courtesy Radio-Electronics®, Gernsback Publications, Inc. Fig. 2-4. The processor, memory, and control sections of a small 8080A microcomputer system. ## Power It is assumed that power supplies for the required +5, -12, and +12 volts are available. They are common, and are relatively inexpensive. (However, be wary of the very cheap supplies.) The intermediate voltages of -5 and -9 volts required by our microcomputer are easily derived from voltage regulator integrated-circuit chips such as the LM320 series, or from zener diode shunts, as is shown in Fig. 2-5. Fig. 2-5. The use of zener diodes provides the necessary -5 and -9 volts required by the microcomputer. It is assumed that +5, +12, and -12 volts are available from the power supply. 12 TO 8224 8086A Courtesy Radio-Electronics®. Gernsback Publications, Inc. ## 8080A Microprocessor Chip Individual output pins on the 8080 microprocessor chip have a fanout of one low-power TTL input, or approximately 0.16 mA. The output pin specifications for the 8080A chip are 1.9 mA for each output pin, or a fan-out of a little greater than one standard TTL load. Neither of these fan-out capabilities are good, but clearly the 8080A is a superior chip that is easier to interface. For this reason, we use it in our microcomputer. Even a fan-out of one is insufficient to drive the required memory chips and output latches. Consequently, bus drivers are also required. These will be described in the following under the bus driver section. ## **Control Lines** The control section of the microcomputer is shown in Fig. 2-6. Included is the previously described 8224 clock generator/driver chip connected directly to the 8080A. The only additional electronic components required, besides the two chips, are a pair of 1-kilohm resistors, a reset switch, and a 6.750-MHz crystal. The remaining control lines on the 8080A chip, those not connected to the 8224 chip, are HOLD, HLDA, INTE, INTERRUPT, WAIT, WR, and DBIN. Five of these lines are not used in our small microcomputer, but are made available if you wish to experiment with them. The HOLD input permits you to drive the 8080A chip into the hold state and disable the address and data busses. The HLDA control output acknowledges the existence of a hold state. The INTERRUPT input permits you to interrupt the 8080A program execution, provided that the interrupt flip-flop within the 8080A chip is enabled. If it is enabled, the INTE output is at logic 1. Finally, the WAIT output permits the 8080A chip to signal that it is not ready or that it is wait- Fig. 2-6. The control of the 8080A chip is readily accomplished through the use of the 8224 clock generator/driver chip and a 6.750-MHz crystal. Courtesy Radio-Electronics®, Gernsback Publications, Inc. ing for some external event. If the HOLD input to the 8080A input is not used, it must be grounded. This is easily done with the aid of a not used, it must be grounded. This is easily done with the aid of a jumper, as shown in Fig. 2-6. The final two control lines are both outputs. The WRITE (WR) signal is active when at logic 0, and indicates that the 8080A chip is sending data out to some device. The remaining signal, data bus in (DBIN), indicates that the data bus is being used for the input of data. It is active in the logic 1 state. In the 8080A chip the data bus is bidirectional, i.e., data transfers into and out of the chip over the same wire connections. Careful management of this bus is necessary for the data to flow properly. This data bus management capability is built into the microprocessor chip itself, but we must be certain that our external devices do not attermat to place their data on the bus at our external devices do not attempt to place their data on the bus at the same time that some other device or the 8080A chip itself is trying to use it. Only one device should be transmitting data over the data bus at any given instant of time. #### Bus Drivers In order to drive the memory chips and output latches on our small 8080 microcomputer, a fan-out of at least ten is required for each output line on the data bus. In addition, the bidirectional character of the data must be maintained. The device that we use to accomplish such objectives is the Intel 8216 4-bit parallel bidirectional bus driver chip, the specifications of which are shown, courtesy of Intel Corporation, on the following pages. Consider output DB<sub>0</sub> in the 8216 logic diagram. The following truth table applies: | DIEN | $\overline{CS}$ | | |------|-----------------|----------------------------------------------------------------------------| | 0 | 0 | $DI_0 \rightarrow DB_0$ , i.e., data is output from the 8080 chip | | 1 | 0 | DB <sub>o</sub> → DO <sub>o</sub> , i.e., data is input into the 8080 chip | | 0 | 1 | high-impedance state; chip disabled | | 1 | 1 | high-impedance state; chip disabled | In other words, when $\overline{DIEN}$ is at logic 0 and the chip is enabled, the 8216 chip acts as an input buffer. When $\overline{DIEN}$ is at logic 1 and the chip is enabled, the 8216 acts as an output buffer. The bus driver section of our microcomputer is shown in Fig. 2-7. Observe that DBIN is connected to $\overline{DIEN}$ (pin 15 on the 8216 chip) and that each 8216 chip is permanently enabled. The truth table relating DBIN and $\overline{DIEN}$ is: | DBIN | DIEN | • | |------|------|---------------------------------------------------| | 0 | 0 | Data is output from the $8080$ chip; DBIN = $0$ , | | | | and thus the data bus is in the output mode. | | 1 | 1 | Data is input into the 8080 chip; DBIN = 1, and | | | | thus the data bus is in the input mode | According to the Intel specifications for the 8216, the absolute maximum output current at a logic 0 state is 125 mA, which is a substantial drive capability. Note that both DBIN and $\overline{WR}$ are buffered by a 7400 or 7404 chip to boost their fan-out from one to ten standard TTL loads. ## Status Information If you carefully study the Intel specifications for the 8080A microprocessor chip, you will observe that certain important control signals are not present on the chip itself. Included among these signals are memory read ( $\overline{MR}$ ), memory write ( $\overline{MW}$ ), input ( $\overline{IN}$ ), output ( $\overline{OUT}$ ), and interrupt knowledge ( $\overline{INTA}$ ). To generate such control signals, the 8080A chip uses a "look ahead" technique: Since the data bus is not in use at all times for data transfer, the 8080A can use the bus to trans- # intel° ## Schottky Bipolar 8216/8226 ## 4 BIT PARALLEL BIDIRECTIONAL BUS DRIVER - Data Bus Buffer Driver for 8080 CPU - Low Input Load Current .25 mA Maximum High Output Drive Capability for Driving System Data Bus - 3.65V Output High Voltage for Direct Interface to 8080 CPU - Three State Outputs - Reduces System Package Count The 8216/8226 is a 4-bit bi-directional bus driver/receiver. The 821B/82ZB is a 4-bit bi-directional bus driver/receiver. All inputs are low power TTL compatible. For driving MOS, the DO outputs provide a high 3.65V V<sub>OH</sub>, and for high capacitance terminated bus structures, the DB outputs provide a high 50mA I<sub>OL</sub> capability. A non-inverting (8216) and an inverting (8226) are available to meet a wide variety of applications for buffering in microcomputer systems. ## SCHOTTKY BIPOLAR 8216/8226 ## FUNCTIONAL DESCRIPTION Microprocessors like the 8080 are MOS devices and are generally capable of driving a single TTL load. The same is true for MOS memory devices. While this type of drive is sufficient in small systems with few components, quite often it is necessary to buffer the microprocessor and memories when adding components or expanding to a multi-board system. system The 8216/8226 is a four bit bi-directional bus driver specifically designed to buffer microcomputer system components. ## Bi-Directional Driver Bi-Directional Driver Each buffered line of the four bit driver consists of two separate buffers that are tri-state in nature to achieve direct bus interface and bi-directional capability. On one side of the driver the output of one buffer and the input of another are tied together (DB), this side is used to interface to the system side components such as memories, (I/O, etc., because its interface is direct TTL compatible and it has high rive (50MA). On the other side of the driver the inputs and outputs are separated to provide maximum flexibility. Of course, they can be tied together so that the driver can be used to buffer a true bi-directional bus such as the 8080 Data Bus. The DO outputs on this side of the driver have a special high voltage output drive capability (3.65V) so that direct interface to the 8080 and 8008 CPUs is schieved with an adequate amount of noise immunity (350mV worst case). ## Control Gating DIEN, CS Control Gating DIEN, US The CS input is actually a device select. When it is "high" the output drivers are all forced to their high-impedance state. When it is at "zero" the device is selected (enabled) and the direction of the data flow is determined by the DIEN input. DIEN input. The DIEN input controls the direction of data flow (see Figure 1) for complete truth table. This direction control is accomplished by forcing one of the pair of buffers into its high impedance state and allowing the other to transmit its data. A simple two gate circuit is used for this function. The 8216/8226 is advice that wall reduce component count in microcomputer systems and at the same time enhance noise immunity to assure reliable, high performance operation. (ь) 8226 Figure 1. 8216/8226 Logic Diagrams #### SCHOTTKY BIPOLAR 8216/8226 ## APPLICATIONS OF 8216/8226 ## 8080 Data Bus Buffer The 8080 CVD Data Bus is capable of driving a single TTL load and is more than adequate for small, single board systems. When expanding such a system to more than one board to increase I/O or Memory size, it is necessary to provide a buffer. The 8216/8226 is a device that is exactly fitted to this application. Shown in Figure 2 are a pair of 8216/8226 connected directly to the 8080 Data Bus and associated control signals. The buffer is bi-directional in nature and serves to isolate the CPU data bus. OPU data bus. On the system side, the DB lines interface with standard semiconductor I/O and Memory components and are completely TTL compatible. The DB lines also provide a high rive capability (50mA) so that an extremely large system can be dirven along with possible bus termination networks. On the 8080 side the DI and DO lines are tied together and are directly connected to the 8080 Data Bus for bi-directional operation. The DO outputs of the 8216/8226 have a high voltage output capability of 3.65 volts which allows direct connection to the 8080 whose minimum input voltage is 3.3 volts. It also gives a very adequate noise margin of 350mV (worst case). 350mV (worst case). The control inputs to 8216/8226 (CS, DIEN) are connected directly to the 8080, DIEN is tied to DBIN so that proper bus flow is maintained, and CS is tied to HLDA so the system side Data Bus will be 3-stated when a Hold request has been acknowledged during a DMA activity. ## Memory and I/O Interface to a Bi-directional Bus In large microomputer systems it is often necessary to provide Memory and I/O with their own buffers and at the same time maintain a direct, common interface to a bi-directional Data Bus. The 8216/8226 has separated, data in and data out lines on one side and a common bi-directional set on the other to accomodate such a function. Shown in Figure 3 is an example of how the 8216/8226 is used in this type of application. used in first type of application. The interface to Memory is simple and direct. The memories used are typically Intel® \$102, \$102A, \$101 or \$107A and Mave separate data inputs and outputs. The DI and DO lines of the \$216/8226 tie to them directly and under control of the MEMR signal, which is connected to the DISM input, an interface to the bi-directional Data Bus is maintained. The interface to I/O is similar to Memory. The I/O devices used are typically Intel® \$255E, and can be used for both input and output ports. The I/O R signal is connected directly to the DIEM input to shart proper data flow from the I/O device to the Data Bus is maintained. The 8218/8226 can be used in a wide variety of other buffering functions in microcomputer systems such as Address Bus Drivers, Drivers to peripheral devices such as printers, and as Drivers for long length cables to other peripherals or Figure 2. 8080 Data Bus Buffer. Figure 3. Memory and I/O Interface to a Bi-Directional Bus. Fig. 2-7. Bus driver section of the small 8080-based microcomputer. Courtesy Radio-Electronics®, Gernsback Publications, Inc. fer additional control information. Such information is output very early in the machine cycle (see Chapter 6) to generate control signals used to control the transfer of data to or from input/output devices and The status information appears on the data bus for a very short period, approximately 500 ns for an 8080 system operating at a 2-MHz clock rate. Since the information is to be used at a later time, it must be latched. The SYSTEM STROBE (STSTB) is generated at pin 7 on the 8224 chip at the correct time to latch, or capture, the status informathe 8224 chip at the correct time to latch, or capture, the status information. Note that $\overline{STSTB}$ signal is generated from the system clock signal $\phi_1$ and the SYNC signal from the 8080A. Any type of latch chip may be used. In Chapter 6, the use of an 8212 buffer/latch chip is described. In Fig. 2-8, a 74174 6-bit positive-edge-triggered latch chip is employed. The 74174 chip is clocked at pin 9. All eight bits on the data bus provide some sort of status information, but not all eight may be needed. The information provided by Intel but not all eight may be needed. The information provided by Intel Corporation on the status bits is reproduced on page 61. In our small 8090 system, the $\overline{WO}$ and STACK status signals are ignored since they are not very useful to us. HLTA and M1 are latched but are not used. The important status signals are INTA (interrupt acknowledge), INP (input), OUT (output), and MEMR (memory read). Together with the DBIN and WR outputs from the 8080A chip, these four signals provide five very important control signals, which basically constitute the control bus in our microcomputer: - ullet $\overline{MR}$ . Memory read. Used to strobe data from a memory chip into the 8080A microprocessor chip. - MW. Memory write. Used to strobe data output from the 8080A chip into read/write memory. Courtesy Radio-Electronics®, Gernsback Publications, Inc. Fig. 2-8. The status information and control section of the small 8080 microcomputer system. The status latch is the 74174 chip, which is a 6-bit latch. Instructions for the 8080 require from one to five machine expection. The 8080 sends out 8 bit of status information on the data bus at the beginning of each machine cycle (during SYNC time). The following table defines the status information. STATUS INFORMATION DEFINITION Data Bus | | Data Bus | | |-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Symbols | ğ | Definition | | INTA. | °a | Acknowledge signal for INTERRUPT request. Signal should be used to gate a restart instruction onto the data bus when DBIN is active. | | <u>wo</u> | ٥ | Indicates that the operation in the current machine cycle will be a WRITE memory or OUTPUT function (WO = 0). Otherwise, a READ memory or INPUT operation will be executed. | | STACK | 05 | Indicates that the address bus holds the pushdown stack address from the Stack Pointer. | | HLTA | D <sup>3</sup> | Acknowledge signal for HALT instruction. | | DOUT | D4 | Indicates that the address bus contains the address of an output device and the date bus will contain the output data when WR is active. | | ř | Dş | Provides a signal to indicate that the CPL is in the fetch cycle for the first byte of an instruction. | | -<br>d<br>N | De | Indicates that the address bus contains the address of an input device and the input data should be placed on the data buwhen DBIN is active. | | MEMR. | 0, | Designates that the data bus will be user for memory read data. | - IN. Input. Used to strobe data from an input device into the accumulator within the 8080A chip. - OUT. Output. Used to strobe data from the accumulator into an output device external to the 8080A chip. - INTA. Interrupt Acknowledge. Used to strobe a single-byte instruction into the instruction register within the 8080A chip during an interrupt. The other signals associated with the control bus are RESET, INT (interrupt), and INTE (interrupt enable). These eight control signals permit us to read and write into and from memory and input/output devices and they also allow us to process interrupts. There is now a system controller and bus driver chip, the Intel 8228, that performs both the bidirectional data bus buffering as well as the latching and gating of the status signals. A typical interface circuit is shown on the following page, courtesy of Intel Corporation. The problem with the 8228 chip is that it is expensive and that it does not provide access to all eight status bits. The data bus buffering is limited to a standard fan-out of ten TTL loads, or 16-mA current sink capability. The authors prefer the simplicity of the individual 8216, 7400, and 74174 chips. #### Memory The necessary control section for the 8080A chip is in place and the status bits are latched. We are now ready to add external devices to our microcomputer. The first devices that will be needed are semiconductor memory chips. Memory comes in various forms and types, but we will only consider two, both of which are random access memories. "Random access" means that any single memory location may be accessed after any other location. We need not be concerned about the memory region between the two locations of interest. As subgroups of semiconductor devices, we have read/write (R/W) memory and read-only memory (ROM). We will choose the 2111 read/write memory chip since it is easy to interface to the 8080A. It is organized as 256 memory locations with four bits per location, i.e., it is a 1024-bit, or one-kilobit, memory chip. The Intel Corporation specification for the 8111-2 chip, which is pin compatible and electrically similar to the 2111 memory chip, is shown on page 64. The 8111-2 has common input and output lines (I/O) over which data is transferred to and from the 8080A microprocessor chip. Clearly, these I/O lines are bidirectional. Each 8111-2 memory chip has eight address inputs ( $A_0$ through $A_7$ ) to uniquely define a single memory location among the 256 possible locations. The control inputs to the 8111-12 include the read/write input (R/W), two chip enable inputs ( $\overline{\rm CE}_1$ and $\overline{\rm CE}_2$ ), and an output disable input (OD). Since the word length in each 8111-2 chip is only four bits, pairs of such chips must be enabled and disabled simultaneously in order to provide the 8-bit word required by the 8080A microprocessor chip. Fig. 2-4 shows that $\overline{\text{MW}}$ (memory write) is connected to R/W (pin 16) on the 8111-2 chip, and that $\overline{\text{MR}}$ (memory read) is connected to pin 9 (OD) on the read/write chip. Assuming that the chip is enabled, the applicable truth table is as follows: | $\overline{MW}$ | $\overline{MR}$ | R/W | OD | | _ | |-----------------|-----------------|-------|------|-----------------------------|----| | 0 | 0 | Note: | Inpu | t condition not possible] | | | 0 | 1 | 0 | 1 | Memory write; disable memor | ry | | 1 | 0 | 1 | 0 | Memory read | | | ī | 1 | 1 1 | 1 | Disable memory output | | The decoding of the address bus is depicted in Fig. 2-9. The desired truth table is: | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | A7A0 | Memory | Use | |-----|-----|-----|-----|-----|-----|----|----|------|---------|----------------------------------------------------------------------------------------------------------| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X X | Block 0 | Reserved for<br>EPROM | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | X X | Block 1 | Reserved for<br>EPROM | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | x x | Block 2 | 8111 read/write<br>memory | | 0 | 0 | 0 | 0 | 0 | 0 | ı | 1 | x x | Block 3 | Reserved for<br>EPROM<br>Reserved for<br>EPROM<br>8111 read/write<br>memory<br>8111 read/write<br>memory | ## Silicon Gate MOS 8111-2 ## 1024 BIT (256 x 4) STATIC MOS RAM WITH COMMON I/O AND OUTPUT DISABLE - Organization 256 Words by 4 Bits - Access Time 850 nsec Max. Common Data Input and Output - Single +5V Supply Voltage - Directly TTL Compatible All Inputs and Output - Static MOS No Clocks or Refreshing Required Simple Memory Expansion Chip Enable Input - Fully Decoded On Chip Address Decode - Inputs Protected All Inputs Have Protection Against Static Charge - Low Cost Packaging 18 Pin Plastic Dual-In-Line Configuration - Low Power Typically 150 mW - Three-State Output OR-Tie Capability The Intel®8111-2 is a 256 word by 4 bit static random access memory element using normally off 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. Common input/output pins are provided. The 8111-2 is designed for memory applications in small systems where high performance, low cost, large bit storage, and simple interfacing are important design objectives. It is directly TTL compatible in all respects: inputs, outputs, and a single +5V supply. Separate chip enable (CE) leads allow easy selection of an individual package when outputs are OR-tied. ICE1 leads allow easy selection of an individual package when outputs are UN-tied. The Inte<sup>®</sup>8111-2 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 mon-olithic chip than either conventional MOS technology or P-channel silicon gate technology. Intel<sup>®</sup> silicon gate technology also provides excellent protection against contamination. This permits the use of low cost silicone packaging. Here an X indicates that either a logic 0 or a logic 1 is permitted. A0 through A7 can be any combination of logic 0 and logic 1 states, a total of 256 different combinations. Observe that only address bits A8 and A9 change, giving all four possible combinations for the two bits. Address bits A10 through A15 remain at logic 0 for all of our selected addresses in our small 8080 microcomputer system. It is customary practice to absolutely decode memory locations, that is, to ensure that all sixteen address bits participate in the decoding of a memory location by providing the chip enable (CE) input as well as the eight address inputs A0 through A7. Fig. 2-9 demonstrates how this is done. Since the address bits A10 through A15 remain at logic 0, we use 74LS05 open-collector inverters in a "wired-on" configuration to provide a uniquely decoded logic condition. Observe the presence of a 1-kilohm pull-up resistor, R4. The truth table for the wired-on circuit is as follows: | A15 | A14 | A13 | A12 | A11 | A10 | 1 0 | |--------------|--------------|--------------|--------------|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | X | X | X | X | X | 1 | 0 | | X | X | X | X | 1 | X | 0 | | X | $\mathbf{X}$ | X | 1 | X | X | 0 | | $\mathbf{X}$ | $\mathbf{X}$ | 1 | $\mathbf{x}$ | X | X | 0 | | X | 1 | X | X | X | X | 0 | | 1 | X | $\mathbf{x}$ | X | X | X | 1 0 | Note: X = either logic 0 or logic 1 Observe that this truth table, though implemented with open-collector inverters, is identical to that for a six-input non gate; the unique logic state is Q=1, and this output condition occurs only when all inputs are at logic 0. Whenever the output of the wired-or, or six-input Nor, circuit is at logic 1, we know that A10 through A15 are at logic 0 and that we are within one of the four selected 256-byte blocks of memory. We must further narrow our memory selection process to a specific memory block. This is done with the aid of a 74LS155 decoder chip, the block diagram and pin configuration both of which are given in Figs. 2-9 and 2-10. The 74LS155 chip is enabled and disabled using the output from the wired-or circuit, where disabled corresponds to logic 0 (no blocks selected) and enabled corresponds to logic 1 (one and only one memory block selected). The truth table for the 74LS155 chip is shown on page 67. The outputs to blocks 2 and 3 go to the $\overline{\text{CE}}_1$ inputs (pin 15) of the respective pairs of 8111-2 read/write memory chips, as can be seen Courtesy Radio-Electronics®, Gernsback Publications, Inc. Fig. 2-9. The address bus, address decoder, and memory section of the small 8080 microcomputer system. For simplicity, the IC9 and IC15 address lines have been omitted; they are in parallel with those of IC10. (A) 74L\$155 chip. (B) 74155 chip. Fig. 2-10. The 74155 and 74LS155 chips. | Enable | MR | В | A | 2Y2 | 2Y3 | 1Y2 | 1Y3 | Block Selection | |--------|----|---|-----|-----|-----|-----|-----|---------------------| | 0 | 0 | X | Х | 1 | 1 | 1 | 1 | None selected | | ĭ | ŏ | ō | ō | 0 | î | 1 | 1 | Block 0 (read | | - | • | - | - | | | | | EPROM memory) | | 7 | 0 | 0 | 1 1 | 1 | 0 | 1 | 1 | Block 1 (read | | - | ٠ | • | - | | | | | F PROM memory) | | . 1 | O | 1 | 0 | 1 | 1 | 0 | 1 | Block 2 (read R/W | | * | • | - | | - | | | | memory) | | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | Block 3 (read R/W | | - | • | _ | | | | | | memory) | | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | None selected | | î | î | ñ | 1 | ī | 1 | 1 | 1 | None selected | | î | î | ĭ | ō. | Ιō | 1 | 1 | 1 | Block 2 (write into | | • | - | - | | 1 | | | | R/W memory) | | 7 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Block 3 (write into | | - | • | - | - | | _ | - | | R/W memory) | for block 3 in Fig. 2-9. When pin 15 of the 8111-2 chip is at logic 0, the chip is enabled since $\overline{\text{CE}}_2$ (pin 10) is wired to logic 0. In addition to read/write memory, our small microcomputer also In addition to read/write memory, our small microcomputer also contains some read-only memory. The reasons for providing such memory will be discussed later. Suffice it to say here that read-only memory is not destroyed when we shut the power off, as is the case with read/write memory. We say that read-only memory is nonvolatile. The type of read-only memory that we employ is actually a special type of read-only memory called electrically programmable read-only memory. Such a memory, which is abbreviated by the initials EPROM, is widely used for one-of-a-kind-type applications. You can purchase a special electronic device called an EPROM Programmer and program the EPROMs for your special applications rather than rely upon the chip manufacturer to do the job for you. Fig. 2-11. Pin configuration of the 1702A/ 8702A chip. Some of the power input pins are used only during programming. We shall assume here that the chip has been properly programmed prior to its inclusion in our 8080 microcomputer system. \*THIS PIN IS THE DATA INPUT LEAD DURING PROGRAMMING We employ the Intel Corp. 1702A (or 8702A) EPROM chips, which can be erased through the use of ultraviolet light and reprogrammed over one-hundred times. The pin configuration of the 1702A/8702A chip is shown in Fig. 2-11. Observe that there are eight address inputs, $\Phi_0$ through $\Phi_0$ , and eight data output pins, DATA OUT 1 through DATA OUT 8, a chip select input (pin 14), and several power input pins. Fig. 2-9 shows this chip incorporated into the 8080 microcomputer system. Pins 12, 13, 15, 22, and 23 are all tied to +5 volts. Pins 16 and 24 are connected to -9 volts. The block 0 output from the 74LS155 decoder chip is connected to the $\overline{\text{CS}}$ input of the 1702A (pin 14). Observe that you can only read the 1702A chip; it is a read-only memory, not a read/write memory. ## Microcomputer Bus The "microcomputer bus" for our small 8080 microcomputer system consists of the address, data, and control busses. The address bus consists of sixteen buffered address lines. In Fig. 2-9, the buffering of address bits A0 through A7 is shown. A pair of inverters, first the 74L04 and then the 7404, are used for each address line. The 74L04 chip has a fan-in of 0.1, or 0.16 mA, and is well suited for use with the 8080A microprocessor chip. The 8216 chips (Fig. 2-4) provide sufficient buffering for the eight data bus lines, D0 through D7. The 7400 NAND gates each have a fan-out of ten, more than enough for each control bus signal line. RESET and INTERRUPT are inputs to the 8080A chip. The INTE output might require a buffer. ## Input/Output The input/output section of our 8080 microcomputer is shown in Fig. 2-12. In subsequent chapters in this book, you will become quite Courtesy Radio-Electronics®, Gernsback Publications, Inc. Fig. 2-12. The input/output section of the small 8080A microcomputer system. familiar with I/O decoding, the use of 7475 latch chips, and the use of 8095 three-state buffer chips. Consequently, we will discuss the of 8095 three-state buffer chips. Consequently, we will discuss the I/O section only briefly here. In order to transfer eight bits of data between the accumulator within the 8080A chip and an I/O device, an 8-bit device code is provided on the address bus at bits A0 through A7. To select a unique device among the 256 possible devices, a decoder is required. In Fig. 2-12, the decoder consists of the 74L42 chip and six 74L505 open-collector inverters present at address lines A3 through A7. Five of the inverters serve as a wired-or, or five-point NOR, circuit to decode address bits A3 through A7 into a unique logic state when the five lines are all at logic 0. The principle used is identical with that used for address bits A10 through A15 in the memory section of our microcomputer. Here, the truth table is as follows: | <u>A7</u> | A6 | A5 | A4 | <b>A</b> 3 | 10 | |-----------|----|----|----|------------|----| | 0 | 0 | 0 | 0 | 0 | 1 | | X | X | X | X | 1 | 0 | | X | X | X | 1 | X | 0 | | X | X | 1 | X | X | 0 | | X | 1 | X | X | X | 0 | | 1 | X | X | X | X | 0 | Note: X = either logic 0 or logic 1 The remaining 74LS05 open-collector inverter is used to invert Q to a logic 0 state when the five address bits are all at logic 0. This logic 0 condition is applied at the D input of the 74L42 chip. Chip 74L42 is wired as a three-line-to-eight-line decoder that has the following truth table: | D | A2 | A1 | A0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | Channel Selected | |---|----|----|----|---|---|---|---|---|---|---|---|---------------------| | 1 | X | X | X | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | No channel selected | | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Channel 0 | | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | Channel 1 | | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | Channel 2 | | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | Channel 3 | | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | Channel 4 | | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | Channel 5 | | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | Channel 6 | | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | Channel 7 | Channels 0, 1, and 2 are gated with the OUT control signal and used to strobe information from the bidirectional data bus into the latch chips for ports 0, 1, and 2, respectively. Channel 0 is gated with the IN control signal and used to strobe input data present at the 8095 three-state buffer chip into the 8080A microprocessor chip. Finally, a pair of 74148 three-line-to-eight-line priority encoder chips are used to encode the fifteen-key keyboard, which consists of keys 0 through 7, the see/store key (S), the go key (G), the HI address byte key (H), the LO address byte key (L), and three additional keys that have no specific defined use (A, B, and C). ## Operation of the Microcomputer You may refer to the previously mentioned articles in Radio-Electronics for a description of how the small microcomputer operates. Briefly, you can enter programs via the keyboard, inspect memory contents, execute 8080 programs that are within the memory capability of the microcomputer, and output information to the three output • 74160 to 74163 Courtesy Texas Instruments, Inc. 8 RESULTANT DISPLAYS USING '46A, '47A, '48, '49, 'L46, 'L47 Courtesy Texas Instruments, Inc. Once your 8080 microcomputer system is operational, you will want to interface it to external devices, be they integrated-circuit chips or larger electromechanical devices. Before we leave this chapter, it would be appropriate to define interfacing and to summarize how a microcomputer can be used to control the operation of other digital integrated-circuit chips, especially those in the 7400 series of chips. Since larger electromechanical devices contain 7400-series chips, once you understand how to interface such chips you will also understand how to interface the devices themselves. #### WHAT IS INTERFACING? Interfacing can be defined as the joining of members of a group (such as people, instruments, etc.) in such a way that they are able to function in a compatible and coordinated fashion. By "compatible and coordinated fashion," we usually mean synchronized. Some important definitions include the following: sync—Short for synchronous, synchronization, synchronizing, etc.<sup>4</sup> synchronization pulses—Pulses originated by the transmitting equipment and introduced into the receiving equipment to keep the equipment at both locations operating in step.<sup>4</sup> synchronize—To lock one element of a system into step with another.4 synchronous—In step or in phase, as applied to two devices or machines. A term applied to a computer, in which the performance of a se- A term applied to a computer, in which the performance of a sequence of operations is controlled by clock signals or pulses.<sup>4</sup> At the same time. synchronous computer-A digital computer in which all ordinary op- erations are controlled by signals from a master clock.<sup>4</sup> synchronous inputs—Those inputs of a flip-flop that do not control the output directly, as do those of a gate, but only when the clock permits and commands.4 synchronous logic-The type of digital logic used in a system in which logical operations take place in synchronism with clock pulses. synchronous operation—Operation of a system under the control of clock pulses.4 We can thus define computer interfacing as: computer interfacing-The synchronization of digital data transmission between a computer and one or more external input/output devices. Although the details of computer interfacing vary with the type of computer employed, the general principles of interfacing apply to a wide variety of computers. Some common characteristics include the following: - The digital data that are transmitted between a computer and an I/O device are either individual clock pulses or full data words. - The computer and the input/output device are both clocked or strobed devices. - The computer sends synchronization pulses, called device select pulses, to the I/O device. They synchronize and select at the same instant of time. - $\bullet$ These device select pulses are generated by the computer program - and interfacing hardware, i.e., they are software controlled. The device select pulses are usually quite short. For an 8080 micro- - computer operating at 2 MHz, they last only 500 ns. Individual device select pulses can be sent to individual input or output devices. This is called external device addressing. - External device addressing is software generated and decoded externally. - Computer program execution can be interrupted by the transmission of a clock pulse from an I/O device to a special input line to the computer. - Upon being interrupted by an external I/O device, the computer goes to a computer subroutine that responds to, or services, the interrupt. - Full data words can be output from, or input into, the accumulator register. For the 8080 microcomputer, a full data word contains - All data transmission operations are synchronized to the internal clock of the computer. 74100 pin 23: logic 1 enables first four latches pin 12: logic 1 enables second four latches 74116 pin 1: logic 0 clears first four latches pins 2 and 3: logic 0 at both pins enables first four latches pin 13: logic 0 clears second four latches pins 14 and 15: logic 0 at both pins enables second four latches 74173 pins 1 and 2: logic 0 at both pins enables three-state outputs pin 7: clock input pins 9 and 10: logic 0 at both pins enables registers pin 15: logic 1 clears registers 74174, pin 9: clock input pins 9: clock input pins 9 and 10: logic 0 at both pins enables registers The 7400-series flip-flops such as the 7470, 7473, 7474, 7476, 74106, etc., have too many different inputs to merit individual listing. The types of inputs found on these chips include: preset, clear, clock, R, S, J, and K. Several typical chips are described below. 7470 pin 2: logic 0 clears flip-flop pins 3, 4, and 5: J inputs pins 9, 10, and 11: K inputs pin 12: clock input pin 13: logic 0 sets flip-flop pin 1: clock input to first flip-flop pin 2: logic 0 clears first flip-flop pin 3: K input to first flip-flop pin 14: J input to first flip-flop pin 15: clock input to second flip-flop pin 6: logic 0 clears second flip-flop pin 7: J input to second flip-flop pin 10: K input to second flip-flop pin 1: logic 0 clears first flip-flop pin 1: logic 0 clears first flip-flop pin 3: clock input to first flip-flop pin 3: clock input to first flip-flop pin 1: logic 0 sets first flip-flop pin 1: logic 0 sets first flip-flop pin 11: clock input to second flip-flop pin 12: D input to second flip-flop pin 13: logic 0 clears second flip-flop pin 13: logic 0 clears second flip-flop #### Memories The characteristics of a variety of memories, not just those found in the 7400 series of integrated-circuit chips, are summarized below. ``` 7488 pin 15: logic 0 enables memory pin 2: logic 0 enables memory pin 3: logic 0 writes; logic 1 reads pins 3, 4, and 5: logic 0 at all three pins enables memory 7489, 8225 74200. pin 12: logic 0 writes; logic 1 reads 74206 pin 3: logic 0 writes; logic 1 reads pin 13: logic 0 enables memory 2102, 8102 1602A pin 14: logic 0 enables memory 1702A, 8702A, 1302, 8302 ``` #### Other Chips Given below are the characteristics of several three-state integrated-circuit chips that support the 8080 microprocessor chip. 8212 pins 1 and 13: logic 0 at pin 1 and logic 1 at pin 13 select this device pin 2: logic 1 latches data and enables three-state outputs pin 11: logic 1 pin 14: logic 0 clears latches 8255 pin 5: logic 0 reads input data pin 6: logic 0 enables chip pin 36: logic 0 writes input data ### Pin Configurations The pin configurations of 72 different integrated-circuit chips are provided on the following pages to assist you with your interfacing activities. The following pages are courtesy of Texas Instruments, Inc., and Intel Corp. ## WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? In the first part of this chapter it was stated that at the end you would be able to do the following: Identify the memory address bus, data bus, control inputs, control outputs, and power inputs on the 40-pin 8080A microprocessor chip. chip. A description of the 8080A microprocessor chip has been given at the beginning of this chapter. Although you may not understand some of the control input and output pins, you certainly should be able to identify all of them. Describe the function of each pin on the 8080A microprocessor chip. Fig. 2-13. The four fundamental tasks of interfacing: (1) external device addressing, (2) latching of output data, (3) strobing of input data, and (4) servicing of interrupts. - Output data from the accumulator is available for only a very short period, and usually must be *latched*. - Input data into the accumulator can be acquired over a very short period, and usually must be strobed into the accumulator. - Device select pulses are used for latching data output and strobing data input. As can be seen from Fig. 2-13 and the preceding comments, the four - fundamental tasks of computer interfacing are: External device addressing through the generation of device select pulses. The latching of output data. - The strobing of input data. The servicing of interrupts. If you can master these four tasks, you will know how to interface a computer. ## WHAT IS AN I/O DEVICE? Some useful definitions include the following: input-output, input/output-General term for the equipment used to communicate with a computer and the data involved in the com- I/O—Abbreviation for input/output.<sup>4</sup> I/O device—Input/output device. Any digital device, including a single integrated-circuit chip, that transmits data or receives data or strobe pulses from a computer. The traditional view of an I/O device is that it is somewhat large or complex. Certainly card readers, magnetic tape units, cathode-ray tube displays, and teletypes fit such a description. However, a single integrated-circuit chip, such as a latch, shift register, counter, or small memory, can be considered to be an I/O device to a computer. If it is digital, it can be an I/O device. Another important point is that several device select pulses may be required for a single I/O device. For example, a 74198 shift register has a pair of control inputs that determine whether the register shifts left, shifts right, or parallel loads eight bits of data. It also has a clock input and a clear input. So, this single 74198 chip, when serving as an output device, may require up to four device select lines from the microcomputer. Thus, the fact that we can generate 256 different input and 256 different output device select pulses does not necessarily mean that we can address 512 different "devices." A more reasonable number is on the order of 50 to 100 different devices. Device select pulses are easy to implement and inexpensive. You should use them frequently in an attempt to substitute computer software for integrated-circuit chip hardware. Remember this theme: software vs hardware. There exists a tradeoff between the two, but your main objective in using microcomputers is to substitute software for hardware. When you substitute software for hardware, the only penalty that you may pay is time, i.e., it takes time to execute computer instructions. If you can accept the delays inherent in computer programs, then you can vastly simplify the circuitry required to accomplish a specific task. #### USES FOR DEVICE SELECT PULSES We have previously defined a clock as either (a) any device that generates at least one clock pulse, or (b) a timing device in a system that provides a continuous series of timing pulses. A pulser is a logic switch that can generate a single clock pulse. A monostable multivibrator is a circuit having only one stable state, from which it can be triggered to change the state, but only for a predetermined interval, after which it returns to the original state. With these three definitions in mind, we can consider a microcomputer to be, among other things, a sophisticated electronic circuit that can act as a clock, a pulser, or a monostable multivibrator. For example, an 8080 microcomputer operating at 2 MHz can: • Generate individual clock pulses, of 500-ns pulse width, at any time, thus acting as a pulser or electronic strobe device. • Generate a train of clock pulses in which the frequency is given by the formula, $\nu = 2/n$ MHz, where n is almost any integer that is greater than or equal to 20. • Generate single monostable pulses, in which the pulse width is given by the formula $\tau = n/2$ $\mu$ s, where n is almost any integer that is greater than or equal to 10. An external flip-flop is required to generate such monostable pulses. The microcomputer does all of the above with the aid of device select pulses whose frequency, but not pulse width, is determined by the microcomputer program. As mentioned previously, such pulses are said to be *software generated*, where the software is the microcomputer program. Thus: - If an isolated clock pulse is generated by the program, then the microcomputer is acting as a pulser or electronic strobe device. If the program contains a timing loop such that a series of clock - If the program contains a timing loop such that a series of clock pulses are generated at repetitive time intervals, then the microcomputer is acting as a clock. - If a pair of clock pulses are generated to preset and clear a flip-flop, then the microcomputer/flip-flop combination is acting as a monostable multivibrator. In this manner, we are substituting software for hardware, i.e., we are eliminating the need to supply a mechanical or electronic pulser, a clock, or a monostable multivibrator. The 8080 microcomputer can generate 256 different 500-ns output clock pulses and 256 different 500-ns input clock pulses with the aid of decoder circuits. In essence, the microcomputer has the capability to act as: - 512 different pulser or electronic strobe devices, or - 512 different clocks, or - 512 different monostable multivibrators, or any combination of pulsers, electronic strobe devices, clocks, and monostable multivibrators whose total is 512. It is difficult to conceive of a single digital circuit that would require so many devices. ## USE OF A MICROCOMPUTER TO STROBE INTEGRATED-CIRCUIT CHIPS Perhaps the most important application for microcomputers is to strobe the operation of instruments, electronic devices, and integrated-circuit chips. Chips are inexpensive, and with them we can demonstrate the entire range of applications for computer-generated device select pulses. Such pulses can, for example, - Clear counters, shift registers, flip-flops, and latches. - Load counters, latches, and shift registers. - Enable multiplexers, demultiplexers, decoders, counters, latches, shift registers, memories, priority encoders, and a variety of other - Inhibit clock inputs to counters and shift registers. - Set, clear, toggle, and clock flip-flops. Select shift left, shift right, load, and inhibit functions in shift By using device select pulses to generate clear, load, enable, inhibit, set, toggle, and select pulses and logic states, we are substituting software for hardware. This is the second time that we have observed this; it won't be the last. Our fundamental objective with microcomputers and microprocessor chips is to substitute software for hardware! This book thus has a dual purpose: (1) to teach you how to interface microcomputers, and (b) to show you how to substitute microcomputer software for integrated-circuit chip hardware. To emphasize the above message, we will summarize the strobe characteristics of some of the common 7400-series integrated-circuit chips. We will group chips by function, and then identify pin numbers associated with strobing operations. For each pin listed, we will indicate the logic state required to accomplish the strobing function. The popular counters are the 7490, 7493, 74192, and 74193. Not quite so popular are the 74160, 74161, 74162, 74163, 74190, and 74191 | 7490 | pins 2 and 3: logic 1 at both pins clears counter | |----------|-------------------------------------------------------------| | | pins 6 and 7: logic 1 at both pins sets counter to 9 | | | pin 14: clock input | | 7493 | pins 2 and 3: logic 1 at both inputs clears counter | | | pin 14: clock input | | 74163 | pin 1: logic 0 clears counter | | 74160 to | pin 2: clock input | | | pin 7: logic 0 inhibits counter | | | pin 9: logic 0 enables flip-flops and allows counter to be | | | loaded | | | pin 10: logic 0 inhibits counter and ripple carry | | 74190, | pin 4: logic 1 inhibits counter | | 74191 | pin 5: logic 0 for up counter and logic 1 for down counter | | | pin 11: logic 0 enables flip-flops and allows counter to be | | | loaded | | | pin 14: clock input | | | F | pin 4: clock input for down counter; logic 1 disables pin 5: clock input for up counter; logic 1 disables 74192, 74193 pin 11: logic 0 enables flip-flops and allows counter to be loaded pin 14: logic 1 clears counter ## Decoders Enable inputs are provided on the 74LS1389, 74LS139, 74154, and 74155 decoders. bcd-to-decimal decoders can be converted to strobed octal decoders if the D input is used as the strobe input. pin 12: logic 0 enables octal decoder 7442, 7445 7446, pin 3: lamp test; logic 0 lights all seven segments 7447, 7448 pins 4, 5, and 6: logic 0 at both pins 4 and 5 and logic 1 at 74LS138 pin 6 enable decoder 74LS139 pin 1: logic 0 enables first decoder pin 15: logic 0 enables second decoder pins 18 and 19: logic 0 at both pins enables decoder 74154 74155 pin 1: logic 1 enables first two-line-to-four-line decoder pin 2: logic 0 enables first two-line-to-four-line decoder pin 13: logic 1 enables second two-line-to-four-line decoder pin 14: logic 0 enables second two-line-to-four-line decoder pins 2 and 14 (connected together): logic 0 enables threeline-to-eight-line decoder #### **Demultiplexers** A decoder can be wired as a demultiplexer. The 74LS138, 74154, and 74155 decoder/demultiplexers each have enable inputs. 74LS138 pins 4 and 5: logic 0 at both inputs enables demultiplexer 74154 pin 19: logic 0 enables demultiplexer 74155 pin 2: logic 0 enables first demultiplexer pin 14: logic 0 enables second demultiplexer ## Data Selectors/Multiplexers Enable inputs are provided on each of the three popular 7400-series data selectors/multiplexers, 74150, 74151, and 74153, as well as on the 74156, 74157, and 74158 multiplexers. 74150 pin 9: logic 0 enables data selector/multiplexer 74151 pin 7: logic 0 enables data selector/multiplexer 74153 pin 1: logic 0 enables first data selector/multiplexer pin 15: logic 0 enables second data selector/multiplexer 74156-58 pin 15: logic 0 selects A inputs; logic 1 selects B inputs pin 15: logic 0 enables data selector/multiplexer #### **Shift Registers** Only the newer 7400-series shift registers will be described. These include the 74164, 75165, 74166, 74194, 74198, and 74199 integrated-circuit chips. pin 8: logic 0 clears register 74164 pin 9: clock input 74165 pin 1: logic 0 loads register; logic 1 shifts data pin 2: clock input pin 15: logic 1 inhibits clock pin 6: logic 1 inhibits clock pin 7: clock input 74166 pin 9: logic 0 clears register pin 15: logic 0 loads register; logic 1 shifts data 74194 pin 10: logic 0 clears register, logic 1 since and pin 1: logic 0 clears register pins 9 and 10: mode select inputs; pin 9 is S0 and pin 10 is S1; S0 = 0 and S1 = 0 inhibits clock; S0 = 1 and S1 = 0 shifts data right; S0 = 0 and S1 = 1 shifts data left; and S0 = 1 and S1 = 1 parallel loads register pin 11: clock input pins 1 and 23: mode select inputs; pin 1 is S0 and pin 23 is S1; S0 = 0 and S1 = 0 inhibits clock; S0 = 1 and S1 = 0 74198 shifts data right; S0 = 0 and S1 = 1 shifts data left; and S0 = 1 and S1 = 1 parallel loads register pin 13: logic 0 clears register pin 11: clock input pin 11: logic 1 inhibits clock pin 13: clock input 74199 pin 14: logic 0 clears register pin 23: logic 0 parallel loads register; logic 1 shifts data right #### **Priority Encoder** The 74148 priority encoder encodes eight data lines to three-line binary. 74148 pin 5: logic 0 enables priority encoder ### Latches and Flip-Flops Latch chips contain four or more D-type flip-flops on a single integrated-circuit chip. The common 7400-series latches include the 7475, 74100, 74116, 74173, 74174, and 74175 latches. 7475 pin 3: logic 1 enables first two latches pin 13: logic 1 enables second two latches 78 | <br>- | | |-------|--| | | 74101 | | | | | | | |---------------|-----------|-----------------------------|----------------------------------------------------|-------------|-----------|----------------------------------|---------------------------| | | | TABLE 1 | | | | TABLE 2 | | | | | | | | | ACTIVE LOW DA | | | | | M - L ARITHMETIC OPERATIONS | | SELECTION | м-н | M - L: ARITHME | TIC OPERATIONS | | SELECTION | M - H | | | | LOGIC | Ca-L | C <sub>11</sub> - H | | | LOGIC | Cn - H | C <sub>n</sub> = L<br>(with carry) | 53 52 51 50 | FUNCTIONS | (no carry) | (with corry) | | \$3 52 \$1 50 | FUNCTIONS | (no carry) | F · A PLUS I | | F + X | F + A MINUS 1 | 5 · A | | | 5 - A - B | F + A + B | f + (A + B) PLUS 1 | | F - XB | F + AB MINUS 1<br>F + AB MINUS 1 | F - AB | | LLHL | F - AB | F - MINUS 1 12 + COMPL) | f - ZERO | 1.1.44 | FFAIR | F + MINUS 1 (2's COMP) | F . ZERO | | | F . AB | F · A PLUS AB | F + A PLUS AB PLUS 1<br>F + (A + B) PLUS AB PLUS 1 | 1 4 1 1 | 1.8 | F - AB PLUS (A - B) | F - AB PLUS IA - BI PLUS | | LHHL | F . A . B | F . A MINUS B MINUS 1 | F + ARNUS B | | 5 - A 🔾 B | F . A MINUS B MINUS 1 | F . (A . B) PLUS 1 | | | F . AB | F + AB MINUS 1 | F - A PLUS AB PLUS 1 | HLLL | f • X8 | F . A PLUS (A . B) | F • A PLUS (A • 8) PLUS 1 | | H L L H | F - A 🔾 B | F . A PLUS 8 | F + A PLUS B PLUS 1<br>F + (A + B) PLUS AB PLUS I | HILH | F • A ⊕ B | F . AE PLUS (A . B) | F . AB PLUS IA . BI PLUS | | нене | F - B | F . A . BIPLUS AB | + • AB | ніни | F * A · B | F · A PLUS A | F - (A - B) PLUS 1 | | H H L L | 6+1 | F . A PLUS A | F . A PLUS A PLUS 1 | H H L L | 1 | F - AB PLUS A | F + AB PLUS A PLUS 1 | | | F . A . B | F . (A . BI PLUS A | F . (A . B) PLUS A PLUS I | | F · AB | F - ABPLUS A | F . A PLUS A PLUS 1 | H H H L F A B F \* (A - B) PLUS A Courtesy Texas Instruments, Inc. 74H106 Courtesy Texas Instruments, Inc. 1 2 3 4 5 6 7 1A 1B NC 1C 1D 1V GND 74H21 \*THIS PIN IS THE DATA INPUT LEAD DURING PROGRAMMING. 1702A Courtesy Intel Corp. 8 Courtesy Intel Corp. The proper description has been provided for each of the 40 pins. You may have trouble with this objective. Once you have read Chapter 6, you will better understand the control input and output pins on the • Describe in some detail the various component sections of a small 8080A microcomputer system. The microcomputer system shown in Figs. 2-4 and 2-12 has been described in considerable detail. You should be able to explain the functions of the following chips: 8224, 8216, 74174, 8111-2, and 1702-A. • List the general principles of computer interfacing that apply to most digital computers. This was done later in the chapter, and the four fundamental tasks of computer interfacing also were listed. Know them well. • Explain what an I/O device is. xpiain what an 170 device. Is. It can be any digital device, including a single integrated-circuit chip, that transmits data to or receives data and strobe pulses from a digital List three important uses for device select pulses. They can serve as a source of clock or monostable multivibrator pulses. They can be used to enable latches, multiplexers, decoders, and shift registers. They can clear counters and registers, and set, clear, or toggle flip-flops. • List the inputs to the common 7400-series integrated-circuit chips that can be strobed with device select pulses from a microcom- This has been done in considerable detail in this chapter. ## **CHAPTER 3** # An Introduction to Microcomputer Programming In this chapter, you will learn the characteristics of the 8080 microprocessor instruction set, including the 78 basic instructions and the 244 instructions (twelve are not used) that are derived from this basic set. You will not have to write programs in this chapter, but examples of programs that you can study will be provided. It is the authors' opinion that microcomputer programming, though tedious, is somewhat easier to master than microcomputer interfacing. There are many books and manuals on microprocessors available, and most seem preoccupied with the subtleties of programming. You should study such books for the values which they provide. We will focus on interfacing, and limit our attention to those instructions that are most useful in interfacing. ## **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Explain what the difference is between an instruction, operation, program, machine code instruction, assembly language instruction, and mnemonic instruction. - Define the terms: assemble, bit, byte, flag, mnemonic symbol, device code, HI address byte, LO address byte, increment, decrement, label, jump, call, return, label, operand, carry flag, parity flag, zero flag, sign flag, register, register pair, subroutine, two-byte instruction, three-byte instruction, unconditional operation, conditional operation, branch instruction, stack, stack pointer, program counter, accumulator, ALU, data byte, and instruction register. Classify the 8080 instructions into five groups. - Explain how an 8-bit instruction can be written in both octal code and hexadecimal code. - List the mnemonic codes, following the Intel Corporation recommendations, for at least ten different 8080 instructions. - Explain the difference between machine language and assembly language. - Identify the HI address byte and the LO address byte in a 16-bit memory address word. - Explain what the differences are between a bit, a byte, a word, and an address. - List at least ten different registers that can be found in the 8080 microprocessor chip. - Explain how the microprocessor knows what to do for a given instruction. - Explain how the microprocessor decodes: instruction classes registers register pairs immediate operations branch operations condition flags increment operations decrement operations #### DEFINITIONS accumulator—The register and associated digital electronic circuitry in the arithmetic unit of a computer in which arithmetic and logical operations are performed. address—In the 8030 microprocessor, a 16-bit number which identifies a memory location. ALU—Abbreviation for arithmetic/logic unit. A computational subsystem that performs the mathematical and logical operations of a digital system.<sup>3</sup> arithmetic operations-Addition, subtraction, multiplication, division and comparison. assemble—To translate from a symbolic program to a binary program by substituting binary operation codes for symbolic operation codes and replacing symbolic addresses with absolute or relocatable addresses.4 assembler-A program that prepares a program in machine language from a program in symbolic language by substituting absolute operation codes for symbolic operation codes and absolute or relocatable addresses for symbolic addresses.4 assembly—A process whereby instructions written in symbolic form by the programmer are changed to machine language by the computer. assembly language—A computer language that has one-to-one correspondence with an assembly program. The assembly program directs a computer to operate on a program in symbolic language to produce a program in machine language.4 assembly language programming—The writing of program instructions in a language that facilitates the translation of programs into binary code through the use of mnemonic symbols.4 assembly program-A program that enables a computer to assemble mnemonic language into machine language. Also called assembly routine.4 auxiliary carry flag-A flip-flop which goes to logic 1 when there is a carry from bit 3 into bit 4 in the 8080 microprocessor during operations such as addition, subtraction, and comparison. Used principally with additions preceding a Decimal Adjust Accumulator instruction. bit-The smallest unit of information which can be represented. A bit may be in one of two states, represented by the binary digits 0 and 1.7 branch instruction-An instruction that causes a program jump to a specified address and execution of the instruction at that address. During the execution of a branch instruction, the central processor replaces the contents of the program counter with the specified address. branch operation-See branch instruction. byte-A group of eight contiguous bits occupying a single memory loca- tion in the 8080 microprocessor. call-A special type of jump in which the central processor is logically required to "remember" the contents of the program counter at the time that the jump occurs. This allows the processor later to resume execution of the main program, when it is finished with the last instruction of the subroutine.8 call subroutine-See call. carry flag-A flip-flop that goes to logic 1 when there is a carry or a borrow out of the high-order bit during an arithmetic operation. Otherwise it is cleared to logic 0. computer instruction-A set of characters which defines an operation, together with one or more addresses, or no address, and which, as a unit, causes the computer to perform the operation on the indicated quantities.5 computer program-A sequence of instructions which, taken as a group, allow the computer to accomplish a desired task.7 conditional—In a computer, subject to the result of a comparison made during computation.4 conditional breakpoint instruction—A conditional jump instruction that causes a computer to stop if a specified switch is set. The routine then may be allowed to proceed as coded, or a jump may be forced. conditional jump—Also called conditional transfer of control. An instruction to a computer which will cause the proper one of two (or more) addresses to be used in obtaining the next instruction, depending on some property of one or more numerical expressions or other conditions.<sup>4</sup> condition flag-See flag. data byte—The 8-bit binary number that the 8080 microprocessor will use in an arithmetic or logical operation or store in memory. decrement—To decrease the value of a binary word. Typically, to decrease the value by one. destination register-The register that receives a transferring 8-bit data device code—The 8-bit code for a specific input or output device. This code is decoded by external decoders which, together with an IN or OUT pulse from the 8080 microprocessor, generate a single device direct addressing—An 8-bit data byte is acquired via a three-byte instruction that contains the 16-bit memory address at which the data byte is located. field—A group of bits in a byte or word that is treated as a single unit of information. Usually the number of bits in the field is specified as, for example, a three-bit field.<sup>7</sup> flag—A single flip-flop that indicates that a certain condition has arisen during the course of arithmetic or logical manipulations or data transmission between a pair of digital electronic devices such as a computer and an instrument. For example, a flag may be a circuit that provides a signal which indicates that an input/output device is ready to receive or transmit data from/to a computer. flag register—A register consisting of the flag flip-flops. general-purpose registers—In the 8080 microprocessor, the B, C, D, E, H, and L registers. hexadecimal code—A digital code based upon the radix 16, in which the decimal numbers 0 through 9 and the letters A through F represent the sixteen distinct states in the code. HI address byte—The eight most significant bits in the 16-bit memory address word for the 8080 microprocessor. Abbreviated H or HI. immediate addressing-Data bytes that are contained in a multibyte instruction. increment—To increase the value of a binary word. Typically, to increase the value by one. instruction—A set of characters which defines an operation, together with one or more addresses, or no address, and which, as a unit, causes the computer to perform the operation on the indicated quantities. The smallest single operation that the computer can be directed to execute. instruction code—A unique binary number that encodes an operation that a computer can perform. instruction decoder—A decoder within a CPU that decodes the instruction code into a series of actions that the computer performs. instruction register—The register that contains the instruction code. jump—1. To cause the next instruction to be selected from a specified storage location in a computer. 2. A deviation from the normal se- quence of execution of instructions in a computer. label—One or more characters that serve to define an item of data or the location of an instruction or subroutine. A character is one symbol of a set of elementary symbols, such as those corresponding to typewriter keys. LO address byte-The eight least significant bits in the 16-bit memory address word for the 8080 microprocessor. Abbreviated L or LO. machine code—A computer instruction that is written as a sequence of 0 and 1 binary digits and that specifically characterizes the instruction and no other. A binary representation of a computer instruction. machine instruction—See machine code. machine language-See machine code. mnemonic-Something used to assist the human memory.4 mnemonic code—Computer instructions written in a form that the programmer can remember easily, but which must be converted into machine language later. mnemonic instructions—Computer instructions that are written in a meaningful notation, such as, for example, ADD, MPY, and STO.<sup>4</sup> mnemonic language—A programming language that is based on easily remembered symbols and that can be assembled into machine language by the computer.<sup>4</sup> mnemonic operation code-See mnemonic instructions. mnemonic symbol—A symbol chosen so that it assists the human memory; for example, the abbreviation MPY used for "multiply."<sup>4</sup> octal code—A digital code based upon the radix 8, in which the decimal numbers 0 through 7 represent the eight distinct states in the code. operand—The quantity that is affected, manipulated, or operated upon. operation—A specific action that a computer will perform whenever an instruction calls for it (e.g., addition, division). operation code—See instruction code. parity—A method of checking the accuracy of binary numbers. An extra bit, called a parity bit, is added to a number. If even parity is used, the sum of all 1's in the number and its corresponding parity bit is always even. If odd parity is used, the sum of the 1's and the parity bit is always odd.4 parity flag-A flip-flop such that if the modulo 2 sum of the bits of the result of a computer operation is logic 0, this flip-flop is set to logic 1. pop—Retrieving data from a stack. program—See computer program. program counter—The 16-bit register that contains the memory address of the next instruction byte that must be executed in a computer program. push-Placing data on a stack. register-A short-term digital electronic storage circuit the capacity of which is usually one computer word.4 register pair—In the 8080 microprocessor, a pair of general-purpose registers that together make up a 16-bit word that is treated as a unit. The three register pairs are B and C, D and E, and H and L. register pair addressing-An 8-bit data byte is acquired via a one-byte instruction that employs a register pair, usually H and L, to generate the 16-bit memory address. return-A special type of jump in which the central processor resumes execution of the main program at the contents of the program counter at the time that the jump occurred. return from subroutine-See return. routine-Set of instruction codes arranged in proper sequence to direct the computer to perform a desired operation or sequence of operations. Alternatively, a subdivision of a program consisting of two or more instructions that are functionally related.5 sign flag-A flip-flop that goes to logic 1 if the most significant bit of the result of an operation has the value of logic 1. single-byte instruction-An 8080 instruction consisting of eight contiguous bits occupying a single memory location. source register-The register that contains an 8-bit word that is being transferred. stack-An area in memory that stores temporary register information and the return addresses of subroutines. stack pointer-A 16-bit register that provides the current location of the stack pointer addressing-Two 8-bit data bytes are acquired via a 1-byte instruction that transfers the data from a memory area called a stack to a register pair or the program counter. subroutine-A small subprogram not stored in the main path of the routine. Such a subroutine is entered by a call operation; provision is made to return control to the main program at the end of the sub- symbolic address-Also called floating address. In digital computer programming, a label chosen to identify a particular word, function, or other information that is independent of the location of the information within the routine. symbolic code—A code by which programs are expressed in source language; that is, storage locations and machine operations are referred to by symbolic names and addresses that do not depend upon their hardware-determined names and addresses.4 symbolic coding—In digital computer programming, any coding system using symbolic rather than actual computer addresses.4 symbolic language programming—See assembly language programming. symbolic programming—A program using symbols instead of numbers for the operations and locations in a computer. Although the writing of the program is easier and faster, an assembly program must be used to decode the symbol into machine language and to assign instruction locations.4 three-byte instruction—An instruction that consists of 24 contiguous bits occupying three successive memory locations. two-byte instruction—An instruction that consists of 16 contiguous bits occupying two successive memory locations. unconditional—Not subject to conditions external to the specific computer instruction. unconditional return—A return instruction that is unconditional. unconditional jump—A computer instruction that interrupts the normal process of obtaining the instructions in an ordered sequence and specifies the address from which the next instruction must be taken. unconditional return—A return instruction that is unconditional. word—A group of sixteen contiguous bits occupying two successive memory locations. (This definition is given by Intel for its 8080 microprocessor.) zero flag-A flip-flop that goes to logic 1 if the result of an instruction has the value $000_8$ . ## WHAT IS A COMPUTER PROGRAM? Graf has defined a computer program as:4 A series of instructions or statements prepared in a form acceptable to the computer, the purpose of which is to achieve a certain result. This is an acceptable definition, for it doesn't imply what the desired result is. In some cases, we may seek to evaluate a mathematical equation, whereas in others we may simply seek to rearrange input data into a more convenient form, which either is stored or else provided as output. With microprocessors, we will increasingly be interested in writing computer programs that will control the operation of a device or group of devices. In a home clothes washer, for example, we may wish to control the amount of water used, the temperature of the water at different washing cycles, the number and types of cycles em- ployed to wash a particular type of fabric, and the time duration of each cycle. Finally, we may ask the microprocessor to sound a bell or buzzer when the washing cycle has been completed. #### WHAT IS AN INSTRUCTION? A computer instruction can be defined as:5 A set of characters which define an operation together with one or more addresses, or no address, and which, as a unit, causes the computer to perform the operation on the indicated quantities. We will discuss the concept of an operation in a subsequent section. ## A character is:5 One symbol of a set of elementary symbols such as those corresponding to typewriter keys. Symbols usually include the decimal digits 0 through 9, the letters A through Z, punctuation marks, dollar signs, commas, operation symbols, and any other single symbols which a computer may read, store, or write. In computer programming, it is not uncommon for one to use the entire typewriter keyboard, including symbols such as @, #, \$, %, ¢, &, $^{\bullet}$ , (, ), P, /, and I. Computer instructions come in a variety of forms. They can be binary numbers: > $10110001_2$ $00011100_2$ 111010012 ## octal numbers: $027_{8}$ 3538 1248 0018 #### hexadecimal numbers: $OA_{16}$ $79_{16}$ $FF_{16}$ $D3_{16}$ $BE_{16}$ ## decimal numbers: 10 35 26 #### No operation Halt ## MACHINE LANGUAGE The modern electronic digital computer is capable of performing manipulations using binary electronic signals only, typically 0 volts (logic 0) and +5 volts (logic 1). Thus, each computer instruction is written as a sequence of 1's and 0's that specifically characterize that instruction and no other. Such a binary representation of a computer instruction is called machine language or machine code. For example, the machine language instruction 000001112 rotates the contents of the accumulator one bit to the left in the 8080 microprocessor. The instruction 000011112 rotates the contents of the accumulator one bit to the right. Altogether, it is possible to create 28 = 256 different 8-bit binary machine language instructions for an 8-bit microprocessor such as the 8080. Of these 256 possible instructions, a total of 244 actually exist. Some other examples of machine language instructions for the 8080 include the following: | 00000000 | No operation | |----------|--------------------------------------------------------| | 00000100 | Increment contents of register B by one | | 00000101 | Decrement contents of register B by one | | 00001100 | Increment contents of register C by one | | 00010100 | Increment contents of register D by one | | 00011100 | Increment contents of register E by one | | 00110111 | Set carry flip-flop to logic 1 | | 00111111 | Complement carry flip-flop | | 01000111 | Move contents of accumulator to register B | | 01011000 | Move contents of register B to register E | | 10000000 | Add contents of register B to contents of accumulator | | 10010000 | Subtract contents of register B from accumulator | | 10110000 | OR contents of register B with contents of accumulator | | 11001001 | Return from subroutine | | 11010111 | Call subroutine at memory address H = 0008 and | | | $L = 020_8$ | | 11111011 | Enable interrupt | All of the machine codes listed above are in binary. ## OCTAL AND HEXADECIMAL MACHINE CODES It can be difficult to remember 8-bit binary machine code instructions, so individuals who perform machine language programming frequently convert such instructions into either octal code or hexadecimal code. Such codes were discussed in Chapter 5 of $Bugbook\ I$ , but we will repeat them here for convenience. The octal digits for the eight 3-bit binary numbers ranging between 000 and 111 are: | Octal Digit | Binary Numbe | |-------------|--------------| | 0 | 000 | | 1 | 001 | | 2 | 010 | | 3 | 011 | | 4 | 100 | | 5 | 101 | | 6 | 110 | | 7 | 111 | The Intel 8080 microprocessor generates 8-bit binary machine code instructions, so we must be able to convert an 8-bit binary word into octal code. The process whereby we accomplish this requires three steps: - 1. Write down the full 8-bit binary word: XXXXXXXX. - Split the 8-bit binary word into groups of three, starting from the least significant bit. Two groups of three and one group of two are created, as in XX XXX XXX. Substitute 0 through 7 for each of the groups to obtain the final - octal coded word. As an example, let us assume that we have the binary word 10011011. We first split it into groups: $$10011011_2 = 10011011$$ Next, we write the equivalent octal word for each of these groups: $$10\ 011\ 011 = 233_8$$ to produce 233s, the octal equivalent of the binary word 10011011. Note that the most significant octal number has only two binary bits, and cannot be larger than octal 3. In summary, the conversion of an 8-bit binary word into its octal equivalent proceeds as follows: The hexadecimal code for the sixteen 4-bit binary numbers is as follows: | Hexadecimal Digit | Binary Numbe | |-------------------|--------------| | 0 | 0000 | | 1 | 0001 | | 2 | 0010 | | 3 | 0011 | | 4 | 0100 | | 5 | 0101 | | 6 | 0110 | | 7 | 0111 | | 8 | 1000 | | 9 | 1001 | | A | 1010 | | В | 1011 | | C | 1100 | | D | 1101 | | E | 1110 | | $\mathbf{F}$ | 1111 | To convert an 8-bit binary word into hexadecimal, we do the following: - 1. Write down the full 8-bit binary word, XXXXXXXX. - 2. Split the 8-bit binary word into two groups of four bits, as in XXXX XXXX. - 3. Substitute 0 through F for each of the groups to obtain the final hexadecimal coded word. We can, as an example, convert 10011011 to hexadecimal. We first split it into two groups of four bits: $$10011011_2 = 1001\ 1011$$ Next, we write the equivalent hexadecimal word for each of these groups: $$1001\ 1011 = 9B_{16}$$ to produce $9B_{16}$ , the hexadecimal equivalent of the original binary word. In summary, the conversion of an 8-bit binary word into its hexadecimal equivalent proceeds as follows: ## $XXXXXXXX_2 = XXXX XXXX$ 4-bit 4-bit hex hex digit digit With the 8080 microprocessor, the memory address contains 16 bits. Such a word can also be converted into either octal or hexadecimal code. For example, memory location $1001100111000101_2$ can be written as: $$\begin{array}{c} 1001100111000101_2 = 1\ 001\ 100\ 111\ 000\ 101_2 = 114705_8 \\ = 1001\ 1001\ 1100\ 0101_2 = 99C5_{16} \end{array}$$ However, when we program in octal for the 8080, we will often see a 16-bit address that is subdivided into two eight-bit bytes. In this case, the eight most significant bits are the HI address byte and the eight least significant bits are the LO address byte. When split like this, each byte is treated as a separate octal number that ranges from 000 to 377. Therefore, our address can be written as: Such an address has a HI address byte of $231_8$ and a LO address byte of $305_8$ Table 3-1 gives some useful conversions between binary, octal, and hexadecimal numbers. The machine language instructions listed in the "Machine Language" section can therefore be rewritten in the following manner: | Binary | Octal | Hexadecimal | |--------------|--------------|--------------| | Machine Code | Machine Code | Machine Code | | 00000000 | 000 | 00 | | 00000100 | 004 | 04 | | 00000101 | 005 | 05 | | 00001100 | 014 | 0C | | 00010100 | 024 | 14 | | 00011100 | 034 | 1C | | 00110111 | 067 | 37 | | 00111111 | 077 | 3 <b>F</b> | | 01000111 | 107 | 47 | | 01011000 | 130 | 58 | | 10000000 | 200 | 80 | | 10010000 | 220 | 90 | | 10110000 | 260 | В0 | | 11001001 | 311 | C9 | | 11010111 | 327 | D7 | | 11111011 | 373 | FB | In this book, we shall write machine instructions in octal code. There are several reasons for doing so: It is easier to convert from an octal number to a binary number than from a hexadecimal number to a binary number. The hexa ${\it mnemonic\ code:}$ NOP MOV B, C INR H ADD D SUB L OUT HLT JMP full words: ADD SUBTRACT COMPARE NO OPERATION HALT JUMP CALL SUBROUTINE RETURN FROM SUBROUTINE EXCLUSIVE-OR $or \ full \ mathematical \ expressions:$ $$X = A^{\circ \circ}2 + B^{\circ}Y + C$$ $X = SQRT(B^{\circ \circ}2 - 4^{\circ}A^{\circ}C)$ to mention but a few commonly encountered types. #### WHAT IS AN OPERATION? We return to Graf for a simple definition for the term operation:4 A specific action which a computer will perform whenever an instruction calls for it (e.g., addition, division). The number of different operations that a computer can perform and the speed with which it can perform such operations provide a measure of how "powerful" the computer is. The operations associated with the Intel 8080 microprocessor include: Information Transfer Operations: Move information from accumulator to memory Move information from accumulator to register Move information from memory to accumulator Move information from register to accumulator Move information to stack Move information from stack Move information to stack pointer Move information to program counter ARITHMETIC OPERATIONS: Add to accumulator Subtract from accumulator Compare with accumulator Rotate accumulator left Rotate accumulator right LOGICAL OPERATIONS: And with accumulator On with accumulator Exclusive-on with accumulator SUBROUTINE OPERATIONS: Call subroutine Call subroutine if flag is at logic 0 Call subroutine if flag is at logic 1 Return from subroutine Return from subroutine if flag is at logic 0 Return from subroutine if flag is at logic 1 Restart at specified subroutine location INPUT/OUTPUT OPERATIONS: Input data from device into accumu- lator Output data from accumulator into device INCREMENT/DECREMENT OPERATIONS: Increment contents of accumulator Decrement contents of accumulator Increment contents of register Decrement contents of register Increment contents of memory Decrement contents of memory JUMP OPERATIONS: Jump unconditionally Jump to memory location if flag is at logic 0 Jump to memory location if flag is at logic 1 OTHER OPERATIONS: Complement accumulator Complement carry flip-flop Set carry flip-flop Decimal adjust the accumulator Enable interrupts Disable interrupts Table 3-1. Binary-Octal-Hexadecimal-Decimal Conversions | Binary Number | Octal Number | Hexadecimal Number | Decimal Number | |---------------|--------------|--------------------|----------------| | 00000000 | 000 | 00 | 0 | | 0000001 | 001 | 01 | 1 | | 00000010 | 002 | 02 | 2 | | 00000011 | 003 | 03 | 3 | | 00000100 | 004 | 04 | 4 | | 00000101 | 005 | 05 | 5 | | 00000110 | 006 | 06 | 6 | | 00000111 | 007 | 07 | 7 | | 00001000 | 010 | 08 | 8 | | 00001001 | 011 | 09 | 9 | | 00001010 | 012 | 0A | 10 | | 00001011 | 013 | ОВ | 11 | | 00001100 | 014 | oC | 12 | | 00001101 | 015 | OD OD | 13 | | 00001110 | 016 | 0E | 14 | | 00001111 | 017 | OF | 15 | | 00010000 | 020 | 10 | 16 | | 00011000 | 030 | 18 | 24 | | 00100000 | 040 | 20 | 32 | | 00101000 | 050 | 28 | 40 | | 00110000 | 060 | 30 | 48 | | 00111000 | 070 | 38 | 56 | | 01000000 | 100 | 40 | 64 | | 01001000 | 110 | 48 | 72 | | 01010000 | 120 | 50 | 80 | | 01011000 | 130 | 58 | 88 | | 01100000 | 140 | 60 | 96 | | 01101000 | 150 | 68 | 104 | | 01110000 | 160 | 70 | 112 | | 01111000 | 170 | 78 | 120 | | 10000000 | 200 | 80 | 128 | | 10001000 | 210 | 88 | 136 | | 10010000 | 220 | 90 | 144 | | 10011000 | 230 | 98 | 152 | | 10100000 | 240 | A0 | 160 | | 10101000 | 250 | A8 | 168 | | 10110000 | 260 | во | 176 | | 10111000 | 270 | B8 | 184 | | 11000000 | 300 | CO | 192 | | 11001000 | 310 | C8 | 200 | | 11010000 | 320 | D0 | 208 | | 11011000 | 330 | D8 | 216 | | 11100000 | 340 | EO | 224 | | 11101000 | 350 | E8 | 232 | | 11110000 | 360 | FO | 240 | | 11111000 | 370 | F8 | 248 | | 11111001 | 371 | F9 | 249 | | 11111010 | 372 | FA | 250 | | 11111011 | 373 | FB | 251 | | 11111100 | 374 | FC FC | 252 | | 11111101 | 375 | FD | 253 | | 11111110 | 376 | FE | 254 | | 11111111 | 377 | FF | 255 | decimal symbols A, B, C, D, E, and F can occasionally be confusing. Seven-segment LED displays are more common and less expensive than hexadecimal LED displays. The origins of specific Intel 8080 microprocessor instructions are easier to understand if such instructions are written in octal rather than in hexadecimal code. These three advantages outweigh the fact that there are only two digits in the hexadecimal instruction versus three digits in the octal one. #### MNEMONIC CODE Mnemonic is a term describing something used to assist the human memory.<sup>4</sup> With this in mind, we have the following definitions: mnemonic code—Computer instructions written in a form the programmer can remember easily, but which must be converted into machine language later by a computer.<sup>4</sup> mnemonic language—A programming language that is based on easily remembered symbols and that can be assembled into machine language by a computer.<sup>4</sup> mnemonic operation code; mnemonic instructions—Computer instructions that are written in a meaningful notation, for example, ADD, MPY, STO.<sup>4</sup> mnemonic symbol—A symbol chosen so that it assists the human memory; for example, the abbreviation MPY used for "multiply."<sup>4</sup> A variety of different mnemonic instructions can be written for the 244 different 8080 machine language instructions. Since we believe in standardization, we shall employ those mnemonic instructions suggested by the Intel Corporation. Such mnemonic instructions are provided in a variety of Intel literature, 12 including: - Intel 8080 Microcomputer System Manual, September, 1975. - Intel Assembly Language Programming Manual, 1976 (Revision C) - Intel Assembly Language Reference Card, 1974. as well as in handy code cards such as the following ones available from Tychon, ${\rm Inc.}^{13}$ • Tychon, Inc., 8080 Octal and Hexadecimal Code Cards. The machine language instructions listed in both the "Machine Language" and the "Octal and Hexadecimal Machine Codes" sections can therefore be written in the following manner: | Octal Machine Code | Mnemonic Cod | | |--------------------|--------------|--| | 000 | NOP | | | 004 | INR B | | | 005 | DCR B | | | 014 | INR C | | | 024 | INR D | | | 034 | INR E | | | 067 | STC | | | 077 | CMC | | | 107 | MOV B,A | | | 130 | MOV E,B | | | 200 | ADD B | | | 220 | SUB B | | | 260 | ORA B | | | 311 | RET | | | 327 | RST 2 | | | 373 | EI | | | | | | ## HOW DO I GO ABOUT THE TASK OF LEARNING COMPUTER PROGRAMMING? Some of you who will read this chapter already know how to do machine language programming and perhaps only desire to brush up on the 8080 microprocessor instruction set. Many more of you will be programming and interfacing a microcomputer for the first time. An important question in your mind might be: How do I go about the task of learning computer programming? In the paragraphs below, some suggestions are offered concerning how to proceed. These comments are provided at the beginning of this chapter, rather than at the end, because it is useful for you to have a "road map" of where you are going in this Bugbook. You may not be initially familiar with some of the terms and concepts that we will use in this section. Don't worry. Just read this material quickly the first time, then refer back to it as you need. ## Where Am I Going? In this book, you will learn how to interface microcomputers to simple digital circuits typically consisting of 7400-series chips and a few specialized Intel 8000-series chips. You will have to learn how to transfer information between the microcomputer and external input/output devices, including integrated-circuit chips. Thus, two of the most important instructions that you should learn are the following, which generate device select pulses: 323 Generate a device select pulse to synchronize the output of eight bits of accumulator data to the device with the de-<B2> vice code given in the second byte of the instruction. and Generate a device select pulse to synchronize the input of 333 <B2> eight bits of data into the accumulator from the device with the device code given in the second byte of the instruction. These are the Out and In instructions, respectively. You will certainly use the Out instruction frequently in later chapters. In a following chapter, you will learn how to write computer subroutines. With such subroutines, the computer jumps from a main program to some other memory location, where it begins execution of the subroutine. Once it has finished with the subroutine, it returns to the main program. Thus the computer must know the location in the main program to which it should return. It does this with the aid of a group of memory locations known as a stack, which store returning memory locations for subroutines. You will not be able to use any subroutine, including those on a preprogrammed PROM chip, unless you locate the stack within the read/write memory that you actually have in your microcomputer. How do you relocate the stack? You employ the following three-byte instruction: Relocate the stack pointer at the 16-bit memory address 061 given by the following two bytes of this instruction. LO memory address byte <B2> <B3> HI memory address byte One of the authors wasted several hours one evening trying to write a subroutine before he realized the need to relocate the stack from where it was initially (which was, in case you are interested, at $HI = 377_8$ and ${ m LO}=377_8).$ Subroutines are very important programming gimmicks, so important that it is a good idea to mention the stack right at the beginning of this chapter. In general, you will not start program execution at memory location $HI = 000_8$ and $LO = 000_8$ and run sequentially through your available memory. You will jump around, sometimes ahead, usually back. So, you will need to know how to jump from one point in your program to another, where execution continues. The instruction that you will require is the Unconditional Jump, a three-byte instruction: - 303 Jump unconditionally to the 16-bit memory location given by the following two bytes of this instruction. - LO memory address byte - <B3> HI memory address byte It is a great instruction. You can do wonders with it. You may want to call a subroutine, which simply means that you are asking the microcomputer to store the memory address of the next instruction in the main program, and then jump to some other memory address where the execution of the subroutine commences. To do this, you will require the *Unconditional Call* instruction, also a three-byte instruction: - 315 Call unconditionally the subroutine at the 16-bit memory location given by the following two bytes of this instruction. - <B2> LO memory address byte - <B3> HI memory address byte This instruction is not sufficient, however. Once you have executed the subroutine, you will need an instruction that will get you back to the main program. This is the *Unconditional Return* instruction, a one-byte instruction. Return unconditionally to the main program. The specific address in the main program is contained in two memory locations in the stack. We have used the term *unconditional* in each of the above three instructions on this page. There also exist a number of *conditional* jump, call, and return instructions that perform their indicated actions only if a flag has a certain specified logic state. This book won't use many of them, so you will be required to learn them on your own. Probably the only conditional instruction that you will use frequently in this book is one associated with the programming of *timing loops*: - Jump to the 16-bit memory location given by the following two bytes of this instruction if the zero flag is at logic 0. - <B2> LO memory address byte - <B3> HI memory address byte You may ask: What is a zero flag? It is simply a single flip-flop that goes to a logic 1 state only if the content of the register or memory operated upon in the preceding instruction goes to $000_8$ . This is an important instruction and one that you will use frequently in Chapter 5. Observe that we haven't yet discussed an Add, Subtract, And, Or, or other type of arithmetic/logical instruction. The fact of the matter is that you won't use many of these instructions in this Bugbook. You may be much too busy and interested in outputting and inputting data to worry much about adding a pair of numbers. There is one subtract instruction that the authors are rather fond of: 227 Subtract the contents of the accumulator from the contents of the accumulator, i.e., clear the accumulator. With this instruction, you set the value of the accumulator to 000<sub>8</sub>. It is very useful When you make timing loops, you may desire to increment the B and C general-purpose registers. The instructions that you will require are: - 004 Increment B register by one. - 014 Increment C register by one. You will also want to decrement these two registers: - 005 Decrement B register by one. - 015 Decrement C register by one. You will certainly want to halt the computer after it has executed a program. To do this, you will employ the popular and highly regarded *Halt* instruction: 166 Halt the microcomputer If you are lazy, you can program the computer to do nothing: 000 No operation This instruction does absolutely nothing. In its spot in the program, it simply consumes time, 2 $\mu$ s to be exact. You can use it to provide spaces in your program that you may fill at a later time. You may want to clear a register, as would be the case with a long timing loop. First, you can clear the accumulator. Then you move the contents of the accumulator to the desired register, as in the following instructions: - 107 Move contents of accumulator to register B. - 117 Move contents of accumulator to register C. - 127 Move contents of accumulator to register D. You may wish to load a specific 8-bit binary number into the accumulator or a register. The following two-byte *immediate* instructions will do the job: - 006 Move the data in the second byte of this instruction into <B2> register B. - 026 Move the data in the second byte of this instruction into <B2> register D. - 076 Move the data in the second byte of this instruction into the <B2> accumulator. You may wish to load a pair of 8-bit binary numbers into two registers with the same instruction. One example of such an instruction is: 041 Move the data in the second and third bytes of this instruction into register pair H. <B2> This byte goes into register L. <B3> This byte goes into register H. Along about Chapter 8, you will need to enable the *interrupt flag* so that you can interrupt the microcomputer from the front panel. You do this with the following instruction: 373 Enable the interrupt system following the execution of the next instruction. In Chapter 8, you will "jam" a one-byte instruction during the interrupt. This is an instruction that calls a subroutine at one of the following memory addresses (all with $\rm HI=000_8$ ): $000_8$ , $010_8$ , $020_8$ , $030_8$ , $040_8$ , $050_8$ , $060_8$ , or $070_8$ . These are the *Restart* instructions, an example of which is given below: 317 Call the subroutine at the memory address given by $H=000_8$ and $L=010_8$ . You can have fun and play games with the accumulator and carry flag. For example, you can: - 007 Rotate the contents of the accumulator left one position. - 017 Rotate the contents of the accumulator right one position. - 047 Decimal adjust the accumulator. - 057 Complement the accumulator. - Off Set the carry flag to logic 1. - 077 Complement the carry flag. And, finally, you can move the contents of a specified memory location to the accumulator, as in the following instruction: 176 Move contents of the memory location addressed by the register pair H,L to the accumulator. Now we come to the point of this section: The above instructions are almost all that you will need for this book! The emphasis has been on computer interfacing, not programming. Just enough program steps have been provided to allow you to make your interfaced integrated-circuit chip to do something useful. ### How Do I Learn Microcomputer Programming? You can learn computer programming with the aid of this Bugbook and some hands-on experience with an 8080-based microcomputer. It is possible to "dry lab" this book, but having a microcomputer before you would make your learning much more interesting. Here are some suggestions: As your first step in learning how to program a microcomputer, survey the microcomputer instruction set and try to learn what you can from it In this book the 8080 microprocessor instruction set has been organized in a variety of ways to help you: (1) an octal/hexadecimal/mnemonic listing of all 256 instructions, from 000,8 to 377,8; (2) an alphabetic listing of the mnemonic instructions; (3) a group listing of the instructions, including the data transfer group, arithmetic group, logical group, branch group, and stack/input/output/machine control group; (4) an instruction summary on a single sheet of paper; and (5) detailed written descriptions of different classes of instructions, in which each class or group is described in terms of how it is decoded by the instruction decoder within the 8080 chip. Study the numerous examples of computer programming given in this book. We haven't used all of the 8080 instructions, but we have used many of the more important ones. You should learn from this book that a computer program doesn't have to be long and involved in order to be useful. You will observe how to generate device select pulses and latch accumulator data with only a few instructions. With several additional instructions, you can generate a timing loop. Practice computer programming by writing many simple programs, each of which illustrate the characteristics of a different 8080 instruction. The authors have followed this rule in this book. They have tried to highlight the behavior of a limited number of useful instructions. They hope they have done so in sufficient depth and with sufficient clarity that you are able to master them. They would encourage you to follow the same procedure as you learn the characteristics of other instructions, such as DAD, ANA, XRA, ORA, CMP; the conditional jumps, calls, and returns; and such interesting instructions as PCHL, XTHL, XCHG, SPHL, POP, and PUSH. Do all of the above with an 8080 microcomputer system in front of you. A microcomputer system is a lot of fun. You will not do justice to this exciting new technology simply by reading this book. Hands-on experience with a microcomputer will give you the depth of experience that you require. ### BIT, BYTE, WORD, AND ADDRESS The terms bit, byte, word, and address are so important that, though we have defined them in the preceding chapter, we shall define them again here. The definitions given below are from the Intel 8080 Assembly Language Programming Manual (Reference 7). bit-The smallest unit of information which can be represented. A bit may be in one of two states, represented by the binary digits 0 or 1.7 byte-A group of eight contiguous bits occupying a single memory location.7 A representation of a byte in memory. Bits which are fixed as 0 or 1 are indicated by 0 or 1; bits which may be either 0 or 1 in different circumstances are represented by letters; thus rp represents a 3-bit field which contains one of the eight possible combinations of zeros and ones.7 word-A group of 16 contiguous bits occupying two successive memory locations. address-A 16-bit number assigned to a memory location corresponding to its sequential position.<sup>7</sup> instruction—The smallest single operation that the computer can be directed to execute.7 program-A sequence of instructions which, taken as a group, allow the computer to accomplish a desired task.7 field-A group of bits in a byte or word which is treated as a single unit of information. Usually the number of bits in the field is specified as, for example, a three-bit field. Keep in mind that the definitions here for byte, word, and address refer specifically to the 8080 microprocessor. Other computers may have smaller or larger bytes, words, and addresses. ### MULTIBYTE INSTRUCTIONS The 8080 microprocessor can execute 244 different instructions. Many of the instructions are similar, and it has been said that the 8080 has only 78 truly different instructions. We are not prepared to quibble on this matter. The point is that, of the 244 instructions, 200 are single-byte instructions, 18 are two-byte instructions, and 26 are three-byte instructions. These three terms can be defined as follows: single-byte instruction-An instruction consisting of eight contiguous bits occupying a single memory location. three-byte instruction-An instruction consisting of 24 contiguous bits occupying three successive memory locations. two-byte instruction-An instruction consisting of 16 contiguous bits occupying two successive memory locations. The first byte of a multibyte instruction is called the *operation code*. The remaining one or two bytes are either an 8-bit *data byte*, two 8-bit *data bytes*, an 8-bit *device code*, or a 16-bit memory address consisting of two 8-bit *address bytes*. Definitions for these new terms are as follows: $operation\ code$ , instruction code –The 8-bit code for the specific action that the 8080 microprocessor will perform. data byte—The 8-bit binary number that the 8080 microprocessor will use in an arithmetic or logical operation or store in memory or a register. device code—The 8-bit code for a specific input or output device. This code is decoded by external decoders which, together with an IN or OUT pulse from the 8080 microprocessor, generate a single device select pulse. HI address byte—The eight most significant bits in the 16-bit memory address word for the 8080 microprocessor. Abbreviated H or HI. LO address byte—The eight least significant bits in the 16-bit memory address word for the 8080 microprocessor. Abbreviated L or LO. Clearly, an 8-bit word stored in memory can be an operation code, data byte, device code, HI address byte, or LO address byte. How do you tell? You examine each 8-bit byte in the context of the actual microcomputer program. Unless there is a mistake in the program, the computer can readily distinguish between the various types of bytes. There will be no ambiguities. We will continue our discussion of this topic in the following section. The first, second, and third bytes in a multibyte instruction are represented by the symbols <B1>, <B2>, and <B3>, respectively. This is the Intel Corporation notation, one which we will follow. The eighteen two-byte instructions for the 8080 microprocessor have the following mnemonic codes: eight MVI instructions: MVI B, MVI C, etc. ADI ACI OUT SUI IN SBI ANI XRI ORI The 26 three-byte instructions for the 8080 have the following mnemonic codes: four LXI instructions nine JUMP instructions nine CALL SUBROUTINE instructions SHLD LHLD STA LDA We will stick to the Intel Corporation mnemonic code throughout this Bugbook. Simple representations for single-byte, two-byte, and three-byte instructions are shown in Fig. 3-1. ### INSTRUCTION VS. DATA: HOW DOES THE COMPUTER KNOW? With the 8080 microcomputer system, we store both instructions and "data," such as that from a laboratory instrument, in the same memory. Instructions and data can almost exist side by side. It is thus reasonable to inquire, how does the microcomputer know the difference between the two? The basic answer is that instructions in memory are stored as a block, or perhaps as a group of blocks scattered throughout memory, and the same is true with data from an instrument. Except for the immediate-type instructions, you rarely, if ever, have both instructions and data Fig. 3-1. Representations of instructions. address byte and a HI address byte. commingled. Such mixing is bad programming and memory organization if it occurs. Therefore, the computer will always know that it is operating on instructions as long as it starts in the correct location in memory and the program is properly written. The instructions will usually exist as a cohesive block in memory. If spread out in memory, there will be well-defined jump, call, return, and restart instructions to tie the subroutines and subsidiary programs together with the main program. With regard to data in memory, the following is suggested: Unless indicated otherwise, such as by proper programming, the computer will treat data in memory as computer instructions and will go wild trying to execute them. In other words, a properly written program will access and store data via selected memory addressing commands such as MOV. However, if for any reason the microcomputer finds itself operating in a data block during the execution of a program, it will treat the data bytes as instruction bytes. How does the computer know the difference between an instruction and data? You write the program in such a manner that it knows the difference. Carelessness on your part will cause the microcomputer to "go bananas." Computer programs must always start with a valid computer operation, not data! #### 8080 MICROPROCESSOR REGISTERS The term register can be defined as follows: register-A short-term digital electronic storage circuit the capacity of which usually is one computer word.15 Single registers in the 8080 microprocessor chip store a single byte, i.e., eight contiguous bits. There are two different sets of registers in the 8080 chip: those that we can address from a program and those that we cannot. The program addressable registers are shown in Fig. 3-2 and include the following: - six 8-bit general-purpose registers addressed singly or in pairs: - B register - C register - D register - E register - H register L register - the 8-bit accumulator, also known as register A - the 16-bit stack pointer register - the 16-bit program counter register Fig. 3-2. The internal register architecture within an 8080 microprocessor chip. Temporary registers over which you have no direct control are omitted. The data bus buffer/latch and the address buffer provide the interface between the circuitry within the chip and the external busses. Two other registers over which, in special cases, you have some control include: - the 8-bit instruction register - a 5-bit flag register in the arithmetic/logic unit (ALU) Additional registers (see Fig. 3-3) that are required to allow the 8080 microprocessor chip to perform its internal operations include two 8-bit temporary registers used singly or as a pair, W temporary register and Z temporary register; an 8-bit temporary accumulator in the arithmetic/logic unit; and an 8-bit temporary register in the arithmetic/logic unit. You cannot address or control the contents of these temporary registers from a program and will not know when the 8080 uses them. Some useful definitions include the following: accumulator—The register and associated digital electronic circuitry in the arithmetic/logic unit (ALU) of a computer in which arithmetic and logical operations are performed. tic and logical operations are performed. general-purpose registers—In the 8080 microprocessor chip, 8-bit registers that can participate in arithmetic and logical operations with the contents of the accumulator. instruction code—A unique 8-bit binary number that encodes an operation that the 8080 microprocessor chip can perform. Fig. 3-3. Functional block diagram of the 8080 central processing unit (CPU). Note the internal data bus, which communicates with the external bidirectional data bus through a data bus buffer/latch located within the 8080 chip. instruction decoder-A decoder within the 8080 microprocessor chip that decodes the instruction code into a series of actions that the microprocessor performs. instruction register—The 8-bit register in the 8080 microprocessor chip that stores the instruction code of the instruction being executed. program counter—The 16-bit register in the 8080 microprocessor chip that contains the memory address of the next instruction byte that stack pointer—The 16-bit register in the 8080 microprocessor chip that stores the memory address of the stack, which is a region of memory that stores temporary information. The Intel Corporation Intellec 8/Mod 80 Microcomputer Development System Reference Manual provides several well-written paragraphs that summarize the concepts of instruction code, instruction register, and instruction decoder. These paragraphs are quoted below. (See Fig. 3-4 also.) "Every computer has a word length that is characteristic of that machine. In most eight-bit systems, it is most efficient to deal with eight-bit binary fields, and the memory associated with such a processor is therefore organized to store eight bits in each addressable memory location. Data and instructions are stored in memory as eight-bits nary numbers, or as numbers that are integral multiples of eight bits: Fig. 3-4. The 8-bit instruction code is first stored in the instruction register, from where it is decoded into a series of clocked actions by the instruction decoder within the 8080 microprocessor chip. 16 bits, 24 bits, and so on. This characteristic eight-bit field is sometimes referred to as a byte. "Each operation that the processor can perform is identified by a unique binary number known as an *instruction code*. An eight-bit word used as an instruction code can distinguish among 256 alternative actions, more than adequate for most processors. "The processor fetches an instruction in two distinct operations. In the first, it transmits the address in its program counter to the memory. In the second, the memory returns the addressed byte to the processor. The CPU stores this instruction byte in a register known as the instruction register, and uses it to direct activities during the remainder of the instruction cycle. "The mechanism by which the processor translates an instruction code into specific processing actions requires more elaboration than we can here afford. The concept, however, will be intuitively clear to an experienced logic designer. The eight bits stored in the instruction register can be decoded and used to activate selectively one of a number of output lines, in this case up to 256 lines. Each line represents a set of activities associated with execution of a particular instruction code. The enabled line can be combined coincidentally with selected timing pulses, to develop electrically sequential signals that can be used to initiate specific actions. This translation of code into action is performed by the instruction decoder and by the associated control circuitry." The important point here is that the instruction code is translated into a sequence of specific actions. The two-phase clock is vital to this process. The actions may result in the moving of data from memory to the accumulator, or adding the contents of register B to register A, or complementing the accumulator, or any of the specific operations contained in the 8080 instruction set. Nevertheless, each specific operation performed by an 8080 instruction is the result of one or more specific actions caused by the instruction decoder. # WHAT TYPES OF OPERATIONS DOES THE 8080 MICROPROCESSOR PERFORM? The purpose of this section is not to subdivide the 8080 instruction set into categories, but rather to identify the basic types of operations that the chip actually performs. - Move a Byte From One Location to Another From one general-purpose register to another From a general-purpose register to memory, and vice versa From the accumulator to memory, and vice versa From the accumulator to a general-purpose register, and vice versa From memory to the instruction register From memory to the program counter, and vice versa From memory to the stack pointer From the accumulator to an output latch From an input device to the accumulator From an external three-state buffer to the instruction register From the flag register to memory, and vice versa From a general-purpose register to the stack pointer From the program counter to the stack, and vice versa From the general-purpose registers to the stack, and vice versa From the accumulator to the stack, and vice versa From the flag register to the stack, and vice versa From an input device to a general-purpose register From a general-purpose register to an output device From a general-purpose register to the program counter - ARITHMETIC AND LOCICAL OPERATIONS AND contents of register or memory with accumulator OR contents of register or memory with accumulator Exclusive-or contents of register or memory with accumulator Compare contents of register or memory with accumulator Add contents of register or memory to accumulator (with or without carry) Subtract contents of register or memory from accumulator (with or without borrow) Rotate contents of accumulator Increment contents of general-purpose register, register pair, ac- cumulator, memory, or stack pointer Decrement contents of general-purpose register, register pair, accumulator, memory, or stack pointer Add contents of register pair to contents of register pair or stack Decimal adjust the contents of the accumulator ### • MISCELLANEOUS OPERATIONS No operation Halt Enable the interrupt system Disable the interrupt system Complement the accumulator Set the carry flag Complement the carry flag Most of the time, all that the 8080 microprocessor chip does is to move a byte from one location to another or perform an arithmetic or logical operation. Rarely does it perform one of the miscellaneous operations. In other words, the chip does not just compute it; it moves bytes ### 8080 MNEMONIC INSTRUCTIONS You should learn as soon as possible the 8080 mnemonics so that you can do assembly language programming, read other assembly language programs for the 8080, and improve your capability to understand the instruction sets for other microprocessor chips. The 8080 mnemonics are listed by groups in the Intel 8080 Microcomputer Systems User's Manual, which you should obtain. Here, the mnemonics are listed in alphabetic order, and then described in detail. There are two reference sources for this material: Intel 8080 Microcomputer Systems User's Manual, Intel Corporation, 3065 Bowers Avenue, Santa Clara, California 95051, 1975. \$5.00. μCOM-8 Software Manual, NEC Microcomputers, Inc., Five Militia Drive, Lexington, Massachusetts 02173, 1975. \$7.50. The authors gratefully acknowledge permission to use the above reference sources. | Mnemonic | Hexa-<br>Octal decimal | Description | |---------------|------------------------|-------------------------------------------------| | ACI <b2></b2> | 316 CE | Add immediate byte to accumulator (with carry) | | ADC M | 216 8E | Add memory contents to accumulator (with carry) | | Mnemonic | Octal | Hexa-<br>decimal | Description | |------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADC r | 218 | † | Add register contents to accumulator | | ADD M<br>ADD r<br>ADI <b2><br/>ANA M<br/>ANA r<br/>ANI <b2></b2></b2> | 206<br>20S<br>306<br>246<br>26S<br>346 | 86<br>†<br>C6<br>A6<br>†<br>E6 | (with carry) Add memory contents to accumulator Add register contents to accumulator Add immediate byte to accumulator AND memory contents with accumulator AND register contents with accumulator AND immediate byte with accumulator | | CALL <b2> <b3> CC <b2> <b3> CM <b2> <b3> CMA CMA CMC CMC CMC</b3></b2></b3></b2></b3></b2> | 315<br>334<br>374<br>057<br>077<br>276 | CD<br>DC<br>FC<br>2F<br>3F<br>BE | Call subroutine unconditionally Call subroutine if carry flag is set Call subroutine if sign flag is set Complement contents of accumulator Complement carry flag Compare memory contents with accumulator | | CMP r CNC <b2> <b3> CNZ <b2> <b3> CP <b2> <b3> CP <b2> <b3> CPE <b2> <b3> CPE <b2> <b3></b3></b2></b3></b2></b3></b2></b3></b2></b3></b2></b3></b2> | 27S<br>324<br>304<br>364<br>354<br>376 | †<br>C4<br>F4<br>EC<br>FE | Compare register contents with accumulator Call subroutine if carry flag is reset Call subroutine if zero flag is reset Call subroutine if sign flag is reset Call subroutine if parity flag is set Compare immediate byte with accumu- | | CPO <b2> <b3><br/>CZ <b2> <b3></b3></b2></b3></b2> | 344<br>314 | E4<br>CC | lator Call subroutine if parity flag is reset Call subroutine if zero flag is set | | DAA DAD B DAD D DAD D DAD H DAD SP DCR M DCR r DCX B DCX D DCX H DCX SP DI | 047<br>011<br>031<br>051<br>071<br>065<br>0D5<br>013<br>033<br>053<br>073<br>363 | 27<br>09<br>19<br>29<br>39<br>35<br>†<br>0B<br>1B<br>2B<br>3B<br>F3 | Decimal adjust the accumulator contents Add register pair B to register pair H Add register pair D to register pair H Add register pair H to register pair H Add stack pointer to register pair H Decrement memory contents Decrement register contents Decrement contents of register pair B Decrement contents of register pair D Decrement contents of register pair H Decrement stack pointer Disable interrupt system | | EI<br>HLT | 373<br>166 | FB<br>76 | Enable interrupt system Halt unconditionally | | IN <82> INR M INR r INX B INX D INX H INX SP | 333<br>064<br>0D4<br>003<br>023<br>043<br>063 | DB<br>34<br>†<br>03<br>13<br>23<br>33 | Input data into accumulator Increment memory contents Increment register contents Increment contents of register pair B Increment contents of register pair D Increment contents of register pair H Increment stack pointer | | JC <b2> <b3><br/>JM <b2> <b3><br/>JMP <b2> <b3><br/>JNC <b2> <b3><br/>JNZ <b2> <b3></b3></b2></b3></b2></b3></b2></b3></b2></b3></b2> | 332<br>372<br>303<br>322<br>302 | DA<br>FA<br>C3<br>D2<br>C2 | Jump if carry flag is set<br>Jump if sign flag is set<br>Jump unconditionally<br>Jump if carry flag is reset<br>Jump if zero flag is reset | | | | Hexa- | Description | |----------------------------|-----|---------------|--------------------------------------------------------------------------------------| | Mnemonic | | decimal | · · · · · · · · · · · · · · · · · · · | | JP <b2> <b3></b3></b2> | 362 | F2 | Jump if sign flag is reset | | JPE <b2> <b3></b3></b2> | 352 | EA | Jump if parity flag is set<br>Jump if parity flag is reset | | JPO <b2> <b3></b3></b2> | 342 | E2 | Jump if zero flag is set | | JZ <b2> <b3></b3></b2> | 312 | CA | | | LDA <b2> <b3></b3></b2> | 072 | 3 <b>A</b> | Load accumulator direct with contents of<br>memory addressed by <b2> <b3></b3></b2> | | LDAX B | 012 | 0A | Load accumulator indirect with contents<br>of memory addressed by register pair B | | LDAX D | 032 | 1A | Load accumulator indirect with contents<br>of memory addressed by register pair<br>D | | LHLD <b2> <b3></b3></b2> | 052 | 2A | Load L and H with contents of M and M+1, respectively, where M = <b2> <b3></b3></b2> | | LXI B <b2> <b3></b3></b2> | 001 | 01 | Load immediate bytes into register pair B | | 1.XI D <b2> <b3></b3></b2> | 021 | 11 | Load immediate bytes into register pair D | | LXI H <b2> <b3></b3></b2> | 041 | 21 | Load immediate bytes into register pair H | | LXI SP <b2> <b3></b3></b2> | 061 | 31 | Load immediate bytes into stack pointer | | | 066 | 36 | Move immediate byte into memory | | MVI M <b2></b2> | 0D6 | † | Move immediate byte into register | | MVI r <b2></b2> | 16S | ÷ | Move register contents to memory | | MOV, M,r<br>MOV r,M | 1D6 | ÷ | Move memory contents to register | | MOV r,M<br>MOV r1,r2 | 1DS | Ť | Move register 2 contents to register 1 | | NOP | 000 | 00 | No operation | | ORA M | 266 | В6 | On memory contents with accumulator | | ORA n | 26S | Ť | On register contents with accumulator | | ORI <b2></b2> | 366 | F6 | On immediate byte with accumulator | | OUT <b2></b2> | 323 | D3 | Output accumulator contents | | PCHL | 351 | E9 | Load program counter with contents of<br>register pair H (indirect jump) | | POP B | 301 | C1 | Pop register pair B off stack | | POP D | 321 | D1 | Pop register pair D off stack | | POP H | 341 | $\mathbf{E}1$ | Pop register pair H off stack | | POP PSW | 361 | F1 | Pop program status word (accumulator<br>and flags) off stack | | PUSH B | 305 | C5 | Push register pair B contents on stack | | PUSH D | 325 | D5 | Push register pair D contents on stack | | PUSH H | 345 | E5 | Push register pair H contents on stack | | PUSH PSW | 365 | F5 | Push program status word (accumulator<br>and flags) on stack | | RAL | 027 | 17 | Rotate accumulator contents left through<br>carry | | RAR | 037 | 1F | Rotate accumulator contents right<br>through carry | | RC | 330 | D8 | Return if carry flag is set | | RET | 311 | C9 | Return unconditionally | | RLC | 007 | 07 | Rotate accumulator contents left | | RM | 370 | F8 | Return if sign flag is set | | RNC | 320 | D0 | Return if carry flag is reset | | RNZ | 300 | | Return if zero flag is reset | | RP | 360 | F0 | Return if sign flag is reset | | | | | | | Mnemonic | Octal | Hexa-<br>decimal | Description | |--------------------------|-------|------------------|-----------------------------------------------------------------------------------------------| | RPE | 350 | E8 | Return if parity flag is set | | RPO | 340 | E0 | Return if parity flag is reset | | RRC | 017 | 0F | Rotate accumulator contents right | | RST n | 3N7 | t | Call subroutine at location HI = 000 and LO = 0N0 | | RZ | 310 | C8 | Return if zero flag is set | | SBB M | 236 | 9E | Subtract memory contents from accumu-<br>lator (with borrow) | | SBB r | 23S | t | Subtract register contents from accumu-<br>lator (with borrow) | | SBI <b2></b2> | 336 | DE | Subtract immediate byte from accumu-<br>lator (with borrow) | | SHLD <b2> <b3></b3></b2> | 042 | 22 | Store contents of register pair H into M and M+1, respectively, where M = <b2> <b3></b3></b2> | | SPHL | 371 | F9 | Move register pair H contents to stack<br>pointer | | STA <b2> <b3></b3></b2> | 062 | 32 | Store accumulator contents direct into memory location address <b2> <b3></b3></b2> | | STAX B | 002 | 02 | Store accumulator contents indirect into<br>memory location addressed by register<br>pair B | | STAX D | 012 | 0A | Store accumulator contents indirect into<br>memory location addressed by register<br>pair D | | STC | 067 | 37 | Set carry flag | | SUB M | 226 | 96 | Subtract memory contents from accumu-<br>lator | | SUB r | 22S | † | Subtract register contents from accumu-<br>lator | | SUI <b2></b2> | 326 | D6 | Subtract immediate byte from accumu-<br>lator | | XCHG | 353 | EB | Exchange contents of register pair D with contents of register pair H | | XRA M | 256 | AE | Exclusive-on memory contents with ac-<br>cumulator | | XRA r | 25S | † | Exclusive-on register contents with ac-<br>cumulator | | XRI <b2></b2> | 356 | EE | Exclusive-on immediate byte with accu-<br>mulator | | XTHL | 343 | E3 | Exchange top of stack with contents of register pair H | Not all possible 256 instruction codes are employed by the 8080 microprocessor chip. Missing codes include the following: <sup>†</sup>These instructions are not easily translated into hexadecimal notation without register or other information. This is one reason why we have chosen to work with octal numbers. | Octal | Hexadecimal | |-------|---------------| | 010 | 08 | | 020 | 10 | | 030 | 18 | | 040 | 20 | | 050 | 28 | | 060 | 30 | | 070 | 38 | | 313 | CB | | 331 | D9 | | 335 | DD | | 355 | $\mathbf{ED}$ | | 375 | FD | # OCTAL/HEXADECIMAL LISTING OF THE 8080 INSTRUCTION SET In addition to listing the 8080 instruction set alphabetically according to the mnemonic code, it is also useful to list the instructions in octal code. Such a list is provided below. You may wish to make a copy of it and keep it handy. The authors have found it to be quite useful when they are developing short programs in machine code. The indication --- indicates that the instruction byte has no influence on the 8080; it is not a valid instruction. | Octal | Hexa-<br>decimal | Mnemonic | Description | |-------|------------------|---------------------------|----------------------------------------------------| | 000 | 00 | NOP | No operation | | 001 | 01 | LXI B <b2> <b3></b3></b2> | Load immediate into register pair B and C | | 002 | 02 | STAX B | Store A indirect into M addressed by B and C | | 003 | 03 | INX B | Increment contents of register pair B and C by one | | 004 | 04 | INR B | Increment register B by one | | 005 | 05 | DCR B | Decrement register B by one | | 006 | 06 | MVI B <b2></b2> | Move immediate into register B | | 007 | 07 | RLC | Rotate A left | | 010 | 08 | | | | 011 | 09 | DAD B | Add contents of B,C to H,L and store in H,L | | 012 | 0A | LDAX B | Load A indirect from M addressed by B<br>and C | | 013 | 0B | DCX B | Decrement contents of register pair B and C by one | | 014 | 0C | INR C | Increment register C by one | | 015 | 0D | DCR C | Decrement register C by one | | 016 | 0E | MVI C <b2></b2> | Move immediate into register C | | 017 | $\mathbf{0F}$ | RRC | Rotate A right | | 020 | 10 | | | | | Hexa- | | <b>5</b> | |-------|---------|----------------------------|---------------------------------------------------------------------------------------------| | Octal | decimal | Mnemonic | Description | | 021 | 11 | LXI D <b2> <b3></b3></b2> | Load immediate into register pair D and E | | 022 | 12 | STAX D | Store A indirect into M addressed by D and E | | 023 | 13 | INX D | Increment contents of register pair D and E by one | | 024 | 14 | INR D | Increment register D by one | | 025 | 15 | DCR D | Decrement register D by one | | 026 | 16 | MVI D <b2></b2> | Move immediate into register D | | 027 | 17 | RAL | Rotate A left through carry | | 030 | 18 | | | | 031 | 19 | DAD D | Add contents of D,E to H,L and store in H,L | | 032 | 1A | LDAX D | Load A indirect from M addressed by D<br>and E | | 033 | 1B | DCX D | Decrement contents of register pair D<br>and E by one | | 034 | 1C | INR E | Increment register E by one | | 035 | 1D | DCR E | Decrement register E by one | | 036 | 1E | MVI E <b2></b2> | Move immediate into register E | | 037 | 1F | RAR | Rotate A right through carry | | 040 | 20 | | | | 041 | 21 | LXI H <b2> <b3></b3></b2> | Load immediate into register pair H and<br>L | | 042 | 22 | SHLD <b2> <b3></b3></b2> | Store L and H into M and M+1, where $M = \langle 82 \rangle \langle 83 \rangle$ | | 043 | 23 | INX H | Increment contents of register pair H and L by one | | 044 | 24 | INR H | Increment register H by one | | 045 | 25 | DCR H | Decrement register H by one | | 046 | 26 | MVI H <b2></b2> | Move immediate into register H | | 047 | 27 | DAA | Decimal adjust A | | 050 | 28 | | | | 051 | 29 | DAD H | Add contents of H,L to H,L and store in H,L | | 052 | 2A | LHLD <b2> <b3></b3></b2> | Load L and H with contents of M and $M+1$ , where $M=\langle B2 \rangle \langle B3 \rangle$ | | 053 | 2B | DCX H | Decrement contents of register pair H and L by one | | 054 | 2C | INR L | Increment register L by one | | 055 | $^{2}D$ | DCR L | Decrement register L by one | | 056 | 2E | MVI L <b2></b2> | Move immediate into register L | | 057 | 2F | CMA | Complement A | | 060 | 30 | | | | 061 | 31 | LXI SP <b2> <b3></b3></b2> | Load immediate into stack pointer | | 062 | 32 | STA <b2> <b3></b3></b2> | Store A direct into M addressed by <b2> <b3></b3></b2> | | 063 | 33 | INX SP | Increment register SP by one | | 064 | 34 | INR M | Increment contents of M by one | | 065 | 35 | DCR M | Decrement contents of M by one | | 066 | 36 | MVI M <b2></b2> | Move immediate into M addressed by H and L | | 067 | 37 | STC | Set carry flip-flop to logic one | | 070 | 38 | D. I.D. CD | Add stack pointer contents to H,L and | |------------|------------|-------------------------|-----------------------------------------------------------------------------| | 071 | 39 | DAD SP | store in H.L | | 072 | 3A | LDA <b2> <b3></b3></b2> | Load A direct with contents of M addressed by <b2> <b3></b3></b2> | | 073 | 3 <b>B</b> | DCX SP | Decrement register SP by one | | 074 | 3C | INR A | Increment register A by one | | 075 | 3D | DCR A | Decrement register A by one | | 076 | 3E | MVI A <b2></b2> | Move immediate into register A | | 077 | 3F | CMC | Complement carry flip-flop | | 100 | 40 | MOV B,B | Move contents of register B to register B | | 101 | 41 | MOV B,C | Move contents of register C to register B | | 102 | 42 | MOV B,D | Move contents of register D to register B | | 103 | 43 | MOV B,E | Move contents of register E to register B | | 104 | 44 | MOV B,H | Move contents of register H to register B | | 105 | 45 | MOV B,L | Move contents to register L to register B | | 106 | 46 | MOV B,M | Move contents of M to register B | | 107 | 47 | MOV B,A | Move contents of register A to register B | | 110 | 48 | MOV C,B | Move contents of register B to register C | | 111 | 49 | MOV C,C | Move contents of register C to register C | | 112 | 4A | MOV C,D | Move contents of register D to register C | | 113 | 4B | MOV C,E | Move contents of register E to register C | | 114 | 4C | MOV C,H | Move contents of register H to register C | | 115 | 4D | MOV C,L | Move contents of register L to register C | | 116 | 4E | MOV C,M | Move contents of M to register C | | 117 | 4F | MOV C,A | Move contents of register A to register C | | 120 | 50 | MOV D,B | Move contents of register B to register D | | 121 | 51 | MOV D,C | Move contents of register C to register D | | 122 | 52 | MOV D,D | Move contents of register D to register D | | 123 | 53 | MOV D,E | Move contents of register E to register D | | 124 | 54 | MOV D,H | Move contents of register H to register D | | 125 | 55 | MOV D,L | Move contents of register L to register D | | 126 | 56 | MOV D,M | Move contents of M to register D Move contents of register A to register D | | 127 | 57 | MOV D,A | Move contents of register B to register E | | 130 | 58 | MOV E,B | Move contents of register C to register E | | 131 | 59 | MOV E,C<br>MOV E.D | Move contents of register D to register E | | 132 | 5A | MOV E,E<br>MOV E,E | Move contents of register E to register E | | 133 | 5B | MOV E,E<br>MOV E,H | Move contents of register H to register E | | 134 | 5C<br>5D | MOV E,H<br>MOV E,L | Move contents of register L to register E | | 135 | 5E | MOV E,M | Move contents of M to register E | | 136<br>137 | 5F | MOV E,M<br>MOV E,A | Move contents of register A to register E | | 140 | 60 | MOV H,B | Move contents of register B to register H | | 141 | 61 | MOV H,C | Move contents of register C to register H | | 142 | 62 | MOV H.D | Move contents of register D to register H | | 143 | 63 | MOV H,E | Move contents of register E to register H | | 144 | 64 | MOV H,H | Move contents of register H to register H | | 145 | 65 | MOV H,L | Move contents of register L to register H | | 146 | 66 | MOV H,M | Move contents of M to register H | | 147 | 67 | MOV H,A | Move contents of register A to register H | | 150 | 68 | MOV L.B | Move contents of register B to register L | | 151 | 69 | MOV L.C | Move contents of register C to register L | | 152 | 6A | MOV L,D | Move contents of register D to register L | | 153 | 6B | MOV L.E | Move contents of register E to register L | | 154 | 6C | MOV L,H | Move contents of register H to register L | | ~~ * | | , | | | 0.1 | Hexa- | 16 | Departmen | |-------------------|----------------------|--------------------|---------------------------------------------------------------------------| | Octal | decimal | Mnemonic | Description | | 155 | 6D | MOV L,L | Move contents of register L to register L | | 156 | 6E | MOV L,M | Move contents of M to register L | | 157 | 6F | MOV L,A | Move contents of register A to register L | | 160 | 70 | MOV M,B | Move contents of register B to M | | 161 | 71 | MOV M,C | Move contents of register C to M<br>Move contents of register D to M | | 162 | 72 | MOV M,D | Move contents of register D to M Move contents of register E to M | | 163 | 73<br>74 | MOV M,E<br>MOV M,H | Move contents of register H to M | | $\frac{164}{165}$ | 7 <del>4</del><br>75 | MOV M,L | Move contents of register L to M | | 166 | 76 | HLT | Halt | | 167 | 77 | MOV M,A | Move contents of register A to M | | 170 | 78 | MOV A,B | Move contents of register B to register A | | 171 | 79 | MOV A,C | Move contents of register C to register A | | 172 | 7A | MOV A,D | Move contents of register D to register A | | 173 | 7B | MOV A,E | Move contents of register E to register A | | 174 | 7C | MOV A,H | Move contents of register H to register A | | 175 | 7D | MOV A,L | Move contents of register L to register A | | 176 | 7E | MOV A,M | Move contents of M to register A | | 177 | 7 <b>F</b> | MOV A,A | Move contents of register A to register A | | 200 | 80 | ADD B | Add contents of register B to register A | | 201 | 81 | ADD C | Add contents of register C to register A | | 202 | 82 | ADD D | Add contents of register D to register A | | 203 | 83 | ADD E | Add contents of register E to register A | | 204 | 84 | ADD H | Add contents of register H to register A | | 205 | 85<br>86 | ADD L<br>ADD M | Add contents of register L to register A Add contents of M to register A | | 206<br>207 | 87 | ADD M<br>ADD A | Add contents of M to register A Add contents of register A to register A | | 210 | 88 | ADC B | Add carry and contents of register B to | | 210 | 00 | ADC B | register A | | 211 | 89 | ADC C | Add carry and contents of register C to<br>register A | | 212 | 8A | ADC D | Add carry and contents of register D to register A | | 213 | 8B | ADC E | Add carry and contents of register E to register A | | 214 | 8C | ADC H | Add carry and contents of register H to register A | | 215 | 8D | ADC L | Add carry and contents of register L to register A | | 216 | 8E | ADC M | Add carry and contents of M to register A | | 217 | 8 <b>F</b> | ADC A | Add carry and contents of register A to register A | | 220 | 90 | SUB B | Subtract contents of register B from reg-<br>ister A | | 221 | 91 | SUB C | Subtract contents of register C from reg-<br>ister A | | 222 | 92 | SUB D | Subtract contents of register D from reg-<br>ister A | | 223 | 93 | SUB E | Subtract contents of register E from reg-<br>ister A | | 224 | 94 | SUB H | Subtract contents of register H from reg-<br>ister A | | 225 | 95 | SUB L | Subtract contents of register L from reg-<br>ister A | |-----|----------|-------|--------------------------------------------------------------| | 226 | 96 | SUB M | Subtract contents of M from register A | | 227 | 97 | SUB A | Clear register A | | 230 | 98 | SBB B | Subtract carry and contents of register B<br>from register A | | 231 | 99 | SBB C | Subtract carry and contents of register C<br>from register A | | 232 | 9A | SBB D | Subtract carry and contents of register D<br>from register A | | 233 | 9B | SBB E | Subtract carry and contents of register E<br>from register A | | 234 | 9C | SBB H | Subtract carry and contents of register H from register A | | 235 | 9D | SBB L | Subtract carry and contents of register L<br>from register A | | 236 | 9E | SBB M | Subtract carry and contents of M from<br>from register A | | 237 | 9F | SBB A | Subtract carry and contents of register A<br>from register A | | 240 | A0 | ANA B | And contents of register B with register A | | 241 | A1 | ANA C | And contents of register C with register A | | 242 | A2 | ANA D | And contents of register D with register A | | 243 | A3 | ANA E | And contents of register E with register A | | 244 | A4 | ANA H | And contents of register H with register A | | 245 | A5 | ANA L | AND contents of register L with register A | | 246 | A6 | ANA M | And contents of M with register A | | 247 | A7 | ANA A | And contents of register A with register A | | 250 | A8 | XRA B | Exclusive-on contents of register B with register A | | 251 | A9 | XRA C | Exclusive-on contents of register C with register A | | 252 | AA | XRA D | Exclusive-on contents of register D with register A | | 253 | AB | XRA E | Exclusive-on contents of register E with register A | | 254 | AC | XRA H | Exclusive-on contents of register H with register A | | 255 | AD | XRA L | Exclusive-on contents of register L with register A | | 256 | AE | XRA M | Exclusive-on contents of M with register A | | 257 | AF | XRA A | Exclusive-on contents of register A with register A | | 260 | В0 | ORA B | On contents of register B with register A | | 261 | B1 | ORA C | On contents of register C with register A | | 262 | B2 | ORA D | On contents of register D with register A | | 263 | B3 | ORA E | On contents of register E with register A | | | В3<br>В4 | ORA H | On contents of register H with register A | | 264 | | ORA L | OR contents of register L with register A | | 265 | B5 | | On contents of M with register A | | 266 | В6 | ORA M | On contents of register A with register A | | 267 | В7 | ORA A | Compare contents of register B with reg- | | 270 | В8 | CMP B | ister A | | Octal | Hexa-<br>decimal | Mnemonic | Description | |-------|------------------|--------------------------|---------------------------------------------------------------| | | | | | | 271 | В9 | CMP C | Compare contents of register C with register A | | 272 | BA | CMP D | Compare contents of register D with reg-<br>ister A | | 273 | BB | CMP E | Compare contents of register E with reg-<br>ister A | | 274 | BC | CMP H | Compare contents of register H with register A | | 275 | BD | CMP L | Compare contents of register L with reg-<br>ister A | | 276 | BE | CMP M | Compare contents of M with register A | | 277 | BF | CMP A | Compare contents of register A with reg-<br>ister A | | 300 | C0 | RNZ | Return from subroutine of zero flip-flop<br>= logic 0 | | 301 | C1 | POP B | Pop stack and store in register pair B and C | | 302 | C2 | JNZ <b2> <b3></b3></b2> | Jump if zero flip-flop = logic 0 | | 303 | C3 | JMP <b2> <b3></b3></b2> | Jump unconditionally to M addressed by<br><b2> <b3></b3></b2> | | 304 | C4 | CNZ <b2> <b3></b3></b2> | Call subroutine if zero flip-flop = logic 0 | | 305 | C5 | PUSH B | Push contents of register pair B and C<br>on stack | | 306 | C6 | ADI <b2></b2> | Add immediate to register A | | 307 | C7 | RST 0 | Call subroutine at address 000s | | 310 | C8 | RZ | Return from subroutine if zero flip-flop = logic 1 | | 311 | C9 | RET | Return from subroutine | | 312 | CA | JZ <b2> <b3></b3></b2> | Jump if zero flip-flop = logic 1 | | 313 | CB | | | | 314 | CC | CZ <b2> <b3></b3></b2> | Call subroutine if zero flip-flop = logic 1 | | 315 | CD | CALL <b2> <b3></b3></b2> | Call subroutine located at M = <b2> <b3></b3></b2> | | 316 | CE | ACI <b2></b2> | Add immediate and carry flip-flop to register A | | 317 | CF | RST 1 | Call subroutine at address 010s | | 320 | D0 | RNC | Return from subroutine if carry flip-flop = logic 0 | | 321 | DI | POP D | Pop stack and store in register pair D and E | | 322 | D2 | JNC <b2> <b3></b3></b2> | Jump if carry flip-flop = logic 0 | | 323 | D3 | OUT <b2></b2> | Output to device addressed by <b2></b2> | | 324 | D4 | CNC <b2> <b3></b3></b2> | Call subroutine if carry flip-flop = logic 0 | | 325 | D5 | PUSH D | Push contents of register pair D and E on<br>stack | | 326 | D6 | SUI <b2></b2> | Subtract immediate from register A | | 327 | D7 | RST 2 | Call subroutine at address 020s | | 330 | D8 | RC | Return from subroutine if carry flip-flop<br>= logic 1 | | 331 | D9 | | | | 332 | DA | JC <b2> <b3></b3></b2> | Jump if carry flip-flop = logic 1 | | 333 | DB | IN <b2></b2> | Input from device addressed by <b2></b2> | | 334 | DC | CC <b2> <b3></b3></b2> | Call subroutine if carry flip-flop = logic 1 | | | | | | Let us examine the 64 MOV instructions that begin with the octal digit 1. These instructions cause eight bits of data to be transferred between (a) the accumulator and a general-purpose register, (b) the accumulator and memory, (c) a general-purpose register and memory, or (d) two different registers. There is a consistent coding pattern, which is described in the following paragraph. The three-octal-digit instruction, in which the first digit is 1, can be represented as follows: The source register is the one that contains the 8-bit data byte that is being transferred. The destination register is the one that receives the transferring 8-bit data byte. Thus, in the octal/hexadecimal listing, we "move contents of [source register] to the [destination register]." The mnemonic is: ### MOV [destination register], [source register] Examine the 8080 instruction listing and verify the conclusions given above. Octal instruction 141 must mean "move contents of register C to register H," and sure enough it does. In these operations, the source register will still contain the transferred data since the MOV operation is simply a copy operation. ## ARITHMETIC AND LOGIC OPERATION DECODING We are also told by Intel Corporation that arithmetic and logic operations correspond to the following 3-bit binary codes: | Arithmetic or Logic Operation | 3-Bit Code | Octal Code | |----------------------------------|------------|------------| | add | 000 | 0 | | add<br>add with carry | 001 | 1 | | | 010 | 2 | | subtract<br>subtract with borrow | 011 | 3 | | * - T | 100 | 4 | | AND | 101 | 5 | | exclusive-or | 110 | 6 | | OR | 111 | 7 | | compare | *** | | If we examine the 64 arithmetic and logic operations that begin with the octal digit 2, we can spot yet another consistent coding pattern shown below. The three-octal-digit instruction, in which the first octal digit is 2, can be represented as follows: In the octal/hexadecimal listing, we perform an arithmetic or logic operation using a source register [with, to, or from] the accumulator. The mnemonic is: [arithmetic or logic operation] [source register] Examine the 8080 instruction listing and verify these additional conclusions. Note again that we are doing on paper what the instruction decoder does electronically. So far, we have decoded 128 of the 244 microprocessor instructions. We are doing well, so let us continue. We note eight additional arithmetic/logical instructions: | 306 | ADI <b2></b2> | |-----|---------------| | 316 | ACI <b2></b2> | | 326 | SUI <b2></b2> | | 336 | SBI <b2></b2> | | 346 | ANI <b2></b2> | | 356 | XRI <b2></b2> | | 366 | ORI <b2></b2> | | 376 | CPI <b2></b2> | The coding pattern is simply the following: the three-octal-digit instruction, in which the first octal digit is 3 and the last octal digit is 6, can be represented as follows: According to the octal/hexadecimal listing, we perform an arithmetic or logic operation using the immediate 8-bit byte [with, to, or from] the accumulator. The mnemonic is: | 335 | DD | any ana | Subtract immediate and carry flip-flop | |------------|------------------------|-------------------------|-----------------------------------------------------------------| | 336 | DE | SBI <b2></b2> | from register A | | 227 | DF | RST 3 | Call subroutine at address 030s | | 337<br>340 | E0 | RPO | Return from subroutine if parity flip-flop | | 340 | EU | III O | = logic 0 | | 341 | E1 | POP H | Pop stack and store in register pair H | | | | | and L Jump if parity flip-flop = logic 0 | | 342 | E2 | JPO <b2> <b3></b3></b2> | Exchange top of stack with contents of | | 343 | E3 | XTHL | H and L | | | Y7.4 | CPO <b2> <b3></b3></b2> | Call subroutine if parity flip-flop = logic 0 | | 344 | E4<br>E5 | PUSH H | Push contents of register pair H and L | | 345 | Eð | 10311 11 | on stack | | 346 | F6 | ANI <b2></b2> | And immediate with contents of register A | | 347 | E7 | RST 4 | Call subroutine at address 040s | | 350 | E8 | RPE | Return from subroutine if parity flip-flop | | | | | = logic 1<br>Jump indirect to M addressed by register | | 351 | E9 | PCHL | pair H and L | | | | IPE <b2> <b3></b3></b2> | Jump if parity flip-flop = logic 1 | | 352 | EA | XCHG | Exchange contents of registers H,L with | | 353 | EB | ACHG | registers D,E | | 354 | EC | CPE <b2> <b3></b3></b2> | Call subroutine if parity flip-flop = logic 1 | | 355 | ED | | a | | 356 | $\mathbf{E}\mathbf{E}$ | XRI <b2></b2> | Exclusive-on immediate with contents of | | | | | register A<br>Call subroutine at address 050₃ | | 357 | EF | RST 5 | Return from subroutine if sign flip-flop = | | 360 | F0 | RP | logic 0 | | 361 | F1 | POP PSW | Pop stack and store in register A and flag | | 301 | 1.1 | 101 15 | flip-flops | | 362 | F2 | JP <b2> <b3></b3></b2> | Jump if sign flip-flop = logic 0 [positive | | | | • | sign] | | 363 | F3 | DI | Disable interrupt Call subroutine if sign flip-flop $=$ logic 0 | | 364 | F4 | CP <b2> <b3></b3></b2> | Push contents of register A and flags on | | 365 | F5 | PUSH PSW | stack | | 366 | F6 | ORI <b2></b2> | On immediate with contents of register A | | 367 | F7 | RST 6 | Call subroutine at address 060s | | 370 | F8 | RM | Return from subroutine if sign flip-flop = | | 0.0 | | | logic 1 | | 371 | F9 | SPHL | Transfer contents of registers H,L to stack pointer | | | | n. (na) (na) | Jump if sign flip-flop = logic 1 [minus | | 372 | FA | JM <b2> <b3></b3></b2> | sign] | | 373 | FB | EI | Enable interrupt | | 374 | FC | CM <b2> <b3></b3></b2> | Call subroutine if sign flip-flop = logic 1 | | 375 | FD | | | | 376 | FE | CPI <b2></b2> | Compare immediate with contents of | | | | 70 F | register A<br>Call subroutine at address 070 <sub>8</sub> | | 377 | FF | RST 7 | Can subfourne at address \$1.50 | | | | | | ### AN EXAMPLE OF INSTRUCTION DECODING We have previously defined the *operation code*, also known as the *instruction code*, as the 8-bit code for the specific operation that the 8080 microprocessor will perform. Study the octal/hexadecimal listing of the 8080 instruction set given on the preceding pages. You will observe that the first octal digit can be a 0, 1, 2, or 3 and that *specific classes of operations correspond to the digits 0, 1, 2, and 3.* Thus we can write the following: | First Octal Digit | Class of Operation | |-------------------|--------------------------------------------------------------------------------------------------------------------------| | 0 | Data operations only, with the possible exception of octal instructions 067 and 077 | | | | | 1 | Data transfer operations only, all of which have the common Intel mnemonic MOV | | 2 | Arithmetic and logic operations only, including add, subtract, AND, exclusive OR, OR, and compare | | 3 | Miscellaneous operations, including all conditional operations such as jump, call subroutine, and return from subroutine | We have just decoded the 244-instruction set of the 8080 microprocessor into four classes of operations, each class containing related operations (perhaps with the exception of the final class, within which the operations are not all closely related). We have done the exact same thing on paper that the *instruction decoder* within the microprocessor does electronically. ### REGISTER DECODING Since we succeeded so well in decoding the set of 244 instructions into four distinct classes, let us examine the octal/hexadecimal instruction set listing for other coding patterns. We are told by Intel Corporation that the accumulator, the six general-purpose registers (B, C, D, E, H, and L), and memory M correspond to the following 3-bit binary codes: | Register Name | 3-Bit Code | Octal Code | |-----------------|------------|------------| | В | 000 | 0 | | $\mathbf{C}$ | 001 | 1 | | D | 010 | 2 | | E | 011 | 3 | | H | 100 | 4 | | L | 101 | 5 | | memory | 110 | 6 | | accumulator (A) | 111 | 7 | the time that the jump occurs. This allows the processor later to resume execution of the main program, when it is finished with the last instruction of the subroutine. $^8$ return from subroutine, return—A special type of jump in which the central processor resumes execution of the main program at the value of the program counter at the time that the call occurred. subroutine—1. In computer technology, the portion of a program that causes a computer to carry out a well-defined mathematical or logical operation. 2. Usually called a closed subroutine. A small subprogram to which control may be transferred from a main program, and returned to the main program at the conclusion of the subroutine. closed subroutine—Subroutine not stored in the main path of the routine. Such a subroutine is entered by a jump operation; provision is made to return control to the main program at the end of the operation.<sup>5</sup> routine—Set of instruction codes arranged in proper sequence to direct the computer to perform a desired operation or sequence of operations. Alternatively, a subdivision of a program consisting of two or more instructions that are functionally related.<sup>5</sup> program—Complete plan for the solution of a problem. More specifically, the complete sequence of machine instructions and routines necessary to solve a problem.<sup>5</sup> With the 8080 microprocessor, branch instructions, except for the *unconditional* ones, correspond to the following 3-bit code for the least significant three bits: | Branch Instruction | 3-Bit Code | Octal Cod | |--------------------|------------|-----------| | return | 000 | 0 | | jump | 010 | 2 | | call | 100 | 4 | The instruction class for a branch instruction is always 3; this is the first octal digit of the three-digit instruction. Branch instructions can be either conditional or unconditional: conditional instruction—In the 8000 microprocessor, an instruction that is subject to a condition, viz., the logic state of a specified flag. unconditional instruction—In the 8080 microprocessor, an instruction that is not subject to any condition, such as the logic state of a specified flag. We shall now discuss the unconditional jump, call, and return instructions, which have the following instruction codes: 303 <B2> <B3> unconditional jump (JMP) 315 <B2> <B3> unconditional call (CALL) unconditional return (RET) Fig. 3-6. Diagrams illustrating the differences between the unconditional jump, call, and return instructions. A call instruction always requires a return instruction in the subroutine. Note that the unconditional return instruction is one-byte, whereas the Note that the unconditional return instruction is one-byte, whereas the other two are three-byte instructions. The differences between unconditional jump, call, and return instructions can be seen with the aid of Fig. 3-6. The jump instruction ① creates a loop in the main program in Fig. 3-6A. If one would start at the beginning of this program, there would be no way in which one could get past this jump instruction. Let us assume that we can get past it and proceed to jump instructions ③ and ④, which both jump to the same location, a subprogram. Unfortunately, from this subprogram the jump instruction ④ forces a return to a single point in the main program. A second loop is thus created as a consequence of jump instructions ④ and ④. ### [arithmetic or logic operation] I where the mnemonics for the arithmetic or logic operations are: ### Immediate Instruction | Arithmetic or Logic Operation | Mnemonic | |-------------------------------|----------| | add | ADI | | add with carry | ACI | | subtract | SUI | | subtract with borrow | SBI | | AND | ANI | | exclusive on | XRI | | OR | ORI | | compare | CPI | ### IMMEDIATE OPERATION DECODING The term $immediate\ addressing$ is defined as follows: immediate addressing—The instruction contains the data itself. This data is either a single 8-bit data byte or two 8-bit data bytes. The least significant byte is first and the most significant byte is second when there are two 8-bit data bytes. Immediate instructions can be represented as shown in Fig. 3-5. Eight immediate instructions were given in the preceding section. The remaining twelve such instructions are: ``` MVI B <B2> 006 016 MVI C \langle B2 \rangle MVI D <B2> 026 MVI E <B2> MVI H <B2> 036 046 056 MVI L <B2> MVI M <B2> 066 MVI A <B2> LXI B <B2> <B3> 076 001 LXI D <B2> <B3> LXI H <B2> <B3> 021 041 LXI SP <B2> <B3> ``` (B) Three-byte immediate instruction. Fig. 3-5. Immediate instructions. We can conclude that all immediate instructions that have a single data byte have either a 0 or 3 octal digit as the instruction class and 6 as the third octal digit. The mnemonic code, MVI [destination register] means "move the following 8-bit data byte to the [destination register]." The memory location M is really not a register, but let us not quibble over this minor detail. #### **BRANCH OPERATION DECODING** To quote the Intellec 8/Mod 80 Microcomputer Development System Reference Manual once again: "The instructions that make up a program are stored in the system's memory. The central processor examines the contents of the memory, in order to determine what action is appropriate. This means that the processor must know which location contains the next instruction. "Each of the locations in memory is numbered, to distinguish it from all other locations in memory. The number which identifies a memory location is called its *address*. "The processor maintains a counter which contains the address of the next program instruction. This register is called the *program counter*. The processor updates the program counter by adding '1' to the counter each time it fetches an instruction, so that the program counter is always current. "The programmer therefore stores his instructions in numerically adjacent addresses, so that the lower addresses contain the first instructions to be executed and the higher addresses contain later instructions. The only time the programmer may violate this sequential rule is . . ." with a branch instruction such as jump, call, subroutine, or return from subroutine. Thus, we can define the following terms: address—The 16-bit binary number which identifies a memory location. program counter—The register that contains the address of the next instruction bute that must be executed in a computer program. struction byte that must be executed in a computer program. branch instruction, branch operation—An instruction that causes a program jump to a specified address and execution of the instruction at that address. During the execution of a branch instruction, the central processor replaces the contents of the program counter with the specified address. jump-1. To cause the next instruction to be selected from a specified storage location in a computer. 2. A deviation from the normal sequence of execution of instructions in a computer.<sup>4</sup> call subroutine, call—1. To transfer control to a specified closed subroutine. 2. A special type of jump in which the central processor is logically required to "remember" the contents of the program counter at Let us now discuss the main program and two subroutines in Fig. 3-6B. This program flows smoothly and there are no problems with it. Thus: - Call instruction © calls Subroutine No. 2. When this subroutine is finished, program control returns to the instruction immediately following call instruction ©. - Call instruction © calls Subroutine No. 1. When this subroutine is finished, program control returns to the instruction immediately following call instruction ©. Finally, call instruction © calls Subroutine No. 1 also. However, - Finally, call instruction ① calls Subroutine No. 1 also. However, the second time that Subroutine No. 1 finishes, program control returns to the instruction immediately following call instruction ①. Clearly, the call instruction is a "smart" instruction, since it remembers where in the main program the call instruction occurred. In contrast, the jump instruction in the program on the left is a "dumb" instruction; it does not remember where it jumped from. Jump instructions are rarely used for the transfer of control to subprograms. Call instructions are used instead, and return instructions are added to convert the subprograms into subroutines. ### CONDITIONAL BRANCH INSTRUCTIONS The three conditional branch instructions can be stated as follows: conditional jump "Jump if [condition flag] is at [logic state] to memory location addressed by bytes B2 and B3. Otherwise, continue to the next sequential instruction." conditional call: "Call subroutine if [condition flag] is at [logic state] at memory location addressed by bytes B2 and B3. Otherwise, continue to the next sequential instruction." conditional return: "Return from subroutine to main program if [condition flag] is at [logic state]. Otherwise, continue to the next sequential instruction." The jump and call conditional instructions are three-byte instructions, which can be represented by: whereas the return conditional instructions are single-byte: A popular technique in developing computer programs is flow- flowchart, flow diagram-A chart showing all the logical steps of a computer program. A program is coded by writing down the successive instructions that will cause the computer to perform the logical operations necessary for solving the problem, as represented on a flowchart.4 flowchart symbol-A symbol used on a flowchart to represent data, flow, equipment, or an operation.4 decision-In a computer, the process of determining further action on the basis of the relationship of two similar items of data.<sup>4</sup> decision symbol—On a flowchart, a symbol used to mark a choice or branching in the sequence of programming of a digital computer.4 We have digressed here because we shall use the symbol for decision commonly found in flowcharts (see Fig. 3-7), and Figs. 3-8 through 3-10 will aid our discussion of the three conditional instructions. The symbol in Fig. 3-7 represents the following decisions: If the flag is at logic 0, go to the indicated instruction; if the flag is at logic 1, go to the alternative instruction. The JZ instruction shown in Fig. 3-8A requires the following decision: If the zero flag is at logic 0, the program executes the next sequential instruction after the JZ instruction; if the zero flag is at logic 1, the program jumps to the memory address contained within the second and third bytes of the instruction. The JNZ instruction (Fig. 3-8B) behaves similarly, but the flag conditions are reversed. The CZ instruction shown in Fig. 3-9A is similar to the JZ instruction but better: If the zero flag is at logic 0, the program executes the next sequential instruction after the CZ instruction; if the zero flag is at logic 1, the address of the following instruction is stored in the stack, and the program jumps to the subroutine given by the memory address contained within the second and third bytes of the instruction. With the Fig. 3-7. Decision symbol used in flowcharts. Fig. 3-8. The conditional instructions JNZ and JZ. CNZ instruction, the flag conditions are reversed (Fig. 3-9B). These instructions are quite popular. instructions are quite popular. With the RZ instruction shown in Fig. 3-10A, the following decision is made: If the zero flag is at logic 0, the subroutine executes the next sequential instruction after the RZ instruction; if the zero flag is at logic 1, a 16-bit address is retrieved from the stack and the program control returns to the main program at the instruction immediately following Fig. 3-9. The conditional instructions CZ and CNZ. Fig. 3-10. Diagrams illustrating conditional instructions RZ and RNZ. the three-byte call subroutine instruction. The figure points out that a return instruction must be executed during any pass through the subroutine. If the RZ instruction is skipped, some other return instruction, such as RET, must be present to transfer control back to the main program. With the RNZ instruction, the flag conditions are reversed (Fig. 3-10B). In the following section, we shall discuss the condition flags in greater detail. #### CONDITION FLAG DECODING A flag is an ubiquitous digital electronic device that is widely used in machine language programming and in computer/instrument interfacing. Unfortunately, it is not easy to find a suitable definition for this term. The best seems to be the following: flag, condition flag—A single flip-flop that indicates that a certain condition has arisen during the course of (a) arithmetic or logical manipulations in a computer program, or (b) data transmission between a pair of digital electronic devices such as a computer and an instrument. For example, a flag indicates when the accumulator has a value of 000<sub>8</sub>. As another example, a flag can be a circuit that provides a signal which indicates that an input device is ready to transmit data to a computer. The important point is that a flag is a flip-flop that provides a 1-bit piece of information about a condition that exists. According to the Intellec 8/Mod 80 Reference Manual, there are five condition flags associated with the execution of instructions in the 8080 microprocessor. These flags are: carry sign parity auxiliary carry and are each represented by a one-bit register, or flip-flop, contained within the microprocessor chip. When you read the Intel literature, keep in mind the following: When a flag is "set," the flag bit is at logic 1; when a flag is "reset," the flag bit is at logic 0. A synonym for "reset" is "cleared." Arithmetic or logical instructions performed on either the accumulator contents, the contents of one of the six general-purpose registers, or the contents of memory, influence the flags in the following ways: zero flag-If the result of an instruction has the value 0008, this flag is set to logic 1; otherwise, it is reset to logic 0. carry flag-If the result of an instruction produces a carry (from addition or rotation) or a borrow (from subtraction or comparison) out of the MSB of the 8-bit data byte, the carry flag is set to logic 1; otherwise, it is reset to logic 0. sign flag-If the result of an instruction produces a logic 1 in the MSB of the 8-bit data byte, this flag is set to logic 1 (indicating a negative result); otherwise, it is reset to logic 0 (indicating a positive result). parity flag—If the result of an instruction produces an 8-bit data byte the modulo 2 sum of the bits of which is logic 0 (indicating even parity), this flag is set to logic 1; otherwise, it is reset to logic 0 (indicating odd parity).8 auxiliary carry flag—If the result of an instruction causes a carry out of bit 3 into bit 4 of the resulting 8-bit data byte, the auxiliary carry flag is set to logic 1; otherwise, it is reset to logic 0. This flag is affected by single-precision additions, subtractions, increments, decrements, comparisons, and logical operations, but it is principally used with addition instructions preceding a DAA (Decimal Adjust Accumulator) instruction. lator) instruction.8 Four of the five condition flags correspond to the following 3-bit binary code, which is contained within all conditional jump, call, and return instructions. This section is shown in the representation for byte B1 of all three instructions: | Condition Flag | Mnemonic | Flag<br>Logic<br>State | 3-Bit<br>Code | Octal<br>Code | |----------------------------|---------------|------------------------|---------------|---------------| | Result is not zero | NZ | 0 | 000 | 0 | | Result is zero | $\mathbf{z}$ | 1 | 001 | 1 | | Result has no carry | NC | 0 | 010 | 2 | | Result has a carry | C | 1 | 011 | 3 | | Result has odd parity | PO | 0 | 100 | 4 | | Result has even parity | $\mathbf{PE}$ | 1 | 101 | 5 | | Result is positive | P | 0 | 110 | 6 | | Result is negative (minus) | M | 1 | 111 | 7 | The consistent coding pattern for all conditional branch instructions is therefore: The 24 different conditional instructions are summarized in Table 3-2. (The auxiliary carry flag is not a valid condition flag; it has limited use in conjunction with the DAA instruction.) Table 3-2 can be best understood by reference to Figs. 3-8 to 3-10A. Though these three figures have been drawn with reference to the condition of the zero flag, it should be clear that they apply, with the appropriate changes, to the remaining three condition flags as well. The basic issue with all of these conditions is: Should the jump, call, or return instruction be ignored (with program control continuing to the next sequential instruction) or not (with program control transferring to some other memory location)? ## REGISTER PAIR DECODING The six general-purpose registers are all eight bits in length. Since sixteen bits are required to address any location within the $65,\!536$ pos- Table 3-2. Summary of the 24 Different Conditional Instructions in the 8080 Microprocessor Instruction Set | | | | Jump | | | | Call | | Retu | ırn | |-------------------------------------------------------------------------------|-----|-----|---------------|-----------|-----|-----|-----------|-----------|------|-----| | Jump, call, or return if<br>the result of an instruc-<br>tion is not zero | | | | | | | | | | | | Jump, call, or return if<br>the result of an instruc-<br>tion is zero | | | | | | | | | | 310 | | Jump, call, or return if<br>the result of an instruc-<br>tion has no carry | | | | | | | | | | | | Jump, call, or return if<br>the result of an instruc-<br>tion has a carry | | | | | | | | | | | | Jump, call, or return if<br>the result of an instruc-<br>tion has odd parity | | | | | | | | | | | | Jump, call, or return if<br>the result of an instruc-<br>tion has even parity | JPE | 352 | < <b>B2</b> > | <b3></b3> | CPE | 354 | <b2></b2> | <b3></b3> | RPE | 35 | | Jump, call, or return if<br>the result of an instruc-<br>tion is positive | JР | 362 | <b2></b2> | <b3></b3> | СР | 364 | <b2></b2> | <b3></b3> | RP | 360 | | Jump, call, or return if<br>the result of an instruc-<br>tion is negative | JM | 372 | <b2></b2> | <b3></b3> | CM | 374 | <b2></b2> | <b3></b3> | RM | 37 | sible locations in memory, it is convenient to have operations that employ pairs of registers rather than single registers. In this way, 16-bit words can be handled and memory locations can be addressed, if necessary, directly. Both the *stack pointer* and the *program counter* are 16-bit registers, so instructions that allow one to set the sixteen bits in these registers would be useful. Intel Corporation has established four register pairs which correspond to the following 2-bit binary codes: | _ | | | |--------------------|-------------|------------| | Register Pair Name | Registers | 2-Bit Code | | B | B and C | 00 | | Ď | D and E | 01 | | H | H and L | 10 | | PSW | A and flags | 11 | Since register pairs are used to designate 16-bit memory addresses, it is important to identify a HI memory address byte and a LO memory address byte. In the above pairs, registers B, D, H, and flags are the HI bytes, i.e., the eight most significant bits in the 16-bit register pair word, and registers C, E, L, and flags are the LO bytes, i.e., the eight least significant bits in the 16-bit register pair word. Some of the register pair instructions, such as *push* and *pop*, require a considerable amount of explanation. Since we will discuss them in a later chapter, at a time when we will have a "need to know," we won't go into any detail here. In the space below, we will briefly summarize the register pair operations and provide the byte representation for each register pair instruction. The letters rp in the byte representations refer to the 2-bit register pair code just given above. PUSH: Push data onto stack, a single-byte instruction. The contents of the specified register pair are saved in two bytes of memory indicated by the stack pointer. (We shall discuss the stack pointer later.) POP: Pop data off stack, a single-byte instruction. The contents of the specified register pair are restored from two bytes of memory indicated by the stack pointer. (This instruction requires more explanation, which will be given later.) DAD: Double add, a single-byte instruction. The 16-bit number in the specified register pair is added to the 16-bit number held in the H and L registers using two's complement arithmetic. The result replaces the contents of the H and L registers. This is a useful instruction for memory indexing. INX: Increment register pair, a single-byte instruction. The 16-bit number held in the specified register pair is incremented by one. DCX: Decrement register pair, a single-byte instruction. The 16-bit number held in the specified register pair is decremented by one. XCHG: Exchange registers, a single-byte instruction. The 16 bits of data held in the H and L registers are exchanged with the 16 bits of data held in the D and E registers. XTHL: Exchange stack, a single-byte instruction. The 16 bits of data held in the H and L registers are exchanged with the 16 bits of data in the top two stack bytes. SPHL: Load stack pointer from H and L, a single-byte instruction. The 16 bits of data held in the H and L registers replace the contents of the stack pointer. The contents of the H and L registers are unchanged. LXI: Load register pair immediate, a three-byte instruction. The third byte of the instruction (the most significant 8 bits of the 16-bit immediate data) is loaded into the first register of the specified pair, while the second byte of the instruction (the least significant 8 bits of the 16-bit immediate data) is loaded into the second register of the specified pair. If the stack pointer is specified as the register pair, the second byte of the instruction replaces the least significant eight bits of the stack pointer, while the third byte of the instruction replaces the most significant eight bits of the stack pointer. Fig. 3-11 summarizes several different register pair operations. The LXI rp command replaces the contents of one of the four register pairs by the second and third bytes in the LXI instruction. LXI SP is particularly important for locating the stack pointer immediately after you apply power to the microcomputer system. XCHG, a single-byte instruction, exchanges the contents of the D register pair with the con- Fig. 3-11. Summary of the more important register pair operations. Both the program counter and stack pointer are 16-bit registers. tents of the H register pair. PCHL replaces the 16-bit program counter word by the H register pair. In view of the definition for the program program counter-The 16-bit register in the 8080 microprocessor that contains the address of the next instruction or instruction byte that must be executed in a computer program. Finally, SPHL replaces the 16-bit stack pointer value by the value of the H register pair. It is another way of relocating the stack pointer. The pop and push instructions are defined below and summarized in Fig. 3-12. pop-Transferring one or more bytes from a stack to some other register or group of registers. Retrieving data from a stack. push-Replacing the contents of one or more memory locations in a stack with the contents of a register or group of registers. Putting data into a stack. stack-The area of memory set aside by the programmer in which data or addresses are stored and retrieved. stack pointer—The 16-bit memory address of the top of the stack. top of stack-The memory address of the last data byte placed on a stack The most common information that resides in a stack is the memory address that the program will return to after execution of a subroutine. Other information, as shown in Fig. 3-12, includes the contents of the six general-purpose registers, the accumulator, and the flags. In Fig. 3-12B, the storage location M(SP) means the contents of that memory location whose I6-bit address is contained in the stack pointer register. The meanings of M(SP-2), M(SP-1), and M(SP+1) should be clear. There exist four different push instructions and four different Fig. 3-12. Diagrams illustrating the PUSH and POP operations, each of which involves a register pair and two memory locations. pop instructions, each of which operates with a register pair and two memory locations within the stack. For example, in the PUSH B instruction, the contents of the B register replace the contents of memory location M(SP-1) and the contents of the C register replace the contents of memory location M(SP-2); after doing this, the stack pointer is decremented by two to allow subsequent push instructions to put additional data bytes on the stack. The POP B instruction reverses this process. The contents of M(SP+1) replaces the contents of the B register and the contents of M(SP) replaces the contents of the C register; after doing this, the stack pointer is incremented by two to make available two additional bytes at the top of the stack that can be popped into a register pair. The push and pop operations will be discussed further in Chapter 8. #### INCREMENT AND DECREMENT OPERATION DECODING The terms increment and decrement can be defined as follows: increment—To increase the value of a binary word. Typically, to increase the value by one. decrement—To decrease the value of a binary word. Typically, to decrease the value by one. The coding patterns for increment and decrement instructions are shown below. The three-octal-digit increment instruction, in which the first octal digit is 0 and the last octal digit is 4, can be represented as follows: The three-octal-digit decrement instruction, in which the first octal digit is 0 and the last octal digit is 5, can be represented as follows: The increment and decrement instructions can be stated as follows: increment: "Increment [register] by 1." decrement: "Decrement [register] by 1." The mnemonics are INR [register] and DCR [register]. We have already discussed or accounted for 218 of the 256 microprocessor instructions. It is a tedious business, and the danger is that we are considering too many different instructions without testing some of them. Our main interest has been to demonstrate how the 8080 microprocessor instructions are decoded by the instruction decoder. It should be apparent that there is a consistent set of coding rules behind the entire 8080 instruction set. Registers, register pairs, arithmetic operations, logical operations, conditional instructions, and the like all have specific coding patterns within the 8080 instruction set. # DATA AND MEMORY ADDRESSING MODES Since the entire computer program and data are located in memory, it should be clear that the addressing of individual memory locations for the purpose of, for example, acquiring data bytes, is an important part of any computer program. Such addressing can be performed in a number of ways, such as: direct addressing—An 8-bit data byte is acquired via a three-byte instruction that contains the 16-bit memory address at which the data byte is located. Byte B2 contains the LO memory address and byte B3 contains the HI memory address. B3 contains the HI memory address. indirect addressing—An 8-bit data byte is acquired via a one-byte instruction that employs a register pair, usually H and L, to generate the 16-bit memory address. The HI memory address is stored in H and the LO memory address is stored in L. We often denote by the letter M the memory location addressed by registers H and L. immediate addressing—An 8-bit data byte is acquired via a two-byte instruction that contains the data byte as byte B2. stack pointer addressing—Two 8-bit data bytes are acquired via a onebyte instruction that transfers the data from a memory area called a stack to a register pair (or, if desired, to the program counter register). A stack pointer register provides the location of the stack, and is automatically incremented by two after each POP operation. The data in the stack has originally been entered by a PUSH operation. In microprocessor instructions included in the "data transfer group," the memory location M refers to that location addressed by the contents of register pair H and L. ## ACCUMULATOR INSTRUCTIONS The different types of accumulator instructions described in this chapter can be classified as follows: - Load an 8-bit data byte into the accumulator, either from memory, another register, or the second byte of an immediate instruction. - Move an 8-bit data byte from the accumulator into either a memory location or another register. - Load an 8-bit data byte into the accumulator from an input device. - Move an 8-bit data byte from the accumulator into an output device. - Rotate the contents of the accumulator. - Complement the accumulator. - Increment or decrement the contents of the accumulator. - Push the contents of the accumulator on the stack, or pop the stack and replace the contents of the accumulator. - Add, subtract, compare, AND, OR, or exclusive-OR the contents of a register, an immediate byte, or memory location with the contents of the accumulator and store the result in the accumulator. - Clear the accumulator. In the following subsections, we shall discuss several instructions that merit additional comment. $\,$ # Rotate Contents of Accumulator Fig. 3-13. Representations of the four different rotate instructions in the 8080 instruction set. 154 - 007 RLC Rotate contents of accumulator left one position. The least significant bit and the carry flag are both set to the value shifted out of the most significant bit position in the 8-bit accumulator byte. - 017 RRC Rotate contents of accumulator right one position. The most significant bit and the carry flag are both set to the value shifted out of the least significant bit position in the 8-bit accumulator byte. - 027 RAL Rotate contents of accumulator left one position through the carry flag. The least significant bit is set equal to the carry bit and the carry flag is set to the value shifted out of the most significant bit in the 8-bit accumulator byte. - 037 RAR Rotate contents of accumulator right one position through the carry flag. The most significant bit is set equal to the carry bit and the carry flag is set to the value shifted out of the least significant bit in the 8-bit accumulator byte. The carry bit and the 8-bit accumulator byte can be viewed as a 9-bit binary word, in which the ninth bit becomes logic 1 whenever the sum of two 8-bit binary words produces a carry out of the most significant bit (bit 7). The rotate instructions are useful for the following situations: - During the multiplication of a pair of 8-bit binary data bytes. To multiply a data byte by 2, simply shift the entire data byte to the left one position. - During the division of a pair of 8-bit binary data bytes. To divide a data byte by 2, simply shift the entire data byte to the right one position. - During the testing of external flag bits entered into the accumulator with the aid of an IN microprocessor instruction. Each external flag can be tested in turn by rotating the accumulator through the carry bit and testing the logic state of the carry bit. The schematic representation for the RAR instruction can be explained as follows: The carry bit is moved to bit 7 of the accumulator byte. Simultaneous with this action, bit 7 is moved to bit 6, bit 6 is moved to bit 5, bit 5 is moved to bit 4, bit 4 is moved to bit 3, bit 3 is moved to bit 2, bit 2 is moved to bit 1, bit 1 is moved to bit 0, and bit 0 is moved to the carry bit. The remaining rotate instructions can be explained in a similar manner. The arrows in the representations designate the destinations of each of the bits shown. ### **Decimal Adjust Accumulator Contents** The purpose of the DAA instruction, **047**, is to convert the result from the addition of two bed numbers via straight binary addition into two packed binary-coded-decimal words, each of which contains four bits. This instruction can, on occasion, exhibit rather confusing behavior. To quote directly from the *Intel 8080 Assembly Language Programming Manual* (1974): - 047 DAA "The eight-bit hexadecimal number in the accumulator is adjusted to form two four-bit binary-coded-decimal (bcd') digits by the following two-step process: - (1) If the least significant four bits of the accumulator represents a number greater than 9, or if the Auxiliary Carry bit is at logic 1, the accumulator is incremented by six. Otherwise, no incrementing occurs. - (2) If the most significant four bits of the accumulator now represent a number greater than 9, or if the normal bit is at logic 1, the most significant four bits of the accumulator are incremented by six. Otherwise, no incrementing occurs. If a carry out of the least significant four bits occurs during Step (1), the Auxiliary Carry bit is set to logic 1; otherwise it is reset to logic 0. Likewise, if a carry out of the most significant four bits occurs during Step (2), the normal Carry bit is set to logic 1; otherwise, it is unaffected. NOTE: This instruction is used when adding decimal numbers. It is the only instruction whose operation is affected by the Auxiliary Carry bit. Condition bits affected: Zero, Sign, Parity, Carry, Auxiliary Carry." When you use this very unusual instruction, we would encourage you to heed the following rule: Use the decimal adjust accumulator (DAA) instruction only after an ADD, ADC, or ADI instruction. Why? Because only after an ADD, ADC, or ADI can you be certain that the logic states of the auxiliary carry and carry bits are correct. One gimmick that you can employ is to add zero to an 8-bit byte that you wish to decimal adjust. This can be done with three consecutive instruction bytes: 306 ADI Add following byte to contents of accumulator **000** 000 Zero 047 Oecimal adjust contents of accumulator These three instruction bytes will allow you to decimal adjust the contents of the accumulator after the following instructions: IN <B2> and INR A. The authors have tried DCR A and SUI <B2>, but did not observe anything useful. The moral here is that you should be very careful with the DAA instruction. You might try various programs that incorporate it and demonstrate to yourself how tricky it is. ### Clear Accumulator There are two instructions that will allow you to clear the accumulator, i.e., set the contents of the accumulator register to $00000000_2$ : 227 SUB A Subtract the contents of the accumulator from the contents of the accumulator 257 XRA A Exclusive-on the contents of the accumulator with the contents of the accumulator Both instructions take only 2 $\mu s$ execution time. # 8080 INSTRUCTION GROUPS To conclude our discussion of instruction decoding, here is a handy 8080 instruction set reference in which the 256 instructions are subdivided into the five groups suggested by Intel Corporation: - 1. Data Transfer Group - 2. Arithmetic Group - 3. Logical Group - 4. Branch Group - 5. Stack, I/O, and Machine Control Group In each group, octal instructions, mnemonics (Intel), and a description of the instruction are provided. #### Data Transfer Group | I dilialei Olook | | |------------------|------------------------------------------------------------------------------------------------------------| | MOV B,B | Move contents of register B to register B | | MOV BC | Move contents of register C to register B | | | Move contents of register D to register B | | | Move contents of register E to register B | | | Move contents of register H to register B | | MOV B.L | Move contents of register L to register B | | MOV B.M | Move contents of memory location M to register B | | | Move contents of accumulator to register B | | | Move contents of register B to register C | | | Move contents of register C to register C | | MOV CD | Move contents of register D to register C | | | MOV B,B<br>MOV B,C<br>MOV B,D<br>MOV B,E<br>MOV B,H<br>MOV B,H<br>MOV B,M<br>MOV B,A<br>MOV C,B<br>MOV C,B | ``` MOV C,E Move contents of register E to register C 113 MOV C,E MOV C,H MOV C,M MOV C,A MOV D,B Move contents of register H to register C Move contents of register L to register C Move contents of memory location M to register C 114 115 116 117 Move contents of accumulator to register C Move contents of register B to register D Move contents of register C to register D Move contents of register D to register D 120 121 122 MOV D,C MOV D,D Move contents of register D to register D Move contents of register E to register D Move contents of register H to register D Move contents of register L to register D Move contents of memory location M to register D Move contents of accumulator to register D MOV D,E MOV D,H MOV D,L MOV D,M 123 124 125 126 127 130 131 MOV D,A MOV E,B MOV E,C Move contents of accumulator to register E Move contents of register B to register E Move contents of register C to register E Move contents of register D to register E Move contents of register E to register E Move contents of register H to register E Move contents of register L to register E 132 133 MOV E,D MOV E,E 134 135 MOV E,H MOV E,L 136 137 140 MOV E,M MOV E,A MOV H,B Move contents of memory location M to register E Move contents of accumulator to register E Move contents of register B to register H Move contents of register C to register H Move contents of register D to register H 141 142 MOV H,C MOV H,D, MOV H,D, MOV H,E MOV H,H MOV H,M MOV H,A MOV L,B MOV L,C 143 144 145 146 147 150 151 Move contents of register E to register H Move contents of register H to register H Move contents of register L to register H Move contents of memory location M to register H Move contents of accumulator to register H Move contents of register B to register L Move contents of register C to register L MOV L,C MOV L,D MOV L,E MOV L,H MOV L,L MOV L,M MOV L,A 152 153 154 155 156 157 Move contents of register D to register L Move contents of register E to register L Move contents of register H to register L Move contents of register L to register L Move contents of memory location M to register L Move contents of accumulator to register L Move contents of register B to memory location M \frac{160}{161} MOV M,B MOV M,C MOV M,D MOV M,E MOV M,H MOV M,L Move contents of register C to memory location M Move contents of register D to memory location M 162 163 164 Move contents of register E to memory location M Move contents of register H to memory location M 165 166 Move contents of register L to memory location M HLT MOV M,A, Move contents of accumulator to memory loca- 167 170 MOV A.B Move contents of register B to accumulator MOV A,B MOV A,C MOV A,D MOV A,E MOV A,H MOV A,L 171 172 Move contents of register C to accumulator Move contents of register D to accumulator 173 174 Move contents of register E to accumulator Move contents of register H to accumulator 175 176 Move contents of register L to accumulator Move contents of memory location M to accu- 177 MOV A,A Move contents of accumulator to accumulator ``` | 006 | MVI B <b2></b2> | Move immediate byte B2 into register B | |-----|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------| | 016 | MVI C <b2></b2> | Move immediate byte B2 into register C | | 026 | MVI D <b2></b2> | Move immediate byte B2 into register D | | 036 | MVI E <b2></b2> | Move immediate byte B2 into register E | | 046 | MVI H <b2></b2> | Move immediate byte B2 into register H | | | MVI L <b2></b2> | Move immediate byte B2 into register L | | 056 | MVI L <b2><br/>MVI M <b2></b2></b2> | Move immediate byte B2 into memory location M | | 066 | | Move immediate byte B2 into accumulator | | 076 | MVI A <b2></b2> | | | 001 | LXI B <b2> <b3></b3></b2> | Load immediate two bytes B2 and B3 into register pair B | | 021 | LXI D <b2> <b3></b3></b2> | Load immediate two bytes B2 and B3 into register pair D | | 041 | LXI H <b2> <b3></b3></b2> | Load immediate two bytes B2 and B3 into regis-<br>ter pair H | | 061 | LXI SP <b2> <b3></b3></b2> | Load immediate two bytes B2 and B3 into register pair SP | | 002 | STAX B | Store accumulator indirect into memory location<br>M addressed by register pair B | | 012 | LDAX B | Load accumulator indirect from memory location<br>M addressed by register pair B | | 022 | STAX D | Store accumulator indirect into memory location<br>M addressed by register pair D | | 032 | LDAX D | Load accumulator indirect from memory location M addressed by register pair D | | 042 | SHLD <b2> <b3></b3></b2> | Store L direct into memory location M addressed<br>by two bytes B2 and B3; store H direct into<br>the succeeding memory location | | 052 | LHLD <b2> <b3></b3></b2> | Load L direct from memory location M addressed<br>by two bytes B2 and B3; load H direct from<br>the succeeding memory location | | 062 | STA <b2> <b3></b3></b2> | Store accumulator direct into memory location M<br>addressed by two bytes B2 and B3 | | 072 | LDA <b2> <b3></b3></b2> | Load accumulator direct from memory location<br>M addressed by two bytes B2 and B3 | | 353 | XCHG | Exchange the contents of registers H and L with<br>the contents of registers D and E, respectively | | 371 | SPHL | Move the contents of registers H and L to stack<br>pointer register | | | | | The above group of data transfer instructions transfer data to and from registers and memory. Condition flags are not affected by any instructions in this group. # Arithmetic Group This group of instructions performs arithmetic operations on data in registers and memory. With certain exceptions, all instructions in this group affect the zero, sign, parity, and carry flags according to the standard rules. The only exceptions are the INR and DCR instructions (carry flag not affected), the INX and DCX instructions (no flags affected), and DAD instruction (only carry flag affected). All subtraction operations are performed via two's complement arithmetic and set the carry flag to logic 1 to indicate a borrow and clear it to indicate no borrow. | 200 | ADD B | Add contents of register B to contents of accumulator | |-----|-------|----------------------------------------------------------------------------------------| | 201 | ADD C | Add contents of register C to contents of accumulator | | 202 | ADD D | Add contents of register D to contents of accumulator | | 203 | ADD E | Add contents of register E to contents of accumulator | | 204 | ADD H | Add contents o fregister H to contents of accumulator | | 205 | ADD L | Add contents of register L to contents of accumulator | | 206 | ADD M | Add contents of memory location M to contents of accu-<br>mulator | | 207 | ADD A | Add contents of accumulator to contents of accumulator | | 210 | ADC B | Add carry bit and contents of register B to contents of accumulator | | 211 | ADC C | Add carry bit and contents of register C to contents of accumulator | | 212 | ADC D | Add carry bit and contents of register D to contents of accumulator | | 213 | ADC E | Add carry bit and contents of register E to contents of accumulator | | 214 | ADC H | Add carry bit and contents of register H to contents of accumulator | | 215 | ADC L | Add carry bit and contents of register L to contents of accumulator | | 216 | ADC M | Add carry bit and contents of memory location M to con-<br>tents of accumulator | | 217 | ADC A | Add carry bit and contents of accumulator to contents of accumulator | | 220 | SUB B | Subtract contents of register B from contents of accumulator | | 221 | SUB C | Subtract contents of register C from contents of accumulator | | 222 | SUB D | Subtract contents of register D from contents of accumulator | | 223 | SUB E | Subtract contents of register E from contents of accumulator | | 224 | SUB H | Subtract contnets of register H from contents of accumulator | | 225 | SUB L | Subtract contents of register L from contents of accumulator | | 226 | SUB M | Subtract contents of memory location M from contents of accumulator | | 227 | SUB A | Subtract contents of accumulator from contents of accumulator, i.e., clear accumulator | | 230 | SBB B | Subtract carry bit and contents of register B from contents of accumulator | | 231 | SBB C | Subtract carry bit and contents of register C from contents of accumulator | | 232 | SBB D | Subtract carry bit and contents of register D from contents of accumulator | | 233 | SBB E | Subtract carry bit and contents of register E from contents of accumulator | | 234 | SBB H | Subtract carry bit and contents of register H from contents of accumulator | | | | | | 235 | SBB L | Subtract carry bit and contents of register L from contents | |-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 236 | SBB M | of accumulator Subtract carry bit and contents of memory location M | | 200 | 022 | from contents of accumulator | | 237 | SBB A | Subtract carry bit and contents of accumulator from con-<br>tents of accumulator | | 004 | INR B | Increment contents of register B by one | | 014 | INR C | Increment contents of register C by one | | 024 | INR D | Increment contents of register D by one | | 034 | INR E | Increment contents of register E by one | | 044 | INR H | Increment contents of register H by one | | 054 | INR L | Increment contents of register L by one | | 064 | INR M | Increment contents of memory location M by one | | 074 | INR A | Increment contents of accumulator by one | | 005 | DCR B | Decrement contents of register B by one | | 015 | DCR C | Decrement contents of register C by one | | 025 | DRC D | Decrement contents of register D by one | | 035 | DCR E | Decrement contents of register E by one | | 045 | DCR H | Decrement contents of register H by one | | 055 | DCR L | Decrement contents of register L by one | | 065 | DCR M | Decrement contents of memory location M by one | | 075 | DCR A | Decrement contents of accumulator by one | | 003 | INX B | Increment contents of register pair B and C by one | | 023 | INX D | Increment contents of register pair D and E by one | | 043 | INX | Increment contents of register pair H and L by one | | 063 | INX SP | Increment contents of stack pointer register by one | | 013 | DCX B | Decrement contents of register pair B and C by one | | 033 | DCX D | Decrement contents of register pair D and E by one | | 053 | DCX H | Degreement contents of register pair H and L by one | | 073 | DCX SP | Degrament contents of stack pointer register by one | | 011 | DAD B | Add contents of register pair B and C to contents of reg- | | 031 | DAD D | ister pair H and L and store in register pair H and L Add contents of register pair D and E to contents of reg- ister pair H and L and store in register pair H and L | | 051 | DAD H | Add contents of register pair H and L to contents of reg- | | 001 | | total pair H and L and store in register pair H and L | | 071 | DAD SP | Add contents of stack pointer register to contents of reg-<br>ister pair H and L and store in register pair H and L | | 047 | DAA | Adjust 8-bit number in the accumulator to form two 4-bit<br>binary coded decimal digits (used after an add instruc-<br>tion that adds two bcd numbers) | | 306 | ADI <b2></b2> | Add immediate byte B2 to contents of accumulator | | 316 | ACI <b2></b2> | Add carry bit and immediate byte B2 to contents of | | 010 | | laton | | 326 | SUI <b2></b2> | Subtract immediate byte B2 from contents of accumulator | | 336 | SBI <b2></b2> | Subtract carry bit and immediate byte B2 from contents of accumulator | | 270 | CMP B | Compare contents of register B with contents of accumulator; the accumulator remains unchanged. The condition flags are set as a result of the subtraction of the contents of register B from the contents of the accumulator | | 271 | CMP C | Compare contents of register C with contents of accumu-<br>lator | |-----|---------------|--------------------------------------------------------------------| | 272 | CMP D | Compare contents of register D with contents of accumulator | | 273 | CMP E | Compare contents of register E with contents of accumulator | | 274 | CMP H | Compare contents of register H with contents of accumulator | | 275 | CMP L | Compare contents of register L with contents of accumulator | | 276 | CMP M | Compare contents of memory location M with contents of accumulator | | 277 | CMP A | Compare contents of accumulator with contents of accumulator | | 376 | CPI <b2></b2> | Compare immediate byte B2 with contents of accumulator | | | | | ## Logical Group This group of instructions performs logical operations on data in registers and memory and on condition flags. With certain exceptions, all instructions in this group affect the zero, sign, parity, auxiliary carry, and carry flags according to the standard rules. The only exceptions are the RLC, RRC, RAL, RAR, CMC, and STC instructions [only the carry flag is affected] and the CMA instruction [no flags affected]. | • | - | | |-----|-------|--------------------------------------------------------------------------------------------| | 240 | ANA B | AND contents of register B with contents of accumulator | | 241 | ANA C | And contents of register C with contents of accumulator | | 242 | ANA D | And contents of register D with contents of accumulator | | 243 | ANA E | And contents of register E with contents of accumulator | | 244 | ANA H | AND contents of register H with contents of accumulator | | 245 | ANA L | AND contents of register L with contents of accumulator | | 246 | ANA M | And contents of memory location M with contents of accumulator | | 247 | ANA A | And contents of accumulator with contents of accumulator | | 250 | XRA B | Exclusive-on contents of register B with contents of accumulator | | 251 | XRA C | Exclusive-on contents of register C with contents of accumulator | | 252 | XRA D | Exclusive-on contents of register D with contents of accumulator | | 253 | XRA E | Exclusive-on contents of register E with contents of accumulator | | 254 | XRA H | Exclusive-or contents of register H with contents of accumulator | | 255 | XRA L | Exclusive-on contents of register L with contents of accumulator | | 256 | XRA M | Exclusive-on contents of memory location M with contents of accumulator | | 257 | XRA A | Exclusive-on contents of accumulator with contents of accumulator, i.e., clear accumulator | | 260 | ORA B | OR contents of register B with contents of accumulator | | 261 | ORA C | OR contents of register C with contents of accumulator | | 262 | ORA D | OR contents of register D with contents of accumulator | | 263 | ORA E | On contents of register E with contents of accumulator | | 264 | ORA H | On contents of register H with contents of accumulator | | | | | | 205 | ORA L | On contents of register L with contents of accumulator | |-----|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 265 | | On contents of negative 2 with contents of accu- | | 266 | ORA M | | | 267 | ORA A | OR contents of accumulator with contents of accumulator | | 007 | RLC | Rotate contents of accumulator left one position. The least significant bit and the carry flag are both set to the value shifted out of the most significant bit position. | | 017 | RRC | Rotate contents of accumulator right one position. The most significant bit and the carry flag are both set to the value shifted out of the least significant bit position | | 027 | RAL | Rotate contents of accumulator left one position through<br>the carry flag. The least significant bit is set equal to<br>the carry bit and the carry flag is set to the value shifted<br>out of the most significant bit | | 037 | RAR | out of the most significant bit. Rotate contents of accumulator right one position through the carry flag. The most significant bit is set equal to the carry bit and the carry flag is set to the value shifted out of the least significant bit | | 057 | CMA | Complement the accumulator | | 067 | STC | Set the carry flag, i.e., the carry bit, to logic 1 | | 077 | CMC | Complement the carry bit | | 346 | ANI <b2></b2> | And immediate byte B2 with contents of accumulator | | | XRI <b2></b2> | Exclusive-on immediate byte B2 with contents of accumu- | | 356 | AIII \DZ> | lator | | 366 | ORI <b2></b2> | On immediate byte B2 with contents of accumulator | ## Branch Group Branch Group This group of instructions alters the normal sequential program flow. No condition flags are affected by any instruction in this group. The two types of branch instructions are unconditional and conditional. Unconditional transfers simply perform the specified operation on the 16-bit program counter register. Conditional transfers examine the status of one of the four processor flags (zero, sign, parity, and carry) to determine if the specified branch is to be executed. The conditions that may be specified are as follows:7 | carry flag is at logic<br>zero flag is at logic<br>sign flag is at logic<br>parity flag is at log | 1 zero flag is at logic 0 1 sign flag is at logic 0 ic 1 parity flag is at logic 0 | |---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------| | 302 JNZ <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2 and B3 if zero flag is at logic 0 | | 312 JZ <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2 and B3 if zero flag is at logic 1 | | 322 JNC <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2 and B3 if carry flag is at logic 0 | | 332 JC <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2 and B3 if carry flag is at logic 1 | | 342 JPO <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2 and B3 if parity flag is at logic 0 | | 352 | JPE <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2<br>and B3 if parity flag is at logic 1 | |-----|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | 362 | JP <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2<br>and B3 if sign flag is at logic 0 | | 372 | JM <b2> <b3></b3></b2> | Jump to memory location addressed by bytes B2<br>and B3 if sign flag is at logic I | | 304 | CNZ <b2> <b3></b3></b2> | Call subroutine at memory location addressed by<br>bytes B2 and B3 if zero flag is at location 0 | | 314 | CZ <b2> <b3></b3></b2> | Call subroutine at memory location addressed by bytes B2 and B3 if zero flag is at logic 1 | | 324 | CNC <b2> <b3></b3></b2> | Call subroutine at memory location addressed by bytes B2 and B3 if carry flag is at logic 0 | | 334 | CC <b2> <b3></b3></b2> | Call subroutine at memory location addressed by bytes B2 and B3 if carry flag is at logic 1 | | 344 | CPO <b2> <b3></b3></b2> | Call subroutine at memory location addressed by bytes B2 and B3 if parity flag is at logic 0 | | 354 | CPE <b2> <b3></b3></b2> | Call subroutine at memory location addressed by bytes B2 and B3 if parity flag is at logic 1 | | 364 | CP <b2> <b3></b3></b2> | Call subroutine at memory location addressed by bytes B2 and B3 if sign flag is at logic 0 | | 374 | CM <b2> <b3></b3></b2> | Call subroutine at memory location addressed by bytes B2 and B3 if sign flag is at logic 1 | | 300 | RNZ | Return from subroutine if zero flag is at logic 0 | | 310 | RZ | Return from subroutine if zero flag is at logic 1 | | 320 | RNC | Return from subroutine if carry flag is at logic 0 | | 330 | RC | Return from subroutine if carry flag is at logic 1 | | 340 | RPO | Return from subroutine if parity flag is at logic 0 | | 350 | RPE | Return from subroutine if parity flag is at logic 1 | | 360 | RP | Return from subroutine if sign flag is at logic 0 | | 370 | RM | Return from subroutine if sign flag is at logic 1 | | 303 | JMP <b2> <b3></b3></b2> | Unconditional jump to memory location addressed by bytes B2 and B3 | | 311 | RET | Unconditional return from subroutine | | 315 | CALL <b2> <b3></b3></b2> | Unconditional call of subroutine at memory loca-<br>tion addressed by bytes B2 and B3 | | 307 | RST 0 | Call subroutine at HI = 000s and LO = 000s | | 317 | RST 1 | Call subroutine at $HI = 000_8$ and $LO = 010_8$ | | 327 | RST 2 | Call subroutine at $HI = 000_s$ and $LO = 020_s$ | | 337 | RST 3 | Call subroutine at $HI = 000_s$ and $LO = 030_s$ | | 347 | RST 4 | Call subroutine at $HI = 000_8$ and $LO = 040_8$ | | 357 | RST 5 | Call subroutine at $HI = 000_8$ and $LO = 050_8$ | | 367 | RST 6 | Call subroutine at HI = 000s and LO = 060s | | 377 | RST 7 | Call subroutine at HI = $000_8$ and LO = $070_8$ | | 351 | PCHL | Move contents of H and L register pair to program counter register, i.e., jump indirect to memory location M addressed by register pair H and L | # Stack, I/O, and Machine Control Group This group of instructions performs I/O, manipulates the stack, and alters internal control flags. With one exception, no condition flags are | affected by any instructions in | this | group. | The | only | exception | is | the | |---------------------------------|-------|----------|-----|------|-----------|----|-----| | POP PSW instruction, which af | fects | all flag | s. | | | | | | POP P | SW instruction | on, which affects all flags. | |------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 333 | IN <b2></b2> | Replace contents of accumulator by 8-bit data byte from input device selected by the device code given in byte B2 | | 323 | OUT <b2></b2> | Send contents of accumulator as 8-bit data byte to output | | 373 | EI | Enable the interrupt system following the execution of | | 363 | DI | Disable the interrupt system immediately following the execution of this instruction | | 166 | HLT | Halt the microprocessor. The registers and flags are un-<br>affected | | 000<br>343 | NOP<br>XTHL | No operation. The registers and flags are unaffected Exchange the top of the stack with the contents of the H and L register pair. The contents of register L is exchanged with the contents of the memory location SP, whose address is specified by the contents of the stack pointer register. The contents of register H is exchanged with the contents of memory location SP+1 | | 301 | POP B | Pop stack and move contents to register pair B and C. Move contents of memory location SP to register C and contents of memory location SP+1 to register B. Increment contents of stack pointer register by two | | 321 | POP D | Pop stack and move contents to register pair D and E. Move contents of memory location SP to register E and contents of memory location SP+1 to register D. Increment contents of stack pointer register by two | | 341 | POP H | Pop stack and move contents to register pair H and L. Move contents of memory location SP to register L and contents of memory location SP+1 to register H. Increment contents of stack pointer register by two | | 361 | POP PSW | Pop stack and move contents to the accumulator and restore the condition flags. Move contents of memory location SP to restore the condition flags and contents of memory location SP+1 to the accumulator. Increment contents of stack pointer register by two. The HI and LO bytes of the PSW register pair is given by | | | | Accumulator Byte S Z O AC O P 1 C | | | | The letters S, Z, AC, P, and C refer to the sign, zero, auxiliary carry, parity, and carry flags. | | 305 | PUSH B | Push stack by moving contents of register pair B and C to memory locations SP-1 and SP-2, respectively. | | 325 | PUSH D | Push stack by moving contents of register pair D and E to memory locations SP-1 and SP-2, respectively. | | 345 | PUSH H | Push stack by moving contents of register pair H and L to memory locations SP-1 and SP-2, respectively. Decrement contents of stack pointer register by two | PUSH PSW Push stack by moving contents of accumulator and the condition flags to memory locations SP-1 and SP-2, respectively. Decrement contents of stack pointer register by two. The location of the logic states for the five flags are given for the POP PSW instruction above ### 8080 INSTRUCTION SUMMARY ## Single-Byte Instructions | INR r | 0S4 | INX | В | 003 | POP B | 301 | RNZ | 300 | XCHG | 353 | |--------------|-----|-------|----|-----|----------|-----|-----|-----|------|-------| | DCR r | 0S5 | INX . | D | 023 | POP D | 321 | RZ | 310 | XTHL | 343 | | | | INX : | H | 043 | POP H | 341 | RNC | 320 | SPHL | 371 | | $MOV r_1r_2$ | 1DS | INX : | SP | 063 | POP PSW | 361 | RC | 330 | PCHL | 351 | | ADD r | 20S | DCX | В | 013 | PUSH B | 305 | RPO | 340 | HLT | 166 | | ADC r | 21S | DCX | D | 033 | PUSH D | 325 | RPE | 350 | NOP | 000 | | SUB r | 22S | DCX | H | 053 | PUSH H | 345 | RP | 360 | DI | 363 | | SBB 4 | 23S | DCX | SP | 073 | PUSH PSW | 365 | RM | 370 | EI | 373 | | ANA r | 24S | | | | | | RET | 311 | DAA | 017 | | XRA r | 25S | DAD | В | 011 | STAX B | 002 | RLC | 007 | CMA | 057 | | ORA r | 26S | DAD | D | 031 | STAX D | 022 | RRC | 017 | STC | 067 | | CMP r | 27S | DAD | H | 051 | LDAX B | 012 | RAL | 027 | CMC | 077 | | | | DAD | CD | 071 | IDAXD | USO | DAD | 037 | PCT | 2 V 7 | ### Two-Byte Instructions | ADI <b2></b2> | 306 | IN <b2></b2> | 333 | MVI B <b2></b2> | 006 | |---------------|-----|---------------|-----|-----------------|-----| | ACI <b2></b2> | 316 | OUT <b2></b2> | 323 | MVI C <b2></b2> | 016 | | SUI <b2></b2> | 326 | | | MVI D <b2></b2> | 026 | | SBI <b2></b2> | 336 | | | MVI E <b2></b2> | 036 | | ANI <b2></b2> | 346 | | | MVI H <b2></b2> | 046 | | XRI <b2></b2> | 356 | | | MVI L <b2></b2> | 056 | | ORI <b2></b2> | 366 | | | MVI M <b2></b2> | 066 | | CPI < R2> | 376 | | | MVI A < R9> | 076 | ## Three-Byte Instructions | JNZ <b2> <b3></b3></b2> | 302 | CNZ <b2> <b3></b3></b2> | 304 | LXI B <b2> <b3></b3></b2> | 001 | |-------------------------|-----|-------------------------|-----|----------------------------|-----| | JZ <b2> <b3></b3></b2> | 312 | CZ <b2> <b3></b3></b2> | 314 | LXI D <b2> <b3></b3></b2> | 021 | | JNC <b2> <b3></b3></b2> | 322 | CNC <b2> <b3></b3></b2> | 324 | LXI H <b2> <b3></b3></b2> | 041 | | JC <b2> <b3></b3></b2> | 332 | CC <b2> <b3></b3></b2> | 334 | LXI SP <b2> <b3></b3></b2> | 061 | | JPO <b2> <b3></b3></b2> | 342 | CPO <b2> <b3></b3></b2> | 344 | | | | JPE <b2> <b3></b3></b2> | 352 | CPE <b2> <b3></b3></b2> | 354 | STA <b2> <b3></b3></b2> | 062 | | JP <b2> <b3></b3></b2> | 362 | CP <b2> <b3></b3></b2> | 364 | LDA <b2> <b3></b3></b2> | 072 | | JM <b2> <b3></b3></b2> | 372 | CM <b2> <b3></b3></b2> | 374 | SHLD <b2> <b3></b3></b2> | 042 | | IMP <b2> <b3></b3></b2> | 303 | CALL < B2> < B3> | 315 | LHLD < R2> < R3> | 052 | ## ASSEMBLY LANGUAGE Once you begin to program in binary, octal, or hexadecimal machine language, you will quickly learn that it can be rather difficult. The problem is that many machine language instructions refer to specific locations in memory. If you desire to make changes in the program, you may need to change memory locations in order to accommodate new instructions inserted at specified points in the original program. One way around this problem is to write your programs in assembly language. The term assembly refers to the process whereby instructions written in symbolic form by the programmer are changed to machine language by a computer. Related terms include the following: assemble-To translate from a symbolic program to a binary program by substituting binary operation codes for symbolic operation codes and replacing symbolic addresses with absolute or relocatable addresses.4 assembler-A program that prepares a program in machine language from a program in symbolic language by substituting absolute operation codes for symbolic operation codes and absolute or relocatable addresses for symbolic addresses.4 assembly language-A computer language that has one-to-one correspondence with an assembly program. The assembly program directs a computer to operate on a program in symbolic language to produce a program in machine language.4 assembly language programming, symbolic language programming-The writing of program instructions in a language that facilitates the translation of programs into binary code through the use of mnemonic instructions such as ADD, MPY, SUB, DIV, STO, etc.4 assembly program-A program that enables a computer to assemble mnemonic language into machine language. Also called assembly routine.4 symbolic address-Also called floating address. In digital computer programming, a label chosen in a routine to identify a particular word, function, or other information independent of the location of the in- formation within the routine. symbolic code-A code by which programs are expressed in source language; that is, storage locations and machine operations are referred to by symbolic names and addresses that do not depend upon their hardware-determined names and addresses. Also called pseudocode.4 symbolic coding-In digital computer programming, any coding sys- tem using symbolic rather than actual computer addresses.4 symbolic programming-A program using symbols instead of numbers for the operations and locations in a computer. Although the writing of the program is easier and faster, an assembly program must be used to decode the symbol into machine language and to assign instruction locations.4 It is important to understand the difference between machine and assembly languages. In machine language programming: - Each instruction in the program is a specific binary number or group of binary numbers. - Storage locations for data and information are given specific binary addresses in memory. - Subroutines are located at specific binary addresses in memory. - Each instruction in the program is located at a specific binary address in memory. - Once written, the program is ready to run. - As alternatives to binary memory addressing, octal or hexadecimal memory addressing can be employed. - Changes in the program are made with difficulty. Changes in the binary addresses of instructions, data, or subroutines may be required. In assembly language programming: - Each instruction in the program is a single mnemonic code or group of mnemonic codes. - Storage locations for data and information are also given symbolic (or mnemonic) names. - Subroutines are located at addresses given by mnemonic names called *labels*. - Each instruction in the program is located at an address characterized by a label. - Once written, the program isn't ready to run. It must be passed through an assembler to convert the symbolic (or mnemonic) code into machine larguage. - into machine language. Binary, octal, or hexadecimal memory addressing are not usually employed, although they can be where convenient. - Changes in the program are made with relative ease. Since none of the memory addresses for instructions, data, or subroutines have been set, new steps can be inserted anywhere in the assembly language program without causing any difficulty. The differences between machine and assembly language instructions will be explored in the next section. ## MACHINE LANGUAGE VS. ASSEMBLY LANGUAGE PROGRAMS We will now write a simple computer program in both 8080 machine and 8080 assembly language and compare the two programs. The program is typical of that which we will use in subsequent chapters: - Subtract the contents of the accumulator from the contents of the accumulator, i.e., clear the accumulator. - Send a device select pulse and the contents of the accumulator to a device called "PRINTER," which has a device code of 000<sub>8</sub>. $\bullet$ Jump unconditionally to the first instruction in the program, which is at a memory location called "START," which is at the memory location HI = $000_8$ and LO = $000_8$ . Octal coding is used in the machine language program, which is as follows: | LO Memory<br>Address | Octal<br>Instruction | Comments | |----------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------| | $000_{\rm s}$ | 227 | Subtract the contents of the accumulator from the contents of the accumulator, i.e., clear the accu- | | 001s | 323 | mulator Send a device select pulse and the contents of the accumulator to the device given in the second byte of the instruction | | 0028 | 000 | Device code | | 003 <sub>8</sub> | 303 | Jump unconditionally to memory location given by following two bytes | | 0048 | 000 | LO memory address byte | | 0058 | 000 | HI memory address byte | And the assembly language program is: \*000 000 START, SUB A OUT PRINTER JMP START START PRINTER, 000 where the labels are: $START = memory \ address \ at \ which \ the \ program \ starts,$ PRINTER = name of output device. The terms label and operand are defined as follows: label-One or more characters that serve to define a byte of data, the location of an instruction or subroutine, or an input or output device. operand-The quantity that is affected, manipulated, produced, or operated upon. To emphasize a point made previously, in assembly language programming, we desire to be able to address data locations, data bytes, devices, instructions, and subroutines by symbolic names instead of by 8-bit or 16-bit octal codes. Note that in the assembly language program, no octal codes are present. All instructions are written in terms of their mnemonics and the output device is given a name, PRINTER. The starting location of the program is called START rather than $HI = 000_8$ and $LO = 000_8$ . The use of assembly language programming is considerably easier than machine language programming, but the latter has one important advantage: it is ready to be executed on the microcomputer, whereas the assembly language program is not. With an assembly language program, one must sort through a table and assign address values to labels and operation code values to operands. One can "hand assemble" a program by assigning address values and by looking up octal equivalents for the mnemonics. Computers are also extremely well suited to this task using "assembler" or "cross assembler" programs. ### INTRODUCTION TO THE EXAMPLES Since programming is one of the important new skills that you must master if you wish to effectively use microcomputers, here we provide a variety of programming examples that test some of the characteristics of the 8080 instruction set. Some of the more unusual instructions are emphasized, such as PUSH, POP, and DAA, along with several output programs that you can use in conjunction with an 8-bit latch/display circuit, which you will learn how to construct in Chapter 7. ### EXAMPLE NO. 1 #### Purpose The purpose of this example is to demonstrate how to clear the micro-computer memory. #### Program | LO Memor | , Octal | | | |----------|-------------|----------|--------------------------------------------------------------------------------------------------| | Address | Instruction | Mnemonic | Comments | | 000 | 227 | SUB A | Clear the accumulator | | 001 | 041 | LXI H | Load the following two data bytes<br>into registers L and H, respec-<br>tively | | 002 | 011 | | L data byte | | 003 | 000 | | H data byte | | 004 | 167 | MOV M,A | Move contents of accumulator to<br>the memory location addressed<br>by the register pair H and L | | 005 | 043 | INX H | Increment the register pair H and L<br>by one | | 006 | 303 | ЈМР | Unconditional jump to the memory<br>location given in the following<br>two bytes | | 007 | 004 | | LO memory address byte | | 010 | 000 | | HI memory address byte | #### Comment This program permits you to clear read/write memory, essentially all $65,\!536$ locations if you so desire, starting at $\rm HI=000$ and $\rm LO=011.$ As soon as it clears location HI = 377 and LO = 377, it starts to clear the program itself. It gets as far as memory location HI = 000 and LO = 004. Finally, it loops indefinitely between locations LO = 004 and LO = 010. The NOP instruction is 000. Thus, a cleared read/write memory location, if treated as an instruction byte, will not perform any useful microcomputer operation. By clearing the read/write memory beforehand, you can prevent undesired program execution when you are testing a new program. [One problem is that you usually do not have 65K of microcomputer memory. A nonexistent memory location provides the 8080 microprocessor chip with a 377; when this is treated as an instruction byte, the 8080 calls a subroutine at locations HI = 000 and LO = 070. To minimize such a problem, you may wish to load instruction byte 166 (HLT) at HI = 000 and LO = 070.] It should be noted, however, that it is not necessary to clear the memory before it is used by the microcomputer. ### EXAMPLE NO. 2 #### Purpose The purpose of this example is to attempt to read the contents of the B and C registers, which are set to the values 010<sub>8</sub> and 001<sub>8</sub>, respectively ## Program | LO Memor | y Octal | | | |----------|-------------|----------|--------------------------------------------------------------------------------| | Address | Instruction | Mnemonic | Comments | | 000 | 041 | LXI H | Load the following two data bytes<br>into registers L and H, respec-<br>tively | | 001 | 200 | | L data byte | | 002 | 000 | | H data byte | | 003 | 001 | LXI B | Load the following two data bytes<br>into registers C and B, respec-<br>tively | | 004 | 001 | | C data byte | | 005 | 010 | | B data byte | | 006 | 166 | HLT | Halt | #### Comments You should be able to successfully execute this program, but you will not know whether anything happened since all data remains within the 8080 chip. See the following example (Example No. 3) for one of the possible solutions to the problem of monitoring the contents of the internal registers. ### EXAMPLE NO. 3 #### **Purpose** The purpose of this example is to write into memory the contents of the B and C registers, which are set to the values 010<sub>8</sub> and 001<sub>8</sub>, respectively. #### Program | LO Memor | y Octal | | | |----------|-------------|----------|---------------------------------------------------------------------------------------------| | Address | Instruction | Mnemonic | Comments | | 000 | 041 | LXI H | Load the following two data bytes<br>into registers L and H, respec-<br>tively | | 001 | 200 | | L data byte | | 002 | 000 | | H data byte | | 003 | 001 | LXI B | Load the following two data bytes<br>into registers C and B, respec-<br>tively | | 004 | 001 | | C data byte | | 005 | 010 | | B data byte | | 006 | 160 | MOV M,B | Move contents of register B to<br>memory location addressed by the<br>register pair H and L | | 007 | 043 | INX H | Increment the register pair H and L<br>by one | | 010 | 161 | MOV M,C | Move contents of register C to<br>memory location addressed by the<br>register pair H and L | | 011 | 166 | HLT | Halt | #### Comments With Example No. 2, you learned that it is impossible to observe directly the contents of registers, B, C, D, E, H, and L. You can observe the contents of the accumulator more or less directly with the aid of an OUT instruction and a pair of latches (you will do this in Chapter 7). However, you must resort to some gimmicks in order to determine the contents of the six general-purpose registers. Such gimmicks include the following: - Storing the contents of the registers in memory, then examining the contents of memory while the microcomputer is in the HOLD - Pushing the contents of the registers onto the stack, then examining the contents of the memory locations in the stack while the microcomputer is in the HOLD state. - Moving the contents of each register to the accumulator, then providing an OUT instruction and latching the contents of the accumulator. You can do this with each register in turn, and can actu- ally follow the register contents while the microcomputer is still running It would be nice to have a group of seven LED registers, each register containing eight bits, that would continuously display the contents of the six general-purpose registers and the accumulator. With the 8080 microprocessor, it is not possible to do so as direct outputs from the chin #### **EXAMPLE NO. 4** #### Purpose The purpose of this example is to load into the stack region of memory the contents of the B and C registers, which are set to the values $010_8$ and $011_8$ , respectively. #### Program | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|----------------------------------------------------------------------------------------------------------------------------| | 000 | 061 | LXI SP | Load the following two data bytes into the stack pointer register | | 001 | 202 | | LO stack pointer byte | | 002 | 000 | | HI stack pointer byte | | 003 | 001 | LXI B | Load the following two data bytes<br>into registers C and B, respec-<br>tively | | 004 | 001 | | C data byte | | 005 | 010 | | B data byte | | 006 | 305 | PUSH B | Replace the contents of memory lo-<br>cations M(SP-1) and M(SP-2)<br>by the contents of registers B and<br>C, respectively | | 007 | 166 | HLT | Halt | #### Comments This program loads the contents of register B into memory location ${\rm HI}=000$ and ${\rm LO}=201$ , and the contents of register C into memory location ${\rm HI}=000$ and ${\rm LO}=200$ . The stack pointer is decremented by one before each register's contents is pushed on the stack. Once the program has come to a halt, you can address the stack locations and demonstrate that the register contents have been stored there. ## EXAMPLE NO. 5 #### Purpose The purpose of this example is to pop prestored data from the stack region in memory, increment and decrement the contents of the popped data, and then push it back on the stack. Register pair B is employed. | Program | | |---------|--| |---------|--| | LO Memor | y Octal | | | |----------|-------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Address | Instruction | Mnemonic | Comments | | 000 | 061 | LXI SP | Load the following two data bytes into the stack pointer register | | 001 | 200 | | LO stack pointer byte | | 002 | 000 | | HI stack pointer byte | | 003 | 227 | SUB A | Clear the accumulator | | 004 | 301 | POP B | Replace the contents of registers B<br>and C by the contents of stack<br>locations M(SP+1) and M(SP),<br>respectively | | 005 | 004 | INR B | Increment contents of register B by one | | 006 | 015 | DCR C | Decrement contents of register C<br>by one | | 007 | 305 | PUSH B | Replace the contents of memory lo-<br>cations M(SP-1) and M(SP-2)<br>by the contents of registers B and<br>C, respectively (Note: keep in<br>mind that the stack pointer has<br>been incremented by two as a<br>result of the POP B instruction at<br>address 004s) | | 010 | 166 | HLT | Halt | #### Data | LO Memory | Memor | |-----------|-------| | Address | Data | | 200 | 222 | | 201 | 333 | #### Comments When you execute this program, you will observe octal byte 221 in memory location HI = 000 and LO = 200, and octal byte 334 in memory location HI = 000 and LO = 201. The initial contents of register B are stored at LO = 201; the initial contents of register C are stored at LO = 200. Register B is incremented, and register C is decremented. The stack pointer will first increment by two, and then decrement by two. At the end of the program, the stack pointer will be at HI = 000 and LO = 200. ## EXAMPLE NO. 6 ## Purpose The purpose of this example is to monitor the state of the five flags, after a simple arithmetic operation, with the aid of the PUSH PSW instruction. #### Program | LO Memor | y Octal<br>Instruction | Mnemonic | Comments | |----------|------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 000 | 061 | LXI SP | Load the following two data bytes into the stack pointer register | | 001 | 202 | | LO stack pointer byte | | 002 | 000 | | HI stack pointer byte | | 003 | 227 | SUB A | Subtract the contents of the accu-<br>mulator from the contents of the<br>accumulator, i.e., clear the accu-<br>mulator | | 004 | 365 | PUSH PSW | Replace the contents of memory lo-<br>cations M(SP-1) and M(SP-2)<br>by the contents of the accumu-<br>lator and the state of the five con-<br>dition flags, respectively | | 005 | 166 | HLT | Halt | | 000 | 200 | | | This is a useful program that permits you to test how arithmetic and logical instructions influence the five flags: sign, zero, auxiliary carry, parity, and carry. After you perform an arithmetic operation at LO = 003, you push the contents of the flags and the accumulator onto the stack. After the microcomputer has halted, you can go directly to the stack region and determine the flag status. The 16-bit program status word appears as follows in the stack: The accumulator byte is the HI register byte and is stored at LO=201. The flag byte is stored at LO=200. The letters S, Z, AC, P, and C in the above illustration refer to the sign, zero, auxiliary carry, parity, and When you execute this program and examine memory location LO = 200, you will observe the 8-bit byte 01010110, which signifies the $\begin{array}{c} Z=0 \ \ Result \ is \ positive \\ S=1 \ \ Result \ is \ zero \\ AC=1 \ \ (meaningless) \\ P=1 \ \ Result \ has \ even \ parity \\ C=0 \ \ Result \ has \ no \ carry \end{array}$ If you modify the instruction bytes at LO = 004 through LO = 006 as shown below and then execute the program, you will observe the 8-bit byte 00000010 at LO = 200. | LO Memori | y Octal | | | |-----------|-------------|----------|------------------------------------------------------------------------| | Address | Instruction | Mnemonic | Comments | | 004 | 074 | INR A | Increment the contents of the accu-<br>mulator by one | | 005 | 365 | PUSH PSW | Push the contents of the accumula-<br>tor and the flags onto the stack | | 006 | 166 | HLT | Halt | The accumulator byte at LO = 201 will be 001. These results signify the following: $S=0\;$ Result is positive $Z=0\;$ Result is not zero $AC=0\;$ Result has no carry from bit D3 to bit D4 in the accumula- tor P = 0 Result has odd parity C = 0 Result has no carry This type of program shows you the state of individual flags before you attempt to use conditional branch instructions. All logical and most arithmetic operations alter the flags. Once you know how a flag will behave, you can employ the appropriate arithmetic/logical instructions and conditional branch instructions in your main program. ## EXAMPLE NO. 7 ## Purpose The purpose of this example is to explore the conditional jump instructions and to determine when a jump occurs. (See Fig. 3-14.) ### Program | LO Memor | y Octal<br>Instruction | Mnemonic | Comments | |----------|------------------------|----------|------------------------------------------------------------------------------------------------------------| | 000 | 061 | LXI SP | Load the following two data bytes | | 000 | 001 | LAI SF | into the stack pointer register | | 001 | 200 | | LO stack pointer byte | | 002 | 000 | | HI stack pointer byte | | 003 | 361 | POP PSW | Pop the contents of the accumulator | | - | | | and the flags from the stack | | 004 | * | * | Operation code for any of the eight<br>conditional instructions (JNZ, JZ,<br>JNC, JC, JPO, JPE, JP, or JM) | | 005 | 004 | | LO memory address byte | | 006 | 000 | | HI memory address byte | | | | *** *** | | | 007 | 166 | HLT | Halt | | 200 | * | * | Flag data byte that will be popped off stack | | 201 | 000 | | Accumulator data byte that will be<br>popped off stack | Fig. 3-14. Conditional instructions JZ and JNZ. Prior to executing this program, you first load memory with a program status word, the flag byte appearing at HI = 000 and LO = 200, and the accumulator data byte at HI = 000 and LO = 201. You also load a desired conditional jump instruction at memory address HI = 000 and LO = 004. Having done so, execution of the program permits you to test how different flag bits influence the execution of any of the eight conditional jump instructions. To demonstrate the program, you may wish to compare the JNZ and JZ conditional jump instructions, which are represented schematically With a flag byte of 002 at LO = 200 and the JNZ instruction byte, 302, at LO = 004, you should observe that the executed program loops between LO = 004 and LO = 006. The sign flag, S, is at logic 0, which indicates to the 8080 chip that the "not zero" condition exists; a jump to HI = 000 and LO = 004 therefore occurs. If you change the flag byte from 002 to 102, no jump will occur and the program will come With a flag byte of 002 and the JZ instruction byte, you should observe that the program comes to a halt. When you change the flag to 102, the program loops between LO = 004 and LO = 006. This behav- ioz, the program loops between LO = 004 and LO = 000. This behavior is predictable from the nature of the JZ instruction, in which a jump occurs only if the zero flag, Z, is at logic 1. We can summarize the program behavior for different popped flag bytes and different conditional jump instructions as shown in the following list. | | | | Conditional | | |--------------|-------------|----------------|-------------|----------| | Flag Byte at | Flag Bit of | Logic State of | Jump | Program. | | LO = 200 | Interest | Flag Bit | Instruction | Behavior | | 002 | Z | 0 | JNZ | loops | | 102 | Z | 1 | JNZ | halts | | 002 | Z | 0 | JZ | halts | | 102 | Z | 1 | JΖ | loops | | 002 | C | 0 | JNC | loops | | 003 | C | 1 | JNC | halts | | 002 | С | 0 | JC | halts | | 003 | С | 1 | JC | loops | | 002 | P | 0 | JPO | loops | | 006 | P | 1 | JPO | halts | | 002 | P | 0 | JPE | halts | | 006 | P | 1 | JPE | loops | | 002 | S | 0 | JP | loops | | 202 | S | 1 | JP | halts | | 002 | S | 0 | JM | halts | | 202 | S | 1 | JM | loops | In each case in the above listing, we have tested one of the flag bits for the indicated conditional jump instruction. ### **EXAMPLE NO. 8** # Purpose The purpose of this example is to demonstrate the execution of a program that contains a *nest* of subroutines. ## Program No. 1 To change the stack pointer location to $\rm HI=003$ and $\rm LO=003$ , use the following program: | LO Memor | y Octal | | | |----------|-------------|----------|-----------------------------------------------------------------| | Address | Instruction | Mnemonic | Comments | | 000 | 061 | LXP SP | Load stack pointer with address<br>given by following two bytes | | 001 | 003 | | LO address byte of stack pointer | | 002 | 003 | | HI address byte of stack pointer | | 003 | 166 | HLT | Halt | The flowchart for this program is shown in Fig. 3-15. Fig. 3-15. Flowchart for Program No. 1. # Program No. 2 After executing Program No. 1, load the main program, which starts at HI = 000. | LO Memor | y Octal<br>Instruction | Mnemonic | Comments | |----------|------------------------|----------|---------------------------------| | Adaress | mstruction | | Call subroutine at HI = 000 and | | 000 | 317 | RST 1 | LO = 010 | | 001 | 166 | HLT | Halt | | | 327 | RST 2 | Call subroutine at HI = 000 and | | 010 | 321 | 101 2 | LO = 020 | | 011 | 311 | RET | Return from subroutine | | | | RST 3 | Call subroutine at HI = 000 and | | 020 | 337 | N31 3 | LO = 030 | | 021 | 311 | RET | Return from subroutine | | | 000 | NOP | No operation | | 030 | | | Return from subroutine | | 031 | 311 | RET | vernin mom zabronime | The flowchart for Program No. 2 is shown in Fig. 3-16. #### Comments Since this example demonstrates how the microcomputer handles nested subroutines, the program *execution* is listed below in full detail. | Add<br>By | | Data | | | |-----------|-----|------|----------|------------------------------------------------------------------------| | HI | LO | Bus | Mnemonic | Comments | | 000 | 000 | 317 | RST 1 | Store program counter on stack, then jump to subroutine at LO = 010 | | 003 | 002 | 000 | | Program counter HI address byte | | 003 | 001 | 001 | | Program counter LO address byte | | 000 | 010 | 327 | RST 2 | Store program counter on stack, then jump to subroutine at LO = 020 | | 003 | 000 | 000 | | Program counter HI address byte | | 002 | 377 | 011 | | Program counter LO address byte | | 000 | 020 | 337 | RST 3 | Store program counter on stack, then jump<br>to subroutine at LO = 030 | | 002 | 376 | 000 | | Program counter HI address byte | | 002 | 375 | 021 | | Program counter LO address byte | | 000 | 030 | 000 | NOP | No operation | | 000 | 031 | 311 | RET | Pop program off of stack, i.e., return from Subroutine 3 | Let us pause at this point in the program execution and examine what has happened so far. We have called three subroutines. Three sets of program counter bytes have been stored on the stack and the stack pointer has been shifted down. We have now executed our first RET instruction and are ready to observe the program counter bytes being popped off the stack. | 002 | 375 | 021 | Program counter LO address Program counter HI address | byte<br>byte | |-----|-----|-----|-------------------------------------------------------|--------------| | 002 | 376 | 000 | Program counter in address | 5,00 | Fig. 3-16. Flowchart for Program No. 2. | 000 | 021 | 311 | RET | Pop program counter off of stack, i.e., return from Subroutine 2 | |-----|-----|-----|-----|---------------------------------------------------------------------| | 002 | 377 | 011 | | Program counter LO address byte | | 003 | 000 | 000 | | Program counter HI address byte | | 000 | 011 | 311 | RET | Pop program counter off of stack, i.e., return<br>from Subroutine 1 | | 003 | 001 | 001 | | Program counter LO address byte | | 003 | 002 | 000 | | Program counter HI address byte | | 000 | 001 | 000 | HLT | Halt | The above program should convince you that you can nest any number of subroutines. The only requirement is that you provide sufficient read/write memory for the stack. The microcomputer will handle all of the bookkeeping chores associated with the call and return instructions. You may now wish to refer again to the flowchart for Program No. 2. ## EXAMPLE NO. 9 ### Purpose The purpose of this example is to demonstrate how you can determine the consequences of different accumulator instructions. ## Some 8080 Accumulator Instructions Many of the 8080 instructions involve the accumulator register, which is also known as register A. In this example, you are provided with a simple program that will allow you to test a variety of accumulator instructions, which include some of the following: | Octal | | | |-------------|----------|-----------------------------------------------| | Instruction | Mnemonic | Comments | | 007 | RLC | Rotate contents of accumulator left one posi- | | | | tion | | 017 | RRC | Rotate contents of accumulator right one position | |-------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------| | 027 | RAL | Rotate contents of accumulator left one posi-<br>tion through carry flag | | 037 | RAR | Rotate contents of accumulator right one position through carry flag | | 047 | DAA | Decimal adjust accumulator | | 057 | CMA | Complement the contents of the accumulator | | 072 <b2> <b3></b3></b2> | LDA | Load the accumulator direct with the contents of the memory address given by the <b2> and <b3> address bytes</b3></b2> | | 074 | INR A | Increment the contents of the accumulator by one | | 075 | DCR A | Decrement the contents of the accumulator<br>by one | | 076 <b2></b2> | MVI A | Load the accumulator with the 8-bit byte that immediately follows | | 170 | MOV A,B | Move the contents of register B to the accumulator | | 171 | MOV A,C | Move the contents of register C to the accumulator | | 172 | MOV A,D | Move the contents of register D to the accumulator | | 173 | MOV A,E | Move the contents of register E to the | | 174 | MOV A,H | Move the contents of register H to the accumulator | | 175 | MOV A,L | Move the contents of register L to the accumulator | | 176 | MOV A,M | Move the contents of the memory location,<br>whose address is given by the register<br>pair H and L. to the accumulator | | 177 | MOV A,A | Move the contents of the accumulator to the accumulator | | 200 | ADD B | Add the contents of register B to the contents of the accumulator | | 206 | ADD M | Add the contents of the memory location, whose address is given by the register pair H and L, to the contents of the accumulator | | 207 | ADD A | Add the contents of the accumulator to the contents of the accumulator | | 210 | ADC B | Add carry bit and contents of register B to the contents of the accumulator | | 217 | ADC A | Add carry bit and contents of accumulator to the contents of the accumulator | | 220 | SUB B | Subtract the contents of register B from the contents of the accumulator | | 227 | SUB A | Clear the governulator | | 230 | SBB B | Subtract the carry bit and contents of regis-<br>ter B from the contents of the accumulator | | 240 | ANA B | AND the contents of register B with the con-<br>tents of the accumulator | | 247 | ANA A | And the contents of the accumulator with the contents of the accumulator | | | | | | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 250 | XRA B | Exclusive-on the contents of register B with the contents of the accumulator | | 257 | XRA A | Clear the accumulator | | 260 | ORA B | On the contents of register B with the con-<br>tents of the accumulator | | 267 | ORA A | On the contents of the accumulator with the contents of the accumulator | | 270 | CMP B | Compare the contents of register B with the contents of the accumulator | | 276 | CMP M | Compare the contents of the memory loca-<br>tion, whose address is given by the regis-<br>ter pair H and L, with the contents of the<br>accumulator | | 277 | CMP A | Compare the contents of the accumulator with the contents of the accumulator | | 306 <b2></b2> | ADI | Add the 8-bit byte that immediately follows<br>to the contents of the accumulator | | 316 <b2></b2> | ACI | Add the 8-bit byte that immediately follows<br>and the carry bit to the contents of the<br>accumulator | | 326 <b2></b2> | SUI | Subtract the 8-bit byte that immediately follows from the contents of the accumulator | | 336 <b2></b2> | SBI | Subtract the 8-bit byte that immediately follows and the carry bit from the contents of the accumulator | | 346 <b2></b2> | ANI | AND the 8-bit byte that immediately follows with the contents of the accumulator | | 356 <b><b2></b2></b> | XRI | Exclusive-on the 8-bit byte that immediately follows with the contents of the accumulator | | 361 | POP PSW | Pop the stack and store the contents in the accumulator and the flag flip-flops | | 366 <b2></b2> | ORI | On the 8-bit byte that immediately follows with the contents of the accumulator | | 376 <b2></b2> | CPI | Compare the 8-bit byte that immediately follows with the contents of the accumulator | ### Program | LO Memor | y Octal | | | |----------|-------------|----------|-----------------------------------------------------------------------------------------| | Address | Instruction | Mnemonic | | | 000 | 061 | LXI SP | Load the following two data bytes into the stack pointer register | | 001 | 000 | | LO stack pointer byte | | 002 | 001 | | HI stack pointer byte | | 003 | 227 | SUB A | Clear the accumulator | | 004 | 016 | MVI C | Move following byte into register C | | 005 | 002 | | Timing byte for register C | | 006 | 315 | CALL | Unconditional call of subroutine located at memory address given by following two bytes | 182 | 007 | 100 | | LO memory address byte<br>HI memory address byte | |-----|-----|-------|----------------------------------------------------------------------------------------------------------| | 010 | 000 | | m | | 011 | 007 | RLC | Rotate the contents of the accumu-<br>lator left one position | | 012 | 074 | INR A | Increment the contents of the accu-<br>mulator by one | | 013 | 000 | NOP | No operation | | 014 | 000 | NOP | No operation | | | | | No operation | | 015 | 000 | NOP | No operation | | 016 | 323 | OUT | Generate device select pulse that al-<br>lows an 8-bit latch to latch the<br>contents of the accumulator | | 017 | 000 | 000 | Device code for 8-bit latch | | | | IMP | Unconditional jump to location given | | 020 | 303 | JMI | by following two address bytes | | 021 | 004 | | LO memory address byte | | 022 | 000 | | HI memory address byte | ## Subroutine (Generates a Time Delay) | John Committee a state | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------|-----------------------------------------------------------------------------------------------------------------------------| | LO Memory Octal | | | G | | Address | Instruction | Mnemonic | Comments | | 100 | 021 | LXI D | Move following two bytes into reg-<br>isters E and D, respectively | | 101 | 301 | | Timing byte for register E | | 102 | 150 | | Timing byte for register D | | 103 | 035 | DCR E | Decrement contents of register E by one | | 104 | 302 | JNZ | If register E is 000s, ignore this instruction; otherwise, jump to memory address given in following two bytes | | 105 | 103 | | LO address byte | | 106 | 000 | | HI address byte | | 107 | 025 | DCR D | Decrement contents of register D by<br>one | | 110 | 302 | JNZ | If register D is 000 <sub>8</sub> , ignore this instruction; otherwise, jump to memory address given in following two bytes | | 111 | 103 | | LO address byte | | 112 | 000 | | HI address byte | | 113 | 015 | DCR C | Decrement contents of register C by one | | 114 | 302 | JNZ | If register C is 000 <sub>8</sub> , ignore this instruction; otherwise, jump to memory address given in following two bytes | | 115 | 100 | | LO address byte | | 116 | 000 | | HI address byte | | 117 | 311 | RET | Unconditional return from this sub-<br>routine | #### Comments This program requires an 8-bit output latch and display to permit you to observe the results of the arithmetic and logical operations that you perform on the accumulator contents. Refer to the circuits de- you perform on the accumulator contents. Never to the checked ac scribed in Chapter 7. The subroutine starting at HI = 000 and LO = 100 generates time delays ranging from 0.200 second to 51.2 seconds through variations in the timing byte for register C at LO memory address 005. If you execute the program as it stands, you will observe that the output display quickly fills up with logic 1's, starting from right to left. At memory addresses 011 through 015, you have five program bytes with which you can perform different types of accumulator operations. Thus, which you can perform different types of accumulator operations. Thus, with the program segment: | 011 | 076 | MVI A | Load the following byte into the accumulator | |-----|-----|-------|----------------------------------------------------------------| | 012 | 360 | 360 | Data byte corresponding to the binary word 111100002 | | 013 | 346 | ANI | AND the data that follows with the contents of the accumulator | | 014 | 252 | 252 | Data byte corresponding to the binary word 101010102 | | 015 | 000 | NOP | No operation | you should observe that the AND operation between the byte 11110000 and the byte 10101010 produces the logical result 10100000, an operation that proceeds bit by bit. By changing the logical instruction at LO = 013, you can demonstrate the behavior of the or and exclusive-or instructions on the same initial data. If you execute the following program segment contained within the main program: | 011 | 074 | INR A | Increment the contents of the accu | |-----|-----|-------|------------------------------------| | | | | mulator by one | | 012 | 067 | STC | Set the carry flag to logic one | | 013 | 077 | CMC | Complement the carry flag | | 014 | 047 | DAA | Decimal adjust the accumulator | | 015 | 000 | NOP | No operation | you should observe a decimal output count from 0 to 99 on the output display. The 047 instruction is the decimal adjust accumulator instruction, which converts the result of adding two bcd numbers in binary back to a pair of packed bcd numbers. It is not a binary-to-bcd conversion instruction as such. #### **EXAMPLE NO. 10** #### Purpose The purpose of this example is to demonstrate the BCD Input and Direct Conversion to Binary Routine, which is No. 80-147 in the Intel Microcomputer User's Library. This program was developed by M. H. Gansler. #### Program | LO<br>Memory | Instruc- | | | |--------------|------------|----------------|--------------------------------------------------------------------------------------------------------------------------| | Address | Byte | Mnemonic | Description | | 000<br>001 | 076<br>* | MVI A | Move immediate byte to the accumulator<br>Two-bcd-digit data byte that is to be con-<br>verted to an 8-bit binary number | | 002<br>003 | 117<br>346 | MOV C,A<br>ANI | Move contents of accumulator to register C And immediate byte with contents of the accumulator | | 004 | 017 | 017 | Mask byte that masks out the most signifi-<br>cant bed digit | | 005 | 137 | MOV E,A | Move contents of accumulator to register E | | 006 | 171 | MOV A,C | Move contents of register C to the accu-<br>mulator | | 007 | 346 | ANI | And immediate byte with contents of the accumulator | | 010 | 360 | 360 | Mask byte that masks out the least signifi-<br>cant bcd digit | | 011 | 017 | RRC | Rotate the accumulator contents one bit<br>to the right and into the carry flag | | 012 | 017 | RRC | Rotate the accumulator contents one bit<br>to the right and into the carry flag | | 013 | 117 | MOV C,A | Move contents of accumulator into regis-<br>ter C | | 014 | 017 | RRC | Rotate the accumulator contents one bit to<br>the right and into the carry flag | | 015 | 017 | RRC | Same as above | | 016 | 201 | ADD C | Add contents of register C to the contents of the accumulator | | 017 | 007 | RLC | Rotate the accumulator contents one bit to<br>the left and into the carry flag | | 020 | 203 | ADD E | Add contents of register E to the contents of the accumulator | | 021 | 323 | OUT | Output contents of accumulator to output<br>port given in the next instruction byte | | 022 | 000 | 000 | Device code for output port zero | | 023 | 166 | HLT | Halt | #### Comments The program starts with the two-bcd-digit number in the accumulator. The result is stored in the accumulator. To convert the program into a subroutine, substitute the RET instruction for the HLT instruction at LO=023. The program can be located anywhere in memory. If you attempt to execute this program, you may wish to compare your results with those shown below: | Decimal Number | Observed Binary Number | | |----------------|------------------------|--| | 1 | 0000001 | | | 10 | 00001010 | | | 20 | 00010100 | | | 50 | 00110010 | | | 75 | 01001011 | | | 80 | 01010000 | | | 90 | 01011010 | | | 99 | 01100011 | | #### EXAMPLE NO. 11 #### Purpose The purpose of this example is to demonstrate a 16-digit bcd addition subroutine, in which two bcd numbers are added together to produce a result that is less than or equal to 9,999,999,999,999,999. This program is listed and described in considerable detail in the $\mu COM$ -8 Software Manual and is given here courtesy of NEC Microcomputers, Inc. The program is started at memory location HI = 003 and LO = 024. #### Program | • | | | | |-------------------|------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------| | | Instruc- | | | | LO Memory | tion | | | | Address | Byte | Mnemonic | Description | | 024 | 021 | LXI D | Load immediate two bytes into registers<br>E and D, respectively | | 025 | 347 | | Registers D and E contain the 16-bit | | 026 | 003 | | address of the least significant digits<br>in the augend | | 027 | 041 | LXI H | Load immediate two bytes into registers L and H, respectively | | 030 | 357 | | Registers H and L contain the 16-bit | | 031 | 003 | | address of the least significant digits<br>in the addend | | ADD16: 032 | 365 | PUSH PSW | Push the program status word onto the stack (NOTE: Make certain that you have loaded the stack pointer before you execute this program.) | | 033 | 305 | PUSH B | Push the contents of register pair B,C onto the stack | | 034 | 016 | MVI C | Move the immediate byte into register C | | 035 | 010 | | Binary number equal to one-half the<br>number of bcd digits. Thus, for 16<br>bcd digits, the octal code would be<br>010 | | 036<br>LOOP2: 037 | 257<br>032 | XRA A<br>LDAX D | Clear the accumulator and carry flag<br>Load the accumulator from the memory<br>location addressed by register pair<br>D,E | | 040 | 216 | ADC M | Add the contents of the memory loca-<br>tion addressed by register pair H,L<br>to the contents of the accumulator | |------------|-----|---------|-------------------------------------------------------------------------------------------------------------------| | 041 | 047 | DAA | Decimal adjust the contents of the ac-<br>cumulator | | 042 | 022 | STAX D | Store the contents of the accumulator<br>into the memory location addressed<br>by register pair D,E | | 043 | 015 | DCR C | Decrement contents of register C by one | | 044 | 312 | IZ | Jump to the memory location DONE2 | | 011 | 012 | , | if the contents of register C are zero | | 045 | 054 | | LO address byte of DONE2 | | 046 | 003 | | HI address byte of DONE2 | | 047 | 053 | DCX H | Decrement contents of register pair H,L<br>by one | | 050 | 033 | DCX D | Decrement contents of register pair D,E<br>by one | | 051 | 303 | JMP | Jump to the memory location LOOP2 | | 052 | 037 | , | LO address byte of LOOP2 | | .053 | 003 | | HI address byte of LOOP2 | | DONE2: 054 | 301 | POP B | Pop contents of register pair B,C off of stack | | 055 | 361 | POP PSW | Pop the program status word off of stack | | 056 | 172 | MOV A,D | Move contents of register D to accumu-<br>lator | | 057 | 323 | OUT | Output contents of accumulator | | 060 | 001 | 001 | Device code of port one | | 061 | 173 | MOV A,E | Move contents of register E to accumu-<br>lator | | 062 | 323 | OUT | Output contents of accumulator | | 063 | 000 | 000 | Device code of port zero | | 064 | 166 | HLT | Halt | #### Discussion This program starts with a 16-digit bcd augend in LO memory addresses 340 through 347, with the least significant bcd digit in location 347 and the most significant bcd digit in location 340. The 16-digit bcd addend is initially in LO memory addresses 350 through 357, with the least significant bcd digit in location 357 and the most significant bcd digit in location 350. The terms addend and augend are defined as follows:<sup>2</sup> augend—In an arithmetic addition, the number increased by having another number (called the addend) added to it. addend—A quantity which, when added to another quantity (called the augend), produces a result called the sum. Program execution starts at ${\rm HI}=003$ and ${\rm LO}=024$ . The sum replaces the augend. Consider an augend of 1,000,000,000,000,009 and an addend of 8,000,000,000,000,001. The memory map for these two 16-digit bed numbers is as follows (all at $\rm HI=003$ ): | LO Memory | BCD | Octal | Binary | |-------------|--------|-------|----------| | Address | Digits | Code | Code | | 340 | 1,0 | 020 | 00010000 | | 341 | 0,0 | 000 | 00000000 | | 342 | 0 0 | 000 | 00000000 | | 343 | 0,0 | 000 | 00000000 | | 344 | 0,0 | 000 | 00000000 | | 345 | 0,0 | 000 | 00000000 | | 346 | 0,0 | 000 | 00000000 | | 347 | 9,9 | 231 | 10011001 | | 350 | 8,0 | 200 | 10000000 | | 351 | 0,0 | 000 | 00000000 | | 352 | 0,0 | 000 | 00000000 | | 353 | 0,0 | 000 | 00000000 | | 354 | 0,0 | 000 | 00000000 | | 355 | 0,0 | 000 | 00000000 | | 356 | 0,0 | 000 | 00000000 | | 35 <b>7</b> | 0,1 | 001 | 00000001 | | | | | | When these two numbers are added, the sum (9,000,000,000,000,000,100) replaces the augend in memory locations HI=003 and LO=340 to HI=003 and LO=347. You should observe the following sequence of bcd numbers in successive memory locations starting at LO=340: which correspond to the 16-digit bcd number 9,000,000,000,000,100. You may wish to add the following bcd numbers and compare your results with the predicted sums. | Augend | Addend | Sum | |-----------------------|-----------------------|-----------------------| | 3,000,000,000,000,100 | 1,000,000,000,000,001 | 4,000,000,000,000,101 | | 0,000,000,000,123,456 | 0,000,000,000,240,833 | 0,000,000,000,364,289 | | 0,000,000,000,927,928 | 0,000,000,000,844,992 | 0,000,000,001,772,920 | | 9,999,999,999,999 | 0,000,000,000,000,001 | 0,000,000,000,000,000 | #### EXAMPLE NO. 12 #### **Purpose** The purpose of this example is to demonstrate the Binary to BCD Subroutine, No. 8-67 in the Intel Microcomputer User's Library. The 188 program was developed by Niels S. Gundestrup of the Geophysical Isotope Laboratory in Denmark. | | Instruc- | | | |------------|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LO Memory | tion | Mnemonic | Description | | Address | Byte | | Move immediate two bytes into register | | 222 | 021 | LXI D | pair D. This is the 16-bit binary<br>number that will be converted to a<br>5-bcd-digit number | | 223 | * | | Least significant 8 bits of 16-bit binary number | | 224 | * | | Most significant 8 bits of 16-bit binary<br>number | | 225 | 041 | LXI H | Move immediate two bytes into register<br>pair D. This is the memory address<br>of the most significant digit (MSD)<br>of the 5-digit bod number. The re-<br>maining four digits are stored in suc-<br>cessive memory locations, one digit<br>per location | | 226 | 340 | | L register byte | | 227 | 003 | | H register byte | | BNBCD: 230 | 365 | PUSH PSW | Push contents of program status word<br>on stack | | 231 | 305 | PUSH B | Push contents of register pair B on stack | | 232 | 325 | PUSH D | Push contents of register pair D on<br>stack | | 233 | 345 | PUSH H | Push contents of register pair H on<br>stack | | 234 | 353 | XCHG | Exchange the contents of register pair H with the contents of register pair D | | 235 | 001 | LXI B | Move immediate two bytes into register pair B (10,000) | | 236 | 360 | | C register byte | | 237 | 330 | | B register byte | | 240 | 315 | CALL | Call subroutine DECNO, which performs the binary to bed conversion (MSD) | | 241 | 276 | | LO address byte | | 242 | 003 | | HI address byte | | 243 | 001 | LXI B | Move immediate two bytes into register pair B (1000) | | 244 | 030 | | C register byte | | 245 | 374 | | B register byte | | 246 | 315 | CALL | Call subroutine DECNO | | 247 | 276 | | LO address byte | | 250 | 003 | | HI address byte | | 251 | 001 | LXI B | Move immediate two bytes into register pair B (100) | | 252 | 234 | | C register byte | | 253 | | | B register byte | | 254 | | CALL | Call subroutine DECNO | | 255 | 276 | | LO address byte | | LO Memory | Instruc-<br>tion | | | | | | | | | | | | | |------------|------------------|----------|-----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--| | Address | Byte | Mnemonic | Description | | | | | | | | | | | | 256 | 003 | | HI address byte | | | | | | | | | | | | 257 | 001 | LXI B | Move immediate two bytes into register<br>pair B (10) | | | | | | | | | | | | 260 | 366 | | C register byte | | | | | | | | | | | | 261 | 377 | | B register byte | | | | | | | | | | | | 262 | 315 | CALL | Call subroutine DECNO | | | | | | | | | | | | 263 | 276 | | LO address byte | | | | | | | | | | | | 264 | 003 | | HI address byte | | | | | | | | | | | | 265 | 175 | MOV A,L | Move contents of register L to the accumulator | | | | | | | | | | | | 266 | 306 | ADI | Add immediate byte to contents of accumulator | | | | | | | | | | | | 267 | 000 | 000 | [Note: 260 if ASCII code is desired] | | | | | | | | | | | | 270 | 022 | STAX D | Store contents of accumulator in the<br>memory location addressed by regis-<br>ter pair D | | | | | | | | | | | | 271 | 341 | POP H | Pop register pair H off stack | | | | | | | | | | | | 272 | 321 | POP D | Pop register pair D off stack | | | | | | | | | | | | 273 | 301 | POP B | Pop register pair B off stack | | | | | | | | | | | | 274 | 361 | POP PSW | Pop program status word off stack | | | | | | | | | | | | 275 | 311 | RET | Return from subroutine | | | | | | | | | | | | DECNO: 276 | 076 | MVI A | Move following byte to accumulator [Note: 260 if ASCII code is desired] | | | | | | | | | | | | 277 | 000 | 000 | [NOTE: 260 if ASCII code is desired] | | | | | | | | | | | | 300 | 325 | PUSH D | Push register D on stack | | | | | | | | | | | | 301 | 135 | MOV E,L | Move contents of register L to register<br>E | | | | | | | | | | | | 302 | 124 | MOV D,H | Move contents of register H to register D | | | | | | | | | | | | 303 | 074 | INR A | Increment contents of accumulator by one | | | | | | | | | | | | 304 | 011 | DAD B | Add contents of register pair B to con-<br>tents of register pair H and store in<br>register pair H | | | | | | | | | | | | 305 | 332 | JC | Jump if carry flag is at logic 1 | | | | | | | | | | | | 306 | 301 | | LO address byte | | | | | | | | | | | | 307 | 003 | | HI address byte | | | | | | | | | | | | 310 | 075 | DCR A | Decrement contents of accumulator by one | | | | | | | | | | | | 311 | 153 | MOV L,E | Move contents of register E to register L | | | | | | | | | | | | 312 | 142 | MOV H,D | Move contents of register D to register H | | | | | | | | | | | | 313 | 321 | POP D | Pop register pair D off stack | | | | | | | | | | | | 314 | 022 | STAX D | Store contents of accumulator in the<br>memory location addressed by regis-<br>ter pair D | | | | | | | | | | | | 315 | 023 | INX D | Increment contents of register pair D by one | | | | | | | | | | | | 316 | 311 | RET | Return from subroutine DECNO | | | | | | | | | | | | Comments | | | | | | | | | | | | | | Comments This program starts with a 16-bit binary number in register pair D,E. The number is converted into a 5-bcd-digit number that is stored starting at HI = 003 and LO = 340. The most significant bcd digit is stored at this location, and the remaining four digits in subsequent locations. The least significant bcd digit is stored at LO = 344. The program BNBCD starts at HI = 003 and LO = 230; however, the 16-bit binary number must exist in register pair D, and the location of the most significant digit in register pair H. We have used LXI instructions to set this information in the registers before BNBCD is executed. The output can be either as decimal numerals or as 8-bit ASCII code, with the most significant bit (the parity bit) at logic 1. A slight error in the original program has been corrected to permit the LSD to be stored in ASCII code. #### TEST This test probes your understanding of the programming techniques and concepts that are described in this chapter. Please write your answers on a separate piece of paper. 3-1. Explain the difference between the following pairs of concepts: instruction vs. operation instruction vs. program assembly language instruction vs. mnemonic instruction mnemonic instruction vs. machine language instruction machine code vs. mnemonic code register vs. register pair program counter vs. stack pointer bit vs. byte byte vs. word word vs. memory address HI address byte vs. LO address byte program vs. subroutine routine vs. program instruction register vs. instruction decoder jump vs. call zero flag vs. sign flag carry flag vs. auxiliary carry flag PUSH vs. POP conditional jump vs. unconditional jump label vs. operand parity flag vs. sign flag accumulator vs. ALU data byte vs. address byte octal code vs. hexadecimal code increment vs. decrement or vs. exclusive or subtract vs. compare stack vs. stack pointer the IN vs. OUT instructions the B register pair vs. the H register pair the MOV vs. MVI instructions $\,$ the ADD vs. ADC instructions carry vs. borrow - 3-2. Summarize the five basic instruction groups and provide examples of instructions within each group. - 3-3. Write a simple microcomputer program in both machine code and in assembly language. With assembly language, use operands and labels. 3-4. Describe the five condition flags and the logic states that characterize - specific conditions. - 3-5. Explain the difference between octal code and hexadecimal code, and give several examples of 8-bit data bytes written in each type of code. Give an example of how the PUSH instruction behaves. - Give an example of how the POP instruction behaves. List at least nine different ways in which data can be loaded into the 3-7. 3-8. accumulator. - Describe the four different types of rotate instructions in the 8080 microprocessor instruction set. - **3-10.** What 8080 microcomputer instructions would you use to: Clear the accumulator Set the accumulator to $111111111_2$ Output data from the accumulator to an output device Input data into the accumulator from an input device Move data from register E into the accumulator Move data from the accumulator into memory location $H=000_8$ and $L=200_8$ Move data into the accumulator from memory location H = 0008 and $L=201_8$ Move data byte $10101110_2$ into the accumulator Check the logic state of each bit in the accumulator Multiply the contents of the accumulator by 4 Divide the contents of the accumulator by 8 Store the contents of the accumulator in a memory location stored in register pair B and C Load the accumulator from a memory location stored in register pair D and E Move the contents from the accumulator to a memory location Set the carry bit to logic 0 Use the least number of instructions that you can in each case. Your performance on this test will be acceptable if you can answer all of the above questions correctly in a four-hour closed-book examination. #### WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? It was stated at the beginning of this chapter that at the end you would be able to do the following: • Explain what the difference is between an instruction, operation, program, machine code instruction, assembly language instruction, and mnemonic instruction. You have learned the distinctions between the above terms in the text provided in this chapter. • Define the terms: assemble, bit, byte, flag, mnemonic symbol, device code, HI address byte, LO address byte, increment, decrement, label, jump, call, return, label, operand, carry flag, parity flag, zero flag, sign flag, register, register pair, subroutine, two-byte instruction, three-byte instruction, unconditional operation, conditional operation, branch instruction, stack, stack pointer, program counter, accumulator, ALU, data byte, and instruction Definitions for these terms have been provided at the beginning and throughout this chapter. Classify the 8080 instructions into five groups. The five groups are: data transfer, arithmetic, logical, branch, and a final group composed of stack, I/O, and machine control instructions. An extensive list of the instruction set has been provided based on these five groups. • Explain how an 8-bit instruction can be written in both octal code and hexadecimal code. This has been discussed in a section within this chapter. List the mnemonic codes, following the Intel Corporation recommendations, for at least ten different 8080 instructions. There are 78 different instructions, so this objective should be rather easy to fulfill. • Explain the difference between machine language and assembly language. We have done this near the end of the chapter. • Identify the HI address byte and the LO address byte in a 16-bit memory address word. You should have no difficulty with this objective. • Explain what the differences are between a bit, a byte, a word, and an address. Definitions have been provided, with reference to the 8080 micro- • List at least ten different registers that can be found in the 8080 microprocessor chip. A list is provided in this chapter. The most important registers are the accumulator, B, C, D, E, H, L, stack pointer, and program counter registers, which total nine. Explain how the microprocessor decodes: instruction classes registers register pairs immediate operations branch operations condition flags increment operations decrement operations Much of this chapter has been devoted to this subject. #### **CHAPTER 4** # Generating a Device Select Pulse In this chapter, you will learn how to generate device select pulses from an 8080 microcomputer. These pulses will be employed in subsequent chapters in this Bugbook to latch output data and also to allow data to be input into the accumulator. The 8080 microprocessor is very powerful in that it can generate up to 256 different output device select pulses and 256 different input device select pulses. This should be more than enough for any reasonable application for the 8080 microprocessor. #### **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Identify the OUT and IN instructions in an 8080 microprocessor program. - Draw a schematic diagram for a circuit that can generate up to 256 different device select pulses. - Explain how device select pulses are generated by the 8080 microprocessor. - Write simple microcomputer programs that employ IN or OUT instructions. - Draw a block diagram for a 74154 four-line-to-sixteen-line decoder. #### DEFINITIONS device select pulse—A software-generated positive or negative clock pulse from a computer that is used to strobe the operation of one or more I/O devices, including individual integrated-circuit chips. I/O-Abbreviation for input/output.4 I/O device—Input/output device. Any digital device, including a single integrated-circuit chip, that transmits data or strobe pulses to a computer or receives data or strobe pulses from a computer. machine cycle—A subdivision of an instruction cycle, which is the time required to execute a complete instruction. A machine cycle is the smallest period required to perform a group of related actions during the execution of an instruction cycle. #### 8080 MICROPROCESSOR I/O INSTRUCTIONS There are only two 8080 microprocessor input/output instructions: 333 <B2> IN Generate a device select pulse to allow an 8-bit data byte to be read from the input device and replace the contents of the accumulator. **323** <B2> OUT Generate a device select pulse to allow an 8-bit data byte present in the accumulator to be sent to an output device. The contents of the accumulator remain unchanged. These two instructions have the following form: where the *device code* is an 8-bit byte that specifies one among 256 different devices. Both of the above instructions are quite similar to each other. The only difference between the two revolves around what occurs in the accumulator. With the input instruction, the accumulator contents change, whereas with the output instruction, they do not. The term device select pulse can be defined in the following manner: device select pulse—A software-generated positive or negative clock pulse from a computer that is used to strobe the operation of one or more I/O devices, including individual integrated-circuit chips. The importance of the device select pulses resides in their use to strobe input data into the accumulator during an input instruction or to strobe the latching of output data from the accumulator during an output instruction. However, they can also be used to strobe the operation of I/O devices under conditions where data transfer to or from the accumulator does not occur. Thus, as pointed out in some detail in Chapter 1, device select pulses are single clock pulses that can be used in a variety of ways, for example, to simulate the behavior of a 555 astable, a pulser, or a 74121 or 555 monostable. The mnemonics for the above two instructions are IN <B2> and OUT <B2>, and each requires ten clock cycles, or 5 $\mu$ s, to execute. Neither instruction affects any of the five condition flags in the 8080 microprocessor. The symbol <B2> indicates that a second instruction byte, in this case a device address, must be present in the program immediately following the IN or OUT instruction code. #### DEVICE SELECT PULSE DECODING The generation of 256 different device codes is accomplished with the aid of the eight least-significant bits in the 16-bit memory address word, i.e., the LO memory address byte, or the eight most-significant bits in the memory address word, i.e., the HI memory address byte. Either 8-bit byte is acceptable for the generation of the device code in the 8080 microprocessor; we have used the LO address bus byte in our examples. Decoders, such as the 74154 four-line-to-sixteen-line decoder, the pin configuration and block diagram of which are given in Fig. 4-1, decode the 8-bit device code into as many as 256 different device select pulses. A single decoder can provide sixteen different pulses. Four bits of the 8-bit device code are applied at the inputs A through D at pins 23 to 20. The sixteen outputs are obtained at pins 1 through 11 and 13 through 17. The two strobe inputs, G1 and G2, must both be at logic 0 to enable the chip. The unique output state is at logic 0; the remaining fifteen outputs are all at logic 1. Fig. 4-1. The 74154 four-line-to-sixteen-line decoder chip #### One 74154 Decoder, Sixteen Device Select Pulses A variety of different strategies can be employed to decode the 8-bit device code and generate individual device select pulses. The simplest decoder circuit is shown in Fig. 4-2: Sixteen different device select pulses are generated with the aid of the four least significant bits in the LO memory address word and either the IN or the OUT synchronization pulse from the 8080 microcomputer. The $\overline{\text{IN}}$ or $\overline{\text{OUT}}$ pulse strobes the decoder at G1; G2 is tied to logic 0. The device select pulse generated with this circuit is a negative clock pulse, which for some uses must be inverted with the aid of a 7404 hex inverter chip. Most simple microcomputer interface circuits will not require more than sixteen device select pulses. Acceptable device codes for the diagram of Fig. 4-2 include the following, where X indicates that either a logic 0 or logic 1 is acceptable in the indicated bit position: | XXXX0000 | XXXX1000 | |----------|----------| | XXXX0001 | XXXX1001 | | XXXX0010 | XXXX1010 | | XXXX0011 | XXXX1011 | | XXXX0100 | XXXX1100 | | XXXX0101 | XXXX1101 | | XXXX0110 | XXXX1110 | | XXXX0111 | XXXX1111 | Separate decoder chips must be used for input and output devices. Thus, a pair of 74154 decoders permits you to select up to sixteen different input devices and sixteen different output devices. Fig. 4-2. A simple decoder circuit that can generate sixteen different device select pulses. The decoding of the address bus is not absolute. # Seventeen 74154 Decoders, 256 Device Select Pulses A circuit that requires a single IN or OUT connection and can generate up to 256 different device select pulses is shown in Fig. 4-3. The most significant four bits in the 8-bit LO memory address word select the decoder on the right, whereas the four least significant bits select the specific output channel on the selected decoder. All device select pulses are negative clock pulses. Fig. 4-3. Diagram of a circuit that can generate 256 different device select pulses. #### Other Decoder Circuits There are many other methods which may be used to generate the OUT and IN device select pulses associated with microcomputer I/O devices. While the hardware may change and may be different from application to application, the software is always the same. You always specify either an OUT (323) or IN (333) instruction and a device code. The decoder circuit shown in Fig. 4-4 demonstrates how two 74154 decoder chips and appropriate two-input Non gates can be used to also generate a unique one-of-256 device select pulse for each device code. While this circuit requires fewer decoders than the scheme shown in Fig. 4-3, a Non gate is needed for each device select pulse generated. You could also use on gates if you required negative rather Fig. 4-4. Another circuit that can generate 256 different device select pulses. Only one of the 256 NOR gates required is shown. than positive device select pulses. Fig. 4-5 shows how you can generate the output device select pulses 000, 001, 002, 003, and 004; the scheme decodes only output instructions. You must duplicate the Fig. 4-5 hardware for input device address decoding. The preceding decoder schemes are used to generate input and output device select pulses for the purpose of transferring data or generating control signals only when a number of devices are located close together, usually on the same printed-circuit board. Peripheral or remote units usually have a simple decoder for the specific device. For example, if you wish to generate a unique device address, such as 371, and either an input or output device select pulse, you would employ the circuit given in Fig. 4-6. the circuit given in Fig. 4-6. You could use a pair of 7485 comparator chips to produce a unique device select pulse, such as the output pulse $\overline{DS}$ 306, only when both sets of eight inputs exactly match (Fig. 4-7). This is a very flexible circuit that is used in systems where the device code must be changed. circuit that is used in systems where the device code must be changed. If you require several device select pulses, combinations of the preceding schemes and decoders are effective. The circuit shown in Fig. 4-8 can be used to generate device addresses 070, 071, 072, and 073. The 7430 eight-input NAND gate decodes the A2 to A7 address bits. When the correct combination of address inputs appear at this gate, the 7442 decoder is enabled at input D (pin 12). The C input to the 7442 chip is used as another enable, in this case, either the IN or OUT Fig. 4-5. Decoding scheme for the generation of output select pulses 000, 001, 002, 003, and 004. Fig. 4-6. Absolute decoder circuit based upon the use of a 7430 8-inp pulse. A pair of comparators could have been used in place of the 7430 chip and associated 7404 inverters. While the hardware has changed in the preceding decoding circuits, the basic software necessary to generate the addresses and IN and OUT pulses remains the same. #### A SAMPLE MICROCOMPUTER PROGRAM $\boldsymbol{A}$ simple program that demonstrates the use of the OUT instruction is given on the following page. Fig. 4-7. Absolute decoder circuit based upon the use of a pair of 7485 4-bit comparator chips. 202 Fig. 4-8. Absolute decoder circuit based upon the use of 7430 8-input NAND gate and a 7442 decoder. | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------| | 000 | 076 | MVI A | Move the following instruction byte into the accumulator | | 001 | 023 | 023 | Data byte | | 002 | 323 | OUT | Generate a device select pulse to output<br>eight bits of accumulator data to the de-<br>vice with the device code given in the<br>following byte | | 003 | 321 | 321 | Device code for output device | | 004 | 303 | JMP | Unconditional jump to the memory location given in the following two bytes | | 005 | 000 | | LO memory address byte | | 006 | 000 | | HI memory address byte | This simple program places data byte 023 into the accumulator; sends the contents of the accumulator to output device 321; and finally returns to LO memory address 000, at which point the program repeats itself. The HI memory address is 000, and all of the above numbers are in three-digit octal code. If you were to apply an oscilloscope to an 8080 microcomputer and observe the execution of the above program, you would observe the timing diagrams shown in Fig. 4-9. The contents of the accumulator are set first and remain unchanged throughout the program; the accumulator byte has a value of 00010011, or 023 in octal code. As the OUT instruction is executed, the LO memory address lines assume the value corresponding to the device code, which is 321 in the above program. This value is held on the address lines for 1.3 $\mu$ s, during which time the $\overline{OUT}$ control signal is generated, typically for 500 ns Fig. 4-9. Timing diagrams applicable for the generation of a device select pulse and the latching of accumulator output during a 5-µs OUT instruction. Information is transferred from the accumulator to an output device and a device select pulse is provided for a period of only 500 ns. in an 8080 microcomputer that is operating at 2 MHz. The combination of the $\overline{\rm OUT}$ control signal and the eight address lines is sufficient to generate 256 different device select pulses, as shown in Fig. 4-3. Data in the accumulator remains the same during the entire 5- $\mu$ s OUT instruction. The device select pulse generated during this period can be used to latch this accumulator information, as will be discussed in Chapter 7. #### **DEVICE SELECT PULSES AS CONTROL PULSES** Device select pulses are not only used for strobing data transfer between the microcomputer and input/output devices. They may be used as control pulses to start or stop machines, clear devices, open valves, etc. The circuit in Fig. 4-10 shows how a device select pulse can be used to clear a 7490 decade counter integrated-circuit chip. Whenever you wish to clear the counter, insert an OUT instruction in your program with the appropriate device address. The specific device select pulse used is obtained from a decoding scheme. A device select pulse can be used in conjunction with a latch, such as the 74175 chip shown in Fig. 4-11, to store switch data, which in this case is displayed on a seven-segment display. Data storage occurs only when the 74175 is clocked. The latch may be cleared by a different device select pulse applied at the clear input to the chip. The timing of when the latch is cleared or when switch data is stored is determined by your microcomputer program. For example, you may initially wish to clock the latch and observe the logic switch settings on the display. You do so with the aid of an output 001 device select pulse applied at pin 1 on the chip. Later in your program, you may wish to clear the latch; in this case, an output 000 device select pulse does the job. The type of program that you would use is as follows: | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|---------------------------------------------| | 000 | 323 | OUT | Send out a 001 device select pulse to clear | | 001 | 001 | 001 | the latch | | • | | • | | | | | • | | | • | | | | | 020 | 323 | OUT | Send out a 000 device select pulse to dis- | | 021 | 000 | 000 | play the updated logic switch data | | • | • | • | | | | _ | | | Fig. 4-10. A device select pulse can be used to clear a counter, as shown here for the 7490 chip. Fig. 4-11. A pair of device select pulses are used here to clock a latch and to clear it. Notice that output instructions have been consistently used to generate the control pulses used to control the operation of the 7490 and 74175 chips. Any input device select pulse could have been used with good results, but there is an important reason why this is not done. Whenever you output data with an OUT instruction, the data in the accumulator is copied into an external output device. The microcomputer does not care whether or not a device exists to accept the data; accumulator contents are not changed. The situation is different with an IN instruction. Whenever an input device select pulse is generated, the microcomputer expects eight bits of data to be transferred to the accumulator from an input device. If no such device is present, the accumulator register is usually loaded with all logic 1's, i.e., with the octal data byte 377. Therefore, you should always use OUT instructions to generate control pulses; by doing so, you continue to have control over the contents of the accumulator. #### **EXAMPLE** #### Purpose The purpose of this example is to show how two 74154 decoders can be configured to generate sixteen contiguous device select pulses within the 256 possible device select pulses. | Program | |---------| |---------| | og.a | | | | |----------------------|----------------------|----------|-------------------------------------------------------------------------------------------------------| | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | | 000 | 323 | OUT | Send out a device select pulse to the device<br>with the device code given by the follow-<br>ing byte | | 001 | 000 | 000 | Device code 000 <sub>8</sub> | | 002 | 323 | OUT | Send out a device select pulse to the device<br>with the device code given by the follow-<br>ing byte | | 003 | 001 | 001 | Device code 001 <sub>8</sub> | 20 (A) 7404 chip pin configuration. (B) 74154 chip pin configuration. (C) Diagram of circuit. Fig. 4-12. Circuit to generate sixteen contiguous device select pulses. | 004 | 323 | OUT | Send out a device select pulse to the device<br>with the device code given by the follow-<br>ing byte | |-----|-----|-----|-------------------------------------------------------------------------------------------------------| | 005 | 002 | 002 | Device code 002 <sub>8</sub> | | | | | Send out a device select pulse to the device | | 006 | 323 | OUT | with the device code given by the follow-<br>ing byte | | 007 | 003 | 003 | Device code 003 <sub>8</sub> | | | | IMP | Unconditional jump to memory address | | 010 | 303 | JMF | given in following two bytes | | 011 | 000 | | LO memory address byte | | | | | HI memory address byte | | 012 | 000 | | rii memory address byte | #### Comments As the microcomputer executes this program, it generates OUT synchronization pulses and provides the device code on the LO address lines, A0 through A7. This information is used by the decoders to produce a unique one-out-of-256 pulse for each device code. Although only four of the possible codes are shown in the schematic diagram and generated by the program, you can generate all sixteen pulses by adding software. The No. 1 74154 decoder already has all of the first sixteen decoded output channels available. The No. 2 74154 decoder acts as a master decoder to enable, or turn on, the lower 74154 decoder only when the address lines A4, A5, A6, and A7 are all at logic 0. The remaining output channels on the No. 2 decoder can be used to enable more decoders to produce additional output device select pulses. The above software contains a loop that causes the microcomputer to continuously output the four output device select pulses. This test probes your understanding of the concepts and experiments in this chapter. Please write your answers on a separate piece of paper. - 4-1. What is a device select pulse, and how is it produced with the aid of interface circuitry to the 8080 microcomputer? Use schematic diagrams in your answer to this question. - 4-2. Describe ten different uses for device select pulses. You can use different - integrated-circuit chips in your answer, but please do not be repetitive. 4-3. Write a simple microcomputer program that generates three different input device select pulses and two different output device select pulses. - 4-4. Draw a series of timing diagrams that show how a 164<sub>8</sub> device select pulse is used to allow an output device to latch the contents of the accumulator, which contains data byte 11010110<sub>2</sub>. Your performance on this test will be acceptable if you can answer all four of these questions correctly in a 40-minute closed-book examination. You will encounter most of the answers in this book in later chapters. #### WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? It was stated at the beginning of this chapter that at the end you will be able to do the following: - Identify the OUT and IN instructions in an 8080 microprocessor program. - The operation codes for these two instructions are 323 and 333, respectively. Whenever they appear in a microprocessor program, they are the OUT and IN instructions, without exception. (A) The 74121 chip used as a monostable multivibrator. Monostable pulses as short as 40 ns can be generated conveniently. (B) The 74122 chip wired as a monostable multivibrator. (C) The 74123 chip wired as a monostable multivibrator. Two independent monostable multivibrators are available on the 74123 chip. (D) The 555 timer chip used as a monostable multivibrator. Pulses shorter than several microseconds cannot be generated by this chip. The strobe pulse must be shorter than the output monostable pulse. Fig. 5-1. Common monostable multivibrators. making changes in the computer program rather than by changing resistors or capacitors, as would be the case for the 74121, 74122, 74123, and 555 monostable multivibrator chips. This brings us to the question: How do we know how long it takes to execute a group of microcomputer instructions? We shall discuss this question in the following section. # HOW LONG DOES IT TAKE TO EXECUTE A MICROCOMPUTER INSTRUCTION? A microcomputer, as any digital computer, is a clocked digital electronic device. This means that all actions occur at or during precisely defined clock intervals. For example, a typical 8080 microprocessor chip is operated at a clock rate of 2 MHz. A single clock cycle, or *state*, has a period of: ``` \begin{array}{l} \mathrm{period} = 1 \mathrm{\ cycle/2,000,000 \ \ cycles \ per \ second \ \ (hertz)} \\ = 0.0000005 \mathrm{\ second} \\ = 0.5 \ \mu \mathrm{s} \\ = 500 \ \mathrm{ns} \end{array} ``` where clock cycle, state, and period are defined as: period—The time required for one complete cycle of a regular, repeating series of events. clock cycle, state-A single clock period or stable condition. Every action within the 8080 microprocessor requires some multiple of the period of microprocessor clock. A computer instruction is a typical microprocessor "action," so it too is performed in some multiple of the period of the microprocessor clock. The fastest instruction requires only four clock periods, called states or clock cycles: four cycles = $$4 \times 500 \text{ ns}$$ = $2 \mu \text{s}$ whereas the slowest instruction, XTHL, requires eighteen clock cycles: eighteen cycles = $$18 \times 500 \text{ ns}$$ = $9 \mu \text{s}$ Clearly, the time required to execute a group of instructions is determined by the cumulative time to execute each of the individual instructions within the group and multiplied by the number of times such instructions are executed. If we are clever, we can arrange a group of instructions in such a manner that their execution requires a predetermined amount of time, such as 0.20 second. As long as the clock rate for the microcomputer remains at 2 MHz, it will always take 0.20 second to execute this group of instructions. Draw a schematic diagram for a circuit that can generate up to 256 different device select pulses. This circuit has been given in Fig. 4-3. It employs seventeen 74154 four-line-to-sixteen-line integrated-circuit chips. $\bullet$ Explain how device select pulses are generated by the 8080 microprocessor. Actually, this chapter has provided only a partial explanation. Each Actually, this chapter has provided only a partial explanation. Each device select pulse is produced as a consequence of an $\overline{OUT}$ or $\overline{IN}$ strobe pulse and a pulse produced by the action of decoding the 8-bit device code that appears for 1.3 $\mu s$ on the memory address bus. We have not discussed how the $\overline{OUT}$ and $\overline{IN}$ pulses are produced, a topic which will be treated in Chapter 6. • Write simple microcomputer programs that employ IN or OUT instructions. This has been done in several examples in this chapter. Most of the programs contain only five instruction bytes. • Draw a block diagram for a 74154 four-line-to-sixteen-line decoder. We have used the 74154 chip often in this chapter, so you should be able to draw a block diagram of it and, by memory, identify some of the more important pin numbers. G1 and G2 are at pins 18 and 19, respectively. The output channels start at pin 1 and continue to pin 11. They resume at pin 13. #### **CHAPTER 5** # **Clock Cycles and Timing Loops** In this chapter, you will examine the timing of various 8080 instructions and the use of a microcomputer as a pulse or timing generator. Microcomputers are used frequently in situations where complex timing periods and sequences are required. Examples include traffic light control, oven and microwave range control, and washer and dryer control. control. #### **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Define the terms: loop, timing loop, period, clock cycle, and state. Program a timing loop that can generate timing delays that are multiples of 0.200 second. - Program a timing loop that can generate timing delays that are multiples of approximately 0.5 millisecond. Demonstrate how a microcomputer can act as a monostable multiplication. ### **DEFINITIONS** $\begin{array}{l} \textit{clock cycle-A single clock period.} \\ \textit{loop-A sequence of instructions that is executed repeatedly until a terminal condition prevails.}^3 \end{array}$ monostable multivibrator—A circuit having only one stable state, from which it can be triggered to change the state, but only for a predetermined interval, after which it returns to the original state. period—The time required for one complete cycle of a regular, repeating series of events. programmable sequencer—A sequencer in which the order in which the events or operations occur can be changed with the aid of programming. sequencer—An electronic device that may be set to initiate a series of events and to make the events follow in sequence, i.e., in order.<sup>4</sup> state—A single clock period, or stable condition. timing loop-A loop that requires a precise period for its execution. #### MONOSTABLE MULTIVIBRATORS A monostable multivibrator can be defined as follows: monostable multivibrator—A circuit having only one stable state, from which it can be triggered to change the state, but only for a predetermined interval, after which it returns to the original state. They are used to generate individual clock pulses of precisely known pulse width. Such clock pulses are widely used in digital electronics to coordinate the timing in digital circuits and also to turn external devices on and off for predetermined time intervals. The schematic diagrams shown in Fig. 5-1 summarize the common monostable multivibrators that are in use today. The 74121, 74122, and 74123 chips generate individual clock pulses whose pulse width varies from about 40 ns to several milliseconds. The 555 monostable can generate pulse width that vary from several microseconds to several minutes. These chips are discussed in greater detail in Chapter 8 in Bugbook II. ### THE MICROCOMPUTER AS A MONOSTABLE MULTIVIBRATOR A microcomputer, such as the 8080, can also act as a monostable multivibrator. It is possible to write a computer program that contains a *timing loop*: timing loop—A loop that requires a precise period for its execution. loop—A sequence of instructions that is executed repeatedly until a terminal condition prevails.<sup>3</sup> It should be clear that such a loop can be interposed between two OUT instructions in a computer program. With proper external circuitry, a single clock pulse of pulse width determined by the computer program can be produced. We might call such a pulse a software-generated monostable pulse. The pulse width can be controlled by Fig. 5-2. Timing diagrams for the two-phase clock inputs to an 8080 chip Time In general, the basic "currency" of a computer is time; the faster that it can perform a series of instructions, the more powerful it is and the more useful it will be in replacing integrated-circuit chips such as those in the 7400-series of chips. At the moment, a typical operating frequency for an 8080-based microcomputer is 2 MHz; this means that a single clock period is equal to 500 ns. This is the time duration between successive pulses of one of the two clock phases, $\phi_1$ and $\phi_2$ , as shown in Fig. 5-2. Keep in mind, however, that the speed of 8090 chips may be increased with improvements in manufacturing techniques. It is quite possible that an improved 8080 chip may operate at a maximum speed of 4 MHz, which means that a single clock period will be only 250 ns. Naturally, the R/W, PROM, and ROM chips will also have to be faster if a useful microcomputer system is to be constructed. And the 8080 is not the last word in computer speed. Improvements in semiconductor manufacturing techniques, particularly in an area called bipolar technology, will lead to inexpensive and widely used microprocessor chips that are clocked at rates as high as 30 MHz, or 33.3 nanoseconds per clock period. ## CLOCK CYCLE LISTING FOR THE 8080 INSTRUCTION SET On the following page is a complete listing of the 8080 instruction set that includes the number of clock cycles required for each instruction. This page is provided by Intel Corporation. In this section, we shall summarize the conclusions that can be derived from this listing. The shortest time during which a single instruction can be executed is four clock cycles, or 2 $\mu$ s, if we assume that a single clock cycle requires 500 ns. Register arithmetic and logical operations and accumuquires 500 iis. negister antimieuc and iogical operations and accumulator contents rotation can be performed in this short interval of time. Included in such a group are the ADD, ADC, SUB, SBB, ANA, XRA, ORA, CMP, RLC, RRC, RAL, and RAR instructions. All register-to-register MOV instructions as well as increment and decrement instructions. INIP, DCP, INIV, and DCV, are consisted in decrement instructions INR, DCR, INX, and DCX, are executed in five clock cycles, or $2.5~\mu s$ . #### INSTRUCTION SET Summary of Processor Instructions | MOV 4 More register to remove the control of | Mnemonic | Description | 0- | , 0, | | stret<br>c O | | | | D. D. | Clock <sup>[2]</sup><br>Cycles | Meemanis | Description | р. | | | truct | | | | | Crock (2)<br>Cycles | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------|-----|------|-----|--------------|-----|-----|----|-------|--------------------------------|------------|-----------------------------|-----|----|---|-------|---|-----|-----|------|---------------------| | Move Figure 10 memory improved 0 1 1 1 0 0 0 0 0 0 | | | | _ | _ | _ | - | | ٠. | | , ., | | | | | - | | | , , | 2 . | 1 40 | LYCHS | | More - Movement program of a 1 0 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 | MOV,1,7 | | | | | | | | | | | | Return on zero | - 1 | 1 | 0 | 0 | , | 0 | n | n | 5(11 | | MATERIAL MAT | | | | | | | | | | | | | | - 1 | 1 | | 0 | | ō | ē | ō | 5/11 | | More members region | | | | | | | | | | | | | | , | | | 1 | 0 | 0 | | 0 | 5/11 | | More mentation accordance of a property | | | | | | | | | | | | | | 1 | | | 1 | | | | | | | No. | | | | | | | | | | | | | | | | | | | | | | | | Conference Con | | Increment reaster | | | | | | | | | | | | . ! | | | | | | | | | | May 9 May 19 | DCRr | | | | | | | | | | | | | - ! | | | • | | | | | | | Commonweal matrix Comm | INR M | Increment memory | o | 6 | - 1 | - î | 0 | 1 | n | ò | 10 | | | | | | | | | | | | | ABO Add repert is A Add repert is A Add repert is A Add repert is A Add repert is Add repert is A | | Decrement memory | . 0 | 0 | 1 | 1 | 0 | - 1 | 0 | 1 | 10 | | | | | | | | | | | | | AGE Add register to A with John 1 0 0 0 1 1 0 0 1 1 | | | - 1 | 0 | 0 | 0 | 0 | \$ | s | S | 4 | | | ٠ | | ۰ | ۰ | | ۰ | | | 10 | | Substitute prefer from A | | | | | | | | | | | | LXID | | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 | | MAN A designer with Control of the C | | | | | | | | | | | | | Pair D & E | - | - | - | | | - | - | | | | AMA A Martegree with A and a 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 | 288 - | | 1 | 0 | 0 | - 1 | - 1 | \$ | s | S | 4 | FXIH | Load immediate register | 0 | 0 | 1 | | 0 | 0 | 0 | 1 | 10 | | SAA Calcard Program and A 0 0 0 0 0 0 1 1 1 1 | | | | | | | | | | | | i | | | | | | | | | | | | 0.0-A. 0.0-regerement A. 0 0 0 0 0 1 10 1 0 0 0 0 1 11 1 | | | | | | | | | | | | | | | | | | | | | | | | Compare regions with A 0 0 0 0 0 0 0 0 0 | | | | | | | | | | | | PUSH B | | - 1 | 1 | 0 | 0 | 0 | -1 | 0 | 1 | 11 | | AGO M. Add memory in A. m | | | | | | - 1 | | | | | | | | | | | | | | | | | | AGE M. Addienness sha with course speak A. 1 0 0 0 1 1 0 0 0 1 1 | A00 M | | | | | ė. | | | | | | PUSH (I | | - 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 11 | | Signature Sign | | | í | | | | | | | | | | | | | | | | | | | | | Sign and process plane A 1 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | SUB M | | - 1 | | | ĭ | 'n | í | | | | PUSH H | | 1 | 1 | 1 | 9 | 0 | , | | , | 11 | | NAME AND COMMITTED STATES OF THE PROPERTY T | S88 M | | - 1 | ō | | i | | i | i | | | Direct Dem | | | | | | | | | | | | All All Medinements with A 1 0 1 0 1 0 0 0 1 1 0 1 0 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 1 0 1 0 1 1 1 0 1 0 1 1 0 1 0 1 1 0 1 0 1 1 0 1 0 1 0 1 1 0 1 0 1 0 1 0 1 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 0 1 0 1 0 0 1 1 0 0 1 0 1 0 0 1 0 1 0 0 1 0 1 0 0 1 0 1 0 0 1 0 0 1 0 1 0 0 0 1 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | with burrow | | | | | | | | | | 103/1738 | | | | | | 9 | | U | | | | ## All Mark Technology Commonlay with A 0 1 0 1 0 0 0 1 1 0 0 | | | 1 | | 1 | | 0 | 1 | 1 | 0 | 1 | PDP B | | | , | n | n | | | | | 10 | | Curry Compare months with A | | | | | | | | | | | | | | | | | | ٠ | ۰ | | | 10 | | Compare management | | | | | | | | | | | | POP D | Pro register pair D & E off | 1 | 1 | 0 | 1 | n | 0 | 0 | 1 | 10 | | ACC Add commentate to A. A. | | | | | | | | | | | | | | | | | | | | | | | | Carry Carr | | | | | | | | | | | | POP H | | 1 | 1 | 1 | 0 | 0 | 0 | | 1 | 10 | | Solid Section of the Control th | ACI | | - 1 | , | U | 0 | 1 | , | 1 | 9 | , | | | | | | | | | | | | | Section Sect | CHP | | | | | | × | | | | | POP PSW | | 1 | 1 | 1 | , | 0 | 0 | 0 | 1 | 10 | | Mail Boston Mail Boston Mail Boston Mail Boston Mail Mail Mail Mail Mail Mail Mail Mail | | | | | | | | | | | | | | | | | | | | | | | | AND Accommendation with A 1 1 1 0 0 1 1 0 7 7 7 7 7 7 7 7 7 7 7 7 | | | | | | | | | | | | | | | | | | | | | | | | State of Connection and A | | And immediate with A | 1 | 1 | 1 | 8 | 0 | 1 | 1 | 0 | 7 | | | | | | | | | | | | | One | XRI | Exclusive Or immediate with | - 1 | 1 | 1 | 0 | 1 | 5 | 1 | 0 | 7 | | | | | | U | • | v | | , | • | | One of the consequent with A | | | | | | | | | | | | XTHL | | 1 | 1 | 1 | n | n | ۸ | 1 | , | 18 | | Compare mediciar work | | | | | 1 | | | | 1 | | | SPHIL | | i | i | 1 | ĭ | ĭ | ě. | ė. | , | | | Mine Control of the C | | | | | | | | | 1 | | | | H & L to program counter | 1 | i | 1 | ò | i | ō | | í | | | MAIN Septim Agriphistopy 0 0 0 1 1 4 MAIN MAI | | | | | | | | | | | | | | | | | 0 | 1 | ū | 0 | 1 | | | Mail Marie Marie Mail | | | | | | | | | | | | | | | | | 1 | 1 | | | 1 | | | Arry Carry C | | | | | | | | | | - ! | | | | | | | | 1 | | | | | | Mark Section | | | ۰ | ۰ | | | • | | | | * | | | | | | | | | | | | | X. Anne so carry 1 1 0 1 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 | JMP | | | 1 | c | 0 | 0 | | | | 10 | | | | | | | | | | | | | ACC | JC . | | i | i | | | | | | | | | | | | | | | | | | | | Many purery p | | Jump on no carry | 1 | 1 | ō | 1 | 9 | 0 | 1 | 0 | | | | | | | | | | | | | | MAZ Many to septem. 1 0 0 0 0 0 0 0 0 0 | | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 10 | | | | | | | | | | | | | Manage sparsers 1 1 1 0 0 1 0 1 0 1 0 1 0 0 | | | 1 | 1 | 0 | | | | 1 | | | | | | | | | | | | | | | Media de la composition del la composition del la composition de la composition de la composition del c | | | 1 | 1 | 1 | | | | 1 | | | | | | | | | | | | | | | Manual part | | | | 1 | 1 | | | | 1 | | | INX SP | | | | i | | | | 1 | | | | AGLI Call dependence | | | | | 1 | | | | | | | | | | Ď. | ó | à | 1 | | í | | | | CC Color overy 1 1 0 1 1 1 0 1 11 0 1 11 0 1 11 0 1 11 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | Decrement D & E | 0 | ō | ō | i | i | ō | , | 1 | 5 | | OCC Called non-servery 1 1 0 1 0 1 0 0 10117 PART CALLED NO. 1 1 0 0 1 0 1 0 1 10 1 0 1 10 1 0 1 10 1 0 1 10 1 0 1 10 1 10 1 10 1 1 1 1 0 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | Decrement H & L | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 5 | | 2.2 Cafe now 2. 1 1 0 0 1 1 0 0 1117 STC Services 0 0 1 0 0 0 1 0 0 1117 STC Services 0 0 1 1 0 0 1 1 1 4 4 4 4 4 4 4 4 4 4 4 | | | | | | | | | | | | | | | | | | 1 | 0 | 1 | 1 | 5 | | CRZ Calmano Amo 1 1 0 0 0 0 0 111/2 ENC Employment Carry 0 0 1 1 0 1 1 4 0 0 0 0 111/2 ENC Employment Carry 0 0 1 1 0 0 1 1 1 4 0 0 0 0 1 11/2 ENC Employment A 0 0 1 1 0 0 1 1 1 4 0 0 0 1 11/2 ENC Employment A 0 0 1 1 0 0 1 1 0 1 0 0 0 1 1 1 4 0 0 0 1 1 1 1 | | | | | | | | | | | | | | | | | | t | | | | | | 22 | | | | | | | | | | | | | | | | | | | | | | | | ON Call primers 1 2 1 1 1 1 1 0 0 11117 SALD SOURCE 0 0 1 0 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 | CP | | | | | | | | | | | | | | | | | | | | | | | OPE Calliospatry was 1 1 1 0 1 1 0 0 11177 LTLL LLLL Classiff & Carrier 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 | CM | | | | | | | | | | | | | | | | | | | | | | | CPO Call copernly odd 1 7 1 0 0 1 0 0 11/17 El Enable (noerup)s 1 1 1 1 1 0 1 1 4 RET Return 1 1 0 0 1 0 0 1 10 0 1 10 10 10 11 4 RC Return or carry 1 1 0 7 1 0 0 0 5/11 NOP No operation 0 0 0 0 0 0 0 0 0 0 | CPE | | | | | | | î. | | | | | | | | | | | | | | | | RET Return 1 1 0 0 1 0 0 1 10 0 1 10 0 1 10 0 1 14 RC Arturn or carry 1 1 0 7 1 0 0 0 5111 NOP No operation 0 0 0 0 0 0 0 0 0 | CPO | | 1 | 1 | | ō | 0 | i | 0 | ò | 11/17 | | | | | | | | | | 1 | | | RC Return or carry 1 1 0 1 1 0 0 0 5/11 NOP No operation 0 0 0 0 0 0 0 0 | RET | | 1 | 1 | | ė | | 0 | 0 | | | | | | | | | | | | : | | | RNC Return on no carry 1 1 0 1 0 0 0 5/11 | | | | | | | | | | | | NOP | | | | | | | | | | | | | HNE | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 6 | 5/11 | | | | | | | | | | | | NOTES: 1. DDD or SSS $\sim$ 000 B $\sim$ 001 C $\sim$ 010 D $\sim$ 011 E $\sim$ 100 H $\sim$ 101 L $\sim$ 110 Memory $\sim$ 111 A, 2. Two possible cycle times, (5/11) indicate instruction cycles dependent on condition flags. Most of the instructions in which transfers of information to or from memory occur require at least seven clock cycles, or 3.5 $\mu$ s. Included in this group are the register-to-memory or memory-to-register MOV instructions; the ADD M, ADC M, SUB M, SBB M, ANA M, XRA M, ORA M, CMP M, MVI, ADI, ACI, SUI, SBI, ANI, XRI, ORI, and CPI instructions; and the STAX and LDAX instructions. The conditional and unconditional jump instructions, MVI M, INR M, DCR M, RET, IN, OUT, LXI, DAD, and POP instructions all require ten clock cycles, or 5 µs, for execution. The conditional call instructions require either eleven or seventeen clock cycles, depending upon whether or not the subroutine is called. If it is called, then seventeen clock cycles, or 8.5 $\mu s$ , are required. If not, only eleven clock cycles, or 5.5 $\mu$ s, are required to perform this type of instruction. Similar considerations apply to the conditional return instructions. If the flag is at such a logic state that a return occurs, then eleven clock cycles, or $5.5 \mu s$ , are required. If no return occurs, then only five clock cycles, or 2.5 µs, are required. It no fetum occurs, then only ave clock cycles, or 2.5 µs, are required for the conditional return instruction. If you are planning a timing loop of precise time duration, you will require this listing. You may desire to make a copy of it for your use while you are programming. Such a listing is also included in the Intel 1080 Microcomputary Sustain Manual 8080 Microcomputer System Manual. #### COUNTING CLOCK CYCLES: SOME SIMPLE MICROCOMPUTER PROGRAMS In this section, we shall consider a number of simple computer programs and learn how to count clock cycles. #### Program No. 1 | LO Memory<br>Address | Octal<br>Instruction<br>Byte | Mnemonic | Comments | |----------------------|------------------------------|----------|----------------------------------------------------------------------| | 000 | 303 | JMP | Unconditional jump to memory address<br>given in following two bytes | | 001<br>002 | 000<br>000 | | LO address byte<br>HI address byte | If you look at the Intel instruction set listing, you will observe that a JMP instruction requires ten clock cycles for execution. Since this program does not contain any IN or OUT instructions, you will have a somewhat difficult time in measuring, or employing this program a somewhat difficult time in measuring, or employing this program to generate, $5-\mu s$ monostable pulses. This program can be discarded for such a purpose. It is important to note that all three bytes of the JMP instruction are "used" in ten clock cycles. This overall time applicable to the control of th plies to all bytes in a multibyte instruction. ### Program No. 2 | LO Memory<br>Address | Octal<br>Instruction<br>Byte | Mnemonic | Clock<br>Cycles | Comments | |----------------------|------------------------------|----------|-----------------|--------------------------------------------------------------------------| | 000 | 323 | OUT | 10 | Generate device select pulse for<br>device with following device<br>code | | 001 | 000 | 000 | | Device code | | 002 | 323 | OUT | 10 | Generate second device select<br>pulse for same device | | 003 | 000 | 000 | | Device code | | 004 | 166 | HLT | 7 | Halt | This program is executed in 27 clock cycles, or 13.5 $\mu$ s. What is interesting about the program, however, is that two device select pulses are generated and sent to the same device. One pulse is used to turn the device on, and the other to turn it off. What device can be turned on and off from a single input? As one example, consider the toggled J-K flip-flop circuit shown in Fig. 5-3. The preset, clear, J, and K inputs are all left unconnected, which means they are all at a logic 1 state. Therefore, each clock pulse applied to the clock input at pin 1 of the 7476 chip will cause the flip-flop to toggle, i.e., to change state. Let us assume that the flip-flop output, Q, is initially at logic 0. The first OUT instruction in Program No. 2 generates a single device select pulse which toggles the flip-flop to logic 1. This output is used as a gating signal to the two-input 7408 and gate, and permits signals from the $\phi_2$ clock to pass through the gate to the five-decade counter, where they are counted. The second OUT instruction in Program No. 2 generates a device select pulse that causes the Q output at pin 15 to return to logic 0; this action disables the 7408 gate and stops the counting by the five-decade counter. How long will the counter count? This question can best be an How long will the counter count? This question can best be answered with the aid of information supplied in Chapter 6. We can anticipate such information by pointing out that the device select pulse is not sent to the 7476 flip-flop until the last 500 ns in the 5-µs OUT instruction. It can be shown that the flip-flop is at a logic 1 state for Fig. 5-3. A 7476 flip-flop toggled at the clock input can be used to gate clock pulses from the master clock in an 8080-based microcomputer. only ten clock cycles, or 5 $\mu s$ : 500 ns during the first OUT instruction and 4.500 $\mu s$ during the second OUT instruction. The 5- $\mu s$ time interval is quite exact: It is not 4.93 $\mu s$ or 5.05 $\mu s$ , but precisely 5.0000 $\mu s$ for a crystal-controlled 2-MHz 8080 clock input. ## Program No. 3 | LO Memory<br>Address | Octal<br>Instruction<br>Byte<br>323 | Mnemonic<br>OUT | Clock<br>Cycles<br>10 | Comments Generate device select pulse | |----------------------|-------------------------------------|-----------------|-----------------------|------------------------------------------------------------| | 000<br>001 | 000 | 000 | 10 | Device code | | 002 | * | * | * | Arithmetic, logical, or other sin-<br>gle-byte instruction | | 003 | 323 | OUT | 10 | Generate device select pulse | | 004 | 000 | 000 | | Device code | | 005 | 166 | HLT | 7 | Halt | Program No. 3 is similar to Program No. 2, except that we have inserted an instruction between the two OUT instructions. All single-byte instructions with the exception of the return instructions can be tested. For example, if the RLC instruction, which requires four clock cycles, were inserted at memory address 002s, the total counting time, as measured by the five-decade counter and the 7476 circuit shown on the preceding page, would be: counting time = $$(4 + 10) \times 500$$ ns = $7000$ ns = $7.0 \mu$ s If you would subtract 5 $\mu$ s, the time required for Program No. 2, from this value, you would measure a time of 2.0 $\mu$ s for the RLC instruction, a time that corresponds to four clock cycles, as indicated in the 8080 timing chart. ### Program No. 4 | LO Memory<br>Address<br>000 | Octal<br>Instruction<br>Byte<br>323 | Mnemonic<br>OUT | Clock<br>Cycles<br>10 | Comments Generate device select pulse that sets the 7476 flip-flop | |-----------------------------|-------------------------------------|-----------------|-----------------------|-------------------------------------------------------------------------------| | 001<br>002 | 000<br>323 | 000<br>OUT | 10 | Device code<br>Generate device select pulse that<br>clears the 7476 flip-flop | | 003 | 001<br>166 | 001<br>HLT | 7 | Different device code<br>Halt | Rather than toggle the 7476 flip-flop, you can connect two different device select signal lines to the preset and clear inputs of the flip-flop. The circuit is shown in Fig. 5-4. It should be apparent that this is an equally, or perhaps more, effective way to change the output states on a flip-flop. In this case, though the 7476 flip-flop is a single "device," Fig. 5-4. A simple 7476 flip-flop circuit and associated timing diagrams. This circuit can be used to count clock cycles in an 8080 microcomputer. two "device select pulses" are required to control it. There need not be any correlation between the number of devices present and the number of device select pulses required to service such devices. ## Program No. 5 | LO Memory<br>Address | Octal<br>Instruction<br>Byte | Mnemonic | Clock<br>Cycles | Comments | |----------------------|------------------------------|----------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 000 | 006 | MVI B | 7 | Move following data byte into B register | | 001 | * | | | Data byte | | 002 | 323 | OUT | 10 | Generate device select pulse that<br>sets the 7476 flip-flop | | 003 | 000 | 000 | | Device code | | 004 | 005 | DCR B | 5 | Decrement contents of register B by one | | 005 | 302 | JNZ | 10 | Conditional jump. If contents of<br>B register are 000, ignore this<br>instruction and go to memory<br>address 010. Otherwise, jump<br>to memory address given in fol-<br>lowing two bytes | | 006 | 004 | | | LO address byte | | 007 | 000 | | | HI address byte | | 010 | 323 | OUT | 10 | Generate device select pulse that clears the 7476 flip-flop | | 011 | 001 | 001 | | Different device code | | 012 | 166 | HLT | 7 | Halt | This interesting program contains: - A conditional jump instruction [at memory address 005] - A timing loop [at memory addresses 004 through 007] - A data byte that determines the time duration of the timing loop [at memory address 001] - Two OUT instructions that generate two different device select pulses The circuit that accompanies this program, along with a pair of timing diagrams, is shown in Fig. 5-4. The first OUT instruction sends a device select pulse to the preset input to the 7476 flip-flop at pin 2. The flip-flop output, Q, is thus set to logic 1, which opens the 7408 gate. The OUT instruction appearing at memory address 010s in the pro- gram clears the flip-flop and closes the gate. The conditional jump instruction, JNZ, at memory address 005 permits a jump only when the zero flag is at logic 0. The decrement instruction at memory address 004 will decrease the contents of the B register by one on each pass through the loop. Eventually, the B register becomes equal to 000, at which time program control moves to the instruction at memory address 010 owing to the JNZ instruction. The magnitude of the data byte at memory address 001 determines the number of loops that occur during the execution of the program. If this data byte is 001, the program will make only a single pass through the instructions at memory addresses 004 through 007. On the other hand, if the data byte is initially 000, the program will loop 256 times. This is because the data byte is decremented before being tested. Each time the program loops through addresses 004 through 007, there is a delay of fifteen clock cycles, or 7.5 µs. This time is multiplied by the number of loop passes that occur. Added to this figure is $\hat{5}$ $\mu s$ , the time associated with clearing the flip-flop via the OUT instruction at memory address 010. The asterisk (\*) at memory address 001 indicates that this data byte can vary from 000 to 377, in octal code. Some calculations will demonstrate how you can vary the time that Program No. 5 is executed. The objective here is to demonstrate, via calculations, how the microcomputer can be used to generate time delays in external digital circuitry. It generates these delays through the use of device select pulses and timing loops. Assume that the data byte at memory address 001 is equal to 001. This is the content of the B register at the end of the instruction byte at memory address 0038. At memory address 004, the contents of the B register are decremented by 1, and become equal to 000. With the aid of the conditional jump instruction that follows, program control is transferred to memory address 010, at which point a device select pulse is generated to clear the flip-flop. The total number of clock cycles between the first and second OUT instructions is: $$\begin{array}{l} \text{number of clock cycles} = [DCR] + [JNZ] + [OUT] \\ = 5 \\ = 25 \end{array}$$ At 500 ns per clock cycle, the total elapsed time is: elapsed time = $$25 \times 500 \text{ ns}$$ = $12.5 \mu \text{s}$ The five-decade counter in the circuit indicated in Fig. 5-4 counts clock pulses for this period. Now assume that the data byte at memory address 001 is **002**. The total number of clock cycles between the first and second OUT instructions is now: $$\begin{array}{l} {\rm number\ of\ clock\ cycles} = 2\ [DCR]\ + 2\ [JNZ]\ + \ [OUT]\\ = \ 10\ + \ 20\ + \ 10\\ = 40 \end{array}$$ which is equivalent to a total elapsed time of: elapsed time = $$40 \times 500 \text{ ns}$$ = $20.0 \mu \text{s}$ If the data byte at memory address 011 is 000, there are 256 passes through the timing loop. The number of clock cycles and total elapsed time between OUT instructions is: $$\begin{array}{l} {\rm number\ of\ clock\ cycles} = 256\ [DCR] + 256\ [JNZ] + [OUT] \\ = 1280\ + 2560\ + 10 \\ = 3850 \\ \\ {\rm elapsed\ time} = 3850 \times 500\ ns \\ = 1925\ \mu s \\ = 1.925\ ms \\ \end{array}$$ This elapsed time of 1.925 milliseconds refers to the time that the 7476 flip-flop output is at a logic 1 state, not to the total elapsed time of the program It should be clear that the pulse width shown in Fig. 5-4 is adjustable. The exact width is determined by the location of the first and second OUT instructions (the ones that generate device select pulses 000 and 001) in the microcomputer program. For example, the pulse width would have the following values as the magnitude of the data byte present at memory address 001 varies from 000 to 377: | Data Byte at LO<br>Memory Address<br>001 | Number of<br>Clock Cycles | Pulse Width (ms) | |------------------------------------------|---------------------------|------------------| | 000 | 3850 | 1.925 | | 001 | 25 | 0.0125 | | 002 | 40 | 0.02 | | 003 | 55 | 0.0275 | | 004 | 70 | 0.035 | | 005 | 85 | 0.0425 | | 010 | 130 | 0.065 | | 020 | 250 | 0.125 | | 050 | 610 | 0.305 | | 100 | 970 | 0.485 | | 200 | 1930 | 0.965 | | 300 | 2890 | 1.445 | | 350 | 3490 | 1.745 | | 377 | 3835 | 1.9175 | You should carefully study the discussion of Program No. 5. It provides the simplest example of a timing loop that can be written. # TIMING LOOPS The definition of a *timing loop* has been given previously in this chapter. Timing loops are widely employed in microprocessor programs in systems that control or sequence instruments and machines. Some characteristics of such loops include the following: - Timing loops of different time durations are required: microseconds, milliseconds, and seconds. - The timing loops are used frequently. Since they are used frequently, they usually appear in the microcomputer program as subroutines. We will now consider such a subroutine, one which we have loaded into PROM starting at memory location H=060 and L=000. This subroutine will generate a timing delay that is precisely equal to 0.2000 second. ### Subroutine No. 1 | | nory<br>lress<br>L<br>000 | Octal<br>Instruction<br>Byte<br>021 | Mnemonic<br>LXI D | Clock<br>Cycles<br>10 | Comments Move following two bytes into registers E and D, respectively | |--------------------------|---------------------------|-------------------------------------|----------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 060<br>060<br>060<br>060 | 001<br>002<br>003<br>004 | 301<br>150<br>035<br>302 | 301<br>150<br>DCR E<br>JNZ | 5<br>10 | Timing byte for register E Timing byte for register D Decrement register E by one If register E is 000s, ignore this instruction; otherwise, jump to memory address given in the following two bytes | | | nory<br>Iress<br>L | Octal<br>Instruction<br>Byte | Mnemonic | Clock<br>Cucles | Comments | |-----|--------------------|------------------------------|----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------| | 060 | 005 | 003 | | | LO address byte | | 060 | 006 | 060 | | | HI address byte | | 060 | 007 | 025 | DCR D | 5 | Decrement register D by one | | 060 | 010 | 302 | JNZ | 10 | If register D is 000s, ignore this instruction; otherwise, jump to memory address given in the following two bytes | | 060 | 011 | 003 | | | LO address byte | | 060 | 012 | 060 | | | HI address byte | | 060 | 013 | 015 | DCR C | 5 | Decrement register C by one | | 060 | 014 | 302 | JNZ | 10 | If register C is 000 <sub>8</sub> , ignore this instruction; otherwise, jump to memory address given in the following two bytes | | 060 | 015 | 000 | | | LO address byte | | 060 | 016 | 060 | | | HI address byte | | 060 | 017 | 311 | RET | 10 | Unconditional return from this | A flowchart for this 0.200-second subroutine is shown in Fig. 5-5. Note that the subroutine is entered with a timing byte already present in register C. As can be seen from the flowchart, there is an E register loop within a D register loop, which is within a C register loop. A program that employs this subroutine is given below. ## Program No. 6 | LO Memory<br>Address | Octal<br>Instruction<br>Byte | Mnemonic | Clock<br>Cycles | Comments | |----------------------|------------------------------|----------|-----------------|-----------------------------------------------------------------------------------------------| | 100 | 061 | LXI D | 10 | Move following two bytes into<br>the stack pointer | | 101 | 200 | 200 | | LO address byte | | 102 | 000 | 000 | | HI address byte | | 103 | 016 | MVI C | 7 | Move following byte into register<br>C | | 104 | ۰ | • | | Timing byte for register C | | 105 | 323 | OUT | 10 | Generate device select pulse that<br>sets the 7476 flip-flop | | 106 | 000 | 000 | | Device code | | 107 | 315 | CALL | 17 | Unconditional call of subroutine<br>located at memory address<br>given by following two bytes | | 110 | 000 | | | LO address byte | | 111 | 060 | | | HI address byte | | 112 | 323 | OUT | 10 | Generate device select pulse that<br>clears the 7476 flip-flop | | 113 | 001 | 001 | | Different device code | | 114 | 166 | HLT | 7 | Halt | 224 Let us assume that the timing byte for register C at memory address $H=000_8$ and $L=001_8$ is $\boldsymbol{001}.$ The steps that occur in both Program No. 6 and Subroutine No. 1 can be summarized as follows: - a. The stack pointer within the 8080 is set to HI = 000 and LO = 200. A timing byte is moved into register C. This takes a total of seventeen clock cycles. However, the five-decade counter connected to the 7476 flip-flop does not measure this time. b. A device select pulse is generated via an OUT instruction. This sets the 7476 flip-flop to logic 1 and starts the counter. Fig. 5-5. Flowchart for Subroutine No. 1, which generates a 0.200-second delay. - c. A subroutine at memory address H = 060 and L = 000 is called unconditionally. This takes seventeen clock cycles, or 8.5 $\mu$ s, a time that is measured by the counter. - d. In the subroutine, timing bytes are moved into registers D and E. This takes ten clock cycles. - e. A timing loop is established with register E. The contents of this register are decremented 193 times. A total of $193\times15=2895$ clock cycles are required. - f. The contents of the D register are decremented by one. This takes fifteen clock cycles. - g. A second timing loop is established with register E, only this time the contents of this register are decremented 256 times. This takes 3840 clock cycles. - h. The contents of the D register are decremented by one. This takes fifteen clock cycles. - i. Steps g and h are repeated 103 times. The total clock cycles required are 3840 × 103 plus 15 × 103 clock cycles. j. The contents of the C register are decremented by one. This takes - j. The contents of the C register are decremented by one. This takes five clock cycles. Since the C register is now $000_8$ , the zero flag is set to logic 1. - k. Ten cycles are consumed with the JNZ instruction at memory location $H=060\ {\rm and}\ L=014.$ - There is an unconditional return from the subroutine. This takes ten clock cycles. - m. Finally, a device select pulse is generated via an OUT instruction. This takes ten clock cycles. The 7476 flip-flop is cleared to logic 0 and the counting stops. How many clock cycles are there in all? We calculate the following: | a. | | i. | 397,065 | |----|-------|----|---------| | b. | | į. | 5 | | c. | 17 | k. | 10 | | d. | 10 | 1. | 10 | | e. | 2,895 | m. | 10 | | f. | 15 | | | The total number of clock cycles is 400,037. At 500 ns per clock cycle, this translates into a timing delay of 0.2000185 second. The timing subroutine is programmed in such a manner that, if the timing byte for register C were 002, the total number of clock cycles would be 800,037, or 0.4000185 second. Each time register C is set at one bit larger than the previous time, an additional 0.2000000 second is added to the timing delay. You will find that a subroutine that generates a 0.200-second timing delay is quite handy. The maximum time delay that you can generate is 51.2000185 seconds using only the C, D, and E registers. A sampling of typical time delays is given below. | Timing Byte for Register C | Time delay (seconds) | |----------------------------|----------------------| | 001 | 0.2000185 | | 002 | 0.4000185 | | 005 | 1.0000180 | | 012 | 2.0000185 | | 031 | 5.0000185 | | 062 | 10.0000185 | | 144 | 20.0000185 | | 279 | 50.0000185 | While the maximum time delay is somewhat over 50 seconds, longer delays may be necessary. These longer times may be obtained by nesting subroutines so that a 30-second time delay subroutine is used 120 times to provide an overall time delay of one hour. Program No. 7 shows how this is done. ## Program No. 7 | LO Memory<br>Address | Octal<br>Instruction<br>Byte | Mnemonic | Clock<br>Cycles | Comments | |----------------------|------------------------------|----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------| | 000 | 061 | LXI SP | 10 | Move following two bytes into the stack pointer | | 001 | 200 | 200 | | LO address byte | | 002 | 000 | 000 | | HI address byte | | 003 | 001 | LXI B | 10 | Move following two bytes into<br>registers C and B, respectively | | 004 | 226 | 226 | | C register byte | | 005 | 170 | 170 | | B register byte | | 006 | 315 | CALL | 17 | Unconditional call of subroutine<br>located at memory address<br>given by the following two | | 007<br>010 | 000<br>060 | | _ | bytes LO address byte HI address byte | | 011 | 005 | DCR B | .5 | Decrement register B by one | | 012 | 302 | JNZ | 10 | If register B is 000 <sub>8</sub> , ignore this instruction; otherwise, jump to the memory address given in the following two bytes | | 013 | 006 | | | LO address byte | | 014 | 000 | | _ | HI address byte | | 015 | 166 | HLT | 7 | Halt | | | | | | | Here we are using Subroutine No. 1 to generate a 30.000-second time delay. The timing byte C has a value of $226_8$ , which corresponds to decimal 150. This 30-second time delay is called 120 times, or $170_8$ in octal code, to produce a total time delay of one hour. This is done with only 30 instruction bytes located in memory. We use the principle of loop *nesting* to accomplish our desired result: ${\it nesting}{-}{\rm In}$ a computer, the inclusion of a loop or routine within a larger loop or routine. ### SEQUENCING WITH A MICROCOMPUTER In Chapter 4 and in this chapter, you have learned how to: - Generate individual device select pulses, up to a total of 512 different pulses. - Write time delay routines that create time delays ranging from 5 μs to minutes or even hours. - Toggle an external J-K flip-flop to turn on and off a digital device such as a counter. - Write program loops that will repeat a sequence of operations after a predetermined time interval. Thus, you already have the ability to create a variety of programmable sequencers, in which you sequence a series of operations at preset time intervals that are determined by the programmed time delays. Some definitions are in order: sequential operation—The carrying out of operations one after the other 4 sequencer—An electronic device that may be set to initiate a series of events and to make the events follow in sequence, i.e., in order.<sup>4</sup> programmable sequencer—A sequencer in which the order in which the events or operations occur can be changed with the aid of programming. These concepts are discussed in some detail in Chapter 5 in Bugbook I. An example of how device select pulses and time delay routines can be used to perform sequential operations is shown in Fig. 5-6. In this example, two liquid streams are added to a large tank, the resulting solution is heated and stirred to allow a reaction to occur, and finally the tank contents are drained. Eight different devices are present; a power switch, three valves, three motors, and a heater. Two device select pulses are employed per device: one to turn it on and the other to turn it off. A variety of time delays are required, varying from 0.01 hour, or 36 seconds, to 65.4 minutes, and all can be readily programmed in the microcomputer. The 36-second time delay is used at least seven times. The important point about this system is that the sequence of operations, and the time intervals between them, can be readily changed simply by altering the microcomputer program. Again, this is an example of software replacing hardware. No counters or special logic circuits Fig. 5-6. A sequence of operations associated with a batch reactor, a piece of equipment used by chemical engineers to perform chemical reactions. Fig. 5-7. This circuit demonstrates (a) the use of 8-input 7430 NAND gates to decode the 8-bit device code from the microcomputer, and (b) the use of an optically isolated solid-state relay to drive a fan motor from a TTL input signal. are required to sequence the operations. The microcomputer can do the whole thing with the aid of device select pulses, eight flip-flops, eight TTL buffers, and eight optoelectronic relays that control ac power with logic 0 and logic 1 signals from a TTL circuit. The extension of Fig. 5-8. Typical optically isolated solid-state relays that are available for a price of \$10 to \$20 in quantities of one. Such relays can control up to 10 A of 115 V ac power from a single TIL output. The relay at the lower right (AC IN) converts ac power to a dc signal, thus permitting you to detect when a fan motor or other power-consuming device is in the "om" state. The small chip is not a semiconductor device, but rather a reed relay that can operate from +5 volts TIL. The Aristan time capsule is a solid-state time delay device. these ideas to traffic lights, building protection, machine operation, and a variety of other situations that require sequential operations should be clear. # CONTROLLING POWER WITH A MICROCOMPUTER Fig. 5-7 shows a circuit in which a 7476 flip-flop controls ac power to a fan motor. This is done with the aid of an optically isolated solid-state relay (Fig. 5-8), a type of relay that has become very popular within the last several years. A simple TTL input to this relay can easily control 10 amperes at 115 volts ac. Although we shall not discuss such relays in this book, it should be clear that a microcomputer can readily control the fan. The LO memory address is connected to each of the two 7430 eight-input NAND gates, which decode the 8-bit device code produced by the OUT instruction. The unique logic 0 state produced by the 7430 gate is then oned with the OUT pulse. ### TEST This test probes your understanding of the concepts and experiments in this chapter. Please write your answers on a separate piece of paper. - 5-1. Define the following terms: loop, timing loop, period, clock cycle, and state. - 5-2. Draw a simple digital circuit that can count clock cycles. - 5-3. Write a microcomputer program that will generate timing delays that are multiples of approximately 100 microseconds. Your performance on this test will be acceptable if you can answer all of the above questions correctly in a one-hour closed-book examination. You will frequently encounter timing loops in microcomputer programs. ## WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? It was stated at the beginning of this chapter that at the end you would be able to do the following: - Define the terms: loop, timing loop, period, clock cycle, and state. This was done at various places in the chapter. - $\bullet$ Program a timing loop that can generate timing delays that are multiples of 0.200 second. - You did this in Subroutine No. 1. Program a timing loop that can generate timing delays that are multiples of approximately 0.5 millisecond. You did this in Program No. 6. • Demonstrate how a microcomputer can act as a monostable multivibrator. You actually generated single timing pulses with the aid of the micro-computer program and the 7476 flip-flop. ## **CHAPTER 6** # Generating Status Information It becomes ever more clear that one of the important functions of the 8080 microprocessor chip is to control the transfer of eight bits of digital information, called a byte, between the internal data bus, located within the 8080 chip itself, and the external data bus, located external to the chip. Internally, information can be stored in registers such as the accumulator, the general-purpose registers, the program counter, stack pointer, and instruction register. Externally, information is stored in memory, the status latch, and input/output devices. In this chapter, you will learn quite a bit more concerning how all this is done. You will gain a general understanding of how the microprocessor operates and interacts with the "outside world" external to the chip. This is a somewhat advanced chapter, one that you can skip for the moment if your time is limited. If you wish, you may read Chapters 7 and 8 first, for they will round out your interfacing skills. Then return to this chapter; you will not miss needed information by skipping it. ### **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Explain the differences between the internal and external busses in an 8080-based microcomputer system. - List the sources and destinations of information that appears on the external data bus. - Explain the differences between a state, clock cycle, instruction cycle, and machine cycle. • Explain what a status bit and a status byte are. • Describe the nine different types of machine cycles. • Describe the function of each of the eight different status bits. Explain how the control outputs on the 8080 chip can be combined logically with one or more of the status bits, and provide at least one example of such a logical combination. Draw timing diagrams that depict the behavior of typical microcomputer instructions. Such diagrams should clearly demonstrate the logic states of the more important control inputs, control outputs, and status bits. Explain the different types of data that can appear on the external data bus. Explain state timing for typical machine cycles. Explain how single stepping of an 8080 microcomputer occurs, complete with timing diagrams and circuit diagrams. Discuss the characteristics of the 8212 eight-bit input/output port integrated-circuit chip. #### **DEFINITIONS** bus—A path over which digital information is transferred, from any of several sources to any of several destinations. Only one transfer of information can take place at any one time. While such transfer is taking place, all other sources that are tied to the bus must be disabled. to bus—To interconnect several digital devices that either receive or transmit digital signals by a common set of conducting paths, called a bus, over which all information between such devices is transferred. control input—An input pin on the 8080 chip that controls the behavior of the microprocessor. control output—An output pin on the 8080 chip that controls the behavior of external chips and devices connected to the 8080 chip. data bus buffer/latch—An 8-bit latch with three-state buffer outputs that controls the transfer of information between the internal data bus within the 8080 microprocessor chip and the external data bus. execution—One of the two functional parts of an instruction cycle. external bus—The 8-bit bidirectional data bus located external to the 8080 microprocessor chip and to which is connected memory, output latches and output devices, and input buffers from input devices. fetch—One of the two functional parts of an instruction cycle. The collective actions of acquiring a memory address and then an instruction or data byte from memory. instruction cycle—A successive group of machine cycles, as few as one or as many as five, which together perform a single microprocessor instruction within the microprocessor chip. internal bus—A bidirectional data bus located within the 8080 microprocessor chip and to which is connected the accumulator, instruction register, general-purpose register, a temporary register, and the arithmetic/logic unit. machine cycle—A subdivision of an instruction cycle during which time a related group of actions occur within the microprocessor chip. In the 8080 microprocessor, there exist nine different machine cycles. All instructions are combinations of one or more of these machine cycles. nonoverlapping two-phase clock—A two-phase clock in which the clock pulses of the individual phases do not overlap. state-A constant interval equal in length to the period of the clock oscillator that drives the central processing unit. status bit—A single bit of output information that is placed on the external data bus early during the execution of a machine cycle and is latched by an integrated-circuit chip called a status latch. Since this bit is acquired early by the latch, it can be used to control external events that occur later in the machine cycle. status byte-An 8-bit byte, i.e., a unit of 8 bits, that contains eight different status bits. status latch—An integrated-circuit chip, such as, for example, the Intel 8212, that latches the eight status bits when they appear on the external data has three-state device—A semiconductor logic device in which there exist three possible output states: (1) a "logic 0" state, (2) a "logic 1" state, or (3) a state in which the output is, in effect, disconnected from the rest of the circuit and has no influence upon it. two-phase clock—A two-output timing device that provides two continuous series of timing pulses that are synchronized together, with a single clock pulse from the second series always following a single clock pulse from the first series. Depending on the type of two-phase clock, the pulses in the first and second series may or may not overlap each other. ## THE BIDIRECTIONAL DATA BUS The 8-bit bidirectional data bus is the main data communications link between the accumulator in the 8080 microprocessor chip and memory, input devices, output devices, and the status latch. By bidirectional it is meant that data can flow in both directions on the bus, from the chip to a device, and from a device into the chip. The bus is three-state. A schematic diagram of data flow on the bus is shown in Fig. 6-1. In the discussion of bus in Chapter 7 of Bugbook II, the following definitions were provided: Fig. 6-1. The data bus buffer/latch within the 8080 chip serves as an internal interface between the internal data bus and the external bidirectional data bus. bus—A path over which digital information is transferred, from any of several sources to any of several destinations. Only one transfer of information can take place at any one time. While such transfer is taking place, all other sources that are tied to the bus must be disabled. to bus—To interconnect several digital devices which either receive or transmit digital signals by a common set of conducting paths, called a bus, over which all information between such devices is transferred. three-state device—A semiconductor logic device in which there are three possible output states: (1) a "logic 0" state, (2) a "logic 1" state, or (3) a state in which the output is, in effect, disconnected from the rest of the circuit and has no influence upon it. In the preceding definition for a bus, the important point is that only one transfer of information can take place at any one time. Since a bus is a shared group of conducting paths, chaos would result if all the transmitters on the bus attempted to send information simultaneously. The basic purpose of a bus is to minimize the number of interconnections required to transfer information between digital devices. The fewer the interconnections, the easier it is to lay out printed-circuit boards. Even within the integrated-circuit chip itself, internal busses are employed to facilitate chip fabrication. The 8080 microprocessor chip has an internal bus and communicates with external devices over an external bus present on printed-circuit boards. In Fig. 6-1 is given a functional block diagram of the external 8-bit bidirectional data bus. On the following page is provided a functional block diagram of the 8080 chip itself. Note the data bus buffer/latch at the top middle part of the diagram. This portion of the 8080 chip is the buffer between the internal and external data busses. When the latch is enabled, data can pass in either direction between the two data busses. On the 8-bit bidirectional data bus (the external bus), there are three transmitters: - memory, - any input device, and the data bus buffer/latch within the 8080 chip; - and four receivers: - memory, - any output device, - the status latch, and the data bus buffer/latch within the 8080 chip. Information that appears on the external bus can be one of the - A data byte that is being transferred from memory, through the data bus buffer/latch, into the accumulator (or one of the six general-purpose registers); - An instruction byte that is being transferred from memory, through the data bus buffer/latch, into the instruction register; • A data byte from an input device that is being transferred through - A data byte from the accumulator; A data byte from the accumulator that is being transferred through the data bus buffer/latch to an output device; - A status byte that is being transferred through the data bus buffer/latch to the status latch; and - An instruction byte from an input device that is being transferred, during an interrupt condition, through the data bus buffer/latch into the instruction register; and perhaps others as well. Clearly, the microprocessor has a considerable timing problem: It must coordinate the transfer of information between all transmitters and all receivers on the external 8-bit bidirectional data bus. It has the same problem on the internal bus as well. How does the microprocessor do all this? This is what we shall discuss in this chapter. This discussion will give you a "feeling" for what happens within a microprocessor chip without bogging you down in the many subtle details of microprocessor operation. For further details, see the Intel Corporation literature, specifically their 8080 Microcomputer System Manual and the Intellec 8/Mod 80 Microcomputer Development System Reference Manual, both of which provide useful information and timing diagrams on what occurs during the different microcomputer machine cycles.8.9 Some of the material provided below is from these two manuals, courtesy of the Intel Corporation. ### INSTRUCTION CYCLES To quote the Intellec 8/Mod 80 Microcomputer Development System Reference Manual: "The 8080 is driven by a two-phase clock oscillator, at a maximum frequency of 2.08 MHz. All processing activities are referred to the period of this clock. The two nonoverlapping clock phases, labeled $\phi_1$ and $\phi_2$ , are furnished by external circuitry. The $\phi_1$ clock divides the processing cycle into states. A state is the smallest unit of processing activity (480 ns when the processor is operating at maximum speed) and is defined as the interval between two successive positive-going transitions of the $\phi_1$ clock. Timing logic within the 8080 uses the clock inputs to produce a SYNC pulse, which identifies the first state of every machine cycle. . . machine cycle. . . . . As shown in Fig. 6-2, the SYNC signal is related to the leading edge of the $\phi_2$ clock. There is a delay between the low-to-high transition of $\phi_2$ and the positive-going edge of the SYNC pulse. There also is a corresponding delay between the next $\phi_2$ pulse and the falling edge of the SYNC signal. Status information is displayed on D0 through D7 during this same interval. Switching of the status signals (occurs only when $\phi_2$ is at logic 1) . . . " "An instruction cycle consists of two functional parts, the fetch and the execution. Each of these functional parts, in turn, consists of a number of machine cycles. During the fetch, a selected instruction Fig. 6-2. Clocks $\phi_1$ and $\phi_2$ and SYNC timing. SYNC does not occur in the second and third machine cycles of a DAD instruction. (one, two, or three bytes) is extracted from memory and deposited in the CPU's instruction register. During the execution part, the instruction is decoded and translated into specific processing activities. The fetch routine requires one machine cycle for each byte to be fetched. The duration of the execution portion of the instruction cycle depends upon the kind of instruction that has been fetched. Some instructions do not require any machine cycles other than those necessary to fetch the instruction; other instructions, however, require additional machine cycles to write or read data to/from memory or I/O devices. The DAD instruction is an exception in that it requires two additional machine cycles to complete an internal register-pair add. "Every instruction cycle contains one, two, three, four, or five machine cycles. Each machine cycle, in turn, consists of three, four, or five states. A state is defined as a constant interval, equal in length to the period of the clock oscillator which drives the CPU (a phase). That is, a state is so defined in all but three cases. Exceptions to the rule are the WAIT state, the hold (HLDA) state, and the halt (HLTA) state, ... A moment's consideration will show that this is reasonable, since the WAIT, the HLDA, and the HLTA states depend on external events and are, by their nature, of indeterminate length. Observe, however, that even these exceptional states must be synchronized with the pulses of the driving clock. Thus the durations of all states, including these, are integral multiples of the clock phase. "To summarize then, each clock *phase* marks a *state*; three to five states constitute a *machine cycle*; and one to five machine cycles comprise an *instruction cycle*. A full instruction cycle requires anywhere from four to eighteen phases for its completion (2.0 microseconds to 9.0 microseconds), depending on the kind of instruction involved." The preceding paragraphs are well written and need little elaboration. The important point is that a microprocessor is a clocked digital electronic device. Clock pulses are required to synchronize and cause specific operations to occur. A sufficient number of operations within the microprocessor must occur for each instruction that it is not possible to do all with a single clock train. Thus, a two-phase clock with nonoverlapping pulses $\phi_1$ and $\phi_2$ is required. For the simplest instruction cycles, eight individual clock pulses are available to coordinate the actions within the microprocessor. For simple instructions, this is all that is required. However, for more complicated instructions, additional clock pulses are required to coordinate the microprocessor actions. The most complicated instruction in the 8080 instruction set is the XTHL instruction, which requires eighteen states, or 36 individual clock pulses, for its completion. Treat the 8080 microprocessor as a digital circuit that you could, if you so desired, wire on breadboarding sockets. It wouldn't be practical for you to do so, because of the many wire connections which might be required. Nevertheless, you shouldn't view the internal workings of the 8080 chip as a mystery. What is inside is simply a clocked digital circuit that is run via a pair of synchronized clock trains called a two-phase clock. Much of the internal circuitry within the 8080 chip is bus oriented, so fewer wire connections are required than you would ordinarily expect. Fig. 6-3 is a schematic diagram of a group of three microcomputer instructions, SUB A, OUT <B2>, and CALL <B2> <B3>, which respectively require four, ten, and 17 states (or clock cycles). This diagram will be discussed in greater detail in the following section. ### MACHINE CYCLES In Fig. 6-3 is a group of three microcomputer instructions each of which requires its own instruction cycle. The SUB A instruction has one machine cycle and a total of four states. The two-byte OUT <B2> instruction requires three machine cycles and a total of ten states. Finally, the three-byte CALL <B2> <B3> instruction requires five machine cycles and a total of seventeen states. The different machine cycles within each instruction are labeled $M_1,\,M_2,\,\ldots$ , and $M_5$ . Five machine cycles is the maximum number required for any of the three Fig. 6-3. State, machine cycle, and instruction cycle timing. There are three microcomputer instructions shown: SUB A, OUT <82>, and CALL <82> <83>, which are, respectively, single-byte, two-byte, and three-byte instructions requiring four, ten, and seventeen clock cycles. instructions shown in the figure. In this section, we shall discuss the individual machine cycles within the overall instruction cycle. There are nine types of machine cycles that may occur within an instruction cycle, although not more than five machine cycles will appear in any given instruction cycle. These types of machine cycles include the following: - Fetch-This machine cycle consists of either four or five states, with the exception of the WAIT, HLDA, and HLTA states, which contain any integral number of states greater than three. During this cycle, the memory address is acquired, status bits are made available on the 8-bit external data bus, register transfers occur within the 8090 chip, and simple arithmetic or logical operations are performed. With some microcomputer instructions, this is the only machine cycle required. Any microcomputer instruction that requires only four or five states requires only the fetch machine cycle. This machine cycle acquires its name from the fact that, during the cycle, the operation code for the instruction is "fetched" from the memory location present in the program counter. This operation code is transferred to the instruction register within the 8080 chip, where it is subsequently decoded by the instruction decoder into a series of actions that the microprocessor performs. During this cycle, the program counter is incremented by one, thus giving the location of the next instruction byte. - Memory read—This machine cycle consists of three states. During this cycle, a byte present in the memory location indicated by the program counter is transferred from memory to one of the registers within the 8080 chip. Such registers include the accumulator, B, C, D, E, H, and L. - Memory write—This machine cycle consists of either three or four states, during which the contents of a register are transferred to the memory location pointed to by the H and L registers. The H and L pointer registers may also be incremented or decremented during this machine cycle. - Output—This machine cycle consists of three states, during which the output device code is made available on the 16-bit memory address bus and the contents of the accumulator are made available on the 8-bit external bidirectional data bus. - Input—This machine cycle also consists of three states, during which the input device code is made available on the 16-bit memory address bus and the data bus buffer/latch within the 8080 microprocessor is enabled to allow input data appearing on the external bus to be transferred to the accumulator. - Stack write—During this three-state machine cycle, an 8-bit data byte is placed upon the external data bus and transferred to the memory location given by either M(SP-1) or M(SP-2), where SP is the stack pointer register within the 8080 microprocessor. • Stack read—During this three-state machine cycle, an 8-bit data byte is transferred from the memory location given by either M(SP) or M(SP+1) via the external data bus to the microprocessor registers, such as H, L, B, C, D, E, or the program counter. Halt—This machine cycle can contain any integral number of states greater than three. The microprocessor remains in a WAIT state for as long as the READY input to the 8080 chip is at logic 0. The WAIT output from the 8080 chip is at logic 1 to acknowledge that the CPU is in a WAIT state. Interrupt—This five-state machine cycle resembles the fetch machine cycle, except that the program counter, which has already been incremented in the fetch cycle, is not incremented. This allows the preinterrupt status of the counter to be saved in the stack and permits an orderly return to the interrupted program after the interrupt request has been processed. The following machine cycles occur for the instructions present in Fig. 6-3. Fetch: $M_1$ in SUB A, OUT <B2>, and CALL <B2> <B3> Memory read: $M_2$ in OUT <B2> and both $M_2$ and $M_3$ in CALL <B2> <B3> Output: M<sub>3</sub> in OUT <B2> Stack Write: Both M<sub>4</sub> and M<sub>5</sub> in CALL <B2> <B3> You might wonder why two similar machine cycles are required during the same instruction cycle, as occurs in the CALL instruction. The answer is that information is being transferred to or from different registers within the 8080 chip during the memory read and stack write machine cycles; consequently, two different cycles are required in each case. It is not hard to imagine that the microprocessors of the future, which will all be much faster than the 8080, will require more machine cycles than five to perform still more complicated instructions such as multiply or divide. Additional information on machine cycles can be found in References 8 and 9. Both sources were used in writing this section. ### MACHINE CYCLE IDENTIFICATION A question that bothers many people when they first learn about the 8080 microprocessor is: How can one determine which machine cycles comprise a microcomputer instruction? The Intel literature describes typical machine cycles for instructions such as INP, OUT, ADD, CALL, HALT, and others, but such descriptions are far from being a complete inventory of the entire 78-instruction set. We may believe that we can decipher most of the instructions given sufficient time and patience, but is there any way to do this while the microcomputer is in operation? The answer to the preceding question is that it is indeed possible to determine which machine cycles comprise a microcomputer instruction; it can be done while the microcomputer is in operation. The details will be provided in the subsections that follow. Much of the information is contained in References 8 and 9. # Latching the Status Bits How does the microcomputer identify the machine cycle in progress? It does so by transmitting an 8-bit status signal during the first state, It does so by transmitting an 8-bit status signal during the first state, $T_1$ , of every machine cycle. These status signals appear on the external 8-bit bidirectional data bus, and are latched by the 8212 status latch circuit shown in Fig. 6-4. There are eight status bits, and we shall discuss them shortly. The important point is that the status bits are the first information applied to the external data bus during a new instruction cycle. Thus, the status bits precede an instruction or data byte from memory or an input or cuttout data but on the external data bus from memory or an input or output data byte on the external data bus. Such information comes after the status bits, not before it. How are the status bits latched? This is shown in both Fig. 6-4 and 6-5. Observe in Fig. 6-4 that the SYNC output from the 8080 chip is connected to the DS<sub>2</sub> input on the 8212 chip. When DS<sub>2</sub> is at logic 1 Courtesy Intel Corp. latching the eight status bits that appear on the external data bus during the $T_1$ and $T_2$ states. 6-4. Diagram of circuit for late Fig. 6-5. Timing diagram that illustrates how the status bits on the 8-bit external data bus are latched by the 8212 chip. and $\overline{DS}_1$ is at logic 0, the status information available on the external data bus is latched and appears at the 8212 output pins 4, 6, 8, 10, 15, 17, 19, and 21. The input to pin 1 on the 8212 chip is $\phi_1$ ; when this input goes to logic 0 with SYNC at logic 1, the latching action occurs (Fig. 6-5). The $\overline{DS}_1$ · $DS_2$ pulse has a pulse width of 500 ns. A typical 8080 microcomputer has such a latch, as shown in Fig. 6-6. ### The Eight Status Bits The eight status bits that appear on the external data bus during the $T_1$ and $T_2$ states of a machine cycle have the following symbols and definitions: | Sumbol | Data<br>Bus Bit | Description | |--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | - · · · · · · · · · · · · · · · · · · · | | INTA | D0 | Acknowledge signal for INTERRUPT request, at which time it is a logic 1. This signal should be used to gate a restart instruction, RST, onto the data bus when DBIN (pin 17 on the 8080 chip) is at logic 1. | | wo | D1 | If the operation in the current machine cycle is a WRITE memory or OUTPUT function, this status bit will be at logic 0. If the operation is a READ memory or INPUT, this status bit will be at logic 1. | | STACK | D2 | A logic 1 indicates that the 16-bit memory address bus holds the stack address from the stack pointer, SP. | | HLTA | <b>D</b> 3 | Acknowledge signal for a HALT instruction. When the machine cycle is a HALT instruction, this status bit will be at logic 1. | |-------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OUT | D4 | A logic 1 for this status bit indicates that the 16-bit memory<br>address bus contains the 8-bit device code of the output de-<br>vice and that the external data bus will contain the output | | | | data when WR (pin 18 on the 8080 chip) is at logic 0. | | $M_1$ | D5 | This status bit provides a logic 1 signal to indicate that the CPU is in the fetch cycle for the first byte of an instruction. | | INP | D6 | A logic 1 for this status bit indicates that the 16-bit memory address bus contains the 8-bit device code of the input device and that the input data should be placed on the external data | | | | bus when DBIN (pin 17 on the 8080 chip) is at logic 1. | | MEMR | D7 | A logic 1 indicates that the external data bus will have data coming from memory during this machine cycle. | To quote from Reference 8: "The machine cycles that actually do occur in a particular instruction cycle depend upon the kind of instruction, with the overriding stipulation that the first machine cycle in any instruction cycle is always a "TEICH. "The processor identifies the machine cycle in progress by transmitting an 8-bit status signal during the first state of every machine cycle. Updated status information appears on the 8080's data lines (D0 through D7) during the SYNC interval. This data may be saved in latches, decoded, and used to develop control signals for external circuitry. Table 6-1 shows how the status information is distributed on the micronrecessor's data bus microprocessor's data bus. Courtesy Tychon, Inc. Fig. 6-6. The location of the 8-bit status latch on the CPIC-80/B printed-circuit board. This board is part of an 8080 microcomputer system manufactured by E&L Instruments, Inc. "Status signals are provided principally for the control of external circuitry. Simplicity of interface, rather than machine identification, dictates the logical definition of individual status bits. You will therefore observe that certain processor machine cycles are uniquely identified by a single status bit, but that others are not. The M<sub>1</sub> status bit, D5, for example, unambiguously identifies a FETCH machine cycle. A STACK READ, on the other hand, is indicated by the coincidence of STACK and MEMR signals. Machine cycle identification data can also be valuable in the test and debugging phases of system development." As indicated in the preceding quote, to identify a specific machine cycle, we employ the truth table shown as Table 6-1. ## 8080 Control Inputs and Outputs In Chapter 1 we discussed the control inputs and outputs to and from the 8080 microprocessor chip. The control inputs include (Fig. 6-7): ``` RESET (pin 12) INT (pin 14) READY (pin 23) HOLD (pin 13) and the control outputs are: WAIT (pin 24) WR (pin 18) HLDA (pin 21) INTE (pin 16) SYNC (pin 19) DBIN (pin 17) ``` The above control inputs and outputs can be combined logically with the eight status outputs: ``` INTA WO STACK HLTA OUT M1 INP MEMR ``` latched by the 8212 buffer/latch chip to coordinate and control data transfer into and out of the microprocessor. This is a very important point. You are not limited to the four control input pins and six control output pins on the 8080 chip (Fig. 6-7); the latched status bits can be used as well. The IN and OUT strobe outputs are not located on the Table 6-1. Truth Table Relating Type of Machine Cycle to Individual Status Bits in 8-Bit Status Word Appearing on the External Data Bus During State T, | | Data Bus Bit and Status Information | | | | | | | | |--------------------------|-------------------------------------|-----------|----------------------|-----------|------------|-------------|----------|------------| | Type of<br>Machine Cycle | MEMR<br>D7 | INP<br>D6 | M <sub>1</sub><br>D5 | OUT<br>D4 | HLTA<br>D3 | STACK<br>D2 | WO<br>D1 | INTA<br>DO | | Instruction Fetch | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | Memory Read | l i | ō | 0 | 0 | 0 | 0 | 1 | 0 | | Memory Write | ò | ō | 0 | 0 | 0 | 0 | 0 | 0 | | Stack Read | i | ō | 0 | 0 | 0 | 1 | 1 | 0 | | Stack Write | 0 | ō | 0 | 0 | 0 | 1 | 0 | 0 | | Input | 0 | i | 0 | 0 | 0 | 0 | 1 | 0 | | Output | 0 | Ó | Ó | 1 | 0 | 0 | 0 | 0 | | Interrupt | 0 | ō | i | 0 | 0 | 0 | 1 | 1 | | Halt | l i | 0 | 0 | 0 | 1 | 0 | 1 | 0 | | Interrupt While Halt | ò | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 8080 chip; you derive them from the status bits after they are latched. The latching of status bits is a very clever piece of digital electronic design, one that maximizes the use of the data bus and eliminates the need for extra output pins on the microprocessor chip. Although it may appear that the price you pay for this capability is one state per machine cycle to latch the status bits, keep in mind that during the same Fig. 6-7. Block diagram of the 8080 microprocessor chip showing the control inputs and outputs as well as the memory address bus and the 8-bit bidirectional data bus (the external data bus). Fig. 6-8. Timing diagrams for signals present on the data bus, address bus, and control bus. Note changes in the status bit outputs. state the 16-bit memory address is being loaded into the program counter. $\,$ ## Timing Diagrams for Typical 8080 Instructions We shall now discuss the preceding points with the aid of Fig. 6-8, which shows timing diagrams for the following digital signals: $\bullet$ the 8080 two-phase clock and several control inputs and outputs (Fig. 6-9), Fig. 6-9. The two-phase clock inputs and several control input and output signals found on the 8080 microprocessor chip. - the latched status bits (Fig. 6-10), - the different types of data that appear on the external data bus - the memory address and I/O device code information that appears on the memory address bus (Fig. 6-12). The letters PC and SP stand for program counter and stack pointer, respectively, which are 16-bit registers within the 8080 microprocessor chip. By "PC -1" is meant that the information on the 16-bit external address bus is one less than the contents of the program counter. The program counter contains the address of the next instruction to be executed, not the address of the current instruction being executed. The three instructions that will be discussed include: SUB A, a single-byte instruction that clears the accumulator; OUT <B2>, a two-byte instruction that provides an OUT strobe pulse that allows an external device to latch the contents of the accumulator, which appears Fig. 6-10. The eight latched status bits. for a fleeting instant on the external data bus; and CALL <B2> <B3>, a three-byte instruction that unconditionally calls a subroutine at the memory address given by bytes B2 and B3. A simple program that incorporates these instructions in sequence is as follows: | LO Memory<br>Address | Octal<br>Instruction | Comments | |----------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------| | 000 | 227 | Subtract contents of accumulator from accumulator, i.e., clear the accumulator | | 001 | 323 | Generate a device select pulse to output eight bits of<br>accumulator data to the device with the device code<br>given in the following byte | | 002 | 000 | Device code for output device | | 003 | 315 | Unconditional call of subroutine located at memory lo-<br>cation given in the following two bytes | | 004 | 040 | LO memory address byte | | 005 | 000 | HI memory address byte | | 006 | 166 | Halt | | 040 | 311 | Unconditional return to main program from this sub-<br>routine | We should note that the stack pointer, SP, has been previously located at LO = $200_8$ and HI = $000_8$ and that the preceding program can be run repeatedly simply by resetting the program counter to HI = $000_8$ and LO = $000_8$ with the aid of the manual RESET control switch on the front panel of an 8080 microcomputer. The execution of this program can be summarized as follows: | | | | Status Bits | | | | | | | | |--------|--------------------------------|--------------------------------------------------------------------------------------------------------------|-------------|----------------|--------------|--------------|----------------|-------------|---------------|--------------| | LO Men | Bus Data Bu | 8 | MEMR | INP | M | OUT | HLTA | STACK | WO | INTA | | 377 | 377 | Mnemonic | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | | NOTE: | bits are latched use the RESET | the microcomputer is<br>in the states shown.<br>control switch to res<br>The reason that we<br>parent below. | To<br>et th | start<br>e pro | the<br>ogran | com<br>1 coi | outer<br>inter | pro<br>to I | gram,<br>II = | , we<br>000s | | 000 | 227 | SUB A | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 001 | 323 | OUT | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 002 | 000 | <b2></b2> | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 000* | | Data output on bus | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | 003 | 315 | CALL | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 004 | 200 | <b2></b2> | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 005 | 000 | <b3></b3> | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 177 | 000 | Stack write | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 176 | 006 | Stack write | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | 040 | 311 | RET | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 177 | 006 | Stack read | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | 176 | 000 | Stack read | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | 006 | 166 | HLT | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | | 377 | 377 | | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Fig. 6-11. Representation of the types of data that appear on the external bidirectional data bus. Observe that no two different types of data are present on the data bus simultaneously. After execution of the above program, the microcomputer is in the HALT state. The asterisked (\*) instruction shows the data output machine cycle. The device code for the output device selected at $LO=002_8$ is $000_8$ . Fig. 6-8 provides the timing diagrams for the first nine machine cycles in the above program listing. The entire program requires thirteen machine cycles; no further execution occurs in the HALT state at the end of the program. If you study the figure well, you will develop a good understanding of most of the important concepts of microprocessor operation. Focus upon the following: • The time before the first machine cycle, M<sub>1</sub>, in the SUB A instruction Here we assume that the microcomputer is in the HALT state, in which the eight status bits are latched in the 8212 chip in the following states: INTA = STACK = OUT = $M_1$ = INP = logic 0 and $\overline{WO}$ = HLTA = MEMR = logic 1. • The unique time when the OUT status bit is latched by the 8212 chip to a logic 1 state. Note that at no other time is the OUT status bit at a logic 1. This condition allows you to uniquely determine two important conditions that occur simultaneously: (1) the I/O device code is present as two identical 8-bit bytes on the 16-bit memory address bus, and (2) the contents of the accumulator are present on the 8-bit external bidirectional data bus. These conditions occur only when the OUT status bit is latched at logic 1. Clearly, the OUT status bit can be used to generate Fig. 6-12. Representation of the types of data that appear on the 16-bit address bus. $$\overline{WR}$$ $\overline{OUT}$ $\equiv$ $\overline{WR}$ $\overline{OUT}$ Fig. 6-13. Logic circuitry for the generation of the OUT control signal. device select pulses that can strobe data from the accumulator to a specified output device. In Fig. 6-8 a vertical arrow is drawn near the bottom of the figure to denote the time at which output data from the accumulator can be latched by an external device. An 8080 microcomputer will generate a 500-ns OUT pulse during the time that the OUT status bit is at logic 1. The logic circuitry employed to do this is shown in Fig. 6-13, i.e., a simple two-input NAND gate that is enabled only when WR and OUT are both at logic 1. The 500ns pulse width is a consequence of the WR input, which remains at logic 0 for only 500 ns, as can be seen in Fig. 6-7. Although the input instruction is not shown, it functions in a manner similar to the output instruction. The INP status bit is latched by the 8212, and a device select pulse is generated while it is latched with the aid of the logic circuit shown in Fig. 6-14. The negative clock pulse, IN, is generated for 500 ns when both DBIN and INP are at logic 1. The status bit M₁ is at a logic 1 state only during the first machine - cycle of an instruction. - The status bit WO is at logic 0 when data is being written into memory or an output device. This status bit is at logic 1 while an instruction byte is being read from memory. During a multibyte Fig. 6-14. Logic circuitry for the generation of the $\overline{\mbox{IN}}$ control signal. instruction, $\overline{\text{WO}}$ remains latched at logic 1 until the full multibyte instruction has been read from memory. - The SYNC output at pin 19 of the 8080 chip is at logic 1 at the same time that the eight status bits are present on the external data bus - The HLTA status bit is latched at logic 1 only when the microcomputer is in the halt state. - The WR output at pin 18 of the 8080 chip is at logic 0 only when data is being written into memory or an output device. When WR is at logic 0, the status bit MEMR must be at a logic 0 state (since no data is being read from memory). - A logic 1 at the MEMR status bit indicates that the external data bus will have data coming from memory during this machine cycle. - The DBIN output at pin 17 on the 8080 chip is at logic 1 only when data from memory or an input device is present on the external data bus. This is the signal that indicates that data is coming from memory into the 8080 chip. - The STACK status bit is usually latched at logic 0. It is latched at logic 1 only when the 16-bit address bus contains the address of a memory location on the stack. - At least four types of 8-bit bytes can appear on the external data bus: the eight status bits, an 8-bit data or instruction byte from memory, eight bits of data from the accumulator, or an 8-bit address byte that is being transferred from memory to the program counter. Only one 8-bit byte appears on the external data bus at a time. There are no circumstances under which two different 8-bit bytes are simultaneously present on the external data bus. - The program counter always contains the 16-bit memory address of the next instruction byte to be executed. The memory address of the existing instruction byte is therefore always one less than the current value of the program counter. - The device code appears on the memory address bus as two identical 8-bit bytes, one occupying the LO address byte and the other occupying the HI address byte. - The number of executed instructions in a program can be counted simply by applying the DBIN output at pin 17 on the 8080 chip and the latched M<sub>1</sub> status bit to a two-input 7408 AND gate. Each pulse from the gate output corresponds to a single instruction. A schematic diagram that shows a status latch connected to an 8080 microprocessor chip is shown in Fig. 6-15. Some status signals are not often used. Among the most important signals derived from the status latch and the 8080 control signals are $\overline{\text{MEMR}}$ , $\overline{\text{MEMW}}$ , $\overline{\text{INTA}}$ , $\overline{\text{I/O R}}$ , and $\overline{\text{I/O W}}$ . In this book, we have used the letters $\overline{\text{IN for I/O R}}$ and $\overline{\text{OUT}}$ for $\overline{\text{I/O W}}$ . The $\overline{\text{MEMR}}$ and $\overline{\text{MEMW}}$ control signals indicate a Fig. 6-15. Diagram of a typical 8080 control circuit that employs an 8212 chip. 1/O R in the diagram is equivalent to IN, and 1/O W is equivalent to OUT. memory read or memory write operation. The $\overline{\text{IN}}$ , $\overline{\text{OUT}}$ , and $\overline{\text{INTA}}$ control signals have been mentioned previously. The 8216 and 8212 chips in Fig. 6-15 have been eliminated through the introduction by Intel Corporation of the 8228 system controller and bus driver chip, which contains a status latch and the necessary gating inside the chip to generate the control signals INTA, MEMR, MEMW, I/O R, and I/O W, as shown in Fig. 6-16. The 8228 chip also acts as a bidirectional bus driver, which allows the bidirectional data bus to be connected to more TTL loads than is possible with a bare 8080 chip. While the 8228 chip replaces several TTL chips, it is still relatively expensive. This discussion is only to call your attention to this chip and other new chips that help to simplify your microcomputer design task. Most individuals will be microcomputer users rather than microcomputer designers, and will not be involved with designs that start with the CPU chip and work up. This chapter gives you some idea of the design considerations required to convert an 8080 microprocessor chip into a full microcomputer. If you are interested in designing microcomputers using microprocessor chips, take a careful look at manufacturers' literature and periodicals. Others may have already encountered and solved your problems. #### State Timing Each different machine cycle is subdivided into from three to five 500-ns $\it states$ labeled $T_1,\ T_2,\ T_3,\ T_4,\ and\ T_5.$ Three additional states— Fig. 6-16. Diagram of a typical 8080 control circuit that is based on the 8228 chip. WAIT, HOLD, and HALT—last from three to an indefinite number of 500-ns clock periods, as controlled by external signals that determine the termination time of such states. The total number of states per instruction is determined by the number of machine cycles and by the number of states in each machine cycle. The simplest 8080 instructions have four states; the most complicated one has eighteen. The 8080 chip does not indicate its internal state directly, by broadcasting state control" output during each state; instead, the 8080 supplies direct control outputs (INTE, HLDA, DBIN, WR, and WAIT) for use by external circuitry. The 8080 passes through at least three states in every machine cycle, with each state defined by successive positive leading edge transitions of the $\phi_1$ clock. Each state contains two clock pulses: a $\phi_1$ pulse and a $\phi_2$ pulse. Events that occur in each state are referred to transitions in the $\phi_1$ and $\phi_2$ clock pulses; such events usually occur at the leading edge or within 50 ns of the leading edge. The activities, or actions, that occur during each state, as explained in References 8 and 9, can be summarized in the following manner: #### State Associated Activities $T_1$ The memory address from the program counter, the H and L register pair, or the stack pointer, or an I/O device number, is placed on the 16-bit memory address bus near the positive leading edge of the $\phi_2$ clock pulse. The SYNC output pin on the 8080 microprocessor chip goes to logic 1 slightly after the positive leading edge of the $\phi_2$ clock pulse. The eight status bits (INTA, $\overline{WO}$ , STACK, HLTA, OUT, M, INP, and MEMR) are placed on the external 8-bit bidirectional data bus slightly after the positive leading edge of the $\phi_2$ clock pulse. T2 The logic states of the HOLD and READY input pins to the 8080 chip and the presence of a HALT instruction are tested. If the READY input is at logic 1, state T3 can be entered; if the READY input is at logic 0, the CPU goes into a wait state, Tw. The SYNC output pin on the 8080 chip goes to logic 0 slightly after the positive leading edge of the φ2 clock pulse. Slightly after the positive leading edge of the $\phi_2$ clock pulse, the 8-bit status word on the external data bus is replaced either by an 8-bit instruction or data byte from memory, or by a data byte from the accumulator or an input device. The contents of the 16-bit memory address bus do not change during this state. DBIN on the 8080 chip goes to logic 1 at $\phi_2$ leading edge. $T_w$ — An optional wait state. The CPU enters this state if the READY input to the 8080 chip is at logic 0 or if a HALT instruction has been executed. If a HALT instruction is encountered, the CPU will remain in this state until an interrupt is received or the program counter is reset. The CPU acknowledges the wait state by placing the WAIT output pin on the 8080 chip at a logic 1 state at the positive leading edge of the $\phi_1$ clock pulse. The HOLD state is a bit more complex and will not be discussed here. A wait period may be of indefinite duration. The processor remains in the waiting condition until its READY input line again goes to logic 1. The instruction cycle may then proceed, beginning with the positive leading edge of the next $\phi_1$ clock pulse. A WAIT interval will therefore consist of an integral number of $T_w$ states and will always be a multiple of the clock period.8 The contents of the 16-bit memory address bus do not change during this state unless the CPU is in the HOLD state. T<sub>3</sub> Data coming from memory and present on the 8-bit external data bus can be transferred to the instruction register, the accumulator, or to one of the general-purpose registers. Data coming from an input device and present on the external data bus can be transferred to the accumulator. Data coming from the accumulator and present on the external data bus can be transferred to memory or to an output device. Data coming from one of the general-purpose registers and present on the external data bus can be transferred to memory. The DBIN output pin on the 8080 chip returns to logic 0 at the positive leading edge of the $\phi_2$ clock pulse. The $\overline{WR}$ output pin on the 8080 chip goes to logic 0 at the positive leading edge of the first $\phi_1$ clock pulse following state $T_2$ . Note that this could occur either in state $T_w$ or state $T_3$ , usually the latter A variety of activities can occur during state $T_3$ , depending upon the type of machine cycle. To summarize, an instruction byte (fetch machine cycle), data byte (memory read, stack read, or input machine cycle), or interrupt instruction (interrupt cycle) is input to the CPU from the 8-bit external data bus; or a data byte (memory write, stack write, or output machine cycle) is output onto the external data bus.<sup>8</sup> - $T_4, T_5$ Two optional states available for the execution of a particular instruction if required. If not, the CPU may skip one or both of them. These states are only used for internal processor operations.<sup>8</sup> The contents of the memory address bus change slightly after the positive leading edge of the $\phi_2$ clock pulse in these states. - T<sub>1</sub> The $\overline{\text{WR}}$ output pin on the 8080 chip returns to a logic 1 at the positive leading edge of the $\phi_1$ clock pulse during this state. This is the first state of a new instruction cycle. The above descriptions are summarized in Figs. 6-17 and 6-18. Fig. 6-17 is a five-state machine cycle, the fetch cycle, in which a memory byte is transferred to the instruction register. As long as the READY output pin is at logic 1 during state $T_2$ , state $T_3$ can be entered. We have not specified what occurs during states $T_4$ and $T_5$ . Fig. 6-18 is a three-state machine cycle in which a data byte is written into memory or an output device. Note that the $\overline{WR}$ output pin on the 8080 chip is at logic 0 during state $T_3$ . DBIN remains at logic 0 during a write or output machine cycle. Fig. 6-17. A five-state machine cycle, the fetch cycle, in which a memory byte is transferred to the instruction register. This concludes our discussion of "state timing" in the 8080 microprocessor chip. It would be worth your time to study Figs. 6-11 and 6-12 and also to obtain copies of References 8 and 9, which go into state timing in considerably greater detail. #### SINGLE STEPPING AN 8080 MICROCOMPUTER Fig. 6-19 shows a circuit used with an 8080 microcomputer to single step through the execution of a computer program. It is described here because it will give a bit more insight into the WAIT state of the 8080 microprocessor. microprocessor. The basic function of the circuit in Fig. 6-19 is to generate, via a debounced pulser on the front panel of the microcomputer, a 550-ns monostable pulse at the D input to the 7474 positive-edge-triggered flip-flop. As shown in Fig. 6-20, the $\phi_1$ TTL clock input to the 7474 flip-flop allows a logic 1 state to exist at pin 23, the READY input, of Fig. 6-18. A three-state machine cycle in which a data byte is written into output device. Note that WR is at logic 0 during state T<sub>3</sub>. the 8080 microprocessor chip. A logic 1 exists for only 500 ns, but this period is sufficient to allow the machine cycle to continue into state T<sub>3</sub> from the series of wait states T<sub>w</sub>. Beyond state T<sub>3</sub> are either states T<sub>4</sub> and perhaps T<sub>5</sub>, or else a new machine cycle, which starts with state T<sub>1</sub>. In other words, the single-step pulser on the front panel allows the machine cycle to enter state T<sub>3</sub> from a wait state. Note that the WAIT output on the 8080 chip goes to logic 0 at the beginning of state T<sub>3</sub>. The debounced logic switch allows you to disable the single-step pulser circuit. In its quiescent state, the debounced logic switch applies a logic 0 at pin 2 of the 7400 NAND gate. This forces the output from the gate to be at logic 1, a logic state that is clocked through the 7474 flip-flop to pin 23 of the 8080 chip. As long as the READY input of the 8080 chip is at logic 1, it is not possible to single step through the program. the program. Note that the single-step pulser has a quiescent state of logic 1. This allows you to employ an external clock to clock the 74123 monostable Fig. 6-19. The circuit employed in an 8080-based microcomputer to permit single-step execution of a computer program. The clock frequency is 2 MHz. Fig. 6-20. Timing diagrams for the single-step circuit shown in Fig. 6-19. at pin 2. The authors have found an external clock, consisting of a 555 timer chip with a clock frequency of about 1 Hz, to be quite useful. There is one final question about the single-step circuit: How fast does the 8080 microcomputer execute a single instruction when in the single-step mode? The answer is: At the full internal clock frequency of 2 MHz. With the single-step capability, you simply force the microcomputer to remain in a wait state. When you bring the READY input to logic 1 for 500 ns, you allow the microcomputer to execute states T<sub>3</sub>, T<sub>4</sub>, and T<sub>1</sub> and T<sub>2</sub> of the next machine cycle at a clock rate of 500 ns per state. You are not able to control the speed with which a single state is executed. As long as the internal clock frequency is 2 MHz, such a speed will always be 500 ns per state. A second and superior single-step circuit, one based on the use of a 7474 flip-flop in 8080 systems that contain an 8224 clock generator/driver chip, is shown in Fig. 6-21. The behavior of this circuit can be Fig. 6-21. A simple single-step circuit for an 8080-based microcomputer that employs an 8224 chip. This circuit can operate at any system clock frequency. Fig. 6-22. Timing diagrams for the circuit given in Fig. 6-21. The step pulse is the pulse applied at pin 3 on the 7474 chip; it may be generated by a manual pulser. understood with the aid of the timing diagrams shown in Fig. 6-22. The key to the operation of the circuit is, as it was in the preceding circuit, the fact that a logic 0 at the READY input to the 8080 chip will force the chip into a wait state. As can be seen from the block diagram for the 8224 chip, the $\phi_2$ clock signal clocks a D-type latch within the 8224 that latches the RDYIN input and outputs it to the READY input of the 8080. The sequence of actions that occurs in the single-step circuit is as follows: - A clock pulse, "step pulse," applied at pin 3 of the 7474 flip-flop, produces a logic 1 at the output Q, which is connected to the RDYIN input of the 8224 chip. - At the positive edge of $\phi_2$ , the READY output from the 8224 chip goes to logic 1. - goes to logic 1. The 8080 chip samples the READY input line during φ<sub>2</sub>; with the READY input now at logic 1, the 8080 finishes the execution of the current machine cycle. - At the end of the second wait state in the timing diagram, the WAIT output line of the 8080 chip returns to logic 0, which clears the 7474 flip-flop. - RDYIN returns to logic 0, which is clocked within the 8224 chip to the READY output at pin 4. - After state T<sub>2</sub> of the next machine cycle, the 8080 microprocessor again enters a wait state since the READY input is again at logic 0. If RDYIN is maintained at logic 1, which it can be if the preset input to the 7474 flip-flop is maintained at logic 0, READY will always be at logic 1 and the 8080 chip will be prevented from entering a wait state. The authors are indebted to Mr. William Dalton, a computer science student at VPI&SU, for pointing out the utility of this circuit, including the fact that it does not require an RC timing circuit and thus can operate any system clock frequency. The specifications for the 8224 clock generator and driver chip are provided on the following two pages. ## THE 8212 EIGHT-BIT INPUT/OUTPUT PORT CHIP The 8212 eight-bit input/output port integrated-circuit chip is destined to be a very popular buffer/latch, so it is worthwhile to understand how it operates. Basically, the chip is a group of eight 7475-type latches each of which has a three-state output buffer (Fig. 6-23). latches each of which has a three-state output buffer (Fig. 6-23). You may recall that the output from the latch in Fig. 6-23 follows the data input as long as the clock input is at logic 1. A logic 0 at the CLR input clears the latch. The enable input, EN, to the three-state buffer must be at logic 1 for data to appear at the output of the buffer. must be at logic 1 for data to appear at the output of the buffer. An important section of the 8212 is devoted to control logic. The logic diagram shown in Fig. 6-24 will make the circuitry easier to understand. The five control inputs can be summarized as follows: - DSI, DS2 Device select. These two inputs are used for device selection. When DSI is at logic 0 and DS2 is at logic 1, the device is selected. In the selected state, the output buffer is enabled and the service request flip-flop (SR) is set to logic 1. When the MD input is at logic 1, the source of clock pulses to the eight latches is from the device select inputs. When the MD input is at logic 0, the output buffer state is determined by the device select inputs. - MD Mode. This input is used to control the state of the output buffer and to determine the source of clock input to the eight latches. When MD is at logic 1, the output buffers are enabled and the source of clock pulses is from the device select inputs. When MD is at logic 0, the output buffer state is determined by the device select inputs and the source of clock pulses to the eight latches is from the STB input. - STB Strobe. This input clocks the eight latches when the MD input is at logic 0. This input also synchronously clears the service request flip-flop to Q=0. #### Schottky Bipolar 8224 #### **CLOCK GENERATOR AND DRIVER** FOR 8080A CPU - Single Chip Clock Generator/Driver for 8080A CPU Power-Up Reset for CPU Ready Synchronizing Flip-Flop Advanced Status Strobe Advanced Status Strobe Scillator Output for External System Timing Crystal Controlled for Stable System Operation Reduces System Package Count The 8224 is a single chip clock generator/driver for the 8080A CPU. It is controlled by a crystal, selected by the designer, to meet a variety of system speed requirements. Also included are circuits to provide power-up reset, advance status strobe and synchronization of ready. The 8224 provides the designer with a significant reduction of packages used to generate clocks and timing for 8080A. PIN CONFIGURATION #### BLOCK DIAGRAM #### PIN NAMES | RESIN | RESET INPUT | XTAL 1 | / CONNECTIONS | |-------|--------------|----------------------|-------------------------| | RESET | RESET OUTPUT | XTAL 2 | FOR CRYSTAL | | ROYIN | READY INPUT | TANK | USED WITH OVERTONE XTAL | | READY | READY OUTPUT | osc | OSCILLATOR OUTPUT | | SYNC | SYNC INPUT | φ <sub>2</sub> (TTL) | D) CLK ITTL LEVELI | | STSTB | STATUS STB | Voc | +5V | | | (ACTIVE LOW) | Vpp | *12V | | 1 | 8080 | GND | ov | | 2 | CLOCKS | | | #### SCHOTTKY BIPOLAR 8224 #### FUNCTIONAL DESCRIPTION The 8224 is a single chip Clock Generator/Driver for the 8080A CPU. It contains a crystal-controlled oscillator, a "divide by nine" counter, two high-level drivers and several auxiliary logic functions. The oscillator circuit derives its basic operating frequency from an external, series resonant, fundamental mode crystal. Two inputs are provided for the crystal connections (XTAL1, XTAL2). The selection of the external crystal frequency depends mainly on the speed at which the 8080A is to be run at. Basically, the oscillator operates at 9 times the desired pro- A simple formula to guide the crystal selection is: Crystal Frequency = $$\frac{1}{t_{CY}}$$ times 9 Example 1: (500ns t<sub>CY</sub>) 2mHz times 9 = 18mHz\* Example 2: (800ns t<sub>CY</sub>) 1.25mHz times 9 = 11.25mHz Another input to the oscillator is TANK. This input allows the use overtone mode crystals. This type of crystal generally has much lower 'gain' than the fundamental type so an external L Creetwork is necessary to provide the additional 'gain' for proper oscillator operation. The external LC network is connected to the TANK input and is AC coupled to ground. See Figure 4. The formula for the LC network is: $$F = \frac{1}{2\pi \sqrt{LC}}$$ The output of the oscillator is buffered and brought out on OSC (pin 12) so that other system timing signals can be derived from this stable, crystal-controlled source. "When using crystals above 10mHz a small amount of frequency "trimming" may be necessary. The addition of a small capacitance (3pF - 10pF) in series with the crystal will accomplish this function. #### Clock Generator The Clock Generator consists of a synchronous "divide by nine" counter and the associated decode gating to create the waveforms of the two 8080A clocks and auxiliary timing signals. The waveforms generated by the decode gating follow a simple 2-5-2 digital pattern. See Figure 2. The clocks generated; phase 1 and phase 2, can best be thought of as consisting of "unit's based on the oscillator frequency. Assume that one "unit" equals the period of the oscillator frequency. By multiplying the number of "units" that are contained in a pulse width or delay, times the period of the oscillator frequency, the approximate time in nanoseconds can be derived. quency, the approximate time in anosconic conscious of the countries. The outputs of the clock generator are connected to two high level drivers for direct interface to the 8080A CPU. A TTL level phase 2 is also brought out \$\phi\_2\$ (TTL) for external timing purposes. It is especially useful in DMA dependant activities. This signal is used to gate the requesting device on the bus once the 8080A CPU issues the Hold Acknowledgement (HLDA). Several other signals are also generated internally so that optimum timing of the auxiliary flip-flops and status strobe (STSTB) is achieved. Fig. 6-23. A typical latch/buffer cell in the 8212 integrated-circuit chip. There are eight of these cells on the chip. The three outputs resulting from the above five control inputs can be described as follows: INT A logic 0 at this output may be used to interrupt the micro-computer. The output must be inverted and then connected to pin 14 of the 8080 chip. Appears as an external output pin. Clock A logic 1 enables the eight D-type latches, which follow the data input. Latching occurs when this output returns to a logic 0 state. Occurs internally within the chip. Enable A logic 1 enables the eight three-state output buffers, one on each latch, A logic 0 forces the buffers into their high-impedance state. Occurs internally within the chip. Table 6-2 summarizes the behavior of the circuitry in Figs. 6-23 and 6-24. Table 6-2. Inputs and Outputs of the 8212 Chip. | Control Inputs | | | | | | | | | |----------------|-----|-----|----|-----|--------|-------------|-------|-----| | CLR | DS2 | DS1 | MD | STB | Enable | Clock | Q(SR) | INT | | 1 | 1 | v | 1 | 1 | 1 | 7 | 1 | ъ | | i | _ش_ | 0 | 1 | 1 | 1 | <b>.</b> 7∟ | 1 | T | | i | 1 | ¬ù- | Ó | 1 | | 1 | 0 | T | | i | -n_ | 0 | ō | 1 | 1 | 1 | 0 | 7 | | i | 1 | ō | ō | | l ı | <b>.</b> | 0 | 0 | The Intel Corporation literature on the 8212 eight-bit input/output port provides a variety of application notes for the use of this chip as a gated buffer, bidirectional bus driver, interrupting input port, interrupt instruction port, output port, and 8080 status latch. Four pages from Fig. 6-24. Details of the control and device select logic for the 8212 integrated-circuit chip. The clock and enable outputs are connected directly to the 7475-type D latches within the chip itself, as shown in Fig. 6-23. They do not exist as outputs from the 8212 chip. the Intel literature are provided on the following pages. The chip is fast, with most actions occurring in no more than 40 ns. #### TEST This test probes your understanding of the advanced concepts discussed in this chapter. Please write your answers on a separate piece of paper. - 6-1. What is the difference between a clock cycle, machine cycle, and in- - 6-1. What is the difference between a check cycle, machine cycle, that instruction cycle? 6-2. What types of 8-bit information can appear on the external data bus? Give as much detail as you can. 6-3. Which of the data storage elements listed below are connected to the external data bus, and which are connected to the internal data bus? accumulator B register #### Schottky Bipolar 8212 #### **EIGHT-BIT INPUT/OUTPUT PORT** - Fully Parallel 8-Bit Data Register and Buffer Service Request Flip-Flop for Interrupt Generation - Low Input Load Current — .25 mA Max. Three State Outputs - Outputs Sink 15 mA - 3.65V Output High Voltage for Direct Interface to 8080 CPU or 8008 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 fatch 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 fatches, gated buffers or multiplexers. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with this device. OUTPUT PIN NAMES | Dis Dis | DATA IN | |---------------------|------------------------| | DO: 00s | DATA OUT | | DS, DS <sub>2</sub> | DEVICE SELECT | | MD | MODE | | STB | STROBE | | INT | INTERRUPT (ACTIVE LOW) | | 615 | CLEAR JACTIVE LOW | ## Applications Of The 8212 -- For Microcomputer Systems Basic Schematic Symbol Gated Buffer Bi-Directional Bus Driver IV Interrupting Input Port Interrupt Instruction Port VI Output Port VII 8080 Status Latch 8008 System 8080 System: 8 Input Ports 8 Output Ports 8 Level Priority Interrupt #### I. Basic Schematic Symbols Two examples of ways to draw the 8212 on system as a system bus (bus containing 8 parallel lines). schematics—(1) the top being the detailed view The output to the data bus is symbolic in reference showing pin numbers, and (2) the bottom being the symbolic view showing the system input or output #### BASIC SCHEMATIC SYMBOLS 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 DSI and DS2. When the device selection logic is false, the outputs are 3-state. 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. #### GATED BUFFER 3-STATE #### SCHOTTKY BIPOLAR 8212 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. # BI-DIRECTIONAL BUS DRIVER 8212 8212 #### IV. Interrupting Input Port 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 V. Interrupt instruction Port The 812 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. (DST could be used to multiplex a variety of interrupt instruction ports onto a common bus). ## SCHOTTKY BIPOLAR 8212 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 hand-shaking 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. (OST+DS2) #### OUTPUT PORT (WITH HAND-SHAKING) #### VII. 8080 Status Latch VII. 8080 Status Latch Here the 8212 is used as the status latch for an 8080 microcomputer system. The input to the 8212 latch is directly from the 8080 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 bidirectional data bus of the microprocessor and the control bus. a R/W memory byte an input device an output device instruction register flags PROM memory byte 6-4. Describe five of the eight status bits and explain what type of information they provide. 6-5. Describe five of the nine machine cycles. - 6-6. Both the status bits and output pins from the 8080 microprocessor chip can be used to provide output signals to interface circuits. Explain how this is done. - 6-7. Describe the different types of states that can comprise a machine cycle. Your performance on this test will be acceptable if you can answer all of the above questions correctly in a 90-minute closed-book examination. The above concepts are advanced concepts that you may not immediately need to know. With time, however, you will find them to be quite important as you develop more complex interface circuits. #### WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? It was stated at the beginning of this chapter that at the end you will be able to do the following: Explain the differences between the internal and external busses in an 8080-based microcomputer system. This was done in the section on the bidirectional data bus. The single 8080 microprocessor sheet from the Intel literature gives an excellent view of the internal data bus. List the sources and destinations of information that appears on the external data bus. This was also done in the section on the bidirectional data bus. • Explain the differences between a state, clock cycle, instruction cycle, and machine cycle. A state and a clock cycle are the same. A machine cycle consists of three or more states. An instruction cycle consists of one to five machine cycles. All of these concepts have been discussed in some detail. - Explain what a status bit and a status byte are. A status byte consists of eight different status bits, which are discussed in the section on machine cycle identification. - Describe the nine different types of machine cycles. They are fetch, memory read, memory write, output, input, stack write, stack read, halt, and interrupt. These nine types of cycles are discussed in considerable detail in the section on machine cycles. - Describe the function of each of the eight different status bits. The eight status bits are given in the section on machine cycle identi- Fig. 6-21 provides the circuit that may be used with an 8080-based microcomputer. Discuss the characteristics of the 8212 eight-bit input/output port integrated-circuit chip. We did this at the end of the chapter. Manufacturer's literature was provided. fication. They are used to identify the type of machine cycle that is being executed. • Explain how the control outputs on the 8080 chip can be combined logically with one or more of the status bits, and provide at least one example of such a logical combination. In the text we have logically combined the following signals: OUT and $\overline{WR}$ INP and DBIN M<sub>1</sub> and DBIN The first pair generated a 500-ns $\overline{\text{OUT}}$ pulse, the second pair generated ated a 500-ns IN pulse, and the third pair generated a single clock pulse at the beginning of each instruction cycle. Draw timing diagrams that depict the behavior of typical micro-computer instructions. Such diagrams should clearly demonstrate the logic states of the more important control inputs, control outputs, and status bits. This was done in considerable detail in this chapter. See Fig. 6-7. • Explain the different types of data that can appear on the external data bus. Data are emphasized here, not instruction bytes. Data can come from the accumulator, from memory, from an input device, from the second and third bytes of an instruction, and from a register. Explain state timing for typical machine cycles. This has been done in the subsection on state timing. Six different states were discussed. Figs. 6-17 and 6-18 provide examples. • Explain how single stepping of an 8080 microcomputer occurs, complete with timing diagrams and circuit diagrams Fig. 6-21 provides the circuit that may be used with an 8080-based microcomputer. • Discuss the characteristics of the 8212 eight-bit input/output port integrated-circuit chip. We did this at the end of the chapter. Manufacturer's literature was provided. #### **CHAPTER 7** ## Microcomputer Input/Output In this chapter, you will learn how to use device select pulses to latch output data from the accumulator and to input data into the accumuoutput data from the accumulator and to input data into the accumulator. Circuits will be provided for six different latch chips and two different input buffer chips. You will also learn how to test a variety of accumulator instructions, including the decimal adjust accumulator instruction, which allows you to conform binary could decimal open. instruction, which allows you to perform binary-coded-decimal operations. #### **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Latch the output from the accumulator of an 8080-based microcomputer with the aid of any one of six different integrated-circuit chips: 7475, 74100, 74175, 75193, 74198, and 8212. - Input TTL data into the accumulator with the aid of either the 8095 or 8212 buffer chips. - Explain what a data logger is. Calculate the timing delays required to data-log digital information appearing at different rates. #### **DEFINITIONS** accumulator—The register and associated digital electronic circuitry in the arithmetic unit of a computer in which arithmetic and logical operations are performed. autoranging instrument-A digital instrument that changes scales automatically. buffer-A digital device that isolates one digital circuit from another. (Note: There exist a variety of other meanings for the term buffer). bus monitor—A device for checking digital signals that appear on a bus. data point—All of the bits required to characterize the sign and magnitude. tude of a measured digital quantity. A data point typically consists of many bits. decimal adjust accumulator-An 8080 microprocessor instruction that permits binary-coded-decimal operations. data logger-An instrument that automatically scans data produced by another instrument or process and records readings of the data for input/output-General term for the equipment used to communicate with a computer and the data involved in the communication.4 I/O-Abbreviation for input/output.4 latch-A simple logic storage element. log-To automatically scan data produced by an instrument or process and record readings of the data for future use. monitor—A device used for checking signals.4 rotate-A computer instruction that causes the contents of the accumulator to move, bit by bit, to the left or right by one position. #### INPUT/OUTPUT When the term, input/output, or I/O, is employed, what is usually meant is that one or more data bytes are transferred between an input/output device and the microcomputer. A pair of schematic diagrams that depict how this is done are shown in Figs. 7-1 and 7-2. The important points provided by these two figures can be summarized as - Input-output of a data byte occurs between an external I/O device and the accumulator within the 8080 chip. - $\bullet$ The function pulses, $\overline{\text{IN}}$ and $\overline{\text{OUT}}$ , are produced by the 8080 microprocessor (along with additional circuitry, as described in Chapter 6) to allow an I/O device to know whether it is transferring a data byte to the microcomputer or receiving a data byte - An 8-bit device code available at the time that an IN or OUT pulse is generated permits the generation of 256 different input device select pulses and 256 different output device select pulses. In other words, quite a bit of digital information is transferred from one point to another within an interfaced microcomputer system during either an IN or OUT microcomputer instruction cycle. Fig. 7-1. The important inputs and outputs of a typical 8080-based microcomputer system. ## MICROCOMPUTER OUTPUT CIRCUITS The basic "gimmick" that you employ to acquire data output from the accumulator is quite simple: You use a single output device select pulse to enable a latch that "latches" a data byte from the bidirectional data bus. The data goes in and out over the same signal lines on the 8080 chip: D0 through D7. Depending upon the type of latch chip, #### MICROCOMPUTER Fig. 7-2. Typical inputs and outputs from an 8080 microprocessor chip. The $\overline{\text{IN}}$ and $\overline{\text{OUT}}$ function pulses are generated with the aid of additional circuitry, i.e., an 8212 status latch. Fig. 7-3. Microcomputer output circuit based on an 8212 chip either a positive or a negative device select pulse is used to strobe, pulse, or latch data. Device select pulses are produced with the aid of a decoder chip, such as the 7442 or 74154, in which the address bus and $\overline{\rm IN}$ or $\overline{\rm OUT}$ control signals are gated together. Based upon the information provided in Chapter 4, you should be able to sketch various decoder and gating schemes to derive input and output device select pulses. Typical microcomputer output circuits include those based upon the 8212 chip (Figs. 7-3A and 7-3B), the 74100 eight-bit D-type latch (Figs. 7-4A and 7-4B), a pair of 7475 D-type latches (Figs. 7-5A and 7-5B), the 74198 eight-bit shift register chip and a pair of 74175 positive-edge triggered latches (Figs. 7-6A, 7-6B, and 7-6C), and even a pair of 74193 up/down counters (Figs. 7-7A and 7-7B). When using the 8212 chip as an output latch, you should make certificated the classic content of the state st When using the 8212 chip as an output latch, you should make certain that the clear input, $\overline{\text{CLR}}$ , at pin 14 is tied to logic 1. This input should normally "float" to logic 1 when unconnected, but experience has shown that this is not always the case. #### MICROCOMPUTER INPUT CIRCUITS The basic "gimmick" that you employ to input data into the accumulator from an input device is equally simple: You use a single input device select pulse to enable a three-state buffer chip, which transfers a data byte to the bidirectional data bus. You can employ a three-state buffer/latch chip such as the 8212 (Fig. 7-8), or a pair of 8095 (74365) three-state buffer chips, which are relatively inexpensive (Figs. 7-9A and 7-9B). In this case, the enabled buffers permit data to be transferred to the bidirectional data bus, D0 through D7, *i.e.* pins 3 through 10 on the 8080 chip. The accumulator acquires the data during the 500-ns input device select pulse. In the preceding illustrations, the device select pulse is a negative clock pulse, as indicated by the bars over the words "Device select pulse." The inputs of the 8095 three-state buffers are connected to logic switches, but they can be connected to any source of eight bits of TTL binary or encoded data. This data is transferred through the 8095 buffers, placed on the data bus, and copied into the accumulator during an IN microcomputer instruction. Data is input each time that the IN instruction is executed. instruction is executed. ## INPUT/OUTPUT INSTRUCTIONS We will repeat the two 8080 microprocessor input/output instructions given in Chapter 4: (A) Pin configuration of the 74100 eight-bit latch chip. (B) Circuit in which a 74100 chip serves as an output latch. The output is prov three-digit octal word. Fig. 7-4. Microcomputer output circuit based on the 74100 latch. (A) Pin configuration of the 7475 four-bit latch chip. (B) Circuit in which a pair of 7475 D-type latches serve as an output port for the microcomputer. Fig. 7-5. Microcomputer output circuit based on a 7475 latch. 333 <B2> IN Generate an input device select pulse to allow an and replace the contents of the accumulator. Generate an output device select pulse to allow an 8-bit data byte present in the accumulator to be sent to an output device. The contents of the accumulator to the contents of the accumulator represents an experience of the contents. <B2> OUT 323 accumulator remain unchanged. (A) Pin configurations of the 74198 eight-bit shift register and the 74175 four-bit latch chips. Both chips contain positive-edge-triggered flip-flops of the 7474 type. (B) Circuit in which a 74198 shift register chip latches the accumulator data. (C) Circuit in which a pair of 74175 latch chips latch the 8-bit accumulator data. Fig. 7-6. Microcomputer output circuits based on the 74198 and 74175 chips. $Q_B = B$ , $Q_C = C$ , and $Q_D = D$ (A) The 74192 or 74193 up/down counter chip. This chip contains a built-in four-bit latch of the 7475 type. LAMP MONITORS (B) Output latch circuit that employs a pair of 74193 up/down counter chips. The microcomputer is used to preset a count in these counters. +5V GND Fig. 7-7. Microcomputer output circuit based on a 74193 chip. The second byte in each of the above instructions, <B2>, is an 8-bit device code that permits you to select any of 256 different input devices or 256 different output devices. Fig. 7-8. Circuit in which an 8212 chip is used as an input buffer to an 8080-based microcomputer. #### INPUT/OUTPUT PROGRAMS A simple program to input the logic switch data in Fig. 7-9B into the accumulator and then immediately output it to one of the microcomputer output circuits shown previously is as follows: | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|----------------------------------| | 000 | 333 | IN | Input data from input device 004 | | 001 | 004 | 004 | Device code 004 | | 002 | 323 | OUT | Output data to output device 000 | | 003 | 000 | 000 | Device code 000 | | 004 | 166 | HLT | Halt | This program will input the logic switch data, output it to an output latch, and then halt. To input and output the data continuously, you would change the above program to the following: | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|---------------------------------------------------------------------------------| | 000 | 333 | IN | Input data from input device 004 | | 001 | 004 | 004 | Device code 004 | | 002 | 323 | OUT | Output data to output device 000 | | 003 | 000 | 000 | Device code 000 | | 004 | 303 | JMP | Unconditional jump to the memory loca-<br>tion given by the following two bytes | | 005 | 000 | | LO address byte | | 006 | 000 | | HI address byte | To store the input data into a memory location and update the memory contents each time new data is input, you would use the following program: | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|----------------------------------------------------------------------------------------------| | 000 | 333 | IN | Input data from input device 004 | | 001 | 004 | 004 | Device code 004 | | 002 | 323 | OUT | Output data to output device 000 | | 003 | 000 | 000 | Device code 000 | | 004 | 062 | STA | Store the accumulator contents in the<br>memory location given by the following<br>two bytes | | 005 | 200 | | LO address byte | | 006 | 003 | | HI address byte | | 007 | 303 | JMP | Unconditional jump to the memory loca-<br>tion given by the following two bytes | | 010 | 000 | | LO address byte | | 011 | 000 | | HI address byte | The program is similar to that shown previously in this section, but this time a STA <B2> <B3> instruction has been added to permit you to store the accumulator contents into a specific memory location, the contents of which are updated during each program loop. You may ask: "How can data be stored when it has previously been sent out to display, which in the above program example is output device 000? Is not the data 'used up' when it is output to a device?" The answer is no. When a data byte is transferred from one location to another, it copied to the new location. It is not used up; the original data is still present in its initial location, be it the accumulator, a register, or a memory location. Data present in a given location, such as the accumulator, can be copied indefinitely. While the concept of using input device select pulses to input eight bits of logic switch data is straightforward, once you have input the data you can perform interesting programming tricks to take advantage of the power of the 8080 chip. For example, assume that the eight bits of data from the logic switches are really the 8-bit ASCII code from a standard ASCII keyboard that has TTL output. Each time eight new bits of data are input, they are tested to determine whether or not they are the ASCII equivalent to the letter E, which has an ASCII code of 305. If so, the input data will be output and also stored in memory. If not, the program will immediately loop back to the IN instruction and input new data. The applicable flowchart for this program is provided in Fig. 7-10 and the program is: | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|---------------------------------------------------------------------------------------------------------------| | 000 | 333 | IN | Input data from input device 004 | | 001 | 004 | 004 | Device code 004 | | 002 | 376 | CPI | Compare the accumulator contents with<br>the following data byte. If they are<br>identical, set the zero flag | | 003 | 305 | 305 | Data byte that is the ASCII code for the letter E | | 004 | 302 | JNZ | Jump to the memory location given by the following two bytes if the zero flag is reset, i.e., at logic 0 | |-----|-----|-----|----------------------------------------------------------------------------------------------------------| | 005 | 000 | | LO address byte | | 006 | 000 | | HI address byte | | | | OUT | Output data to output device 000 | | 007 | 323 | | | | 010 | 000 | 000 | Device code 000 | | 011 | 062 | STA | Store the accumulator contents in the<br>memory location given by the following | | | | | two bytes | | 012 | 200 | | LO address byte | | | | | HI address byte | | 013 | 003 | | | | 014 | 166 | HLT | Halt | The compare immediate instruction at LO memory addresses 002 and 003 permits you to compare the ASCII byte 305 with the contents of the accumulator without altering the contents of the accumulator. Only the flag contents are changed. If the ASCII byte for the letter E and the accumulator contents are identical, the zero flag is set to logic 1; otherwise, it is reset to logic 0. The flag state is then used in the following conditional jump instruction, JNZ, to decide whether to continue looping or to continue to the OUT instruction at LO memory address 007. ## MICROCOMPUTER OUTPUT TO A MULTIPLEXED DISPLAY One important characteristic of microcomputers is their ability to replace hardware, i.e., integrated-circuit chips, wires, capacitors, etc., with software. The preceding example, in which a microcomputer program tested the input for the ASCII code equivalent of the letter E, is a good illustration. Simple modifications of earlier input/output programs changed the entire nature of what the microcomputer system did. These same changes would take much more time to develop and test if they were performed with hardware only. test if they were performed with hardware only. A multiplexed display is a good example of a hardware-software tradeoff. Assume that you wish to display up to five decimal digits on an indicator display. The classical hardware approach would be to use a latch, a decoder-driver, and a seven-segment display for each numeral. This can be an expensive approach that also consumes a great deal of cover. An alternative approach, one that requires both hardware and software, is shown in Fig. 7-11. You use the microcomputer to multiplex, or scan, the digits very quickly. By doing so at a sufficiently fast rate, it appears to the human eye that each digit is on continuously, as would be expected for a normal display. The main features of the circuit are a 74175 latch to temporarily store the data to be displayed, a 7448 decoder/driver to decode this data into an output for each of the seven light-emitting diode (LED) segments in the display, and a (A) The 8095 three-state buffer chip. All six three-state buffers are gated simultaneously, and there is a two-input NOR gate at the enable inputs. (B) Input circuit that employs two 8095 three-state buffer chips. The logic switches can be replaced by any 8-bit source of TTL data. Fig. 7-9. Microcomputer input circuit based on 8095 chips. 74154 decoder to select the individual digits in the five-digit display. The 7448 encodes the proper segments to be displayed at the same time that the 74154 decoder chooses a single digit. In practice, a high-current decoder such as the 74145 would be used in place of the 74154. The program for the multiplexed display is straightforward. No decision-making is necessary, so there are no conditional jumps. Fig. 7-10. Program flowchart that tests an input character to determine whether or not it is the ASCII character E. When an E is finally detected, the program outputs it, stores it, and then comes to a halt. | LO Memory<br>Address | Octal<br>Instruction | Comments | |----------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 000 | 227 | Clear the accumulator | | 001 | 323 | Generate a device select pulse that can be used for<br>some other operation, such as clearing the 74175<br>latch (wiring not shown in the schematic diagram) | | 002 | 005 | Device code for other operation | | 003 | 041 | Load the following two bytes into the L and H registers, respectively | | 004 | 200 | L register byte | | 005 | 001 | H register byte | | 006 | 176 | Move the contents of memory location addressed by<br>the register pair H and L to the accumulator | | 007 | 323 | Generate device select pulse that applies a logic 0 to pin 7 of the Hewlett-Packard five-digit display. | | 010 | 000 | Device code for pin 7 of the display | | 011 | 043 | Increment the contents of the register pair H and L by one | | 012 | 176 | Move contents of memory location addressed by register pair H and L to accumulator (Nore: The register pair has been incremented by 1 from its value at memory address 006) | | 013 | 323 | Generate device select pulse that applies a logic 0 to<br>pin 4 of the Hewlett-Packard five-digit display | | 014 | 002 | Device code for pin 4 of the display | | 015 | 043 | Increment the contents of the register pair H and L | | 016 | 176 | Move contents of memory location addressed by regis-<br>ter pair H and L to accumulator | | 017 | 323 | Generate device select pulse that applies a logic 0 to<br>pin 13 of the Hewlett-Packard five-digit display | | LO Memory<br>Address | Octal<br>Instruction | Comments | |----------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------| | | | | | 020 | 003 | Device code for pin 13 of the display | | 021 | <b>04</b> 3 | Increment the contents of the register pair H and L by one | | 022 | 176 | Move contents of memory location addressed by regis-<br>ter pair H and L to accumulator | | 023 | 323 | Generate device select pulse that applies a logic 0 to<br>pin 1 of the Hewlett-Packard five-digit display | | 024 | 044 | Device code for pin 1 of the display | | 025 | 076 | Move the following byte to the accumulator | | 026 | 017 | This byte, which is input to the 7448 chip, blanks the seven segments of the display at pin 9 and allows only the decimal point to appear | | 027 | 323 | Generate device select pulse that applies a logic 0 at<br>pin 9 and a logic 1 at pin 5 of the Hewlett-Packard<br>five-digit display | | 030 | 001 | Device code for pin 9 and pin 5 of the display | | 031 | 303 | Unconditional jump to memory location given by fol-<br>lowing two bytes | | 032 | 000 | LO address byte | | 033 | 000 | HI address byte | The numbers to be displayed must be present within the microcomputer memory before this program is executed. For example, the digits 7, 3, 0, and 5 are stored in memory locations ${\rm HI}=001$ and ${\rm LO}=200$ to 203. The decimal-point position is hardwired; the blank position is generated in software. The numbers are output from right to left in the circuit, so the data is stored in memory as follows: | LO Memory | | |-----------|-----------| | Address | Data Byte | | 200 | 007 | | 201 | 003 | | 202 | 000 | | 203 | 005 | A previously executed program or program segment could have placed such data in the indicated memory locations. Such data could be input data from some other device, or it could be the result of arithmetic operations. Today, multiplexed displays are the rule rather than the exception. Almost every hand calculator display is multiplexed. The flowchart for the preceding program is shown in Figure 7-12. Note that there is a single loop, one that is executed at the full microcomputer speed. #### DATA LOGGING WITH AN 8080 MICROCOMPUTER A data logger can be defined as follows. Fig. 7-11. A multiplexed Hewlett-Packard five-digit seven-segment LED display. data logger—An instrument that automatically scans data produced by another instrument or process and records readings of the data for It should be clear that a microcomputer can be a data logger. Data from an instrument can be put into the accumulator and then stored in memory. At a later time, this stored information can be read out in any one of a variety of ways. Data logging will become a common application of a variety of ways. Data logging will become a common application for microcomputers in the future. Perhaps the most important questions to consider when you plan to log data from an instrument are the following: (1) How many data points do you wish to log? (2) How much time will it take to log all of these points? (3) How much digital information is contained in a single data point? (4) What do you wish to do with the logged data once it has been acquired? (5) Do you need short-term or long-term data storage? We shall now discuss each of these questions. data storage? We shall now discuss each of these questions. #### How Many Data Points? The number of data points that you wish to log and the time that you will need to store them will dictate the type of storage device required. If you need to log 1,000,000 four-digit binary-coded-decimal words, you will require a memory capacity of sixteen million bits. You will therefore require some form of magnetic tape or magnetic disk. Fig. 7-12. Flowchart for the operation of the multiplexed Hewlett-Packard five-digit seven-segment display shown in Fig. 7-11. On the other hand, if you need to log 100 points, each containing four bcd digits, and store the data only for several hours, only 1600 bits of memory are required. A simple R/W memory would do quite nicely for such an application. ## Short-Term or Long-Term Storage? Read/write memory is not, in general, suitable for long-term storage of data. For one reason, such memory is volatile; if a power failure occurs, all of the data will be lost. Core memory is not volatile, but on the other hand it is quite expensive and generally not suited for long-term storage of data unless the amount of data stored is limited in amount. The best data storage devices at present appear to be magnetic tape, such as a cassette, and magnetic disk, such as the increasingly popular "floppy disks." A high-quality tape cassette can store as many as 500,000 bits of information on a single cassette that costs no more than \$10. If you are willing to gamble, you can put your own clock track on a high-quality audio cassette and reduce tape costs to about \$4 per cassette. The authors have done so with considerable success. An inexpensive and long-term storage technique is the use of perforated paper tape. However, it should be pointed out that it takes considerable time to punch such tape as well as to read it back into a computer. # How Much Information in a Single Data Point? A typical data point is usually a several-digit binary-coded-decimal or binary number that contains both a decimal point or range as well as a sign. Usually, the decimal point or range is fixed and the sign is positive, but this is not always the case. New digital devices are increasingly incorporating an autoranging capability, which simply means that the device decides where to place the decimal point. In general, you can plan on a data point containing at least sixteen bits of digital information. With 100 data points, you must multiply 100 by the number of bits per data point, 16, to obtain the total memory capacity required, i.e., 1600 bits. Frequency meters typically have many more bits per data point. A seven-digital frequency meter has at least 28 bits per data point. # What Will You Do With the Logged Data? Some logged data can be considered only to be "raw" data that must be manipulated and interpreted to produce a useful final result. For example, it might be necessary to convert a digital voltage into a force. With such cases, the logged data will require mathematical computations that are best performed soon after the data is acquired. Clearly, with data that requires additional treatment, it is best to keep the data in digital electronic form until it can be treated. Read/write memory and magnetic tape are both quite suitable for such a purpose. Once the data is in a final form, it can be printed out. Keep in mind that the printing of data is a type of long-term data storage. It is certainly the least expensive type of long-term storage around, but you pay a penalty in that you must consume time to convert it back to an electronic or magnetic type of storage if you wish to perform additional mathematical manipulations on the data. # How Many Data Points per Second? This is a question that is of fundamental importance in all data logging operations. The data can, for example: appear quite slowly and take considerable periods, such as a day, for its acquisition, or appear extremely rapidly, and take only milliseconds for the acquisition of hundreds of data points. Both extremes in data acquisition rates point to the need for automated data acquisition techniques, such as the use of a microcomputer-based data logger. There is no question that data in the laboratory, as well as elsewhere, will increasingly be logged automatically by built-in microcomputers. Chart recorders may still be used, but they will no longer need to be of the quality required in previous years. In the future, a major use for chart recorders may simply be to allow the eye to visually "integrate" a block of data to detect curvature, linearity, etc. As a demonstration of data logging, we would like to provide a computer program that enables us to log 256 eight-bit data points as fast as the microcomputer can input and store them. For example, let us assume that we are logging data from a pair of 7490 decade counters, as shown in Fig. 7-13. The question that we seek to answer is: What is the minimum amount of time required to log 256 data points from the two counters, where each data point contains two bcd digits? | LO Memory | Octal | Clock | | |-----------|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------| | Address | Instruction | Cycles | Comments | | 000 | 061 | 10 | Load the following two bytes into the stack pointer register | | 001 | 100 | | LO stack pointer byte | | 002 | 003 | | HI stack pointer byte | | 003 | 006 | 7 | Load the following data byte into the B register | | 004 | 000 | | Number of points that will be logged by the microcomputer | | 005 | 041 | 10 | Load the following two bytes in the register pair L and H | | 006 | 000 | | L register byte | | 007 | 001 | | H register byte | | 010 | 323 | 10 | Generate device select pulse to set the 7476 flip-flop | | 011 | 000 | | Device code for preset input | | 012 | 333 | 10 | Generate device select pulse that allows eight<br>bits of data from a pair of 7490 counters to<br>be input into the accumulator | | 013 | 000 | | Device code for input buffer chips | | 014 | 167 | 7 | Move the contents of the accumulator to the memory location given by the register pair H and I. | | 015 | 043 | 5 | Increment the register pair H and L by one | | 016 | 005 | 5 | Decrement the contents of register B by one | | 017 | 302 | 10 | If register B is 000s, ignore this instruction. Otherwise, jump to the memory address given by the following two bytes | | 020 | 012 | | LO address byte | | 021<br>022 | 000<br>323 | 10 | HI address byte<br>Generate device select pulse that clears the<br>7476 flip-flop | |------------|------------|----|-----------------------------------------------------------------------------------| | 023 | 001 | | Device code for clear input | | 024 | 166 | | Halt | In the program, we have provided a pair of OUT instructions to allow us to employ the techniques described in Chapter 5 to count clock pulses, such as the 7476 flip-flop circuit shown in Fig. 7-14. Device select pulse 000 sets the flip-flop, and device select pulse 001 clears it. While it is set, the five-decade counter counts clock cycles from the microcomputer clock microcomputer clock. microcomputer clock. Thirty-seven clock cycles are required for each 8-bit data point acquired by the microcomputer program. For 256 data points and a microcomputer operating at 2 MHz, a total of 256 × 37 = 9472 clock cycles, or 4.741 ms, are required in all. At 18.5 $\mu$ s per 8-bit data point, approximately 54,000 data points per second can be logged by the microcomputer. And this is not even the limit. If you desire to log data at a slower rate, you will need to insert a time delay subroutine in the above program. The 0.2-second subroutine described in Chapter 5 should be quite convenient for slow data rates. The modifications necessary to the above program are rather data rates. The modifications necessary to the above program are rather simple: Fig. 7-13. Simple data logging circuit that employs a pair of cascoded 7490 counters. Fig. 7-14. The 7476 latch circuit permits you to determine experimentally how long it takes to log and store 256 data points. The behavior of the circuit is shown in the timing diagram. | 016 | 7 | Load the following byte into the C register | |-----|---------------------------------------|------------------------------------------------------------------------------------------------------------------------| | * | | Timing byte for time delay subroutine | | 315 | 17 | Call subroutine at memory address given by following two bytes | | 000 | | LO address byte | | 060 | | HI address byte | | 005 | 5 | Decrement contents of register B by one | | 302 | 10 | If register B is 000s, ignore this instruction. Otherwise, jump to the memory address given by the following two bytes | | 012 | | LO address byte | | 000 | | HI address byte | | 323 | 10 | Generate device select pulse that clear the 7476 flip-flop | | 003 | | Device code | | 166 | | Halt | | | * 315 000 060 005 302 012 000 323 003 | 315 17 000 060 005 5 302 10 012 000 323 10 003 | 166 Halt If the data byte at memory address 017 is set at 001, corresponding to a 0.20-second time delay per data point, it will now require about 51.3 seconds to log all 256 points. Simply by changing the data byte at memory address 017, you can change the time per data point from 0.20 second per point to 51.2 seconds per point. This capability points up the advantages of microcomputers as data loggers. To output the file of 256 data points, you employ a circuit which resembles that shown in Fig. 7-15. The program that you use to sequentially output the stored data points is similar to the program that you initially used to log them. Thus, in the preceding program in this section, make the following program changes: section, make the following program changes: Fig. 7-15. Data logging circuit that outputs ASCII coded numeric data. Logic switches HGFE should be set at 1011, respectively. | 012 | 176 | MOV, M,A | 7 | Move the contents of the memory location given<br>by the register pair H and L to the accumula- | |-----|-----|----------|----|-------------------------------------------------------------------------------------------------| | 013 | 323 | OUT | 10 | output the accumulation data to the Gibit laten | | 014 | 002 | 002 | | and octal display Device code for the latch/display | # WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? It was stated at the beginning of this chapter that at the end you will be able to do the following: • Latch the output from the accumulator with the aid of any one of six different integrated-circuit chips: 7475, 74100, 74175, 74193, 74198, and 8212. This was done in the section "Microcomputer Output Circuits." • Input TTL data into the accumulator with the aid of either the 8095 or 8212 buffer chips. This was done in the section "Microcomputer Input Circuits." - Explain what a data logger is. A discussion concerning data loggers was provided in the text. A circuit and a program were provided to create a simple microcomputer based data logger. - Calculate the timing delays required to data log digital informa-tion appearing at different rates. This was discussed in the text. ## **CHAPTER 8** # Subroutines, Interrupts, External Flags, and Stacks In this chapter you will focus your attention primarily upon the fourth and final fundamental task of computer interfacing: the servicing of interrupts. We have already discussed some of the details of interrupt servicing in Chapter 1. Here, you will learn how to construct an external flag and how to interface such a flag to the microcomputer. Microcomputers are typically operated in the interrupt mode, so the concepts described in this chapter are quite important. Study them carefully and review the examples. ### **OBJECTIVES** At the end of this chapter, you will be able to do the following: - Define the terms: subroutine, SSI, MSI, LSI, allocate, stack, interrupt, polling, software driver, vectored interrupt, disabled interrupt, external flag, deferred interrupt, and sense register. - Explain how you would mask an 8-bit word to obtain the logic state of bit 5, or the logic state of any of the other seven bits. - Explain how digital information is loaded and removed from the 8080 microcomputer stack. - Perform an approximate calculation that will tell you when to use a subroutine. - Describe how you would interface an ASCII keyboard. #### **DEFINITIONS** - allocate—In a computer, to assign storage locations to main routines and subroutines, thus fixing the absolute values of symbolic addresses.<sup>4</sup> - breakpoint—A place in a routine specified by an instruction, instruction digit, or other condition, where the routine may be interrupted by external intervention or by a monitor routine.\* - breakpoint instruction—In the programming of a digital computer, an instruction, which, together with a manual control, causes the computer to stop.<sup>4</sup> - breakpoint switch—A manually operated switch that controls conditional operation at breakpoints; it is used primarily in debugging.4 deferred interrupt—A computer interrupt that occurs at some time after an external flag is set. - disable interrupt—To disable the interrupt flag within a microprocessor chip. - enable interrupt—To enable the interrupt flag within a microprocessor chip. - external flag—A digital circuit, usually containing a single flip-flop, which indicates a condition that exists with an input/output device. - flag—In a computer, an indication that a particular operation has been completed.<sup>4</sup> Also, a flag is a flip-flop that can be either set or cleared in response to operations that are occurring within a microcomputer. - immediate interrupt—A computer interrupt that occurs as soon as an external flag is set. - internal flag—A digital circuit, usually containing a single flip-flop, which indicates a condition that exists internally within the microprocessor chip. - interrupt—In a computer, a break in the normal flow of a system or routine such that the flow can be resumed from that point at a later time. The source of the interrupt may be internal or external. - interrupt flag—A flip-flop within the microprocessor chip that can be enabled or disabled by microprocessor software and which can detect an interrupt pulse and remember the fact that an interrupt occurred. - large-scale integration—Monolithic digital integrated-circuit chips with a typical complexity of 100 or more gates or gate-equivalent circuits. The number of gates per chip used to define LSI depends upon the manufacturer. Abbreviated LSI.4 - large-scale programs—Programs that contain from 1000 to 10,000 instruction bytes. Abbreviated LSP. - mask-A logical technique in which certain bits of a word are blanked out or inhibited.<sup>4</sup> medium-scale integration—Integrated-circuit chips that function as simple, self-contained logic systems, such as decade counters, small read/write memories, decoders, multiplexers, and shift registers. Such chips usually contain from 20 to 100 gates. Medium-scale integration is abbreviated MSI. medium-scale programs-Programs that contain from 100 to 1000 in- struction bytes. Abbreviated MSP. multilevel interrupt—An interrupt system in which there exist many interrupt lines to the microcomputer, each line being tied to a separate I/O device. The microcomputer does not need to scan the devices to determine which one caused the interrupt. nesting-In a computer, the inclusion of a routine or block of data within a larger routine or block of data. polling—Periodic interrogation of each of the devices that share a communication line to determine whether it requires servicing. The multiplexer or control station sends a poll that has the effect of asking the selected device, "Do you have anything to transmit?" priority—The condition in which input/output devices are ordered in importance so that some devices take precedence over others. response time—The time between the interrupt request by a device and the first instruction byte of the software driver that services it. sense—To examine or determine the status of some system component.<sup>4</sup> service routine—In digital computer programming, a routine designed to assist in the actual operation of the computer.<sup>4</sup> This term may also mean a subroutine that services an interrupt signal from an external device. single-line interrupt—An interrupt system in which there is a single interrupt line. Multiple devices must be oned to this line. Each input to the on gate is from an I/O device. Once it receives an interrupt, the microcomputer must scan all of the devices to determine which one generated the interrupt. small-scale integration—Integrated circuits that provide only simple gates, buffers, or flip-flops. Such chips usually contain no more than ten to twenty gates. Abbreviated SSI. small-scale programs—Programs that contain up to 100 instruction bytes. Abbreviated SSP. stack—A region of memory that stores temporary information, typically the contents of the internal registers within a microprocessor chip. software driver—A subroutine or part of a computer program that transfers information between the computer and a specified input/output device. status—The contents of the internal registers, including the flag bits, in a microprocessor during program execution, at a given instant. subroutine—A small subprogram not stored in the main path of the routine. Such a subroutine is entered by a jump operation known as a call; provision is made to return control to the main program at the end of the subroutine. vectored interrupt—An interrupt system in which the interrupt causes a direct branch to that part of the program that services the interrupt. This is the fastest mode of interrupt operation. vector bits—The individual bits that designate the branch location in a vector interrupt instruction. very large-scale integration—Monolithic digital integrated-circuit chips with a typical complexity of 2000 or more gates or gate-equivalent circuits. Abbreviated VLSI. very large-scale programs—Programs that contain more than 10,000 instruction bytes. Abbreviated VLSP. ### WHAT IS A SUBROUTINE? A subroutine can be defined as follows: subroutine—A small subprogram not stored in the main path of the routine. Such a subroutine is entered by a jump operation known as a call; provision is made to return control to the main program at the end of a subroutine. The call instruction causes the microcomputer to transfer program control to the selected subroutine. Subroutines are generally dedicated to specific repeated tasks, so when a task is finished we would like the microcomputer to return to the main program that issued the call and resume operation there. Whenever a call instruction is used, whether it is conditional or unconditional, the microcomputer stores a return address on its *stack* so that we have a way of knowing at which point to return when the subroutine execution is finished. A *stack* is a region of read/write memory that you allocate for the storage of temporary information, such as return addresses from subroutines and the contents of the internal registers within a microprocessor chip. What return address is stored on a stack? Is it always the same 16-bit address? Fig. 8-1 provides answers to these two questions: Once we execute a three-byte call instruction and the associated subroutine, we would like to return to the instruction byte that immediately follows the three-byte call instruction. Thus, the 16-bit address of instruction byte A, shown in Fig. 8-1, is the one that is stored on the stack. If "x" is the 16-bit address of the call instruction, then "x+3" is the 16-bit address that is stored on the stack. Since only eight bits at a time can be stored in the read/write memory of an 8080 microcomputer, two consecutive memory locations in the stack are required to store the full 16-bit return address. The 8080 microprocessor chip automatically stores these two return address bytes on the stack whenever Fig. 8-1. The return address that is stored on the stack is x+3, the address of the instruction byte that immediately follows the three-byte call instruction. $we\ execute\ a\ call\ instruction.$ The process is called $pushing\ an\ address$ on the stack. All subroutines must end, in one way or another, with a return instruction. The return instruction may be conditional or unconditional. In either case, a return causes the 8080 microprocessor chip to retrieve the 16-bit return address from the stack. This address is placed in the chip's program counter, and program execution resumes again at the correct point, such as "x+3" in our example. We do not have to be concerned with the methods that the 8080 chip uses to store or retrieve information from the stack. However, we must be certain that we do have a stack area available in read/write memory before we attempt to call any subroutine. We can locate the stack anywhere within the available 65,536 bytes of memory by using the LXI SP instruction, a three-byte instruction in which the second and third bytes contain the 16-bit stack address, which is stored in a 16-bit register within the 8080 chip that is called a stack pointer register. If you wish, for example, to set the starting address of the stack at HI = 003 and LO = 300, you would use the instruction byte sequence: | LO Memory<br>Address Byte | Octal<br>Instruction<br>Byte | Mnemonic | Comments | |---------------------------|------------------------------|------------|------------------------------------------------------------------------------| | 000 | 061 | LXI SP | Load the stack pointer register<br>with the following two ad-<br>dress bytes | | 001<br>002 | 300<br>003 | 300<br>003 | LO address byte<br>HI address byte | Upon execution of this instruction, the stack pointer will contain the 16-bit address given by HI=003 and LO=300. The setting of the stack pointer is one of the most important initialization conditions that you must execute at the very beginning of an 8080 microcomputer program. In the preceding program, we have assumed that we have only 1K of read/write memory. We have located the stack near the "top" of this memory, i.e., near the highest (or largest) memory locations. The reason for doing so is that the stack, as information is added to it, grows down toward lower memory addresses. In fact, the address HI = 003 and LO = 300 is only a temporary address for the stack. If we were to call a subroutine, we would observe that the return address (also called the linking address) is stored as an 8-bit HI address byte at HI = 003 and LO = 277, and an 8-bit LO address byte at HI = 003 and LO = 276. The stack pointer would then be decremented by two. Most 8080 users are not concerned about the order with which the address is pushed on the stack. For your information, the HI address (or data) byte is always pushed first on the stack and the LO address (or data) byte second. The first byte to be removed, or popped from a stack is always the LO address (or data) byte. This is entirely consistent with the way that the 8080 chip handles three-byte instructions: The LO address (or data) byte is always loaded first into the LO byte of a 16-bit register, such as the program counter, stack pointer, or the register pairs DE, BC, or HL. The stack pointer is always decremented (to a lower address) before data or address information is pushed onto the stack. The stack pointer is always incremented (to a higher address) after data or address information is popped from the stack. If we would examine the stack area in memory after a number of subroutines had used it, we would find that some information was still there. Is this important? Not really, since the appropriate information has long ago been copied back into the 8080 microprocessor chip where it was needed. The old information is meaningless to the microcomputer; the information will be written over whenever the stack is used again. #### USE OF THE STACK FOR DATA AND STATUS STORAGE Most subroutines employ the general-purpose registers or the internal flags within an 8080 chip. Problems occur when we have data in registers that the subroutine will also use. Imagine that the microcomputer is in the middle of a lengthy numerical calculation when a subroutine call is caused by an interrupt. What happens to the temporary data in the registers? Are they destroyed? Must the calculation be repeated? Can we overcome this serious limitation? Clearly, we must have the ability to store the program status, which can be defined as the contents of the internal registers, including the flag bits, that exist inside a microprocessor chip during the execution of a program at a given instant. For an 8080 chip, the status is contained within the following registers: program counter accumulator register B register C register D register E register H register L five flag bits If we know this information, program execution can be interrupted. We store the program status in the stack using a group of four instructions, called *push* instructions and a single call subroutine instruction. At the end of a subroutine, we retrieve the program status using four pop instructions and a subroutine return instruction. The eight push and pop instructions can be listed as follows: | 305<br>325<br>345<br>365 | PUSH B<br>PUSH D<br>PUSH H<br>PUSH PSW | Store contents of register pair B,C on the stack<br>Store contents of register pair D,E on the stack<br>Store contents of register pair H,L on the stack<br>Store program status word (PSW), i.e., the con- | |--------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | tents of the accumulator and the five flags,<br>on the stack | | 301 | POP B | Return the top two stack bytes to the register pair B,C | | 321 | POP D | Return the top two stack bytes to the register pair D,E | | 341 | POP H | Return the top two stack bytes to the register pair H,L | | 361 | POP PSW | Return the top two stack bytes to the accumulator and flag flip-flops | All stack push and pop operations involve either the program counter All stack push and pop operations involve either the program counter or a register pair; they are 16-bit operations that are performed upon two 8-bit bytes, a LO address or data byte and a HI address or data byte. The program status word (PSW) is the accumulator register, A, and the five 8080 chip flags—carry, zero, parity, sign, and auxiliary carry—along with three dummy bits. Fig. 8-2 illustrates the push and pop instructions. SP is the 16-bit address contained in the stack pointer. pop instructions. SP is the 16-bit address contained in the stack pointer register within the 8080 chip. The stack is a last-in first-out (LIFO) stack. The last data that is pushed onto the stack must be the first data to be popped from the stack. This is easy to see with the aid of Fig. 8-3. Note that the push and pop orders are the reverse of each other. In this example, the subroutine did not affect registers D or E, so there was no need to place them on the stack. them on the stack. The push and pop instructions permit great programming flexibility, since we can store our temporary data before a subroutine is executed and retrieve it after we have finished the subroutine. This brings up one interesting question: Would the push and pop instructions be lo- Fig. 8-2. The PUSH and POP operations, each of which involves a register pair and two memory locations. cated before and after the call instruction, or would they be included in the subroutine? Fig. 8-4 presents the two alternatives. The answer to this question is that you would include them in the subroutine. It makes more sense to place them in the subroutine rather than repeat them every time there is a call instruction. The stack thus stores both the return address (the <code>linking address</code>) as well as the original data in all register pairs affected in the subroutine itself. When we assign a location for the stack in read/write memory, we must make Fig. 8-3. Proper procedure for pushing and popping information on the stack. program as needed. certain that there exists sufficient memory for the status information associated with several nested subroutine calls. Since the stack grows down toward lower memory addresses, we usually place the initial stack location at the highest available read/write memory address. Finally, subroutines must contain the same number of push and pop instructions, in reverse order, as well as a conditional or unconditional return instruction. If there conditions are not not apply to the conditional or unconditional return instruction. return instruction. If these conditions are not met, your stack could "run away" in read/write memory and destroy any program or data that exists in read/write memory. For an 8080 microcomputer oper- Fig. 8-4. Two alternatives for locating the PUSH and POP instructions associated with a subroutine call. ated at 2 MHz, it takes only several seconds to wipe out 65,536 mem- ory bytes. Let us finish our discussion with the aid of Fig. 8-5, which shows the contents of the stack after a call and four successive push instructions. Please note the following: - ullet Before we called the subroutine, the original location of the stackpointer was HI = 003<sub>8</sub> and LO = 303<sub>8</sub>. • After we pushed PSW on the stack, the new location of the stack - pointer was HI = 003<sub>8</sub> and LO = 271<sub>8</sub>. We can therefore conclude Fig. 8-5. The stack. that the stack pointer "points" to the top filled memory location in the stack, not the first empty stack location. • The stack is a first-in, last-out stack. The first bytes in were the program counter bytes from the call instruction. They are the last to be popped from the stack. The last bytes in were the flags and accumulator contents; they are the first to be popped out. • The HI byte of the program counter or HI byte of a register pair is the first to be placed on the stack and the last of the two bytes to be removed. When a register pair is popped, the LO byte of the pair always is popped first. • In a push instruction, the HI byte or register is stored in stack location SP - 1 and the LO byte or register is stored in stack location SP - 2. The stack pointer, SP, is decremented by two to produce a new value of the stack pointer. In a pop instruction, the LO byte or register is popped from stack location SP and the HI byte or register is popped from stack location SP + 1. The stack pointer, SP, is incremented by two to produce a new value of the stack pointer. ### WHEN IS A SUBROUTINE USED? When do you use a subroutine? This depends upon two factors: the number of steps in the subroutine, and the number of times you call the subroutine from the main program. Some general rules are as follows: - If the proposed subroutine will contain only three or four instruction bytes, there is little incentive for you to write the subroutine no matter how many times you call it in the main program. - If the proposed subroutine will be used only once in a program or group of programs, you might as well incorporate it into the main program and not use it as a subroutine. - If the proposed subroutine will be used by other people as a component of their programs, then you should definitely write it as a subroutine and pay particular attention to where it is located in memory. - If you wish to minimize the time it takes to perform a group of instructions, you should minimize the number of subroutines present. - You should minimize the length of your main program and maximize the length of your subroutines. Basically, your long-term goal should be to acquire a repertoire of subroutines that make microcomputer programming easy. Your decision on when to use a subroutine can perhaps be facilitated by the use of Fig. 8-6, in which we plot C, the number of times a sub- Number of instruction bytes used in subroutine (less call and return) Fig. 8-6. Diagram indicating when a subroutine should be used routine is used in a main program, versus X, the number of instruction bytes (less call and return instructions) used in the subroutine. We have used the equation $$F = \frac{CX}{X + 4C}$$ to determine when a subroutine should be employed. When F>1, a subroutine should be used; when F<1, a subroutine is not needed. A toss-up situation occurs when F=1 (black squares). In the equation, the quantity CX is the total number of instruction bytes used in the entire main program (less the call and return instructions). The quantity X+4C is related to the number of instruction bytes in the entire main program required to repeatedly call and return from the subroutine. The ratio of these two terms, F, is a measure of their relative importance. You should use your own judgment concerning when to use a subroutine. The authors believe that subroutines will become increasingly important as microcomputers proliferate. In the following sections, a point of view is presented concerning subroutines. ### HARDWARE INTEGRATION: SSI, MSI, LSI, AND VLSI Let us briefly summarize the incredible progress that has occurred in digital electronics within the last ten to fifteen years. This progress is basically reflected in the acronyms SSI, MSI, LSI, and VSLI, which we shall now define: small-scale integration (SSI)—Integrated-circuit chips that provide only simple gates or flip-flops. Such chips usually contain no more than ten to twenty gates. Abbreviated SSI. medium-scale integration (MSI)—Integrated-circuit chips that function as simple, self-contained logic systems, such as decade counters, small read/write memories, decoders, multiplexers, and shift registers. Such chips usually contain from 20 to 100 gates. Abbreviated MSI. large-scale integration (LSI)—Monolithic digital integrated-circuit chips with a typical complexity of 100 or more gates or gate-equivalent circuits. The number of gates per chip used to define LSI depends on the manufacturer. Abbreviated LSI. pends on the manufacturer. Abbreviated LSI. very large-scale integration (VLSI)—Monolithic digital integrated-circuit chips with a typical complexity of 2000 or more gates or gate-equivalent circuits. Abbreviated VLSI. The scale subdivisions are a bit arbitrary. Nevertheless, progress in the area of digital electronics is closely reflected in the scale of integration that has been achieved at any given time. In the mid-1960's, small-scale integration emerged as an important force in electronics. The chips were expensive, and many of them were required to build a useful instrument or computer. By the late 1960's, medium-scale integration began to cut the cost of digital instruments by reducing the chip count and labor required. The early 1970's saw large-scale integration emerge: large memories and UART integrated-circuit chips. The electronics industry barely caught its breath when very-large-scale integration appeared and gave a hint as to the incredible impact that electronics will have still in the future. The 4K random access memories and 8-bit microprocessors provide individuals with an opportunity to construct powerful computers for only several hundred dollars. Yet to come are full computers-on-a-chip, with 4K of RAM, 16K of ROM, and fast multiply/diivde capabilities. They are only a few years away. # SOFTWARE INTEGRATION: SSP, MSP, LSP, AND VLSP You can also observe progress in the area of digital electronics by watching what happens to memory chips. The trends are: New memory chips will contain more memory per chip. The 4K RAMs and 16K ROMs were common in 1975. Not far off are the 16K RAMs and 64K ROMs. Yet to come will be the 64K RAMs and 256K ROMs. You should note that it takes only an 18-bit memory address word to address any location among 262,144 different locations • The fast memory chips will become faster. A tradeoff exists between the size of memory and the basic speed of a memory cell, but improvements in technology are paving the way to large memories that are faster than today's chips. Memory speed and memory size are the important variables for the future. The speed of memory basically determines the execution time of an instruction in a computer. The faster the memory, the more instructions that can be executed in a given period, and the more powerful programs that can be used. The authors believe that a good measure of the progress yet to be made by microcomputers is the length of microcomputer programs employed. Parallel to the abbreviations, SSI, MSI, LSI, and VLSI, they would like to suggest the following indicators of program complexity: $small-scale\ programs\ (SSP)-Programs\ that\ contain\ up\ to\ 100\ instruction\ bytes.$ Abbreviated SSP. medium-scale programs (MSP)—Programs that contain from 100 to 1000 instruction bytes. Abbreviated MSP. large-scale programs (LSP)—Programs that contain from 1000 to 10,000 instruction bytes. Abbreviated LSP. very-large-scale programs (VLSP)—Programs that contain more than 1,000 instruction bytes. Abbreviated VLSP. In order to execute a 10,000 instruction-byte programs, your computer must have both a very large memory and also a very fast one. With an 8-bit computer, 10,000 instruction bytes corresponds to 80,000 memory bits, or 80 kilobits of memory. Have you tried to write a 1000-instruction-byte program? It takes quite a bit of time, especially if the program is carefully written and performs some interesting function. What this discussion is leading up to is the importance of subroutines. A subroutine can be of any length. If a variety of subroutines are readily available, they will save you time since you do not have to rewrite them. Thus, a 1000-instruction-byte program might be very easy to write, provided that it consists of 200 bytes of main program and 800 bytes of subroutines that others have worked out for you. You ought to think about subroutines with every MSP program that you write. What program functions are required? Time delays? Multibit addition, subtraction, multiplication, or division? Put them in subroutines. Do you need to log data from a four-bcd-digit instrument? Write a data logging subroutine in which you can set in the main program the number of points desired and the time between individual points. Do you need to output information to a teletype via a UART chip and 20-mA current loop? Write a software driver, a computer subroutine that handles the data transfer requirements. # THE 8080 SUBROUTINE INSTRUCTIONS We consider there to be 26 subroutine instructions in the 8080 microprocessor instruction set: - $\bullet$ A three-byte unconditional call instruction, CALL - 315 CALL <B2> <B3> Unconditional call of subroutines at memory location addressed by bytes B2 and B3 - A one-byte unconditional return instruction, RET Unconditional return from subroutine 311 RET - Eight different one-byte restart instructions, RST 307 RST 0 Call subroutine at H Call subroutine at $HI = 000_8$ and LO $=000_{8}$ Call subroutine at HI = 0008 and LO 317 RST 1 **327** RST 2 Call subroutine at HI = 000s and LO $= 020_{8}$ Call subroutine at HI = 000<sub>8</sub> and LO 337 RST 3 347 RST 4 Call subroutine at HI = 0008 and LO $= 040_{8}$ Call subroutine at HI = 0008 and LO 357 RST 5 Call subroutine at $HI = 000_8$ and LO367 RST 6 $= 060_8$ Call subroutine at HI = 0008 and LO 377 RST 7 $= 070_{8}$ - Eight different one-byte conditional return instructions 300 RNZ. | | t different one by to | | |-----|-----------------------|-----------------------------------------| | 300 | RNZ | Return from subroutine if zero flag is | | - | 10.12 | at logic 0 | | 310 | R7 | Return from subroutine if zero flag is | | 310 | 1(2) | | | | | at logic 1 | | 320 | RNC | Return from subroutine if carry flag is | | 320 | 10.00 | at logic 0 | | | | | | 330 | RC | Return from subroutine if carry flag is | at logic 1 Return from subroutine if parity flag 340 RPO is at logic 0 | 350 | RPE | | Return from subroutine if parity flag is at logic 1 | |--------|---------|---------------------|----------------------------------------------------------------------------------------------------| | 360 | RP | | Return from subroutine if sign flag is at logic 0 | | 370 | RM | | Return from subroutine if sign flag is at logic 1 | | • Eigh | t diffe | rent three-byte | conditional call instructions | | 304 | CNZ | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>zero flag is at logic 0 | | 314 | | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>zero flag is at logic 1 | | 324 | CNC | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>carry flag is at logic 0 | | 334 | CC | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>carry flag is at logic 1 | | 344 | CPO | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>parity flag is at logic 0 | | 354 | CPE | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>parity flag is at logic 1 | | 364 | CP | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>sign flag is at logic 0 | | 374 | CM | <b2> <b3></b3></b2> | Call subroutine at memory location<br>addressed by bytes B2 and B3 if<br>sign flag is at logic 1 | You may refer to Chapter 3 or the appendix for a more detailed discussion of the above instructions. We need not repeat it here. # THE 8080 STACK INSTRUCTIONS There exist fourteen stack operations in addition to the subroutine instructions given in the above section. We consider a stack instruction to be one in which the location of the stack pointer or the contents of the stack, or both, are altered. Rather than discuss the stack operations in detail, we shall simply list them here and you may refer to Chapter 3 or the appendix for a more extensive discussion. | • A three-byte load in 061 LXI <b2> &lt;</b2> | mmediate instruction, LXI SP (B3> Load immediate two bytes B2 and B3 into the stack pointer register | |-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------| | • A data transfer instr<br>371 SPHL | ruction, SPHL Move the contents of registers H and L to the stack pointer register | | 063 INX SP | decrement instructions, INX SP and DCX SP Increment contents of stack pointer register by one | | 073 DCX SP | Decrement contents of stack pointer register by one | | • An arithmetic instru<br>071 DAD SP | Add contents of stack pointer register<br>to contents of register pair H and L | | | and store in register pair H and L | | • A stack contents ex 343 XTHL | change instruction, XTHL Exchange the top of the stack with the contents of the H and L register pair | | • Four single-byte sta<br>301 POP B | ack pop instructions, POP Pop stack and move contents to register pair B and C. Increment stack pointer register by two | | <b>321</b> POP D | Pop stack and move contents to reg-<br>ister pair D and E. Increment stack<br>pointer register by two | | <b>341</b> POP H | Pop stack and move contents to reg-<br>ister pair H and L. Increment stack<br>pointer register by two | | 361 POP PSW | Pop stack and move contents to ac-<br>cumulator and restore the condition<br>flags. Increment stack pointer regis-<br>ter by two | | • Four single-byte sta | ack push instructions, PUSH Push contents of register pair B and C | | <b>305</b> PUSH B | on stack. Decrement stack pointer register by two | | <b>325</b> PUSH D | Push contents of register pair D and E<br>on stack. Decrement stack pointer<br>register by two | | <b>345</b> PUSH H | Push contents of register pair H and L<br>on stack. Decrement stack pointer<br>register by two | | | 010 | Push contents of accumulator and the condition flags on stack. Decrement stack pointer register by two ### MEMORY ALLOCATION We are about ready to discuss the question "What is a stack?" in greater detail. Before we do so, however, we should briefly consider the *allocation* of memory in a microcomputer. The term *allocate* means: allocate—In a computer, to assign storage locations to main routines and subroutines, thus fixing the absolute values of symbolic addresses Basically, allocation means how we subdivide a memory section or block into smaller groups of locations, each of which contains one of the following: - A main program, at which the microcomputer starts execution. The main program need not be long. In fact, it can mainly consist of calls of subroutines and wait loops. - One or more *subroutines*, where most of the computing work is performed. The subroutines can be time delays, arithmetic calculation routines, software drivers, and service routines, to mention a few types. - Up to eight small interrupt service routines, which respond to different interrupt conditions and restart instructions, RST, jammed into the microcomputer. - A single stack, where temporary information is stored while subroutines are being executed. You can consider the stack to be the computer's bookkeeper. It keeps track of all the subroutines that have been called. Several hypothetical locations for the above groups are illustrated in Fig. 8-7, which fits all of them into the first 1K memory section of the microcomputer. Note that it is not necessary to crowd the different types of memory regions together. The stack, if at all possible, should be separated from the other program regions. This is because it grows from the end of memory toward the beginning. ### MODES OF MICROCOMPUTER OPERATION In this book, we have written only simple microcomputer programs and have constructed quite simple microcomputer interfaces that employ only a few 7400-series integrated-circuit chips (plus the 8212 buffer/latch and the 8095 buffer chips). Although you will continue in the same vein in this chapter as well, the real world of microcom- Memory address H L OOD OOD Interrupt service routines OOD IOO Main program OOI 300 Subroutines OOS 300 Stack Fig. 8-7. A hypothetical memory allocation scheme for the first 1K memory section. Here the stack is located at the top of the memory section, somewhat removed from all other memory regions. puter interfacing will demand from you at least an order-of-magnitude increase in programming and interfacing sophistication. In the real world, you will be required to interface instruments and machines and to communicate between the microcomputer and a teletype, cathoderay tube (crt) display, another microcomputer, a minicomputer, a cassette tape unit, a magnetic disk, and the like. In short, a single 8080 microcomputer may be required to communicate with a number of input/output devices, all of which seek the attention of the microcomputer. How does a single microcomputer handle many I/O devices? It handles only one device at a time! However, the way it handles "only one device" can be quite clever and interesting. There are two main modes of microcomputer operation: polled and interrupt. These modes will now be discussed in turn. ### Polled Operation Graf has defined polling as: polling—Periodic interrogation of each of the devices that share a communications line to determine whether it requires servicing. The multiplexer or control station sends a poll that has the effect of asking the selected device: "Do you have anything to transmit?" 4 When a microcomputer services a device, it simply exchanges digital information with the device in a manner that is prescribed by some segment of the microcomputer program. The particular program segment is frequently called a software driver, which can be defined as: software driver—A subroutine or part of a computer program that transfers information between the computer and a specified input/output device In polled operation, the microcomputer simply sequences through devices tied to the microcomputer looking for individual devices that need servicing. When it finds a device that needs servicing, it stops sequencing, calls up a software driver, and services the device. Once it has finished, it continues sequencing through the devices. Polled operation is most useful with relatively slow devices that do not require frequent servicing, or at least can wait to be serviced. Advantage is taken of the differences in speed between the microcomputer and the polled devices, each of which might be serviced in only a fraction of a second. In 100 ms, the 8080 microcomputer can execute approximately 20,000 instructions. #### Interrupt Operation Graf has defined an interrupt as: interrupt—In a computer, a break in the normal flow of a system or routine such that the flow can be resumed from that point at a later time. The source of the interrupt may be internal or external.<sup>4</sup> Interrupt operation is a much more sophisticated mode of microcomputer operation, one that can circumvent most of the inherent disadvantages of polled operation. Thus, in polled operation: - The microcomputer spends much of its time sequencing through the devices tied to it. - Once a device is serviced, it must wait its turn until all other devices are sequenced and, if necessary, also serviced. In other words, there is no priority in polled operation. All devices are treated equally. - The response time between when a device wants servicing and when it is serviced can be substantial, at least by microcomputer standards. In contrast, in interrupt operation: - The microcomputer may spend much of its time in a wait loop, waiting for a device to ask for servicing. - There can exist *priority* in interrupt operation. The most important devices can be serviced more often than the less important devices. - The response time between when an important device wants servicing and when it is serviced can be very short, even by microcomputer standards. With the 8080 microcomputer, this time is usually no more than 10 μs. - Software becomes much more complex. The terms priority and $response\ time$ are defined in the following ways: priority—The condition in which input/output devices are ordered in importance so that some devices take precedence over others. response time—The time between the interrupt request by a device and the first instruction byte of the software driver that services it. Interrupt operation is depicted schematically in Fig. 8-8. In 8080 microcomputers, an I/O device that interrupts the microcomputer sends both an interrupt clock pulse—a single pulse—as well as an 8-bit instruction byte that tells the microcomputer what to do after it has been interrupted. With the 8080 microcomputer this 8-bit instruction is one of the eight different restart instructions (RST), which are single-byte instructions that call a subroutine at one of eight different locations: HI = 000<sub>8</sub> and LO = 000, 010, 020, 030, 040, 050, 060, or 070<sub>8</sub>. The 8080A microprocessor chip permits multibyte interrupt instructions. We will not discuss this possibility in this book, but be aware that it exists. Clearly, in interrupt operation, the 8080 microcomputer services its devices on demand, perhaps with the aid of priority considerations. If no device needs servicing, the microcomputer simply idles in a wait Fig. 8-8. During an interrupt an 8-bit instruction is "jammed" into the instruction register within the 8080 chip. loop or performs other software tasks. It must be clear that interrupts are complex, require additional software, and are difficult to debug. Many individuals keep their interrupt use to a minimum. ### BASIC TYPES OF INTERRUPTS There exist three types of interrupts: single-line, multilevel, and vectored. They can be defined as follows: single-line interrupt-An interrupt system in which there is a single interrupt line. Multiple devices must be oned to this line. Each input to the on gate is from an I/O device. Once it receives an interrupt, the microcomputer must scan all of the devices to determine which one generated the interrupt. multilevel interrupt-An interrupt system in which there exist many interrupt lines to the microcomputer, each line being tied to a separate I/O device. The microcomputer does not need to scan the devices to determine which one caused the interrupt. vectored interrupt-An interrupt system in which the interrupt causes a direct branch to that part of the program that services the interrupt. This is the fastest mode of interrupt operation. These three types of interrupts are shown schematically in Fig. 8-9. The single-line interrupt is a popular type of interrupt with microcomputers and one that is easy to implement. There exists no limit to the number of devices that can be oned together to a single interrupt line. Three devices are shown in Fig. 8-9A. However, the more devices, the longer the time required to scan them. Priority is determined by the order in which the devices are scanned under software control. The multilevel interrupt, shown in Fig. 8-9B, is an effective technique if a sufficient number of interrupt pins exist on the microprocessor chip. This is rarely the case. Existing microprocessor chips have no more than four interrupt pins. The vectored interrupt technique (Fig. 8-9C) permits direct branching to the part of a program, most likely a subroutine called a service subroutine, that immediately services the interrupt. The interrupt pulse is first sent to the microprocessor chip, followed by an 8-bit single-byte instruction that is jammed into the microprocessor immediately after the interrupt pulse. The Intel 8080 provides eight different restart instructions, as mentioned in a previous section: | 307 | RST 0 | Call subroutine at $HI = 000_8$ and $LO = 000_8$ | |-----|-------|--------------------------------------------------| | 317 | RST 1 | Call subroutine at $HI = 000_8$ and $LO = 010_8$ | | 327 | RST 2 | Call subroutine at $HI = 000_8$ and $LO = 020_8$ | | 337 | RST 3 | Call subroutine at $HI = 000_8$ and $LO = 030_8$ | | 347 | BST 4 | Call subroutine at $HI = 000$ and $LO = 040$ . | Fig. 8-9. Three different types of interrupt techniques. | 357 | RST 5 | Call subroutine at $HI = 000_8$ and $LO = 050_8$ | |-----|-------|--------------------------------------------------| | 367 | BST 6 | Call subroutine at $HI = 000_8$ and $LO = 060_8$ | | 377 | BST 7 | Call subroutine at $HI = 000_8$ and $LO = 070_8$ | You should observe that only three of the eight bits are changed in the above restart (RST) instructions. Intel Corporation has taken advantage of this fact and has provided a special chip, called the 8214 priority interrupt control unit, that contains all the logic needed to: - Cause an interrupt to the 8080 microprocessor chip. Jam three vector bits, in combination with five other vector bits, into the 8080 microprocessor chip immediately after the interrupt. - Provide eight levels of priority, e.g., the eight RST instructions. Provide open-collector outputs for both the interrupt and vector outputs, thus permitting interrupt capability by more than eight The manufacturer's specifications for the chip are shown in Chapter 1. One would expect the interrupt hardware within microprocessor chips to improve with time. The 8080A and 8228 chips permit multibyte instructions to be entered immediately after an interrupt. However, special digital circuitry external to the chip is required to take advantage of this feature. A new interface chip, the Intel 8259 programmable interrupt controller, performs some of these functions. ### ENABLE AND DISABLE INTERRUPT INSTRUCTIONS It is not uncommon for a computer to have a variety of I/O devices connected to it, each demanding attention constantly. The use of priority levels helps with the problem of servicing such devices, but occasionally the computer may want to know that an interrupt has arrived without the necessity of servicing the interrupt. This is particularly true during a complex or time-dependent piece of software. For this purpose, there is a piece of internal circuitry within the microprocessor and software to allow it to turn a "deaf ear" to all interrupts. The circuitry is an interrupt flip-flop or flag (the terms mean the same thing) that can be enabled or disabled by single-byte microcomputer instructions. Some definitions are in order: interrupt flag, interrupt flip-flop-A flip-flop within the microprocessor chip that can be enabled or disabled by microprocessor software and can detect an interrupt pulse and remember the fact that an interrupt occurred. disable interrupt-To disable the interrupt flag within a microprocessor enable interrupt-To enable the interrupt flag within a microprocessor The enable interrupt and disable interrupt instructions in the 8080 microprocessor instruction set are: - 373 EI Enable the interrupt system within the microprocessor chip following the execution of the next instruction. - 363 DI Disable the interrupt system within the microprocessor chip immediately following the execution of this instruc- If the interrupt flag is enabled, then an interrupt will be serviced immediately. However, even if the interrupt flag is disabled, the computer can still detect whether or not an interrupt has occurred. If an interrupt did occur while the interrupt flag was disabled, then an interrupt would occur as soon as the flag is enabled. Only one interrupt event is remembered. ### EXTERNAL FLAGS The term flag has been defined in Chapter 1 as: flag—In a computer, an indication that a particular operation has been completed.<sup>4</sup> Also, a flip-flop that can be either set or cleared in response to operations occurring in the microcomputer. Such a flag can more correctly be called an *internal flag*, since it is located within the circuitry internal to the 8080 microprocessor chip. An extremely important, but quite simple, interface circuit is an *external flag*, which can be defined as follows: external flag-A digital circuit, usually containing a single flip-flop, which indicates a condition that exists with an input/output device. "Internal flag" can be defined in a similar manner. Thus: internal flag—A digital circuit, usually containing a single flip-flop, which indicates a condition that exists internally within the microprocessor chip. The really important word in the preceding definitions is condition. A flag is able to detect a change in condition almost instantaneously; it is then able to remember this condition until it is cleared by a clock pulse from the microprocessor or, if the flag is internal, until the executed program changes the logic state of the flag. It might be more appropriate to call an external flag an external condition flag. This term is redundant, however. External flags indicate the conditions that exist with an input/output device; thus, they are able to synchronize the operation of the device with that of the microcomputer. They are no less important in a properly functioning interfaced microcomputer system than the device select pulses that we discussed previously. The different types of conditions that the flag can indicate include, but are not limited to, the following: - Data is available to be input into the microcomputer from the device. - The device is ready to accept output data from the microcomputer. - The device has finished one operation, and is ready to start a new operation. - The device is busy and does not wish to be disturbed. - A power failure has occurred; the microcomputer must react immediately to save valuable data and programs. - The device is not in operation at the moment. A controlled quantity has exceeded the danger zone. The value of a controlled quantity is too high. - The value of a controlled quantity is too low. A schematic diagram of a typical external flag circuit is shown in Fig. 8-10. The authors prefer this circuit to one that can be constructed from a 7476 J-K flip-flop. The 7474 flip-flop is positive-edge-triggered, whereas the 7476 flip-flop is level-triggered, but both flip-flops are effective. A positive edge clocks the Q output of the flip-flop to logic 1. This logic state is input into a 7400 two-input NAND gate, which inverts the signal and applies logic 0 to the interrupt terminal of the 8080. While signal and appress logic 0 to the interrupt terminal of the 3000, while the 8080 chip itself requires a logic 1 to generate an interrupt at pin 14 on the chip, the figure shows a logic 0 generating the interrupt. This means that the interrupt input is inverted before it enters the 8080. The active low (logic 0) condition is the authors' design condition in the 8080-based microcomputer that they used. The second input on the 7400 NAND gate can be used to gate the interrupt into the microcomputer. If the arm flag within the microprocessor has been previously enabled by an EI instruction, the microcomputer is interrupted and the program branches to a subroutine indicated by an 8-bit instruction that is "jammed" into the computer via external circuitry. The "jammed" instruction is usually a restart instruction, RST n, but may be any other single-byte instruction. You should be aware of the fact that the new 8080A microprocessor chip, available from Intel and others, permits the jamming of a multibyte Fig. 8-10. An external flag circuit instruction, such as a subroutine call, during an interrupt. Extra hardware, including the 8228 chip, is required to do so, however. It is poor design procedure to drive long lines, wires, etc., directly from flip-flop or latch outputs. The 7400 two-input NAND gate has been added to provide the drive capability and to buffer the flip-flop output. A more useful representation of the external flag circuit is shown in Fig. 8-11. This circuit is called "external flag 0," and the following inputs and outputs of the flag are identified: - The condition pulse, which is usually from some instrument or device. - The clear input, CLR-0. A negative clock pulse will clear the flag. - The preset input, PR-0. A negative clock pulse will set the flag. - The flag output, STAT-0. This output is typically sent as input into the microcomputer through a three-state input port. - The interrupt output from the flag, INT-0. A negative clock pulse from this output will interrupt the microcomputer. "External flag 1" would have input $\overline{\text{CLR-1}}$ and $\overline{\text{PR-1}}$ and outputs STAT-1 and $\overline{\text{INT-1}}$ . Similar considerations apply for other flags. # Clearing an External Flag The obvious way to clear an interrupt flag is through the use of the INTA status bit, which goes to logic 1 early in a machine cycle when there is an interrupt condition. This logic 1 state can be inverted and applied to the $\overline{CLR-0}$ input of external flag 0 or any other flag, as shown schematically in Fig. 8-12. shown schematically in Fig. 8-12. The clearing operation can sometimes occur very quickly, in as little as 2 $\mu$ s. A more typical value is 7 $\mu$ s. We will not consider all of the subtleties associated with this type of clearing operation, but Fig. 8-11. Circuit for external flag 0. Fig. 8-12. External flags, such as flag 0, can be cleared via the use of the INTA status signal. the key variables are the instruction being executed and the machine the key Variables are the instruction being executed and the machine cycle within the instruction cycle at the time that the interrupt occurs. It is usually quite desirable to provide a manual clear capability from the front panel of an interfaced instrument. One example of how this can be done is shown in Fig. 8-13. Note that either the INTA signal or the pulser can apply a clear pulse to the flag. Naturally, a 7408 AND gate can be substituted for the combination of a NAND gate and 7404 inverter. An equally interesting type of flag clearing circuit is one in which the clear pulse is generated by software, i.e., via an output device select pulse from the microcomputer. A negative device select pulse is required, and this is noted by the symbol DS, where there is a bar indicating inversion over the letters DS. Circuits employing such a clear signal are shown in Fig. 8-14. ### **Deferred and Immediate Interrupts** The terms deferred interrupt and immediate interrupt can be defined as follows: deferred interrupt-A computer interrupt that occurs at some time after an external flag goes to logic 1. immediate interrupt-A computer interrupt that occurs as soon as an external flag goes to logic 1. An example of an immediate interrupt is where the interrupting signal is applied directly to the 8080's interrupt input (pin 14). For external flag 0, as soon as STAT-0 goes to logic 1, INT-0 goes to logic 0 and the microcomputer is interrupted. A simple deferred interrupt circuit is shown in Fig. 8-15. The reason why the circuit is deferred is that you can control when INT goes to logic 0 by the gating signal DS 0028. Naturally, this signal is generated by the microcomputer software, so a considerable period can elapse between the time that Q goes to logic 1 and the time that the output from the 7400 Fig. 8-13. A circuit that permits both a manual and an interrupt acknowledge input to the clear input of external flag 0. (B) 0038 and manual clear. Fig. 8-14. Use of device select pulses to clear external flag 0. NAND gate goes to logic 0. You will see this in another example in this chapter. This circuit is an example of how software can replace hardware. With the DS 002<sub>8</sub> device select pulse, you can control the time delay. This circuit is exceedibly model in called intermed and the control of th delay. This circuit is especially useful in polled interrupt systems; the device select pulse serves as the polling signal. ### **External Flag Output** Not too many tricks are performed with output STAT-0 from an external flag such as external flag 0. Usually, you input this bit into the microcomputer. Thus, for the STAT-4 output from external flag 4, you can use either of the three-state circuits shown in Fig. 8-16. These circuits employ three-state buffers such as the 74125 or 74126. You may recall that we talked about these buffers in Chapter 7 in Bugbook II. A device select pulse, generated by an IN instruction, is used to input data into the accumulator. The pin configurations for the two chips are provided in Fig. 8-17. If you wish to input the STAT outputs from several external flags, the authors would recommend the use of an 8212 three-state buffer/ latch chip (Fig. 8-18). Such a circuit is very useful in polled interrupt operation. Once you have input the logic states of the external flags Fig. 8-15. A deferred interrupt circuit. INT does not become logic 0 until both Q is logic 1 and a device select pulse is applied to the 7400 NAND gate. Fig. 8-16. The use of three-state buffers to input status bits into the 8080. into the microcomputer, you can perform logical manipulations and rotations to determine which flags are at a logic 1 state, which are at logic 0, which have changed from logic 0 to logic 1, and which have changed from logic 1 to logic 0. You can use any of these conditions or logic state changes to call subroutines that service the devices tied to the external flags. As a final point, the sequence of events that occurs in conjunction with an interrupt can be listed as follows: - The external flag output, STAT, goes to logic 1. - Essentially immediately (if an immediate interrupt) or after some time delay (if a deferred interrupt), a logic 0 is applied to the interrupt terminal, INT. - A pulse is generated by the microprocessor chip to acknowledge the interrupt (INTA). This pulse can be used to "jam" a single-byte instruction into the microprocessor chip and, if desired, to also clear the flag. - The external flag is cleared as soon as it receives the clear pulse. STAT returns to logic 0 and INT returns to logic 1. The vector restart instruction, RST n, is applied to the data bus only during the interrupt acknowledge ( $\overline{\text{INTA}}$ ) time. Unlike all other input bytes, the 8-bit restart instruction byte goes directly to the instruction register within the 8080 microprocessor chip, where it is executed. We shall discuss vector restart instructions in a later example. Fig. 8-17. Pin configurations of the 74125 and 74126 three-state buffer chips. For the 74125 chip a logic 0 enables the buffer; in the 74126 a logic 1 enable signal is required. #### Single-Line Interrupt (Polled Interrupt) If you have only a single interrupt terminal and are not able to employ the vector interrupt feature of the 8080 microcomputer, you can still wire the circuit shown in Fig. 8-19. You can poll the four external flags with the aid of four different device select pulses, each gated with an external flag in the manner shown in Fig. 8-20. #### INTERRUPT MASK In polled interrupt operation, you typically sense the logic states of the external flags with the aid of a status register (Fig. 8-18), which inputs the bits into the accumulator of the microcomputer. Once the bits are in the accumulator, the question arises: What do you do next? You have several possibilities: - Rotate each bit, in turn, into the carry flag and employ a conditional call instruction that is dependent upon whether the carry flag is at logic 0 or logic 1. In this way, you poll the status of each external flag and are able to call the subroutine required if a given flag is set. - Mask each 8-bit sense word with a mask word that basically makes it easy to determine whether a given external flag is set or cleared. Once the mask operation has been completed, different arithmetic or logical operations can be employed to immediately determine whether the external flag is set or cleared. Once this is done, a conditional call instruction can be employed. Typically an AND operation does the masking. The term mask can be defined in the following manner: mask—A logical technique in which certain bits of a word are blanked out or inhibited.4 Fig. 8-19. If any of the interrupt inputs, <u>INT-n</u>, to the 72H21 AND gate become logic 0, an interrupt signal is output from the gate. It is useful to give an example of a *mask operation*. Assume that there exist eight different external flags that are attached to the following devices: | Flag Number | Device | |-------------|--------------------------| | 0 | Teletype | | 1 | Paper tape reader | | 2 | Cathode-ray-tube display | | 3 | Minicomputer | | 4 | Temperature recorder | | 5 | Digital voltmeter | | 6 | Pressure indicator | | 7 | Unassigned | Each device has its own external flag, and all eight flags are connected to a 8212 status register. If we wish to determine whether or not the microcomputer flag is set, i.e., at logic 1, we can employ the following program: | LO Memory<br>Address | Octal<br>Instruction | Mnemonic | Comments | |----------------------|----------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | | | | | | | | | 150 | 333 | IN | Generate input device select pulse<br>that inputs the flag bits at the<br>status register into the accumu-<br>lator | | 151 | 001 | 001 | Device code for status register | | 152 | 346 | ANI | And the contents of the accumula-<br>tor with the following mask word | | 153 | 010 | 010 | Mask word that masks all flag bits<br>except flag bit 3 | | 154 | 302 | JNZ | If the contents of the accumulator are not zero, jump to the memory location given by the following address bytes. Otherwise, ignore this instruction | Fig. 8-20. The INT-n is not generated until both STAT-n and DS-n are at logic 1. This permits you to "poll" each external flag using software. | 7 | | | |------------|------------|------------------------------------| | 155<br>156 | 000<br>002 | LO address byte<br>HI address byte | | • | • | | | | • | | | | | | Presumably a service routine is present at memory location H = 002and L = 000 to handle the situation when the external flag for the minicomputer is set. # INTERFACING A KEYBOARD In this section we shall discuss how to interface an ASCII keyboard. Some of the schematics shown will be simplified for clarity. Recall the keyboard example in Chapter 7 where you input a keyboard code and compared it with the ASCII code for the letter E. The flowchart was as shown in Fig. 8-21. The program remains in a very tight input loop, even when no key is pressed and no ASCII code is properted to input next OM. Such a program is inafficient in that it very ugit input 100p, even when no key is pressed and no ASCII code is present at input port 004. Such a program is inefficient in that it wastes the valuable time of the microcomputer, which could be performing more meaningful tasks. #### Flag Bit Testing Fig. 8-21. Flowchart that tests an input charac-ter to determine whether or not it is ASCII character E. When an E is finally detected, the program outputs it, stores it, and then comes to a halt. Most ASCII keyboards generate a short output pulse, which is called READY or VALID, each time a key is pressed on the keyboard. In the case of one keyboard, this pulse has a duration of $1~\mu s$ , a pulse width that is much too short to be entered directly into the microcomputer. 329 The reason is that most timing loops that test for a single input bit consume at least 12 $\mu$ s for a 2-MHz microcomputer. For a 1- $\mu$ s input pulse, the odds are that 92 percent of the time it will not be detected. The solution to this problem is to connect the VALID output signal from the keyboard to an external flag, the output of which is input and tested by the microcomputer. A simplified circuit is shown in Fig. 8-22. The 7474 flip-flop is the flag, which is clocked to a logic 1 output state by the 1-µs signal pulse from the keyboard. The microcomputer program tests for the logic state of the flag output, clears the flag with device select pulse OUT 065, and inputs the keyboard data into the accumulator. The actual program is as follows: | LO Memor | y Octal | | | |---------------|-------------|----------|---------------------------------------------------------------------------------------------------| | $Add\tau ess$ | Instruction | Mnemonic | Comments | | 000 | 333 | IN | Input flag data from 8212 status register | | 001 | 017 | 017 | Device code for 8212 status register | | 002 | 346 | ANI | Mask the accumulator contents with the following data byte | | 003 | 010 | 010 | Mask data byte for input bit D3 | | 004 | 312 | JZ | If the result of the masking operation is zero, jump to HI = 000 and LO = 000 and test flag again | | 005 | 000 | | LO address byte | | 006 | 000 | | HI address byte | | 007 | 323 | OUT | Clear the flag by sending a device select<br>pulse to the CLR input | | 010 | 065 | 065 | Device code for CLR input of flag | | 011 | 333 | IN | Input keyboard data into the accumulator | | 012 | 005 | 005 | Device code for 8212 input port | | 013 | | | | | 014 | | | | The flowchart for this program is provided in Fig. 8-23. Flag bit D3 can be tested in other ways, such as by rotating it into the carry bit and testing the carry bit with a JC or JNC instruction. There are many different ways to test status or flag bits. When the keyboard/microcomputer system is first turned on, it is important to initialize the system by clearing all flags. Traditionally, this has been done through the use of one or more manual RESET switches, which are gated with device select pulses such as $\overline{\text{OUT 065}}.$ An alternative to the use of manual switches is a short initialization program that generates all necessary clear flag pulses, including $\overline{\text{OUT 065}}$ . # **Vectored Interrupts** Even though the VALID flag testing program is more efficient than the program in Chapter 7 that simply input keyboard data, most microcomputers have more important things to do than monitor a single flag bit. In some cases, hundreds of flags need to be tested. In other cases, the microcomputer is performing a complex mathematical calculation Fig. 8-22. Simplified circuit that demonstrates how the VALID flag from the keyboard is tested by the 8080 microcomputer. that requires considerable computation time. The point is that most microcomputers should be interfaced in such a way that they respond only when a key is pressed on the keyboard; at all other times, the keyboard is ignored. A good typist will type five to ten characters per second, or 100 to 200 ms per ASCII character. This is very slow by microcomputer standards, and the microcomputer can be doing many other things between keystrokes. However, once a key is pressed, it would be useful for the microcomputer to respond immediately. With an 8080-based microcomputer, "immediate" response can be accomplished through the use of vectored interrupts. A vectored interrupt has been previously defined in this chapter as an interrupt system in which the interrupt causes a direct branch to that part of the program that services the interrupt. The necessary circuitry for our keyboard example is shown in Fig. 8-24. Observe that the 8212 input port remains the same, but that the VALID pulse is now input to the INTERRUPT input of our 8080-based microcomputer. In this case, the interrupt input requires a negative interrupt pulse; if you input directly into the 8080 microprocessor chip, you will require a positive interrupt pulse, INT. Once the 8080 chip receives an interrupt pulse, and if the interrupt flag within the chip has been previously enabled by an enable interrupt instruction, EI, the 8080 finishes the execution of its current instruction and then sends out an interrupt acknowledge signal, $\overline{\text{INTA}}$ , that is used to gate a single-byte restart instruction, RST n, directly into the instruc- Fig. 8-23. Flowchart for the program that tests for the VALID flag. When VALID = 1, a single character is entered from the keyboard. Fig. 8-24. Simplified vector interrupt for the ASCII character keyboard. If there are other interrupting devices in the system, a NAND gate must be used prior to the INTERRUPT input on the 8080 chip. tion register within the 8080 chip. This is the only time in which you can, using an external three-state buffer chip, input directly into the instruction register rather than the accumulator or other general-purpose register. In effect, you "jam" an instruction byte into the instruction register. The hardware used to jam an instruction byte is shown in Fig. 8-24. It consists of an 8-bit gated driver chip that is called the interrupt instruction port. In Fig. 8-24 the jammed instruction is a RST 5, or 357, instruction, which causes the microcomputer to immediately go to the subroutine located at HI = 000 and LO = 050. Let us examine the software required for a vectored interrupt system. Since the RST n is a call subroutine instruction, you must first set up a stack pointer within read/write memory. You then write an enable interrupt instruction, EI, to permit the 8080 microprocessor chip to be interrupted by an external signal applied at the INT input pin. Next, you jump to an area of memory that we shall call MAIN TASK. This is the main program, most likely located in ROM or EPROM, that will be periodically interrupted MAIN TASK. be periodically interrupted. MAIN TASK can be located anywhere in memory, but the authors recommend that it be located away from the interrupt service routines area of memory, which starts at HI = 000 and merrupt service routines area of memory, which starts at HI = 000 and LO = 000 and continues to approximately HI = 000 and LO = 077. Note, however, that the final interrupt subroutine location, at LO = 070, can accommodate a subroutine of any length. We can summarize the preceding comments by listing the program that we have developed so far. Thus: | LO<br>Memory<br>Address | Octal<br>Instruc-<br>tion | Mnemonic | Comments | |-------------------------|---------------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------| | 000 | 061 | LXI SP | Locate the stack within read/write mem-<br>ory by inputing the following two ad-<br>dress bytes into the stack pointer within<br>the 8080 chip | | 001 | 300 | 300 | LO address byte | | 002 | 003 | 003 | HI address byte | | 003 | 373 | EI | Enable the interrupt flag within the 8080 chip | | 004 | 303 | JMP | Jump to MAIN TASK | | 005 | * | • | LO address byte of MAIN TASK | | 006 | * | | HI address byte of MAIN TASK | | | | | | | 050 | 333 | IN | Input keyboard data into the accumulator<br>Device code for 8212 input port | | 051 | 005 | 005 | Device code for 6212 input port | | : | hased sor | urica routine M | contains other software associated with the key-<br>lost likely, there is a jump instruction to some | | • | other me | nory address av | way from the interrupt service subroutine area. | | 057 | 311 | RET | Return from subroutine, the last instruc-<br>tion in the keyboard service routine | It should be clear that an interrupt from the keyboard will force the microcomputer to jam a RST 5 instruction into the instruction register. Upon execution, this instruction byte will call the keyboard service routine that starts at $\rm HI=000$ and $\rm LO=050$ . This subroutine ends with a RET statement, which permits the microcomputer to return to MAIN TASK, which could be a simple control loop or a complicated mathematical program. They keyboard service routine will usually be short and not consume much time. The preceding program will work, but if you try to execute it, you will observe a number of operating difficulties. First, you will not be able to execute the keyboard service routine more than once. Why not? You have failed to re-enable the interrupt flag within the 8080 chip. Remember the following rule: During an interrupt machine cycle, the internal interrupt flag within the 8080 chip is first disabled, then an interrupt acknowledge signal, $\overline{\text{INTA}}$ , is generated to permit a RST n instruction to be jammed into the instruction register. The key point here is that the interrupt flag is disabled to prevent further interrupts while the microcomputer is servicing the current interrupt. If you wish to re-enable the interrupt flag, you must do so by providing an EI instruction in the interrupt service routine. The interrupt flag is not automatically enabled. It is common practice to provide an enable interrupt instruction, EI, immediately before the RET instruction of the interrupt service subroutine. Since the interrupt flag does not become active until after the next instruction has been executed, you can return to MAIN TASK before another interrupt is accepted by the 8080 chip. If this capability were not provided, there would be the danger that you would fill much of read/write memory with linking return addresses waiting to be used, because interrupt service routines were interrupted again, before they had a chance to return. In all other respects, you treat your vector subroutines as normal subroutines. If the contents of the registers are important, you use the PUSH and POP instructions to save and restore registers. A typical interrupt subroutine would appear as shown in Fig. 8-25. Since there exist only seven memory locations between our vector address at LO = 050 and the next vector address at LO = 060, you will not be able to fit in four PUSH instructions, four POP instructions, one EI instruction, one RET instruction, and the keyboard service instructions without encroaching on the next one or two vector subroutine locations. Instead, you place a jump instruction at LO = 050, 051, and 052 that transfers control to an area of memory where you will have more room for software. At the end of the service routine, the RET instruction will still return program control to the point where the MAIN Fig. 8-25. A typical interrupt subroutine. The first instructions, the PUSH instructions, save the microcomputer status. Near the end of the subroutine, the microcomputer status is popped back into the internal registers. TASK was interrupted. The relationship between the MAIN TASK, vector jump instruction at $\rm HI=000$ and $\rm LO=050$ , and keyboard service software is shown in Fig. 8-26. The interfacing of the keyboard could have been made more complex. For example, deferred interrupts or priority interrupts could have been used. In the preceding example, there was little incentive to do so. # PRIORITY INTERRUPTS Priority interrupts are interrupts that are ordered in importance so that some interrupting devices take precedence over others. They are Fig. 8-26. Relationship between MAIN TASK, the vector subroutine jump, and the keyboard service software, which is located elsewhere in memory. used whenever a number of interrupts can occur at the same time, or whenever there is a need to determine which interrupting devices are the most important. Of various ways to establish priority, the easiest way is to set priority in software and then to poll the interrupting devices and determine which devices should be serviced in which order. For example, consider the interface circuit in Fig. 8-27. Three interrupts are shown, but many more could be included in a practical system. An interrupt occurs whenever one of the flag flip-flops becomes set by a pulse at its clock input. We show this as a positive interrupt pulse, which is what is required for most 8080-based microcomputers. If the interrupt pulse is applied directly to the 8080 chip, a 7410 chip should be used, as shown in Fig. 8-27. When the 8080 accepts the interrupt, it generates an INTA pulse that gates the RST instruction code 357, which is pre- Fig. 8-27. Polled interrupt circuit that consists of three interrupting devices. The positive interrupt pulse is connected directly to the INT input pin on the 8080 microprocessor chip. wired at the interrupt instruction port, directly into the instruction register. Upon execution of the RST 5 instruction, a subroutine at HI=000 and LO=050 is called. The RST 5 instruction causes a *vector*, or branch, to the indicated subroutine, where the software polling of the interrupting devices takes place. interrupting devices takes place. Each flag bit for the one-hour clock, keyboard, and cassette shown in Fig. 8-27 is input at logic 1 to the 7410 three-input NAND gate if service is not needed, and as logic 0 if service is needed. The normal logic state of the output from the 7410 gate is logic 0; a positive clock pulse at this output is required to interrupt most 8080-based microcomputers. In the program, which is given below, the priority is set so that the tape cassette has the highest priority (high-speed device), the keyboard is next in priority (low-speed device), and the one-hour clock is last in priority (unbelievably slow device). The software is as follows: | - | | | | |---------|----------|----------|----------------------------------------------------------------------------------------------------------| | LO | Octal | | | | Memory | Instruc- | | - · | | Address | tion | Mnemonic | Comments | | 050 | 333 | IN | Input status bits of three flags | | 051 | 057 | 057 | Device code for 8212 input port | | 052 | 057 | CMA | Complement the status bits $(1 \rightarrow 0 \text{ and } 0 \rightarrow 1)$ | | 053 | 346 | ANI | Mask out all bits except bits D0, D1, and D2 | | 054 | 007 | 007 | Mask byte | | 055 | 037 | RAR | Rotate accumulator contents right through carry (bit D0 is rotated into the carry bit) | | 056 | 332 | JС | If carry bit is logic 1, jump to the cassette service routine located at HI = 003 and LO = 100 | | 057 | 100 | | LO address byte of cassette service routine | | 060 | 003 | | HI address byte of cassette service routine | | 061 | 037 | RAR | Rotate accumulator contents right once again (bit D1 is now rotated into the carry bit) | | 062 | 332 | JС | If carry bit is logic 1, jump to the keyboard service routine located at HI = 003 and LO = 200 | | 063 | 200 | | LO address byte of keyboard service routine | | 064 | 003 | | HI address byte of keyboard service routine | | 065 | 037 | RAR | Rotate accumulator contents right (bit D2 is now rotated into the carry bit) | | 066 | 332 | JC. | If carry bit is logic 1, jump to the one-hour clock service routine located at HI = 003 and LO = 300 | | 067 | 300 | | LO address byte of one-hour clock service rou-<br>tine | | 070 | 003 | | HI address byte of one-hour clock service rou-<br>tine | | 071 | 166 | HLT | If you got to this point, something is wrong. The microcomputer is halted; find out what the problem is. | Note the use of the CMA instruction at LO = 052. Normally, the flag would be at logic 1 if service is needed and logic 0 if service is not needed. In the example in Fig. 8-26 the situation is just the opposite. The use of the CMA instruction illustrates how easy it is to invert eight bits of accumulator data. The ANI instruction at LO = 053 masks out bits D3 through D7 as an illustration of how a masking operation can be used. However, since RAR instructions are used, and since we keep track of how many times we rotate the accumulator contents, the ANI instruction is not really needed here. Other bit-testing methods could be implemented in software. These service routines are very similar to those used with regular vector service routines, as shown in Fig. 8-25. Such routines generally end with an enable interrupt instruction, EI, and a return instruction, RET. Even when polling is used, we still must return to the main program that was interrupted. The above polling routine runs through vector addresses LO=060 and LO=070. This is not an error; there exist no other interrupts which use these vector addresses. Other variations in the polling program are possible. Since the interrupt flags are input into the accumulator, we may wish to save the contents of the accumulator and flags at the time that MAIN TASK was interrupted. To do so, we would provide a PUSH PSW instruction at LO = 050. Each service subroutine would require a POP PSW instruction immediately before the EI instruction. Other PUSH and POP instructions would be required to save the register contents. Finally, it is quite likely that the first instruction in each service routine would clear the flag associated with the subroutine. Thus, as shown in Fig. 8-27, an $\overline{OUT}$ $\overline{O11}$ pulse would clear the cassette flag, an $\overline{OUT}$ $\overline{O12}$ would clear the keyboard flag, and an $\overline{OUT}$ $\overline{O13}$ would clear the one-hour clock flag. The authors have found the above polling program to be very useful in their own work. Other polling software schemes will work equally well, but the one given above is simple and effective. The one-hour clock raises an important question: Why would you build an external one-hour hardware clock when you already have software to do the same thing in under 50 instruction bytes? The answer to this question depends on how you use your computer. If your computer can sit and do the one-hour software and nothing else, or if you are using interrupts and can tolerate a small amount of error in the hour time-delay subroutine (owing to the time that the microcomputer spends with the interrupts), then use software. If you need to know the exact time, use hardware. Remember, when you use interrupts and interrupt service routines, you are essentially interjecting additional software into the MAIN TASK program flow. This additional software takes time. You must not only check the interrupting device, but you must also service it. If you interrupt a one-hour software time delay routine four times with a two-minute device service routine, the execu- tion of the time delay routine will take one hour and eight minutes rather than one hour. The one-hour software routine operations are suspended when there is an interrupt that requires some other task to be performed. The one-hour external clock can be called a *real-time clock*, since it keeps real time, as opposed to microcomputer software time. # HARDWARE PRIORITY INTERRUPTS Interrupt priorities may also be generated using hardware. Hardware priority interrupts are very important when a number of interrupting devices are connected to a microcomputer and all require relatively fast service. The "gimmick" employed is simple: Each interrupting device generates its own restart instruction, RST n, which, when input into the 8080 microcomputer, causes an immediate vector to location HI = 000 and LO = 0N0, where N can be 0, 1, 2, 3, 4, 5, 6, or 7. In addition, priority is automatically assigned by the hardware, so that device 7 has higher priority than device 6, which has higher priority than device 5, etc. In other words, if > represents priority, then: The circuit that you would use is shown in Fig. 8-28. The 74148 eight-line-to-three-line priority-encoder integrated-circuit chip is a sixteen-pin chip that has the pin configuration and truth table shown in Fig. 8-29. Note that the data inputs and outputs are active at the low logic level. The 74148 chip will accept up to eight logic 0 inputs from flags, such as those shown in Fig. 8-28 and will output the binary code for the highest numbered input that is at logic 0. For Fig. 8-28. Hardware priority interrupt circuit that generates eight different vector restart instructions, RST n, that have priority 7>6>5>4>3>2>1>0. Fig. 8-29. Pin configuration and truth table for the 74148 eight-line-to-one-line priority encoder chip. example, if you have simultaneous interrupt requests from both device 5 and device 7, device 7 has the higher priority and the 74148 chip and inverters will supply an octal 7 for the middle octal digit in the restart instruction, 3N7. This vectors the program to location HI = 000 and LO = 070. The RST 0 instruction is not often used since its only effect is to reset the microcomputer and start the MAIN TASK program again. Fig. 8-28 has been simplified for clarity. The necessary flags and flag clearing lines are not shown. Additional hardware refinements could be added to the circuit to make it more efficient. These would include an additional 7442 decoder to generate the flag clearing pulses without using OUT instructions, and a mask register so that various devices could be masked on or off via external hardware. The modified circuit is shown in Fig. 8-30. It is a very sophisticated priority interrupt scheme that provides great flexibility in the use of vectored interrupts in conjunction with an 8080-based microcomputer. You must first decide which devices will be allowed to interrupt the microcomputer and which will not. You develop an 8-bit mask pattern in which interrupting devices are assigned a logic 1 and noninterrupting devices are assigned a logic 0. These eight bits are output from the accumulator to the two 7475 latches shown at the left in Fig. 8-30. An OUT 030 instruction is used for this purpose. Bit position D7 corresponds to interrupting device 7, which has the highest priority and can generate a vector to the address HI = 000 and LO = 070. Those devices that are masked will probably use a status register input to request service, as shown previously in this chapter. Interrupt requests from flags are gated with the on gates (one is shown at the left of Fig. 8-30) tied to the 7475 mask register and non-masked interrupt requests are passed to the 74100 8-bit latch. Whenever the interrupt flag within the 8080 chip is enabled, INTE is high and enables the 74100 chip. The actions of the 74148 priority encoder and interrupt instruction port have been described previously. When Fig. 8-30. Example of a sophisticated priority interrupt circuit that generates individual flag clear pulses and has a mask register so that devices can be masked on or off via external hardware. the interrupt is received by the 8080 chip, it disables its internal interrupt enable flip-flop and the INTE output returns to logic 0, latching any interrupts present at the 74100 chip. The $\overline{\rm INTA}$ signal not only inputs the RST n instruction byte; it also pulses the 7442 decoder to produce a clear pulse that clears the flip-flop associated with the vector interrupt currently being serviced. Many other interrupt schemes can be used, including those based upon the Intel 8214 priority interrupt control unit. The Intel 8259 programmable interrupt controller can generate eight vectored priority interrupts for an 8080 microprocessor chip and is cascadable for up to 64 vectored priority interrupts without additional circuitry. Although interrupts permit fast response to external events or demands for service, their use requires some degree of sophistication in both hardware and software. #### PRIORITY INTERRUPT SOFTWARE As the final topic in this chapter, let us consider the software required for a priority interrupt system. Assume that we have only two interrupting devices: high-priority device 7 and low-priority device 2. Each device generates its own restart instruction byte, which causes a vector to either location ${\rm LO}=070$ or ${\rm LO}=020$ , respectively. Also assume that the high-priority device interrupts the main program, called MAIN TASK, on a regular basis and is quickly serviced via software. Device 2, the low-priority device, is assumed to interrupt on an irregular schedule. It requires considerable time to service. For example, device 2 could be another microcomputer that is dumping blocks of data into our microcomputer. The most important software is the MAIN TASK software that is executed whenever the external devices are not being serviced. If the software were not important, it would not be the "main task" performed by our microcomputer. Early in MAIN TASK, we locate the stack pointer with an LXI SP intruction and also enable the interrupt flip-flop using an EI instruction. Since the interrupts can occur at any time, both PUSH and POP instructions are required in the interrupt service routines. Such instructions will save and restore any registers that are altered in the service routines. The execution of the software can be graphically represented by a time line, as shown in Fig. 8-31. Notice that the high-priority device has interrupted MAIN TASK four times, whereas the low-priority device has only interrupted once. The high-priority device interrupts on a regular basis, as shown by its spacing on the MAIN TASK time line. The heavy line indicates when the interrupt is enabled. Fig. 8-32 shows a more realistic time line. The time line in Fig. 8-31 is somewhat deceptive since only the time spent in MAIN TASK is Fig. 8-31. Program execution time line for MAIN TASK. Interrupts by the high- and low-priority devices are denoted by the symbols \* and $\Delta$ , respectively. shown. It is more correct to show the real time spent in both MAIN TASK and in the subroutines. In Fig. 8-32 the MAIN TASK starts oper-TASK and in the subroutines. In Fig. 8-32 the MAIN TASK starts operating and is interrupted by the high-priority device. After executing the high-priority device service subroutine, control is returned to MAIN TASK, which is interrupted by the low-priority device later on the time line. Control is eventually returned to MAIN TASK, which is then interrupted at repeated intervals by the high-priority device. Clearly, it takes considerably longer to reach the end of MAIN TASK when it is repeatedly interrupted by other devices, each requiring service. During a critical timing period, such interruptions would be disastrous if we are relying on programmed time-delay loops to generate the time delay. We have assumed that the high-priority device interrupts on a regular basis. It probably tried to interrupt the execution of the law priority. lar basis. It probably tried to interrupt the execution of the low-priority Fig. 8-32. Program execution time line for MAIN TASK and both the low- and high-priority service subroutine shown in Fig. 8-32. If high had a higher priority than low, why didn't an interrupt occur? The answer is that the interrupt flag within the 8080 chip was not enabled during the execution of the low-priority device service subroutine. In our first attempt at writing the interrupt service software, we forgot to take this possibility into account. As a result, data or signals from the high-priority device were lost during the low-priority device service software. We can correct our software easily by placing the enable interrupt instruction, EI, at the beginning of the low-priority device service subroutine. We can also design hardware to store data or signals that occur during a missed interrupt. By moving the enable interrupt instruction, EI, to the beginning of the low-priority device service subroutine, we may encounter a new problem: a chopped-up low-priority device software flow, as shown in Fig. 8-33. To emphasize the point, we have assumed that the highpriority device interrupts the low-priority device service software twice, chopping the low-priority software into three pieces. With the lowpriority device software so split up, we must inquire whether we are able to complete the low-priority software before the low-priority device generates a new interrupt. It is entirely possible for the low-priority device to interrupt the microcomputer while it is still trying to service the last interrupt request from the low-priority device. While the interrupt response is fast, the actual execution time may be much slower than the time required for a single pass through the interrupt service software. This is a consequence of the fact that we can interrupt our interrupts. Such considerations should give you a good idea of the care needed when using priority interrupts. It is very easy for a microcomputer to become interrupt bound, i.e., it spends all of its time checking and servicing interrupts and has no time left for its MAIN TASK software. In our MAIN TASK software, we may wish to prevent interrupts from occurring during sensitive time-delay software or complex time-dependent tasks or calculations. The disable interrupt instruction, DI, allows the microcomputer to be immune to external interrupts. Such a Fig. 8-33. Program execution time line that demonstrates the interrupting of an interrupt service routine. The "low" interrupt software is interrupted twice by the "high" priority device. Fig. 8-34. Program execution time line that demonstrates the use of DI and EI instructions to permit a critical task to be performed in MAIN TASK. In this case, however, an interrupt is missed or delayed while the critical task is being executed. situation is shown in Fig. 8-34. The interrupt flip-flop is disabled to permit a critical task to be performed, and then re-enabled. Unfortunately, the time line for the execution of MAIN TASK shows that an interrupt from the high-priority device was missed. Without additional, and usually complex, hardware as a back up, it is very easy to loose signals or data from interrupting devices while the interrupt flag is disabled. The important point here is that we do not know when an external device will interrupt MAIN TASK, and we cannot be sure that it will not do so during the period that the interrupt flip-flop is disabled. How do we circumvent this problem? It isn't easy, and this is why we must use a great deal of caution when using interrupts. Another type of interrupt which may be of interest is a time-oriented Another type of interrupt which may be of interest is a *time-oriented interrupt*. Only one interrupt is used: a clock. The clock interrupts every 10 milliseconds, or other reasonable period. When interrupted, the microcomputer uses a look-up table to determine which devices to check to see if they need service. Some devices are always checked, while other slower devices might be checked once every one thousand times. This is a useful technique, but it requires considerable amounts of software to work well. The newer 8080-type microprocessor chips permit multibyte instructions to be input during an interrupt, so that a complete three-instruction-byte call or jump could be inserted. The ability to "jam" a three-byte instruction eliminates the need to use the restart instructions and associated vector locations, and provide you with much greater flexibility in the use of hardware and software. It appears that the Intel 8259 programmable interrupt controller will allow you to perform direct calls to interrupt service subroutines, but it is a complex device, not for the beginner. We shall finish this chapter with some final notes of caution. Interrupts are difficult to debug. Since interrupts can occur at almost any time, typical software debugging programs are difficult to apply; most are ineffective. Special diagnostic software is required to test interrupts in specific applications. If you can avoid the use of interrupts, do so. Spend your valuable time on other noninterrupt approaches, if possible. Your efforts will usually be well rewarded. #### TEST This test probes your understanding of the interrupt techniques discussed in this chapter. Please write your answers on a separate piece of paper. - 8-1. Describe how the following sequence of stack instructions are loaded on the stack: PUSH D, PUSH B, PUSH PSW, PUSH H. - 8-2. Draw a simple circuit for an external flag and explain all of the inputs and outputs. - 8-3. A small routine requires four instruction bytes and is used ten times in an 8080 microcomputer program. Explain how you would decide whether or not the routine should be made into a subroutine, complete with a return instruction. - $\bf 8-4. \ Describe the different types of subroutine instructions in the 8080 microprocessor instruction set.$ - 8-5. Describe the different types of stack instructions in the 8080 microprocessor instruction set. - $\ensuremath{\mathbf{8-6.}}$ Explain the differences between the following types of interrupts: deferred vectored single-line immediate multilevel polled Your performance on this test will be acceptable if you can answer all of the above questions correctly in a 90-minute closed-book examination. # WHAT HAVE YOU ACCOMPLISHED IN THIS CHAPTER? It was stated at the beginning of this chapter that at the end you would be able to do the following: - Define the terms: subroutine, SSI, MSI, LSI, allocate, stack, interrupt, polling, software driver, vectored interrupt, disabled interrupt, external flag, deferred interrupt, and sense register. Definitions for these terms have been provided in the chapter in several locations. - Explain how you would mask an 8-bit word to obtain the logic state of bit 5. - As an example, we provided a simple program in which bit 3 in an 8-bit word was masked. You should be able to apply similar techniques to bit 5. - Explain how digital information is loaded and removed from the 8080 microcomputer stack. Wo did this in conjunction with Fig. 8-3 which is a very interesting - We did this in conjunction with Fig. 8-3, which is a very interesting diagram of a typical stack. - Perform an approximate calculation that will tell you when to use a subroutine. - See Fig. 8-6 and the associated discussion. - Describe how you would interface an ASCII keyboard. This subject is discussed in considerable detail near the end of the chanter. # APPENDIX 1 # References The references that are cited by superscripts in this book are as - 1. Charles L. Garfinkel, of Keithley Instruments, Inc., is the originator of this definition. - 2. Donald Eadie, Introduction to the Basic Computer, Prentice-Hall, Inc., Englewood Cliffs, New Jersey, 1973. - 3. Texas Instruments, Inc., Microprocessor Handbook, Dallas, Texas, - 4. Rudolf F. Graf, Modern Dictionary of Electronics, Howard W. - Sams & Company, Inc., Indianapolis, 1977. 5. Microdata Corp., Microprogramming Handbook, Santa Ana, California, 1971. - 6. Abraham Marcus and John D. Lenk, Computers for Technicians, Prentice-Hall, Inc., Englewood Cliffs, New Jersey, 1973. - 7. Intel Corp., Intel 8080 Assembly Language Programming Manual, Santa Clara, California, 1974. - 8. Intel Corp., Intel Intellec 8/Mod 80 Microcomputer Development System Reference Manual, Santa Clara, California, 1975. - 9. Intel Corp., Intel 8080 Microcomputer Systems User's Manual, Santa Clara, California, July, 1975. - 10. J. Blukis and M. Baker, Practical Digital Electronics, Hewlett-Packard Company, Santa Clara, California, 1974. - 11. An Introduction to Microcomputers, Adam Osborne and Associates, Inc., Berkeley, California, 1975. - 12. The Intel literature is available from Intel Corporation, 3065 Bowers Avenue, Santa Clara, California 95051 [telephone: (408) 246-7051], or from their dealers, representatives, and distributors. - The cards can be obtained from Tychon, Inc., P. O. Box 242, Blacksburg, Virginia 24060. Charles J. Sippl and David A. Kidd, Microcomputer Dictionary and Guide, Matrix Publishers, Inc., Champaign, Illinois, 1976. # APPENDIX 2 # The 8080A Instruction Set This appendix summarizes all of the important characteristics of each instruction in the 8080A instruction set: the number of machine cycles, the number of states, the type of memory addressing, and the flags that are influenced upon execution of the instruction. A description of each instruction is provided and, in some cases, examples of its use are given. # MICROCOMPUTER PROGRAMMING Unless you have a background in computer science or possess a special knack for computer programming, you will probably find machine level and assembly level programming somewhat tedious and difficult initially. There does not appear to be any shortcut to learning programming. In due time you will become sufficiently familiar with your instruction set and with programming tricks to be able to write programs of modest size with little effort. You will be able to apply skills that you learn with one instruction set to other instruction sets, whether they are for microcomputers, minicomputers, or even mainframe computers. If you are interested in high-level languages, you do not have long to wait. In addition to the MITS BASIC package, a BASIC 8080 software package from the Livermore Laboratory and an 8080 FORTRAN compiler (Control Logic, Inc.) are available. The Livermore software is available through the Intel User's Group, "Insite." The point to note, however, is that you probably will need to learn some assembly language programming. Simple programs and sub- routines can be written as easily and quickly in assembly language as they can in a higher-level language; such programs are also executed more quickly, require less memory, and are probably easier to understand. You will need to learn assembly language programming in order to understand other assembly programs that receive widespread distribution. Finally, a knowledge of assembly language programming provides the basis for understanding and comparing instruction sets. If you have someone else do your programming, it will be expensive; if you do it yourself, it will also be expensive. However, if you can adapt other programs to your applications, your programming costs will be less. # SOURCES OF 8080 PROGRAMMING INFORMATION Here is a list of some sources for 8080/8080A programming information that the authors have found useful: Intel Corporation, Intel 8080 Microcomputer Systems User's Manual, Intel Corporation, 3605 Bowers Avenue, Santa Clara, California 95051, 810 Chapter 4 provides a summary of the 8080/8080A instruction set. For each type of instruction, the number of machine cycles required to execute the instruction are listed. If the instruction has two possible execution times, both times are listed. Significant data addressing modes are listed, as are the flags that are affected by the execution of the instruction. Other chapters discuss the functions of a computer, the 8080 CPU, techniques of interfacing to the 8080, and the 8080 family of hardware components. If you are doing serious work with 8080 microcomputers, you should have this manual. Intel Corporation, Intel 8080 Assembly Language Programming Manual, Intel Corporation, 3605 Bowers Avenue, Santa Clara, California 95051. An excellent manual that discusses such topics as the program counter, stack pointer, computer program representation in memory, memory addressing, condition bits, assembly language, and the entire 8080 instruction set. Also discussed is the use of macros, or macroin-structions, which are extremely important in assembly language programming. This manual is the one that you will need if you do programming with the 8080 Intel cross-assembler, or if you read programs that are cross-assembled using the Intel software package. Many of the programs in the Intel library can be understood with the aid of this manual. NEC Microcomputers, Inc., The μCOM-8 Software Manual, NEC Microcomputers, Inc., 5 Militia Drive, Lexington, Massachusetts 02173, \$10. A superb manual that provides the following sample programming • A simple sensing device A gated counter A programmed real-time motor controller An N-way program branch - An interrupt subroutine program A 10-Hz Teletype I/O subroutine - A 16-digit bcd add or subtract subroutine - A data-move operation in memory Macroprogramming and conditional assembly Excellent descriptions are provided for individual 8080 instructions. Flowcharts are provided for each programming problem. For the student who has some experience with 8080 assembly lan- guage programming, this manual will demonstrate a number of very useful programming techniques. 4. Intel Corporation, Intel 8-bit User's Program Library, Intel Corporation, User's Library, Microcomputer Systems, 3065 Bowers Avenue, Santa Clara, California 95051. Membership is available on a 12month basis to those contributing an acceptable program to the applicable library or by paying a \$100 membership fee. Programs submitted to the User's Library must be accompanied by the Microcomputer User's Library Submittal Form. Full-size copies may be ordered from the Software Marketing Group at Intel. This form is used by the User's Library Manager in preparing the catalog and updates, and the description of the "Function" is used in preparations of the "Function" is used in preparations. and updates, and the description of the runction is used in prepara-tion of the catalog index which is sent to prospective subscribers. This form is also used as the prefix to each program contained in the library, and therefore should be carefully prepared. On the back of the Library Submittal Form are detailed instructions for program sub-mittal which should be closely adhered to. These documentation standards are maintained to ensure the usability of each library program by every interested member. Read carefully items 2, 3, and 4 in the instructions for program submittal to the User's Library. The program cannot be a duplication of a program that already is in the library. The program should be of a program that already is in the library. The program should be error-free and must be in standard Intel language (4004, 4040, 8008, 8080, or PL/M). Submit a typed source listing and a paper tape. The original User's Library package had an update on December 8, 1975, a second update in September, 1976, followed by updates every two months. As of September, 1976, there were 200 programs in the library. It is the most extensive library of programs for any microcomputer. Source tapes are available for a small handling fee. The Administrator of the User's Library is Ms. Marianne Vilas. The User's library saves time in the development of 8080 programs. All of the programs can be modified or tailored to meet specific applications. During 1975, the Intel Corporation sponsored a 22-week User's Library Contest which substantially expanded the User's - Library. Some of the programs that you will find in the library include the following. - DATA ARRAY Move (8080). A contiguous array of data may be relocated in memory, regardless of the magnitude and direction of the move. The source and destination array locations may overlap. The maximum array size is 216 bytes. - Paper-Tape Labeler (8080). Accepts ASCII character from teletype keyboard and punches corresponding alphanumeric character on tape. - Text Storage Program (8080). Allows text to be stored in memory using a letter of the alphabet as a pointer. After the message is stored, it can be retrieved by depressing a single key on the teletype. Up to 32 messages may be stored and retrieved independently. - CLOCK SUBROUTINE (8080). Maintains a current time of day, decimal adjusted in bcd, of hours, minutes, and seconds. Must be invoked by external hardware once each 1.00000 second, usually by an external interrupt. Time is stored in three bytes of memory, in the 24-hour system, or, optionally, in the 12-hour system. - Timesharing Communications (8080). To communicate with a medium- to large-scale computer system as an external timesharer user. - IBM SELECTRIC OUTPUT PROGRAM (8080). Allows IBM Selectric Model 731 to be used as an output device. - 8080 IDLE ANALYZER FOR APPROXIMATING CPU UTILIZATION (8080). Displays amount of time 8080 would have spent in an idle loop. When RUN time is compared with idle time, the percent of CPU utilization can be calculated. Time display is in memory in ASCII. - INTERRUPT SERVICE ROUTINE (8080). Handles multiple-level interrupts, saving all registers and flags and outputing the status of the current interrupt to an external status latch. - 8080 DIS-ASSEMBLER (8080 PL/M). This program inputs a hexadecimal tape and generates a symbolic assembly language program suitable for modifications and/or assembling. - MEMORY DIAGNOSTIC PROGRAM (8080). Writes test bytes in any range of memory and compares the written bit combination with what is read. Upon detection of a defective memory location, an error message is printed specifying the address, reference, and actual values. - MATH (8080). Routines for fixed- and floating-point arithmetic together with a demonstration program that performs algebraic evaluation (from left to right with no operator precedence) and allows unlimited parentheses nesting. - ELEMENTARY FUNCTION PACKAGE (8080). Calculates the following floating-point values with five-decimal-digit precision: square root, logarithm, exponential function, sine, cosine, arc tangent, hyperbolic sine, and hyperbolic cosine. Adds, subtracts, multiplies, and - divides with seven-decimal-digit floating-point precision. (Note: The authors have used this program and like it very much. The entire program requires approximately 2500 bytes of memory.) - 8080 FLOATING-POINT PACKAGE WITH BCD CONVERSION ROUTINE (8080). Performs floating-point addition, subtraction, multiplication, division, fixing, floating, negation, and conversion from floating point bcd with exponent. - 8080 Least-Squares Quadratic Fitting Routine (8080). Performs summations and matrix manipulation for fitting up to 256 floating-point X, Y pairs to a function of the form: $aX^2 + bX + c = Y$ . - N-Byte Binary Multiplication and Leading Zero Blanking (8080). The program performs binary multiplication on two numbers and returns a result that may be up to 255 bytes in length. - 8080 Cross-Compiler on the PDP-11 (8080). Accepts input in a format familiar to PDP-11 users and produces a fully coded listing, symbol table, and punched tape for use with the standard loader. - PAGE LISTING PROGRAM (8080). Provides facility for listing information in a paginated, numbered format. This is accomplished through the system software with the console printer. - SOURCE PAPER TAPE TO MAGNETIC CASSETTE (8080). Will copy a source paper tape onto a magnetic cassette. End statement must be followed by a carriage return. Program will ignore leading blanks. - NATURAL LOGARITHM (8080). Computes the natural logarithm of numbers between 1 and 65,535. - BCD MULTIPLICATION (8080). Multiplies up to a six-digit BCD number by a four-digit bcd number providing a ten-digit bcd result. All numbers are unsigned. - Double-Precision Multiple (8080 PL/M). Multiplies two 16-bit numbers, returning the most significant sixteen bits (in address form) through the appropriate registers to the calling program. The intrinsic PL/M multiply capability is employed for the byte-by-byte multiplications. - SUBROUTINE Log. This subroutine takes the log to any integer base of any positive floating-point number. - 5. Scelbi Computer Consulting, Inc., 1322 Rear Post Road, Milford, Connecticut 06460. - The following software is available: - Machine Language Programming for the 8008 (and similar microcomputers), \$19.95 An 8080 Assembler Program, \$17.95 - An 8080 Editor Program, \$14.95 8080 Monitor Routines, \$11.95 - SCELBAL. SCientific ELementary BAsic Language for 8008/8080 Systems, \$49.00 - SCELBI's First Book of Computer Games for the 8008/8080, \$14.95 SCELBI's GALAXY GAME for the 8008/8080, \$14.95 Nat Wadsworth writes well. You can pick up many microcomputer programming techniques from the above. Unfortunately, tapes are not available. 6. Zilog Corporation, Z80-CPU Technical Manual, Zilog, Inc., 170 State Street, Los Altos, California 94022, \$7.50. You do not obtain many programming hints from this manual, but it is very interesting to compare the Z80 chip with the 8080A in terms of the instruction set. 7. Byte, Byte Publications, Inc., 70 Main Street, Peterborough, New Hampshire 03458, \$12 per year, \$22 per two years, or \$30 per three The individual articles vary in quality but you will find useful programs and programming techniques discussed in this journal, which is one of the magazines that is aimed at the hobby microcomputer market. 8. National Semiconductor Corp., PACE Logic Designer's Guide to Programmed Equivalents to TTL Functions, National Semiconductor Corporation, 2900 Semiconductor Drive, Santa Clara, California 95051, \$5.00. Although it is for an entirely different microprocessor, the 16-bit PACE, this book does an excellent job of demonstrating the substitution of software for hardware. Hardware circuits are provided and described. Programs are then provided that duplicate the basic functions of the hardware. With some knowledge of the PACE instruction set, you should be able to convert the programs to Intel 8080 language. The advantages of 16-bit operations are certainly evident. 9. Kilobaud, Kilobaud, Peterborough, New Hampshire 03458, \$15 per year, \$36 for three years, \$155 for life subscription. In the same category as Byte, i.e., the magazine is directed toward the hobby market. A useful magazine. 10. Adam Osborne and Associates, Inc., P. O. Box 2036, Berkeley, California 94702. The following books are available for 8080 users: An Introduction to Microcomputers. Volume I. Basic Concepts, \$7.50 An Introduction to Microcomputers. Volume II. Some Real Products,, \$12.50 8080 Programming for Logic Design, \$7.50 All of these books belong in the library of any serious user of 8080 systems. In some cases, they provide information that is not available anywhere else. 11. W. J. Weller, A. V. Shatzel, and H. Y. Nice, Practical Microcomputer Programming. The Intel 8080, Northern Technology Books, P. O. Box 62, Evanston, Illinois 60204, \$21.95. We found this book to be quite useful in the development of programming skills, including small assembly language algorithms. # 8080 INSTRUCTION SET SUMMARIES Machine code and assembly language summaries of the 8080 instruction set are available from a number of different sources: - Intel Corporation, Intel 8080 Assembly Language Reference Card, Intel Corporation, 3065 Bowers Avenue, Santa Clara, California 95051. - Provides a hexadecimal listing of the 8080 instruction set as well as a listing by instruction function. Hexadecimal-ASCII listing is also provided. - Tychon, Inc., 8080 Octal/Hexadecimal Code Cards, Tychon, Inc., P. O. Box 242, Blacksburg, Virginia 24060. - A sliding insert permits you to rapidly find the 8-bit octal or hexadecimal instruction code for an assembly language instruction. Flag status after an instruction is also indicated. - 3. Martin Research, 8080 Instruction Set, 3336 Commercial Ave., North-Brook, Illinois 60062. - Subdivides the 8080 instruction set by function. Compact statement of flag status after different types of instructions are executed. - R. Baker, Byte, p. 84 (February 1976). Compact octal code listing of the 8080 instruction set. - P. R. Rony, D. G. Larsen, and J. A. Titus, The 8080A Bugbook: Microcomputer Interfacing and Programming, Howard W. Sams & Co., - Inc., 4300 West 62nd St., Indianapolis, Indiana 46268. The 8080 instruction set is given as an instruction group listing, an alphabetic listing of mnemonics, and an octal/hexadecimal numerical listing. The octal/hexadecimal listing provides a handy conversion table for octal to hexadecimal, and vice versa. # DESCRIPTION OF INDIVIDUAL 8080 INSTRUCTIONS We now shall proceed to describe the 8080 instruction set in detail. We shall use material from both the Intel 8080 Microcomputer Systems User's Manual and the µCOM-8 Software Manual, courtesy of Intel Corporation and NEC Microcomputers, Inc., respectively. For your use, several pages are provided from the Intel manual to help you understand the significance of the terms, symbols, and abbreviations used in the description of each instruction. Intel groups the 8080 instructions as: Data Transfer Group: Move data between registers or between memory and registers - ARITHMETIC GROUP: Add, subtract, increment, or decrement data in registers or in memory - LOGICAL GROUPS: AND, OR, exclusive-or, compare, rotate, or complement data in registers in memory. - Branch Group: Conditional and unconditional jump instructions, subroutine call instructions, and return instructions. - STACK, I/O, AND MACHINE CONTROL GROUP: Includes I/O instructions, as well as instructions for maintaining the stack and internal control flags. #### INSTRUCTION SET A computer, no matter how sophisticated, can only do what it is "told" to do. One "tells" the computer what to do via a series of coded instructions referred to as a Program. The realm of the programmer is referred to as Software, in contrast to the Hardware that comprises the actual computer equipment. A computer's software refers to all of the programs that have been written for that computer. the programs that have been written for that computer. When a computer is designed, the engineers provide the Central Processing Unit (CPU) with the ability to perform a particular set of operations. The CPU is designed such that a specific operation is performed when the CPU control logic decodes a particular instruction. Consequently, the operations that can be performed by a CPU define the computer's Instruction Set. computer's instruction Set. Each computer instruction allows the programmer to initiate the performance of a specific operation. All computers implement certain arithmetic operations in their instruction set, such as an instruction to add the contents of two registers. Often logical operations (e.g., Off the contents of two registers) and register operate instructions set, accomputer's instruction set will also have instructions the computer's instruction set will also have instructions that move data between register, between a register and memory, and between a register and restrict on the performed only if certain conditions have been met; for example, jump to a particular instruction if the result of the last operation was zero. Conditional instructions provide a program with a decision-making capability. By logically organizing a sequence of instructions into By logically organizing a sequence of instructions into a coherent program, the programmer can "tell" the computer to perform a very specific and useful function. The computer, however, can only execute programs whose instructions are in a binary coded form (i.e., a series of 1's and 0's), that is called Machine Code. Because it would be extremely cumbersome to program in machine code, programming languages have been developed. There are programs available which convert the programming language instructions into machine code that can be interpreted by the processor. preted by the processor. One type of programming language is Assembly Language. A unique assembly language memonic is "ssigned to each of the computer's instructions. The programmer can write a program (called the Source Program) using these memonics and certain operands; the source program is then converted into machine instructions (called the Object Code). Each assembly language instruction is converted into one machine code instruction (or or more bytes) by an Assembler program. Assembly languages are usually machine dependent (i.e., they are usually able to run on only one type of computer). #### THE 8080 INSTRUCTION SET The 8080 instruction set includes five different types - Data Transfer Group -- move data between registers or between memory and registers - Arithmetic Group add, subtract, increment or decrement data in registers or in memory. - Logical Group AND, OR, EXCLUSIVE-OR, compare, rotate or complement data in registers or in memory - Branch Group conditional and unconditional jump instructions, subroutine call instructions and return instructions - Stack, I/O and Machine Control Group includes I/O instructions, as well as instructions for maintaining the stack and internal control flags. # Instruction and Data Formats: Memory for the 8080 is organized into 8-bit quantities, called Bytes. Each byte has a unique 16-bit binary address corresponding to its sequential position in memory. The 8080 can directly address up to 65,536 bytes of memory, which may consist of both read-only memory (ROM) elements and random-access memory (RAM) elements (read/ write memory). Data in the 8080 is stored in the form of 8-bit binary LSB When a register or data word contains a binary number, it is necessary to establish the order in which the bits of the number are written, in the Intel 8080, BIT 0 is referred to as the Least Significant Bit (LSB), and BIT 7 (of an B bit number) is referred to as the Most Significant Bit (MSB). The 8080 program instructions may be one, two or three bytes in length. Multiple byte instructions must be stored in successive memory locations; the address of the first byte is always used as the address of the instructions. The exact instruction format will depend on the particular operation to be executed. | Byte Three | D <sub>7</sub> | 1 | 1 | 1 | T | D | |------------|----------------|---|---|---|---|---| | | | | | | | | # Addressing Modes: Often the data that is to be operated on is stored in memory. When multi-byte numeric data is used, the data, like instructions, is stored in successive memory locations, with the least significant byte first, followed by increasingly significant bytes. The 8080 has four different modes for addressing data stored in memory or in registers: - Direct Bytes 2 and 3 of the instruction contain the exact memory address of the data item (the low-order bits of the address are in byte 2, the high-order bits in byte 3). - Register The instruction specifies the register or register-pair in which the data is located. - Register Indirect The instruction specifies a reg-ister-pair which contains the memory address where the data is located (the high-order bits of the address are in the first register of the pair, the low-order bits in the second). Immediate — The instruction contains the data itself. This is either an 8-bit quantity or a 16-bit quantity (least significant byte first, most significant byte second). most significant byte second). Unless directed by an interrupt or branch instruction, the execution of instructions proceeds through consecutively increasing memory locations. A branch instruction can specify the address of the next instruction to be executed in one of two ways: - di no no of two ways: Direct The branch instruction contains the address of the next instruction to be executed. (Except for the "ISST" instruction, byte 2 contains the low-order address and byte 3 the high-order address and byte 3 the high-order address and instruction indicates a register-pair which contains the address of the next instruction to be executed. (The high-order bits of the address are in the first register of the pair, the low-order bits in the second.) The RST instruction is a special one-byte call instruction is a special one-byte call instruc- The RST instruction is a special one-byte call instruc-tion (usually used during interrupt sequences). RST in-cludes a three-bit field; program control is transferred to the instruction whose address is eight times the contents of this three-bit field. #### Condition Flags: or Address There are five condition flags associated with the execution of instructions on the 8080. They are Zero, Sign, Parity, Carry, and Auxiliany Carry, and are each represented by a 1-bit register in the CPU. A flag is "set" by forcing the bit to 1; "reset" by forcing the bit to 0. Unless indicated otherwise, when an instruction affects a flag, it affects it in the following manner: If the result of an instruction has the value 0, this flag is set; otherwise it is reset. If the most significant bit of the result of the operation has the value 1, this flag is set; otherwise it is reset. set; otherwise it is reset. If the modulo 2 sum of the bits of the result of the operation is 0, (i.e., if the result has even parity), this flag is set; otherwise it is reset (i.e., if the result has odd parity). Parity: If the instruction resulted in a carry (from addition), or a borrow (from sub-traction or a comparison) out of the high-order bit, this flag is set; otherwise it is Auxiliary Carry: If the instruction caused a carry out of bit 3 and into bit 4 of the resulting value, the auxiliary carry is set; otherwise it is reset. This flag is affected by single precision additions, subtractions, increments, decrements, ownersions, and logical operations, but is principally used with additions and increments preceding a DAA (Decimal Adjust Accumulator) instruction. instruction. Symbols' and Abbreviations: The following symbols and abbreviations are used in the subsequent description of the 8080 instructions: #### SYMBOLS MEANING | accumulator | Register A | |-------------|------------------------------------| | addr | 16-bit address quantity | | data | 8-bit data quantity | | data 16 | 16-bit data quantity | | byte 2 | The second byte of the instruction | | byte 3 | The third byte of the instruction | 8-bit address of an I/O device r r1 r2 One of the registers A,B,C,D,E,H,L DDD,SSS The bit pattern designating one of the registers A,B,C,D,E,H,L (DDD=destination, SSS=source): | DD 01 333 | REGISTER NAM | |-----------|--------------| | 111 | Α | | 000 | В | | 001 | C | | 010 | D | | 011 | E | | 100 | н | | 101 | Ł | | | | rp One of the register pairs: B represents the B,C pair with B as the high-order register and C as the low-order register; D represents the D,E pair with D as the high-order register and E as the low-order register; H represents the H,L pair with H as the high-order register and L as the low-order register; SP represents the 16-bit stack pointer. The bit pattern designating one of the register pairs B,D,H,SP: | RP | REGISTER PAIR | |---------------|-------------------------------| | 00 | B-C | | 01 | D-E | | 10 | H-L | | 11 | SP | | o first (biob | order) register of a decision | The first (high-order) register of a designated register pair, The second (low-order) register of a designated register pair, rt 16-bit program counter register (PCH and PCL are used to refer to the high-order and low-order 8 bits respectively). 16-bit stack pointer register (SPH and SPL are used to refer to the high-order and low-order 8 bits respectively). rm Bit m of the register r (bits are number 7 through 0 from left to right). Z.S.P.CY.AC The condition flags: Zero, Sign, Parity, Carry, and Auxiliary Carry, respectively. The contents of the memory location or registers enclosed in the parentheses. "Is transferred to" Logical AND Exclusive OR Inclusive OR PC Addition Two's complement subtraction Multiplication "Is exchanged with" The one's complement (e.g., $(\overline{A})$ ) The restart number 0 through 7 The binary representation 000 through 111 for restart number 0 through 7 respectively. #### Description Format: The following pages provide a detailed description of the instruction set of the 8080. Each instruction is described in the following manner: - The MAC 80 assembler format, consisting of the instruction mnemonic and operand fields, is printed in BOLDFACE on left side of first line. - The name of the instruction is enclosed in parenthesis on the right side of the first line. - 3. The next line(s) contain a symbolic description of the operation of the instruction. - 4. This is followed by a narative description of the operation of the instruction. - The following line(s) contain the binary fields and patterns that comprise the machine instruction. - patterns that comprise the machine instruction. 6. The last four lines contain incidental information about the execution of the instruction. The number of machine cycles and states required to execute the instruction are listed first. If the instruction has two possible execution times, as a Conditional Jump, both times will be fissed, separated by a stash. Next, and synginificant data addressing modes are listed. The last line lists any of the five Flags that are affected by the execution of the instruction. rh # DATA TRANSFER GROUP This group of instructions transfers data to and from registers and memory. Condition flags are not affected by any instruction in this group. # MOV r1, r2 The MOV r1, r2 instruction transfers data from the specified source register S (or r2) to the specified destination register D (or r1). The source or destination may be any of the single registers B, C, D, H, or L, the accumulator A, and M (the contents of the memory address specified by the register pair H, L). In the three-octal-digit byte, the first digit is always a 1. The second and third octal digits vary depending upon the source and destination. The octal instruction, 166, is a halt rather than a MOV instruction. The contents of the source register are not changed during a MOV instruction; you are copying the register contents to some other location. #### MOV r,M The MOV r,M instruction transfers data from M (the contents of the memory address specified by the register pair H,L) to the specified destination register r, which may be any of the single registers B, C, D, H, or L, or the accumulator, A. You copy the contents of the memory address into a register; the contents of memory remain unchanged. <sup>\*</sup>The following description of an 8080A instruction, and others like it in the following pages, appears in the Intel 8080 Microcomputer Systems User's Manual and is reprinted in this text through the courtesy of the Intel Corporation, Santa Clara, California 95051. All rights reserved. #### MOV M,r The MOV M,r instruction transfers data from the specified source register r to M (the memory address specified by the register pair H,L). The source register may be any of the single registers B, C, D, E, H, or L, or the accumulator, A. The register contents are copied in memory; the contents of the register remain unchanged. ## MVI r,data The MVI r,data instruction transfers data from the second byte of the two-byte instruction to the specified destination register r. The term immediate refers to the fact that the data byte is contained within the multibyte instruction. The specified destination register may be any of the single registers B, C, D, E, H, or L, the accumulator, A, and M (the contents of the memory address specified by the register pair H,L). When the destination is M, you have the instruction MVI M, data, which is discussed in the following paragraph. The data can be any 8-bit binary number between 00000000 and 111111111. #### MVI M,data The MVI M,data instruction transfers data from the second byte of the instruction to M (the memory address specified by the register pair H,L). The data can be any 8-bit binary number between 00000000 and 111111111. ## LXI rp,data 16 Fig. A-1. The single-byte data transfer instructions MVI r and MOV r1, r2. Only two sets of MOV r1, r2 instructions are shown. Fig. A-2. The two-byte data transfer instructions LXI rp, PCHL, SPHL, and XCHG. PCHL causes a branch to the location initially contained in register pair H. Figs. A-1 and A-2 illustrate some of the characteristics of the MOV, MVI, and LXI instructions. Only two sets of MOV rl,r2 instructions are shown. Note that LXI rp,data is equivalent to two MVI r,data instructions. Thus: LXI B <B2> <B3> is equivalent to: MVI B <B2> (corresponds to <B3> in the LXI B instruction) MVI C <B2> (corresponds to <B2> in the LXI B instruction) The second byte in a two-byte instruction is always referred to as <B2>. A single LXI rp,data instruction requires ten states for its execution, whereas two MVI r,data instructions require a total of fourteen states of execution time. Thus, by using the LXI rp,data instruction, you save four states of execution time. In many cases, however, such a saving is unimportant. # STA addr (Store Accumulator direct) ((byte 3)(byte 2) — (A) The content of the accumulator is moved to the memory location whose address is specified in byte 2 and byte 3 of the instruction. 0 0 1 1 0 0 1 0 low-order addr high-order addr Cycles: 4 States: 13 Addressing: direc Flags: none The STA addr instruction permits you to store the contents of the accumulator directly into a memory location without the use of the register pair H,L. The address of the memory location is specified in the second and third bytes of the instruction. The LO address byte is byte 2 and the HI address byte is byte 3. The STA addr instruction is equivalent to the two-instruction sequence: LXI H <B2> <B3> MOV M,A # LDA addr The LDA addr instruction permits you to load the accumulator with the contents of the memory location specified by bytes B2 and B3 in the instruction. You need not use the H,L register pair. The LO address byte is <B2> and the HI address byte is <B3>. The LDA addr instruction is equivalent to the two-instruction sequence: LXI H <B2> <B3> MOV A,M #### LHLD addr This instruction is useful when memory locations contain address information. Thus, LHLD addr causes the L register to be loaded with the memory byte addressed by bytes B2 and B3 in the instruction, *i.e.*, addr. The H register is loaded with the memory byte located at addr +1. Thus, you perform a 16-bit transfer of a memory address to the register pair H,L. Once you learn XCHG, you will observe that the section of code: LHLD <B2> <B3> XCHG is functionally equivalent to: LXI H <B2> <B3> MOV E,M INX H MOV D,M The first section of code requires 20 states for execution; the second section of code requires 29 states. ## **XCHG** The XCHG instruction causes the contents of the register pairs D,E and H,L to be exchanged. To be specific, the contents of registers D and H are exchanged, and the contents of registers E and L are exchanged. This instruction permits you to use register pair H,L as a memory address while another address is held in register pair D,E. You can modify the contents of register pair D,E, without changing register pair H,L. For example, register pair H,L may specify a memory location that you use to modify register pair D,E. Two XCHG instructions in sequence: XCHG XCHG are equivalent to a no operation. 366 #### SHLD addr (Store H and L direct) ((byte 3)(byte 2) +— (L) ((byte 3)(byte 2) +) —— (H) The content of register L is moved to the memory lo-cation whose address is specified in byte 2 and byte 3. The content of register H is moved to the succeed-ing memory location. Cycles: 5 States: 16 Addressing: direct Flags: none The SHLD addr instruction causes the contents of the L register to be stored at the memory location given by bytes B2 and B3 in the instruction, i.e., addr. The contents of the H register are stored in the memory location, addr + 1. In other words, you perform a 16-bit transfer of an address byte in register pair H,L to two successive memory locations, addr and addr + 1. This instruction is useful in creating a group of memory locations that contain address information rather than data. As for most 8080A instructions, byte B2 is the LO address byte and byte B3 is the HI address byte of addr. The section of code: > XCHG SHLD <B2> <B3> is equivalent to the section of code: LXI H <B2> <B3> MOV M,E INX H MOV M,D #### LDAX rp (Load accumulator indirect) (A) $\leftarrow$ ((rpi) The content of the memory location, whose address is in the register pair rp. is moved to register A. Note: only register pairs rp. B (registers B and C) or rp-D (registers D and E) may be specified. 0 0 R P 1 0 1 0 Cycles: 2 States: 7 Addressing: reg, indirect Flags: none The LDAX rp instruction permits you to load the accumulator with the contents of the memory location addressed by a register pair other than register pair H,L. Thus, with LDAX B, you use register pair B,C to supply the 16-bit memory address; with LDAX D, you use register pair D,E to supply the address. The section of code: LXI D <B2> <B3> LDAX D is functionally identical with: LXI H <B2> <B3> MOV A,M STAX rp (Store accumulator indirect) ((rp)): ← (A) The content of register A is moved to the memory location whose address is in the register pair rp. Note: only register pairs rp=8 (register B and C) or rp=0 (registers D and C) may be specified. Cycles: 2 States: 7 Addressing: reg. indirect The STAX rp instruction permits you to store the contents of the accumulator in the memory location addressed by either register pair B,D or register pair D,E. The section of code: LXI B <B2> <B3> STAX B is identical with: LXI H <B2> <B3> MOV M,A The significance of the STAX $\rm rp$ and LDAX $\rm rp$ instructions is that you can have three independent 16-bit memory addresses stored in the 368 general-purpose registers inside the 8080A microprocessor chip. Enough instructions are available to permit you to use all three addresses. The condition flags are not affected by any of the instructions in the following list: MOV rl,r2 MOV r,M MOV M,r MVI r, data MVI M, data LXI rp, data 16 STA addr LDA addr XCHG LHLD addr SHLD addr LDAX rp STAX rp These instructions comprise the data transfer group in the 8080A microprocessor. # ARITHMETIC GROUP This group of instructions performs arithmetic operations on data in registers and memory. Unless indicated otherwise, all instructions in this group affect the zero, sign, parity, carry, and auxiliary carry flags according to standard rules. All subtraction operations are performed via two's complement arithmetic and set the carry flag to one to indicate a borrow and clear it to indicate no borrow. ## ADD r The ADD r instruction causes the contents of the source register S to be added to the contents of the accumulator. The source register a to be any of the general-purpose registers B, C, D, E, H, L, the accumulator A, or M (the contents of memory as addressed by register pair H,L). The ADD M instruction is described below. The instruction affects all four of the testable flag bits: carry, parity, zero, and sign. The auxiliary carry flag is also affected. ## ADD M The ADD M instruction causes the contents of the memory location M, which is addressed by register pair H,L, to be added to the contents of the accumulator. The memory contents remain unchanged after the addition. The instruction affects all five flags and requires two machine cycles. ## ADI data The ADI data instruction causes the data present in the second byte of the instruction to be added to the contents of the accumulator. The instruction affects all five flags. ## ADC r and ADC M 370 To quote the \$\mu COM-8\$ Software Manual: "In order to perform add and subtract operations, some special arithmetic instructions are required. Multiple-digit arithmetic requires that two items be monitored and saved somewhere. These two items are the sum of the digits as they are added, and the presence or absence of a carry bit. When a carry bit is produced, it must be added to the sum of the next digits. Similarly, with subtract operations, the existence of a borrow must be detected so it can be deducted from the difference of the next digits. The Add with Carry and Subtract with Borrow instructions provide simple monitoring and saving of carry bits, making multidigit addition and subtraction quite straightforward. ADC r, ADC M, and ACI data are the Add with Carry instructions. ADC r causes the contents of the source S to be added to the sum of the accumulator contents and the carry bit." The ADC r and ADC M instructions are similar to the ADD r and ADC M instructions are similar to the ADD r and ADC M instructions are similar to the ADD r and The ADC r and ADC M instructions are similar to the ADD r and ADD M instructions; the only difference is that the carry bit is added to the least-significant bit in the 8-bit accumulator byte. All flags are affected by these instructions. Memory location M is addressed by the contents of register pair H,L. ## ACI data (Add immediate with carry) (A) — (A) + (byte 2) + (CY) The content of the second byte of the instruction and the content of the CY flag are added to the contents of the accumulator. The result is placed in the accumulator. 1 1 1 0 0 1 1 1 1 0 0 data Cycles: 2 States: 7 Addressing: immediate Flags: 2.5.P.CY.AC The ACI data instruction causes the 8-bit data quantity present in the second byte of the instruction to be added to the sum of the accumulator contents and the carry bit. The instruction affects all five flags. # SUB r and SUB M The SUB r instruction causes the contents of the source register S to be subtracted from the accumulator. The source register can be any of the general-purpose registers B, C, D, E, H, and L, the accumulator, A, or M (the contents of memory as addressed by register pair H,L). All five flags are affected by the execution of this instruction. If you wish to clear the accumulator, the single instruction: #### SUB A which has an instruction code of 227, will do it. #### SUI data The SUI data instruction causes the 8-bit data quantity specified in the second instruction byte to be subtracted from the accumulator. All five flags are affected. # SBB r and SBB M The SBB r instruction causes the contents of the source S to be subtracted from the difference of the accumulator contents and the borrow bit. The source register can be any of the general-purpose registers B, C, D, E, H, and L; the accumulator, A; or M, the contents of memory addressed by register pair H,L. All five flags are affected by the SBB r and SBB M instructions. ## SBI data The SBI data instruction causes the 8-bit data quantity specified in the second instruction byte to be subtracted from the difference of the accumulator contents and the borrow bit. All five flags are affected. Some examples of the various addition and subtraction operations would be appropriate. Consider the following program: ADD B ADD C If the initial register contents are A=00111110, B=11100000, and C=00101111, and if the carry bit were initially zero, then the above section of code would yield the following result in the accumulator: | Carry Bit | | | |-----------|-----------|----------------------------| | 0 | 00111110 | accumulator contents | | | +11100000 | register B contents | | 1 | 00011110 | sum stored in accumulator | | | +00101111 | register C contents | | 0 | 01001101 | sum' stored in accumulator | Note carefully the behavior of the carry bit in this situation. If there is no carry out of the most significant bit (MSB) in the accumulator, the carry bit is cleared; if there is a carry out of the most significant bit in the accumulator during the addition, the carry bit is set. When you added B to the accumulator, you had a carry. When you added the contents of C to the sum, there was no carry. The carry from previous operations is not preserved, or "carried forward." Now let us contrast the preceding results with the behavior of the following section of code: ADC B ADC C Assume the same initial values for registers A, B, C, and the carry bit. You would obtain the following results: $\begin{array}{c|cccc} \textit{Carry Bit} \\ 0 & 0.01111110 \\ & + \frac{11100000}{00011110} & \text{accumulator contents} \\ 1 & 0.0011110 & \text{sum stored in accumulator} \end{array}$ So far, there is no difference. However, when we add the contents of register C to the above sum, we do observe a difference: $\begin{array}{c} \textbf{Carry Bit} \\ & 0 \ 0 \ 0 \ 1 \ 1 \ 1 \ 0 \\ & + \ 1 \\ & + \ 0 \ 0 \ 1 \ 0 \ 1 \ 1 \ 1 \ 1 \\ \hline 0 & \hline 0 \ 1 \ 0 \ 0 \ 1 \ 1 \ 1 \ 0 \\ \end{array} \begin{array}{c} \text{sum stored in accumulator} \\ \text{carry bit} \\ \text{register C contents} \\ \text{sum'} \end{array}$ Now consider the following section of code: SUB B SUB C for the same initial values of registers A, B, C, and the carry bit. Note that if you perform a borrow out of the MSB of the accumulator, the carry bit is set; if no borrow occurs, the carry bit is cleared. Thus you should observe the following: $\begin{array}{c|ccccc} \textit{Carry Bit} & & & & & & & \\ 0 & & & 0.0111110 & & & & & \\ & & -11100000 & & & & & \\ 1 & & \hline{01011110} & & & & \\ -00101111 & & & & & \\ 0 & \hline{00101111} & & & & \\ \end{array} \quad \begin{array}{c} \text{accumulator contents} \\ \text{register B contents} \\ \text{difference stored in accumulator} \\ \text{register C contents} \\ \text{difference' stored in accumulator} \\ \end{array}$ Now let us perform subtraction operations using the SBB r instructions: SBB B SBB C We have the following results: Carry Bit 0 001111110 accumulator contents $-\frac{11100000}{01011110}$ accumulator contents 1 001011110 difference stored in accumulator When we perform the SBB C operation, we subtract the contents of register C from the difference between the borrow bit and the contents of the accumulator: $\begin{array}{c} 010111110 \\ - \\ 010101111 \\ 0 \\ \hline \end{array} \begin{array}{c} \text{difference stored in accumulator} \\ \text{register C contents} \\ \text{difference' stored in accumulator} \end{array}$ The ADC r and SBB r instructions are used whenever you perform double- or triple-precision arithmetic operations. A double-precision arithmetic operation is one which is performed on two 16-bit quantities to yield a 16-bit result. A triple-precision operation is one which is performed on two 24-bit quantities to yield a 24-bit result. The preceding examples of addition and subtraction operations are provided courtesy of NEC Microcomputers, Inc., from their $\mu COM$ -8 Software Manual. DAA (Decimal Adjust Accumulator) The sight-bit number in the accumulator is adjusted to form two four-bit Binary-Coded-Decimal digits by the following process: 1. If the value of the least significant 4 bits of the accumulator is greater than 9 or if the AC flag is set, 6 is added to the accumulator. 2. If the value of the most significant 4 bits of the accumulator is now greater than 9, or if the CY flag is set, 6 is added to the most significant 4 bits of the accumulator. NOTE: All flags are affected. O O 1 O O 1 1 1 1 States: 4 Flags: Z,S,P,CY,AC To quote the $\mu COM\text{-}8$ Software Manual: "In order to perform operations in binary coded decimal (bcd), one special instruction is needed. When the 8080A CPU performs an arithmetic operation, it produces the result in binary. When working in bcd this does not produce the correct result. To remedy this, a DAA instruction is used. DAA stands for Decimal Adjust Accumulator, which is exactly what DAA does. The DAA instruction treats the 8-bit Accumulator as two 4-bit Accumulators. Through the use of a nontestable flag known as the Auxiliary Carry, the DAA operation adjusts the result of a binary addition operation to packed bcd. "For example, the DAA instruction causes the following operation. If the Auxiliary Carry is set to one or the least significant nibble (LSN) is greater than 9, six is added to the least significant nibble. Then, if the Carry flag is set to one or the most significant nibble is greater than 9, six is added to the most significant nibble (MSN)." The term nibble is defined as follows: nibble—A group of four contiguous bits that usually represent a bcd digit. The least significant nibble (LSN), most significant nibble (MSN), accumulator, auxiliary carry flag (ACy), and carry flag (Cy) can be represented as shown in Fig. A-3. Assume, as is done in an example in the $\mu COM$ -8 Software Manual, that the accumulator contains the bcd representation for 75 (MSN = 0111 and LSN = 0101), that the B register contains the bcd representation for 38 (MSN = 0011 and LSN = 1000), and the carry flag is logic zero. The instruction ADC B produces the following result in the accumulator: With the auxiliary carry, if the instruction causes a carry out of bit 3 and into bit 4 of the resulting value, the auxiliary carry flag is set; other- Fig. A-3. Identification of the most significant and least significant nibbles wise it is reset. In the preceding example, there is no carry out of bit 3 and into bit 4, so the auxiliary carry bit is zero after the operation. The DAA command finds ACy reset to 0 and LSN = 1101. Because the LSN is greater than nine, six is added to it and the result is 0011. Because the MSN is greater than nine, six is also added to it and the result is 0000. The final result after the DAA operation is: decimal adjusted sum $0\,0\,0\,0\,0\,0\,1\,1$ which is equivalent to the decimal number 103. The DAA operation can be written as follows: Carry Auxiliary Carry Bit Bit1010 +0110+0110DAA Operation result of DAA Operation 00110000 0000 decimal number Thus, 75 + 38 = 103. In actual operation, the DAA adjustment is done in parallel, rather than in the serial manner illustrated. However, this serial explanation, courtesy of the µCOM-8 Software Manual of NEC Microcomputers, Inc., is easier to understand and illustrates the adjustment better. The DAA instruction should immediately follow an addition operation, as certain 8080A instructions alter the state of the auxiliary carry flag. Such an alteration could result in incorrect results. There is an important difference between the Intel 8080A microprocessor chip and the equivalent chip, the $\mu$ COM-8 chip of NEC Microcomputers, Inc. The µCOM-8 chip has an extra nontestable flag called Subtract. To quote from the NEC Manual: "For addition, the Sub flag is set to zero. . . For subtraction, Sub is set to one causing the following DAA operation. If ACy is set to one (a borrow occurred) six is subtracted from the LSN. Then if the Cy is set to one (a borrow occurred) six is subtracted from the MSN. The use of a DAA instruction immediately after an operation on two bytes in packed bcd format adjusts the result to two bcd digits and a carry or borrow in packed bcd format. Note that the DAA operations performs directly after subtraction, eliminating the need for 100's complement arithmetic for subtraction. If you are doing considerable amounts of bcd manipulation, you would be interested in the $\mu$ COM-8 chip in preference to the 8080A. However, such would only be the case if you require the full speed of the microcomputer. With additional instructions, the 8080A can easily accomplish the same task of producing a packed bcd format after a subtraction. # INR r and INR M The INR r instruction causes a one to be added to the destination register D. The destination register can be any of the general-purpose registers B, C, D, E, H, and L; the accumulator, A; or M, the contents of memory as addressed by register pair H,L. All flags are affected except the carry flag. ## DCR r and DCR M The DCR r instruction causes a one to be subtracted from the destination register D. The destination register can be any of the general-purpose registers B, C, D, E, H, and L; the accumulator, A; or M, the contents of memory as addressed by register pair H,L. Only four of the five flags are affected; the carry flag remains unchanged. # INX rp and DCX rp The INX rp causes the register pair specified by rp to be incremented by one; the DCX rp causes the register pair specified by rp to be decremented by one. RP can be the register pair specified by B, D, or H (corresponding to BC, DE, or HL) or the 16-bit stack pointer specified by SP. INX and DCX do not affect any flag bits; they are usually not used in arithmetic operations, their main use being to increment or decrement 16-bit memory addresses. # DAD rp According to the NEC manual: "While the INX and DCX instructions allow incrementing and decrementing register pairs, the DAD, Double Add, instruction allows adding register pairs together. DAD rp causes the register pair specified by rp to be added to the contents of the H,L register pair, with the result remaining in the H,L pair. The Carry Flag is the only status flag affected by the DAD instruction. The instructions INX, DCX, and DAD allow the calculation of table lookup." Also used for indexed addressing and file data manipulation. ## CMP r and CMP M To quote the $\mu$ COM-8 Software Manual: "CMP r and CMP M are used to compare two data quantities without altering them. CMP r compares the contents of the accumulator with one of the single registers B, C, D, E, H, and L; the accumulator, A; or M, the memory location addressed by the H,L register pair. The instruction does not affect any of the data registers, but affects the four flag bits Carry, Zero, Sign, and Parity. The compare instructions actually perform an internal subtraction of the source S from the accumulator. The flags are set on the basis of what would have been the result of the subtraction. Thus Zero is set if the quantities were equal, Sign is set if the result was negative (the most significant bit is logic 1), Parity is set if the result has even parity, and Carry is set if there is a borrow out of bit 7 (source data greater than Accumulator data). "Thus, in every case: Carry is set if a borrow occurs; else reset; Sign is set equal to the MSB of the result; Zero is set if the result is zero; else reset; Parity is set if the parity of the result is even; else reset." The compare instructions are best used for unsigned arithmetic comparison (numbers in the range of 0 to 255<sub>10</sub>), also called logical or character comparisons. For this case, the results for the zero and carry flags may be interpreted as follows: # Result of Compare Operation | esuit of Compare Operation | | Relationship Between Accumulator | |----------------------------|------------|----------------------------------| | Zero Flag | Carry Flag | and Register | | 1 | X | accumulator = register | | $\bar{\mathbf{x}}$ | 1 | accumulator < register | | ī | 1 | $accumulator \leq register$ | | 0 | 0 | accumulator > register | | X | 0 | $accumulator \ge register$ | | | | | Note: X = don't care Thus, the relations =, <, $\geq$ may be tested using a single jump instruction, while $\leq$ , > require two. Note that if the operands are reversed, > replaces $\leq$ and < replaces $\geq$ . #### **CPI** data The CPI data instruction is an immediate operation which compares the contents of the accumulator with the 8-bit quantity in the second byte of the instruction. The instruction affects all five flags, but only four of the flags produce useful results. The flags are set or cleared on the basis of what would have been the result of the subtraction. The contents of the accumulator remain unchanged. See the preceding discussion of the CMP r instruction for additional details. It can be argued that the CMP r and CPI data instructions are logical rather than arithmetic operations. In view of the fact that an arithmetic operation—subtraction—is performed, we include it in the group of arithmetic operations. The objective of the compare instructions is to produce decisions that are reflected in the logic states of the flag bits. #### LOGICAL GROUP This group of instructions performs logical, i.e., Boolean, operations on data in registers and memory and on condition flags. Unless indicated otherwise, all instructions in this group affect the zero, sign, parity, auxiliary carry, and carry flags according to the standard rules. #### ANA r and ANA M The ANA r instruction performs a parallel bit-by-bit logical AND of the contents of the accumulator and the contents of the source register S. The source register can be any of the general-purpose registers B, C, D, E, H, and L; the accumulator, A; or M, the contents of the memory location addressed by the register pair H,L. For example, the ANA B operation performs a bit-by-bit logic AND operation with the contents of register B and the contents of the accumulator. The special case of ## ANA A clears the carry flag and causes the zero flag to be set if the result is zero, cleared if the result is not zero. All of the flags are affected by the ANA r instruction. Since $A \cdot A = A$ , the data in the accumulator is not changed. This is a "trick" to clear the carry flag or simply test for zero in the accumulator. ## ANI data The ANI data instruction performs a bit-by-bit logical and of the contents of the accumulator with the contents of the second byte of the instruction. All flags are affected by the instruction. # ORA r and ORA M The ORA r instruction performs a parallel bit-by-bit logical on of the contents of the accumulator and the contents of the source register S. The source register can be any of the general-purpose registers B, C, D, E, H, and L; the accumulator, A; or M, the contents of the memory location addressed by the register pair H,L. The command #### ORA A which has the octal instruction code 267, is a convenient way to clear the carry flag without affecting anything else. Both ORA r and a related two-byte instruction, ORI data, clear the carry flag and cause the zero flag to be set if the result is zero, or cleared if the result is not zero. #### **ORI** data The ORI data instruction performs a bit-by-bit logical on of the contents of the accumulator with the contents of the second byte of the instruction. All flags are affected by the instruction. ## XRA r and XRA M The XRA r instruction performs a bit-by-bit logical exclusive-on of the contents of the accumulator and the contents of the source register S. The source register can be any of the general-purpose registers B, C, D, E, H, and L; the accumulator, A; or M, the memory location addressed by the register pair H,L. All flags are affected by the instruction. #### XRI data (Exclusive OR immediate) (A) → (A) → (byte 2) The content of the second byte of the instruction is ekclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: 2 States: 7 dressing: immediate Flags: Z,S,P,CY,AC The XRI data instruction performs a bit-by-bit logical exclusive-on of the contents of the accumulator with the contents of the second byte of the instruction. All flags are affected by the instruction. To quote the NEC Microcomputers, Inc., $\mu COM$ -8 Software Manual: "The above logic instructions will be used to implement a programming technique known as masking. Masking is a technique by which bits of an operand are selectively modified for use in a later operation. There are three general types of masking: - Clear all bits not operated upon. Set all bits not operated upon (seldom used). Leave unaltered all bits not operated upon." "The first two approaches are called exclusive masking and the third approach is called inclusive masking. For example, assume that the accumulator contains the following value: Bit: 11011/0110 accumulator contents To test bit 3 for a zero or one and simultaneously clear the other bits, the accumulator is masked with 00001000. By using the instruction > ANI 010 the accumulator will contain zeros with the zero flag set if bit 3 had been a zero, and it will contain 010, in octal code, with the zero flag cleared if bit 3 had been one. "In order to set bit 3 to one and leave the other bits alone, the same bit pattern is used and the instruction > ORI 010 is used. The result in this case is 11011110 in the accumulator. "In order to set bit 3 to zero and leave the other bits alone, the accumulator is and with 1111011, the complement of the mask of the first example. With the instruction ANI 367 the accumulator result is 11010110. These are the most commonly used bit manipulation operations, since masking is accomplished in one step. Many others are possible, but they often require more than one instruction for implementation." #### RAL and RAR The RAL instruction, or rotate accumulator left, causes the accumulator to rotate all bits one position to the left through the carry bit, i.e., a 9-bit rotate. Bit 7 transfers to the carry flag, the carry bit transfers to bit 0, bit 0 transfers to bit 1, bit 1 transfers to bit 2, and so on, as shown in Fig. A-4. The RAR instruction, or rotate accumulator right, causes the accumulator to rotate all bits one position to the right through the carry bit, i.e., a 9-bit rotate. Bit 0 transfers to the carry flag, the carry bit transfers to bit 7, bit 7 transfers to bit 6, bit 6 transfers to bit 5, and so on, as shown in Fig. A-4. The RLC instruction, or rotate left circular, rotates the accumulator one bit to the left and into the carry flag, as shown in Fig. A-4. The RRC instruction, or rotate right circular, rotates the accumulator one bit to the right and into the carry flag, as also shown in Fig. A-4. In both of these instructions, the original information appearing in the carry flag is lost. the carry flag is lost. #### CMA The CMA instruction complements the contents of the accumulator without affecting any of the flag bits. For example, if the accumulator contained 11010001, the CMA instruction would convert it to 00101110. Each individual bit is complemented. # STC and CMC The STC instruction sets the carry flag to logic 1; the CMC instruction complements the carry flag. No other flag bits are affected. #### **BRANCH GROUP** This group of instructions alters normal sequential program flow. Condition flags are not affected by any instruction in this group. The two types of branch instructions are unconditional and conditional. Unconditional transfers simply perform the specified operation on register PC, the program counter. Conditional transfers examine the status of one of the four process flags—zero, sign, parity, or carry—to determine if the specified branch operation is to be executed. The conditions that may be specified are as follows: | | Condition | CCC | |----|-----------------------|-----| | NZ | not zero $(Z = 0)$ | 000 | | ž | zero $(Z=1)$ | 001 | | NC | no carry $(CY = 0)$ | 010 | | Č | carry $(CY = 1)$ | 011 | | PO | parity odd (P = 0) | 100 | | PE | parity even $(P = 1)$ | 101 | | P | plus $(S=0)$ | 110 | | M | minus $(S=1)$ | 111 | | | | | NOTE: CCC is the three-bit code for the condition of the flags ## JMP addr The *program counter* is the 16-bit register in the 8080A microprocessor chip that contains the memory address of the next instruction byte that must be executed in a computer program. The JMP addr instruction is simply a byte transfer instruction, in which the second and third instruction bytes are transferred directly to the program counter. No arithmetic or logical operations are involved, and no flag bits are affected. The JMP instruction is a three-byte instruction that contains the Fig. A-5. Diagram that illustrates the branching characteristics of the JMP instruction. 16-bit memory address to which program control is transferred. You can jump forwards or backwards to any of the 65,536 possible memory locations. The microprocessor chip does not remember the point from which it jumped, in distinct contrast to the behavior of the CALL and RET instructions discussed in the following. The behavior of the JMP instruction can be understood with the aid The behavior of the JMP instruction can be understood with the aid of Fig. A-5. The first JMP instruction, $\odot$ , is a backwards jump that creates a loop. JMP $\odot$ and JMP $\odot$ transfer program control to the subprogram. The exit from the subprogram is to the same place, that designated by the JMP $\odot$ instruction. ## CALL addr and RET Many times you may want to branch out of a main program but return to it later. To do so, you must not only know your new destination, but you must somehow also remember your original location. To accomplish this, you have two types of instructions: call subroutine and return from subroutine. Here we shall discuss the unconditional instructions CALL addr and RET. To quote the NEC Microcomputers, Inc., manual: "The call instruction transfers control to a subroutine. The instruction CALL addr saves the incremented program counter on the pushdown stack and places the address in the program counter. The pushdown stack is a block of read/write memory addressed by a special 16-bit register known as the Stack Pointer which can be loaded by the user (LXI H, data 16). The stack operates as a last-in first-out memory (LIFO), with the Stack Pointer register addressing the most recent entry into the stack. The Return instruction causes the entry at the top of the stack to be placed into the Program Counter. Thus a CALL instruction transfers program control from the main program into the subroutine and a RET instruction transfers control back to the main program." See Fig. A-6. The location of the *stack* is usually at the higher memory addresses in the available memory of an 8080A-based microcomputer. In Fig. A-7, the stack is some distance from the main program and subroutines. the stack is some distance from the main program and subroutines. Fig. A-6. Diagram that demonstrates the branching characteristics of the CALL and RET instructions. Note that the return is always to the instruction byte immediately following the CALL instruction. # JNZ, JZ, JNC, JC, JPO, JPE, JP, and JM addr > Cycles: 3 States: 10 Addressing: immediate Flags: none In a conditional jump instruction, if the condition is satisfied, the second and third bytes of the instruction are transferred to the program counter and a jump occurs. If the condition is not satisfied, no changes occur to the program counter; program control passes to the instruction immediately following the jump. Fig. A-7. Memory map for a typical 8080-based microcomputer. Observe that the stack is lo-cated near the end of memory. The various conditions can be summarized as follows: - The 8-bit result of the immediately preceding arithmetic or logical operation is Not equal to Zero, i.e., the zero flag is NZ: cleared. - $\mathbf{Z}$ : - The 8-bit result of the immediately preceding arithmetic or logical operation is equal to Zero, i.e., the zero flag is set. The 8-bit result of the immediately preceding arithmetic or logical operations produces No Carry out of the most significant bit; or, the carry flag is cleared. NC: - The 8-bit result of the immediately preceding arithmetic or logical operation produces a Carry out of the most signifi-C: - regical operation produces a carry out of the most significant bit; or, the carry flag is set. The 8-bit result of the immediately preceding arithmetic or logical operation has a Parity that is Odd, i.e., the parity flag PO: is cleared. - The 8-bit result of the immediately preceding arithmetic or logical operation has a Parity that is Even, i.e., the parity PE: - The 8-bit result of the immediately preceding arithmetic or logical operation produces a MSB that has a Plus sign, i.e., the sign flag is cleared. P: Fig. A-8. The characteristics of JZ and JNZ instructions. M: The 8-bit result of the immediately preceding arithmetic or logical operation produces a MSB that has a Minus sign, i.e., the sign flag is set. The value of CCC that corresponds to each of the conditions has been shown several pages previously. The behavior of two of the conditional instructions INZ and IZ, can be understood with the aid of Fig. A.8. instructions, JNZ and JZ, can be understood with the aid of Fig. A-8. In the JNZ instruction, the jump occurs only if the 8-bit result or an arithmetic or logical operation is Not Zero. The decision symbol which is used in flowcharting, indicates that what happens next depends upon the state of the zero flag. For JNZ, a jump occurs only if the zero flag is cleared, i.e., at logic 0. For JZ, a jump occurs if the 8-bit result is equal to zero; in such a case the zero flag is at logic 1. It is possible to become confused concerning the conditions NZ and Z. Note that NZ and Z refer to the 8-bit result of an operation, not to the logic state of the zero flag. NZ means that the 8-bit result of an operation is not zero; Z means that the 8-bit result of an operation is zero (though the zero flag is at logic 1). This discussion has tried to demonstrate that a condition can be viewed in terms of the 8-bit result of an arithmetic/logic operation (NZ, Z, NC, C, PO, PE, P, or M) or in terms of the logic state of the individual flags that test the result of an arithmetic/logic operation. The authors prefer the use of the 8-bit result of an ALU operation, including the letter symbols NZ, Z, NC, etc. # CNZ, CZ, CNC, CC, CPO, CPE, CP, and CM addr In a conditional call instruction, if the condition is satisfied, the subroutine at the memory location given in the second and third instruction bytes is called. The contents of the program counter are placed on the stack, so that a return instruction can return program control to the instruction immediately following the conditional call instruction. If the condition is not satisfied, program execution passes to the instruction immediately following the conditional call instruction. # RNZ, RZ, RNC, RC, RPO, RPE, RP, and RM In a conditional return instruction, if the condition is satisfied, a return occurs from the subroutine; the program counter contents on the stack are transferred to the program counter and program execution resumes at the instruction immediately after the subroutine call instruction. Fig. A-9. The characteristics of CZ and CNZ instructions. Fig. A-10. The characteristics of RZ and RNZ instructions. 396 If the condition is not satisfied, the program execution passes to the instruction which is immediately following the conditional return instruction The conditional instructions CZ, CNZ, RZ, and RNZ are depicted schematically in Figs. A-9 and A-10. Remember, Z means that the zero flag must be at logic 1 for a call or return to occur; otherwise, program control passes to the next instruction. NZ means that the zero flag must be at logic 0 for a call or return to occur; otherwise, program control passes to the next instruction. #### RST r To quote the $\mu COM$ -8 Software Manual: "The EI (Enable interrupt) and DI (disable interrupt) instructions provide control over the acceptance of an interrupt request. With this control established, the next problem to be resolved is how does the external device indicate to the processor where the desired interrupt routine is located. The 8080A accomplishes this identification by allowing the device to supply one instruction when the interrupt is acknowledged. Although any 8080A instruction can be specified, only two are of practical value: a Call instruction, CALL, and a Restart instruction, RST... A RST instruction is actually a specialized type of CALL. The instruction RST N is a call to one of eight locations in memory specified by an integer expression in the range, 0 through 7 in octal code, indicated by N. The locations specified by the integers 0 through 7 are listed below. | Value of N | Location Called | |------------|-------------------------| | 0 | HI = 000 and LO = 000 | | 1 | HI = 000 and LO = 010 | | 2 | HI = 000 and LO = 020 | | 3 | HI = 000 and LO = 030 | | 4 | HI = 000 and LO = 040 | | 5 | HI = 000 and LO = 050 | | 6 | HI = 000 and LO = 060 | | 7 | HI = 000 and LO = 070 | "A RST instruction causes the incremented program counter to be pushed onto the stack exactly as a CALL instruction does. It then loads the program counter with HI=000 and LO=0N0, where N is 0 through 7. Thus, RST 4 causes the program counter to be pushed onto the stack and HI=000 and LO=040 to be entered into the program counter. "Program execution then continues from the restart location. If the device service routine requires more than eight bytes to service (as most do), the instruction placed at the Restart point must jump to the interrupt service subroutine. Since RST is actually a specialized subroutine call, the interrupt service subroutine must end with a return instruction, to return control to the interrupted program by popping the return address. "Since the 8080A has only eight RST instructions, any additional levels of interrupt must be implemented using CALL instructions. This means a CALL addr instruction must be supplied by the interrupting device, which is somewhat more difficult to implement in hardware because CALL is a three-byte instruction. However, once implemented, a direct call to a routine is slightly faster than a Restart and subsequent jump operation. Although this is not a major factor, this difference in response speed should be considered when determining how to implement interrupt service routines. The primary benefit realized by using the CALL approach is that n-way interrupt vectoring is achieved in hardware, eliminating the need for software in low order memory (for RST processing). This frees those memory locations for use by user programs and removes a constraint from the system memory design." #### PCHI The PCHL instruction causes the program counter to be loaded with the contents of the H,L register pair. Program execution then continues at the point designated by the content of H,L. In effect, this is a jump instruction, but since the H,L register pair can be operated upon arithmetically, it allows the implementation of a variety of calculated jumps. The instruction sequence: is identical in function with: JMP <B2> <B3> ## STACK, I/O, AND MACHINE CONTROL GROUP This group of instructions performs I/O, manipulates the stack, and alters internal control flags. Unless otherwise specified, condition flags are not affected by any instructions in this group. #### PUSH rp and POP rp To quote the $\mu COM$ -8 Software Manual: "Two special instructions enable programmers to save and restore the registers using the stack, PUSH and POP. PUSH rp causes the register pair specified by rp to be placed at the top of the stack. The stack is a special portion of read/write memory designated by the user and treated as a last-in (Push) ((SP) = 1) --- (rh) ((SP) = 2) --- (rl) ((SP) --- (SP) (Pop) (ri) + ((SP)) (rh) + ((SP) + 1) (SP) + (SP) + 2 The content of the memory location, whose address is specified by the content of register SP, is moved to the low-order register of register pair rp. The content of the memory location, whose address is one more than the content of register SP, is moved to the high-order register of register are. The content of register sP rp. The content of register sP rp. The content of register sP rp. The content of the precisiter SP is incremented by 2. Note: Register pair rp = SP may not be specified. 1 1 R P 0 0 0 1 1 State: 10 Addition: The product of first-out (LIFO) memory through the use of a 16-bit Stack Pointer. A PUSH operation causes the Stack Pointer to decrement by one and store the most significant register (the HI register) in memory at this new location specified by the Stack Pointer. The Stack Pointer is then decremented again and the least significant register (the LO register) is then stored in memory at that address. For a POP operation, the data at the memory location addressed by the Stack Pointer is moved into the least significant register (the LO register, which can be C, E, or L); the Stack Pointer is incremented and the data at the new memory location is loaded into the most significant register (the HI register, which can be B, D, or H). The Stack Pointer is then incremented again. again. "For both PUSH and POP operations, the register pair, rp, may be one of the three double registers BC, DE, or HL (identified as B, D, Fig. A-11. The four different PUSH instructions. Observe that the HI byte is pushed first on the stack. Fig. A-12. The four different POP instructions. Observe that the LO byte is popped first. and H, respectively) or the contents of the Flag register and the Accumulator, indicated by PSW which stands for program status word)." The PUSH and POP instructions are represented schematically in Figs. A-11 and A-12. In these diagrams, SP is the stack pointer location before the PUSH or POP instruction. #### PUSH psw and POP psw ``` (Push processor status word) ((SP) - 1) --- (A) ((SP) - 2)_0 --- (CY), ((SP) - 2)_1 --- 1 ((SP) - 2)_2 --- ((P), ((SP) - 2)_3 --- 0 ((SP) - 2)_4 --- (A), ((SP) - 2)_5 --- 0 ((SP) - 2)_6 --- (2), ((SP) - 2)_7 --- (S) (SP) --- (SP) --- 2 The content of register A is moved to the memory location whose address is one less than register SP. The content of the condition flags are assembled into a processor status word and the word is moved to the memory location whose address is two less than the content of register SP. The content of register SP is decremented by two. 1 1 1 1 0 1 0 1 Cycles: 3 States: 11 Addressing: reg. indirect Flags: none ``` The letters PSW stand for *processor status word*, which is the contents of the accumulator and the five status flags. Refer to the preceding description of the PUSH rp and POP rp instructions. The flag register, F, is regarded as the least significant register and the accumulator, A, is regarded as the most significant register. The program status word is important because it saves the actual machine status as determined by the five flag bits. When it is restored, machine operation can resume in the correct state, regardless of how the interrupting subroutine affected the flags. | FLAG WORD | | | | | | | | | | | | |-----------|-------|-------|----------------|-------|-------|-------|----------------|--|--|--|--| | $D_7$ | $D_6$ | $D_5$ | D <sub>4</sub> | $D_3$ | $D_2$ | $D_1$ | D <sub>0</sub> | | | | | | s | Z | 0 | AC | 0 | Р | 1 | CY | | | | | In the $\mu$ COM-8 integrated-circuit chip, which is essentially identical in function with the 8080A microprocessor chip, there is an extra status flag, SUB. In the flag register, SUB occupies the $D_5$ bit position. In addition, the $D_3$ bit position is at logic 1 rather than at logic 0 (which is the case for the 8080A chip). The authors consider the SUB flag to be a useful feature of 8080A-type microprocessors, and hope that it becomes incorporated in future versions of the chip by manufacturers such as Texas Instruments, National Semiconductor, Intel, etc. An example of the operation of the stack is given in Fig. A-13. The section of code employed is | Main Task | Subroutine | |-----------|------------| | LXI SP | PUSH B | | 303 | PUSH D | | 003 | PUSH H | | CALL | PUSH PSW | | <b2></b2> | | | <b3></b3> | | The stack pointer originally was located at $\rm HI=003$ and $\rm LO=303$ . After the CALL subroutine instruction, the two program counter bytes are pushed onto the stack and the stack pointer moves to HI=003 and LO=301. Note that the HI program counter byte goes on the stack first, but comes off the stack last. A succession of four push instructions load the stack with the contents of the six general-purpose registers, the accumulator, and the flag register. After all of this, the stack pointer (SP) location is HI=003 and LO=271, the top filled location on the stack. Once the subroutine has been executed, there is the problem of removing the contents of the stack and placing them back into the 8080A microprocessor chip. The section of code, located at the end of the subroutine, that accomplishes this is: Fig. A-13. The stack. POP PSW POP H POP D POP B RET In each case, the LO byte comes off the stack first. Recall that in three-byte instructions, the LO byte is always the second byte of the instruction. Thus, the 8080A chip is consistent in its handling of 16-bit address words. Once the contents of the stack have been popped off, the stack pointer returns to its original location of HI = 003 and LO = 002 Registers can be pushed and popped in any order. However, the program counter is almost always pushed first and popped last. The caution that you must observe is that you must pop registers in the reverse order with which you pushed them. For example, with the stack configuration shown in Fig. A-13, if you executed the following section of code at the end of the subroutine POP PSW POP B POP H POP D RET you would encounter problems with the execution of the main program. The original register contents would not be returned to their original locations. The chip would attempt to execute the program, but there is not much chance of a useful result. is not much chance of a useful result. If you do not need to push registers on a stack during a subroutine call, do not do so. Store only that information on the stack which is needed by the 8080A chip when it resumes the main program. #### XTHL (Exchange stack top with H and L) (L) → ((SP) + (SP) (S The XTHL instruction is used to exchange the contents of the H,L register pair with the top pair of items on the stack. The contents of the top location, the one addressed by the stack pointer SP, are exchanged with the contents of register L. The stack pointer is incremented, and the contents of memory addressed by this new value of SP are exchanged with the contents of register H. #### CDUI The SPHL instruction is used to load the stack pointer register with the contents of the register pair H,L. The contents of L are placed in the LO eight bits of the stack pointer, and the contents of H are placed in the HI eight bits of the stack pointer. As pointed out in the NEC Microcomputers, Inc., manual: "The SPHL instruction can be used to load the stack pointer with a value which has been computed using the double register arithmetic operations available with the HL register pair. This should always be done with care, since it is easy to lose track of where the stack pointer is pointing, with subsequent loss of stack content." #### **OUT** port The OUT port instruction moves the 8-bit contents of the accumulator to the output port specified by the second byte of the instruction. Two-hundred fifty-six unique output ports can be selected. During the third machine cycle of the instruction, the device code appears on the ad- dress bus, an $\overline{OUT}$ control pulse is generated, and the contents of the accumulator appear on the external bidirectional data bus. #### IN port The IN port instruction permits the 8080A chip to read the data present at the input port given by the second byte of the instruction. Two-hundred fifty-six unique input ports can be addressed. During the third machine cycle of the instruction, the device code for the input device appears on the address bus, an $\overline{\rm IN}$ control signal appears on the control bus, and information appearing on the bidirectional data bus also appears in the accumulator. #### El and Di To quote the NEC Microcomputers, Inc., $\mu COM$ -8 Software Manual: "Whether the 8080A responds to an interrupt request is determined by the state of an internal interrupt flip-flop, INTE. When this flip-flop is set to one, the processor responds to interrupts. When it is reset to zero, the processor ignores interrupt requests. The INTE flip-flop is affected by both program control and system operations. System operations which affect INTE are a system reset and the acknowledgement of an interrupt. Both operations clear INTE and thus disable the interrupt facility. If further interrupts are to be acknowledged after a Reset or Acknowledge Interrupt, the program must re-enable the flip-flop. Two instructions, EI, Enable Interrupt, and DI, Disable Interrupt, provide programmed control of the INTE flip-flop. The EI instruction sets the INTE flip-flop to one, enabling the interrupt facility, while the DI instruction clears the INTE flip-flop to zero, disabling the interrupt facility. Thus if it is desired that a section of the program be executed with high speed and without the possibility of being interrupted, the DI instruction may be used to disable interrupts for that section of code. After the section is complete, EI re-enables the interrupt facility. Since the acknowledgement of an interrupt request the INTE flip-flop to zero, an EI should be the first instruction in any routine that services interrupts. (This assumes that the interrupt acknowledge resets the interrupt request. This must be done to prevent hanging up the 8080A processor.) An exception should be made when servicing the fastest I/O device. To avoid disturbing service to this I/O unit, the INTE flip-flop should be enabled at the end of the routine." HLT The HLT instruction causes the processor to suspend operation until the 8080A chip receives a reset signal or receives an interrupt request signal (INT). The processor accepts the INT request regardless of the condition of the internal interrupt flip-flop. After processing the interrupt, instruction execution continues at the next location after the halt command. NOP The NOP instruction does absolutely nothing except occupy a location in memory and take up four states during program execution. It is used for program debugging, in which extra NOP instructions are placed in a program for subsequent modification. When deletions are made to a program, NOPs should be inserted in their place. With the aid of material in the Intel 8080 Microcomputer Systems With the aid of material in the Intel 8080 Microcomputer Systems User's Manual and the NEC Microcomputers, Inc., $\mu$ COM-8 Software Manual, a detailed description of the individual instructions of the 8080A microprocessor chip has been provided. The authors are grateful to both Intel Corporation and NEC Microcomputers, Inc., for their kind permission to use information in their manuals. If you are a serious user of the 8080A chip, you should have both manuals in your possession. ### APPENDIX 3 # 8080 Instruction Set (Intel Corp. Summary) | | | | | las | tructi | | ede! | 1 | | Clock (≥ | | | | | | veti | | | | | Clock (2) | |----------|------------------------------------------|-----|-----|-----|--------|-----|------|-----|-----|----------|----------|---------------------------------------|-----|-----|-----|------|----------------|-----|-----|----|-----------| | Mnemosic | Description | 0, | 06 | 05 | | | 0 | | 00 | Cycles | Mnemonic | Description | 0, | 06 | 05 | D4 | D <sub>3</sub> | 02 | D- | По | Cycles | | MOV.12 | Move register to register | _ | , | D | 0 | 0 | s | s | s | 5 | RZ | Return on zero | , | 1 | 0 | 0 | , | 0 | 0 | 0 | 5/11 | | MOV M | Move register to memory | ñ | 1 | ï | ï | 0 | s | s | s | , | RNZ | Return on no zero | 1 | 1 | 0 | 0 | 9 | 0 | c | 0 | 5/11 | | MOV: N | Move memory to reaster | ō | i | Ď | ò | D | 1 | 1 | ė | , | RP. | Return on positive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 5/11 | | HLT | Half | a | 1 | 1 | 1 | 0 | 1 | 1 | ò | , | 8M | Return on minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 5/11 | | MVI | Move immediate register | ō | 0 | ò | 0 | D | 1 | 1 | 0 | 7 | RPE | Return on panity even | 1 | | 1 | 0 | 1 | 0 | 0 | 0 | 5/11 | | MVIM | Move immediate memory | ō | 0 | ï | i | 0 | 1 | 1 | 0 | 10 | RPD | Return on parity add | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 5/11 | | INB | Increment register | - 6 | 0 | Ð | п | D | 1 | 0 | 0 | 5 | AST | Restart | | 1 | Α | Α | A | 1 | 1 | 1 | 11 | | oce. | Decrement register | 0 | 0 | Ð | D | ٥ | 1 | 0 | 1 | 5 | IN | logut | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 | | INR M | Increment memory | ₿ | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 | DUT | Output | 1 | , | 0 | 1 | 0 | 0 | 1 | 1 | 10 | | DCR M | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 | LXI B | Load immediate register | 0 | 0 | 0 | 0 | 8 | 0 | 0 | 1 | 10 | | ADD r | Add register to A | 1 | 0 | 8 | 0 | 0 | S | \$ | S | 4 | | Pair B & C | | | | | | | | | | | ADC: | Add register to A mith carry | 1 | 0 | 0 | 8 | 1 | S | S | s | 4 | LXI 0 | Load ommediate register | 0 | 0 | 0 | • | 0 | 0 | 0 | 1 | 10 | | suB r | Subtract register from A | 1 | 0 | 0 | 1 | 0 | \$ | s | \$ | 4 | | Pair O & E | | | | | | | | | | | BB r | Subtract register from A<br>with borrow | 1 | 0 | 8 | 1 | 1 | S | s | \$ | 4 | (XI H | Load immediate register<br>Pair H & L | 0 | 0 | ' | 0 | 0 | 0 | 0 | 1 | 10 | | ANA : | And register with A | - 1 | 0 | 1 | 0 | 9 | S | 5 | \$ | 4 | LXI SP | Load immediate stack pointer | 0 | 0 | 1 | • | 0 | 0 | 0 | 1 | 10 | | XRA | Exclusive Dr register with A | - 1 | 0 | 1 | 0 | 1 | s | S | \$ | | PUSH B | Push register Pair 8 & C on | - 1 | • | 0 | 9 | 0 | 1 | 0 | 1 | 11 | | 1 420 | Or register with A | | 0 | 1 | 1 | 0 | s | s | \$ | | | stack | | | | | | | | | | | CMP | Compare register with A | 1 | 0 | 1 | 1 | 1 | s | \$ | \$ | 4 | PUSH D | Push register Pair D & E on | - 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 11 | | ADD M | Add memory to A | - 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | | stack | | | | | | | | | | | ADC M | Add memory to A with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | , | PUSH H | Push register Pair H & L on | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 11 | | SUB M | Subtract memory from A | - 1 | 0 | 6 | 1 | 0 | 1 | 1 | 0 | , | | stack | | | | | | | | | | | 588 M | Subtract memory from A<br>with burrow | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | , | PUSH PSW | Push A and Flags<br>on stack | 1 | 1 | , | , | 0 | 1 | 0 | , | 11 | | ANA M | And memory with A | - 1 | 0 | 1 | Ü | 0 | 1 | | 0 | 1 | PGP 8 | Pup register pair B & C off | 1 | 1 | ū | 0 | 0 | 0 | 0 | 1 | 10 | | XRA M | Exclusive Or memory with A | | 0 | 1 | 0 | - 1 | 1 | - 1 | 0 | 1 | | stack | | | | | | | | | | | ORA M | Or memory with A | - 1 | 0 | -1 | | 0 | -1 | | 0 | 2 | POP D | Pop register pair D & E off | - 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 | | CMP M | Compare memory with A | - 1 | 0 | 1 | - 1 | - 1 | | 1 | 0 | , | | stack | | | | | | | | | | | AÜI | Add immediate to A | 1 | 1 | 9 | 0 | 0 | 1 | 1 | 6 | , | POPH | Pop register pair H & C off | 1 | 1 | 1 | 0 | 0 | 0 | 0 | ) | 10 | | ACI | Add immediate to A with<br>carry | 1 | 1 | 6 | 0 | 1 | 1 | 1 | 0 | , | POP PSW | Stack<br>Pop A and Flags | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 10 | | Sui | Subtrart immediate from A | | 1 | 0 | - 1 | 0 | - 1 | 1 | 0 | 1 | | aff stack | | | | | | | | | | | SBI | Subtract immediate from A | - 1 | 1 | 0 | 1 | | 1 | 1 | 0 | 7 | STA | Store Adrect | 0 | 0 | 1 | | 0 | 0 | 1 | 0 | 13 | | | with barrow | | | | | | | | | | LOA | Lead A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 | | ANI | And immediate with A | - 1 | 1 | 1 | 0 | 0 | 3 | 1 | 0 | 1 | XCHG | Exchange 0 & E. H & L | , | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 | | XRI | Exclusive Or immediate with | 1 | 1 | 1 | Ð | 1 | 1 | 1 | 0 | 7 | жтиц | Registers Exchange top of stack H & L | 1 | , | , | 0 | 0 | 0 | 1 | 1 | 18 | | ORI | Grummediate with A | - 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 | SPHI | H & L to start gornter | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 5 | | CPI | Compare immediate with A | - ; | - i | - 1 | - 1 | i | i | i | ů | i | PCHL | H & L to program counter | 1 | i | 1 | 0 | 1 | 0 | 0 | 1 | 5 | | RLC | Rorate A left | ė | 0 | ò | Ď. | ò | i | - i | i | | DAD 8 | Add 8 & C to H & L | | o | 0 | 9 | 1 | 0 | 0 | 1 | 10 | | RRC | Rotate A right | ň | 0 | 0 | 0 | ĭ | - i | i | i. | | DADD | Add 0 & E to H & L | 0 | ō | 0 | 1 | 1 | 0 | 0 | 1 | 10 | | RAI | Rotate A left through carry | ě | 0 | 0 | , | | - i | - i | - 1 | 4 | DADH | Add H & L to H & L | | à | 1 | 9 | 1 | 0 | 0 | 1 | 10 | | RAR | Rosare A right through | ő | 0 | a | - 1 | ű | - i | - i | - 1 | 4 | DAD SP | Add stack pointer to H & 1 | o | á | 1 | 1 | 1 | 0 | 0 | 1 | 10 | | m.e.n | Catty | • | | | | | | | | | STAX B | Store A indirect | 0 | ġ | 0 | 0 | 0 | 0 | 1 | 0 | 7 | | JMP | Jump unconditional | | , | 6 | | | п | 1 | 1 | 10 | STAXD | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 7 | | JC JMr | Jump on carry | - 1 | - 1 | 0 | ň | - î | ñ | - 1 | á | 10 | LDAXB | Load A money | Ö | ė | 0 | 0 | 1 | 0 | - 1 | 0 | 7 | | INC | Jump on no carry | - 1 | , | ň | i | | ō | - 1 | ñ | 10 | LOAXO | Load A indirect | Ď | 0 | 0 | | 1 | 0 | - 1 | 0 | , | | JZ | Jump on rero | - ; | - 1 | | ò | ĭ | ō | i | ō | 10 | INK B | Increment B & C registers | ō | ė | ė | 0 | 0 | 0 | 1 | 1 | 5 | | JMZ | Jump on no rero | - 1 | | ō | 0 | 0 | ň | i | ñ | 10 | INXD | Increment D & E registers | 0 | ò | ė | - 1 | 0 | 0 | | 1 | 5 | | JP JP | Jump on no zero<br>Jump on positive | | - ; | 1 | , | 0 | | i | 0 | 10 | INXH | Lacrement H & L registers | ě | | ĭ | ò | ō | ō | - i | 1 | 5 | | JM | Jump on pussive | | - ( | - 1 | - 1 | | | i | ě | 10 | INX SP | Increment stack pointer | ō | n | 1 | 1 | 0 | o | 1 | 1 | 5 | | | | - ; | - ; | - 1 | 'n | - 1 | | | 0 | 10 | OCX B | Decrement B & C | ů | n | ò | ò | i | ŏ | i | i | 5 | | JPE | Jump on parity even | , | | - 1 | 0 | ò | | - : | ŏ | 10 | DCXD | Decrement D & E | 0 | n | o | i | , | ň | - 1 | i | 5 | | JPO | Jump on painty odd<br>Call unconditional | | - : | 'n | 0 | | | 'n | ĭ | 17 | DCXH | Decrement H & L | ő | n | ĭ | ė | í | ň | - i | i | | | CALL | | , | - ! | 0 | ň | - : | - 1 | 0 | ė | 11.12 | DCX SP | Decrement stack pointer | ă | ň | í | , | i | ň | i | 1 | Š | | CC | Call on carry | - 1 | - : | 0 | , | ė | ÷ | 0 | ŏ | 11.17 | EMA | Complement A | | 0 | , | ò | - i | ĭ | - i | 1 | i | | CNC | Call on no carry | - 1 | - : | 0 | ė | , | - 1 | n | 0 | 11.17 | STC | Set carry | ō | ň | - 1 | i | ė | i | i | i | 4 | | CZ | Call on zero | 1 | | 0 | 0 | - 1 | - ! | 0 | 0 | 11.17 | CMC | Complement carry | 0 | 0 | - ; | - í | ř | , | - 1 | i | • | | CNZ | Call on no zero | 1 | | 0 | - 0 | 0 | - ! | 0 | 0 | 11 17 | I DAG | Decimal adjust A | 0 | ň | - 1 | ė | ò | - 1 | - i | i | 4 | | EP. | Calf on positive | | 1 | | 1 | U | - : | 0 | 0 | 11:17 | SHLD | Store H & L dract | ů | ň | - 1 | ā | 0 | ó | - i | ò | 16 | | CM | Call on minus | ! | - 1 | - 1 | 1 | - 1 | ! | 9 | 0 | 11/37 | SHED | Store H & L direct | 0 | n | - 1 | 0 | 1 | o | i | ō | 16 | | CPE | Call on panty even | . ! | 1 | - 1 | | 1 | - 1 | | | 11/37 | | Enable Interrupts | , | i | i | 1 | - 1 | ň | ÷ | ĭ | 4 | | CPO | Call on parity odd | 1 | 1 | | 0 | 0 | | 0 | 0 | 10 | E)<br>Di | Disable interrupts | - ; | - 1 | ÷ | - ; | ò | ő | i | i | 4 | | RET | Return | 1 | 1 | 0 | 8 | 1 | 0 | 0 | 0 | 5/11 | NDP | Disable interrupt<br>No operation | 0 | i | ò | ò | o | 0 | | ó | | | RC | Resum on carry | 1 | - 1 | 0 | | | | | . 0 | 5/11 | 1100 | no operance | 0 | ۰ | ۰ | | ۰ | | | , | | | RNC | Return on no cerry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | . 0 | 2/11 | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | NOTES: 1. DDD or SSS = 000 8 = 001 C = 010 D = 011 E = 100 H = 101 L = 110 Memory = 111 A. 2. Two possible cycle times, (6/11) indicate instruction cycles dependent on condition flags. ## Index Breakpoint, 298 instruction, 298 switch, 298 Buffer, 276 Bus, 18, 234, 236 driver, 40 drivers, microcomputer, 55 monitor, 276 Byte, 40, 95 status, 41 Accumulator, 18, 29, 94, 119, 275 instructions, 183-187 Addend, 187 Address, 94, 115, 138 bus, 43 memory, 28 Allocate, 298, 314 ALU, 94 Altman, Laurence, 24 Arithmetic group, 8080, 159-162 operations, 94 Assemble, 94, 187 Assembler, 95, 187 Assembler, 95, 187 Assembler, 95, 187 Assembler, 95, 187 Assembler, 95, 187 Assembly definition, 95 language, 95, 168-188 programming, 95, 187 Autoranging instrument, 276 Autiliary carry flag, 95, 145 c Call, 95, 138 subroutine, 95 Carry flag, 95, 145 Cell, memory, 28 Character, 100 Clear accumulator instructions, 157 Clearing memory, programming example, 170-171 Clock, 18 cycles and timing loops, 211-232 clock cycle listing, 8080, 215-217 counting clock cycles, 217-223 controlling power with a microcomputer, 231 definitions, 211-23 instruction, 212-215 microcomputer as multivibrator, 212-214 monostable multivibrators, 212 sequencing with a microcomputer, 228-232 timing loops, 212, 233-228 generator/ driver chip, 8224, 47-51 Clocks, 8080 chip, 42-43 Closed subroutine, 139 Code, mnemonic, 108-109 Computer definition, 18 digital, 17-18 instruction, 95, 100 В Basic types of interrupts, 318-320 Bcd addition programming example, 186-188 to binary routine, 184-185 Bidirectional definition, 18 data bus, 18, 235-238 8080 chip, 44-45 Binary 8080 chip, 44-45 Binary numbers, 100 to bed subroutine, 188-191 Bit, 40, 95 status, 41 Bootstrap, 40 Branch group, 8080, 163-164 instruction, 95, 138 operation, 95, 138 ``` Computer—cont interfacing, 13, 18, 40, 72 program, 95, 99-100 uses of, 11-12 vs. digital computer, 25-26 wired-program, 20 Conditional branch instructions, 141-144 breakpoint instruction, 96 call, 141 definition, 96 instruction, 139 jump, 96, 141 return, 141 Condition flag, 96, 144 Control input, 234 lines, microcomputer, 53-55 output, 234 pulses, device select pulses as, 205-206 Controller, 18 what is a, 26-27 Controlling power with a microcomputer, 231 Controls, 8080 chip, 45-47 Counting clock cycles, 217-223 Determining effects of accumulator instructions, 189-184 Determining effects of accumulator instructions, 189-184 Device code, 96, 116 select pulse, 18, 72 generating, 195-208 as control pulses, 205-206 decoding, 197-202 definitions, 196 8080 microprocessor 1/0 instructions, 196-197 example, 206-208 sample microcomputer program, 202-204 uses for, 74-75 Digital computer, 19, 26 computer, 19, 26 controller, 19, 26 controller, 201-201 Direct address, 19, 19 addressing, 96, 153 and 200-200 addressing, 96, 153 Disable interrupt, 298, 320 E Badie, Donald, 23 8080A individual 8080 instructions, 357 arithmetic group, 369-382 arithmetic group, 369-382 branch group, 389-399 data transfer group, 361-369 logical group, 389-399 stack, 170, and machine control group, 389-389 stack, 170, and machine control group, 399-309 micromputer programming, 351-352 sources of 8080 programming information, 359-357 summaries, 8080, 357, 409 microprocessor chip information seurces, 14 instruction set, 12 memory, 12 number of manufacturers, 12 programming, 12 programming, 12 programming, 12 programs available, 13 8224 clock/generator driver chip, 47-51 Enable interrupt, 298, 320 Execution, 234 Exploring jump instructions, 176-178 External device addressing, 19, 72 typical 8080 microcomputer, 33-36 DAD instruction, register pair, 148 Data and memory addressing modes, 153 bus bidirectional, 44 buffer/latch, 234 byte, 96, 116 input, typical 8080 microcomputer, 32-33 logger, 276, 288-289 logging with an 8080 microcomputer, 288-295 how many data points, 289-290 per second, 291-295 how many data points, 290-291 single data, what to do with, 291 short- or long-term storage, 290-291 simple dap point, information in, 291 minor, 43 minor, 43 minor, 53 minor, 53 minor, 53 minor, 54 minor, 54 minor, 55 minor, 57 min D DAD instruction, register pair, 148 exporing jump instructions, 176-178 atternal device addressing, 19, 72 typical 8080 microcomputer, 33-36 flags, 298, 321-327 clearing, 320-324 deferred and immediate interrupts, 324-32 immediate interrupts, 325-326 single-line (polled), 327 lens, 324 Fetch, 234 Field, 96, 115 Fixed-program computer, 19, 26 Flag, 40, 46, 96, 144, 298, 321 register, 96 ``` | | Interfacing, 19, 40, 71 | |------------------------------------------------------|------------------------------------------------------------------| | Flowchart<br>definition, 142 | a keyboard, 329-335 | | symbol, 142 | flag-bit testing, 329-330 | | Flow diagram, 142 | vectored interrupts, 330-335 | | | four fundamental tasks of, 13 | | G | what is, 71-73 | | 0 1 | Internal | | General-purpose | bus, 235<br>flag, 298, 321 | | computer, 19, 26<br>register, 96, 119 | Interrupt, 19, 36, 298 | | Generating | basic types, 318-320 | | device select pulse, 195-208 | flag, 298, 320 | | definitions, 196 | flip-flop, 320 | | device select pulses | hardware priority, 339-342 | | as control pulses, 205-206 | mask, 327-329 | | decoding, 197-202 | priority, 335-339 | | 8080 microprocessor I/O instructions, | servicing, typical microcomputer, 36-37 | | 196-197<br>example, 206-208 | software priority, 342-346 | | sample microcomputer program, | Introduction to microcomputer programming, | | 202-204 | 93-192<br>accumulator instructions, 153-157 | | status information, 233-273 | assembly language, 166-168 | | bidirectional data bus, 235-238 | bit, byte, word, and address, 114-115 | | definitions, 234-235 | conditional branch instructions, 141-144 | | 8212 eight-bit input/output port chip, | data and memory addressing modes, 153 | | 263-267 | decoding | | instruction cycles, 238-240 | arithmetic and logic operation, 135-137 | | machine cycles, 240-242<br>identification, 242-258 | branch operation, 138-141 | | single stepping an 8080 microcomputer, | condition flag, 144-146 | | 258-263 | decrement and increment, 152-153<br>immediate operation, 137-138 | | | instruction, example, 134 | | н | register, 134-135 | | п | register pair, 146-152 | | Halt instruction, 112 | definitions, 94-99 | | Hardware, 19, 25 | 8080 | | integration, 309 | microprocessor registers, 118-122 | | priority interrupts, 339-342 | mnemonic instructions, 123-127 | | vs. software, 25 | examples, programming, 170-192 | | Hexadecimal code, 96 | instruction<br>groups, 8080, 157-166 | | HI<br>address byte, 96, 116 | summary, 8080, 166 | | memory address, 40 | vs. data, 117-118 | | Hierarchy, computer, 17-18 | learning, programming, 109-114 | | HLDA, 46 | machine language, 103 | | HOLD, 46 | vs. assembly language programs, | | | 168-169 | | 1 | mnemonic code, 108-109<br>multibyte instructions, 115-117 | | Immediate | octal | | addressing, 96, 137, 153 | and hexadecimal machine codes, | | interrupt, 298, 324 | 103-108 | | IN, 62 | /hexadecimal listing, instruction set, | | Increment, 96, 112, 152 | 127-133 | | Indirect addressing, 153 | operations performed by 8080 | | IN instruction, 110, 196 | microprocessor, 122-123 | | Input circuits, microcomputer, 278-279 | what is<br>a computer program, 99-100 | | Input/output, 19, 73, 276<br>microcomputer, 275-295 | an instruction, 100-101 | | data logging, 288-295 | an operation, 101-103 | | definitions, 275-276 | Instruction, 97, 115 | | input circuits, 278-279 | code, 97, 119 | | instructions, 279-282 | cycle, 234, 238-240 | | output circuits, 277-278 | decoder, 97, 120 | | output to multiplexed display, 285-288 | execution time, 214-215 | | programs, 283-285<br>small 8080 microcomputer, 68-70 | groups, 157-166<br>input/output, 279-282 | | typical 8080 microcomputer, 33 | register, 97, 120 | | INT, 45 | set, 8080A, 351-408 | | INTA, 62 | individual 8080 instructions, 357 | | INTA, 62<br>INTE, 46 | arithmetic group, 369-382 | | a, | | | Instruction—cont | Main program, 314 | |--------------------------------------------------------------|-----------------------------------------------------------| | set, 8080A | Mask, 298, 327 | | individual 8080 instructions<br>branch group, 389-399 | Medium-scale<br>integration, 299 | | data transfer group, 361-369 | programs, 299 | | logical group, 382-389 | Memory, 19, 28 | | stack, I/O, and machine control | address, 19, 28, 40 | | group, 399-408 | bus, 29 | | programming, 351-342 | 8080 chip, 43-44 | | sources of 8080 programming | allocation, 314 | | information, 352-357 | cell, 19, 28 | | summaries, 8080, 357, 409 | clearing, programming example, 170-171 | | summary, 166 INX instruction, register, pair, 148 | data, 19, 28<br>PROM, 28 | | I/O, 40, 73, 196, 276 | read | | device, 40, 73-74, 196 | -only, 28 | | | /write, 28 | | ı | small 8080 microcomputer, 62-67 | | Jump, 97, 138 | volatile, 20, 29 | | K | word, 19-20, 28 | | Keyboard, interfacing, 329-335 | Microcomputer | | flag bit testing, 329-330 | as controller, 12<br>bus, small 8080, 68 | | vectored interrupts, 330-335 | definition, 20 | | i | input | | Label, 97, 168, 169 | circuits, 278-279 | | Large-scale | /output, 275-295 | | integration, 298 | data logging, 288-295 | | programs, 298 | definitions, 275-276 | | Latch, 40, 276 | instructions, 279-282 | | status, 41 | objectives, 275 output to multiplexed display, | | Loading stack, programming example, 173 | 285-288 | | Log, 276 | programs, 283-285 | | Logic, synchronous, 41, 72<br>Logical group, 8080, 162-163 | output circuits, 277-278 | | LO | use to strobe integrated-circuit chips, | | address byte, 97, 116 | 75-80 | | memory address, 40 | counters, 76-77 | | Loop, 140, 211, 212 | data selectors/multiplexers, 77 | | LXI instruction, register pair, 149 | decoders, 77<br>demultiplexers, 77 | | M | latches and flip-flops, 78-79 | | Machine | memories, 79-80 | | code, 97 | other chips, 80 | | instruction, 97 | pin configurations, 80 | | language, 97 | priority encoder, 78 | | cycle, 196, 235, 240-242 | shift registers, 78 | | fetch, 241 | what is a, 11-13<br>Microcontroller, 20 | | halt, 242 | Microprocessor, 20, 24-25 | | identification, 242-258 | applications, 16 | | eight status bits, 244-246 8080 control inputs and outputs, | as controllers and logic processors, 14-18 | | 246-248 | 8080 | | 8212 eight-bit input/output port | bidirectional data bus, 44-45 | | chip, 263-267 | clocks, 42-43 | | latching the status bits, 243-244 | controls, 45-47 | | single stepping an 8080 | memory address, 43-44<br>power, 42 | | microcomputer, 258-263 | 8080A, 53 | | state timing, 254-258<br>timing diagrams, 8080 instructions, | Mnemonic, 97 | | 248-254 | code, 108-109 | | input, 241 | instructions, 108 | | interrupt, 242 | language, 108 | | memory | operation code, 108 | | read, 241 | symbol, 97, 108 | | write, 241 | Modes of microcomputer operation, 314-318 | | output, 241 | interrupt operation, 316-318<br>polled operation, 315-316 | | stack<br>read, 242 <sup></sup> | Monitor, 276 | | write, 241 | Monitoring flags, programming example, | | language vs. assembly language, 168-169 | 174-176 | | | | 414 Manual Pri | Monostable multivibrator, 20, 212 | Programming, microcomputer—cont | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MR. 59 | learning, 109-114 | | Multibyte instructions, 115-117 | machine language, 103 vs. assembly language programs, | | Multilevel interrupt, 299, 318 | 168-169 | | Multiplexed display, output to, 285-288 | mnemonic code, 108-109 | | Multivibrator, microcomputer as, 212-214 | multibyte instructions, 115-117 | | MW, 59 | octal/hexadecimal | | N | listing, instructions set, 127-133 | | | machine codes, 103-108 | | Nest, subroutine, 178-180 | operations, 101-103, 122-123 | | Nesting, 288, 299<br>Nonoverlapping two-phase clock, 235 | program, 99-100 | | Nonovertapping two-phase clock, 200 | registers, 99-100 | | 0 | Programs, input/output, 283-285 | | * | Pulser, 20 | | Octal code, 97 | Push, 98, 150 | | Operand, 97, 169 | PUSH instruction, register pair, 148 | | Operation, 97, 101-103 | | | code, 97, 116 | R | | small 8080 microcomputer, 70-71<br>OSC, 51 | 7 . 1 | | | Random access memory, 20 | | OUT, 62 | RDYIN, 51 | | OUT instructions, 110, 196 | READY, 51<br>Read | | Output | definition, 20, 29 | | circuits, microcomputer, 277-278 | -only memory, 20, 28 | | to multiplexed display, 285-288 | /write memory, 28 | | • | Reading B and C registers, programming | | r | example, 171 | | Parity, 97-98 | READY, 45-46 | | flag, 98, 145 | References | | Period, 212, 214 | helpful, 21-23 | | $\phi_1$ and $\phi_2$ , 51 | text (superscript), 349-350 | | Polling, 299, 315 | Register, 30, 98, 118 | | Pop, 98, 150 | pair, 98 | | POP instruction, register pair, 148 | addressing, 98 | | Popping stack, programming example, | Requirements, minimum computer, 27 | | 173-174 | RESET, 51 | | Power | RESET, 45 | | controlling with a microcomputer, 231 | RESIN, 47-51 | | 8080 chip, 42 | Response time, 299, 316 | | microcomputer, 52<br>Priority, 299, 317 | Restart instruction, 113 | | interrupts, 335-339 | Return, definition, 98, 139 | | software, 342-346 | Rotate, 276 | | Program, 115, 139 | instructions, 154-155 | | counter, 98, 120, 150 | Routine, 98, 139 | | Programmable | | | read-only memory, 20, 28 | S | | sequencer, 212, 228 | | | Programming, microcomputer, 93-192 | Sense, 299 | | accumulator instructions, 153-157 | | | assembly language, 166-168 | Sequencer, 212, 228 | | | Sequencing with a microcomputer, 228-232 | | bit, byte, word, and address, 114-115 | Sequencing with a microcomputer, 228-232<br>Sequential operation, 228 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144 | Sequencing with a microcomputer, 228-232<br>Sequential operation, 228<br>Service routine, 299 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153 | Sequencing with a microcomputer, 228-232<br>Sequential operation, 228<br>Service routine, 299<br>Sign flag, 98, 145 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding | Sequencing with a microcomputer, 228-232<br>Sequential operation, 228<br>Service routine, 299<br>Sign flag, 98, 145<br>Single | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding<br>arithmetic and logic operation, 135-137 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 299 Sign flag, 98, 145 Single -byte instruction, 98, 115 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding<br>arithmetic and logic operation, 135-137<br>branch operation, 138-141 | Sequencing with a microcomputer, 228-232<br>Sequential operation, 228<br>Service routine, 299<br>Sign flag, 98, 145<br>Single<br>-byte instruction, 98, 115<br>-line interrupt, 299, 318, 327 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding<br>arithmetic and logic operation, 135-137<br>branch operation, 138-141<br>condition flag, 144-146 | Sequencing with a microcomputer, 228-232<br>Sequential operation, 228<br>Sign flag, 98, 145<br>Single -byte instruction, 98, 115<br>-line interrupt, 299, 318, 327<br>Small | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding<br>arithmetic and logic operation, 135-137<br>branch operation, 138-141<br>condition flag, 144-146<br>decrement and increment, 152-153 | Sequencing with a microcomputer, 228-232<br>Sequential operation, 228<br>Service routine, 299<br>Sign flag, 98, 145<br>Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327<br>Small 8080 microcomputer, 39-91<br>definitions, 40-41 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding<br>arithmetic and logic operation, 135-137<br>branch operation, 138-141<br>condition flag, 144-146<br>decrement and increment, 152-153<br>immediate operation, 137-138 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 239 Sign flag, 98, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small 8080 microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding<br>arithmetic and logic operation, 135-137<br>branch operation, 138-141<br>condition flag, 144-146<br>decrement and increment, 152-153<br>immediate operation, 137-138<br>instruction, example, 134 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 239 Sign flag, 98, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small 8080 microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 | | bit, byte, word, and address, 114-115 conditional branch instructions, 141-144 data and memory addressing modes, 153 decoding arithmetic and logic operation, 135-137 branch operation, 138-141 condition flag, 144-146 decrement and increment, 152-153 immediate operation, 137-138 instruction, example, 134 register, 134-135 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 239 Sign flag, 98, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small 8080 microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 bidirectional data bus, 44-45 clocks, 42-43 | | bit, byte, word, and address, 114-115<br>conditional branch instructions, 141-144<br>data and memory addressing modes, 153<br>decoding<br>arithmetic and logic operation, 135-137<br>branch operation, 138-141<br>condition flag, 144-146<br>decrement and increment, 152-153<br>immediate operation, 137-138<br>instruction, example, 134<br>register, 134-135<br>pair, 146-152 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 299 Sign flag, 98, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small 8080 microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 bidirectional data bus, 44-45 clocks, 42-43 controls, 45-47 | | bit, byte, word, and address, 114-115 conditional branch instructions, 141-144 data and memory addressing modes, 153 decoding arithmetic and logic operation, 135-137 branch operation, 138-141 condition flag, 144-146 decrement and increment, 152-153 immediate operation, 137-138 instruction, example, 134 register, 134-135 pair, 146-152 definitions, 94-99 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 299 Sign flag, 98, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small 8080 microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 bidirectional data bus, 44-45 clocks, 42-43 controls, 45-47 memory address, 43-44 | | bit, byte, word, and address, 114-115 conditional branch instructions, 141-144 data and memory addressing modes, 153 decoding arithmetic and logic operation, 135-137 branch operation, 138-141 condition flag, 144-146 decrement and increment, 152-153 immediate operation, 137-138 instruction, example, 134 register, 134-135 pair, 146-152 definitions, 94-99 examples, programming, 170-192 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 299 Sign flag, 98, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small 8080 microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 bidirectional data bus, 44-45 clocks, 42-43 controls, 45-47 memory address, 43-44 power, 42 | | bit, byte, word, and address, 114-115 conditional branch instructions, 141-144 data and memory addressing modes, 153 decoding arithmetic and logic operation, 135-137 branch operation, 138-141 condition flag, 144-146 decrement and increment, 152-153 immediate operation, 137-138 instruction, example, 134 register, 134-135 pair, 146-152 definitions, 94-99 examples, programming, 170-192 instructions, 100-101 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 239 Sign flag, 39, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 bidirectional data bus, 44-45 clocks, 42-43 controls, 45-47 memory address, 43-44 power, 42 8224 clock generator/driver chip, | | bit, byte, word, and address, 114-115 conditional branch instructions, 141-144 data and memory addressing modes, 153 decoding arithmetic and logic operation, 135-137 branch operation, 138-141 condition flag, 144-146 decrement and increment, 152-153 immediate operation, 137-138 instruction, example, 134 register, 134-135 pair, 146-152 definitions, 94-99 examples, programming, 170-192 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 299 Sign flag, 98, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small 8080 microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 bidirectional data bus, 44-45 clocks, 42-43 controls, 45-47 memory address, 43-44 power, 42 8224 clock generator/driver chip, 47-51 | | bit, byte, word, and address, 114-115 conditional branch instructions, 141-144 data and memory addressing modes, 153 decoding arithmetic and logic operation, 135-137 branch operation, 138-141 condition flag, 144-146 decrement and increment, 152-153 immediate operation, 137-138 instruction, example, 134 register, 134-135 pair, 146-152 definitions, 94-99 examples, programming, 170-192 instructions, 100-101 groups, 157-166 | Sequencing with a microcomputer, 228-232 Sequential operation, 228 Service routine, 239 Sign flag, 39, 145 Single -byte instruction, 98, 115 -line interrupt, 299, 318, 327 Small microcomputer, 39-91 definitions, 40-41 8080 microprocessor chip, 42-47 bidirectional data bus, 44-45 clocks, 42-43 controls, 45-47 memory address, 43-44 power, 42 8224 clock generator/driver chip, | ``` Small—cont 8080 microcomputer microcomputer, 51-71 bus drivers, 55 control lines, 53-55 8080A microprocessor chip, 53 input/output, 68-70 memory, 62-67 microcomputer bus, 68 operation of the microcomputer, 70-71 power, 52 status information, 55-62 objectives, 39-40 use for device select pulses, 74-75 use to strobe integrated-circuit chips, 75-80 counters, 76-77 data selectors/multiplexers, 77 denoiltylexers, 77 latches and 6ip-flops, 78-79 memories, 79-80 other chips, 80 pin configurations, 80 priority encoder, 78 shift registers, 78 ale integration, 299 rocgrams, 299 recgrams, Symbolic—cont code, 99, 167 coding, 99, 167 language programming, 99 programming, 99, 167 Sync, 41, 71 Synchronize, 41, 71 Synchronize, 41, 71 Synchronous, 41, 71 computer, 41, 72 inputs, 41, 72 operation, 41, 72 TANK, 47 Three -byte instruction, 99, 115 -state device, 41, 235, 236 Timing loops, 212, 223, 228 Top of stack, 150 Two -byte instruction, 99, 115 -phase clock, 41, 235 Typical 8080 microcomputer, 27-37 data input, 32-33 output, 31-32 external device addressing, 33-36 interrupt servicing, 36-37 memory, 22-31 other input/output techniques, 33 pin configurations, 80 priority encoder, 78 shift registers, 79 programs, 299 programs, 299 software, 20, 25 driver, 299, 316 integration, 309-311 priority interrupts, 342-346 Sources, information, 8080 chip, 14 Special-purpose computer, 20, 26 SPHL instruction, register pair, 149 Stack, 98, 150, 299 instructions, 8080, 312-314 I/O, and machine control group, 8080, 164-166 pointer, 98, 120, 150 addressing, 98, 153 use of, data and status storage, 302-307 State, 212, 214, 215 Status, 299 bit, 41, 235 byte, 41, 235 byte, 41, 235, 238 information generating, 233-273 bidirectional data bus, 235-238 definitions, 234-235 8212 eight-bit input/output port chip, 260-30 cm, 238-240 machine cycles, 240-242 single stepping an 8080 microcomputer, 258-264 microcomputer, 258-264 microcomputer, 55-62 latch, 41 Stored-program computer, 20, 26 STSTE, 51 Subrootine, 98, 139, 299-300 instructions, 8080, 311-312 what is a, 300-302 whole sused, 307-308 Symbolic subservable stepping and subservable address, 98, 167 Unconditional call, 111 definition, 99 instruction, 139 jump, 99, 110 return, 99, 111 Vector bits, 300 Vectored interrupt, 300, 318 Very-large-scale integration, 300 programs, 300 Volatile memory, 20 WAIT, 46 Wired-program computer, 20, 26 Word, 41, 99, 115 length, 41 memory, 28 Write, 20, 29 WRITE (WR), 46 Writing into memory, programming example, 172-173 XCHG instruction, register pair, 149 XTAL, 47 XTHL instruction, register pair, 149 Zero flag, 99, 111, 145 ```