## MCS-80'm

## USER'S MANUAL

(WITH INTRODUCTION TO MCS-85 ${ }^{\text {w }}$ )

## OCTOBER 1977



## MCS-80 ${ }^{\text {™ }}$ USER'S MANUAL <br> (WITH INTRODUCTION TO MCS-85" ${ }^{\text {™ }}$

The MCS-80 ${ }^{\text {TM }}$ family of microcomputer components has been greatly expanded since the last version of the MCS-80 manual was published in September, 1975. Over the last two years, expansion of MCS-80 family devices, coupled with the best system development support in the industry, have made Intel's 8080A the industry standard microprocessor.
Now Intel introduces the MCS-85 family, an evolutionary system based around the third generation 8085 microprocessor. MCS-85 has all the features of an MCS-80 system with higher performance and lower cost. MCS-85, the next industry standard for new designs.
Over forty microcomputer components are described in detail in this manual. Among the newest are:

8251A Improved Programmable Communication Interface
8253 Programmable Interval Timer
8255A Improved Programmable Peripheral Interface
8257 Programmable DMA Controller
8259 Programmable Interrupt Controller
8279 Programmable Keyboard/Display Controller
2716 2K x 8 EPROM, 5 Volt Only
2114 1K $\times 4$ Static RAM
2116 16K $\times 1$ Dynamic RAM
80855 Volt Advanced 8080 Processor
8155/56 Combination 256x8 Static RAM, 22 I/O Lines, 14-bit Counter
8355 Combination $2 \mathrm{~K} \times 8$ ROM, 16 I/O Lines
8755 Combination 2K x 8 EPROM (5 Volt), 16 I/O Lines

## intel <br> Microcomputers. First from the beginning.

## CONTENTS

INTRODUCTION
General ..... 1
Advantages of Designing with Microcomputers ..... 11
Microcomputer Design Aids ..... 111
Application Example ..... III
Application Table ..... IV
CHAPTER 1 - THE FUNCTIONS OF A COMPUTER
A Typical Computer System ..... 1-1
The Architecture of a CPU ..... 1-1
Computer Operations ..... 1-3
CHAPTER 2 - THE 8080 CENTRAL PROCESSING UNIT
General ..... 2-1
Architecture of the 8080 CPU ..... 2-2
The Processor Cycle ..... 2-3
Interrupt Sequences ..... 2-11
Hold Sequences ..... 2-12
Halt Sequences ..... 2-13
Start-up of the 8080 CPU ..... 2-13
CHAPTER 3 - INTERFACING THE 8080
General ..... 3-1
Basic System Operation ..... 3-1
CPU Module Design ..... 3-2
Interfacing the 8080 to Memory and I/O Devices ..... 3-6
CHAPTER 4 - INSTRUCTION SET
General ..... 4-1
Data Transfer Group ..... 4-4
Arithmetic Group ..... 4-6
Branch Group ..... 4-11
Stack, I/O and Machine Control Group ..... 4-13
Summary Table ..... 4-15
CHAPTER 5 - INTRODUCTION TO MCS-85 ${ }^{\text {TM }}$ ..... 5-1
CHAPTER 6 - MICROCOMPUTER SYSTEM COMPONENT DATA SHEETS
CPU Group
8080A 8-Bit Microprocessor ..... 6-1
8080A-1 8-Bit Microprocessor ..... 6-8
8080A-2 8-Bit Microprocessor ..... 6-12
M8080A 8-Bit Microprocessor (MIL) ..... 6-16
8224 Clock Generator and Driver ..... 6-20
M8224 Clock Generator and Driver (MIL) ..... 6-26
8801 Clock Generator Crystal ..... 6-30
8228/8238 System Controller and Bus Driver ..... 6-32
M8228/M8238 System Controller and Bus Driver (MIL) ..... 6-38
8085 Single Chip 8-Bit N-Channel Microprocessor ..... 6-43
EPROMs and ROMs
8708 8192-Bit EPROM ..... 6-57
2716 2048x8 EPROM ..... 6-60
8308 8192-Bit MOS ROM ..... 6-64
8316A 16,384-Bit MOS RAM ..... 6-68
2316E 2048x8 ROM ..... 6.71
PROM and ROM Programming Instructions ..... 6-74
CHAPTER 6 - MICROCOMPUTER SYSTEM COMPONENT DATA SHEETS (Continued)
RAMs
8101A-4 1024-Bit RAM with I/O ..... 6-95
8102A-4 1024-Bit MOS RAM ..... 6-98
8111A-4 1024-Bit RAM with I/O ..... 6-102
5101 256x4 CMOS RAM ..... 6-105
M5101-4/M5101L-4 256x4-Bit Static CMOS RAM ..... 6-109
2114 1024x4 Static MOS RAM ..... 6-112
2142 1024×4-Bit Static RAM ..... 6-116
2104A 4096x1 Dynamic MOS RAM ..... 6-120
2107B 4096x1 Dynamic MOS RAM ..... 6-128
2116 16,384x1 Dynamic MOS RAM ..... 6-134
3222 4K Dynamic RAM Refresh Cont ..... 6-142
3232 4K Dynamic RAM Multiplexer and Refresh Counter ..... 6-148
3242 16K Dynamic RAM Multiplexer and Refresh Counter ..... 6-152
Peripherals and Support Circuits
8205 High Speed 1 out of 8 Binary Decoder ..... 6-159
8212 8-Bit Input/Output Port ..... 6-165
M8212 8-Bit Input/Output Port (MIL) ..... 6-174
8214 Priority Interrupt Control ..... 6-179
M8214 Priority Interrupt Control (MIL) ..... 6-183
8216/8226 4-Bit Parallel Bi-Directional Bus Driver ..... 6-186
M8216 4-Bit Parallel Bi-Directional Bus Driver (MIL) ..... 6-191
8251A Programmable Communication Interface ..... 6-194
M8251 Communication Interface ..... 6-209
8253/8253-5 Programmable Interval Timer ..... 6-212
8255A/8255A-5 Programmable Peripheral Interface ..... 6-223
M8255A Programmable Peripheral Interface (MIL) ..... 6-244
8257/8257-5 DMA Controller ..... 6-247
8259/8259-5 Interrupt Controller ..... 6-265
8271 Floppy Disk Controller ..... 6-281
8273 SDLC Protocol Controller ..... 6-285
8275 CRT Controller ..... 6-289
8279/8279-5 Keyboard/Display Interface ..... 6-293
Memory and I/O Expanders for MCS-85 ${ }^{\text {TM }}$
8155/8156 2048-Bit Static MOS RAM with I/O Ports and Timer ..... 6-307
8355 16,384-Bit ROM with I/O ..... 6-319
8755 16,384-Bit EPROM with I/O ..... 6-326
CHAPTER 7 - SUPPORT PRODUCTS
Intellec Prompt 80 ..... 7-1
Intellec Microcomputer Development System ..... 7-5
ICE-80 8080 In-Circuit Emulator ..... 7-9
UPP Universal PROM Programmer ..... 7-15
$\mu$ Scope ${ }^{\text {TM }} 820$ Microprocessor System Console ..... 7-17
$\mu$ Scope ${ }^{\text {TM }}$ Probe 8080A ..... 7-21
CHAPTER 8 - GENERAL INFORMATION
Ordering Information ..... 8-1
Packaging Information ..... 8-2
Military Program ..... 8-9
Instruction Set Summaries ..... 8-12

## INTRODUCTION



## INTRODUCTION

Since their inception, digital computers have continuously become more efficient, expanding into new applications with each major technological improvement. The advent of minicomputers enabled the inclusion of digital computers as a permanent part of various process control systems. Unfortunately, the size and cost of minicomputers in "dedicated" applications has limited their use. Another approach has been the use of custom built systems made up of "random logic" (i.e., logic gates, flip-flops, counters, etc.). However, the huge expense and development time involved in the design and debugging of these systems has restricted their use to large volume applications where the development costs could be spread over a large number of machines.

Today, Intel offers the systems designer a new alternative . . . the microcomputer. Utilizing the technologies and experience gained in becoming the world's largest supplier of LSI memory components, Intel has made the power of the digital computer available at the integrated circuit level. Using the n-channel silicon gate MOS process, Intel engineers have implemented the fast ( $2 \mu \mathrm{~s}$. cycle) and powerful ( 72 basic instructions) 8080 microprocessor on a single LSI chip. When this processor is combined with memory and I/O circuits, the computer is complete. Intel offers a variety of random-access memory (RAM), read-only memory (ROM) and shift register circuits, that combine with the 8080 processor to form the MCS- 80 microcomputer system, a system that can directly address and retrieve as many as 65,536 bytes stored in the memory devices.

The 8080 processor is packaged in a 40 -pin dual in-line package (DIP) that allows for remarkably easy interfacing. The 8080 has a 16 -bit address bus, a 8 -bit bidirectional data bus and fully decoded, TTL-compatible control outputs. In addition to supporting up to 64 K bytes of mixed RAM and ROM memory, the 8080 can address up to 256 input ports and 256 output ports; thus allowing for virtually unlimited system expansion. The 8080 instruction set includes conditional branching, decimal as well as binary arithmetic,
logical, register-to-register, stack control and memory reference instructions. In fact, the 8080 instruction set is powerful enough to rival the performance of many of the much higher priced minicomputers, yet the 8080 is upward software compatible with Intel's earlier 8008 microprocessor (i.e., programs written for the 8008 can be assembled and executed on the 8080).

In addition to an extensive instruction set oriented to problem solving, the 8080 has another significant featureSPEED. In contrast to random logic designs which tend to work in parallel, the microcomputer works by sequentially executing its program. As a result of this sequential execution, the number of tasks a microcomputer can undertake in a given period of time is directly proportional to the execution speed of the microcomputer. The speed of execution is the limiting factor of the realm of applications of the microcomputer. The 8080, with instruction times as short as $2 \mu \mathrm{sec}$., is an order of magnitude faster than earlier generations of microcomputers, and therefore has an expanded field of potential applications.

The architecture of the 8080 also shows a significant improvement over earlier microcomputer designs. The 8080 contains a 16 -bit stack pointer that controls the addressing of an external stack located in memory. The pointer can be initialized via the proper instructions such that any portion of external memory can be used as a last in/first out stack; thus enabling almost unlimited subroutine nesting. The stack pointer allows the contents of the program counter, the accumulator, the condition flags or any of the data registers to be stored in or retrieved from the external stack. In addition, multi-level interrupt processing is possible using the 8080's stack control instructions. The status of the processor can be "pushed" onto the stack when an interrupt is accepted, then "popped" off the stack after the interrupt has been serviced. This ability to save the contents of the processor's registers is possible even if an interrupt service routine, itself, is interrupted.

|  | CONVENTIONAL SYSTEM | PROGRAMMED LOGIC |
| :--- | :--- | :--- |
| Product definition <br> System and logic design | Done with logic diagrams | Simplified because of ease of incorporating features <br> Can be programmed with design aids <br> (compilers, assemblers, editors) <br> Lab Instrumentation |
| PC card layout <br> Documentation <br> Cooling and packaging and hardware aids reduce time | Fewer cards to layout <br> Less hardware to document <br> Reduced system size and power consumption <br> eases job |  |
| Power distribution <br> Engineering changes | Done with yellow wire | Less power to distribute <br> Change program |

Table 0-1. The Advantages of Using Microprocessors

## ADVANTAGES OF DESIGNING WITH MICROCOMPUTERS

Microcomputers simplify almost every phase of product development. The first step, as in any product development program, is to identify the various functions that the end system is expected to perform. Instead of realizing these functions with networks of gates and flip-flops, the functions are implemented by encoding suitable sequences of instructions (programs) in the memory elements. Data and certain types of programs are stored in RAM, while the basic program can be stored in ROM. The microprocessor performs all of the system's functions by fetching the instructions in memory, executing them and communicating the results via the microcomputer's I/O ports. An 8080 microprocessor, executing the programmed logic stored in a single 2048-byte ROM element, can perform the same logical functions that might have previously required up to 1000 logic gates.

The benefits of designing a microcomputer into your system go far beyond the advantages of merely simplifying product development. You will also appreciate the profitmaking advantages of using a microcomputer in place of custom-designed random logic. The most apparent advantage is the significant savings in hardware costs. A microcomputer chip set replaces dozens of random logic elements, thus reducing the cost as well as the size of your system. In addition, production costs drop as the number of individual components to be handled decreases, and the number of complex printed circuit boards (which are difficult to layout, test and correct) is greatly reduced. Probably the most profitable advantage of a microcomputer is its flexibility for change. To modify your system, you merely re-program the memory elements; you don't have to redesign the entire system. You can imagine the savings in time and money when you want to upgrade your product. Reliability is another reason to choose the microcomputer over random logic. As the number of components decreases, the probability of a malfunctioning element likewise decreases. All
of the logical control functions formerly performed by numerous hardware components can now be implemented in a few ROM circuits which are non-volatile; that is, the contents of ROM will never be lost, even in the event of a power failure. Table 0-1 summarizes many of the advantages of using microcomputers.

## MICROCOMPUTER DESIGN AIDS

If you're used to logic design and the idea of designing with programmed logic seems like too radical a change, regardless of advantages, there's no need to worry because Intel has already done most of the groundwork for you. The INTELLEC ${ }^{\circledR}$ Microcomputer Development System provides flexible, inexpensive and simplified methods for OEM product development. The INTELLEC MDS provides RAM program storage making program loading and modification easier, a display and control console for system monitoring and debugging, standard TTY and CRT interfaces, incircuit emulation capability (ICE-80), PROM programming capability using the Universal PROM Programmer module, and a standard software package (System Monitor, Assembler and Text Editor). In addition to the standard software package available with the INTELLEC MDS Intel offers a resident PL/M compiler. Intel's Microcomputer Division is always available to provide assistance in every phase of your product development.

Intel also provides complete documentation on all their hardware and software products. In addition to this User's Manual, there are the:

- PL/Mi-80 Programming Manual
- 8080/8085 Assembly Language Programming


## Manual

- INTELLEC MDS Operator's Manual
- INTELLEC MDS Hardware Reference Manual
- ICE-80 Operator's Manual
- ICE-80 Hardware Reference Manual
- 8080 User's Program Library "Insite"


## APPLICATIONS EXAMPLE

The 8080 can be used as the basis for a wide variety of calculation and control systems. The system configurations for particular applications will differ in the nature of the peripheral devices used and in the amount and the type of memory required. The applications and solutions described in this section are presented primarily to show how microcomputers can be used to solve design problems. The 8080 should not be considered limited either in scope or performance to those applications listed here.

Consider an 8080 microcomputer used within an automatic computing scale for a supermarket. The basic machine has two input devices: the weighing unit and a keyboard, used for function selection and to enter the price per unit of weight. The only output device is a display showing the total price, although a ticket printer might be added as an optional output device.

The control unit must accept weight information from the weighing unit, function and data inputs from the keyboard, and generate the display. The only arithmetic function to be performed is a simple multiplication of weight times rate.

The control unit could probably be realized with standard TTL logic. State diagrams for the various portions could be drawn and a multiplier unit designed. The whole design could then be tied together, and eventually reduced to a selection of packages and a printed circuit board layout. In effect, when designing with a logic family such as TTL, the designs are "customized" by the choice of packages and the wiring of the logic.

If, however, an 8080 microcomputer is used to realize
the control unit (as shown in Figure 0-1), the only "custom" logic will be that of the interface circuits. These circuits are usually quite simple, providing electrical buffering for the input and output signals.

Instead of drawing state diagrams leading to logic, the system designer now prepares a flow chart, indicating which input signals must be read, what processing and computations are needed, and what output signals must be produced. A program is written from the flow chart. The program is then assembled into bit patterns which are loaded into the program memory. Thus, this system is customized primarily by the contents of program memory.

For this automatic scale, the program would probably reside in read-only memory (ROM), since the microcomputer would always execute the same program, the one which implements the scale functions. The processor would constantly monitor the keyboard and weighing unit, and update the display whenever necessary. The unit would require very little data memory; it would only be needed for rate storage, intermediate results, and for storing a copy of the display.

When the control portion of a product is implemented with a microcomputer chip set, functions can be changed and features added merely by altering the program in memory. With a TTL based system, however, alterations may require extensive rewiring, alteration of PC boards, etc.

The number of applications for microcomputers is limited only by the depth of the designer's imagination. We have listed a few potential applications in Table 0-2, along with the types of peripheral devices usually associated with each product.


Figure 0-1. Microcomputer Application - Automatic Scale

| APPLICATION | PERIPHERAL DEVICES ENCOUNTERED |
| :---: | :---: |
| Intelligent Terminals | Cathode Ray Tube Display <br> Printing Units <br> Synchronous and Asynchronous data lines <br> Cassette Tape Unit <br> Keyboards |
| Gaming Machines | Keyboards, pushbuttons and switches <br> Various display devices <br> Coin acceptors <br> Coin dispensers |
| Cash Registers | Keyboard or Input Switch Array <br> Change Dispenser <br> Digital Display <br> Ticket Printer <br> Magnetic Card reader <br> Communication interface |
| Accounting and Billing Machines | Keyboard <br> Printer Unit <br> Cassette or other magnetic tape unit "Floppy" disks |
| Telephone Switching Control | Telephone Line Scanner Analog Switching Network Dial Registers Class of Service Parcel |
| Numerically Controlled Machines | Magnetic or Paper Tape Reader <br> Stepper Motors <br> Optical Shaft Encoders |
| Process Control | Analog-to-Digital Converters Digital-to-Analog Converters Control Switches Displays |

Table 0-2. Microprocessor Applications

Chapter 1

## THE FUNCTIONS OF A COMPUTER



## THE FUNCTIONS OF A COMPUTER

This chapter introduces certain basic computer concepts. It provides background information and definitions which will be useful in later chapters of this manual. Those already familiar with computers may skip this material, at their option.

## A TYPICAL COMPUTER SYSTEM

A typical digital computer consists of:
a) A central processor unit (CPU)
b) A memory
c) Input/output (I/O) ports

The memory serves as a place to store Instructions, the coded pieces of information that direct the activities of the CPU, and Data, the coded pieces of information that are processed by the CPU. A group of logically related instructions stored in memory is referred to as a Program. The CPU "reads" each instruction from memory in a logically determined sequence, and uses it to initiate processing actions. If the program sequence is coherent and logical, processing the program will produce intelligible and useful results.

The memory is also used to store the data to be manipulated, as well as the instructions that direct that manipulation. The program must be organized such that the CPU does not read a non-instruction word when it expects to see an instruction. The CPU can rapidly access any data stored in memory; but often the memory is not large enough to store the entire data bank required for a particular application. The problem can be resolved by providing the computer with one or more Input Ports. The CPU can address these ports and input the data contained there. The addition of input ports enables the computer to receive information from external equipment (such as a paper tape reader or floppy disk) at high rates of speed and in large volumes.

A computer also requires one or more Output Ports that permit the CPU to communicate the result of its processing to the outside world. The output may go to a display, for use by a human operator, to a peripheral device that produces "hard-copy," such as a line-printer, to a
peripheral storage device, such as a floppy disk unit, or the output may constitute process control signals that direct the operations of another system, such as an automated assembly line. Like input ports, output ports are addressable. The input and output ports together permit the processor to communicate with the outside world.

The CPU unifies the system. It controls the functions performed by the other components. The CPU must be able to fetch instructions from memory, decode their binary contents and execute them. It must also be able to reference memory and I/O ports as necessary in the execution of instructions. In addition, the CPU should be able to recognize and respond to certain external control signals, such as INTERRUPT and WAIT requests. The functional units within a CPU that enable it to perform these functions are described below.

## THE ARCHITECTURE OF A CPU

A typical central processor unit (CPU) consists of the following interconnected functional units:

- Registers
- Arithmetic/Logic Unit (ALU)
- Control Circuitry

Registers are temporary storage units within the CPU. Some registers, such as the program counter and instruction register, have dedicated uses. Other registers, such as the accumulator, are for more general purpose use.

## Accumulator:

The accumulator usually stores one of the operands to be manipulated by the ALU. A typical instruction might direct the ALU to add the contents of some other register to the contents of the accumulator and store the result in the accumulator itself. In general, the accumulator is both a source (operand) and a destination (result) register.

Often a CPU will include a number of additional general purpose registers that can be used to store operands or intermediate data. The availability of general purpose
registers eliminates the need to "shuffle" intermediate results back and forth between memory and the accumulator, thus improving processing speed and efficiency.

## Program Counter (Jumps, Subroutines and the Stack):

The instructions that make up a program are stored in the system's memory. The central processor references the contents of 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 (pointing to the next instruction).

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 when an instruction in one section of memory is a Jump instruction to another section of memory.

A jump instruction contains the address of the instruction which is to follow it. The next instruction may be stored in any memory location, as long as the programmed jump specifies the correct address. During the execution of a jump instruction, the processor replaces the contents of its program counter with the address embodied in the Jump. Thus, the logical continuity of the program is maintained.

A special kind of program jump occurs when the stored program "Calls" a subroutine. In this kind of jump, the processor is required to "remember" the contents of the program counter at the time that the jump occurs. This enables the processor to resume execution of the main program when it is finished with the last instruction of the subroutine.

A Subroutine is a program within a program. Usually it is a general-purpose set of instructions that must be executed repeatedly in the course of a main program. Routines which calculate the square, the sine, or the logarithm of a program variable are good examples of functions often written as subroutines. Other examples might be programs designed for inputting or outputting data to a particular peripheral device.

The processor has a special way of handling subroutines, in order to insure an orderly return to the main program. When the processor receives a Call instruction, it increments the Program Counter and stores the counter's contents in a reserved memory area known as the Stack. The Stack thus saves the address of the instruction to be executed after the subroutine is completed. Then the pro-
cessor loads the address specified in the Call into its Program Counter. The next instruction fetched will therefore be the first step of the subroutine.

The last instruction in any subroutine is a Return. Such an instruction need specify no address. When the processor fetches a Return instruction, it simply replaces the current contents of the Program Counter with the address on the top of the stack. This causes the processor to resume execution of the calling program at the point immediately following the original Call Instruction.

Subroutines are often Nested; that is, one subroutine will sometimes call a second subroutine. The second may call a third, and so on. This is perfectly acceptable, as long as the processor has enough capacity to store the necessary return addresses, and the logical provision for doing so. In other words, the maximum depth of nesting is determined by the depth of the stack itself. If the stack has space for storing three return addresses, then three levels of subroutines may be accommodated.

Processors have different ways of maintaining stacks. Some have facilities for the storage of return addresses built into the processor itself. Other processors use a reserved area of external memory as the stack and simply maintain a Pointer register which contains the address of the most recent stack entry. The external stack allows virtually unlimited subroutine nesting. In addition, if the processor provides instructions that cause the contents of the accumulator and other general purpose registers to be "pushed" onto the stack or "popped" off the stack via the address stored in the stack pointer, multi-level interrupt processing (described later in this chapter) is possible. The status of the processor (i.e., the contents of all the registers) can be saved in the stack when an interrupt is accepted and then restored after the interrupt has been serviced. This ability to save the processor's status at any given time is possible even if an interrupt service routine, itself, is interrupted.

## Instruction Register and Decoder:

Every computer has a Word Length that is characteristic of that machine. A computer's word length is usually determined by the size of its internal storage elements and interconnecting paths (referred to as Busses); for example, a computer whose registers and busses can store and transfer 8 bits of information has a characteristic word length of 8 -bits and is referred to as an 8 -bit parallel processor. An eight-bit parallel processor generally finds it 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-bit binary numbers, or as numbers that are integral multiples of eight bits: 16 bits, 24 bits, and so on. This characteristic eight-bit field is often referred to as a Byte.

Each operation that the processor can perform is identified by a unique byte of data known as an Instruction

Code or Operation Code. An eight-bit word used as an instruction code can distinguish between 256 alternative actions, more than adequate for most processors.

The processor fetches an instruction in two distinct operations. First, the processor transmits the address in its Program Counter to the memory. Then 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 execution.

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, should be intuitively clear to any logic designer. The eight bits stored in the instruction register can be decoded and used to selectively activate 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 with selected timing pulses, to develop electrical signals that can then be used to initiate specific actions. This translation of code into action is performed by the Instruction Decoder and by the associated control circuitry.

An eight-bit instruction code is often sufficient to specify a particular processing action. There are times, however, when execution of the instruction requires more information than eight bits can convey.

One example of this is when the instruction references a memory location. The basic instruction code identifies the operation to be performed, but cannot specify the object address as well. In a case like this, a two- or threebyte instruction must be used. Successive instruction bytes are stored in sequentially adjacent memory locations, and the processor performs two or three fetches in succession to obtain the full instruction. The first byte retrieved from memory is placed in the processor's instruction register, and subsequent bytes are placed in temporary storage; the processor then proceeds with the execution phase. Such an instruction is referred to as Variable Length.

## Address Register(s):

A CPU may use a register or register-pair to hold the address of a memory location that is to be accessed for data. If the address register is Programmable, (i.e., if there are instructions that allow the programmer to alter the contents of the register) the program can "build" an address in the address register prior to executing a Memory Reference instruction (i.e., an instruction that reads data from memory, writes data to memory or operates on data stored in memory).

## Arithmetic/Logic Unit (ALU):

All processors contain an arithmetic/logic unit, which is often referred to simply as the ALU. The ALU, as its name implies, is that portion of the CPU hardware which
performs the arithmetic and logical operations on the binary data.

The ALU must contain an Adder which is capable of combining the contents of two registers in accordance with the logic of binary arithmetic. This provision permits the processor to perform arithmetic manipulations on the data it obtains from memory and from its other inputs.

Using only the basic adder a capable programmer can write routines which will subtract, multiply and divide, giving the machine complete arithmetic capabilities. In practice, however, most ALUs provide other built-in functions, including hardware subtraction, boolean logic operations, and shift capabilities.

The ALU contains Flag Bits which specify certain conditions that arise in the course of arithmetic and logical manipulations. Flags typically include Carry, Zero, Sign, and Parity. It is possible to program jumps which are conditionally dependent on the status of one or more flags. Thus, for example, the program may be designed to jump to a special routine if the carry bit is set following an addition instruction.

## Control Circuitry:

The control circuitry is the primary functional unit within a CPU. Using clock inputs, the control circuitry maintains the proper sequence of events required for any processing task. After an instruction is fetched and decoded, the control circuitry issues the appropriate signals (to units both internal and external to the CPU) for initiating the proper processing action. Often the control circuitry will be capable of responding to external signals, such as an interrupt or wait request. An Interrupt request will cause the control circuitry to temporarily interrupt main program execution, jump to a special routine to service the interrupting device, then automatically return to the main program. A Wait request is often issued by a memory or I/O element that operates slower than the CPU. The control circuitry will idle the CPU until the memory or I/O port is ready with the data.

## COMPUTER OPERATIONS

There are certain operations that are basic to almost any computer. A sound understanding of these basic operations is a necessary prerequisite to examining the specific operations of a particular computer.

## Timing:

The activities of the central processor are cyclical. The processor fetches an instruction, performs the operations required, fetches the next instruction, and so on. This orderly sequence of events requires precise timing, and the CPU therefore requires a free running oscillator clock which furnishes the reference for all processor actions. The combined fetch and execution of a single instruction is referred to as an Instruction Cycle. The portion of a cycle identified
with a clearly defined activity is called a State. And the interval between pulses of the timing oscillator is referred to as a Clock Period. As a general rule, one or more clock periods are necessary for the completion of a state, and there are several states in a cycle.

## Instruction Fetch:

The first state(s) of any instruction cycle will be dedicated to fetching the next instruction. The CPU issues a read signal and the contents of the program counter are sent to memory, which responds by returning the next instruction word. The first byte of the instruction is placed in the instruction register. If the instruction consists of more than one byte, additional states are required to fetch each byte of the instruction. When the entire instruction is present in the CPU, the program counter is incremented (in preparation for the next instruction fetch) and the instruction is decoded. The operation specified in the instruction will be executed in the remaining states of the instruction cycle. The instruction may call for a memory read or write, an input or output and/or an internal CPU operation, such as a register-to-register transfer or an add-registers operation.

## Memory Read:

An instruction fetch is merely a special memory read operation that brings the instruction to the CPU's instruction register. The instruction fetched may then call for data to be read from memory into the CPU. The CPU again issues a read signal and sends the proper memory address; memory responds by returning the requested word. The data received is placed in the accumulator or one of the other general purpose registers (not the instruction register).

## Memory Write:

A memory write operation is similar to a read except for the direction of data flow. The CPU issues a write signal, sends the proper memory address, then sends the data word to be written into the addressed memory location.

## Wait (memory synchronization):

As previously stated, the activities of the processor are timed by a master clock oscillator. The clock period determines the timing of all processing activity.

The speed of the processing cycle, however, is limited by the memory's Access Time. Once the processor has sent a read address to memory, it cannot proceed until the memory has had time to respond. Most memories are capable of responding much faster than the processing cycle requires. A few, however, cannot supply the addressed byte within the minimum time established by the processor's clock.

Therefore a processor should contain a synchronization provision, which permits the memory to request a Wait state. When the memory receives a read or write enable signal, it places a request signal on the processor's READY line, causing the CPU to idle temporarily. After the memory has
had time to respond, it frees the processor's READY line, and the instruction cycle proceeds.

## Input/Output:

Input and Output operations are similar to memory read and write operations with the exception that a peripheral I/O device is addressed instead of a memory location. The CPU issues the appropriate input or output control signal, sends the proper device address and either receives the data being input or sends the data to be output.

Data can be input/output in either parallel or serial form. All data within a digital computer is represented in binary coded form. A binary data word consists of a group of bits; each bit is either a one or a zero. Parallel I/O consists of transferring all bits in the word at the same time, one bit per line. Serial I/O consists of transferring one bit at a time on a single line. Naturally serial I/O is much slower, but it requires considerably less hardware than does parallel I/O.

## Interrupts:

Interrupt provisions are included on many central processors, as a means of improving the processor's efficiency. Consider the case of a computer that is processing a large volume of data, portions of which are to be output to a printer. The CPU can output a byte of data within a single machine cycle but it may take the printer the equivalent of many machine cycles to actually print the character specified by the data byte. The CPU could then remain idle waiting until the printer can accept the next data byte. If an interrupt capability is implemented on the computer, the CPU can output a data byte then return to data processing. When the printer is ready to accept the next data byte, it can request an interrupt. When the CPU acknowledges the interrupt, it suspends main program execution and automatically branches to a routine that will output the next data byte. After the byte is output, the CPU continues with main program execution. Note that this is, in principle, quite similar to a subroutine call, except that the jump is initiated externally rather than by the program.

More complex interrupt structures are possible, in which several interrupting devices share the same processor but have different priority levels. Interruptive processing is an important feature that enables maximum untilization of a processor's capacity for high system throughput.

## Hold:

Another important feature that improves the throughput of a processor is the Hold. The hold provision enables Direct Memory Access (DMA) operations.

In ordinary input and output operations, the processor itself supervises the entire data transfer. Information to be placed in memory is transferred from the input device to the processor, and then from the processor to the designated memory location. In similar fashion, information that goes
from memory to output devices goes by way of the processor.

Some peripheral devices, however, are capable of transferring information to and from memory much faster than the processor itself can accomplish the transfer. If any appreciable quantity of data must be transferred to or from such a device, then system throughput will be increased by
having the device accomplish the transfer directly. The processor must temporarily suspend its operation during such a transfer, to prevent conflicts that would arise if processor and peripheral device attempted to access memory simultaneously. It is for this reason that a hold provision is included on some processors.

## Chapter 2

THE 8080 CENTRAL PROCESSING UNIT


## THE 8080 CENTRAL PROCESSING UNIT

The 8080 is a complete 8 -bit parallel, central processor unit (CPU) for use in general purpose digital computer systems. It is fabricated on a single LSI chip (see Figure 3-1). using Intel's n-channel silicon gate MOS process. The 8080 transfers data and internal state information via an 8 -bit, bidirectional 3-state Data Bus ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ). Memory and peripheral device addresses are transmitted over a separate 16 -
bit 3-state Address Bus ( $A_{0} \cdot A_{15}$ ). Six timing and control outputs (SYNC, DBIN, WAIT, $\overline{W R}$, HLDA and INTE) emanate from the 8080, while four control inputs (READY, HOLD, INT and RESET), four power inputs ( $+12 v,+5 v$, -5 v , and GND) and two clock inputs ( $\phi_{1}$ and $\phi_{2}$ ) are accepted by the 8080.


Figure 2-1. 8080 Photomicrograph With Pin Designations

## ARCHITECTURE OF THE 8080 CPU

The 8080 CPU consists of the following functional units:

- Register array and address logic
- Arithmetic and logic unit (ALU)
- Instruction register and control section
- Bi-directional, 3-state data bus buffer

Figure 2-2 illustrates the functional blocks within the 8080 CPU .

## Registers:

The register section consists of a static RAM array organized into six 16 -bit registers:

- Program counter (PC)
- Stack pointer (SP)
- Six 8-bit general purpose registers arranged in pairs, referred to as B,C; D,E; and H,L
- A temporary register pair called W,Z

The program counter maintains the memory address of the current program instruction and is incremented auto-
matically during every instruction fetch. The stack pointer maintains the address of the next available stack location in memory. The stack pointer can be initialized to use any portion of read-write memory as a stack. The stack pointer is decremented when data is "pushed" onto the stack and incremented when data is "popped" off the stack (i.e., the stack grows "downward").

The six general purpose registers can be used either as single registers ( 8 -bit) or as register pairs (16-bit). The temporary register pair, $W, Z$, is not program addressable and is only used for the internal execution of instructions.

Eight-bit data bytes can be transferred between the internal bus and the register array via the register-select multiplexer. Sixteen-bit transfers can proceed between the register array and the address latch or the incrementer/ decrementer circuit. The address latch receives data from any of the three register pairs and drives the 16 address output buffers ( $A_{0} \cdot \mathrm{~A}_{15}$ ), as well as the incrementer/ decrementer circuit. The incrementer/decrementer circuit receives data from the address latch and sends it to the register array. The 16 -bit data can be incremented or decremented or simply transferred between registers.


Figure 2-2. 8080 CPU Functional Block Diagram

## Arithmetic and Logic Unit (ALU):

The ALU contains the following registers:

- An 8-bit accumulator
- An 8-bit temporary accumulator (ACT)
- A 5-bit flag register: zero, carry, sign, parity and auxiliary carry
- An 8-bit temporary register (TMP)

Arithmetic, logical and rotate operations are performed in the ALU. The ALU is fed by the temporary register (TMP) and the temporary accumulator (ACT) and carry flip-flop. The result of the operation can be transferred to the internal bus or to the accumulator; the ALU also feeds the flag register.

The temporary register (TMP) receives information from the internal bus and can send all or portions of it to the ALU, the flag register and the internal bus.

The accumulator (ACC) can be loaded from the ALU and the internal bus and can transfer data to the temporary accumulator (ACT) and the internal bus. The contents of the accumulator (ACC) and the auxiliary carry flip-flop can be tested for decimal correction during the execution of the DAA instruction (see Chapter 4).

## Instruction Register and Control:

During an instruction fetch, the first byte of an instruction (containing the OP code) is transferred from the internal bus to the 8 -bit instruction register.

The contents of the instruction register are, in turn, available to the instruction decoder. The output of the decoder, combined with various timing signals, provides the control signals for the register array, ALU and data buffer blocks. In addition, the outputs from the instruction decoder and external control signals feed the timing and state control section which generates the state and cycle timing signals.

## Data Bus Buffer:

This 8 -bit bidirectional 3 -state buffer is used to isolate the CPU's internal bus from the external data bus ( $D_{0}$ through $D_{7}$ ). In the output mode, the internal bus content is loaded into an 8 -bit latch that, in turn, drives the data bus output buffers. The output buffers are switched off during input or non-transfer operations.

During the input mode, data from the external data bus is transferred to the internal bus. The internal bus is precharged at the beginning of each internal state, except for the transfer state ( $\mathrm{T}_{3}$-described later in this chapter).

## THE PROCESSOR CYCLE

An instruction cycle is defined as the time required to fetch and execute an instruction. During the fetch, a selected instruction (one, two or three bytes) is extracted from memory and deposited in the CPU's instruction register. During the execution phase, the instruction is decoded and translated into specific processing activities.

Every instruction cycle consists of one, two, three, four or five machine cycles. A machine cycle is required each time the CPU accesses memory or an I/O port. The fetch portion of an instruction cycle requires one machine cycle for each byte to be fetched. The duration of the execution portion of the instruction cycle depends on 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 (see Chapter 4).

Each machine cycle consists of three, four or five states. A state is the smallest unit of processing activity and is defined as the interval between two successive positivegoing transitions of the $\phi_{1}$ driven clock pulse. The 8080 is driven by a two-phase clock oscillator. All processing activities are referred to the period of this clock. The two nonoverlapping clock pulses, labeled $\phi_{1}$ and $\phi_{2}$, are furnished by external circuitry. It is the $\phi_{1}$ clock pulse which divides each machine cycle into states. Timing logic within the 8080 uses the clock inputs to produce a SYNC pulse, which identifies the beginning of every machine cycle. The SYNC pulse is triggered by the low-to-high transition of $\phi_{2}$, as shown in Figure 2-3.

*SYNC DOES NOT OCCUR IN THE SECOND AND THIRD MACHINE CYCLES OF A DAD INSTRUCTION SINCE THESE MACHINE CYCLES ARE USED FOR AN INTERNAL REGISTER-PAIR ADD.

Figure 2-3. $\phi_{1}, \phi_{2}$ And SYNC Timing
There are three exceptions to the defined duration of a state. They are the WAIT state, the hold (HLDA) state and the halt (HLTA) state, described later in this chapter. Because the WAIT, the HLDA, and the HLTA states depend upon external events, they are by their nature of indeterminate length. Even these exceptional states, however, must
be synchronized with the pulses of the driving clock. Thus, the duration of all states are integral multiples of the clock period.

To summarize then, each clock period 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 eightteen states for its completion, depending on the kind of instruction involved.

## Machine Cycle Identification:

With the exception of the DAD instruction, there is just one consideration that determines how many machine cycles are required in any given instruction cycle: the number of times that the processor must reference a memory address or an addressable peripheral device, in order to fetch and execute the instruction. Like many processors, the 8080 is so constructed that it can transmit only one address per machine cycle. Thus, if the fetch and execution of an instruction requires two memory references, then the instruction cycle associated with that instruction consists of two machine cycles. If five such references are called for, then the instruction cycle contains five machine cycles.

Every instruction cycle has at least one reference to memory, during which the instruction is fetched. An instruction cycle must always have a fetch, even if the execution of the instruction requires no further references to memory. The first machine cycle in every instruction cycle is therefore a FETCH. Beyond that, there are no fast rules. It depends on the kind of instruction that is fetched.

Consider some examples. The add-register (ADD r) instruction is an instruction that requires only a single machine cycle (FETCH) for its completion. In this one-byte instruction, the contents of one of the CPU's six general purpose registers is added to the existing contents of the accumulator. Since all the information necessary to execute the command is contained in the eight bits of the instruction code, only one memory reference is necessary. Three states are used to extract the instruction from memory, and one additional state is used to accomplish the desired addition. The entire instruction cycle thus requires only one machine cycle that consists of four states, or four periods of the external clock.

Suppose now, however, that we wish to add the contents of a specific memory location to the existing contents of the accumulator (ADD M). Although this is quite similar in principle to the example just cited, several additional steps will be used. An extra machine cycle will be used, in order to address the desired memory location.

The actual sequence is as follows. First the processor extracts from memory the one-byte instruction word addressed by its program counter. This takes three states. The eight-bit instruction word obtained during the FETCH machine cycle is deposited in the CPU's instruction register and used to direct activities during the remainder of the instruction cycle. Next, the processor sends out, as an address,
the contents of its $H$ and $L$ registers. The eight-bit data word returned during this MEMORY READ machine cycle is placed in a temporary register inside the 8080 CPU . By now three more clock periods (states) have elapsed. In the seventh and final state, the contents of the temporary register are added to those of the accumulator. Two machine cycles, consisting of seven states in all, complete the "ADD M" instruction cycle.

At the opposite extreme is the save $H$ and $L$ registers (SHLD) instruction, which requires five machine cycles. During an "SHLD" instruction cycle, the contents of the processor's $H$ and $L$ registers are deposited in two sequentially adjacent memory locations; the destination is indicated by two address bytes which are stored in the two memory locations immediately following the operation code byte. The following sequence of events occurs:
(1) A FETCH machine cycle, consisting of four states. During the first three states of this machine cycle, the processor fetches the instruction indicated by its program counter. The program counter is then incremented. The fourth state is used for internal instruction decoding.
(2) A MEMORY READ machine cycle, consisting of three states. During this machine cycle, the byte indicated by the program counter is read from memory and placed in the processor's Z register. The program counter is incremented again.
(3) Another MEMORY READ machine cycle, consisting of three states, in which the byte indicated by the processor's program counter is read from memory and placed in the W register. The program counter is incremented, in anticipation of the next instruction fetch.
(4) A MEMORY WRITE machine cycle, of three states, in which the contents of the $L$ register are transferred to the memory location pointed to by the present contents of the $W$ and $Z$ registers. The state following the transfer is used to increment the $W, Z$ register pair so that it indicates the next memory location to receive data.
(5) A MEMORY WRITE machine cycle, of three states, in which the contents of the H register are transferred to the new memory location pointed to by the $W, Z$ register pair.

In summary, the "SHLD" instruction cycle contains five machine cycles and takes 16 states to execute.

Most instructions fall somewhere between the extremes typified by the "ADD $r$ " and the "SHLD" instructions. The input (INP) and the output (OUT) instructions, for example, require three machine cycles: a FETCH, to obtain the instruction; a MEMORY READ, to obtain the address of the object peripheral; and an INPUT or an OUTPUT machine cycle, to complete the transfer.

While no one instruction cycle will consist of more then five machine cycles, the following ten different types of machine cycles may occur within an instruction cycle:
(1)

FETCH (M1)
MEMORY READ
MEMORY WRITE

## STACK READ

(5) STACK WRITE
(7) OUTPUT
(8) INTERRUPT
(9) HALT
(10) HALT•INTERRUPT

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

The processor identifies the machine cycle in progress by transmitting an eight-bit status word during the first state of every machine cycle. Updated status information is presented on the 8080's data lines ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ), during the SYNC interval. This data should be saved in latches, and used to develop control signals for external circuitry. Table 2-1 shows how the positive-true status information is distributed on the processor's data bus.

Status signals are provided principally for the control of external circuitry. Simplicity of interface, rather than machine cycle 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_{1}$ status bit ( $D_{6}$ ), 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 is also valuable in the test and de-bugging phases of system development. Table 2-1 lists the status bit outputs for each type of machine cycle.

## State Transition Sequence:

Every machine cycle within an instruction cycle consists of three to five active states (referred to as $\mathrm{T}_{1}, \mathrm{~T}_{2}, \mathrm{~T}_{3}$, $T_{4}, T_{5}$ or $T_{W}$ ). The actual number of states depends upon the instruction being executed, and on the particular machine cycle within the greater instruction cycle. The state transition diagram in Figure 2-4 shows how the 8080 proceeds from state to state in the course of a machine cycle. The diagram also shows how the READY, HOLD, and INTERRUPT lines are sampled during the machine cycle, and how the conditions on these lines may modify the
basic transition sequence. In the present discussion, we are concerned only with the basic sequence and with the READY function. The HOLD and INTERRUPT functions will be discussed later.

The 8080 CPU does not directly indicate its internal state by transmitting a "state control" output during each state; instead, the 8080 supplies direct control output (INTE, HLDA, DBIN, $\overline{W R}$ and WAIT) for use by external circuitry.

Recall that the 8080 passes through at least three states in every machine cycle, with each state defined by successive low-to-high transitions of the $\phi_{1}$ clock. Figure $2-5$ shows the timing relationships in a typical FETCH machine cycle. Events that occur in each state are referenced to transitions of the $\phi_{1}$ and $\phi_{2}$ clock pulses.

The SYNC signal identifies the first state ( $T_{1}$ ) in every machine cycle. As shown in Figure 2-5, the SYNC signal is related to the leading edge of the $\phi_{2}$ clock. There is a delay ( $\mathrm{t}_{\mathrm{DC}}$ ) between the low-to-high transition of $\phi_{2}$ and the positive-going edge of the SYNC pulse. There also is a corresponding delay (also tDC) between the next $\phi_{2}$ pulse and the falling edge of the SYNC signal. Status information is displayed on $D_{0}-D_{7}$ during the same $\phi_{2}$ to $\phi_{2}$ interval. Switching of the status signals is likewise controlled by $\phi_{2}$.

The rising edge of $\phi_{2}$ during $T_{1}$ also loads the processor's address lines ( $A_{0}-A 15$ ). These lines become stable within a brief delay ( $\mathrm{t}_{\mathrm{D}}$ ) of the $\phi_{2}$ clocking pulse, and they remain stable until the first $\phi_{2}$ pulse after state $T_{3}$. This gives the processor ample time to read the data returned from memory.

Once the processor has sent an address to memory, there is an opportunity for the memory to request a WAIT. This it does by pulling the processor's READY line low, prior to the "Ready set-up" interval (t $\mathrm{R}_{\mathrm{RS}}$ ) which occurs during the $\phi_{2}$ pulse within state $T_{2}$ or TW. As long as the READY line remains low, the processor will idle, giving the memory time to respond to the addressed data request. Refer to Figure 2-5.

The processor responds to a wait request by entering an alternative state ( $\mathrm{T}_{\mathrm{W}}$ ) at the end of $\mathrm{T}_{2}$, rather than proceeding directly to the $T_{3}$ state. Entry into the $T_{W}$ state is indicated by a WAIT signal from the processor, acknowledging the memory's request. A low-to-high transition on the WAIT line is triggered by the rising edge of the $\phi_{1}$ clock and occurs within a brief delay ( ${ }^{\mathrm{D}} \mathrm{DC}$ ) of the actual entry into the TW state.

A wait period may be of indefinite duration. The processor remains in the waiting condition until its READY line again goes high. A READY indication must precede the falling edge of the $\phi_{2}$ clock by a specified interval ( $t_{\text {RS }}$ ), in order to guarantee an exit from the $\mathrm{T}_{\mathrm{W}}$ state. The cycle may then proceed, beginning with the rising edge of the next $\phi_{1}$ clock. A WAIT interval will therefore consist of an integral number of TW states and will always be a multiple of the clock period.

Instructions for the 8080 require from one to five machine cycles for complete execution. 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
Symbols Bit

## Definition

INTA* $\mathrm{D}_{0}$

Acknowledge signal for INTERRUPT request. Signal should be used to gate a restart instruction onto the data bus when DBIN is active.
$\overline{\text { WO }}$
$\mathrm{D}_{1}$ Indicates that the operation in the current machine cycle will be a WRITE memory or OUTPUT function ( $\overline{\mathrm{WO}}=0$ ). Otherwise, a READ memory or INPUT operation will be executed.
STACK $\quad \mathrm{D}_{2} \quad \begin{aligned} & \text { Indicates that the address bus holds the } \\ & \text { pushdown stack address from the Stack }\end{aligned}$ pushdown stack address from the Stack Pointer.
HLTA $\quad D_{3} \quad$ Acknowledge signal for HALT instruction.
OUT $\quad \mathrm{D}_{4} \quad$ Indicates that the address bus contains the address of an output device and the data bus will contain the output data when WR is active.
$M_{1} \quad D_{5} \quad$ Provides a signal to indicate that the CPU is in the fetch cycle for the first byte of an instruction.
INP* $\quad \mathrm{D}_{6} \quad$ Indicates that the address bus contains the address of an input device and the input data should be placed on the data bus when DBIN is active.
MEMR* $\quad D_{7} \quad$ Designates that the data bus will be used for memory read data.

* These three status bits can be used to control the flow of data onto the 8080 data bus.



## STATUS WORD CHART



Figure 2-4. CPU State Transition Diagram

The events that take place during the $\mathrm{T}_{3}$ state are determined by the kind of machine cycle in progress. In a FETCH machine cycle, the processor interprets the data on its data bus as an instruction. During a MEMORY READ or a STACK READ, data on this bus is interpreted as a data word. The processor outputs data on this bus during a MEMORY WRITE machine cycle. During I/O operations, the processor may either transmit or receive data, depending on whether an OUTPUT or an INPUT operation is involved.

Figure 2-6 illustrates the timing that is characteristic of a data input operation. As shown, the low-to-high transition of $\phi_{2}$ during $T_{2}$ clears status information from the processor's data lines, preparing these lines for the receipt of incoming data. The data presented to the processor must have stabilized prior to both the " $\phi_{1}$-data set-up" interval ( $\mathrm{t}_{\mathrm{DS} 1}$ ), that precedes the falling edge of the $\phi_{1}$ pulse defining state $T_{3}$, and the " $\phi_{2}$-data set-up" interval ( ${ }^{\text {DS } 2}$ ), that precedes the rising edge of $\phi_{2}$ in state $T_{3}$. This same
data must remain stable during the "data hold" interval ( $\mathrm{t} \mathrm{DH}^{\prime}$ ) that occurs following the rising edge of the $\phi_{2}$ pulse. Data placed on these lines by memory or by other external devices will be sampled during $\mathrm{T}_{3}$.

During the input of data to the processor, the 8080 generates a DBIN signal which should be used externally to enable the transfer. Machine cycles in which DBIN is available include: FETCH, MEMORY READ, STACK READ, and INTERRUPT. DBIN is initiated by the rising edge of $\phi_{2}$ during state $T 2$ and terminated by the corresponding edge of $\phi_{2}$ during $T_{3}$. Any $T_{W}$ phases intervening between $T_{2}$ and T3 will therefore extend DBIN by one or more clock periods.

Figure 2-7 shows the timing of a machine cycle in which the processor outputs data. Output data may be destined either for memory or for peripherals. The rising edge of $\phi_{2}$ within state $T_{2}$ clears status information from the CPU's data lines, and loads in the data which is to be output to external devices. This substitution takes place within the


NOTE: (N) Refer to Status Word Chart on Page 2-6.
Figure 2-5. Basic 8080 Instruction Cycle


NOTE: (N) Refer to Status Word Chart on Page 2-6.

Figure 2-6. Input Instruction Cycle


Figure 2-7. Output Instruction Cycle
"data output delay" interval (tDD) following the $\phi_{2}$ clock's leading edge. Data on the bus remains stable throughout the remainder of the machine cycle, until replaced by updated status information in the subsequent $\mathrm{T}_{1}$ state. Observe that a READY signal is necessary for completion of an OUTPUT machine cycle. Unless such an indication is present, the processor enters the $T_{W}$ state, following the $T_{2}$ state. Data on the output lines remains stable in the interim, and the processing cycle will not proceed until the READY line again goes high.

The 8080 CPU generates a $\overline{W R}$ output for the synchronization of external transfers, during those machine cycles in which the processor outputs data. These include MEMORY WRITE, STACK WRITE, and OUTPUT. The negative-going leading edge of $\overline{W R}$ is referenced to the rising edge of the first $\phi_{1}$ clock pulse following $\mathrm{T}_{2}$, and occurs within a brief delay ( ${ }^{\mathrm{D} D}$ ) of that event. $\overline{\mathrm{WR}}$ remains low until re-triggered by the leading edge of $\phi_{1}$ during the state following $T_{3}$. Note that any $T_{W}$ states intervening between $T_{2}$ and $T_{3}$ of the output machine cycle will neces-
sarily extend $\overline{W R}$, in much the same way that DBIN is affected during data input operations.

All processor machine cycles consist of at least three states: $T_{1}, T_{2}$, and $T_{3}$ as just described. If the processor has to wait for a response from the peripheral or memory with which it is communicating, then the machine cycle may also contain one or more TW states. During the three basic states, data is transferred to or from the processor.

After the $\mathrm{T}_{3}$ state, however, it becomes difficult to generalize. $\mathrm{T}_{4}$ and $\mathrm{T}_{5}$ states are available, if the execution of a particular instruction requires them. But not all machine cycles make use of these states. It depends upon the kind of instruction being executed, and on the particular machine cycle within the instruction cycle. The processor will terminate any machine cycle as soon as its processing activities are completed, rather than proceeding through the $\mathrm{T}_{4}$ and $\mathrm{T}_{5}$ states every time. Thus the 8080 may exit a machine cycle following the $T_{3}$, the $T_{4}$, or the $T_{5}$ state and proceed directly to the $\mathrm{T}_{1}$ state of the next machine cycle.

| STATE | ASSOCIATED ACTIVITIES |
| :---: | :--- |
| $\mathrm{T}_{1}$ | A memory address or I/O device number is <br> placed on the Address Bus (A 15-0); status <br> information is placed on Data Bus (D7-0). |
| $\mathrm{T}_{2}$ | The CPU samples the READY and HOLD in- <br> puts and checks for halt instruction. |
| TW | Processor enters wait state if READY is low <br> or if HALT instruction has been executed. |
| T3 | An instruction byte (FETCH machine cycle), <br> data byte (MEMORY READ, STACK READ) <br> or interrupt instruction (INTERRUPT machine <br> cycle) is input to the CPU from the Data Bus; <br> or a data byte (MEMORY WRITE, STACK <br> WRITE or OUTPUT machine cycle) is output <br> onto the data bus. |
| T4 <br> T5 | States T4 and T5 are available if the execu- <br> tion of a particular instruction requires them; <br> if not, the CPU may skip one or both of <br> them. T4 and T5 are only used for internal <br> processor operations. |

Table 2-2. State Definitions

## INTERRUPT SEQUENCES

The 8080 has the built-in capacity to handle external interrupt requests. A peripheral device can initiate an interrupt simply by driving the processor's interrupt (INT) line high.

The interrupt (INT) input is asynchronous, and a request may therefore originate at any time during any instruction cycle. Internal logic re-clocks the external request, so that a proper correspondence with the driving clock is established. As Figure $2-8$ shows, an interrupt request (INT) arriving during the time that the interrupt enable line (INTE) is high, acts in coincidence with the $\phi_{2}$ clock to set the internal interrupt latch. This event takes place during the last state of the instruction cycle in which the request occurs, thus ensuring that any instruction in progress is completed before the interrupt can be processed.

The INTERRUPT machine cycle which follows the arrival of an enabled interrupt request resembles an ordinary FETCH machine cycle in most respects. The $\mathrm{M}_{1}$ status bit is transmitted as usual during the SYNC interval. It is accompanied, however, by an INTA status bit ( $\mathrm{D}_{0}$ ) which acknowledges the external request. The contents of the program counter are latched onto the CPU's address lines during $T_{1}$, but the counter itself is not incremented during the INTERRUPT machine cycle, as it otherwise would be.

In this way, the pre-interrupt status of the program counter is preserved, so that data in the counter may be restored by the interrupted program after the interrupt request has been processed.

The interrupt cycle is otherwise indistinguishable from an ordinary FETCH machine cycle. The processor itself takes no further special action. It is the responsibility of the peripheral logic to see that an eight-bit interrupt instruction is "jammed" onto the processor's data bus during state $\mathrm{T}_{3}$. In a typical system, this means that the data-in bus from memory must be temporarily disconnected from the processor's main data bus, so that the interrupting device can command the main bus without interference.

The 8080's instruction set provides a special one-byte call which facilitates the processing of interrupts (the ordinary program Call takes three bytes). This is the RESTART instruction (RST). A variable three-bit field embedded in the eight-bit field of the RST enables the interrupting device to direct a Call to one of eight fixed memory locations. The decimal addresses of these dedicated locations are: $0,8,16$, $24,32,40,48$, and 56 . Any of these addresses may be used to store the first instruction(s) of a routine designed to service the requirements of an interrupting device. Since the (RST) is a call, completion of the instruction also stores the old program counter contents on the STACK.


NOTE: (N) Refer to Status Word Chart on Page 2-6.

Figure 2-8. Interrupt Timing


Figure 2-9. HOLD Operation (Read Mode)


Figure 2-10. HOLD Operation (Write Mode)

## HOLD SEQUENCES

The 8080A CPU contains provisions for Direct Memory Access (DMA) operations. By applying a HOLD to the appropriate control pin on the processor, an external device can cause the CPU to suspend its normal operations and relinquish control of the address and data busses. The processor responds to a request of this kind by floating its address to other devices sharing the busses. At the same time, the processor acknowledges the HOLD by placing a high on its HLDA outpin pin. During an acknowledged HOLD, the address and data busses are under control of the peripheral which originated the request, enabling it to conduct memory transfers without processor intervention.

Like the interrupt, the HOLD input is synchronized internally. A HOLD signal must be stable prior to the "Hold set-up" interval ( $\mathrm{t}_{\mathrm{HS}}$ ), that precedes the rising edge of $\phi_{2}$.

Figures 2-9 and 2-10 illustrate the timing involved in HOLD operations. Note the delay between the asynchronous HOLD REQUEST and the re-clocked HOLD. As shown in the diagram, a coincidence of the READY, the HOLD, and the $\phi_{2}$ clocks sets the internal hold latch. Setting the latch enables the subsequent rising edge of the $\phi_{1}$ clock pulse to trigger the HLDA output.

Acknowledgement of the HOLD REQUEST precedes slightly the actual floating of the processor's address and data lines. The processor acknowledges a HOLD at the beginning of $T_{3}$, if a read or an input machine cycle is in progress (see Figure 2-9). Otherwise, acknowledgement is deferred until the beginning of the state following $T_{3}$ (see Figure 2-10). In both cases, however, the HLDA goes high within a specified delay ( ${ }^{D} \mathrm{DC}$ ) of the rising edge of the selected $\phi_{1}$ clock pulse. Address and data lines are floated within a brief delay after the rising edge of the next $\phi_{2}$ clock pulse. This relationship is also shown in the diagrams.

To all outward appearances, the processor has suspended its operations once the address and data busses are floated. Internally, however, certain functions may continue. If a HOLD REQUEST is acknowledged at $T_{3}$, and if the processor is in the middle of a machine cycle which requires four or more states to complete, the CPU proceeds through $\mathrm{T}_{4}$ and $\mathrm{T}_{5}$ before coming to a rest. Not until the end of the machine cycle is reached will processing activities cease. Internal processing is thus permitted to overlap the external DMA transfer, improving both the efficiency and the speed of the entire system.

The processor exits the holding state through a sequence similar to that by which it entered. A HOLD REQUEST is terminated asynchronously when the external device has completed its data transfer. The HLDA output
returns to a low level following the leading edge of the next $\phi 1$ clock pulse. Normal processing resumes with the machine cycle following the last cycle that was executed.

## HALT SEQUENCES

When a halt instruction (HLT) is executed, the CPU enters the halt state ( $T_{W H}$ ) after state $T_{2}$ of the next machine cycle, as shown in Figure 2-11. There are only three ways in which the 8080 can exit the halt state:

- A high on the RESET line will always reset the 8080 to state $\mathrm{T}_{1}$; RESET also clears the program counter.
- A HOLD input will cause the 8080 to enter the hold state, as previously described. When the HOLD line goes low, the 8080 re-enters the halt state on the rising edge of the next $\phi_{1}$ clock pulse.
- An interrupt (i.e., INT goes high while INTE is enabled) will cause the 8080 to exit the Halt state and enter state $\mathrm{T}_{1}$ on the rising edge of the next $\phi_{1}$ clock pulse. NOTE: The interrupt enable (INTE) flag must be set when the halt state is entered; otherwise, the 8080 will only be able to exit via a RESET signal.

Figure 2-12 illustrates halt sequencing in flow chart form.

## START-UP OF THE 8080 CPU

When power is applied initially to the 8080, the processor begins operating immediately. The contents of its program counter, stack pointer, and the other working registers are naturally subject to random factors and cannot be specified. For this reason, it will be necessary to begin the power-up sequence with RESET.

An external RESET signal of three clock period duration (minimum) restores the processor's internal program counter to zero. Program execution thus begins with memory location zero, following a RESET. Systems which require the processor to wait for an explicit start-up signal will store a halt instruction (EI, HLT) in the first two locations. A manual or an automatic INTERRUPT will be used for starting. In other systems, the processor may begin executing its stored program immediately. Note, however, that the RESET has no effect on status flags, or on any of the processor's working registers (accumulator, registers, or stack pointer). The contents of these registers remain indeterminate, until initialized explicitly by the program.


NOTE: (N) Refer to Status Word Chart on Page 2-6
Figure 2-11. HALT Timing


Figure 2-12. HALT Sequence Flow Chart.


NOTE: (N) Refer to Status Word Chart on Page 2-6.

Figure 2-13. Reset.


NOTE: (N) Refer to Status Word Chart on Page 2-6.

Figure 2-14. Relation between HOLD and INT in the HALT State.

| MNEMONIC | OP CODE |  | M1 ${ }^{[1]}$ |  |  |  |  | M2 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{D}_{7} \mathrm{D}_{6} \mathrm{D}_{5} \mathrm{D}_{4}$ | $\mathrm{D}_{3} \mathrm{D}_{2} \mathrm{D}_{1} \mathrm{D}_{0}$ | T1 | T2 ${ }^{[2]}$ | T3 | T4 | T5 | T1 | T2 ${ }^{[2]}$ | T3 |
| MOV r1, r 2 | 01 D D | D S S s | PC OUT STATUS | $\mathrm{PC}=\mathrm{PC}+1$ | INST $\rightarrow$ TMP/IR | (SSS) $\rightarrow$ TMP | $(\mathrm{TMP}) \rightarrow$ DDD |  |  |  |
| MOV r, M | 01 D D | D 110 | 4 | 4 |  | $x^{[3]}$ |  | HL OUT STATUS[6] | DATA | DDD |
| MOV M, r | $0 \times 111$ | 0 s s s |  |  |  | $(S S S) \rightarrow$ TMP |  | HL OUT STATUS[7] | (TMP) | -DATA BUS |
| SPHL | 11111 | 1001 |  |  |  | (HL) | SP |  |  |  |
| MVI redata | 00 D D | D 110 |  |  |  | X |  | PC OUT STATUS[6] |  | -DDDD |
| MVI M, data | $\begin{array}{llll}0 & 0 & 1 & 1\end{array}$ | 0110 |  |  |  | x |  | 1 |  | TMP |
| LXI rp, data | 0 OR P | 00001 |  |  |  | X |  |  | $\mathrm{PC}=P \mathrm{PC}+1 \quad \mathrm{~B} 2$ | -1 |
| LDA addr | 00011 | 1010 |  |  |  | X |  |  | $P C=P C+1 \quad B 2$ | Z |
| STA addr | 00011 | 0010 |  |  |  | x |  |  | $P C=P C+1 \quad B 2$ | z |
| LHLD addr | 0010 | 1010 | . |  |  | X |  | 1 | $\mathrm{PC}=\mathrm{PC}+1 \quad \mathrm{~B} 2$ | Z |
| SHLD addr | 0010 | 00010 |  |  |  | x |  | PC OUT STATUS ${ }^{[6]}$ | $\mathrm{PC}=\mathrm{PC}+1 \quad \mathrm{~B} 2-$ | z |
| LDAX rp ${ }^{\text {[4] }}$ | 0 OR P | 1010 |  |  |  | X |  | rp OUT STATUS ${ }^{[6]}$ | DATA | A |
| STAX rp ${ }^{[4]}$ | 0 O R P | 0010 |  |  |  | X |  | rpOUT STATUS[7] |  | DATA BUS |
| XCHG | 1110 | $1 \begin{array}{llll}1 & 0 & 1 & 1\end{array}$ |  |  |  | $(\mathrm{HL}) \longleftrightarrow(\mathrm{DE})$ |  |  |  |  |
| ADD r | 1000 | 0 s s s |  |  |  | $\begin{aligned} & \text { (SSS }) \rightarrow \text { TMP } \\ & (\mathrm{A}) \rightarrow \mathrm{ACT} \end{aligned}$ |  | [9] | $(\mathrm{ACT})+(\mathrm{TMP}) \rightarrow \mathrm{A}$ |  |
| ADD M | 1000 | 01110 |  |  |  | (A) $\rightarrow$ ACT |  | HL OUT STATUS ${ }^{[6]}$ | DATA | -TMP |
| ADI data | 1.100 | 0110 |  |  |  | (A) $\rightarrow$ ACT |  | PC OUT STATUS[6] | $\mathrm{PC}=\mathrm{PC}+1 \quad \mathrm{~B} 2-$ | -TMP |
| ADCr | 1000 | 1 S S S |  |  |  | $\begin{aligned} & \text { (SSS) } \rightarrow \text { TMP } \\ & (\mathrm{A}) \rightarrow \mathrm{ACT} \end{aligned}$ |  | [9] | $(\mathrm{ACT})+($ TMP) $+C Y \rightarrow A$ |  |
| ADC M | 1000 | 1110 |  |  |  | (A) $\rightarrow$ ACT |  | HL OUT STATUS ${ }^{[6]}$ | DATA | TMP |
| ACl data | 1100 | 1110 |  |  |  | (A) $\rightarrow$ ACT |  | PC OUT STATUS ${ }^{[6]}$ | $\mathrm{PC}=\mathrm{PC}+1 \quad \mathrm{~B} 2-$ | -TMP |
| SUB r | 1001 | 0 s s s |  |  |  | $\underset{(\mathrm{A}) \rightarrow \mathrm{ACT}}{(\mathrm{SSS}) \rightarrow \text { TMP }}$ |  | [9] | ( ACT )-(TMP) $\rightarrow$ A |  |
| SUB M | 1001 | 0110 |  |  |  | $(\mathrm{A}) \rightarrow \mathrm{ACT}$ |  | HL OUT STATUS ${ }^{[6]}$ | DATA | $\rightarrow$ TMP |
| SUI data | 1101 | 0110 |  |  |  | ( A$) \rightarrow \mathrm{ACT}$ |  | PC OUT STATUS ${ }^{[6]}$ | $\mathrm{PC}=\mathrm{PC}+1 \quad \mathrm{~B} 2-$ | -TMP |
| SBB r | 10001 | 1 s s s |  |  |  | $\begin{aligned} & \text { (SSS) } \rightarrow \text { TMP } \\ & (\mathrm{A}) \rightarrow \mathrm{ACT} \end{aligned}$ |  | [9] | ( ACT )-(TMP)-CY $\rightarrow$ A |  |
| SBB M | 1001 | 1110 |  |  |  | (A) $\rightarrow$ ACT |  | HL OUT STATUS ${ }^{[6]}$ | DATA- | -TMP |
| SBI data | 1101 | 1110 |  |  |  | (A) $\rightarrow$ ACT |  | PC OUT STATUS ${ }^{[6]}$ | $P C=P C+1 \quad B 2-$ | -TMP |
| INR r | 00 D | D 100 |  |  |  | $\begin{aligned} & (D D D) \rightarrow T M P \\ & (T M P)+1 \rightarrow A L U \end{aligned}$ | ALU $\rightarrow$ DDD |  |  |  |
| INR M | 0011 | 0100 |  |  |  | X |  | HL OUT STATUS[6] | $\begin{aligned} & \text { DATA - } \\ & \text { (TMP) }+1 \end{aligned}$ | $\begin{aligned} & -\mathrm{TMP} \\ & -\mathrm{ALU} \end{aligned}$ |
| DCR r | 00 D | D 101 |  |  |  | $\begin{aligned} & \text { (DDD) } \rightarrow \text { TMP } \\ & (T M P)+1 \rightarrow A L U \end{aligned}$ | ALU $\rightarrow$ DDD |  |  |  |
| DCR M | 0011 | 0101 |  |  |  | X |  | HL OUT STATUS ${ }^{[6]}$ | $\begin{aligned} & \text { DATA- } \\ & \text { (TMP)-1 } \end{aligned}$ | $\begin{aligned} & -T M P \\ & -A L U \end{aligned}$ |
| INX rp | 00 RP | 00011 |  |  |  | (RP) +1 | RP |  |  |  |
| DCX rp | 00 RP | 1011 |  |  |  | (RP) - 1 | RP |  |  |  |
| DAD rp ${ }^{[8]}$ | 0 O R P | 1001 |  |  | . | X |  | (ri) $\rightarrow$ ACT | $\begin{aligned} & (\mathrm{L}) \rightarrow \text { TMP, } \\ & (\mathrm{ACT})+(\mathrm{T} M P) \rightarrow \mathrm{ALU} \end{aligned}$ | ALU $\rightarrow$ L, CY |
| DAA | 0010 | $0 \begin{array}{llll}0 & 1 & 1 & 1\end{array}$ |  |  |  | DAA $\rightarrow$ A, FLAGS ${ }^{(10]}$ |  |  |  |  |
| ANA r | 1010 | 0 s s s | $1$ |  | $\ddagger$ | $\begin{aligned} & \text { (SSS) } \rightarrow \text { TMP } \\ & (\mathrm{A}) \rightarrow \mathrm{ACT} \end{aligned}$ |  | [9] | $(A C T)+(T M P) \rightarrow A$ |  |
| ANA M | 1010 | 0110 | PC OUT STATUS | $\mathrm{PC}=\mathrm{PC}+1$ | INST $\rightarrow$ TMP/IR | $(A) \rightarrow A C T$ |  | HL OUT STATUS ${ }^{[6]}$ | DATA | $\rightarrow$ TMP |


| M3 |  |  | M4 |  |  | M5 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| T1 | $\mathrm{T}_{2}{ }^{[2]}$ | T3 | T1 | T2 ${ }^{[2]}$ | T3 | T1 | T2 ${ }^{[2]}$ | T3 | T4 | T5 |
|  |  |  |  |  |  |  |  |  | $4$ | $4$ |
|  |  | $\sqrt{4}=$ |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| m | 4 | 4n! |  |  |  |  |  |  |  | $\sqrt{4 \pi}$ |
| HL OUT STATUS[7] | (TMP) | - DATA BuS |  |  |  |  |  |  |  |  |
| PC OUT STATUS[6] | $\mathrm{PC}=\mathrm{PC}+1 \quad \mathrm{~B} 3-$ | rh |  |  |  |  |  | . |  |  |
| 4 | $P C=P C+1 \quad 83-$ | $\rightarrow$ w | wz out STATUS[6] | DATA | A | $4$ | ? |  |  |  |
|  | $P C=P C+1 \quad B 3-$ | $\rightarrow$ W | wZ OUT STATUS[7] | (A) | - DATA BUS | $4$ |  |  |  |  |
| $\downarrow$ | $P C=P C+1 \quad B 3-$ | - W | WZ OUT STATUS[6] | $\begin{aligned} & \text { DATA } \\ & W Z=W Z+1 \end{aligned}$ | L | wZ OUT STATUs [6] | DATA | H |  |  |
| PCOUT STATUS [6] | $P C=P C+1 \quad 83-$ | - W | wZ OUT STATUS[7] | $\begin{aligned} & \text { (L) } \\ & w Z+1 \end{aligned}$ | - Data bus | wz Out STATUS[7] | (H) | -DATA BUS |  |  |
| $2$ |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| [9] | $(\mathrm{ACT})+(\mathrm{TMP}) \rightarrow \mathrm{A}$ |  |  |  |  |  |  |  |  |  |
| [9] | $(\mathrm{ACT})+(\mathrm{TMP}) \rightarrow \mathrm{A}$ |  |  |  |  |  |  | $4$ |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| [9] | $(\mathrm{ACT})+($ TMP) $+\mathrm{C} Y \rightarrow \mathrm{~A}$ |  |  |  |  |  |  |  |  |  |
| [9] | $(A C T)+(T M P)+C Y \rightarrow A$ |  | $1$ |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| [9] | ( ACT )-(TMP) $\rightarrow$ A |  |  |  |  |  |  |  |  | $\sqrt{2=1}$ |
| [9] | ( ACT )-(TMP) $\rightarrow$ A |  |  |  |  |  |  |  | [ |  |
|  |  |  |  |  |  |  |  |  |  |  |
| [9] | ( ACT )-(TMP)-CY $\rightarrow$ A |  |  |  |  |  |  |  |  |  |
| [9] | ( ACT )-(TMP)-CY $\rightarrow \mathrm{A}$ |  |  |  |  | $\square$ |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| HL OUT STATUS[7] | ALU | - DATA BUS |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | $4$ |  |  |
| HL OUT STATUS[7] | ALU | - DATA BUS |  |  |  |  |  |  |  |  |
|  |  |  | $\square$ |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |
| $(\mathrm{rh}) \rightarrow \mathrm{ACT}$ | $\begin{aligned} & (H) \rightarrow T M P \\ & (A C T)+(T M P)+C Y \rightarrow A L U \end{aligned}$ | $\mathrm{ALU} \rightarrow \mathrm{H}, \mathrm{CY}$ |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | I. |  |  |
|  |  |  |  | $4$ |  |  |  |  |  |  |
| [9] | ( ACT ) + (TMP) $\rightarrow$ A |  |  |  |  |  |  |  |  |  |




## NOTES:

1. The first memory cycle (M1) is always an instruction fetch; the first (or only) byte, containing the op code, is fetched during this cycle.
2. If the READY input from memory is not high during T2 of each memory cycle, the processor will enter a wait state (TW) until READY is sampled as high.
3. States T4 and T5 are present, as required, for operations which are completely internal to the CPU. The contents of the internal bus during T4 and T5 are available at the data bus; this is designed for testing purposes only. An " X " denotes that the state is present, but is only used for such internal operations as instruction decoding.
4. Only register pairs $\mathrm{rp}=\mathrm{B}$ (registers B and C ) or $\mathrm{rp}=\mathrm{D}$ (registers D and E) may be specified.
5. These states are skipped.
6. Memory read sub-cycles; an instruction or data word will be read.
7. Memory write sub-cycle.
8. The READY signal is not required during the second and third sub-cycles (M2 and M3). The HOLD signal is accepted during M2 and M3. The SYNC signal is not generated during M2 and M3. During the execution of DAD, M2 and M3 are required for an internal register-pair add; memory is not referenced.
9. The results of these arithmetic, logical or rotate instructions are not moved into the accumulator (A) until state T2 of the next instruction cycle. That is, $A$ is loaded while the next instruction is being fetched; this overlapping of operations allows for faster processing.
10. If the value of the least significant 4-bits of the accumulator is greater than 9 or if the auxiliary carry bit is set, 6 is added to the accumulator. If the value of the most significant 4 -bits of the accumulator is now greater than 9 , or if the carry bit is set, 6 is added to the most significant 4-bits of the accumulator.
11. This represents the first sub-cycle (the instruction fetch) of the next instruction cycle.
12. If the condition was met, the contents of the register pair $W Z$ are output on the address lines $\left(A_{0-15}\right)$ instead of the contents of the program counter (PC).
13. If the condition was not met, sub-cycles M4 and M5 are skipped; the processor instead proceeds immediately to the instruction fetch (M1) of the next instruction cycle.
14. If the condition was not met, sub-cycles M2 and M3 are skipped; the processor instead proceeds immediately to the instruction fetch (M1) of the next instruction cycle.
15. Stack read sub-cycle.
16. Stack write sub-cycle.
17. CONDITION

| $N Z-$ not zero $(Z=0)$ | 000 |
| :---: | :--- |
| $Z-$ zero $(Z=1)$ | 001 |
| $N C-$ no carry $(C Y=0)$ | 010 |
| $C-$ carry $(C Y=1)$ | 011 |
| $P O-$ parity odd $(P=0)$ | 100 |
| $P E-$ parity even $(P=1)$ | 101 |
| $P-\operatorname{plus}(S=0)$ | 110 |
| $M-\operatorname{minus}(S=1)$ | 111 |

18. I/O sub-cycle: the I/O port's 8 -bit select code is duplicated on address lines 0-7 ( $\mathrm{A}_{0-7}$ ) and 8-15 ( $\mathrm{A}_{8-15}$ ).
19. Output sub-cycle.
20. The processor will remain idle in the halt state until an interrupt, a reset or a hold is accepted. When a hold request is accepted, the CPU enters the hold mode; after the hold mode is terminated, the processor returns to the halt state. After a reset is accepted, the processor begins execution at memory location zero. After an interrupt is accepted, the processor executes the instruction forced onto the data bus (usually a restart instruction).

| SSS or DDD | Value | rp | Value |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A | 111 | B | 00 |  |  |
| B | 000 | D | 01 |  |  |
| C | 001 | H | 10 |  |  |
| D | 010 | SP | 11 |  |  |
| E | 011 |  |  |  |  |
| H | 100 |  |  |  |  |
| L | 101 |  |  |  |  |

Chapter 3
INTERFACING THE 8080


## INTERFACING THE 8080

This chapter will illustrate, in detail, how to interface the 8080 CPU with Memory and I/O. It will also show the benefits and tradeoffs encountered when using a variety of system architectures to achieve higher throughput, decreased component count or minimization of memory size.

8080 Microcomputer system design lends itself to a simple, modular approach. Such an approach will yield the designer a reliable, high performance system that contains a minimum component count and is easy to manufacture and maintain.

The overall system can be thought of as a simple block diagram. The three (3) blocks in the diagram repre sent the functions common to any computer system

CPU Module* Contains the Central Processing Unit, system timing and interface circuitry to Memory and I/O devices.

Memory Contains Read Only Memory (ROM) and Read/Write Memory (RAM) for program and data storage.

I/O Contains circuitry that allows the computer system to communicate with devices or structures existing outside of the CPU or Memory array.
for example: Keyboards, Floppy Disks, Paper Tape, etc.

There are three busses that interconnect these blocks:
Data Bus $\dagger$ A bi-directional path on which data can flow between the CPU and Memory or I/O.

Address Bus A uni-directional group of lines that identify a particular Memory location or I/O device.

[^0]Control Bus A uni-directional set of signals that indicate the type of activity in current process.

Type of activities: 1. Memory Read
2. Memory Write
3. I/O Read
4. I/O Write
5. Interrupt Acknowledge


Figure 3-1. Typical Computer System Block Diagram

## Basic System Operation

1. The CPU Module issues an activity command on the Control Bus.
2. The CPU Module issues a binary code on the Address Bus to identify which particular Memory location or I/O device will be involved in the current process activity.
3. The CPU Module receives or transmits data with the selected Memory location or I/O device.
4. The CPU Module returns to (1) and issues the next activity command.

It is easy to see at this point that the CPU module is the central element in any computer system.

The following pages will cover the detailed design of the CPU Module with the 8080. The three Busses (Data, Address and Control) will be developed and the interconnection to Memory and I/O will be shown.

Design philosophies and system architectures presented in this manual are consistent with product development programs underway at INTEL for the MCS-80. Thus, the designer who uses this manual as a guide for his total system engineering is assured that all new developments in components and software for MCS-80 from INTEL will be compatible with his design approach.

## CPU Module Design

The CPU Module contains three major areas:

1. The 8080 Central Processing Unit
2. A Clock Generator and High Level Driver
3. A bi-directional Data Bus Driver and System Control Logic

The following will discuss the design of the three major areas contained in the CPU Module. This design is presented as an alternative to the Intel ${ }^{\circledR} 8224$ Clock Generator and Intel 8228 System Controller. By studying the alternative approach, the designer can more clearly see the considerations involved in the specification and engineering of the 8224 and 8228 . Standard TTL components and Intel general purpose peripheral devices are used to implement
the design and to achieve operational characteristics that are as close as possible to those of the 8224 and 8228. Many auxiliary timing functions and features of the 8224 and 8228 are too complex to practically implement in standard components, so only the basic functions of the 8224 and 8228 are generated. Since significant benefits in system timing and component count reduction can be realized by using the 8224 and 8228 , this is the preferred method of implementation.

## 1. 8080 CPU

The operation of the 8080 CPU was covered in previous chapters of this manual, so little reference will be made to it in the design of the Module.

## 2. Clock Generator and High Level Driver

The 8080 is a dynamic device, meaning that its internal storage elements and logic circuitry require a timing reference (Clock), supplied by external circuitry, to refresh and provide timing control signals.

The 8080 requires two (2) such Clocks. Their waveforms must be non-overlapping, and comply with the timing and levels specified in the 8080 A.C. and D.C. Characteristics, page 5-15.

## Clock Generator Design

The Clock Generator consists of a crystal controlled,


Figure 3-2. 8080 CPU Interface


Figure 3-3. 8080 Clock Generator
20 MHZ oscillator, a four bit counter, and gating circuits.

The oscillator provides a 20 MHZ signal to the input of a four (4) bit, presettable, synchronous, binary counter. By presetting the counter as shown in figure $3-\mathrm{J}$ and clocking it with the 20 MHZ signal, a simple decoding of the counters outputs using standard TTL gates, provides proper timing for the two (2) 8080 clock inputs.

Note that the timing must actually be measured at the output of the High Level Driver to take into account the added delays and waveform distortions within such a device.

## High Level Driver Design

The voltage level of the clocks for the 8080 is not TTL compatible like the other signals that input to the 8080 . The voltage swing is from .6 volts ( $V_{\text {ILC }}$ ) to 11 volts ( $\mathrm{V}_{\mathrm{IHC}}$ ) with risetimes and falltimes under 50 ns . The Capacitive Drive is 20 pf (max.). Thus, a High Level Driver is required to interface the outputs of the Clock Generator (TTL) to the 8080.

The two (2) outputs of the Clock Generator are capacitivity coupled to a dual- High Level clock driver. The driver must be capable of complying with the 8080 clock input specifications, page 5-15. A driver of this type usually has little problem supplying the
positive transition when biased from the $8080 \mathrm{~V}_{\mathrm{DD}}$ supply ( 12 V ) but to achieve the low voltage specification ( $\mathrm{V}_{\text {ILC }}$ ) . 8 volts Max. the driver is biased to the $8080 \mathrm{~V}_{\mathrm{BB}}$ supply ( -5 V ). This allows the driver to swing from GND to $V_{D D}$ with the aid of a simple resistor divider.

A low resistance series network is added between the driver and the 8080 to eliminate any overshoot of the pulsed waveforms. Now a circuit is apparent that can easily comply with the 8080 specifications. In fact rise and falltimes of this design are typically less than 10 ns .


Figure 3-4. High Level Driver

## Auxiliary Timing Signals and Functions

The Clock Generator can also be used to provide other signals that the designer can use to simplify large system timing or the interface to dynamic memories.

Functions such as power-on reset, synchronization of external requests (HOLD, READY, etc.) and single step, could easily be added to the Clock Generator to further enhance its capabilities.

For instance, the 20 MHZ signal from the oscillator can be buffered so that it could provide the basis for communication baud rate generation.

The Clock Generator diagram also shows how to generate an advanced timing signal ( $\phi 1 \mathrm{~A}$ ) that is handy to use in clocking "D" type flipflops to synchronize external requests. It can also be used to generate a strobe (STSTB) that is the latching signal for the status information which is available on the Data Bus at the beginning of each machine cycle. A simple gating of the SYNC signal from the 8080 and the advanced ( $\phi 1 \mathrm{~A}$ ) will do the job. See Figure 3-3.
3. Bi-Directional Bus Driver and System Control Logic

The system Memory and I/O devices communicate with the CPU over the bi-directional Data Bus. The system Control Bus is used to gate data on and off the Data Bus within the proper timing sequences as dictated by the operation of the 8080 CPU . The data lines of the 8080 CPU , Memory and I/O devices are 3 -state in nature, that is, their output drivers have the ability to be forced into a high-impedance mode and are, effectively, removed from the circuit. This 3state bus technique allows the designer to construct a system around a single, eight (8) bit parallel, bi-directional Data Bus and simply gate the information on or off this bus by selecting or deselecting (3-stating) Memory and I/O devices with signals from the Control Bus.

## Bi-Directional Data Bus Driver Design

The 8080 Data Bus (D7-D0) has two (2) major areas of concern for the designer:

1. Input Voltage level $\left(\mathrm{V}_{\mathrm{IH}}\right) 3.3$ volts minimum.
2. Output Drive Capability ( $\mathrm{I}_{\mathrm{OL}}$ ) 1.7 mA maximum.


Figure 3-5. 8080 System Control

The input level specification implies that any semiconductor memory or I/O device connected to the 8080 Data Bus must be able to provide a minimum of 3.3 volts in its high state. Most semiconductor memories and standard TTL I/O devices have an output capability of between 2.0 and 2.8 volts, obviously a direct connection onto the 8080 Data Bus would require pullup resistors, whose value should not affect the bus speed or stress the drive capability of the memory or I/O components.

The 8080A output drive capability ( $\mathrm{I}_{\mathrm{OL}}$ ) 1.9 mA max. is sufficient for small systems where Memory size and I/O requirements are minimal and the entire system is contained on a single printed circuit board. Most systems however, take advantage of the high-performance computing power of the 8080 CPU and thus a more typical system would require some form of buffering on the 8080 Data Bus to support a larger array of Memory and I/O devices which are likely to be on separate boards.

A device specifically designed to do this buffering function is the INTEL ${ }^{\oplus} 8216$, a (4) four bit bi-directional bus driver whose input voltage levelis compatible with standard TTL devices and semiconductor memory components, and has output drive capability of 50 mA . At the 8080 side, the 8216 has a "high" output of 3.65 volts that not only meets the 8080 input spec but provides the designer with a worse case 350 mV noise margin.

A pair of 8216's are connected directly to the 8080 Data Bus (D7-D0) as shown in figure 3-5. Note that the DBIN signal from the 8080 is connected to the direction control input ( $\overline{\mathrm{DIEN}}$ ) so the correct flow of data on the bus is maintained. The chip select ( $\overline{\mathrm{CS}}$ ) of the 8216 is connected to BUS ENABLE ( $\overline{\mathrm{BUSEN}}$ ) to allow for DMA activities by deselecting the Data Bus Buffer and forcing the outputs of the 8216's into their high impedance (3-state) mode. This allows other devices to gain access to the data bus (DMA).

## System Control Logic Design

The Control Bus maintains discipline of the bi-directional Data Bus, that is, it determines what type of device will have access to the bus (Memory or I/O) and generates signals to assure that these devices transfer Data with the 8080 CPU within the proper timing "windows" as dictated by the CPU operational characteristics.
As described previously, the 8080 issues Status information at the beginning of each Machine Cycle on its Data Bus to indicate what operation will take place during that cycle. A simple (8) bit latch, like an INTEL ${ }^{\oplus} 8212$, connected directly to the 8080 Data Bus (D7-D0) as shown in figure $3-5$ will store the

Status information. The signal that loads the data into the Status Latch comes from the Clock Generator, it is Status Strobe ( $\overline{\mathrm{STSTB}}$ ) and occurs at the start of each Machine Cycle.

Note that the Status Latch is connected onto the 8080 Data Bus (D7-D0) before the Bus Buffer. This is to maintain the integrity of the Data Bus and simplify Control Bus timing inDMA dependent environments.

As shown in the diagram, a simple gating of the outputs of the Status Latch with the DBIN and $\overline{W R}$ signals from the 8080 generate the (4) four Control signals that make up the basic Control Bus.

These four signals: 1. Memory Read ( $\overline{\mathrm{MEM} \mathrm{R}}$ )
2. Memory Write ( $\overline{\mathrm{MEM} \mathrm{W}}$ )
3. I/O Read (I/O R)
4. I/O Write ( $\overline{\mathrm{I} / \mathrm{OW})}$
connect directly to the MCS-80 component "family" of ROMs, RAMs and I/O devices.

A fifth signal, Interrupt Acknowledge ( $\overline{\text { INTA })}$ is added to the Control Bus by gating data off the Status Latch with the DBIN signal from the 8080 CPU. This signal is used to enable the Interrupt Instruction Port which holds the RST instruction onto the Data Bus.

Other signals that are part of the Control Bus such as WO, Stack and M1 are present to aid in the testing of the System and also to simplify interfacing the CPU to dynamic memories or very large systems that require several levels of bus buffering.

## Address Buffer Design

The Address Bus (A15-A0) of the 8080, like the Data Bus, is sufficient to support a small system that has a moderate size Memory and I/O structure, confined to a single card. To expand the size of the system that the Address Bus can support a simple buffer can be added, as shown in figure 3-6. The INTEL 8212 or 8216 is an excellent device for this function. They provide low input loading ( .25 mA ), high output drive and insert a minimal delay in the System Timing.

Note that BUS ENABLE ( $\overline{\mathrm{BUSEN}}$ ) is connected to the buffers so that they are forced into their highimpedance (3-state) mode during DMA activities so that other devices can gain access to the Address Bus.

## INTERFACING THE 8080 CPU TO MEMORY AND I/O DEVICES

The 8080 interfaces with standard semiconductor Memory components and I/O devices. In the previous text the proper control signals and buffering were developed which will produce a simple bus system similar to the basic system example shown at the beginning of this chapter.

In Figure 3-6 a simple, but exact 8080 typical system is shown that can be used as a guide for any 8080 system, regardless of size or complexity. It is a "three bus" architecture, using the signals developed in the CPU module.

Note that Memory and I/O devices interface in the same manner and that their isolation is only a function of the definition of the Read-Write signals on the Control Bus. This allows the 8080 system to be configured so that Memory and I/O are treated as a single array (memory mapped I/O) for small systems that require high thruput and have less than 32 K memory size. This approach will be brought out later in the chapter.

## ROM INTERFACE

A ROM is a device that stores data in the form of Program or other information such as "look-up tables" and is only read from, thus the term Read Only Memory. This type of memory is generally non-volatile, meaning that when the power is removed the information is retained.

This feature eliminates the need for extra equipment like tape readers and disks to load programs initially, an important aspect in small system design.

Interfacing standard ROMs, such as the devices shown in the diagram is simple and direct. The output Data lines are connected to the bi-directional Data Bus, the Address inputs tie to the Address bus with possible decoding of the most significant bits as "chip selects" and the $\overline{M E M R}$ signal from the Control Bus connected to a "chip select" or data buffer. Basically, the CPU issues an address during the first portion of an instruction or data fetch (T1 \& T2). This value on the Address Bus selects a specific location within the ROM, then depending on the ROM's delay (access time) the data stored at the addressed location is present at the Data output lines. At this time (T3) the CPU Data Bus is in the "input Mode" and the control logic issues a Memory Read command ( $\overline{\mathrm{MEMR}}$ ) that gates the addressed data on to the Data Bus.

## RAM INTERFACE

A RAM is a device that stores data. This data can be program, active "look-up tables," temporary values or external stacks. The difference between RAM and ROM is that data can be written into such devices and are in essence, Read/Write storage elements. RAMs do not hold their data when power is removed so in the case where Program or "look-up tables" data is stored a method to load


Figure 3-6. Microcomputer System

RAM memory must be provided, such as: Floppy Disk, Paper Tape, etc.

The CPU treats RAM in exactly the same manner as ROM for addressing data to be read. Writing data is very similar; the RAM is issued an address during the first portion of the Memory Write cycle (T1 \& T2) in T3 when the data that is to be written is output by the CPU and is stable on the bus an $\overline{M E M W}$ command is generated. The $\overline{M E M W}$ signal is connected to the R/W input of the RAM and strobes the data into the addressed location.

In Figure 3-7 a typical Memory system is illustrated to show how standard semiconductor components interface to the 8080 bus. The memory array shown has 8 K bytes ( 8 bits/byte) of ROM storage, using four Intel ${ }^{\text {® }} 8216$ As and 512 bytes of RAM storage, using Intel 8111 static RAMs. The basic interface to the bus structure detailed here is common to almost any size memory. The only addition that might have to be made for larger systems is more buffers (8216/8212) and decoders (8205) for generating "chip selects."

The memories chosen for this example have an access time of 850 nS (max) to illustrate that slower, economical devices can be easily interfaced to the 8080 with little effect on performance. When the 8080 is operated from a clock generator with a tCY of 500 nS the required memory access time is Approx. $450-550 \mathrm{nS}$. See detailed timing specification Pg. 5-16. Using memory devices of this speed such as Intel $8308,8102 \mathrm{~A}, 8107 \mathrm{~A}$, etc. the READY input to the 8080 CPU can remain "high" because no "wait" states are required. Note that the bus interface to memory shown in Figure $3-7$ remains the same. However, if slower memories are to be used, such as the devices illustrated (8316A, 8111) that have access times slower than the minimum requirement a simple logic control of the READY input to the 8080 CPU will insert an extra "wait state" that is equal to one or more clock periods as an access time "adjustment" delay to compensate. The effect of the extra "wait" state is naturally a slower execution time for the instruction. A single "wait" changes the basic instruction cycle to 2.5 microSeconds.


Figure 3-7. Typical Memory Interface

## I/O INTERFACE

## General Theory

As in any computer based system, the 8080 CPU must be able to communicate with devices or structures that exist outside its normal memory array. Devices like keyboards, paper tape, floppy disks, printers, displays and other control structures are used to input information into the 8080 CPU and display or store the results of the computational activity.

Probably the most important and strongest feature of the 8080 Microcomputer System is the flexibility and power of its I/O structure and the components that support it. There are many ways to structure the I/O array so that it will "fit" the total system environment to maximize efficiency and minimize component count.

The basic operation of the I/O structure can best be viewed as an array of single byte memory locations that can be Read from or Written into. The 8080 CPU has special instructions devoted to managing such transfers (IN, OUT). These instructions generally isolate memory and I/O arrays so that memory address space is not effected by the 1/O structure and the general concept is that of a simple transfer to or from the Accumulator with an addressed "PORT". Another method of $\mathrm{I} / \mathrm{O}$ architecture is to treat the I/O structure as part of the Memory array. This is generally referred to as "Memory Mapped I/O" and provides the designer with a powerful new "instruction set" devoted to I/O manipulation.


Figure 3-8. Memory/I/O Mapping.

## Isolated I/O

In Figure 3-9 the system control signals, previously detailed in this chapter, are shown. This type of I/O architecture separates the memory address space from the I/O address space and uses a conceptually simple transfer to or from Accumulator technique. Such an architecture is easy to understand because I/O communicates only with the Accumulator using the IN or OUT instructions. Also because of the isolation of memory and I/O, the full address space ( 65 K ) is uneffected by I/O addressing.


Figure 3-9. Isolated I/O.

## Memory Mapped I/O

By assigning an area of memory address space as I/O a powerful architecture can be developed that can manipulate I/O using the same instructions that are used to manipulate memory locations. Thus, a "new" instruction set is created that is devoted to I/O handling.

As shown in Figure 3-10, new control signals are generated by gating the $\overline{M E M R}$ and $\overline{M E M W}$ signals with $A_{15}$, the most significant address bit. The new I/O control signals connect in exactly the same manner as Isolated I/O, thus the system bus characteristics are unchanged.

By assigning A15 as the I/O "flag", a simple method of $\mathrm{I} / \mathrm{O}$ discipline is maintained:

If $A_{15}$ is a "zero" then Memory is active.
If $\mathrm{A}_{15}$ is a "one" then I/O is active.
Other address bits can also be used for this function. A 15 was chosen because it is the most significant address bit so it is easier to control with software and because it still allows memory addressing of 32 K .

I/O devices are still considered addressed "ports" but instead of the Accumulator as the only transfer medium any of the internal registers can be used. All instructions that could be used to operate on memory locations can be used in I/O.

Examples:

| MOVr, M | (Input Port to any Register) |
| :--- | :--- |
| MOV M, r | (Output any Register to Port) |
| MVI M | (Output immediate data to Port) |
| LDA | (Input to ACC) |
| STA | (Output from ACC to Port) |
| LHLD | (16 Bit Input) |
| SHLD | (16 Bit Output) |
| ADD M | (Add Port to ACC) |
| ANA M | ("AND" Port with ACC) |

It is easy to see that from the list of possible "new" instructions that this type of $1 / 0$ architecture could have a drastic effect on increased system throughput. It is conceptually more difficult to understand than Isolated I/O and it does limit memory address space, but Memory Mapped I/O can mean a significant increase in overall speed and at the ${ }^{-}$ same time reducing required program memory area.


Figure 3-10. Memory Mapped I/O.

## I/O Addressing

With both systems of I/O structure the addressing of each device can be configured to optimize efficiency and reduce component count. One method, the most common, is to decode the address bus into exclusive "chip selects" that enable the addressed I/O device, similar to generating chipselects in memory arrays.

Another method is called "linear select". In this method, instead of decoding the Address Bus, a singular bit from the bus is assigned as the exclusive enable for a specific I/O device. This method, of course, limits the number of I/O devices that can be addressed but eliminates the need for extra decoders, an important consideration in small system design.

A simple example illustrates the power of such a flexible I/O structure. The first example illustrates the format of the second byte of the IN or OUT instruction using the Isolated I/O technique. The devices used are Intel ${ }^{\circledR} 8255$ Programmable Peripheral Interface units and are linear selected. Each device has three ports and from the format it can be seen that six devices can be addressed without additional decoders.


Figure 3-11. Isolated I/O - (Linear Select) (8255)

The second example uses Memory Mapped I/O and linear select to show how thirteen devices (8255) can be addressed without the use of extra decoders. The format shown could be the second and third bytes of the LDA or STA instructions or any other instructions used to manipulate I/O using the Memory Mapped technique.

It is easy to see that such a flexible I/O structure, that can be "tailored" to the overall system environment, provides the designer with a powerful tool to optimize efficiency and minimize component count.

EXAMPLE \#2


Figure 3-12. Memory Mapped I/O - (Linear Select (8255)

## I/O Interface Example

In Figure 3-16 a typical I/O system is shown that uses a variety of devices (8212, 8251 and 8255 ). It could be used to interface the peripherals around an intelligent CRT terminals; keyboards, display, and communication interface. Another application could be in a process controller to interface sensors, relays, and motor controls. The limitation of the application area for such a circuit is solely that of the designers imagination.

The I/O structure shown interfaces to the 8080 CPU using the bus architecture developed previously in this chapter. Either Isolated or Memory Mapped techniques can be used, depending on the system I/O environment.

The 8251 provides a serial data communication interface so that the system can transmit and receive data over communication links such as telephone lines.


0 - DATA 1 - COMMAND

Figure 3-13. 8251 Format.

The two (2) 8255 s provide twenty four bits each of programmable I/O data and control so that keyboards, sensors, paper tape, etc., can be interfaced to the system.


Figure 3-14. 8255 Format.

The three 8212s can be used to drive long lines or LED indicators due to their high drive capability. $(15 \mathrm{~mA})$


Figure 3-15. 8212 Format.

Addressing the structure is described in the formats illustrated in Figures 3-13, 3-14, 3-15. Linear Select is used so that no decoders are required thus, each device has an exclusive "enable bit".

The example shows how a powerful yet flexible I/O structure can be created using a minimum component count with devices that are all members of the 8080 Microcomputer System.


Figure 3-16. Typical I/O Interface.

Chapter 4

## INSTRUCTION SET



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

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.

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., OR the contents of two registers) and register operate instructions (e.g., increment a register) are included in the instruction set. A computer's instruction set will also have instructions that move data between registers, between a register and memory, and between a register and an I/O device. Most instruction sets also provide Conditional Instructions. A conditional instruction specifies an operation to be 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 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.

One type of programming language is Assembly Language. A unique assembly language mnemonic is assigned to each of the computer's instructions. The programmer can write a program (called the Source Program) using these mnemonics 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 (1 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 of instructions:

- 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 instructiens 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 integers:

DATA WORD


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


Two-Byte Instructions


Three-Byte Instructions


## 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).

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:

- Direct - The branch instruction contains the address of the next instruction to be executed. (Except for the 'RST' instruction, byte 2 contains the low-order address and byte 3 the high-order address.)
- Register indirect - The branch 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 (usually used during interrupt sequences). RST includes 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:

There are five condition flags associated with the execution of instructions on the 8080. They are Zero, Sign, Parity, Carry, and Auxiliary 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:

Zero: If the result of an instruction has the value 0 , this flag is set; otherwise it is reset.

Sign: If the most significant bit of the result of the operation has the value 1 , this flag is set; otherwise it is reset.
Parity: 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).
Carry: If the instruction resulted in a carry (from addition), or a borrow (from subtraction or a comparison) out of the highorder bit, this flag is set; otherwise it is reset.

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, comparisons, and logical operations, but is principally used with additions and increments preceding a DAA (Decimal Adjust Accumulator) 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 $\quad 8$-bit data quantity
data $16 \quad 16$-bit data quantity
byte 2 The second byte of the instruction
byte 3 The third byte of the instruction
port $\quad 8$-bit address of an I/O device
$r, r 1, r 2 \quad$ 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, $S S S=$ source):

| DDD or SSS | REGISTER NAME |
| :---: | :---: |
| 111 | A |
| 000 | B |
| 001 | C |
| 010 | D |
| 011 | E |
| 100 | H |
| 101 | L |

One of the register pairs:
$B$ represents the $B, C$ pair with $B$ as the highorder register and $C$ as the low-order register;
D represents the $D, E$ pair with $D$ as the highorder register and $E$ as the low-order register;
$H$ represents the $H, L$ pair with $H$ as the highorder register and $L$ as the low-order register; SP represents the 16 -bit stack pointer register.

RP 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 |


| rh | The first (high-order) register of a designated register pair. |
| :---: | :---: |
| $r$ | The second (low-order) register of a designated register pair. |
| PC | 16-bit program counter register ( PCH and PCL are used to refer to the high-order and low-order 8 bits respectively). |
| SP | 16 -bit stack pointer register (SPH and SPL are used to refer to the high-order and loworder 8 bits respectively). |
| $r^{m}$ | Bit $m$ of the register $r$ (bits are number 7 through 0 from left to right). |
| Z,S,P,CY,AC | The condition flags: <br> Zero, <br> Sign, <br> Parity, <br> Carry, and Auxiliary Carry, respectively. |
| ( ) | The contents of the memory location or registers enclosed in the parentheses. |
| $\longleftarrow$ | "Is transferred to" |
| $\wedge$ | Logical AND |
| * | Exclusive OR |
| V | Inclusive OR |
| $+$ | Addition |
| - | Two's complement subtraction |
| * | Multiplication |
| $\leftrightarrow$ | "Is exchanged with" |
|  | The one's complement (e.g., ( $\overline{\mathrm{A}})$ ) |
| n | The restart number 0 through 7 |
| NNN | 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:

1. The MAC 80 assembler format, consisting of the instruction mnemonic and operand fields, is printed in BOLDFACE on the left side of the first line.
2. 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.
5. The following line(s) contain the binary fields and 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 in a Conditional Jump, both times will be listed, separated by a slash. Next, any significant data addressing modes (see Page 4-2) are listed. The last line lists any of the five Flags that are affected by the execution of the instruction.

## 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 (Move Register)
$(r 1) \longleftarrow(r 2)$
The content of register r 2 is moved to register r 1 .

| 0 | 1 | D | D | D | S | S | S |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Cycles: 1 <br> States: 5 <br> Addressing: register <br> Flags: none  |  |  |  |  |  |  |  |

MOV r, M
(Move from memory)
$(r) \longleftarrow((H)(L))$
The content of the memory location, whose address is in registers $H$ and $L$, is moved to register $r$.

| 0 | 1 | $D$ | $D$ | $D$ | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 2
States: 7
Addressing: reg. indirect
Flags: none

MOV M, $r$ (Move to memory)
$((H)(L)) \longleftarrow(r)$
The content of register $r$ is moved to the memory location whose address is in registers H and L .

| 0 | 1 | 1 | 1 | 0 | $S$ | $S$ | $S$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 2
States: 7
Addressing: reg. indirect
Flags: none

## MVI r, data (Move Immediate)

(r) $\longleftarrow$ (byte 2)

The content of byte 2 of the instruction is moved to register $r$.

| 0 | 0 | $D$ | $D$ | $D$ | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |

Cycles: 2
States: 7
Addressing: immediate
Flags: none

## MVI M, data (Move to memory immediate)

$((\mathrm{H})(\mathrm{L})) \longleftarrow$ (byte 2)
The content of byte 2 of the instruction is moved to the memory location whose address is in registers H and L .

| 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| data |  |  |  |  |  |  |  |  |

Cycles: 3
States: 10
Addressing: immed./reg.indirect
Flags: none

LXI rp, data 16 (Load register pair immediate)
$($ rh $) \longleftarrow$ (byte 3),
(rl) $\leftarrow$ (byte 2)
Byte 3 of the instruction is moved into the high-order register (rh) of the register pair rp. Byte 2 of the instruction is moved into the low-order register ( r ) of the register pair rp.

| 0 | 0 | $R$ | $P$ | 0 | 0 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| low-order data |  |  |  |  |  |  |  |
| high-order data |  |  |  |  |  |  |  |

Cycles: 3
States: 10
Addressing: immediate
Flags: none
(Load Accumulator direct)
$(A) \longleftarrow($ (byte 3$)$ (byte 2))
The content of the memory location, whose address is specified in byte 2 and byte 3 of the instruction, is moved to register $A$.

| 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| low-order addr |  |  |  |  |  |  |  |
| high-order addr |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |

Cycles: 4
States: 13
Addressing: direct
Flags: none

## STA add

(Store Accumulator direct)
((byte 3)(byte 2)) $\longleftarrow(\mathrm{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: direct
Flags: none

## LHLD addr (Load H and L direct)

(L) $\longleftarrow(($ byte 3$)$ (byte 2))
$(\mathrm{H}) \longleftarrow(($ byte 3$)($ byte 2$)+1)$
The content of the memory location, whose address is specified in byte 2 and byte 3 of the instruction, is moved to register L. The content of the memory location at the succeeding address is moved to register H .

| 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| low-order addr |  |  |  |  |  |  |  |
| high-order addr |  |  |  |  |  |  |  |

Cycles: 5
States: 16
Addressing: direct
Flags: none

SHLD addr (Store H and L direct)
((byte 3)(byte 2)) $\longleftarrow$ (L)
$(($ byte 3$)($ byte 2$)+1) \longleftarrow(\mathrm{H})$
The content of register $L$ is moved to the memory location whose address is specified in byte 2 and byte 3. The content of register H is moved to the succeeding memory location.

| 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| low-order addr |  |  |  |  |  |  |  |
| high-order addr |  |  |  |  |  |  |  |
| Cycles: 5 |  |  |  |  |  |  |  |
| States: 16 |  |  |  |  |  |  |  |
| Addressing: direct |  |  |  |  |  |  |  |
| Flags: none |  |  |  |  |  |  |  |

LDAX rp (Load accumulator indirect)
$(A) \longleftarrow((r p))$
The content of the memory location, whose address is in the register pair rp, is moved to register A. Note: only register pairs $r p=B$ (registers $B$ and $C$ ) or $r p=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

## STAX rp

(Store accumulator indirect)
( $(\mathrm{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 $\mathrm{rp}=\mathrm{B}$ (registers B and C ) or $\mathrm{rp}=\mathrm{D}$ (registers D and E) may be specified.


XCHG (Exchange $H$ and $L$ with $D$ and $E$ )
$(\mathrm{H}) \longleftrightarrow$ (D)
$(\mathrm{L}) \longleftrightarrow$ (E)
The contents of registers $H$ and $L$ are exchanged with the contents of registers D and E .

| 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Cycles: 1 <br> States: 4 <br>  Addressing: <br> Flags: register <br> none  |  |  |  |  |  |  |  |

## 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 the 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 (Add Register)
$(A) \longleftarrow(A)+(r)$
The content of register $r$ is added to the content of the accumulator. The result is placed in the accumulator.

| 1 | 0 | 0 | 0 | 0 | $s$ | $s$ | $s$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 4
Addressing: register
Flags: $\quad Z, S, P, C Y, A C$

ADD M (Add memory)
$(\mathrm{A}) \longleftarrow(\mathrm{A})+((\mathrm{H})(\mathrm{L}))$
The content of the memory location whose address is contained in the H and L registers is added to the content of the accumulator. The result is placed in the accumulator.

| 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 2
States: 7
Addressing: reg. indirect
Flags: $\quad Z, S, P, C Y, A C$

## ADI data <br> (Add immediate)

$(A) \longleftarrow$
(A) + (byte 2)

The content of the second byte of the instruction is added to the content of the accumulator. The result is placed in the accumulator.

| 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |

Cycles: 2
States: 7
Addressing: immediate
Flags: Z,S,P,CY,AC

ADC r (Add Register with carry)
$(A) \longleftarrow(A)+(r)+(C Y)$
The content of register $r$ and the content of the carry bit are added to the content of the accumulator. The result is placed in the accumulator.

| 1 | 0 | 0 | 0 | 1 |  | S |  | S | S |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Cycles: |  |  | 1 |  |  |  |  |
|  |  | States: 4 |  |  | 4 |  |  |  |  |
|  |  | Addressing: re |  |  | register |  |  |  |  |
|  |  | Flags: Z |  |  | Z,S,P,CY,AC |  |  |  |  |

ADC M (Add memory with carry)
$(A) \longleftarrow$
$(\mathrm{A})+((\mathrm{H})(\mathrm{L}))+(\mathrm{CY})$

The content of the memory location whose address is contained in the H and L registers and the content of the CY flag are added to the accumulator. The result is placed in the accumulator.

| 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 2
States: 7
Addressing: reg. indirect
Flags: $\quad Z, S, P, C Y, A C$

## ACI data <br> (Add immediate with carry)

$(A) \longleftarrow(A)+($ byte 2$)+(C Y)$
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 | 0 | 0 | 1 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |

Cycles: 2
States: 7
Addressing: immediate
Flags: $\quad Z, S, P, C Y, A C$

SUB r (Subtract Register)
$(A) \longleftarrow(A)-(r)$
The content of register $r$ is subtracted from the content of the accumulator. The result is placed in the accumulator.


SUB M (Subtract memory)
$(A) \longleftarrow(A)-((H)(L))$
The content of the memory location whose address is contained in the $H$ and $L$ registers is subtracted from the content of the accumulator. The result is placed in the accumulator.


SUI data (Subtract immediate)
$(A) \longleftarrow(A)-$ (byte 2$)$
The content of the second byte of the instruction is subtracted from the content of the accumulator. The result is placed in the accumulator.

| 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |
|  | Cycles: $\quad 2$ |  |  |  |  |  |  |
| States: $\quad 7$ |  |  |  |  |  |  |  |
| Addressing: immediate |  |  |  |  |  |  |  |
| Flags: $\quad$ Z,S,P,CY,AC |  |  |  |  |  |  |  |

SBB r
(Subtract Register with borrow)
$(A) \longleftarrow(A)-(r)-(C Y)$
The content of register $r$ and the content of the $C Y$ flag are both subtracted from the accumulator. The result is placed in the accumulator.

| 1 | 0 | 0 | 1 | 1 | $S$ | $S$ | $S$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 4
Addressing: register
Flags: Z,S,P,CY,AC

SBB M (Subtract memory with borrow)
$(A) \longleftarrow(A)-((H)(L))-(C Y)$
The content of the memory location whose address is contained in the H and L registers and the content of the CY flag are both subtracted from the accumulator. The result is placed in the accumulator.


SBI data (Subtract immediate with borrow)
$(A) \longleftarrow(A)-($ byte 2$)-(C Y)$
The contents of the second byte of the instruction and the contents of the CY flag are both subtracted from the accumulator. The result is placed in the accumulator.

| 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |
| Cycles: | 2 |  |  |  |  |  |  |
| States: | 7 |  |  |  |  |  |  |
| Addressing: | immediate |  |  |  |  |  |  |
| Flags: $\quad$ Z,S,P,CY,AC |  |  |  |  |  |  |  |

INR $\mathbf{r} \quad$ (Increment Register)
$(r) \longleftarrow(r)+1$
The content of register $r$ is incremented by one. Note: All condition flags except CY are affected.

| 0 | 0 | D | D | D | 1 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |  |  |
| Cycles: | 1 |  |  |  |  |  |  |
| States: | 5 |  |  |  |  |  |  |
| Addressing: | register |  |  |  |  |  |  |
| Flags: | Z,S,P,AC |  |  |  |  |  |  |

INR M (Increment memory)
$((H)(L)) \longleftarrow((H)(L))+1$
The content of the memory location whose address is contained in the H and L registers is incremented by one. Note: All condition flags except CY are affected.

| 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 3
States: 10
Addressing: reg. indirect
Flags: Z,S,P,AC

DCR r (Decrement Register)
$(r) \longleftarrow(r)-1$
The content of register $r$ is decremented by one. Note: All condition flags except CY are affected.

| 0 | 0 | D | D | D | 1 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |  |  |
| Cycles: | 1 |  |  |  |  |  |  |
| States: | 5 |  |  |  |  |  |  |
|  | Addressing: | register |  |  |  |  |  |
|  | Flags: | Z,S,P,AC |  |  |  |  |  |

## DCR M (Decrement memory)

$((H)(L)) \longleftarrow((H)(L))-1$
The content of the memory location whose address is contained in the $H$ and $L$ registers is decremented by one. Note: All condition flags except CY are affected.

| 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Cycles: 3  <br>  States: 10 <br>  Addressing: reg. indirect <br>  Flags: Z,S,P,AC |  |  |  |  |  |  |  |

INX rp (Increment register pair)
$(r h)(r l) \longleftarrow(r h)(r l)+1$
The content of the register pair rp is incremented by one. Note: No condition flags are affected.

| 0 | 0 | $R$ | $P$ | 0 | 0 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 5
Addressing: register
Flags: none

DCX rp (Decrement register pair)
$(r h)(r l) \longleftarrow(r h)(r l)-1$
The content of the register pair $r p$ is decremented by one. Note: No condition flags are affected.


## DAD rp (Add register pair to $H$ and $L$ )

$(H)(L) \longleftarrow(H)(L)+(r h)(r l)$
The content of the register pair rp is added to the content of the register pair $H$ and $L$. The result is placed in the register pair H and L. Note: Only the CY flag is affected. It is set if there is a carry out of the double precision add; otherwise it is reset.

| 0 | 0 | R | P | 1 | 0 | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Cycles: |  | 3 |  |  |  |
|  |  | States: 1 |  | 10 |  |  |  |
|  |  | Addressing: re |  | register |  |  |  |
|  |  |  |  | CY |  |  |  |

DAA (Decimal Adjust Accumulator)
The eight-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.

$$
\begin{aligned}
& \begin{array}{|l|l|l|l|l|l|l|l|}
\hline 0 & 0 & 1 & 0 & 0 & 1 & 1 & 1 \\
\hline
\end{array} \\
& \text { Cycles: } 1 \\
& \text { States: } 4 \\
& \text { Flags: } \quad Z, S, P, C Y, A C
\end{aligned}
$$

## Logical Group:

This group of instructions performs logical (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 Register)
$(A) \longleftarrow(A) \wedge(r)$
The content of register $\cdot \mathrm{r}$ is logically anded with the content of the accumulator. The result is placed in the accumulator. The CY flag is cleared.

| 1 | 0 | 1 | 0 | 0 | S | S | S |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1 States: 4
Addressing: register
Flags: Z,S,P,CY,AC

ANA M
(AND memory)
$(A) \longleftarrow(A) \wedge((H)(L))$
The contents of the memory location whose address is contained in the $H$ and $L$ registers is logically anded with the content of the accumulator. The result is placed in the accumulator. The CY flag is cleared.

$(A) \longleftarrow(A) \wedge($ byte 2$)$
The content of the second byte of the instruction is logically anded with the contents of the accumulator.
The result is placed in the accumulator. The CY and AC flags are cleared.

| 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |


| Cycles: | 2 |
| ---: | :--- |
| States: | 7 |
| Addressing: | immediate |
| Flags: | $Z, S, P, C Y, A C$ |

XRA r (Exclusive OR Register)
$(A) \longleftarrow(A) \forall(r)$
The content of register $r$ is exclusive-or'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared.


XRA M
(Exclusive OR Memory)
$(A) \longleftarrow(A) \forall((H)(L))$
The content of the memory location whose address is contained in the $H$ and $L$ registers is exclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared.

| 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 2
States: 7
Addressing: reg. indirect
Flags: $\quad Z, S, P, C Y, A C$

## XRI data

(Exclusive OR immediate)
$(A) \longleftarrow(A) \forall$ (byte 2)
The content of the second byte of the instruction is exclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared.
$\left.\begin{array}{|l|l|l|l|l|l|l|l|}\hline 1 & 1 & 1 & 1 & 0 & 1 & 1 & 1\end{array}\right) 0$.

Cycles: 2
States: 7
Addressing: immediate
Flags: Z,S,P,CY,AC

ORA r (OR Register)
$(A) \longleftarrow(A) \vee(r)$
The content of register $r$ is inclusive-OR' $d$ with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared.

| 1 | 0 | 1 | 1 | 0 | S | S | S |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles:
1
States: 4
Addressing: register Flags: Z,S,P,CY,AC

ORAM (OR memory)
$(A) \longleftarrow(A) \vee((H)(L))$
The content of the memory location whose address is contained in the $H$ and $L$ registers is inclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared.


ORI data (OR Immediate)
(A) $\longleftarrow$ (A) $\vee$ (byte 2)

The content of the second byte of the instruction is inclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared.

| 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |

$$
\begin{aligned}
\text { Cycles: } & 2 \\
\text { States: } & 7 \\
\text { Addressing: } & \text { immediat } \epsilon \\
\text { Flags: } & \mathrm{Z}, \mathrm{~S}, \mathrm{P}, \mathrm{CY}, \mathrm{AC}
\end{aligned}
$$

## CMP r (Compare Register)

(A) - (r)

The content of register $r$ is subtracted from the accumulator. The accumulator remains unchanged. The condition flags are set as a result of the subtraction. The $Z$ flag is set to 1 if $(A)=(r)$. The CY flag is set to 1 if $(A)<(r)$.

| 1 | 0 | 1 | 1 | 1 | $S$ | $S$ | $S$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 4
Addressing: register
Flags: Z,S,P,CY,AC
(A) $-((\mathrm{H})(\mathrm{L}))$

The content of the memory location whose address is contained in the H and L registers is subtracted from the accumulator. The accumulator remains unchanged. The condition flags are set as a result of the subtraction. The $Z$ flag is set to 1 if $(A)=((H)(L))$. The CY flag is set to 1 if $(A)<((H)(L))$.


CPI data (Compare immediate)
(A) - (byte 2)

The content of the second byte of the instruction is subtracted from the accumulator. The condition flags are set by the result of the subtraction. The $Z$ flag is set to 1 if $(A)=($ byte 2$)$. The CY flag is set to 1 if (A) $<$ (byte 2 ).

| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| data |  |  |  |  |  |  |  |  |

Cycles: 2
States: 7
Addressing: immediate
Flags: $\quad Z, S, P, C Y, A C$

RLC (Rotate left)
$\left(A_{n+1}\right) \longleftarrow\left(A_{n}\right) ;\left(A_{0}\right) \longleftarrow\left(A_{7}\right)$
$(C Y) \longleftarrow\left(A_{7}\right)$
The content of the accumulator is rotated left one position. The low order bit and the CY flag are both set to the value shifted out of the high order bit position. Only the CY flag is affected.

| 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 4
Flags: CY

RRC (Rotate right)

$$
\left(A_{n}\right) \longleftarrow\left(A_{n+1}\right) ; \quad\left(A_{7}\right) \longleftarrow\left(A_{0}\right)
$$

$$
(C Y) \leftarrow\left(A_{0}\right)
$$

The content of the accumulator is rotated right one position. The high order bit and the CY flag are both set to the value shifted out of the low order bit position. Only the CY flag is affected.

| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 4
Flags: CY

RAL
(Rotate left through carry)
$\left(A_{n+1}\right) \longleftarrow\left(A_{n}\right) ;(C Y) \longleftarrow\left(A_{7}\right)$
$\left(A_{0}\right) \longleftarrow(C Y)$
The content of the accumulator is rotated left one position through the CY flag. The low order bit is set equal to the CY flag and the CY flag is set to the value shifted out of the high order bit. Only the CY flag is affected.

| 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| Cycles: 1 <br> States: 4 <br>  Flags: <br>  CY |  |  |  |  |  |  |  |

RAR (Rotate right through carry)
$\left(A_{n}\right) \longleftarrow\left(A_{n+1}\right) ;(C Y) \longleftarrow\left(A_{0}\right)$
$\left(A_{7}\right) \longleftarrow(C Y)$
The content of the accumulator is rotated right one position through the CY flag. The high order bit is set to the CY flag and the CY flag is set to the value shifted out of the low order bit. Only the CY flag is affected.

| 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Cycles: 1  <br>  States: 4 <br>  Flags: CY |  |  |  |  |  |  |  |

## CMA (Complement accumulator)

$(A) \longleftarrow \overline{(A)}$
The contents of the accumulator are complemented (zero bits become 1, one bits become 0 ). No flags are affected.


CMC (Complement carry)
$(C Y) \longleftarrow(\overline{C Y})$
The CY flag is complemented. No other flags are affected.


STC (Set carry)
$(\mathrm{CY}) \longleftarrow 1$
The CY flag is set to 1 . No other flags are affected.


## Branch Group:

This group of instructions alter 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 processor flags to determine if the specified branch is to be executed. The conditions that may be specified are as follows:

| CONDITION | CCC |
| ---: | :--- |
| $N Z-\operatorname{not}$ zero $(Z=0)$ | 000 |
| $Z-\operatorname{zero}(Z=1)$ | 001 |
| $N C-$ no carry $(C Y=0)$ | 010 |
| $C-\operatorname{carry}(C Y=1)$ | 011 |
| $P O-$ parity odd $(P=0)$ | 100 |
| $P E-\operatorname{parity}$ even $(P=1)$ | 101 |
| $P-\operatorname{plus}(S=0)$ | 110 |
| $M-\operatorname{minus}(S=1)$ | 111 |

JMP addr (Jump)
$(\mathrm{PC}) \longleftarrow$ (byte 3) (byte 2)
Control is transferred to the instruction whose ad-
dress is specified in byte 3 and byte 2 of the current instruction.

| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| low-order addr |  |  |  |  |  |  |  |
| high-order addr |  |  |  |  |  |  |  |
| Cycles: 3 |  |  |  |  |  |  |  |
| States: 10 |  |  |  |  |  |  |  |
| Addressing: immediate |  |  |  |  |  |  |  |
| Flags: none |  |  |  |  |  |  |  |

Jcondition addr (Conditional jump) If (CCC), $(\mathrm{PC}) \longleftarrow$ (byte 3) (byte 2) If the specified condition is true, control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction; otherwise, control continues sequentially.

| 1 | 1 | C | C | C | 0 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |  |  |
| low-order addr |  |  |  |  |  |  |  |
|  | high-order addr |  |  |  |  |  |  |
| Cycles: 3 |  |  |  |  |  |  |  |
| States: 10 |  |  |  |  |  |  |  |
| Addressing: immediate |  |  |  |  |  |  |  |
| Flags: none |  |  |  |  |  |  |  |

CALL addr
(Call)
$((S P)-1) \longleftarrow(\mathrm{PCH})$
$((S P)-2) \longleftarrow(P C L)$
$(\mathrm{SP}) \longleftarrow(\mathrm{SP})-2$
$(\mathrm{PC}) \longleftarrow$ (byte 3) (byte 2)
The high-order eight bits of the next instruction address are moved to the memory location whose address is one less than the content of register SP. The low-order eight bits of the next instruction address are moved to the memory location whose address is two less than the content of register SP. The content of register SP is decremented by 2 . Control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction.


Ccondition addr
(Condition call)
If (CCC),
$((S P)-1) \longleftarrow(P C H)$
$((S P)-2) \longleftarrow(P C L)$
$(S P) \longleftarrow(S P)-2$
(PC) $\longleftarrow$ (byte 3) (byte 2)
If the specified condition is true, the actions specified in the CALL instruction (see above) are performed; otherwise, control continues sequentially.

| 1 | 1 | $C$ | $C$ | $C$ | 1 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| low-order addr |  |  |  |  |  |  |  |
| high-order addr |  |  |  |  |  |  |  |

Cycles: $3 / 5$
States: 11/17
Addressing: immediate/reg. indirect
Flags: none

## RET <br> (Return)

$(P C L) \longleftarrow((S P))$;
$(\mathrm{PCH}) \longleftarrow((\mathrm{SP})+1)$;
$(S P) \longleftarrow(S P)+2$;
The content of the memory location whose address is specified in register SP is moved to the low-order eight bits of register PC. The content of the memory location whose address is one more than the content of register SP is moved to the high-order eight bits of register PC. The content of register SP is incremented by 2.


Rcondition (Conditional return)
If (CCC),
$(P C L) \longleftarrow((S P))$
$(\mathrm{PCH}) \longleftarrow((\mathrm{SP})+1)$
$(S P) \longleftarrow(S P)+2$
If the specified condition is true, the actions specified in the RET instruction (see above) are performed; otherwise, control continues sequentially.


RST n (Restart)
$((\mathrm{SP})-1) \longleftarrow(\mathrm{PCH})$
$((\mathrm{SP})-2) \longleftarrow(\mathrm{PCL})$
$(\mathrm{SP}) \longleftarrow(\mathrm{SP})-2$
$(P C) \longleftarrow 8^{*}(N N N)$
The high-order eight bits of the next instruction address are moved to the memory location whose address is one less than the content of register SP. The low-order eight bits of the next instruction address are 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. Control is transferred to the instruction whose address is eight times the content of NNN.


Program Counter After Restart

PCHL (Jump H and L indirect - move H and L to PC . $(\mathrm{PCH}) \longleftarrow(\mathrm{H})$ $(\mathrm{PCL}) \longleftarrow(\mathrm{L})$
The content of register H is moved to the high-order eight bits of register PC. The content of register $L$ is moved to the low-order eight bits of register PC.

| 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 5
Addressing: register
Flags: none

## 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 (Push)

$((S P)-1) \longleftarrow(r h)$
$((S P)-2) \longleftarrow(r)$
$(S P) \longleftarrow(S P)-2$
The content of the high-order register of register pair rp is moved to the memory location whose address is one less than the content of register SP. The content of the low-order register of register pair rp 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 2. Note: Register pair rp = SP may not be specified.

| 1 | 1 | $R$ | $P$ | 0 | 1 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |  |  |
| Cycles: | 3 |  |  |  |  |  |  |
| States: | 11 |  |  |  |  |  |  |
| Addressing: | reg. indirect |  |  |  |  |  |  |
| Flags: none |  |  |  |  |  |  |  |

PUSH PSW (Push processor status word)
$((\mathrm{SP})-1) \longleftarrow(\mathrm{A})$
$((S P)-2)_{0} \longleftarrow(C Y),((S P)-2)_{1} \longleftarrow 1$
$((S P)-2)_{2} \longleftarrow(P), \quad((S P)-2)_{3} \longleftarrow 0$
$((\mathrm{SP})-2)_{4} \longleftarrow(\mathrm{AC}),((\mathrm{SP})-2)_{5} \longleftarrow 0$
$((S P)-2)_{6} \longleftarrow(Z), \quad((S P)-2)_{7} \longleftarrow(S)$
$(S P) \longleftarrow(S P)-2$
The content of register $A$ is moved to the memory location whose address is one less than register SP. The contents 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


```
POPrp (Pop)
    (rl) ఒ((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 highorder register of register pair rp. The content of register SP is incremented by 2. Note: Register pair $r p=S P$ may not be specified.

| 1 | 1 | $R$ | $P$ | 0 | 0 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  |  |  |  |  |
| Cycles: | 3 |  |  |  |  |  |  |
|  | States: | 10 |  |  |  |  |  |
|  | Addressing: | reg. indirect |  |  |  |  |  |
|  | Flags: | none |  |  |  |  |  |

POP PSW (Pop processor status word)
$(\mathrm{CY}) \longleftarrow((\mathrm{SP}))_{0}$
$(P) \longleftarrow((S P))_{2}$
$(\mathrm{AC}) \longleftarrow((\mathrm{SP}))_{4}$
$(Z) \longleftarrow((S P))_{6}$
$(\mathrm{S}) \longleftarrow((\mathrm{SP}))_{7}$
$(A) \longleftarrow((S P)+1)$
$(S P) \longleftarrow(S P)+2$
The content of the memory location whose address is specified by the content of register SP is used to restore the condition flags. The content of the memory location whose address is one more than the content of register SP is moved to register A. The content of register SP is incremented by 2.

| 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Cycles: 3  <br>  States: 10 <br>  Addressing: reg. indirect <br>  Flags: Z,S,P,CY,AC |  |  |  |  |  |  |  |

XTHL (Exchange stack top with H and L )
$(\mathrm{L}) \leftrightarrow((S P))$
$(\mathrm{H}) \leftrightarrow((\mathrm{SP})+1)$
The content of the $L$ register is exchanged with the content of the memory location whose address is specified by the content of register SP. The content of the H register is exchanged with the content of the memory location whose address is one more than the content of register SP.

| 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 5
States: 18
Addressing: reg. indirect
Flags: none

## SPHL (Move HL to SP)

$(S P) \longleftarrow(H)(L)$
The contents of registers $H$ and $L(16$ bits) are moved to register SP.

| 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 5
Addressing: register
Flags: none

IN port (Input)
$(\mathrm{A}) \longleftarrow$ (data)
The data placed on the eight bit bi-directional data bus by the specified port is moved to register $A$.

| port |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

Cycles: 3
States: 10
Addressing: direct
Flags: none

## OUT port <br> (Output)

(data) $\leftarrow$ (A)
The content of register $A$ is placed on the eight bit bi-directional data bus for transmission to the specified port.

| 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| port |  |  |  |  |  |  |  |

Cycles: 3
States: 10
Addressing: direct
Flags: none

EI (Enable interrupts)
The interrupt system is enabled following the execution of the next instruction.

| 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  Cycles: 1 <br>  States: 4 <br>  Flags: none  |  |  |  |  |  |  |  |

DI (Disable interrupts)
The interrupt system is disabled immediately following the execution of the DI instruction.

| 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 4
Flags: none

HLT (Halt)
The processor is stopped. The registers and flags are unaffected.

| 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Cycles: 1
States: 7
Flags: none

NOP
(No op)
No operation is performed. The registers and flags are unaffected.

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Cycles: 1 <br> States: 4 <br>  Flags: none |  |  |  |  |  |  |  |

## 8080 INSTRUCTION SET

Summary of Processor Instructions


NOTES: 1. DDD or SSS: B 000, C 001. D 010. E 011. H 100. L 101. Memory 110. A 111.
2. Two possible cycle times. $(6 / 12)$ indicate instruction cycles dependent on condition flags.

## 8080 INSTRUCTION SET

## Summary of Processor Instructions (Cont.)

| Mnemonic | Description | $\mathrm{O}_{7}$ | Instruction Code[1] |  |  |  |  |  |  | Clock[2] |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | Cycles |
| SUBTRACT |  |  |  |  |  |  |  |  |  |  |
| SUB r | Subtract register from A | 1 | 0 | 0 | 1 | 0 | S | S | S | 4 |
| SBB r | Subtract register from A with borrow | 1 | 0 | 0 | 1 | 1 | S | S | S | 4 |
| SUB M | Subtract memory from A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBB M | Subtract memory from A with borrow | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| SUI | Subtract immediate from A | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBI | Subtract immediate from A with borrow | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| LOGICAL |  |  |  |  |  |  |  |  |  |  |
| ANA r | And register with A | 1 | 0 | 1 | 0 | 0 | S | S | S | 4 |
| XRA r | Exclusive Or register with A | 1 | 0 | 1 | 0 | 1 | S | S | S | 4 |
| ORA r | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S | S | 4 |
| CMP r | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | S | S | 4 |
| ANA M | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRA M | Exclusive Or memory with A | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORA M | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CMP M | Compare memory with A | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| ANI | And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 |
| XRI | Exclusive Or immediate with A | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| ORI | Or immediate with A | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| CPI | Compare immediate with A | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 7 |
| ROTATE |  |  |  |  |  |  |  |  |  |  |
| RLC | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 4 |
| RRC | Rotate A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 |
| RAL | Rotate A left through carry | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 |
| RAR | Rotate A right through carry | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 |
| SPECIALS |  |  |  |  |  |  |  |  |  |  |
| CMA | Complement A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 4 |
| STC | Set carry | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| CMC | Complement carry | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| DAA | Decimal adjust A | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| INPUT/OUTPUT |  |  |  |  |  |  |  |  |  |  |
| IN | Input | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
| OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| CONTROL |  |  |  |  |  |  |  |  |  |  |
| EI | Enable Interrupts | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| DI | Disable Interrupt | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 |
| NOP | No-operation | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
| HLT | Halt | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |

Chapter 5
INTRODUCTION TO MCS-85"'


## INTRODUCTION TO MCS-85 ${ }^{\text {" }}$

## EVOLUTION

In December 1971, Intel introduced the first general purpose, 8-bit microprocessor, the 8008. It was implemented in P-channel MOS technology and was packaged in a single 18 pin , dual in-line package (DIP). The 8008 used standard semiconductor ROM and RAM and, for the most part, TTL components for I/O and general interface. It immediately found applications in byte-oriented end products such as terminals and computer peripherals where its instruction execution ( 20 micro-seconds), general purpose organization and instruction set matched the requirements of these products. Recognizing that hardware was but a small part in the overall system picture, Intel developed both hardware and software tools for the design engineer so that the transition from prototype to production would be as simple and fast as possible. The commitment of providing a total systems approach with the 8008 microcomputer system was actually the basis for the sophisticated, comprehensive development tools that Intel has available today.

## THE 8080A MICROPROCESSOR

With the advent of high-production N -channel RAM memories and 40 pin DIP packaging, Intel designed the 8080A microprocessor. It was designed to be software compatible with the 8008 so that the existing users of the 8008 could preserve their investment in software and at the same time provide dramatically increased performance ( 2 microsecond instruction execution), while reducing the amount of components necessary to implement a system. Additions were made to the basic instruction set to take advantage of this increased performance and large system-type features were included on-chip such as DMA, 16-bit addressing and external stack memory so that the total spectrum of application could be significantly increased. The 8080 was first sampled in December 1973. Since that time it has become the standard of the industry and is accepted as the primary building block for more microcomputer based applications than all other microcomputer systems combined.

## A TOTAL SYSTEMS COMMITMENT

The Intel ${ }^{\text {® }}$ 8080A Microcomputer System encompasses a total systems commitment to the user to fully support his needs both in developing prototype
systems and reliable, high volume production. From complex MOS/LSI peripheral components to resident high level systems language (PL/M) the Intel ${ }^{\circledR}$ 8080 Microcomputer System provides the most comprehensive, effective solution to today's system problems.



YEAR


## THE MCS-85 ${ }^{\text {™ }}$ MICROCOMPUTER SYSTEM

The basic philosophy behind the MCS-85 microcomputer system is one of logical, evolutionary advance in technology without the waste of discarding existing investments in hardware and sotware. The MCS-85 provides the existing 8080 user with an increase in performance, a decrease in the component count, a single 5 volt operation and still preserves $100 \%$ of his existing software investment. For the new microcomputer user, the MCS-85 represents the refinement of the most popular microcomputer in the industry, the Intel 8080, along with a wealth of supporting software, documentation and peripheral components to speed the cycle from prototype to production. The identical development tools that Intel has produced to support the 8080 microcomputer system can be used for the MCS-85, and additional add-on features are available to optimize system development for MCS-85.

This section of the MCS-85 User's Manual will briefly detail the basic differences between the MCS-85 and MCS-80'" families. It will illustrate both the hardware and software compatibilities and also reveal some of the engineering trade-offs that were met during the design of MCS-85. More detailed discussion of the MCS-85 bus operation and component specifications are available in Sections: 2,3,4, but the information provided in this section, Section 1, will be extremely helpful in understanding the basic concepts and philosophies behind the MCS-85.

It is important for the reader of the MCS-85 User's Manual to have a solid understanding of the 8080 microcomputer system. Most of the terms and procedures that are used in the MCS-85 User's. Manual are based on information in the MCS-80 User's Manual. Please refer to the MCS-80'User's Manual as required.


MCS-85 ${ }^{\text {TM }}$ TOTAL SYSTEM

## SYSTEM INTEGRATION

The MCS-85 integrates many of the functions that are auxiliary to an 8080A based system. Functions such as: clock generation, system control and interrupt prioritizing are integrated into on-chip features of the 8085 Central Processor. The 8085 is, of course, the central element in the MCS-85 family. It coordinates all bus transfers and operations and executes the instruction set. The 8085 CPU is designed to be the controlling master of a unique, multiplexed bus system. This bus structure will be discussed in detail later in the manual but basically, the information provided on the data bus is timemultiplexed and contains both data and the lower 8 address bits (A7-A0). The address bus contains the remaining 8-bits (A8-A15). The 8085 CPU generates signals that tell peripheral devices what type of information is on the multiplexed bus (Address/ Data) and from that point on the operation is almost identical to the MCS-80m CPU Group. The multiplexed bus structure was chosen because it had no detrimental effect on system performance, allowed complete compatibility to existing peripheral components, provided improved timing margins and access requirements and freed device pins so that more functions could be integrated on the 8085 and other components of the family.
To enhance the system integration of MCS-85, several special components with combined memory and I/O were designed. These new devices have been designed to directly interface to the multiplexed bus of the 8085. It is interesting to note that the pin locations of the 8085 and the special peripheral components were assigned to minimize PC board area and allow for a smooth, efficient layout. The details on the new peripheral components will be discussed later in the manual.


MCS-80'M ${ }^{\text {™ }}$ CPU GROUP (BASIC FUNCTIONS)


MCS-85 CPU/8085 (BASIC FUNCTIONS)

MCS-85 ${ }^{\text {™ }}$ CPU/©085 (BASIC FUNCTIONS)


## MULTIPLEXED BUS TIMING

## SOFTWARE COMPATIBILITY

As with any computer system the cost of software development far outweighs those of hardware. A microcomputer-based system is traditionally a very cost-sensitive application and the development of software is one of the key areas where success or failure of the cost objectives is vital.


The 8085 CPU is $100 \%$ software compatible with the Intel 8080 CPU. The compatibility is at the object or "machine code" level so that existing programs written for 8080A execution will run on the 8085 as is. This becomes even more evident to the user who has mask programmed ROMs and wishes to update his system without the need for new masks.

## PROGRAMMER TRAINING

A cost which is often forgotten is that of programmer training. A new, or modified instruction set, would require programmers to relearn another set of mnemomics and greatly effect the productivity during development. The $100 \%$ compatibility of the 8085 CPU assures that no re-training effort will be required.

For the new microcomputer user, the software compatibility between the 8085 and 8080A means that all of the software development tools that are available for the 8080A and all software libraries for 8080A will operate with the new design and thus save immeasurable cost in development and debug.

The 8085 CPU does however add two instructions to initialize and maintain hardware features of the 8085. Two of the unused opcodes of the 8080A instruction set were designated for the addition so that $100 \%$ compatibility could be maintained.
As mentioned previously, the MCS-85 is designed to be a logical, evolutionary advance that solves problems in the most efficient, cost effective manner available. $100 \%$ software compatibility fulfills one of the most important aspects of the overall MCS-85 system philosophy.

## HARDWARE COMPATIBILITY

The integration of auxiliary 8080A functions, such as clock generation, system control and interrupt prioritization, dramatically reduces the amount of components necessary for most systems. In addition to integrating some of the MCS-80 ${ }^{\text {TM }}$ system functions, the MCS-85 operates off a single +5 volt power supply to further simplify hardware development and debug. A close examination of the AC/DC specifications of the MCS-85 systems components shows that each is specified to supply a maximum of 400 micro Amps of source current and a full TTL load of sink current so that a very substantial system can be constructed without the need for extra TTL buffers or drivers. Input and output voltage levels are also specified so that a minimum of 400 microvolts noise margin is provided for reliable, high-performance operation.

## PC BOARD CONSIDERATIONS

The 8085 CPU and the 8080A are not pin-compatible due to the reduction in power supplies and the addition of integrated auxiliary features. However the pinouts of the MCS-85 system components were carefully assigned to minimize PC board area and thus yield a smooth, efficient layout. For new designs this incompatibility of pinouts presents no problems and for upgrades of existing designs the reduction of components and board area will far offset the incompatibility.

## MCS-85 ${ }^{\text {TM }}$ SPECIAL PERIPHERAL COMPONENTS

The MCS-85 was designed to minimize the amount of components required for most systems. Intel designed several new peripheral components that combine memory, I/O and timer functions to fulfill this requirement. These new peripheral devices directly interface to the multiplexed MCS-85 bus structure and provide new levels in system integration for today's designer.


8155/8156 RAM, I/O and Timer
256 bytes RAM
2-8-bit ports
1-6-bit port (programmable)
1-14-bit programmable interval timer
Single +5 volt supply operation 40 pin DIP plastic or cerdip package


## 8355 ROM and I/O

2K bytes ROM
2-8-bit ports (direction programmable) Single +5 volt supply operation 40 pin DIP plastic or cerdip package


## 8755 EPROM and I/O

Socket compatible with 8355 2K bytes EPROM
2-8-bit ports (direction programmable)
Single +5 volt supply read operation
U.V. Erasable

40 pin DIP package

## 8755/8355

One of the most important advances made with the MCS-85 is the socket-compatibility of the 8355 and 8755 components. This allows the systems designer to develop and debug in erasable PROM and then, when satisfied, switch over to mask-programmed ROM 8355 with no performance degradation or board relayout. It also allows quick prototype production for market impact without going to a "kluge" solution.


## SYSTEM EXPANSION

Each of these peripheral components has features that allow a small to medium system to be constructed without the addition of buffers and decoders to further reduce the component count.


[^1]
## INTERFACING TO MCS-80 ${ }^{\text {™ }}$ <br> PERIPHERAL COMPONENTS

The MCS-80 has a wide range of peripheral components that solve system problems and provide the designer with a great deal of flexibility in his I/O, Interrupt and DMA structures. The MCS-85 is directly compatible with these peripherals, and, with the exception of the 8257 DMA controller, needs no additional circuitry for their interface. The 8257 DMA controller uses an 8212 latch and some gating to support the multiplexed bus of MCS-85.

## MULTIPLEX BUS

To understand the exact interface between the MCS-85 and the MCS-80 ${ }^{\text {m }}$ peripheral components, recall that the 8080A CPU issues the address of the I/O device on its 16 -bit address bus. The I/O address appears on both the upper and lower 8 -bits of the address bus. The 8085 CPU utilizes a multiplexed bus structure where the address bus contains only the upper 8 -bits of information. The data bus contains both data and the lower 8 -bits of information of the address. Since the read/write control signals are only issued when there is data on the bus and the address bus contains the I/O device address, then all of the MCS-80 peripherals will interface directly with no hardware or software problems. In fact, due to the manner in which the 8085 control signals were implemented, memorymapped I/O becomes simpler to use than with MCS80 and combinations of memory-mapped and standard I/O techniques will provide the designer with new flexibilities to maximize system efficiency.

## MCS-80 ${ }^{\text {™ }}$ PERIPHERALS

To interface 825X peripherals to 8085 bus at 3 MHz , the user must use a set of MCS-80 peripherals, called, "825X-5". It includes 8251A, 8253-5, 8255A-5, 8257-5 and 8259-5 as shown below:
8251A Programmable Communications Interface
8253-5 Programmable Interval Timer 8255A-5 Programmable Peripheral Interface 8257-5 Programmable DMA Controller 8259-5 Programmable Interrupt Controller
This compatibility also assures the designer that all new peripheral components from Intel will interface to the MCS-85 bus structure to further expand the application spectrum of MCS-85.


## INTERFACING TO STANDARD MEMORY

The MCS-85 was designed to support the full range of system configurations from small 3 chip applications to large memory and I/O applications. The 8085 CPU issues advanced timing signals (S0 \& S1) so that, in the case of large systems, these signals could be used to simplify bus arbitration logic and dynamic RAM refresh circuitry.

The multiplexed bus structure of the MCS-85 provides direct interface to MCS-80 ${ }^{\text {TM }}$ peripheral components, but in large, memory intensive systems, standard ROM and RAM memory will be present due to the economies of such devices when used in large quantities per system. In most memory intensive systems I/O requirements do not generally track memory space. Thus standard memory is a more cost effective solution for these applications than the special 8155,8355 devices.

## DEMULTIPLEXING THE BUS

In order to interface standard memory components such as Intel@ 8102A, 8101A, 8111A, 8316A, 8308, 2104 and 2116 the MCS- 85 bus must be "demultiplexed". This is accomplished by connecting an Intel ${ }^{(8)} 8212$ latch to the data bus and strobing the latch with the ALE signal from the 8085 CPU. The ALE signal is issued to indicate that the information on the data bus is actually the lower 8 -bits of the address bus, and the 8212 simply latches this information so that a full 16 -bit address is now available to interface standard memory components.

## USE OF 8212

The additional component may at first seem wasteful but large, memory intensive systems are usually multi-card implementations and require some form of TTL buffering to provide necessary current and voltage levels. Therefore, the additional 8212 will probably be required for the buffering task and the de-multiplexing of the data bus is incidental.

## SYSTEM PERFORMANCE

The true benchmark of any microcomputer-based system is the amount of tasks that can be assigned to the software execution and still meet the overall product performance requirements. Speed of CPU instruction execution has been the common approach to system through-put problems but this puts a greater strain on the memory access requirement and bus operation than is usually practical for most applications. A much more desirable method would be to distribute the taskload to peripheral devices and free the systems software to simply initializing and maintaining these devices on a regular basis.

## DISTRIBUTED PROCESSING

The concept of distributed task processing is not new to the computer designer, but until recently little if any task distribution was available to the microcomputer user. The MCS-85 is fully supported by Intel's MCS-80 ${ }^{\text {TM }}$ peripheral components. All are programmable and each can relieve the systems software of many of the bookkeeping I/O and timing tasks common to any system.

## INSTRUCTION CYCLE/ACCESS

The basic instruction cycle of the 8085 is 1.3 microseconds. It is the same speed as the 8080A-1 and a closer look at the MCS-85 bus operation shows that the access requirement for this speed is only 450 nanoseconds. The MCS- $80^{\text {TM }}$ access requirements for this speed would be under 300 nanoseconds to illustrate the efficiency and improved timing margins of the MCS-85 bus structure.

## THROUGHPUT/COST

When a total system through-put analysis is taken, the MCS-85 with its programmable peripheral components will yield the most cost-effective, reliable and producible system available.

## FOR MORE INFORMATION

Data Sheets on the $8085,8155 / 56,8355$, and 8755 are provided later in this manual.
More detailed information on MCS-85 is available in the Intel@ MCS-85 User's Manual.



## Chapter 6

MICROCOMPUTER SYSTEM COMPONENT DATA SHEETS



## CPU Group



## CPU Group

8080A 8-Bit Microprocessor ..... 6-1
8080A-1 8-Bit Microprocessor ..... 6-8
8080A-2 8-Bit Microprocessor ..... 6-12
M8080A 8-Bit Microprocessor (MIL) ..... 6-16
8224 Clock Generator and Driver ..... 6-20
M8224 Clock Generator and Driver (MIL) ..... 6-26
8801 Clock Generator Crystal ..... 6-30
8228/8238 System Controller and Bus Driver ..... 6-32
M8228/M8238 System Controller and Bus Driver (MIL) ..... 6-38
8085 Single Chip 8-Bit N-Channel Microprocessor ..... 6-43

8080A

## SINGLE CHIP 8-BIT N-CHANNEL MICROPROCESSOR

The 8080A is functionally and electrically compatible with the Intel ${ }^{\circledR} 8080$.

- TTL Drive Capability


## - $2 \mu$ s Instruction Cycle

- Powerful Problem Solving Instruction Set


## - Six General Purpose Registers and an Accumulator

## - Sixteen Bit Program Counter for Directly Addressing up to 64K Bytes of Memory

- Sixteen Bit Stack Pointer and Stack Manipulation Instructions for Rapid Switching of the Program Environment
- Decimal,Binary and Double Precision Arithmetic
- Ability to Provide Priority Vectored Interrupts
512 Directly Addressed I/O Ports

The Intel ${ }^{\circledR}$ 8080A is a complete 8 -bit parallel central processing unit (CPU). It is fabricated on a single LSI chip using Intel's n -channel silicon gate MOS process. This offers the user a high performance solution to control and processing applications. The 8080A contains six 8 -bit general purpose working registers and an accumulator. The six general purpose registers may be addressed individually or in pairs providing both single and double precision operators. Arithmetic and logical instructions set or reset four testable flags. A fifth flag provides decimal arithmetic operation.
The 8080A has an external stack feature wherein any portion of memory may be used as a last in/first out stack to store/ retrieve the contents of the accumulator, flags, program counter and all of the six general purpose registers. The sixteen bit stack pointer controls the addressing of this external stack. This stack gives the 8080A the ability to easily handle multiple level priority interrupts by rapidly storing and restoring processor status. It also provides almost unlimited subroutine nesting. This microprocessor has been designed to simplify systems design. Separate 16 -line address and 8 -line bi-directional data busses are used to facilitate easy interface to memory and I/O. Signals to control the interface to memory and I/O are provided directly by the 8080A. Ultimate control of the address and data busses resides with the HOLD signal. It provides the ability to suspend processor operation and force the address and data busses into a high impedance state. This permits ORtying these busses with other controlling devices for (DMA) direct memory access or multi-processor operation.


## 8080A FUNCTIONAL PIN DEFINITION

The following describes the function of all of the 8080A I/O pins. Several of the descriptions refer to internal timing periods.

## $A_{15}-A_{0}$ (output three-state)

ADDRESS BUS; the address bus provides the address to memory (up to 64 K 8 -bit words) or denotes the I/O device number for up to 256 input and 256 output devices. $A_{0}$ is the least significant address bit.

## $D_{7}-D_{0}$ (input/output three-state)

DATA BUS; the data bus provides bi-directional communication between the CPU, memory, and I/O devices for instructions and data transfers. Also, during the first clock cycle of each machine cycle, the 8080 A outputs a status word on the data bus that describes the current machine cycle. $D_{0}$ is the least significant bit.
SYNC (output)
SYNCHRONIZING SIGNAL; the SYNC pin provides a signal to indicate the beginning of each machine cycle.

## DBIN (output)

DATA BUS IN; the DBIN signal indicates to external circuits that the data bus is in the input mode. This signal should be used to enable the gating of data onto the 8080A data bus from memory or I/O.

## READY (input)

READY; the READY signal indicates to the 8080A that valid memory or input data is available on the 8080A data bus. This signal is used to synchronize the CPU with slower memory or I/O devices. If after sending an address out the 8080A does not receive a READY input, the 8080A will enter a WAIT state for as long as the READY line is low. READY can also be used to single step the CPU.

## WAIT (output)

WAIT; the WAIT signal acknowledges that the CPU is in a WAIT state.

## $\overline{W R}$ (output)

WRITE; the WR signal is used for memory WRITE or I/O output control. The data on the data bus is stable while the $\overline{W R}$ signal is active low ( $\overline{W R}=0$ ).

## HOLD (input)

HOLD; the HOLD signal requests the CPU to enter the HOLD state. The HOLD state allows an external device to gain control of the 8080A address and data bus as soon as the 8080A has completed its use of these buses for the current machine cycle. It is recognized under the following conditions:

- the CPU is in the HALT state.
- the CPU is in the T2 or TW state and the READY signal is active. As a result of entering the HOLD state the CPU ADDRESS BUS $\left(A_{15}-A_{0}\right)$ and DATA BUS ( $\left.D_{7}-D_{0}\right)$ will be in their high impedance state. The CPU acknowledges its state with the HOLD ACKNOWLEDGE (HLDA) pin.


## HLDA (output)

HOLD ACKNOWLEDGE; the HLDA signal appears in response to the HOLD signal and indicates that the data and address bus


## Pin Configuration

will go to the high impedance state. The HLDA signal begins at:

- T3 for READ memory or input.
- The Clock Period following T3 for WRITE memory or OUTPUT operation.
In either case, the HLDA signal appears after the rising edge of $\phi_{1}$ and high impedance occurs after the rising edge of $\phi_{2}$.


## INTE (output)

INTERRUPT ENABLE; indicates the content of the internal interrupt enable flip/flop. This flip/flop may be set or reset by the Enable and Disable Interrupt instructions and inhibits interrupts from being accepted by the CPU when it is reset. It is automatically reset (disabling further interrupts) at time T1 of the instruction fetch cycle (M1) when an interrupt is accepted and is also reset by the RESET signal.

## INT (input)

INTERRUPT REQUEST; the CPU recognizes an interrupt request on this line 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 it will not honor the request.

## RESET (input) ${ }^{11]}$

RESET; while the RESET signal is activated, the content of the program counter is cleared. After RESET, the program will start at location 0 in memory. The INTE and HLDA flip/flops are also reset. Note that the flags, accumulator, stack pointer, and registers are not cleared.

$$
\begin{array}{ll}
\text { VSS } & \text { Ground Reference. } \\
\text { V DD } & +12 \pm 5 \% \text { Volts. } \\
\text { V CC } & +5 \pm 5 \% \text { Volts. } \\
\text { V }_{\text {BB }} & -5 \pm 5 \% \text { Volts (substrate bias). }
\end{array}
$$

$\phi_{1}, \phi_{2} 2$ externally supplied clock phases. (non TTL compatible)

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

| All Input or Output Voltages |  |
| :---: | :---: |
| With Respect to $\mathrm{V}_{\text {BB }}$ | -0.3 V to +20 V |
| $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ With Respect to $\mathrm{V}_{\mathrm{BB}}$ | -0.3 V to +20 V |
| Power Dissipation | . 1.5W |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VILC | Clock Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $V_{S S}+0.8$ | V | $\begin{aligned} \mathrm{I}_{\mathrm{OL}} & =1.9 \mathrm{~mA} \text { on all outputs, } \\ \mathrm{I}_{\mathrm{OH}} & =-150 \mu \mathrm{~A} . \end{aligned}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High Voltage | 9.0 |  | $V_{D D}+1$ | V |  |
| $V_{\text {IL }}$ | Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $\mathrm{VSS}^{+0.8}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 3.3 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 3.7 |  |  | V |  |
| $\mathrm{I}_{\text {DD (AV) }}$ | Avg. Power Supply Current ( $\mathrm{V}_{\text {DD }}$ ) |  | 40 | 70 | mA | $\begin{aligned} & \text { Operation } \\ & -\mathrm{T}_{\mathrm{CY}}=.48 \mu \mathrm{sec} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 60 | 80 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{BB}}$ ) |  | . 01 | 1 | mA |  |
| $I_{\text {IL }}$ | Input Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{CLOCK}} \leqslant \mathrm{~V}_{\mathrm{DD}} \end{aligned}$ |
| $I_{C L}$ | Clock Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ |  |
| ${ }^{\text {dL }}{ }^{[2]}$ | Data Bus Leakage in Input Mode |  |  | $\begin{aligned} & -100 \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |
| $I_{\text {FL }}$ | Address and Data Bus Leakage During HOLD |  |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {ADDR/DATA }}=V_{C C} \\ & V_{\text {ADDR/DATA }}=V_{S S}+0.45 \mathrm{~V} \end{aligned}$ |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} \quad V_{C C}=V_{D D}=V_{S S}=0 V, V_{B B}=-5 V$

| Symbol | Parameter | Typ. | Max. | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\phi}$ | Clock Capacitance | 17 | 25 | pf | $\mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 6 | 10 | pf | Unmeasured Pins |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 10 | 20 | pf |  |

## NOTES:

1. The RESET signal must be active for a minimum of 3 clock cycles.
2. When DBIN is high and $\mathrm{V}_{I N}>\mathrm{V}_{1 \mathrm{H}}$ an internal active pull up will be switched onto the Data Bus.
3. $\Delta I$ supply $/ \Delta T_{A}=-0.45 \% /{ }^{\circ} \mathrm{C}$.

TYPICAL SUPPLY CURRENT VS. TEMPERATURE, NORMALIZED. [3]


DATA BUS CHARACTERISTIC DURING DBIN


## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CY}}{ }^{[3]}$ | Clock Period | 0.48 | 2.0 | $\mu \mathrm{sec}$ | $\begin{aligned} & \square-c_{L}=100 \mathrm{pf} \\ & -\mathrm{C}_{\mathrm{L}}=50 \mathrm{pf} \end{aligned}$ |
| $\mathrm{tr}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | Clock Rise and Fall Time | 0 | 50 | nsec |  |
| $\mathrm{t}_{\phi 1}$ | $\phi_{1}$ Pulse Width | 60 |  | nsec |  |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 220 |  | nsec |  |
| $\mathrm{t}_{\mathrm{D} 1}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  | n sec |  |
| $\mathrm{t}_{\mathrm{D} 2}$ | Delay $\phi_{2}$ to $\phi_{1}$ | 70 |  | nsec |  |
| $\mathrm{t}_{\mathrm{D} 3}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 80 |  | nsec |  |
| $\mathrm{t}_{\mathrm{DA}}{ }^{\text {[2] }}$ | Address Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| $\mathrm{t}_{\text {DD }}{ }^{[2]}$ | Data Output Delay From $\phi_{2}$ |  | 220 | nsec |  |
| $t_{D C}{ }^{[2]}$ | Signal Output Delay From $\phi_{1}$, or $\phi_{2}$ (SYNC, $\overline{W R}$, WAIT, HLDA) |  | 120 | nsec |  |
| $t_{\text {DF }}[2]$ | DBIN Delay From $\phi_{2}$ | 25 | 140 | nsec |  |
| $\mathrm{t}_{\text {DI }}{ }^{[1]}$ | Delay for Input Bus to Enter Input Mode |  | ${ }^{\text {t }}$ DF | nsec |  |
| ${ }^{\text {t }{ }_{\text {S } 1}}$ | Data Setup Time During $\phi_{1}$ and DBIN | 30 |  | nsec |  |

TIMING WAVEFORMS ${ }^{[14]}$ (Note: Timing measurements are made at the following reference voltages: CLOCK " 1 " $=8.0 \mathrm{~V}$ $" 0 "=1.0 \mathrm{~V}$; INPUTS " 1 " = $3.3 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$; OUTPUTS " 1 " = $2.0 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$.)

inte

## A.C. CHARACTERISTICS (Continued)

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {t }}^{\text {DS2 }}$ | Data Setup Time to $\phi_{2}$ During DBIN | 150 |  | nsec | $C_{L}=50 p f$ |
| $t_{D H}{ }^{[1]}$ | Data Hold Time From $\phi_{2}$ During DBIN | [1] |  | nsec |  |
| $t_{\text {IE }}{ }^{\text {[2] }}$ | INTE Output Delay From $\phi_{2}$ |  | 200 | n sec |  |
| $\mathrm{t}_{\text {RS }}$ | READY Setup Time During $\phi_{2}$ | 120 |  | nsec |  |
| $\mathrm{t}_{\mathrm{HS}}$ | HOLD Setup Time to $\phi_{2}$ | 140 |  | nsec |  |
| $\mathrm{t}_{\text {IS }}$ | INT Setup Time During $\phi_{2}$ (During $\phi_{1}$ in Halt Mode) | 120 |  | nsec |  |
| $\mathrm{t}_{\mathrm{H}}$ | Hold Time From $\phi_{2}$ (READY, INT, HOLD) | 0 |  | nsec |  |
| $\mathrm{t}_{\text {FD }}$ | Delay to Float During Hold (Address and Data Bus) |  | 120 | nsec |  |
| $\mathrm{t}_{\mathrm{AW}}{ }^{[2]}$ | Address Stable Prior to $\bar{W} \mathrm{R}$ | [5] |  | nsec | $C_{L}=100 \mathrm{pf}$ : Address, Data <br> $C_{L}=50 \mathrm{pf}: \overline{W R}$, HLDA, DBIN |
| $\mathrm{t}_{\mathrm{DW}}{ }^{[2]}$ | Output Data Stable Prior to $\overline{W R}$ | [6] |  | nsec |  |
| $\mathrm{t}_{W \mathrm{D}}{ }^{[2]}$ | Output Data Stable From $\overline{W R}$ | [7] |  | nsec |  |
| ${ }_{t_{W A}}{ }^{[2]}$ | Address Stable From $\overline{W R}$ | [7] |  | nsec |  |
| $\mathrm{t}_{\mathrm{HF}}{ }^{[2]}$ | HLDA to Float Delay | [8] |  | nsec |  |
|  | $\overline{\mathrm{WR}}$ to Float Delay | [9] |  | nsec |  |
| $\mathrm{t}_{\mathrm{AH}}{ }^{\text {[2] }}$ | Address Hold Time After DBIN During HLDA | -20 |  | nsec |  |



NOTES:

1. Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured. ${ }^{{ }^{D}} \mathrm{DH}=50$ ns or $\mathrm{t}_{\mathrm{DF}}$, whichever is less.
2. Load Circuit.

3. $\mathrm{t}_{\mathrm{C} Y}=\mathrm{t}_{\mathrm{D} 3}+\mathrm{t}_{\mathrm{r} \phi 2}+\mathrm{t}_{\phi 2}+\mathrm{t}_{\mathrm{f} \phi 2}+\mathrm{t}_{\mathrm{D} 2}+\mathrm{t}_{\mathrm{r} \phi 1} \geqslant 480 \mathrm{~ns}$.

TYPICAL $\triangle$ OUTPUT DELAY VS. $\triangle$ CAPACITANCE

4. The following are relevant when interfacing the 8080A to devices having $\mathrm{V}_{\mathrm{IH}}=3.3 \mathrm{~V}$ :
a) Maximum output rise time from .8 V to $3.3 \mathrm{~V}=100 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}=\mathrm{SPEC}$.
b) Output delay when measured to $3.0 \mathrm{~V}=\mathrm{SPEC}+60 \mathrm{~ns} @ C_{L}=\mathrm{SPEC}$.
c) If $C_{L} \neq$ SPEC, add $.6 \mathrm{~ns} / \mathrm{pF}$ if $\mathrm{C}_{\mathrm{L}}>\mathrm{C}_{\text {SPEC }}$, subtract. $3 \mathrm{~ns} / \mathrm{pF}$ (from modified delay) if $\mathrm{C}_{\mathrm{L}}<\mathrm{C}_{\text {SPEC }}$.


If not HLDA, $\mathrm{t}_{\mathrm{WD}}=\mathrm{t} W \mathrm{~A}=\mathrm{t}_{\mathrm{D}}+\mathrm{t}_{\mathrm{r} \phi 2}+10 \mathrm{~ns}$. If $\mathrm{HLDA}, \mathrm{t} W \mathrm{D}=\mathrm{t} W \mathrm{~A}=\mathrm{t} W \mathrm{~F}$.
$t_{H F}=t_{D} 3+t_{\mathrm{r} \phi 2}-50 \mathrm{~ns}$.
${ }^{T} W F=t_{D 3}+t_{r} 2_{2}-10 \mathrm{~ns}$
Data in must be stable for this period during DBIN $\cdot T_{3}$. Both tDS1 and tDS2 must be satisfied.
Ready signal must be stable for this period during $T_{2}$ or $T_{W}$. (Must be externally synchronized.)
Hold signal must be stable for this period during $T_{2}$ or $T_{W}$ when entering hold mode, and during $T_{3}, T_{4}, T_{5}$ and $T_{W H}$ when in hold mode. (External synchronization is not required.)
13. Interrupt signal must be stable during this period of the last clock cycle of any instruction in order to be recognized on the following instruction. (External synchronization is not required.)
14. This timing diagram shows timing relationships only; it does not represent any specific machine cycle.

## INSTRUCTION SET

The accumulator group instructions include arithmetic and logical operators with direct, indirect, and immediate addressing modes.

Move, load, and store instruction groups provide the ability to move either 8 or 16 bits of data between memory, the six working registers and the accumulator using direct, indirect, and immediate addressing modes.

The ability to branch to different portions of the program is provided with jump, jump conditional, and computed jumps. Also the ability to call to and return from subroutines is provided both conditionally and unconditionally. The RESTART (or single byte call instruction) is useful for interrupt vector operation.

Double precision operators such as stack manipulation and double add instructions extend both the arithmetic and interrupt handling capability of the 8080A. The ability to
increment and decrement memory, the six general registers and the accumulator is provided as well as extended increment and decrement instructions to operate on the register pairs and stack pointer. Further capability is provided by the ability to rotate the accumulator left or right through or around the carry bit.

Input and output may be accomplished using memory addresses as I/O ports or the directly addressed I/O provided for in the 8080A instruction set.

The following special instruction group completes the 8080A instruction set: the NOP instruction, HALT to stop processor execution and the DAA instructions provide decimal arithmetic capability. STC allows the carry flag to be directly set, and the CMC instruction allows it to be complemented. CMA complements the contents of the accumulator and XCHG exchanges the contents of two 16 -bit register pairs directly.

## Data and Instruction Formats

Data in the 8080A is stored in the form of 8-bit binary integers. All data transfers to the system data bus will be in the same format.

$$
\begin{aligned}
& \begin{array}{lllllllll}
D_{7} & D_{6} & D_{5} & D_{4} & D_{3} & D_{2} & D_{1} & D_{0} \\
\hline
\end{array} \\
& \text { DATA WORD }
\end{aligned}
$$

The program instructions may be one, two, or three bytes in length. Multiple byte instructions must be stored in successive words in program memory. The instruction formats then depend on the particular operation executed.

One Byte Instructions

$$
\begin{array}{|llllllll|}
\hline D_{7} & D_{6} & D_{5} & D_{4} & D_{3} & D_{2} & D_{1} & D_{0} \\
\hline
\end{array}
$$

Two Byte Instructions

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |$\quad$| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |$D_{0}$ OP CODE

## TYPICAL INSTRUCTIONS

Register to register, memory reference, arithmetic or logical, rotate, return, push, pop, enable or disable Interrupt instructions

OPERAND
Immediate mode or I/O instructions

Three Byte Instructions

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ | OP CODE |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | | Jump, call or direct load and store |
| :---: |
| $D_{7}$ |
| $D_{6}$ |$D_{5}$

For the 8080A a logic " 1 " is defined as a high level and a logic " 0 " is defined as a low level.

## 8080A 8-BIT MICROPROCESSOR



## 8080A-1 <br> SINGLE CHIP 8-BIT N-CHANNEL MICROPROCESSOR

The 8080A is functionally and electrically compatible with the Inte ${ }^{\circledR} 8080$.

## - TTL Drive Capability

- $1.3 \mu$ s Instruction Cycle
- Powerful Problem Solving Instruction Set


## - Six General Purpose Registers and an Accumulator

## - Sixteen Bit Program Counter for Directly Addressing up to 64K Bytes of Memory

- Sixteen Bit Stack Pointer and Stack Manipulation Instructions for Rapid Switching of the Program Environment
- Decimal,Binary and Double Precision Arithmetic
- Ability to Provide Priority Vectored Interrupts
- 512 Directly Addressed I/O Ports

The Intel ${ }^{(8)}$ 8080A is a complete 8 -bit parallel central processing unit (CPU). It is fabricated on a single LSI chip using Intel's n-channel silicon gate MOS process. This offers the user a high performance solution to control and processing applications. The 8080A contains six 8 -bit general purpose working registers and an accumulator. The six general purpose registers may be addressed individually or in pairs providing both single and double precision operators. Arithmetic and logical instructions set or reset four testable flags. A fifth flag provides decimal arithmetic operation.
The 8080A has an external stack feature wherein any portion of memory may be used as a last in/first out stack to store/ retrieve the contents of the accumulator, flags, program counter and all of the six general purpose registers. The sixteen bit stack pointer controls the addressing of this external stack. This stack gives the 8080A the ability to easily handle multiple level priority interrupts by rapidly storing and restoring processor status. It also provides almost unlimited subroutine nesting. This microprocessor has been designed to simplify systems design. Separate 16 -line address and 8 -line bi-directional data busses are used to facilitate easy interface to memory and I/O. Signals to control the interface to memory and I/O are provided directly by the 8080A. Ultimate control of the address and data busses resides with the HOLD signal. It provides the ability to suspend processor operation and force the address and data busses into a high impedance state. This permits ORtying these busses with other controlling devices for (DMA) direct memory access or multi-processor operation.


## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | C to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages |  |
| With Respect to $\mathrm{V}_{\mathrm{BB}}$ | -0.3 V to +20 V |
| $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ With Respect to $\mathrm{V}_{\mathrm{BB}}$ | -0.3 V to +20V |
| Power Dissipation | 1.5W |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VILC | Clock Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V | $\mathrm{I}_{\mathrm{OL}}=1.9 \mathrm{~mA}$ on all outputs,$I_{O H}=150 \mu \mathrm{~A} .$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High Voltage | 9.0 |  | $\mathrm{V}_{\text {DD }}+1$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $V_{S S}+0.8$ | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 3.3 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $V_{\text {OL }}$ | Output Low Voltage |  |  | 0.45 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 3.7 |  |  | V |  |
| $\mathrm{I}_{\mathrm{DD}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{DD}}$ ) |  | 40 | 70 | mA | Operation$\mathrm{T}_{\mathrm{CY}}=.32 \mu \mathrm{sec}$ |
| $l_{\text {CC (AV) }}$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 60 | 80 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{BB}}$ ) |  | . 01 | 1 | mA |  |
| $I_{\text {IL }}$ | Input Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{CLOCK}} \leqslant \mathrm{~V}_{\mathrm{DD}} \\ & \mathrm{~V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |
| ${ }^{\text {ICL }}$ | Clock Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ |  |
| ${ }^{\text {DLia] }}$ | Data Bus Leakage in Input Mode |  |  | $\begin{aligned} & -100 \\ & -2.0 \end{aligned}$ | $\begin{gathered} \mu \mathrm{A} \\ \mathrm{~mA} \end{gathered}$ |  |
| $I_{\text {FL }}$ | Address and Data Bus Leakage During HOLD |  |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {ADDR/DATA }}=V_{C C} \\ & V_{\text {ADDR/DATA }}=V_{S S}+0.45 \mathrm{~V} \end{aligned}$ |

## CAPACITANCE

$$
T_{A}=25^{\circ} \mathrm{C} \quad V_{C C}=V_{D D}=V_{S S}=0 V, V_{B B}=-5 V
$$

| Symbol | Parameter | Typ. | Max. | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\phi}$ | Clock Capacitance | 17 | 25 | pf |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 6 | 10 | pf | Unmeasured Pins |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 10 | 20 | pf | Returned to $\mathrm{V}_{\mathrm{SS}}$ |

## NOTES:

1. The RESET signal must be active for a minimum of 3 clock cycles.
2. When DBIN is high and $V_{I N}>V_{I H}$ an internal active pull up will be switched onto the Data Bus.
3. $\Delta I$ supply $/ \Delta T_{A}=-0.45 \% /{ }^{\circ} \mathrm{C}$.


DATA BUS CHARACTERISTIC DURING DBIN


## A.C. CHARACTERISTICS

CAUTION: When operating the 8080A-1 at or near full speed, care must be taken to assure precise timing compatibility between 8080A-1, 8224 and 8228 .
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CY}}{ }^{[3]}$ | Clock Period | . 32 | 2.0 | $\mu \mathrm{sec}$ | $\begin{aligned} & -\mathrm{C}_{\mathrm{L}}=50 \mathrm{pf} \\ & -\mathrm{C}_{\mathrm{L}}=50 \mathrm{pf} \end{aligned}$ |
| $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | Clock Rise and Fall Time | 0 | 25 | nsec |  |
| $t_{\text {¢ }}$ | $\phi_{1}$ Pulse Width | 50 |  | nsec |  |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 145 |  | nsec |  |
| $t_{\text {D1 }}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  | nsec |  |
| $t_{\text {D2 }}$ | Delay $\phi_{2}$ to $\phi_{1}$ | 60 |  | nsec |  |
| $t_{\text {D }}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 60 |  | nsec |  |
| $t_{\text {DA }}$ [2] | Address Output Delay From $\phi_{2}$ |  | 150 | nsec |  |
| $\mathrm{t}_{\text {DD }}{ }^{[2]}$ | Data Output Delay From $\phi_{2}$ |  | 180 | nsec |  |
| $t_{D C}{ }^{[2]}$ | Signal Output Delay From $\phi_{1}$, or $\phi_{2}$ (SYNC, $\overline{\text { WR }}$,WAIT, HLDA) |  | 110 | nsec |  |
| $\mathrm{t}_{\mathrm{DF}}$ [2] | DBIN Delay From $\phi_{2}$ | 25 | 130 | nsec |  |
| $t_{\text {DI }}{ }^{[1]}$ | Delay for Input Bus to Enter Input Mode |  | ${ }^{\text {t }}$ DF | nsec |  |
| $\mathrm{t}_{\mathrm{DS} 1}$. | Data Setup Time During $\phi_{1}$ and DBIN | 10 |  | nsec |  |

TIMING WAVEFORMS ${ }^{[14]}$ (Note: Timing measurements are made at the following reference voltages: CLOCK " 1 " $=8.0 \mathrm{~V}$ $" 0 "=1.0 \mathrm{~V}$; INPUTS $" 1 "=3.3 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$; OUTPUTS " 1 " $=2.0 \mathrm{~V},{ }^{\prime \prime} 0 "=0.8 \mathrm{~V}$.)

inte

## A.C. CHARACTERISTICS (Continued)

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DS2 }}$ | Data Setup Time to $\phi_{2}$ During DBIN | 120 |  | nsec | $C_{L}=50 \mathrm{pf}$ |
| $\mathrm{t}_{\mathrm{DH}}{ }^{[1]}$ | Data Hold Time From $\phi_{2}$ During DBIN | [1] |  | nsec |  |
| $\mathrm{t}_{\mathrm{IE}}{ }^{\text {[2] }}$ | INTE Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| $t_{\text {RS }}$ | READY Setup Time During $\phi_{2}$ | 90 |  | nsec |  |
| ${ }_{\text {thS }}$ | HOLD Setup Time to $\phi_{2}$ | 120 |  | nsec |  |
| $\mathrm{t}_{\mathrm{IS}}$ | INT Setup Time During $\phi_{2}$ (During $\phi_{1}$ in Halt Mode) | 100 |  | nsec |  |
| $\mathrm{t}_{\mathrm{H}}$ | Hold Time From $\phi_{2}$ (READY, INT, HOLD) | 0 |  | nsec |  |
| $\mathrm{t}_{\mathrm{FD}}$ | Delay to Float During Hold (Address and Data Bus) |  | 120 | nsec |  |
| ${ }^{t_{A W}}{ }^{[2]}$ | Address Stable Prior to $\overline{W R}$ | [5] |  | nsec | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pf}:$ Address, Data $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pf}: \overline{\mathrm{WR}}, \mathrm{HLDA}$, DBIN |
| $\mathrm{t}_{\mathrm{DW}}{ }^{[2]}$ | Output Data Stable Prior to $\overline{\mathrm{WR}}$ | [6] |  | nsec |  |
| ${ }_{\mathrm{t}_{W}{ }^{[2]}}$ | Output Data Stable From $\overline{\mathrm{WR}}$ | [7] |  | nsec |  |
| ${ }_{\text {W }}^{\text {A }}$ [ ${ }^{[2]}$ | Address Stable From $\overline{W R}$ | [7] |  | nsec |  |
| $\mathrm{t}_{\mathrm{HF}}{ }^{\text {[2] }}$ | HLDA to Float Delay | [8] |  | nsec |  |
| $\mathrm{t}_{W}{ }^{[2]}$ | $\overline{\mathrm{WR}}$ to Float Delay | [9] |  | nsec |  |
| $\mathrm{taH}^{[2]}$ | Address Hold Time After DBIN During HLDA | -20 |  | nsec |  |



NOTES:

1. Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured ${ }^{t} D H=50 \mathrm{~ns}$ or ${ }^{\mathrm{t}} \mathrm{DF}$, whichever is less.
2. Load Circuit.


TYPICAL $\triangle$ OUTPUT DELAY VS. $\triangle$ CAPACITANCE

4. The following are relevant when interfacing the 8080 A to devices having $\mathrm{V}_{1 \mathrm{H}}=3.3 \mathrm{~V}$ : a) Maximum output rise time from .8 V to $3.3 \mathrm{~V}=100 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}=\mathrm{SPEC}$.
b) Output delay when measured to $3.0 \mathrm{~V}=\mathrm{SPEC}+60 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}=\mathrm{SPEC}$.

5. $t_{A W}=2 t^{t} Y^{-t} \mathrm{D} 3^{-t} \mathrm{r} \phi 2^{-110 \mathrm{nsec} .}$
6. $t_{D W}=t^{t} C{ }^{-t} \mathrm{D} 3^{-t_{r} \phi 2-150 n s e c .}$
7. If not $H L D A, t_{W D}=t W A=t D 3+t_{r} \phi 2+10 \mathrm{~ns}$. If $H L D A, t_{W D}=t W A=t W F$.
$t_{H F}=t_{D} 3+t_{\mathrm{r} \phi 2}-50 \mathrm{~ns}$.
${ }^{t} W F=t_{D} 3+t_{r \phi 2}-10 \mathrm{~ns}$
0. Data in must be stable for this period during DBIN $\cdot T_{3}$. Both tDS1 and tDS2 must be satisfied.
11. Ready signal must be stable for this period during $T_{2}$ or $T_{W}$. (Must be externally synchronized.)
12. Hold signal must be stable for this period during $T_{2}$ or $T_{W}$ when entering hold mode, and during $T_{3}, T_{4}, T_{5}$ and TWH when in hold mode. (External synchronization is not required.)
3. Interrupt signal must be stable during this period of the last clock cycle of any instruction in order to be recognized on the following instruction. (External synchronization is not required.)
14. This timing diagram shows timing relationships only; it does not represent any specific machine cycle.

## 8080A-2 <br> SINGLE CHIP 8-BIT N-CHANNEL MICROPROCESSOR

- TTL Drive Capability

■ $1.5 \mu$ Instruction Cycle

- Powerful Problem Solving Instruction Set
- Six General Purpose Registers and an Accumulator
- Sixteen Bit Program Counter for Directly Addressing up to 64K Bytes of Memory

\author{

- Sixteen Bit Stack Pointer and Stack Manipulation Instructions for Rapid Switching of the Program Environment <br> - Decimal,Binary and Double Precision Arithmetic <br> - Ability to Provide Priority Vectored
Interrupts <br> ■ 512 Directly Addressed I/O Ports
}


#### Abstract

The Intel ${ }^{\circledR}$ 8080A is a complete 8 -bit parallel central processing unit (CPU). It is fabricated on a single LSI chip using Intel's $n$-channel silicon gate MOS process. This offers the user a high performance solution to control and processing applications. The 8080A contains six 8 -bit general purpose working registers and an accumulator. The six general purpose registers may be addressed individually or in pairs providing both single and double precision operators. Arithmetic and logical instructions set or reset four testable flags. A fifth flag provides decimal arithmetic operation. The 8080A has an external stack feature wherein any portion of memory may be used as a last in/first out stack to store/ retrieve the contents of the accumulator, flags, program counter and all of the six general purpose registers. The sixteen bit stack pointer controls the addressing of this external stack. This stack gives the 8080A the ability to easily handle multiple level priority interrupts by rapidly storing and restoring processor status. It also provides almost unlimited subroutine nesting. This microprocessor has been designed to simplify systems design. Separate 16 -line address and 8 -line bi-directional data busses are used to facilitate easy interface to memory and I/O. Signals to control the interface to memory and I/O are provided directly by the 8080A. Ultimate control of the address and data busses resides with the HOLD signal. It provides the ability to suspend processor operation and force the address and data busses into a high impedance state. This permits ORtying these busses with other controlling devices for (DMA) direct memory access or multi-processor operation.




## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input or Output Voltages
With Respect to $V_{B B}$
-0.3 V to +20 V
$\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ With Respect to $\mathrm{V}_{\mathrm{BB}} \quad-0.3 \mathrm{~V}$ to +20 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . 1.5W
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {ILC }}$ | Clock Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V | $\begin{aligned} \mathrm{I}_{\mathrm{OL}} & =1.9 \mathrm{~mA} \text { on all outputs, } \\ \mathrm{I}_{\mathrm{OH}} & =150 \mu \mathrm{~A} . \end{aligned}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High Voltage | 9.0 |  | $\mathrm{V}_{\mathrm{DD}}+1$ | V |  |
| $V_{\text {IL }}$ | Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V |  |
| $V_{\text {IH }}$ | Input High Voltage | 3.3 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  |  | 0.45 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 3.7 |  |  | V |  |
| $\mathrm{I}_{\mathrm{DD}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{DD}}$ ) |  | 40 | 70 | mA | Operation$T_{C Y}=.38 \mu \mathrm{sec}$ |
| $\operatorname{ICC}(A V)$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 60 | 80 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{BB}}$ ) |  | . 01 | 1 | mA |  |
| $I_{\text {IL }}$ | Input Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{CLOCK}} \leqslant \mathrm{~V}_{\mathrm{DD}} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CL}}$ | Clock Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ |  |
| ${ }^{\text {DL }}{ }^{[2]}$ | Data Bus Leakage in Input Mode |  |  | $\begin{aligned} & -100 \\ & -2.0 \end{aligned}$ | $\underset{\mathrm{mA}}{\mu \mathrm{~A}}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |
| $I_{\text {FL }}$ | Address and Data Bus Leakage During HOLD |  |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {ADDR/DATA }}=V_{\mathrm{CC}} \\ & V_{\text {ADDR/DATA }}=\mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \end{aligned}$ |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} \quad V_{C C}=V_{D D}=V_{S S}=0 V, V_{B B}=-5 V$

| Symbol | Parameter | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\phi}$ | Clock Capacitance | 17 | 25 | pf | $\mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz}$ <br> Unmeasured Pins <br> Returned to $\mathrm{V}_{\mathrm{SS}}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 6 | 10 | pf |  |
| Cout | Output Capacitance | 10 | 20 | pf |  |

## NOTES:

1. The RESET signal must be active for a minimum of 3 clock cycles.
2. When DBIN is high and $V_{I N}>V_{I H}$ an internal active pull up will be switched onto the Data Bus.
3. $\Delta I$ supply $/ \Delta T_{A}=-0.45 \% /{ }^{\circ} \mathrm{C}$.


DATA BUS CHARACTERISTIC DURING DBIN


## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\mathrm{C}_{\mathrm{C}}{ }^{[3]}}$ | Clock Period | . 38 | 2.0 | $\mu \mathrm{sec}$ | $\begin{aligned} & -c_{L}=100 \mathrm{pf} \\ & -\mathrm{C}_{\mathrm{L}}=50 \mathrm{pf} \end{aligned}$ |
| $\mathrm{tr}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | Clock Rise and Fall Time | 0 | 50 | nsec |  |
| $\mathrm{t}_{\phi 1}$ | $\phi_{1}$ Pulse Width | 60 |  | nsec |  |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 175 |  | nsec |  |
| $t_{\text {D1 }}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  | nsec |  |
| ${ }^{\text {t }}$ 2 | Delay $\phi_{2}$ to $\phi_{1}$ | 70 |  | nsec |  |
| $\mathrm{t}_{\mathrm{D} 3}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 70 |  | nsec |  |
| $t_{\text {DA }}$ [2] | Address Output Delay From $\phi_{2}$ |  | 175 | nsec |  |
| $t_{\text {DD }}{ }^{[2]}$ | Data Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| ${ }^{t_{D C}}{ }^{[2]}$ | Signal Output Delay From $\phi_{1}$, or $\phi_{2}$ (SYNC, $\overline{\text { WR, WAIT, HLDA) }}$ |  | 120 | nsec |  |
| ${ }^{\text {t }}{ }_{\text {DF }}$ [2] | DBIN Delay From $\phi_{2}$ | 25 | 140 | nsec |  |
| ${ }_{t_{D 1}{ }^{[1]}}$ | Delay for Input Bus to Enter Input Mode |  | ${ }^{\text {t }}$ DF | nsec |  |
| ${ }^{\text {t }{ }_{\text {S } 1}}$ | Data Setup Time During $\phi_{1}$ and DBIN | 20 |  | nsec |  |

TIMING WAVEFORMS ${ }^{[14]}$ (Note: Timing measurements are made at the following reference voltages: CLOCK " 1 " $=8.0 \mathrm{~V}$ $" 0 "=1.0 \mathrm{~V}$; INPUTS " 1 " = $3.3 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$; OUTPUTS " 1 " = $2.0 \mathrm{~V}, " 0$ " $=0.8 \mathrm{~V}$.)


INTE

## A.C. CHARACTERISTICS (Continued)

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tos } 2}$ | Data Setup Time to $\phi_{2}$ During DBIN | 130 |  | nsec | $C_{L}=50 p f$ |
| ${ }^{\text {DH }}{ }^{[1]}$ | Data Hold Time From $\phi_{2}$ During DBIN | [1] |  | nsec |  |
| $\mathrm{t}_{\mathrm{IE}}{ }^{\text {[2] }}$ | INTE Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| $t_{\text {RS }}$ | READY Setup Time During $\phi_{2}$ | 90 |  | nsec |  |
| $t_{\text {HS }}$ | HOLD Setup Time to $\phi_{2}$ | 120 |  | nsec |  |
| $\mathrm{t}_{\text {IS }}$ | INT Setup Time During $\phi_{2}$ (During $\phi_{1}$ in Halt Mode) | 100 |  | nsec |  |
| $t_{H}$ | Hold Time From $\phi_{2}$ (READY, INT, HOLD) | 0 |  | nsec |  |
| $\mathrm{t}_{\mathrm{FD}}$ | Delay to Float During Hold (Address and Data Bus) |  | 120 | nsec |  |
| $\mathrm{t}_{\mathrm{AW}}{ }^{[2]}$ | Address Stable Prior to $\overline{W R}$ | [5] |  | nsec | $C_{L}=100 \mathrm{pf}$ : Address, Data $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pf}: \overline{\mathrm{WR}}, \mathrm{HLDA}, ~ D B I N$ |
| $t_{\text {DW }}{ }^{[2]}$ | Output Data Stable Prior to WR | [6] |  | nsec |  |
| $\mathrm{t}_{W}{ }^{\text {[2] }}$ | Output Data Stable From $\overline{W R}$ | [7] |  | nsec |  |
| ${ }_{\text {twA }}{ }^{[2]}$ | Address Stable From WR | [7] |  | nsec |  |
| $\mathrm{t}_{\mathrm{HF}}{ }^{\text {[2] }}$ | HLDA to Float Delay | [8] |  | nsec |  |
| ${ }_{\text {twF }}{ }^{\text {[2] }}$ | $\overline{\text { WR }}$ to Float Delay | [9] |  | nsec |  |
| $\mathrm{t}_{\mathrm{AH}}{ }^{\text {[2] }}$ | Address Hold Time After DBIN During HLDA | -20 |  | nsec |  |



NOTES:

1. Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured. ${ }^{t} \mathrm{DH}=50 \mathrm{~ns}$ or tDF, whichever is less.
2. Load Circuit.

3. ${ }^{t}{ }_{C Y}=t_{D} 3+t_{r \phi 2}+t_{\phi 2}+t_{f \phi 2}+t_{D}+t_{r \phi 1} \geqslant 380 \mathrm{~ns}$.

4. The following are relevant when interfacing the 8080 A to devices having $\mathrm{V}_{1 \mathrm{H}}=3.3 \mathrm{~V}$ :
a) Maximum output rise time from .8 V to $3.3 \mathrm{~V}=100 \mathrm{~ns} @ C_{L}=S P E C$.
b) Output delay when measured to $3.0 \mathrm{~V}=\mathrm{SPEC}+60 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}=\mathrm{SPEC}$.

5. $t_{A W}=2 \mathrm{t}_{\mathrm{C}}{ }^{-1} \mathrm{D} 3^{-t_{\mathrm{r}}} \boldsymbol{\phi} 2-130 \mathrm{nsec}$.

6. If not HLDA, $\mathrm{tWD}=\mathrm{tWA}=\mathrm{tD} 3+\mathrm{t}_{\mathrm{r} \phi 2}+10 \mathrm{~ns}$. If $\mathrm{HLDA}, \mathrm{tWD}=\mathrm{t} W A=\mathrm{t} W F$.
7. $t_{H F}=t_{D} 3+t_{\text {r }} 2-50 \mathrm{~ns}$.
8. $\mathrm{t} W \mathrm{~F}=\mathrm{t}_{\mathrm{D} 3}+\mathrm{t}_{\mathrm{r} \phi 2}-10 \mathrm{~ns}$
9. Data in must be stable for this period during DBIN $\cdot T_{3}$. Both tDS1 and tDS2 must be satisfied.
10. Ready signal must be stable for this period during $T_{2}$ or $T_{W}$. (Must be externally synchronized.)
11. Hold signal must be stable for this period during $T_{2}$ or $T_{W}$ when entering hold mode, and during $T_{3}, T_{4}, T_{5}$ and TWH when in hold mode. (External synchronization is not required.)
12. Interrupt signal must be stable during this period of the last clock cycle of any instruction in order to be recognized on the following instruction. (External synchronization is not required.)
13. This timing diagram shows timing relationships only; it does not represent any specific machine cycle.

M8080A

## SINGLE CHIP 8-BIT N-CHANNEL MICROPROCESSOR

The M8080A is functionally compatible with the Inte ${ }^{\circledR} 8080$.

- Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- $\pm 10 \%$ Power Supply Tolerance
- $2 \mu$ s Instruction Cycle
- Powerful Problem Solving Instruction Set
- Six General Purpose Registers and an Accumulator


## - Sixteen Bit Program Counter for Directly Addressing up to 64K Bytes of Memory

- Sixteen Bit Stack Pointer and Stack Manipulation Instructions for Rapid Switching of the Program Environment
- Decimal,Binary and Double Precision Arithmetic
- Ability to Provide Priority Vectored Interrupts
- 512 Directly Addressed I/O Ports
- TTL Drive Capability

The Intel ${ }^{\circledR}$ M8080A is a complete 8 -bit parallel central processing unit (CPU). It is fabricated on a single LSI chip using Intel's n -channel silicon gate MOS process. This offers the user a high performance solution to control and processing applications. The M8080A contains six 8-bit general purpose working registers and an accumulator. The six general purpose registers may be addressed individually or in pairs providing both single and double precision operators. Arithmetic and logical instructions set or reset four testable flags. A fifth flag provides decimal arithmetic operation.
The M8080A has an external stack feature wherein any portion of memory may be used as a last in/first out stack to store/ retrieve the contents of the accumulator, flags, program counter and all of the six general purpose registers. The sixteen bit stack pointer controls the addressing of this external stack. This stack gives the M8080A the ability to easily handle multiple level priority interrupts by rapidly storing and restoring processor status. It also provides almost unlimited subroutine nesting.
This microprocessor has been designed to simplify systems design. Separate 16 -line address and 8 -line bi-directional data busses are used to facilitate easy interface to memory and I/O. Signals to control the interface to memory and I/O are provided directly by the M8080A. Ultimate control of the address and data busses resides with the HOLD signal. It provides the ability to suspend processor operation and force the address and data busses into a high impedance state. This permits ORtying these busses with other controlling devices for (DMA) direct memory access or multi-processor operation.


## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages |  |
| With Respect to $V_{B B}$ | -0.3 V to +20V |
| $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{S S}$ With Respect to $\mathrm{V}_{\mathrm{BB}}$ | -0.3 V to +20 V |
| Power Dissipation | 1.7 W |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VILC | Clock Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V | $\begin{aligned} \mathrm{I}_{\mathrm{OL}} & =1.9 \mathrm{~mA} \text { on all outputs, } \\ \mathrm{I}_{\mathrm{OH}} & =150 \mu \mathrm{~A} . \end{aligned}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High Voltage | 8.5 |  | $\mathrm{V}_{\mathrm{DD}}+1$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 3.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 3.7 |  |  | V |  |
| $\mathrm{I}_{\mathrm{DD}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{DD}}$ ) |  | 50 | 80 | mA | $\begin{aligned} & \text { Operation } \\ & \mathrm{T}_{\mathrm{CY}}=.48 \mu \mathrm{sec} \end{aligned}$ |
| $\operatorname{ICC}(A V)$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 60 | 100 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{BB}}$ ) |  | . 01 | 1 | mA |  |
| $I_{\text {IL }}$ | Input Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{CLOCK}} \leqslant \mathrm{~V}_{\mathrm{DD}} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CL}}$ | Clock Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ |  |
| $\mathrm{I}_{\mathrm{DL}}{ }^{[2]}$ | Data Bus Leakage in Input Mode |  |  | $\begin{aligned} & -100 \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |
| $I_{\text {FL }}$ | Address and Data Bus Leakage During HOLD |  |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {ADDR/DATA }}=V_{C C} \\ & V_{\text {ADDR/DATA }}=V_{S S}+0.45 \mathrm{~V} \end{aligned}$ |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} \quad V_{C C}=V_{D D}=V_{S S}=0 V, V_{B B}=-5 V$

| Symbol | Parameter | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\phi}$ | Clock Capacitance | 17 | 25 | pf | $\mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz}$ <br> Unmeasured Pins Returned to $\mathrm{V}_{\mathrm{SS}}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 6 | 10 | pf |  |
| Cout | Output Capacitance | 10 | 20 | pf |  |

## NOTES:

1. The RESET signal must be active for a minimum of 3 clock cycles.
2. When DBIN is high and $V_{I N}>V_{I H}$ an internal active pull up will be switched onto the Data Bus.
3. $\Delta I$ supply $/ \Delta T_{A}=-0.45 \% /^{\circ} \mathrm{C}$.

TYPICAL SUPPLY CURRENT VS. TEMPERATURE, NORMALIZED. [3]


DATA BUS CHARACTERISTIC DURING DBIN


## A.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CY}}{ }^{\text {[3] }}$ | Clock Period | 0.48 | 2.0 | $\mu \mathrm{sec}$ | $J-C_{L}=50 \mathrm{pf}$ |
| $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | Clock Rise and Fall Time | 0 | 50 | nsec |  |
| $\mathrm{t}_{\phi 1}$ | $\phi_{1}$ Pulse Width | 60 |  | nsec |  |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 220 |  | nsec |  |
| $\mathrm{t}_{\mathrm{D} 1}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  | n sec |  |
| $\mathrm{t}_{\mathrm{D} 2}$ | Delay $\phi_{2}$ to $\phi_{1}$ | 80 |  | nsec |  |
| $\mathrm{t}_{\mathrm{D} 3}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 80 |  | nsec |  |
| $t_{\text {DA }}$ [2] | Address Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| $\mathrm{t}_{\mathrm{DD}}{ }^{[2]}$ | Data Output Delay From $\phi_{2}$ |  | 220 | nsec |  |
| $\mathrm{t}_{\mathrm{DC}}{ }^{[2]}$ | Signal Output Delay From $\phi_{1}$, or $\phi_{2}$ (SYNC, $\overline{\text { WR }}$, WAIT, HLDA) |  | 140 | nsec |  |
| $\mathrm{t}_{\mathrm{DF}}$ [2] | DBIN Delay From $\phi_{2}$ | 25 | 150 | nsec |  |
| $t_{D 1}{ }^{[1]}$ | Delay for Input Bus to Enter Input Mode |  | t ${ }_{\text {DF }}$ | nsec |  |
| ${ }^{\text {t }}$ S 1 | Data Setup Time During $\phi_{1}$ and DBIN | 30 |  | nsec |  |

TIMING WAVEFORMS ${ }^{[14]}$ (Note: Timing measurements are made at the following reference voltages: CLOCK " 1 " = 7.0V, $" 0 "=1.0 \mathrm{~V}$; INPUTS " 1 " $=3.0 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$; OUTPUTS " ${ }^{\prime \prime}{ }^{\prime \prime}=2.0 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$.)

inte

## A.C. CHARACTERISTICS (Continued)

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ DS2 | Data Setup Time to $\phi_{2}$ During DBIN | 130 |  | nsec | $C_{L}=50 \mathrm{pf}$ |
| $\mathrm{t}_{\mathrm{DH}}{ }^{\text {[1] }}$ | Data Hold Time From $\phi_{2}$ During DBIN | [1] |  | nsec |  |
| $\mathrm{t}_{\text {IE }}{ }^{\text {[2] }}$ | INTE Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| $\mathrm{t}_{\mathrm{RS}}$ | READY Setup Time During $\phi_{2}$ | 120 |  | nsec |  |
| $\mathrm{t}_{\mathrm{HS}}$ | HOLD Setup Time to $\phi_{2}$ | 140 |  | nsec |  |
| $\mathrm{t}_{\text {IS }}$ | INT Setup Time During $\phi_{2}$ (During $\phi_{1}$ in Hialt Mode) | 120 |  | nsec |  |
| $t_{H}$ | Hold Time From $\phi_{2}$ (READY, INT, HOLD) | 0 |  | nsec |  |
| $\mathrm{t}_{\text {FD }}$ | Delay to Float During Hold (Address and Data Bus) |  | 130 | nsec |  |
| ${ }^{\mathrm{A}_{\text {AW }}}{ }^{[2]}$ | Address Stable Prior to $\bar{W} \bar{R}$ | [5] |  | nsec | $C_{L}=50 \mathrm{pf}$ |
| ${ }_{t_{\text {DW }}}{ }^{[2]}$ | Output Data Stable Prior to $\overline{\mathrm{WR}}$ | [6] |  | nsec |  |
| ${ }_{\text {W }}^{\text {D }}{ }^{[2]}$ | Output Data Stable From $\overline{W R}$ | [7] |  | nsec |  |
| ${ }^{\text {twA }}{ }^{[2]}$ | Address Stable From $\overline{W R}$ | [7] |  | nsec |  |
| $\mathrm{t}_{\mathrm{HF}}{ }^{\text {[2] }}$ | HLDA to Float Delay | [8] |  | nsec |  |
| ${ }^{t_{W F}}{ }^{[2]}$ | $\overline{W R}$ to Float Delay | [9] |  | nsec |  |
| $\mathrm{taH}^{[2]}$ | Address Hold Time After DBIN During HLDA | -20 |  | nsec |  |



NOTES:

1. Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured. ${ }^{\text {t }} D H=50$ ns or tDF, whichever is less.
2. Load Circuit.

3. ${ }^{t} \mathrm{CY}=\mathrm{t}_{\mathrm{D} 3}+\mathrm{t}_{\mathrm{r} \phi 2}+\mathrm{t}_{\phi 2}+\mathrm{t}_{\mathrm{f} \phi 2}+\mathrm{t}_{\mathrm{D} 2}+\mathrm{t}_{\mathrm{r} \phi 1} \geqslant 480 \mathrm{~ns}$.

TYPICAL $\triangle$ OUTPUT DELAY VS. $\triangle$ CAPACITANCE

4. The following are relevant when interfacing the M8080A to devices having $\mathrm{V}_{1 \mathrm{H}}=3.3 \mathrm{~V}$ :
a) Maximum output rise time from .8 V to $3.3 \mathrm{~V}=100 \mathrm{~ns} @ C_{\mathrm{L}}=\mathrm{SPEC}$.
b) Output delay when measured to $3.0 \mathrm{~V}=\mathrm{SPEC}+60 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}=\mathrm{SPEC}$.
c) If $C_{L} \neq S P E C$, add $.6 \mathrm{~ns} / \mathrm{pF}$ if $\mathrm{C}_{\mathrm{L}}>\mathrm{C}_{\text {SPEC }}$, subtract $.3 \mathrm{~ns} / \mathrm{pF}$ (from modified delay) if $\mathrm{C}_{\mathrm{L}}<\mathrm{C}_{\mathrm{SPEC}}$.

6. $\mathrm{t}_{\mathrm{DW}}=\mathrm{t}_{\mathrm{CY}}-\mathrm{t}_{\mathrm{D} 3}-\mathrm{t}_{\mathrm{r} \phi 2-170 \mathrm{nsec} \text {. }}$
. If not HLDA, $\mathrm{t} W \mathrm{D}=\mathrm{t}_{\mathrm{W}} \mathrm{A}=\mathrm{t}_{\mathrm{D}} 3+\mathrm{t}_{\mathrm{r} \phi 2}+10 \mathrm{~ns}$. If HLDA, $\mathrm{t} W \mathrm{D}=\mathrm{t} W A=\mathrm{t} W \mathrm{~F}$.
$\mathrm{t}_{\mathrm{HF}}=\mathrm{t}_{\mathrm{D}} 3+\mathrm{t}_{\mathrm{r} \phi 2}-50 \mathrm{~ns}$.
${ }^{2} W F=t_{D 3}+t_{r \phi 2}-10 \mathrm{~ns}$
10. Data in must be stable for this period during DBIN $\cdot \mathrm{T}_{3}$. Both $\mathrm{t}_{\mathrm{DS} 1}$ and $\mathrm{t}_{\mathrm{DS} 2}$ must be satisfied
11. Ready signal must be stable for this period during $T_{2}$ or $T_{W}$. (Must be externally synchronized.)
12. Hold signal must be stable for this period during $T_{2}$ or $T_{W}$ when entering hold mode, and during $T_{3}, T_{4}, T_{5}$ and TWH when in hold mode. (External synchronization is not required.)
13. Interrupt signal must be stable during this period of the last clock cycle of any instruction in order to be recognized on the following instruction. (External synchronization is not required.)
14. This timing diagram shows timing relationships only; it does not represent any specific machine cycle.

# CLOCK GENERATOR AND DRIVER FOR 8080A CPU 

\author{

- Single Chip Clock Generator/Driver for 8080A CPU <br> - Power-Up Reset for CPU <br> - Ready Synchronizing Flip-Flop <br> - 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


PIN NAMES

| $\overline{\text { RESIN }}$ | RESET INPUT |
| :--- | :--- |
| RESET | RESET OUTPUT |
| RDYIN | READY INPUT |
| READY | READY OUTPUT |
| SYNC | SYNC INPUT |
| STSTB | STATUS STB <br> (ACTIVE LOW) |
| $\phi_{1}$ | 8080 <br> CLOCKS |
| $\phi_{2}$ | CLOCK |


| XTAL 1 | }{} |
| :--- | :--- |
| XTAL 2 |  |
| FOR CRYSTAL |  |

## 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:

$$
\begin{aligned}
\text { Crystal Frequency } & =\frac{1}{\mathrm{t}_{\mathrm{CY}}} \text { times } 9 \\
& \\
\text { Example 1: } & \left(500 \mathrm{~ns} \mathrm{t}_{\mathrm{CY}}\right) \\
& 2 \mathrm{mHz} \text { times } 9=18 \mathrm{mHz}^{*} \\
\text { Example 2: } & \left(800 \mathrm{~ns} \mathrm{t}_{\mathrm{CY}}\right) \\
& 1.25 \mathrm{mHz} \text { times } 9=11.25 \mathrm{mHz}
\end{aligned}
$$

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{L C}}
$$

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 10 mHz a small amount of frequency "trimming" may be necessary to produce the exact desired frequency. The addition of a small selected 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 "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.
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 onto 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 ( $\overline{\text { STSTB }}$ ) is achieved.


EXAMPLE: $\left(8080 \mathrm{t}_{\mathrm{cY}}=500 \mathrm{~ns}\right)$ OSC $=18 \mathrm{mHz} / 55 \mathrm{~ns}$ $\phi_{1}=110 \mathrm{~ns}(2 \times 55 \mathrm{~ns})$
$\phi_{2}=275 \mathrm{~ns}(5 \times 55 \mathrm{~ns})$ $\phi_{2}=275 \mathrm{~ns}(5 \times 55 \mathrm{~ns})$

$$
\phi_{2}-\phi_{1}=110 \mathrm{~ns}(2 \times 55 \mathrm{~ns})
$$

## 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 ( $\phi 1 \mathrm{~A}$ ), 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.

An external RC network is connected to the $\overline{\operatorname{RESIN}}$ input. The slow transition of the power supply rise is sensed by an internal Schmitt Trigger. This circuit converts the slow transition into a clean, fast edge when its input level reaches a predetermined value. The output of the Schmitt Trigger is connected to a "D" type flip-flop that is clocked with $\phi 2 \mathrm{D}$ (an internal timing signal). The flip-flop is synchronously reset and an active high level that complies with the 8080A input spec is generated. For manual switch type system Reset circuits, an active low switch closing can be connected to the RESIN input in addition to the power-on RC netnetwork.


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 RDYIN input presents the asynchronous "wait request" to the "D" type flip-flop. By clocking the flip-flop with $\phi 2 \mathrm{D}$, 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.


## D.C. Characteristics

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%$.

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $I_{F}$ | Input Current Loading |  |  | -. 25 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Clamp Voltage |  |  | 1.0 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | . 8 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $V_{\text {IH }}$ | Input "High" Voltage | $\begin{aligned} & 2.6 \\ & 2.0 \end{aligned}$ |  |  | V | Reset Input All Other Inputs |
| $\mathrm{V}_{\text {IH }}-\mathrm{V}_{\text {IL }}$ | REDIN Input Hysteresis | . 25 |  |  | mV | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output "Low" Voltage |  |  | $\begin{aligned} & .45 \\ & .45 \end{aligned}$ | V <br> V | $\left(\phi_{1}, \phi_{2}\right)$, Ready, Reset, $\overline{\text { STSTB }}$ $\mathrm{IOL}^{2}=2.5 \mathrm{~mA}$ <br> All Other Outputs $\mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output "High" Voltage $\phi_{1}, \phi_{2}$ READY, RESET <br> All Other Outputs | $\begin{aligned} & 9.4 \\ & 3.6 \\ & 2.4 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{ISC}^{[1]}$ | Output Short Circuit Current (All Low Voltage Outputs Only) | -10 |  | -60 | mA | $\begin{aligned} & V_{\mathrm{O}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  |  | 115 | mA |  |
| IDD | Power Supply Current |  |  | 12 | mA |  |

Note: 1. Caution, $\phi_{1}$ and $\phi_{2}$ output drivers do not have short circuit protection

## CRYSTAL REQUIREMENTS

Tolerance: $.005 \%$ at $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$
Resonance: Series (Fundamental)*
Load Capacitance: 20-35pF
Equivalent Resistance: $75-20$ ohms
Power Dissipation (Min): 4mW
*With tank circuit use 3rd overtone mode.

## A.C. Characteristics

$\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{DD}}=+12.0 \mathrm{~V} \pm 5 \% ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  | Units | TestConditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| ${ }^{\text {t }}$ ¢ | $\phi_{1}$ Pulse Width | $\frac{2 \mathrm{tcy}}{9}-20 \mathrm{~ns}$ |  |  | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ to 50 pF |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | $\frac{5 t c y}{9}-35 n s$ |  |  |  |  |
| $\mathrm{t}_{\mathrm{D} 1}$ | $\phi_{1}$ to $\phi_{2}$ Delay | 0 |  |  |  |  |
| $\mathrm{t}_{\mathrm{D} 2}$ | $\phi_{2}$ to $\phi_{1}$ Delay | $\frac{2 \mathrm{tcy}}{9}-14 \mathrm{~ns}$ |  |  |  |  |
| $t_{\text {D3 }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | $\frac{2 \mathrm{tcy}}{9}$ |  | $\frac{2 \mathrm{tcy}}{9}+20 \mathrm{~ns}$ |  |  |
| $\mathrm{t}_{\mathrm{R}}$ | $\phi_{1}$ and $\phi_{2}$ Rise Time |  |  | 20 |  |  |
| $\mathrm{t}_{\mathrm{F}}$ | $\phi_{1}$ and $\phi_{2}$ Fall Time |  |  | 20 |  |  |
| $t_{\text {D } \downarrow 2}$ | $\phi_{2}$ to $\phi_{2}$ (TTL) Delay | -5 |  | +15 | ns | $\begin{aligned} & \phi_{2} \mathrm{TTL}, \mathrm{CL}=30 \\ & \mathrm{R}_{1}=300 \Omega \\ & \mathrm{R}_{2}=600 \Omega \end{aligned}$ |
| tDSs | $\phi_{2}$ to STSTB Delay | $\frac{6 \mathrm{tcy}}{9}-30 \mathrm{~ns}$ |  | $\frac{6 \mathrm{tcy}}{9}$ |  |  |
| tpw | STSTB Pulse Width | $\frac{\text { tcy }}{9}-15 \mathrm{~ns}$ |  |  |  | $\begin{aligned} & \text { STSTB }, C L=15 \mathrm{pF} \\ & \mathrm{R}_{1}=2 \mathrm{~K} \end{aligned}$ |
| ${ }_{\text {t }}$ ( ${ }^{\text {d }}$ | RDYIN Setup Time to Status Strobe | $50 \mathrm{~ns}-\frac{4 \mathrm{tcy}}{9}$ |  |  |  | $\mathrm{R}_{2}=4 \mathrm{~K}$ |
| ${ }_{\text {t }}{ }_{\text {dre }}$ | RDYIN Hold Time After STSTB | $\frac{4 \text { tcy }}{9}$ |  |  |  |  |
| ${ }^{\text {t }}$ D | RDYIN or RESIN to $\phi_{2}$ Delay | $\frac{4 \mathrm{tcy}}{9}-25 \mathrm{~ns}$ |  |  |  | Ready \& Reset $\begin{aligned} & C L=10 \mathrm{pF} \\ & \mathrm{R}_{1}=2 \mathrm{~K} \\ & \mathrm{R}_{2}=4 \mathrm{~K} \end{aligned}$ |
| ${ }^{\text {telk }}$ | CLK Period |  | $\frac{\text { tcy }}{9}$ |  |  |  |
| $f_{\text {max }}$ | Maximum Oscillating Frequency | 18.432 |  |  | MHz |  |
| $\mathrm{C}_{\text {in }}$ | Input Capacitance |  |  | 8 | pF | $\begin{aligned} & V_{\mathrm{CC}}=+5.0 \mathrm{~V} \\ & V_{\mathrm{DD}}=+12 \mathrm{~V} \\ & V_{\mathrm{BIAS}}=2.5 \mathrm{~V} \\ & f=1 \mathrm{MHz} \end{aligned}$ |



## WAVEFORMS



VOLTAGE MEASUREMENT POINTS: $\phi_{1}, \phi_{2}$ Logic " 0 " $=1.0 \mathrm{~V}$, Logic " $1 "=8.0 \mathrm{~V}$. All other signals measured at 1.5 V .

## EXAMPLE:

A.C. Characteristics (For $\mathrm{t}_{\mathrm{CY}}=488.28 \mathrm{~ns}$ )
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{t}_{\phi 1}$ | $\phi_{1}$ Pulse Width | 89 |  |  | ns | ${ }^{\mathrm{t}} \mathrm{CY}=488.28 \mathrm{~ns}$ |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 236 |  |  | ns |  |
| $t_{\text {D1 }}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{D} 2}$ | Delay $\phi_{2}$ to $\phi_{1}$ | 95 |  |  | ns |  |
| ${ }_{\text {t }}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 109 |  | 129 | ns |  |
| $\mathrm{t}_{\mathrm{r}}$ | Output Rise Time |  |  | 20 | ns | $\phi_{1} \& \phi_{2}$ Loaded to $C_{L}=20$ to 50 pF |
| $\mathrm{t}_{\mathrm{f}}$ | Output Fall Time |  |  | 20 |  |  |
| ${ }^{\text {t }}$ DSS | $\phi_{2}$ to STSTB Delay | 296 |  | 326 | ns |  |
| ${ }^{t}{ }_{D}{ }^{2}$ | $\phi_{2}$ to $\phi_{2}$ (TTL) Delay | -5 |  | +15 | ns |  |
| $t_{\text {PW }}$ | Status Strobe Pulse Width | 40 |  |  |  | Ready \& Reset Loaded to $2 \mathrm{~mA} / 10 \mathrm{pF}$ |
| tDRS | RDYIN Setup Time to STSTB | -167 |  |  | ns |  |
| $t_{\text {DRH }}$ | RDYIN Hold Time after STSTB | 217 |  |  | ns | All measurements referenced to 1.5 V unless specified otherwise. |
| $t_{\text {DR }}$ | READY or RESET to $\phi_{2}$ Delay | 192 |  |  | ns |  |
| f | Oscillator Frequency |  |  | 18.432 | MHz |  |

M8224
CLOCK GENERATOR AND DRIVER FOR 8080A CPU

## ■ Single Chip Clock Generator/Driver for M8080A CPU

■ Power-Up Reset for CPU

- Ready Synchronizing Flip-Flop
- Advanced Status Strobe
- Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

■ Oscillator Output for External System Timing

- Crystal Controlled for Stable System Operation
Reduces System Package Count
$\pm 10 \%$ Power Supply Tolerance

The M8224 is a single chip clock generator/driver for the M8080A 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 M8224 provides the designer with a significant reduction of packages used to generate clocks and timing for M8080A.

PIN CONFIGURATION



PIN NAMES

| $\overline{\text { RESIN }}$ | RESET INPUT |
| :--- | :--- |
| RESET | RESET OUTPUT |
| RDYIN | READY INPUT |
| READY | READY OUTPUT |
| SYNC | SYNC INPUT |
| $\overline{\text { STSTB }}$ | STATUS STB <br> (ACTIVE LOW) |
| $\phi_{1}$ | 8080 <br> $\phi_{2}$ |


| XTAL 1 | CONNECTIONS <br> FOR CRYSTAL |
| :--- | :--- |
| XTAL 2 | USED WITH OVERTONE XTAL |
| TANK | OSCILLATOR OUTPUT |
| OSC | $\phi_{2}$ CLK (TTL LEVEL) |
| $\phi_{2}$ (TTL) | +5 V |
| $V_{C C}$ | +12 V |
| $V_{D D}$ | 0 V |
| GND |  |

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Supply Voltage, $\mathrm{V}_{\mathrm{CC}}$. . . . . . . . . . . . $\quad-0.5 \mathrm{~V}$ to +7 V
Supply Voltage, VDD . . . . . . . . . . . . -0.5 V to +13.5 V
Input Voltage . . . . . . . . . . . . . . . . . . $\quad-1.0 \mathrm{~V}$ to +7 V
Output Current . . . . . . . . . . . . . . . . . . . . . . 100mA
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%$.

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Current Loading |  |  | -. 25 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $I_{R}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Ciamp Voltage |  |  | -1.2 | V | $\mathrm{IC}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | . 8 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{1}$ | Input "High" Voltage $\overline{\text { RESIN }}$ All Other Inputs | $\begin{aligned} & 2.6 \\ & 2.0 \end{aligned}$ |  |  | V |  |
| $\mathrm{V}_{\text {IH }}-\mathrm{V}_{\text {IL }}$ | $\overline{\text { RESIN }}$ Input Hysteresis | . 25 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output "Low" Voltage OSC, $\phi 2$ (TTL) All Other Outputs |  |  | $.45$ $.45$ | $\mathrm{V}$ $\mathrm{V}$ | $\begin{aligned} & \mathrm{OL}=10 \mathrm{~mA} \\ & \mathrm{lOL}=2.5 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \text { Output "High" Voltage } \\ & \phi_{1}, \phi_{2} \\ & \text { READY, RESET } \\ & \text { OSC, } \phi 2 \text { (TTL), STSTB } \end{aligned}$ | $\begin{aligned} & 9.0 \\ & 3.3 \\ & 2.4 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $10 S^{[1]}$ | Output Short Circuit Current (All Low Voltage Outputs Only) | -10 |  | -60 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \end{aligned}$ |
| $I_{\text {cc }}$ | Power Supply Current |  |  | 115 | mA |  |
| IDD | Power Supply Current |  |  | 12 | mA |  |

Note: 1. Caution, $\phi_{1}$ and $\phi_{2}$ output drivers do not have short circuit protection

## CRYSTAL REOUIREMENTS

Tolerance: $.005 \%$ at $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Resonance: Series (Fundamental)*
Load Capacitance: 20-35pF
Equivalent Resistance: 75-20 ohms
Power Dissipation (Min): 4mW
*With tank circuit use 3rd overtone mode.

## A.C. CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=+5.0 \pm 10 \% ; \mathrm{V}_{\mathrm{DD}}=+12.0 \mathrm{~V} \pm 10 \% ; \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  | Units | Test <br> Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{t}_{\boldsymbol{\prime} 1}$ | $\phi_{1}$ Pulse Width | $\frac{2 \mathrm{tcy}}{9}-20 \mathrm{~ns}$ |  |  | ns | $C_{L}=20 \mathrm{pF}$ to 50 pF |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | $\frac{5 t c y}{9}-45 n s$ |  |  |  |  |
| $t_{\text {D1 }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | 0 |  |  |  |  |
| ${ }^{\text {t }}$ 2 | $\phi_{2}$ to $\phi_{1}$ Delay | $\frac{2 t c y}{9}-25 n s$ |  |  |  |  |
| $t_{\text {D }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | $\frac{2 \mathrm{tcy}}{9}$ |  | $\frac{2 \mathrm{tcy}}{9}+40 \mathrm{~ns}$ |  |  |
| $t_{\text {R }}$ | $\phi_{1}$ and $\phi_{2}$ Rise Time |  |  | 25 |  |  |
| $\mathrm{t}_{\mathrm{F}}$ | $\phi_{1}$ and $\phi_{2}$ Fall Time |  |  | 25 |  |  |
| $t_{\text {D } ¢ 2}$ | $\phi_{2}$ to $\phi_{2}$ (TTL) Delay | -5 |  | +15 | ns | $\begin{aligned} & \phi_{2} \text { TTL,CL= } 30 \mathrm{pF} \\ & \mathrm{R}_{1}=300 \Omega \\ & \mathrm{R}_{2}=600 \Omega \end{aligned}$ |
| ${ }^{\text {D DSS }}$ | $\phi_{2}$ to STSTB Delay | $\frac{6 \mathrm{tcy}}{9}-30 \mathrm{~ns}$ |  | $\frac{6 \text { tcy }}{9}$ |  | $\begin{aligned} & \overline{\text { STSTB }}, C L=15 \mathrm{pF} \\ & \mathrm{R}_{1}=2 \mathrm{~K} \\ & \mathrm{R}_{2}=4 \mathrm{~K} \end{aligned}$ |
| tPW | $\overline{\text { STSTB Pulse Width }}$ | $\frac{\text { tcy }}{9}-23 n s$ |  |  |  |  |
| ${ }^{\text {t DRS }}$ | RDYIN Setup Time to Status Strobe | $50 \mathrm{~ns}-\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| ${ }^{\text {t }}$ DRH | RDYIN Hold Time <br> After STSTB | $\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| ${ }^{\text {t }}$ D | READY or RESET to $\phi_{2}$ Delay | $\frac{4 t c y}{9}-25 n s$ |  |  |  | $\begin{aligned} & C L=10 \mathrm{pF} \\ & \mathrm{R}_{1}=2 \mathrm{~K} \\ & \mathrm{R}_{2}=4 \mathrm{~K} \end{aligned}$ |
| tclk | CLK Period |  | $\frac{\text { tcy }}{9}$ |  |  |  |
| $f_{\text {max }}$ | Maximum Oscillating Frequency | 18.432 |  |  | MHz |  |
| $\mathrm{C}_{\text {in }}$ | Input Capacitance |  |  | 8 | pF | $\begin{aligned} & V_{C C}=+5.0 \mathrm{~V} \\ & V_{D D}=+12 \mathrm{~V} \\ & V_{B I A S}=2.5 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |



## WAVEFORMS



VOLTAGE MEASUREMENT POINTS: $\phi_{1}, \phi_{2}$ Logic " 0 " = 1.0 V , Logic " 1 " = 7.0 V . READY, RESET Logic " 0 " $=0.8 \mathrm{~V}$, Logic " 1 " = 3.0 V . All other signals measured at 1.5 V .

## Example:

A.C. CHARACTERISTICS ( For $_{\mathrm{t}}^{\mathrm{CY}} \mathrm{=}=488.28 \mathrm{~ns}$.)
$T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%$.

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{t}_{\phi 1}$ | $\phi_{1}$ Pulse Width | 89 |  |  | ns ns ns ns | ${ }^{\mathrm{t}} \mathrm{CY}=488.28 \mathrm{~ns}$ |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 226 |  |  |  |  |
| $\mathrm{t}_{\mathrm{D} 1}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  |  |  |  |
| $\mathrm{t}_{\mathrm{D} 2}$ | Delay $\phi_{2}$ to $\phi_{1}$ | 84 |  |  |  | $\phi_{1} \& \phi_{2}$ Loaded to $C_{L}=20$ to 50 pF |
| $\mathrm{t}_{\mathrm{D} 3}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 109 |  | 149 | ns |  |
| $\mathrm{t}_{\mathrm{r}}$ | Output Rise Time |  |  | 25 | ns |  |
| $\mathrm{t}_{\mathrm{f}}$ | Output Fall Time |  |  | 25 |  |  |
| $\mathrm{t}_{\text {DSS }}$ | $\phi_{2}$ to $\overline{\text { STSTB }}$ Delay | 296 |  | 326 | ns |  |
| ${ }^{\text {t }}{ }_{\text {¢ }}$ 2 | $\phi_{2}$ to $\phi_{2}$ (TTL) Delay | -5 |  | +15 | ns |  |
| $t_{\text {PW }}$ | Status Strobe Pulse Width | 31 |  |  | ns | Ready \& Reset Loaded to $2 \mathrm{~mA} / 10 \mathrm{pF}$ |
| $t_{\text {DRS }}$ | RDYIN Setup Time to STSTB | -167 |  |  | ns |  |
| torh | RDYIN Hold Time after STSTB | 217 |  |  | ns | All measurements referenced to 1.5 V |
| $t_{\text {DR }}$ | READY or RESET to $\phi_{2}$ Delay | 192 |  |  | ns | unless specified otherwise. |

# 8801 <br> CLOCK GENERATOR CRYSTAL FOR 8224/8080A 

- Specifically Selected For Intel ${ }^{\circledR} 8224$

■ 18.432 MHz for $1.95 \mu \mathrm{~s}$ 8080A Cycle

- Simple Generation of All Standard Communication Baud Rates

The 8801 is a quartz crystal specifically selected to operate with the 8224 clock generator and 8080 A . It resonates in the fundamental frequency mode at 18.432 MHz . This frequency allows the 8080 A at full speed ( $\mathrm{T}_{\mathrm{CY}}=488 \mathrm{~ns}$ ) to have a cycle of $1.95 \mu \mathrm{~s}$ and also simplifies the generation of all standard communication baud rates. The 8801 crystal is exactly matched to the requirements of the 8080A/8224 and provides both high-performance and system flexibility for the microcomputer designer.

8801 INTERFACE


## APPLICATIONS

The selection of 18.432 MHz provides the 8080A with clocks whose period is 488 ns . This allows the 8080A to operate at very close to its maximum specified speed ( 480 ns ). The 8224, when used with the 8801, outputs a signal on its OSC pin that is an approximately symetrical square wave at a frequency of 18.432 MHz . This frequency signal can be easily divided down to generate an accurate, stable baud rate clock that can be connected directly to the tiansmitter or receiver clocks of the 8251 USART. This feature allows the designer to support most standard communication interfaces with a minimum of extra hardware.
The chart below (Fig. 1) shows the equivalent baud rates that are generated with the corresponding dividers.

## BLOCK DIAGRAM



| BAUD RATE <br> $\mathbf{6 4 x}$ | BAUD RATE <br> $\mathbf{1 6 x}$ | FREQUENCY | BASIC <br> DIVIDER | PLUS TRIM <br> DIVIDER |
| :---: | :---: | :---: | :---: | :---: |
| 9600 |  | 614.4 KH | $\div 30$ | - |
| 4800 | 19.2 K | 307.2 KH | $\div 30$ | $\div 2$ |
| 2400 | 9600 | 153.6 KH | $\div 30$ | $\div 4$ |
| 1200 | 4800 | 76.8 KH | $\div 30$ | $\div 8$ |
| 600 | 2400 | 38.4 KH | $\div 30$ | $\div 16$ |
| 300 | 1200 | 19.2 KH | $\div 30$ | $\div 32$ |
|  | 600 | 9.6 KH | $\div 30$ | $\div 64$ |
|  | 300 | 4.8 KH | $\div 30$ | $\div 128$ |
| $* 109.1$ | 6.982 KH | $\div 30$ | $\div 88$ |  |

*For 109.1 (64x) Baud rate divide 1200 Baud Frequency ( 76.8 KH ) by 11.

Figure 1. Baud Rate Chart

## ELECTRICAL CHARACTERISTICS

Recommended Drive Level . . . . . . . . . . . . . . 5mW
Type of Resonance . . . . . . . . . . . . . . . . . . . . . . Series
Equivalent Resistance . . . . . . . . . . . . . . . . . . 20 ohms
Maximum Shunt Capacity . . . . . . . . . . . . . . . 7pF
Maximum Frequency Deviation

$$
\begin{aligned}
& 0^{\circ}-70^{\circ} \mathrm{C} \text {. . . . . . . . . . . . . . . . . } \pm .005 \% \\
& -55^{\circ}-125^{\circ} \text { C . . . . . . . . . . . . . . . . . } \pm .002 \%
\end{aligned}
$$

## ORDERING INFORMATION

Intel Products may be ordered from either your local Intel sales office or stocking Intel distributor.

# 8228/8238 <br> SYSTEM CONTROLLER AND BUS DRIVER FOR 8080A CPU 

## - Single Chip System Control for MCS-80 ${ }^{\text {TM }}$ Systems

\author{

- Built-in Bi-Directional Bus Driver for Data Bus Isolation
}
- Allows the Use of Multiple Byte Instructions (e.g. CALL) for Interrupt
Acknowledge


## - User Selected Single Level Interrupt Vector (RST 7)

- 28 Pin Dual In-Line Package
- Reduces System Package Count

■ *8238 Has Advanced IOW/MEMW for Large System Timing Control

The 8228 is a single chip system controller and bus driver for MCS-80. It generates all signais required to directly interface MCS-80 family RAM, ROM, and I/O components.
A bi-directional bus driver is included to provide high system TTL fan-out. It also provides isolation of the 8080 data bus from memory and I/O. This allows for the optimization of control signals, enabling the systems deisgner to use slower memory and I/O. The isolation of the bus driver also provides for enhanced system noise immunity.
A user selected single level interrupt vector (RST 7) is provided to simplify real time, interrupt driven, small system requirements. The 8228 also generates the correct control signals to allow the use of multiple byte instructions (e.g., CALL) in response to an INTERRUPT ACKNOWLEDGE by the 8080A. This feature permits large, interrupt driven systems to have an unlimited number of interrupt levels.
The 8228 is designed to support a wide variety of system bus structures and also reduce system package count for cost effective, reliable, design of the MCS-80 systems.

PIN CONFIGURATION


8228/8238 BLOCK DIAGRAM


PIN NAMES

| D7-D0 | DATA BUS ( 8080 SIDE) | INTA | INTERRUPT ACKNOWLEDGE |
| :---: | :---: | :---: | :---: |
| DB7.DB0 | DATA BUS (SYSTEM SIDE) | HLDA | HLDA (FROM 8080) |
| $\overline{\text { IOR }}$ | I/O READ | WR | WR (FROM 8080) |
| I/OW | I/O WRITE | BUSEN | BUS ENABLE INPUT |
| MEMR | MEMORY READ | STSTB | STATUS STROBE (FROM 8224) |
| MEMW | MEMORY WRITE | $\mathrm{V}_{\mathrm{Cc}}$ | $+5 \mathrm{~V}$ |
| DBIN | DBIN (FROM 8080) | GND | 0 VOLTS |

## FUNCTIONAL DESCRIPTION

## General

The 8228 and 8238 are single chip System Controllers and Data Bus drivers for the 8080 Microcomputer System. They generate all control signals required to directly interface MCS $80^{T \mathrm{M}^{*}}$ family RAM, ROM, and I/O components.

Schottky Bipolar technology is used to maintain low delay times and provide high output drive capability to support small to medium systems.

## Bi-Directional Bus Driver

An eight bit, bi-directional bus driver is provided to buffer the 8080 data bus from Memory and I/O devices. The 8080A data bus has an input requirement of 3.3 volts ( min ) and can drive (sink) a maximum current of 1.9 mA . The $8228 / 38$ data bus driver assures that these input requirements will be not only met but exceeded for enhanced noise immunity. Also, on the system side of the driver adequate drive current is available ( 10 mA Typ.) so that a large number of Memory and I/O devices can be directly connected to the bus.

The Bi-Directional Bus Driver is controlled by signals from the Gating Array so that proper bus flow is maintained and its outputs can be forced into their high impedance state (3-state) for DMA activities.

## Status Latch

At the beginning of each machine cycle the 8080 CPU issues "status" information on its data bus that indicates the type of activity that will occur during the cycle. The 8228/38 stores this information in the Status Latch when the STSTB input goes "low". The output of the Status Latch is connected to the Gating Array and is part of the Control Signal generation.

## Gating Array

The Gating Array generates control signals (MEM R, MEM W,
 Latch with signals from the 8080 CPU (DBIN, $\overline{W R}$, and HLDA).

The "read" control signals ( $\overline{\mathrm{MEM} \mathrm{R}}, \overline{\mathrm{I} / \mathrm{OR}}$ and $\overline{\text { INTA }}$ ) are derived from the logical combination of the appropriate Status Bit (or bits) and the DBIN input from the 8080 CPU. The "write" control signals from the 8228 ( $\overline{\mathrm{MEM} W}, \overline{\mathrm{I} / \mathrm{OW}}$ ) are derived from the logical combination of the appropriate Status Bit (or bits) and the $\overline{W R}$ input from the 8080 CPU. The write signals coming from the 8238 are advanced for large system timing control.

All Control Signals are "active low" and directly interface to MCS-80 family RAM, ROM and I/O components.
The $\overline{\text { NTA }}$ control signal is normally used to gate the "interrupt instruction port" onto the bus. It also provides a special feature in the $8228 / 38$. If only one basic vector is needed in the interrupt structure, such as in small systems, the 8228/38 can automatically inserta RST 7 instruction onto the bus at the proper time. To use this option, simply connect the INTA output of the $8228 / 38$ (pin 23) to the +12 volt supply through a series resistor ( 1 K ohms). The voltage is sensed internally by the $8228 / 38$ and logic is "set-up" so that when the DBIN input is active a RST 7 instruction is gated on to the bus when an interrupt is acknowledged. This feature provides a single interrupt vector with no additional components, such as an interrupt instruction port.

When using CALL as an Interrupt instruction the 8228/38 will generate an INTA pulse for each of the three bytes.
The $\overline{B U S E N}$ (Bus Enable) input to the Gating Array is an asynchronous input that forces the data bus output buffers and control signal buffers into their high-impedance state if it is a "one". If BUSEN is a "zero" normal operation of the data buffer and control signals take place.



STATUS WORD CHART


## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias. | $-0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |
| Supply Voltage, $\mathrm{V}_{\mathrm{CC}}$ | -0.5 V to +7 V |
| Input Voltage. | -1.5 V to +7 V |
| Output Current. | . 100 mA |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ.[1] | Max. |  |  |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage, All Inputs |  | . 75 | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$; $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current, $\overline{\text { STSTB }}$ |  |  | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=5.25 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
|  | $\mathrm{D}_{2}$ \& $\mathrm{D}_{6}$ |  |  | 750 | $\mu \mathrm{A}$ |  |
|  | $\begin{aligned} & D_{0}, D_{1}, D_{4}, D_{5} \\ & \& D_{7} \end{aligned}$ |  |  | 250 | $\mu \mathrm{A}$ |  |
|  | All Other Inputs |  |  | 250 | $\mu \mathrm{A}$ |  |
| $I_{R}$ | Input Leakage Current $\overline{\text { STSTB }}$ |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=5.25 \mathrm{~V} \\ & V_{R}=5.25 \mathrm{~V} \end{aligned}$ |
|  | $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ |  |  | 20 | $\mu \mathrm{A}$ |  |
|  | All Other Inputs |  |  | 100 | $\mu \mathrm{A}$ |  |
| $\mathrm{V}_{\text {TH }}$ | Input Threshold Voltage, All Inputs | 0.8 |  | 2.0 | V | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| ${ }^{\text {l CC }}$ | Power Supply Current |  | 140 | 190 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage, $D_{0}-D_{7}$ |  |  | . 45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$; $\mathrm{IOL}=2 \mathrm{~mA}$ |
|  | All Other Outputs |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage, $D_{0}-D_{7}$ | 3.6 | 3.8 |  | V | $V_{\mathrm{CC}}=4.75 \mathrm{~V}$; $\mathrm{lOH}=-10 \mu \mathrm{~A}$ |
|  | All Other Outputs | 2.4 |  |  | V | $\mathrm{l}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| los | Short Circuit Current, All Outputs | 15 |  | 90 | mA | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| IO(off) | Off State Output Current, All Control Outputs |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=5.25$ |
|  |  |  |  | -100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ |
| IINT | INTA Current |  |  | 5 | mA | (See Figure below) |

[^2]
## WAVEFORMS



VOLTAGE MEASUREMENT POINTS: $D_{0}-D_{7}$ (when outputs) Logic " 0 " $=0.8 \mathrm{~V}$, Logic " 1 " $=3.0 \mathrm{~V}$. All other signals measured at 1.5 V .
*ADVANCED $\overline{I O W} / \overline{M E M W}$ FOR 8238 ONLY.
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$.

| Symbol | Parameter | Limits |  | Units | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $t_{\text {PW }}$ | Width of Status Strobe | 22 |  | ns |  |
| $\mathrm{t}_{\text {SS }}$ | Setup Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 8 |  | ns |  |
| ${ }_{\text {tSH }}$ | Hold Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 5 |  | ns |  |
| ${ }^{\text {t }}$ D | Delay from STSTB to any Control Signal | 20 | 60 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RR}}$ | Delay from DBIN to Control Outputs |  | 30 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $t_{\text {RE }}$ | Delay from DBIN to Enable/Disable 8080 Bus |  | 45 | ns | $C_{L}=25 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RD}}$ | Delay from System Bus to 8080 Bus during Read |  | 30 | ns | $C_{L}=25 \mathrm{pF}$ |
| twr | Delay from $\overline{\mathrm{WR}}$ to Control Outputs | 5 | 45 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| ${ }^{\text {t WE }}$ | Delay to Enable System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ after STSTB |  | 30 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| two | Delay from 8080 Bus $D_{0}-D_{7}$ to System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ during Write | 5 | 40 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{E}}$ | Delay from System Bus Enable to System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ |  | 30 | ns | $C_{L}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{HD}}$ | HLDA to Read Status Outputs |  | 25 | ns |  |
| $t_{\text {DS }}$ | Setup Time, System Bus Inputs to HLDA | 10 |  | ns |  |
| ${ }^{\text {t }}$ H | Hold Time, System Bus Inputs to HLDA | 20 |  | ns | $C_{L}=100 \mathrm{pF}$ |

## CAPACITANCE

This parameter is periodically sampled and not $100 \%$ tested.

| Symbol | Parameter | Limits |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  | Min. | Typ.[1] | Max. | Unit |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 8 | 12 | pF |
| COUT | Output Capacitance <br> Control Signals |  | 7 | 15 | pF |
| I/O | I/O Capacitance <br> (D or DB) |  | 8 | 15 | pF |

TEST CONDITIONS: $V_{B I A S}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$.

Note 2: For $D_{0}-D_{7}: R_{1}=4 K \Omega, R_{2}=\infty \Omega$,
$C_{L}=25 p F$. For all other outputs:
$R_{1}=500 \Omega, R_{2}=1 \mathrm{~K} \Omega, C_{L}=100 \mathrm{pF}$.


INTA Test Circuit (for RST 7)


# SYSTEM CONTROLLER AND BUS DRIVER FOR M8080A CPU 

## - Single Chip System Control for MCS-80 Systems

- Built-in Bi-Directional Bus Driver for Data Bus Isolation
- Allows the use of Multiple Byte Instructions (e.g. CALL) for Interrupt Acknowledge
- M8238 has Advanced IOW/ MEMW for Large System Timing Control

■ User Selected Single Level Interrupt Vector (RST 7)

- 28 Pin Dual In-Line Package
- Reduces System Package Count

■ Full Military Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

- $\pm 10 \%$ Power Supply Tolerance

The M8228 is a single chip system controller and bus driver for MCS-80. It generates all signals required to directly interface MCS-80 family RAM, ROM, and I/O components.
A bi-directional bus driver is included to provide high system TTL fan-out. It also provides isolation of the 8080 data bus from memory and I/O. This allows for the optimization of control signals, enabling the systems designer to use slower memory and I/O. The isolation of the bus driver also provides for enhanced system noise immunity.
A user selected single level interrupt vector (RST 7) is provided to simplify real time, interrupt driven, small system requirements. The M8228 also generates the correct control signals to allow the use of multiple byte instructions (e.g., CALL) in response to an INTERRUPT ACKNOWLEDGE by the M8080A. This feature permits large, interrupt driven systems to have an unlimited number of interrupt levels.

The M8228 is designed to support a wide variety of system bus structures and also reduce system package count for cost effective, reliable, design of the MCS-80 systems.


PIN NAMES

| D7.D0 | DATA BUS ( 8080 SIDE) | INTA | INTERRUPT ACKNOWLEDGE |
| :---: | :---: | :---: | :---: |
| DB7-DB0 | DATA BUS (SYSTEM SIDE) | HLDA | HLDA (FROM 8080) |
| I/OR | I/O READ | WR | WR (FROM 8080) |
| I/OW | I/O WRITE | BUSEN | BUS ENAPLE INPUT |
| MEMR | MEMORY READ | STSTB | STATUS STROBE (FROM 8224) |
| MEMW | MEMORY WRITE | Vcc | $+5 \mathrm{~V}$ |
| DBIN | DBIN (FROM 8080) | GND | 0 VOLTS |

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | $125^{\circ}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ |
| Supply Voltage, $\mathrm{V}_{\text {CC }}$ | -0.5 V to +7 V |
| Input Voltage | -1.0 V to +7 V |
| Output Current | 100 mA |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS $T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$.

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage, All Inputs |  | -1.2 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current, $\overline{\text { STSTB }}$ |  | 500 | $\mu \mathrm{A}$ | $V_{F}=0.4 \mathrm{~V}$ |
|  | $\mathrm{D}_{2}, \mathrm{D}_{6}$ |  | 750 | $\mu \mathrm{A}$ |  |
|  | $\mathrm{D}_{0}, \mathrm{D}_{1}, \mathrm{D}_{4}, \mathrm{D}_{5}, \mathrm{D}_{7}$ |  | 250 | $\mu \mathrm{A}$ |  |
|  | All Other Inputs |  | 250 | $\mu \mathrm{A}$ |  |
| $I_{R}$ | Input Leakage Current $\mathrm{DB}_{0}-\mathrm{D}_{7}$ |  | 20 | $\mu \mathrm{A}$ | $V_{R}=5.5 \mathrm{~V}$ |
|  | All Other Inputs |  | 100 | $\mu \mathrm{A}$ |  |
| $\mathrm{V}_{\text {TH }}$ | Input Threshold Voltage, All Inputs | 0.8 | 2.0 | V | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 210 | mA |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage, $D_{0}-D_{7}$ |  | . 5 | V | $\mathrm{IOL}^{\text {O }}=2 \mathrm{~mA}$ |
|  | All Other Outputs |  | . 5 | V | $\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage, $D_{0}-D_{7}$ | 3.3 |  | V | $\mathrm{IOH}^{\text {O }}=-10 \mu \mathrm{~A}$ |
|  | All Other Outputs | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| los | Short Circuit Current, All Outputs | 15 | 90 | mA | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| lo (Off) | Off State Output Current, All Controls Outputs |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ |
|  |  |  | -100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ |
| IINT | $\overline{\text { INTA }}$ Current |  | 5 | mA | (See Figure on page 3) |

Note 1: Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.

CAPACITANCE This parameter is periodically sampled and not $100 \%$ tested.

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 8 | 12 | pF |
| Cout | Output Capacitance Control Signals |  | 7 | 15 | pF |
| I/O | I/O Capacitance (D or DB) |  | 8 | 15 | pF |

TEST CONDITIONS: $\mathrm{V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$.

Note 2: For $D_{0}-D_{7}: R_{1}=4 K \Omega, R_{2}=\infty \Omega$, $C_{L}=25 p F$. For all other outputs: $R_{1}=500 \Omega, R_{2}=1 \mathrm{~K} \Omega, C_{L}=100 \mathrm{pF}$.



INTA Test Circuit (for RST 7)
A.C. CHARACTERISTICS $T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$.

| Symbol | Parameter | Limits |  | Units | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tpW | Width of Status Strobe | 25 |  | ns |  |
| ${ }_{\text {tss }}$ | Setup Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 8 |  | ns |  |
| ${ }_{\text {t }}^{\text {S }}$ | Hold Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 5 |  | ns |  |
| ${ }^{\text {t }}$ D | Delay from STSTB to any Control Signal | 20 | 75 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RR}}$ | Delay from DBIN to Control Outputs |  | 30 | ns | $C_{L}=100 \mathrm{pF}$ |
| $t_{\text {RE }}$ | Delay from DBIN to Enable/Disable 8080 Bus |  | 45 | ns | $\mathrm{C}_{\mathrm{L}}=25 \mathrm{pF}$ |
| $t_{\text {RD }}$ | Delay from System Bus to 8080 Bus during Read |  | 45 | ns | $\mathrm{C}_{\mathrm{L}}=25 \mathrm{pF}$ |
| twr | Delay from $\overline{W R}$ to Control Outputs | 5 | 60 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| twe | Delay to Enable System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ after $\overline{\text { STSTB }}$ |  | 30 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| ${ }^{\text {tw }}$ | Delay from 8080 Bus $D_{0}-D_{7}$ to System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ during Write | 5 | 40 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| ${ }^{\text {t }}$ E | Delay from System Bus Enable to System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ |  | 30 | ns | $C_{L}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{HD}}$ | HLDA to Read Status Outputs |  | 25 | ns | $C_{L}=100 \mathrm{pF}$ |
| $t_{\text {DS }}$ | Setup Time, System Bus Inputs to HLDA | 10 |  | ns |  |
| ${ }^{\text {t }} \mathrm{H}$ | Hold Time, System Bus Inputs to HLDA | 20 |  | ns |  |

## WAVEFORMS



VOLTAGE MEASUREMENT POINTS: $\mathrm{D}_{0}-\mathrm{D}_{7}$ (when outputs) Logic " 0 " $=0.8 \mathrm{~V}$, Logic " 1 " $=3.0 \mathrm{~V}$. All other signals measured at 1.5 V .
*Advanced $\overline{\mathrm{IOW}} / \overline{\mathrm{MEMW}}$ for M8238 only.


## M8080A CPU Interface



Status Word Chart

8085

## SINGLE CHIP 8-BIT N-CHANNEL MICROPROCESSOR

■ Single +5V Power Supply
■ 100\% Software Compatible with 8080A

- $1.3 \mu$ s Instruction Cycle
- On-Chip Clock Generator (with External Crystal or RC Network)
■ On-Chip System Controller
- Four Vectored Interrupts (One is non-
Maskable) Maskable)
- Serial In/Serial Out Port
- Decimal, Binary and Double Precision Arithmetic
- Direct Addressing Capability to 64K Bytes of Memory

The Intel ${ }^{\circledR 8} 8085$ is a new generation, complete 8 bit parallel central processing unit (CPU). Its instruction set is $100 \%$ software compatible with the 8080A microprocessor, and it is designed to improve the present 8080's performance by higher system speed. Its high level of system integration allows a minimum system of three IC's: 8085 (CPU), 8156 (RAM) and 8355/8755 (ROM/PROM).
The 8085 incorporates all of the features that the 8224 (clock generator) and 8228 (system controller) provided for the 8080 , thereby offering a high level of system integration.
The 8085 uses a multiplexed Data Bus. The address is split between the 8 bit address bus and the 8 bit data bus. The onchip address latches of $8155 / 8355 / 8755$ memory products allows a direct interface with 8085.

8085 CPU FUNCTIONAL
BLOCK DIAGRAM


## 8085 FUNCTIONAL PIN DEFINITION

The following describes the function of each pin:

## A $_{8}-\mathbf{A}_{15}$ (Output 3-State)

Address Bus; The most significant 8-bits of the memory address or the 8 -bits of the I/O address, 3 -stated during Hold and Halt modes.

## $\mathrm{AD}_{0-7}$ (Input/Output 3-state)

Multiplexed Address/Data Bus; Lower 8-bits of the memory address (or I/O address) appear on the bus during the first clock cycle of a machine state. It then becomes the data bus during the second and third clock cycles.

3-stated during Hold and Halt modes.

## ALE (Output 3-state)

Address Latch Enable: It occurs during the first clock cycle of a machine state and enables the address to get latched into the on-chip latch of peripherals. The falling edge of ALE is set to guarantee setup and hold times for the address information. ALE can also be used to strobe the status information. 3stated during Hold and Halt modes.

## So, S1 (Output)

Data Bus Status. Encoded status of the bus cycle:

$$
\begin{array}{lll}
\frac{\mathbf{S}_{\mathbf{1}}}{0} & \frac{\mathbf{S}_{\mathbf{0}}}{0} & \\
\cline { 1 - 1 } & \text { HALT } \\
0 & & 1 \\
1 & & \text { WRITE } \\
1 & & \text { READ } \\
\text { FETCH }
\end{array}
$$

$S_{1}$ can be used as an advanced $R / \bar{W}$ status.

## $\overline{\mathrm{RD}}$ (Output 3-state)

READ; indicates the selected memory or I/O device is to be read and that the Data Bus is available for the data transfer. Tri-stated during Hold and Halt.

## $\overline{W R}$ (Output 3-state)

WRITE; indicates the data on the Data Bus is to be written into the selected memory or I/O location. Data is set up at the trailing edge of $\overline{W R}$. Tri-stated during Hold and Halt modes.

## READY (Input)

If Ready is high during a read or write cycle, it indicates that the memory or peripheral is ready to send or receive data. If Ready is low, the CPU will wait for Ready to go high before completing the read or write cycle.

## HOLD (Input)

HOLD; indicates that another Master is requesting the use of the Address and Data Buses. The CPU, upon receiving the Hold request, will relinquish the use of buses as soon as the completion of the current machine cycle. Internal processing can continue. The processor can regain the buses only after the Hold is removed. When the Hold is acknowledged, the Address, Data, $\overline{R D}, \overline{W R}, 10 / \bar{M}$, and ALE lines are tri-stated.

## HLDA (Output)

HOLD ACKNOWLEDGE; indicates that the CPU has received the Hold request and that it will relinquish the


Figure 1. 8085 PINOUT DIAGRAM
buses in the next clock cycle. HLDA goes low after the Hold request is removed. The CPU takes the buses one half clock cycle after HLDA goes low.

## INTR (Input)

INTERRUPT REQUEST; is used as a general purpose interrupt. It is sampled only during the last clock cycle of the instruction. If it is active, the Program Counter (PC) will be inhibited from incrementing and an INTA will be issued. During this cycle a RESTART or CALL instruction can be inserted to jump to the interrupt service routine. The INTR is enabled and disabled by software. it is disabled by Reset and immediately after an interrupt is accepted.

## INTA (Output)

INTERRUPT ACKNOWLEDGE; is used instead of (and has the same timing as) $\overline{\mathrm{RD}}$ during the Instruction cycle after an INTR is accepted. It can be used to activate the 8259 Interrupt chip or some other interrupt port.

RST 5.5
$\begin{aligned} & \text { RST } 6.5 \\ & \text { RST } 7.5\end{aligned} \quad-$ (Inputs)
RESTART INTERRUPTS; These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted.

```
RST 7.5 -> Highest Priority
RST }6.
RST 5.5 -> Lowest Priority
```

7 he priority of these interrupts is ordered as shown above. Tinese interrupts have a higher priority than the INTR.

## TRAP (Input)

Trap interrupt is a nonmaskable restart interrupt. It is recognized at the same time as INTR. It is unaffected by any mask or Interrupt Enable. It has the highest priority of any interrupt.

## $\overline{\text { RESET IN }}$ (Input)

Reset sets the Program Counter to zero and resets the Interrupt Enable and HLDA flip-flops. None of the other flags or registers (except the instruction register) are affected. The CPU is held in the reset condition as long as Reset is applied.

## RESET OUT (Output)

Indicates CPU is being reset. Can be used as a system RESET. The signal is synchronized to the processor clock.

## $X_{1}, X_{2}$ (Input)

Crystal or R/C network connections to set the internal clock generator. X1 can also be an external clock input instead of a crystal.

## CLK (Output)

Clock Output for use as a system clock when a crystal or R/C network is used as an input to the CPU.

## 10/M (Output)

IO/ $\bar{M}$ indicates whether the Read/Write is to memory or I/O. Tri-stated during Hold and Halt modes.

## SID (Input)

Serial input data line. The data on this line is loaded into accumulator bit 7 whenever a RIM instruction is executed.

## SOD (output)

Serial output data line. The output SOD is set or reset as specified by the SIM instruction.

## $V_{\text {cc }}$

+5 volt supply.
$\mathbf{v}_{\mathbf{S S}}$
Ground Reference.

## FUNCTIONAL DESCRIPTION

The 8085 is a complete 8 bit parallel central processor. It is designed with N -channel depletion loads and requires a single +5 volt supply. Its basic clock speed is 3 MHz thus improving on the present 8080's performance with higher system speed. Also it is designed to fit into a minimum system of three IC's: The CPU, a RAM/IO, and a ROM or PROM/IO chip.
The 8085 uses a multiplexed Data Bus. The address is split between the higher 8-bit Address Bus and the lower 8-bit Address/Data Bus. During the first cycle the address is sent out. The lower 8 -bits are latched into the peripherals by the Address Latch Enable (ALE). During the rest of the machine cycle the Data Bus is used for memory or I/O data.

The 8085 provides $\overline{R D}, \overline{W R}$, and $10 / \overline{\text { Memory }}$ signals for bus control. An Interrupt Acknowledge signal (INTA) is also provided. Hold, Ready, and all Interrupts are synchronized. The 8085 also provides serial input data (SID) and serial output data (SOD) lines for simple serial interface.
In addition to these features, the 8085 has three maskable, restart interrupts and one nonmaskable trap interrupt.

## 8085 vs. 8080

The 8085 includes the following features on-chip in addition to all of the 8080 functions.
a. Internal clock generator
b. Clock output
c. Fully synchronized Ready
d. Schmitt action on RESET IN
e. RESET OUT pin
f. $\overline{R D}, \overline{W R}$, and $I O / \bar{M}$ Bus Control Signals
g. Encoded Status information
h. Multiplexed Address and Data
i. Direct Restarts and nonmaskable Interrupt
j. Serial Input/Output lines.

The internal clock generator requires an external crystal or R-C network. It will oscillate at twice the basic CPU operating frequency. A $50 \%$ duty cycle, two phase, nonoverlapping clock is generated from this oscillator internally and one phase of the clock ( $\phi 2$ ) is available as an external clock. The 8085 directly provides the external RDY synchronization previously provided by the 8224. The RESET IN input is provided with a Schmitt action input so that power-on reset only requires a resistor and capacitor. RESET OUT is provided for System RESET.
The 8085 provides $\overline{R D}, \overline{W R}$ and $10 / \bar{M}$ signals for Bus control. An INTA which was previously provided by the 8228 in 8080 system is also included in 8085.

## STATUS INFORMATION

Status information is directly available from the 8085. ALE serves as a status strobe. The status is partially encoded, and provides the user with advanced timing of the type of bus transfer being done. $10 / \bar{M}$ cycle status signal is provided directly also. Decoded $S_{0}, S_{1}$ carries the following status information:

|  | $\mathbf{S}_{\mathbf{1}}$ | $\mathbf{S}_{\mathbf{0}}$ |
| :--- | :---: | :---: |
|  | 0 | 0 |
| HALT | 0 | 1 |
| WRITE | 1 | 0 |
| READ | 1 | 1 |

S1 can be interpreted as $R / \bar{W}$ in all bus transfers.
In the 8085 the 8 LSB of address are multiplexed with the data instead of status. The ALE line is used as a strobe to enter the lower half of the address into the memory or peripheral address latch. This also frees extra pins for expanded interrupt capability.

## INTERRUPT AND SERIAL I/O

The 8085 has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP. INTR is identical in function to the 8080 INT. Each of three RESTART inputs, $5.5,6.5,7.5$, has a programmable mask. TRAP is also a RESTART interrupt except it is non-maskable.
The three RESTART interrupts cause the internal execution of RST (saving the program counter in the stack and branching to the RESTART address) if the interrupts are enabled and if the interrupt mask is not set. The nonmaskable TRAP causes the internal execution of a RST independent of the state of the interrupt enable or masks.

| Name | RESTART Addre |
| :---: | :---: |
| TRAP | $24_{16}$ |
| RST 5.5 | $2 C_{16}$ |
| RST 6.5 | $34_{16}$ |
| RST 7.5 | $3 C_{16}$ |

There are two different types of inputs in the restart interrupts. RST 5.5 and RST 6.5 are high level-sensitive like INTR (and INT on the 8080) and are recognized with the same timing as INTR. RST 7.5 is rising edge-sensitive.

For RST 7.5, only a pulse is required to set an internal flip flop which generates the internal interrupt request. The RST 7.5 request flip flop remains set until the request is serviced. Then it is reset automatically. This flip flop may also be reset by using the SIM instruction or by issuing a RESET IN to the 8085. The RST 7.5 internal flip flop will be set by a pulse on the RST 7.5 pin even when the RST 7.5 interrupt is masked out.
The status of the three RST interrupt masks can only be affected by the SIM instruction and RESET IN.

The interrupts are arranged in a fixed priority that determines which interrupt is to be recognized if more than one is pending as follows: TRAP - highest priority, RST 7.5, RST 6.5, RST 5.5, INTR - lowest priority. This priority scheme does not take into account the priority of a routine that was started by a higher priority interrupt. RST 5.5 can interrupt a RST 7.5 routine if the interrupts were reenabled before the end of the RST 7.5 routine.

The TRAP interrupt is useful for catastrophic errors such as power failure or bus error. The TRAP input is recognized just as any other interrupt but has the highest priority. It is not affected by any flag or mask. The TRAP input is both edge and level sensitive. The TRAP input must go high and


FIGURE 2. 8085 BASIC SYSTEM TIMING.
remain high to be acknowledged, but will not be recognized again until it goes low, then high again. This avoids any false triggering due to noise or logic glitches.
The following diagram illustrates the TRAP interrupt request circuitry within the 8085.


Note that the servicing of any interrupt (TRAP, RST 7.5, RST 6.5, RST 5.5, INTR) disables all future interrupts (except TRAPs) until an El instruction is executed.
Since a TRAP interrupt can occur and disable the other interrupts whether they were previously enabled or not, it is not possible to restore the previous interrupt enable status following a TRAP.
The serial I/O system is also controlled by the RIM and SIM instructions. SID is read by RIM, and SIM sets the SOD data.

## BASIC SYSTEM TIMING

The 8085 has a multiplexed Data Bus. ALE is used as a strobe to sample the lower 8-bits of address on the Data Bus. Figure 2 shows an instruction fetch, memory read and I/O write cycle (OUT). Note that during the I/O write and read cycle that the I/O port address is copied on both the upper and lower half of the address.
As in the 8080, the READY line is used to extend the read and write pulse lengths so that the 8085 can be used with slow memory. Hold causes the CPU to relinguish the bus when it is through with it by floating the Address and Data Buses.

## SYSTEM INTERFACE

8085 family includes memory components, which are directly compatible to the 8085 CPU. For example, a system consisting of the three chips, 8085,8156 , and 8355 will have the following features:

- 2K Bytes ROM
- 256 Bytes RAM
- 1 Timer/Counter
- 4 8-bit I/O Ports
- 16 -bit I/O Port
- 4 Interrupt Levels
- Serial In/Serial Out Ports

This minimum system, using the standard I/O technique is as shown in Figure 3.

In addition to standard I/O, the memory mapped I/O offers an efficient I/O addressing technique. With this technique, an area of memory address space is assigned for $1 / \odot$ address, thereby, using the memory address for I/O manipulation. Figure 4 shows the system configuration of Memory Mapped I/O using 8085.
The 8085 CPU can also interface with the standard memory that does not have the multiplexed address/data bus. It will require a simple 8212 (8-bit latch) as shown in Figure 5.


FIGURE 3. 8085 MINIMUM SYSTEM (STANDARD I/O TECHNIQUE)


FIGURE 4. MCS-85™ MINIMUM SYSTEM (MEMORY MAPPED I/O)


FIGURE 5. MCS-85 ${ }^{\text {™ }}$ SYSTEM (USING STANDARD MEMORIES)

## DRIVING THE $X_{1}$ AND $X_{2}$ INPUTS

The user may drive the $X_{1}$ and $X_{2}$ inputs of the 8085 with a crystal, an external clock source or an RC network as shown below:

1.6 MHz INPUT FREQUENCY

$\approx 3 \mathrm{MHz}$
INPUT FREQUENCY
RC Mode causes a large drift in clock frequency because of the variation in on-chip timing generation parameters. Use of RC Mode should be limited to an application, which can tolerate a wide frequency variation.

1.6 MHz INPUT FREQUENCY
(DUTY CYCLE AT 6MHz: 25 ~ 50\%) *WITH AN EXTERNAL CLOCK SOURCE $X_{2}$ SHOULD BE LEFT FLOATING.

$\sim 6 \mathrm{MHz}$
INPUT FREQUENCY
This circuit may be used when the clock input has $>50 \%$ duty cycle at 6 MHz .

FIGURE 6. DRIVING THE CLOCK INPUTS (X1 AND X2) OF 8085

## GENERATING 8085 WAIT STATE

The following circuit may be used to insert one WAIT state in each 8085 machine cycle.

The D flip flops should be chosen such that

- CLK is rising edge triggered
- CLEAR is low-level active.



## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin
With Respect to Ground . . . . . . . . . . . . -0.3 to +7V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . 1.5 Watt
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operat tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$; unless otherwise specified)

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 170 | mA |  |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {in }}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {out }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{ILR}}$ | Input Low Level, RESET | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IHR}}$ | Input High Level, RESET | 2.4 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{HY}}$ | Hysteresis, RESET | 0.25 |  | V |  |

Bus Timing Specification as a $\mathrm{T}_{\mathrm{CY}}$ Dependent

| $\mathrm{t}_{\mathrm{AL}}$ | - | (1/2) T-50 | MIN |
| :---: | :---: | :---: | :---: |
| ${ }_{\text {L }}$ L | - | (1/2) T-60 | MIN |
| $t_{\text {LL }}$ | - | (1/2) T-40 | MIN |
| $\mathrm{t}_{\text {LCK }}$ | - | (1/2) T-60 | MIN |
| $\mathrm{t}_{\mathrm{LC}}$ | - | (1/2) T-30 | MIN |
| ${ }^{\text {t }}$ AD | - | (5/2+N) T-225 | MAX |
| ${ }^{\text {R }}$ RD | - | (3/2 + N ) T-200 | MAX |
| $t_{\text {RAE }}$ | - | (1/2) T-60 | MIN |
| ${ }^{\text {cha }}$ | - | (1/2) T-40 | MIN |
| ${ }_{\text {b }}$ W | - | $(3 / 2+N) T-60$ | MIN |
| ${ }_{\text {t }}$ D | - | (1/2) T - 80 | MIN |
| ${ }^{\text {t }} \mathrm{C}$ | - | $(3 / 2+N) T-80$ | MIN |
| ${ }^{\text {t }}$ CL | - | (1/2) T-110 | MIN |
| $\mathrm{t}_{\text {ARY }}$ | - | (3/2) T-260 | MAX |
| ${ }^{\text {H }}$ HACK | - | (1/2) T-50 | MIN |
| $\mathrm{t}_{\text {HABF }}$ | - | $(1 / 2) T+30$ | MAX |
| $\mathrm{t}_{\text {HABE }}$ | - | (1/2) T+30 | MAX |
| ${ }^{\text {t }}$ AC | - | (2/2) T-50 | MIN |
| $\mathrm{t}_{1}$ | - | (1/2) T-80 | MIN |
| $\mathrm{t}_{2}$ | - | (1/2) T-40 | MIN |
| $\mathrm{t}_{\mathrm{RV}}$ | - | (3/2) T - 80 | MIN |
| ${ }^{\text {I INS }}$ | - | $(1 / 2) T+200$ | MIN |

NOTE: $\quad \mathrm{N}$ is equal to the total WAIT states.
$T=t_{C Y C}$.
A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions ${ }_{\text {cosem }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{CYC}}$ | CLK Cycle Period | 320 | 2000 | ns |  |
| ${ }^{\text {t }} 1$ | CLK Low Time | 80 |  | ns |  |
| $\mathrm{t}_{2}$ | CLK High Time | 120 |  | ns |  |
| $t_{r}, t_{f}$ | CLK Rise and Fall Time |  | 30 | ns |  |
| $\mathrm{t}_{\mathrm{AL}}$ | Address Valid Before Trailing Edge of ALE | 110 |  | ns |  |
| $t_{\text {LA }}$ | Address Hold Time After ALE | 100 |  | ns |  |
| $\mathrm{t}_{\text {LL }}$ | ALE Width | 120 |  | ns |  |
| $\mathrm{t}_{\text {LCK }}$ | ALE Low During CLK High | 100 |  | ns |  |
| ${ }^{\text {L }}$ LC | Trailing Edge of ALE to Leading Edge of Control | 130 |  | ns |  |
| ${ }^{\text {t AFR }}$ | Address Float After Leading Edge of $\overline{\text { READ }}$ (INTA) |  | 0 | ns |  |
| $t_{\text {AD }}$ | Valid Address to Valid Data In |  | 575 | ns |  |
| $t_{\text {RD }}$ | $\overline{\text { READ }}$ (or INTA) to Valid Data |  | 280 | ns |  |
| $\mathrm{t}_{\text {RDH }}$ | Data Hold Time After $\overline{\text { READ }}$ (INTA) | 0 |  | ns |  |
| $t_{\text {RAE }}$ | Trailing Edge of $\overline{R E A D}$ to Re-Enabling of Address | 120 |  | ns |  |
| ${ }^{\text {t }}$ CA | Address (A8-A15) Valid After Control | 120 |  | ns | $C_{L}=150 \mathrm{pF}$ |
| ${ }^{\text {D }}$ DW | Data Valid to Trailing Edge of WRITE | 420 |  | ns |  |
| ${ }_{\text {twD }}$ | Data Valid After Trailing Edge of WRITE | 80 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CC}$ | Width of Control Low ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { INTA }}$ ) | 400 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CL}$ | Trailing Edge of Control to Leading Edge of ALE | 50 |  | ns |  |
| $t_{\text {AR }}$ | READY Valid From Address Valid |  | 220 | ns |  |
| $t_{\text {RYS }}$ | READY Setup Time to Leading Edge of CLK | 110 |  | ns |  |
| $t_{\text {RYH }}$ | READY Hold Time | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{HACK}}$ | HLDA Valid to Trailing Edge of CLK | 110 |  | ns |  |
| $\mathrm{t}_{\text {HABF }}$ | Bus Float After HLDA |  | 190 | ns |  |
| ${ }^{\text {t }} \mathrm{RV}$ | Control Trailing Edge to Leading Edge of Next Control | 400 |  | ns |  |
| ${ }^{\text {A }}$ A | Address Valid to Leading Edge of Control | 270 |  | ns |  |
| $\mathrm{t}_{\mathrm{HDS}}$ | HOLD Setup Time to Trailing Edge of CLK | 170 |  | ns |  |
| $\mathrm{t}_{\mathrm{HDH}}$ | HOLD Hold Time | 0 |  | ns |  |
| ${ }^{\text {tins }}$ | INTR Setup Time to Leading Edge of CLK (M1, T1 only). Also RST and TRAP | 360 |  | ns |  |
| $\mathrm{t}_{\text {INH }}$ | INTR Hold Time | 0 |  | ns |  |

NOTES: 1. A8-15 Address Specs apply to $1 O / \bar{M}, S 0$ and S1.
2. For all output timing where $C_{L} \neq 150 \mathrm{pf}$ use the following correction factors:

25pf $\leqslant C_{L}<150$ pf : $-10 \mathrm{~ns} / \mathrm{pf}$
150pf $<C_{L} \leqslant 300$ pf : $+.30 \mathrm{~ns} / \mathrm{pf}$
3. Output timings are measured with purely capacitive load.
4. All timings are measured at output voltage $\mathrm{V}_{\mathrm{L}}=.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}=2.0 \mathrm{~V}$, and 1.5 V with 20 ns rise and fall time on inputs,
5. To calculate timing specifications at other values of TCYC use the table in Table 2.
6. L.E. = Leading Edge T.E. $=$ Trailing Edge


FIGURE 8. CLOCK TIMING WAVEFORM

## READ OPERATION



WRITE OPERATION



FIGURE 10. 8085 HOLD TIMING


FIGURE 11. 8085 INTERRUPT AND HOLD TIMING


EPROMs and ROMs

## EPROMs and ROMs

8708 8192-Bit EPROM ..... 6-57
2716 2048x8 EPROM ..... 6-60
8308 8192-Bit MOS ROM ..... 6-64
8316A 16,384-Bit MOS RAM ..... 6-68
2316E 2048x8 ROM ..... 6-71
PROM and ROM Programming Instructions ..... 6-74

# 8708 <br> 8192 BIT ERASABLE AND ELECTRICALLY REPROGRAMMABLE READ ONLY MEMORY 

## 1024x8 Organization

- Fast Programming -

Typ. 100 sec . For All 8K Bits

- Low Power During Programming
- Access Time-450 ns
- Standard Power Supplies $+12 \mathrm{~V}, \pm 5 \mathrm{~V}$
- Static-No Clocks Required
- Inputs and Outputs TTL Compatible During Both Read and Program Modes
- Three-State Output-OR-Tie Capability

The Intel ${ }^{\circledR} 8708$ is a high speed 8192 bit erasable and electrically reprogrammable ROM (EPROM) ideally suited where fast turn around and pattern experimentation are important requirements.

The 8708 is packaged in a 24 pin dual-in-line package with transparent lid. The transparent lid allows the user to expose the chip to ultraviolet light to erase the bit pattern. A new pattern can then be written into the device.

A pin for pin mask programmed ROM, the Inte $\left.\right|^{\circledR}$ 8308, is available for large volume production runs of systems initially using the 8708.

The 8708 is fabricated with the time proven N -channel silicon gate technology.

## PIN CONFIGURATION



PIN NAMES

[^3]BLOCK DIAGRAM


PIN CONFIGURATION DURING READ OR PROGRAM

| MODE | PIN NUMBER |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 9-11, 13-17 | 12 | 18 | 19 | 20 | 21 | 24 |
| READ | $\mathrm{D}_{\text {OUt }}$ | $\mathrm{v}_{\mathrm{ss}}$ | $\mathrm{v}_{\text {ss }}$ | $\mathrm{V}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\text {BB }}$ | $\mathrm{v}_{\mathrm{cc}}$ |
| Program | $\mathrm{D}_{\text {IN }}$ | $\mathrm{v}_{\mathrm{ss}}$ | Pulsed | $V_{D D}$ | $\mathrm{V}_{\mathrm{HWW}}$ | $v_{B B}$ | $v_{\text {cc }}$ |

## PROGRAMMING

The programming specifications are identical to those of the 2708. (See ROM and PROM Programming Instructions, page 6-74).

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . $-25^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
$\mathrm{V}_{\mathrm{DD}}$ With Respect to $\mathrm{V}_{\mathrm{BB}} \ldots . . . . . . . . . .+20 \mathrm{~V}$ to -0.3 V
$\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{SS}}$ With Respect to $\mathrm{V}_{\mathrm{BB}} \ldots . . .+15 \mathrm{~V}$ to -0.3 V
All Input or Output Voltages With
Respect to $\mathrm{V}_{\mathrm{BB}}$ During Read . . . . . . . . +15 V to -0.3 V
$\overline{\mathrm{CS}} / \mathrm{WE}$ Input With Respect to $\mathrm{V}_{\mathrm{BB}}$
During Programming
+20 V to -0.3 V
Program Input With Respect to $\mathrm{V}_{\mathrm{BB}} \ldots \ldots+35 \mathrm{~V}$ to -03 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . 1.5W
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## READ OPERATION

## D.C. AND OPERATING CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {LI }}$ | Address and Chip Select Input Sink Current |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ or $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IL }}$ |
| ILO | Output Leakage Current |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.25 \mathrm{~V}, \overline{\mathrm{CS}} / \mathrm{WE}=5 \mathrm{~V}$ |
| $\mathrm{IDD}^{[2]}$ | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 50 | 65 | mA | Worst Case Supply Currents: <br> All Inputs High $\overline{\mathrm{CS}} / \mathrm{WE}=5 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| $\mathrm{ICC}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 6 | 10 | mA |  |
| $\mathrm{IBB}^{\text {[2] }}$ | $\mathrm{V}_{\text {BB }}$ Supply Current |  | 30 | 45 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $\mathrm{V}_{\text {SS }}$ |  | 0.65 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 3.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | 3.7 |  |  | V | $\mathrm{IOH}^{\prime}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{P}_{\mathrm{D}}$ | Power Dissipation |  |  | 800 | mW | $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |

NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. The total power dissipation of the 8708 is specified at 800 mW . It is not calculable by summing the various currents (IDD, ICC, and $I_{B B}$ ) multiplied by their respective voltages since current paths exist between the various power supplies and $V_{S S}$. The IDD $I_{C C}$, and $I_{B B}$ currents should be used to determine power supply capacity only.

## TYPICAL D.C. CHARACTERISTICS



## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to Output Delay |  | 280 | 450 | ns |
| $\mathrm{t}_{\overline{\mathrm{CO}}}$ | Chip Select to Output Delay |  | 60 | 120 | ns |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip De-Select to Output Float | 0 |  | 120 | ns |
| $\mathrm{t}_{\mathrm{OH}}$ | Address to Output Hold | 0 |  |  | ns |

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Parameter | Typ. | Max. | Unit | Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 4 | 6 | pF | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 8 | 12 | pF | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ |

Note. This parameter is periodically sampled and not $100 \%$ tested.

## A.C. TEST CONDITIONS

Output Load: 1 TTL gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
Input Rise and Fall Times: $\leqslant 20 n s$
Timing Measurement Reference Levels: 0.8 V and 2.8 V for inputs; 0.8 V and 2.4 V for outputs
Input Pulse Levels: 0.65 V to 3.0 V

## WAVEFORMS



## ERASURE CHARACTERISTICS

The erasure characteristics of the 8708 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000-4000 \AA$ range. Data show that constant exposure to room level flourescent lighting could erase the typical 8708 in approximately 3 years while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 8708 is to be exposed to these types of lighting conditions for extended periods of time, opaque labels are available from Intel which should be placed over the 8708 window to prevent unintentional erasure.

The recommended erasure procedure (see page 3-55) for the 8708 is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity $X$ exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a $12000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ power rating. The 8708 should be placed within one inch from the lamp tubes during erasure. Some lamps have a filter on their tubes and this filter should be removed before erasure.

\author{

- Single +5V Power Supply <br> - Simple Programming Requirements Single Location Programming Programs With One 50ms Pulse <br> - Low Power Dissipation <br> 525mW Max. Active Power <br> 132mW Max. Standby Power
}

The Intel ${ }^{\circledR} 2716$ is a 16,384 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 2716 operates from a single 5 -volt power supply, has a static power down mode, and features fast single address location programming. It makes designing with EPROMs faster, easier and more economical. For production quantities, the 2716 user can convert rapidly to Intel's new pin-for-pin compatible 16K ROM, the 2316E.

Since the 450 -nsec 2716 operates from a single 5 -volt supply, it is ideal for use with the newer high performance +5 V microprocessors such as Intel's 8085 and 8048 . The 2716 is also the first EPROM with a static power down mode which reduces the power dissipation without increasing access time. The maximum active power dissipation is 525 mW while the maximum standby power dissipation is only 132 mW , a $75 \%$ savings.

The 2716 has the simplest and fastest method yet devised for programming EPROMs - single pulse TTL level programming. No need for high voltage pulsing because all programming controls are handled by TTL signals. Now, it is possible to program on-board, in the system, in the field. Program any location at any time - either individually, sequentially or at random, with the 2716's single address location programming. Total programming time for all 16,384 bits is only 100 seconds.

MODE SELECTION
PIN CONFIGURATION

| $A_{7}-1$ | 24 |
| ---: | :--- |
| $A_{6}-V_{C C}$ |  |
| $A_{5}-3$ | 23 |

PIN NAMES

| $A_{0}-\mathrm{A}_{10}$ | ADDRESSES |
| :--- | :--- |
| PD/PGM | POWER DOWN/PROGRAM |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | OUTPUTS |


| PINS <br> MODE | PD/PGM (18) | $\begin{gathered} \overline{\mathrm{CS}} \\ (20) \end{gathered}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{PP}} \\ & (21) \end{aligned}$ | $\begin{aligned} & V_{c c} \\ & (24) \end{aligned}$ | OUTPUTS $(9.11,13.17)$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | +5 | Dout |
| Deselect | Don't Care | $\mathrm{V}_{\mathrm{IH}}$ | +5 | +5 | High Z |
| Power Down | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | +5 | +5 | High Z |
| Program | Pulsed $\mathrm{V}_{\text {IL }}$ to $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{1 \mathrm{H}}$ | $+25$ | +5 | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +25 | +5 | Dout |
| Program Inhibit | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | +25 | +5 | High Z |

BLOCK DIAGRAM

parametric limits are subject specification. Some
PROGRAMMING
The programming specifications are described in the PROM/ROM Programming Instructions on page 6-74.

## Absolute Maximum Ratings*

Temperature Under Bias .$-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
All Input or Output Voltages with
Respect to Ground
+6 V to -0.3 V
Vpp Supply Voltage with Respect to Ground
+28 V to -0.3 V
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## READ OPERATION

## D.C. and Operating Characteristics

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}{ }^{[1,2]}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}{ }^{[2]}=\mathrm{V}_{\mathrm{CC}} \pm 0.6 \mathrm{~V}^{[3]}$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[4]}$ | Max. |  |  |
| $I_{\text {LI }}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.25 \mathrm{~V}$ |
| $\mathrm{IPP} 1{ }^{\text {[2] }}$ | V PP Current |  |  | 5 | mA | $\mathrm{V}_{\mathrm{PP}}=5.85 \mathrm{~V}$ |
| $\mathrm{ICCl}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Standby) |  | 10 | 25 | mA | $\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{\mathrm{IH}}, \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{ICC2}^{\text {[2] }}$ | $\mathrm{V}_{\text {CC }}$ Current (Active) |  | 57 | 100 | mA | $\overline{\mathrm{CS}}=\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{1} \mathrm{~L}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.2 |  | $\mathrm{V}_{\mathrm{CC}^{+1}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |

NOTES: 1. $V_{\text {CC }}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after VPP.
2. VPP may be connected directly to $V_{C C}$ except during programming. The supply current would then be the sum of ICC and IPP1.
3. The tolerance of 0.6 V allows the use of a driver circuit for switching the $V_{\text {PP }}$ supply pin from $\mathrm{V}_{\mathrm{C}}$ in read to 25 V for programming.
4. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
5. This parameter is only sampled and is not $100 \%$ tested.
6. t ACC 2 is referenced to PD/PGM or the addresses, whichever occurs last.

## Typical Characteristics



$$
\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}{ }^{[1]}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}^{[2]}=\mathrm{V}_{\mathrm{CC}} \pm 0.6 \mathrm{~V}^{[3]}
$$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{\text {[4] }}$ | Max. |  |  |
| ${ }^{\text {tacc }} 1$ | Address to Output Delay |  | 250 | 450 | ns | $\mathrm{PD} / \mathrm{PGM}=\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{t}_{\text {ACC2 }}$ | PD/PGM to Output Delay |  | 280 | 450 | ns | $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Select to Output Delay |  |  | 120 | ns | $\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{t}_{\text {PF }}$ | PD/PGM to Output Float | 0 |  | 100 | ns | $\overline{\mathrm{CS}}=\mathrm{V}_{\text {IL }}$ |
| $t_{\text {dF }}$ | Chip Deselect to Output Float | 0 |  | 100 | ns | $\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\text {toh }}$ | Address to Output Hold | 0 |  |  | ns | PD/PGM $=\overline{C S}=V_{\text {IL }}$ |

Capacitance ${ }^{[5]} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Parameter | Typ. | Max. | Unit | Conditions |
| :--- | :--- | ---: | ---: | :---: | :--- |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 4 | 6 | pF | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 8 | 12 | pF | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ |

NOTE: Please refer to page 2 for notes.
WAVEFORMS


## A.C. Test Conditions:

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$ Input Rise and Fall Times: $\leqslant 20 \mathrm{~ns}$ Input Pulse Levels: 0.8 V to 2.2 V
Timing Measurement Reference Level:

| Inputs | 1 V and 2 V |
| :--- | :--- |
| Outputs | 0.8 V and 2 V |

## ERASURE CHARACTERISTICS

The erasure characteristics of the 2716 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000-4000 \AA$ range. Data show that constant exposure to room level fluorescent lighting could erase the typical 2716 in approximately 3 years, while it would take approximatley 1 week to cause erasure when exposed to direct sunlight. If the 2716 is to be exposed to these types of lighting conditions for extended periods of time, opaque labels are available from Intel which should be placed over the 2716 window to prevent unintentional erasure.
The recommended erasure procedure (see page 3-55) for the 2716 is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity $X$ exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a $12000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ power rating. The 2716 should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.

## DEVICE OPERATION

The six modes of operation of the 2716 are listed in Table I. It should be noted that all inputs for the six modes are at TTL levels. The power supplies required are a $+5 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$ and a $\mathrm{V}_{\mathrm{Pp}}$. The $\mathrm{V}_{\mathrm{PP}}$ power supply must be at 25 V during the three programming modes, and must be at 5 V in the other three modes.
table I. mode selection

| PINS <br> MODE | PD/PGM <br> (18) | $\begin{gathered} \overline{\mathrm{CS}} \\ (20) \end{gathered}$ | $\begin{aligned} & V_{P P} \\ & (21) \end{aligned}$ | $\begin{aligned} & V_{c c} \\ & (24) \end{aligned}$ | $\begin{aligned} & \text { OUTPUTS } \\ & (9-11,13-17) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | +5 | Dout |
| Deselect | Don't Care | $\mathrm{V}_{\mathrm{iH}}$ | +5 | +5 | High Z |
| Power Down | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | +5 | +5 | High Z |
| Program | Pulsed $\mathrm{V}_{\text {IL }}$ to to $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +25 | +5 | Dout |
| Program Inhibit | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | High 2 |

## READ MODE

Data is available at the outputs in the read mode. Data is available 450 ns ( $\mathrm{t}_{\mathrm{ACC}}$ ) from stable addresses with $\overline{\mathrm{CS}}$ low or 120 ns ( $\mathrm{t}_{\mathrm{CO}}$ ) from $\overline{\mathrm{CS}}$ with addresses stable.

## DESELECT MODE

The outputs of two or more 2716s may be OR-tied together on the same data bus. Only one 2716 should have its outputs selected ( $\overline{\mathrm{CS}}$ low) to prevent data bus contention between 2716s in this configuration. The outputs of the other 2716s should be deselected with the $\overline{\mathrm{CS}}$ input at a high TTL level.

## POWER DOWN MODE

The 2716 has a power down mode which reduces the active power dissipation by $75 \%$, from 525 mW to 132 mW . Power down is achieved by applying a TTL high signal to the PD/PGM input. In power down the outputs are in a high impedance state, independent of the $\overline{\mathrm{CS}}$ input.

## PROGRAMMING

Initially, and after each erasure, all bits of the 2716 are in the " 1 " state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 ' $s$ " will be programmed, both " 1 ' $s$ " and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The 2716 is in the programming mode when the $V_{\text {PP }}$ power supply is at 25 V and $\overline{\mathrm{CS}}$ is at $\mathrm{V}_{\mathrm{IH}}$. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the addresses and data are stable, a 50 msec , active high, TTL program pulse is applied to the PD/PGM input. A program pulse must be applied at each address location to be programmed. You can program any location at any time - either individually, sequentially, or at random. The program pulse has a maximum width of 55 msec . The 2716 must not be programmed with a DC signal applied to the PD/PGM input.
Programming of multiple 2716s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled 2716s may be connected together when they are programmed with the same data. A high level TTL pulse applied to the PD/PGM input programs the paralleled 2716s.

## PROGRAM INHIBIT

Programming of muitiple 2716s in parallel with different data is also easily accomplished. Except for PD/PGM, all like inputs (including $\overline{\mathrm{CS}}$ ) of the parallel 2716s may be common. A TTL level program pulse applied to a 2716 's PD/PGM input with VPP at 25 V will program that 2716. A low level PD/PGM input inhibits the other 2716s from being programmed.

## PROGRAM VERIFY

A verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed wth $\mathrm{V}_{\mathrm{PP}}$ at 25 V . Except during programming and program verify, V pp must be at 5 V .

8308
8192 BIT STATIC MOS READ ONLY MEMORY

■ Fast Access Time: 450 ns

- Standard Power Supplies: +12V, $\pm 5 \mathrm{~V}$

■ TTL Compatible: All Inputs and Outputs

- Programmable Chip Select Input for Easy Memory Expansion

Three-State Output: OR-Tie Capability<br>■ Fully Decoded: On Chip Address Decode<br>- Inputs Protected: All Inputs Have Protection Against Static Charge<br>■ Pin Compatible to 8708 PROM

The Intel ${ }^{\circledR} 8308$ is a 8192 bit static MOS read only memory organized as 1024 words by 8 -bits. This ROM is designed for memory applications where high performance, large bit storage, and simple interfacing are important design objectives.
The inputs and outputs are TTL compatible. The chip select input (CS2/ $\overline{\operatorname{CS} 2}$ ) is programmable. An active high or low level chip select input can be defined by the designer and the desired chip select logic level is fixed at Intel during the masking process. The programmable chip select input, as well as OR-tie compatibility on the outputs, facilitates easy memory expansion. The pin compatible UV erasable 8708 PROM is available for initial system prototyping.
The 8308 read only memory is fabricated with N -channel silicon gate technology. This technology provides the designer with high performance, easy-to-use MOS circuits.

## PIN CONFIGURATION



BLOCK DIAGRAM

 EITHER A LOGIC $1\left(V_{I H}\right)$ OR LOGIC $0\left(V_{\text {iL }}\right)$. A LOGIC 0 SHOULD BE SPECIFIED IN ORDER TO BE COMPATIBLE WITH THE 8708.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias . . . . . $-25^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage On Any Pin With Respect

To $V_{B B}$. . . . . . . . . . . . . . . . . . . -0.3 V to 20 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . 1.0 Watt

## *COMMENT

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## PROGRAMMING

The programming specifications are described in the PROM/ROM Programming Instructions on page 6-74.

## D.C. AND OPERATING CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ Unless Otherwise Specified.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. |  |  |
| $I_{L I}$ | Input Load Current (All Input Pins Except $\overline{\mathrm{CS}}_{1}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0$ to 5.25 V |
| $\mathrm{I}_{\text {LCL }}$ | Input Load Current on $\overline{\mathrm{CS}}_{1}$ |  |  | -1.6 | mA | $\mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |
| ILPC | Input Peak Load Current on $\overline{\mathrm{CS}}_{1}$ |  |  | -4 | mA | $\mathrm{V}_{\text {IN }}=0.8 \mathrm{~V}$ to 3.3 V |
| ILKC | Input Leakage Current on $\overline{\mathrm{CS}}_{1}$ |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=3.3 \mathrm{~V}$ to 5.25 V |
| ILO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | Chip Deselected |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage | $\mathrm{V}_{\text {SS }}{ }^{-1}$ |  | 0.8 V | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 3.3 |  | $\mathrm{V}_{C C}+1.0$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output "Low" Voltage |  |  | 0.45 | V | $\mathrm{IOL}=2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output "High" Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-4 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output "High" Voltage | 3.7 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| ${ }^{\text {ICC }}$ | Power Supply Current $\mathrm{V}_{\text {CC }}$ |  | 10 | 15 | mA |  |
| $\mathrm{I}_{\mathrm{DD}}$ | Power Supply Current VDD |  | 32 | 60 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}$ | Power Supply Current $\mathrm{V}_{\mathrm{BB}}$ |  | $10 \mu \mathrm{~A}$ | 1 | mA |  |
| $P_{D}$ | Power Dissipation |  | 460 | 840 | mW |  |

NOTE 1: Typical values for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage
D.C. OUTPUT CHARACTERISTICS

D.C. OUTPUT CHARACTERISTICS


## A.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Specified.

| Symbol | Parameter | Limits ${ }^{\text {[2] }}$ |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| ${ }_{\text {t }}^{\text {ACC }}$ | Address to Output Delay Time |  | 200 | 450 | ns |
| ${ }^{\text {c }} \mathrm{CO}_{1}$ | Chip Select 1 to Output Delay Time |  | 85 | 160 | ns |
| $\mathrm{t}_{\mathrm{CO}}^{2}$ | Chip Select 2 to Output Delay Time |  | 125 | 220 | ns |
| $t_{\text {DF }}$ | Chip Deselect to Output Data Float Time |  | 125 | 220 | ns |

NOTE 2: Refer to conditions, of Test for A.C. Characteristics. Add 50 nanoseconds (worst case) to specified values at $\mathrm{V}_{\mathrm{OH}}=3.7 \mathrm{~V} @ \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.

## CONDITIONS OF TEST FOR A.C. CHARACTERISTICS

Output Load $\qquad$ 1 TTL Gate, and $C_{\text {LOAD }}=100 \mathrm{pF}$ Input Pulse Levels . 65 V to 3.3 V Input Pulse Rise and Fall Times . . . . . . . . . . . 20 nsec Timing Measurement Reference Level
$2.4 \mathrm{~V} \mathrm{~V}_{\mathrm{IH}}, \mathrm{V}_{\mathrm{OH}} ; 0.8 \mathrm{~V} \mathrm{~V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{OL}}$

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{BB}}=-5 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}$.
$\mathrm{V}_{\mathrm{CC}}$ and all other pins tied to $\mathrm{V}_{\mathrm{SS}}$.

| Symbol | Test | Limits |  |
| :--- | :---: | ---: | ---: |
|  |  | Typ. | Max. |
| $C_{I N}$ | Input Capacitance |  | 6 pF |
| $C_{\text {OUT }}$ | Output Capacitance |  | 12 pF |



## TYPICAL CHARACTERISTICS (Nominal supply voltages unless otherwise noted.)

IDD VS. TEMPERATURE (NORMALIZED)

$\overline{\mathrm{CS}}_{1}$ INPUT
CHARACTERISTICS

$\triangle$ OUTPUT CAPACITANCE VS. $\triangle$ OUTPUT DELAY


TACC VS. TEMPERATURE (NORMALIZED)


## 8316A

## 16,384 BIT STATIC MOS READ ONLY MEMORY Organization-2048 Words x 8 Bits Access Time-850 ns max

## - Single +5 Volts Power Supply Voltage <br> - Directly TTL Compatible - All Inputs and Outputs <br> - Low Power Dissipation of $31.4 \mu \mathbf{W} /$ Bit Maximum <br> - Three Programmable Chip Select Inputs for Easy Memory Expansion

\author{

- Three-State Output - OR-Tie Capability <br> - Fully Decoded - On Chip Address Decode <br> - Inputs Protected - All Inputs Have Protection Against Static Charge
}

The Intel 8316 A is a 16,384 -bit static MOS read only memory organized as 2048 words by 8 bits. This ROM is designed for microcomputer memory applications where high performance, large bit storage, and simple interfacing are important design objectives.
The inputs and outputs are fully TTL compatible. This device operates with a single +5 V power supply. The three chip select inputs are programmable. Any combination of active high or low level chip select inputs can be defined and the desired chip select code is fixed during the masking process. These three programmable chip select inputs, as well as OR-tie compatibility on the outputs, facilitate easy memory expansion.

The 8316A read only memory is fabricated with $N$-channel silicon gate technology. This technology provides the designer with high performance, easy-to-use MOS circuits. Only a single +5 V power supply is needed and all devices are directly TTL compatible.

## PIN CONFIGURATION



BLOCK DIAGRAM


PIN NAMES

| $A_{0} \cdot A_{10}$ | ADDRESS INPUTS |
| :--- | :--- |
| $O_{1} \cdot O_{8}$ | DATA OUTPUTS |
| $C_{1} \cdot C_{3}$ | PROGRAMMABLE CHIP SELECT INPUTS |

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias
$-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin
With Respect to Ground . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . 1.0W
PROGRAMMING: The programming specifications are in the ROM and PROM Programming Instructions (see page 6-74).
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. AND OPERATING CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ unless otherwise specified

| SYMBOL | PARAMETER | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | TYP. ${ }^{(1)}$ | MAX. |  |  |
| $I_{L I}$ | Input Load Current (All Input Pins) |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| ILOH | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{CS}=2.2 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=4.0 \mathrm{~V}$ |
| I LOL | Output Leakage Current |  |  | -20 | $\mu \mathrm{A}$ | $\mathrm{CS}=2.2 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.45 \mathrm{~V}$ |
| ICC | Power Supply Current |  | 40 | 98 | mA | All inputs 5.25V Data Out Open |
| $V_{\text {IL }}$ | Input "Low" Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output "Low" Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output "High" Voltage | 2.2 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |

(1) Typical values for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.

## TYPICAL D.C. CHARACTERISTICS

VIN LIMITS VS. TEMPERATURE


OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE



OUTPUT SOURCE CURRENT VS. OUTPUT VOLTAGE

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$ unless otherwise specified

| SYMBOL | PARAMETER |  | LIMITS |  |  |
| :---: | :--- | :--- | :---: | :---: | :---: |
|  |  | MIN. | TYP. ${ }^{(1)}$ | MAX. |  |
| $\mathrm{t}_{\mathrm{A}}$ | UNIT |  |  |  |  |
| $\mathrm{t}_{\mathrm{CO}}$ | Address to Output Delay Time |  | 400 | 850 | nS |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip Select to Output Enable Delay Time |  |  | 300 | nS |

## CONDITIONS OF TEST FOR A.C. CHARACTERISTICS

Output Load . . . 1 TTL Gate, and $C_{\text {LOAD }}=100 \mathrm{pF}$ Input Pulse Levels . . . . . . . . . . . . . . . 0.8 to 2.0 V Input Pulse Rise and Fall Times . (10\% to 90\%) 20 nS Timing Measurement Reference Level Input
Output
0.45 V to 2.2 V

## A.C. WAVEFORMS



TYPICAL A.C. CHARACTERISTICS



\author{

- Fast Access Time-450 ns Max. <br> - Single +5V $\pm 10 \%$ Power Supply <br> - Intel MCS 80 and 85 Compatible <br> - Three Programmable Chip Selects for Simple Memory Expansion and System Interface
}

The Intel ${ }^{\circledR}$ 2316E is a 16,384 -bit static, N-channel MOS read only memory (ROM) organized as 2048 words by 8 bits. Its high bit density is ideal for large, non-volatile data storage applications such as program storage. The three-state outputs and TTL input/output levels allow for direct interface with common system bus structures. The 2316E single +5 V power supply and 450 ns access time are both ideal for usage with high performance microcomputers such as the Intel MCS ${ }^{\top M}-80$ and $M_{C S}{ }^{T M}$ - 85 devices.

A cost-effective system development program may be implemented by using the pin compatible Intel 2716 16K UV EPROM for prototyping and the lower cost 2316E ROM for production. The 2716 is fully compatible to the 2316 E in all respects. The three 2316 E programmable chip selects may be defined by the user and are fixed during the masking process. To simplify the conversion from 2716 prototyping to 2316 E production, it is recommended that the 2316 E programmable chip select logic levels be defined the same as that shown in the below data sheet pin configuration. This pin configuration and these chip select logic levels are the same as the 2716.

## PIN CONFIGURATION



PIN NAMES

| $A_{0}-A_{10}$ | ADDRESS INPUTS |
| :--- | :--- |
| $D_{7}-D_{0}$ | DATA OUTPUTS |
| $C_{1}-\mathrm{CS}_{3}$ | CHIP SELECT INPUTS |

BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias. . . . . . . $-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage On Any Pin With Respect
to Ground
-0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . 1.0 Watt
${ }^{*} C O M M E N T$ : Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, unless otherwise specified.

| SYMBOL | PARAMETER | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | TYP. ${ }^{(1)}$ | MAX. |  |  |
| $I_{\text {LI }}$ | Input Load Current (All Input Pins) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\mathrm{I}_{\text {LOH }}$ | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | Chip Deselected, $\mathrm{V}_{\text {Out }}=4.0 \mathrm{~V}$ |
| $\mathrm{I}_{\text {LOL }}$ | Output Leakage Current |  |  | -20 | $\mu \mathrm{A}$ | Chip Deselected, $\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 70 | 120 | mA | All Inputs 5.25V Data Out Open |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{CC}}+1.0 \mathrm{~V}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output "Low" Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output "High" Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |

NOTE: 1. Typical values for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.

## A.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise specified.

| SYMBOL | LIMITS | UNIT |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. |  |
| $\mathrm{t}_{\mathrm{A}}$ | Address to Output Delay Time |  | 450 | ns |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Select to Output Enable Delay Time |  | 120 | ns |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip Deselect to Output Data Float Delay Time | 10 | 100 | ns |

## CONDITIONS OF TEST FOR

## A.C. CHARACTERISTICS

Output Load . . . . . . . . . 1 TTL Gate and $C_{L}=100 \mathrm{pF}$
Input Pulse Levels . . . . . . . . . . . . . . . . . . . . 0.8 to 2.4V
Input Pulse Rise and Fall Times (10\% to 90\%) . . . . . 20 ns Timing Measurement Reference Level

```
Input
Output
1 V and 2.2 V
Output . . . . . . . . . . . . . . . . . . . . . . 0.8 V and 2.0 V
```

CAPACITANCE ${ }^{(2)} \quad T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| SYMBOL | TEST | LIMITS |  |
| :--- | :--- | :---: | :---: |
|  |  | TYP. | MAX. |
| C IN | All Pins Except Pin Under <br> Test Tied to AC Ground | 5 pF | 10 pF |
| COUT | All Pins Except Pin Under <br> Test Tied to AC Ground | 10 pF | 15 pF |

NOTE: 2. This parameter is periodically sampled and is not $100 \%$ tested.

## A.C. Waveforms



## Typical System Application (8K $\times 8$ ROM Memory)



## PROM AND ROM PROGRAMMING INSTRUCTIONS

## TABLE OF CONTENTS

Page No.
I. PROM AND ROM INPUT FORMATS ..... 6-75
A. General Information ..... 6-75
B. Paper Tape Format ..... 6-75

1. Intellec Hex ..... 6-75
2. BPNF ..... $6-76$
3. Non-Intellec Hex ..... 6-77
C. Computer Punched Card Format ..... 6-77
4. Intellec Hex ..... 6-77
5. PN ..... 6-79
D. Custom PROM/ROM Order Forms ..... 6-80
6. MOS EPROMs ..... 6-81
7. 8755 ..... 6-81
8. 2316E, 8316A ..... 6-82
9. 8308 ..... 6-83
10. 8355 ..... 6-84
II. MOS EPROMs ..... 6-85
A. Erasure Procedure ..... 6-85
11. UV Sources ..... 6-85
B. $2708 / 2704$ Programming ..... 6-86
C. 2716 Programming ..... 6-88
D. $8748 / 8755$ Programming ..... 6-89
III. DEVICE PHOTOGRAPHS ..... 6-90

## I. PROM AND ROM INPUT FORMATS

## A. General Information

Intel can accept programming and masking information for PROMs, EPROMs, or ROMs in the form of punched paper tape, a master device from which to copy, or computer punched cards. The allowable paper tape and computer punched card formats are given in Table I. The preferred formats are the Intel Intellec Hex and BPNF since these formats are defined to allow detection of errors.

It is desirable that two, preferably different, input media for each customer code be sent so Intel can perform a code verification to detect any errors between the two inputs. This procedure, if followed, can avoid errors due to a mispunched tape/card or sending a defective or improper master device.
All orders must be accompanied by a customer PROM/ROM order form. A copy of the form is contained in this section and additional copies are available from Intel Literature Department, 3065 Bowers Ave., Santa Clara, California 95051.

Table I. Acceptable Paper Tape and Computer Card Formats

| Paper Tape | Computer Card |
| :--- | :--- |
| Intellec Hex | Intellec Hex |
| BPNF | PN |
| Hex |  |

## B. Paper Tape Format

The paper tape which should be used is $1^{\prime \prime}$ wide paper using 7 or 8 -bit ASCII code (such as a Model 33 ASR Teletype produces). The three paper tape formats which should be sent are described in Sections B1 through B3.

## B1. Intellec Hex Paper Tape Format

In the Intel Intellec Hex Format, a data field can contain either 8 or 4-bit data. Two ASCII hexadecimal characters must be used to represent both 8 and 4-bit data. In the case of 4-bit data, only one of the characters is meaningful and must be specified on the Intel PROM/ROM Order Form.

Preceding the first data field and following the last data field there must be a leader/trailer length of at least 25 null characters. Comments (except for a colon) may be placed on the tape leader.

The format described below is readily generated by the Intel Intellec Microcomputer Development System or by systems programmed by the user.

1. RECORD MARK FIELD: Frame 0

The ASCII code for a colon (:) is used to signal the start of a record.
2. RECORD LENGTH FIELD: Frames 1 and 2

The number of data bytes in the record is representated by two ASCII hexadecimal digits in this field. The high-order digit is in frame 1. The maximum number of data bytes in a record is 255 (FF in hexadecimal). An end-of-file record contains two ASCII zeros in this field.
3. LOAD ADDRESS FIELD: Frames 3-6

The four ASCII hexadecimal digits in frames $3-6$ give the address at which the data is loaded. The high-order digit is in frame 3, the lower-order digit in frame 6. The first data byte is stored in the location indicated by the load address; successive bytes are stored in successive memory locations. This field in an end-of-file record contains zeros or the starting address of the program.
4. RECORD TYPE FIELD: Frames 7 and 8

The two ASCII hexadecimal digits in this field specify the record type. The high-order digit is in frame 7. All data records are type 0; end-of-file records are type 1. Other possible values for this field are reserved for future expansion.
5. DATA FIELD: Frames 9 to $9+2^{*}$ (record length) -1

A data byte is represented by two frames containing the ASCII characters $0-9$ or $A-F$, which represent a hexadecimal value between 0 and FF ( 0 and 255 decimal). The high-order digit is in the first frame of each pair. If the data is 4 -bit, then either the high or low-order digit represents the data and the other digit of the pair may be any ASCII hexadecimal digit. There are no data bytes in an end-of-file record.
6. CHECKSUM FIELD: Frames 9+2* (record length) to $9+2^{*}$ (record length) +1

The checksum field contains the ASCII hexadecimal representation of the two's complement of the 8 -bit sum of the 8 -bit bytes that result from converting each pair of ASCII hexadecimal digits to one byte of binary, from the record length field to and including the last byte of the data field. Therefore, the sum of all the ASCII pairs in a record after converting to binary, from the record length field to and including the checksum field, is zero.

## Intellec Hex Example:

$$
\begin{aligned}
& : 10310000311 \text { A320E03117E31CD40003A9231B7C2EE } \\
& : \text { 1031100060310E00117031CD40003A9231B7C2607B } \\
& : 10312000312 A 7 E 31227 A 310 E 03117 E 31 C D 40003 A B 0 \\
& : 103130009231 B 7 C 260312 A 8 C 317 C B 5 C A 50310 E 044 D \\
& : 10314000118831 C D 40003 A 9231 B 7 C 26031 C 3273186 \\
& : 103150000 E 01117 A 31 C D 40000 E 09119031 C D 4000 A 1 \\
& : 103160000 E 0 C 119231 C D 40000 E 09119031 C D 40006 E \\
& : 0 A 3170007 E 3196310100000092311 B \\
& : 10317 C 0092310100963180008 C 31923100009631 F 1 \\
& : 04318 E 0092319231 B 7 \\
& : 02319400923176 \\
& : 00310001 \mathrm{CE}
\end{aligned}
$$

## B2. BPNF Paper Tape Format

The format requirements are as follows:

1. All data fields are to be punched in consecutive order, starting with data field 0 (all addresses low). There must be exactly N data fields for a $\mathrm{N} \times 8$ or $\mathrm{N} \times 4$ device organizations.
2. Each data field must begin with the start character $B$ and end with the stop character F. There must be exactly 8 or 4 data characters between the B and F for a $\mathrm{N} \times 8$ or $\mathrm{N} \times 4$ organization, respectively.
NO OTHER CHARACTERS, SUCH AS RUBOUTS, ARE ALLOWED ANYWHERE IN A DATA FIELD. If in preparing a tape an error is made, the entire data field, including the $B$ and $F$ must be rubbed out. Within the data field, a $P$ results in a high level output, and an N results in a low level output.
3. Preceding the first data field and following the last data field, there must be a leader/trailer length of at least 25 characters. This should consist of rubout punches (letter key for Telex tapes) or null characters.
4. Between data fields, comments not containing B's or F's may be inserted. Carriage return and line feed characters should be inserted (as a "comment") after each 72 characters. When these carriage returns, etc., are inserted, the tape may be easily listed on the teletype for purposes of error checking. The customer may also find it helpful to insert the word number (as a comment) at least every four word fields.
5. Included in the tape before the leader should be the customer's complete Telex or TWX number and if more than one pattern is being transmitted, the device pattern number.
6. MSB and LSB are the most and least significant bit of the device outputs. Refer to the data sheet for the pin numbers.

## Example of BPNF $2048 \times 8$ format $(\mathbf{N}=2048)$ :



## Example of $512 \times 4$ format ( $\mathbf{N}=512$ ):



## B3. Non-Intellec Hex Paper Tape Format

For the non-Intellec Hex Format, a data field can contain either 8 or 4 -bit data. Two ASCII hexadecimal characters must be used to represent both 8 and 4 -bit data. In the case of 4 -bit data, only one of the characters is meaningful and must be specified on the Intel PROM/ROM Order Form.

Parity is allowed; however, it is not checked. Preceding the first data field and following the last data field there must be a leader/trailer length of at least 25 null characters or rubout punches.
The format requirements are as follows:

1. The start of the first data field is indicated by a colon. After the last data field, a semicolon must be punched to indicate the end. All data fields are to be punched in consecutive order, starting with data field $00_{\mathrm{H}}$ (all addresses low).
2. Two hex characters must be used to represent the data field of both $N$ word $\times 8$-bit and $N$ word $\times 4$-bit devices. For an 8 -bit data field, the high order data is represented by the left justified character of the pair. Either character of the pair may be used to represent the word field of a N word $\times 4$-bit device, however, it must be consistent throughout the word field. The other character may be any hex character.
A field of "don't care" data is allowed. Data after a field of "don't care" will be programmed starting at an address location enclosed in parentheses. In the following example, data is entered in addresses $00_{\mathrm{H}}$ to $05_{\mathrm{H}}$, followed with "don't care" from addresses $06_{H}$ to $25_{H}$, data being entered again starting at address location $26_{H}$, and followed with "don't care" data to the last address location.

3. The $x$ character may be used to rubout any erroneous character(s). The \# character may be used to rubout an entire line up to the previous carriage return.
4. Spaces are allowed only between separate word fields.
5. After each 72 characters, a carriage return followed by a line feed should be punched to allow a print-out of the tape.
6. Comments must be placed only between the tape leader and the start of the first data field.

## C. Computer Punched Card Format

The following general format is applicable to the programming information sent on computer punched cards:

1. An 80 column Hollerith card (interpreted) punched on an IBM 026 or 029 keypunch should be submitted.
2. A single deck must consist of a Title Card followed by the data cards. There will be $\mathrm{N} / 8$ or $\mathrm{N} / 14$ data cards for N words $\times 8$-bit and N words $\times 4$-bit devices, respectively, in the PN format.
For the Intellec Hex format, there will be $\mathrm{N} / 32$ data cards for both N words $\times 8$-bit and N words $\times 4$-bit devices, and one end of file card.

## C1. Intellec Hex Computer Punched Card Format

Two hex characters must be used to represent data for both a N word $\times 8$-bit and N word x 4 -bit device. For the latter, only one of the characters is meaningful and must be specified on the Intel PROM/ROM Order Form. The entire data field for all bits must be punched even if it is "don't care".

| DECIMAL NUMBER INDICATING THE TRUTH TABLE NUMBER |  |  |
| :---: | :---: | :---: |
| NO. OF OUTPUTS <br> 4 or 8 | Column | Data |
| TITLE CARD INTEL | 1 | Punch a T |
| DESIGNATION CUSTOMER'S P/N | 2-3 | Blank |
| CUSTOMER'S DIVISIONOR CUSTOMER'S | 4-28 | Customer Company Name |
| COMPANY NAME LOCATION P/N | 29-30 | Blank |
|  | 31-50 | Customer's Company Division or location |
| \|in |1 | 51-52 | Blank |
|  | 53-61 | Customer Part Number |
| 1 111 131 I 11 1 | 62-63 | Blank |
|  | 64-72 | Punch the Intel 4 -digit basic part number and in ( ) the number of output bits; e.g., 2708 |
|  |  | (8), 2316 (8), or 3605 (4) |
|  | 73-74 | Blank |
|  | 75-76 | Chip number for ROMs with programmable chip select inputs. If not applicable. leave |
|  |  | chip select inputs. If not applicable. leave blank. |
| 666666666666666\|66666616666666666666666566666666661666566665566666666666666666t | 77-78 | Biank |
|  | 79-80 | Punch a 2 -digit decimal number to indicate |
|  |  | truth table number. The first truth table will be 00 , second 01 , third 02 . etc. |
| (1) |  |  |

a. N word $\times 8$-bit device

| Column | Data |
| :---: | :---: |
| 1 | Record mark: A colon is used to signal the start of a record. |
| 2-3 | Record length: This is the count of the actual data bytes in the record. Column 2 contains the high order digit of the count, Column 3 contains the low order digit. A record length of zero indicates end of file. All frames containing data will have a maximum record length of $10_{\text {Hex }}$ bytes (32 decimal). |
| 4-7 | Load address: The four characters starting addresses at which the following data will be loaded. The high order digit of the load address is in Column 4 and the low order digit is in Column 7. The first data byte is stored in the location indicated by the load address. Successive data bytes are stored in successive memory locations. ROMs containing more than 32 bytes of data will use two or more records or cards to transmit the data. Although the load address for the beginning record need not be 0000, each subsequent load address should be " $10_{\mathrm{H}}$ " ( 32 decimals) greater than the last. |
| 8-9 | Record type: A 2-digit code in this field specifies the type of this record. The high order digit of this code is located in Column 8. Currently, all data records are type 0 . End-of-file records will be type 1 ; they are distinguished by a zero RECORD LENGTH field (see above). Other possible values for this field are reserved for future expansion. |
| 10-73 | Data |
| 75-75 | Checksum: Same as paper tape format. |
| 76-78 | Blank |
| 79-80 | Punch same 2-digit decimal number as in Title Card. |

b. N word x 4 -bit device

This format is identical to the previously documented 8-bit hexadecimal format with the following exceptions:

| Column | Data |
| :---: | :---: |
| $10-73$ | Each memory location is represented by two <br> columns containing the characters 0-9, |
|  | A-F. Since this is 4-bit data, the user must <br> indicate which character of each pair is to <br> be used as valid data. A single deck must be <br> submitted without mixing first and second <br> characters of the pair. |

## C2. PN Computer Punched Card Format

A word field consists of only P 's and N 's. A punched P will result in an output high level and a punched N in an output low level. The B and F characters, unlike the paper tape format, are illegal characters. The entire data field for all bits must be punched even if it is "don't care". The data field must begin in consecutive order, starting with address 0 (all addresses logically low).

| DECIMAL NUMBER INDICATING THE TRUTH TABLE NUMBER NO. OF OUTPUTS |  |  |
| :---: | :---: | :---: |
| 4 or 8 | Column | Data |
| TITLE CARD INTEL | 1 | Punch a T |
| DESIGNATION CUSTOMER'S P/N | 2-3 | Blank |
| CUSTOMER'S DIVISION OR CUSTOMER'S | 4-28 | Customer Company Name |
| COMPANY NAME <br> LOCATION <br> P/N | 29-30 | Blank |
| $\underset{\sim}{\square}$ | 31-50 | Customer's Company Division or location |
|  | 51-52 | Blank |
| \\| IIIII 11 | 53-61 | Customer Part Number |
| 111111 | 62-63 | Blank |
| 10000!11000001000000000000000010010000000000000000000000000001000000018 | 64-72 | Punch the Intel 4-digit basic part number and in () the number of output bits; e.g., 2708 |
|  |  | (8), 2316 (8), or 3605 (4) |
| \$3333333331311333313313333333333333331331433331313333333333313333331133333333333 | 73-74 | Blank |
| 14444444444444444444444444444444444444444444444444444444444444444444 | 75-76 | Chip number for ROMs with programmable |
|  |  | blank. |
| 66666666666666616666661666666666666666666666666666166666666666666666666666666666 | 77-78 | Blank |
| 11111111111111111111111111111111111111111111111111111111111111111 | 79-80 | Punch a 2-digit decimal number to indicate |
| 888888488888888888888888888888888888888888888888888888888888888888888881818888888 |  | truth table number. The first truth table |
|  |  | will be 00 , second 01 , third 02 , etc. |

## Title Card Format.

For a N words $\times 4$-bit organization only, cards 2 and those following should be punched as shown. Each card specifies the 4 -bit output of 14 words.


| Column | Data |
| :---: | :---: |
| 1-5 | Punch the 5 digit decimal equivalent of the binary coded location which begins each card. The address is right justifled, i.e., Øøøøø, ØøØ14, Øøø28, etc. |
| 6 | Blank |
| 7-10 | Data Field |
| 11 | Blank |
| 12-15 | Data Field |
| 16 | Blank |
| 17-20 | Data Field |
| 21 | Blank |
| 22-25 | Data Field |
| 26 | Blank |
| 27-30 | Data Field |
| 31 | Blank |
| 32-35 | Data Field |
| 36 | Blank |
| 37-40 | Data Field |
| 41 | Blank |
| 42-45 | Data Field |
| 46 | Blank |
| 47-50 | Data Field |
| 51 | Blank |
| 52-55 | Data Field |
| 56 | Blank |
| 57-60 | Data Field |
| 61 | Blank |
| 62-65 | Data Field |
| 66 | Blank |
| 67-70 | Data Field |
| 71 | Blank |
| 72.75 | Data Field |
| 76-78 | Blank |
| $79-80$ | Punch same 2 digit decimal number as in title card. |

For a N words $\times 8$-bit organization only, cards 2 and those following should be punched as shown. Each card specifies the 8 -bit output of 8 words.


| Column | Data |
| :---: | :---: |
| 1-5 | Punch the 5 digit decimal equivalent of the binary coded location which begins each card. The address is right justified, i.e., ØøØøø, ØøØø8, Øøø 16, etc. |
| 6 | Blank |
| 7-14 | Data Field |
| 15 | Blank |
| 16-23 | Data Field |
| 24 | Blank |
| 25-32 | Data Field |
| 33 | Blank |
| 34-41 | Data Field |
| 42 | Blank |
| 43-50 | Data Field |
| 51 | Blank |
| 52-59 | Data Field |
| 60 | Blank |
| 61-68 | Data Field |
| 69 | Blank |
| 70-77 | Data Field |
| 78 | Blank |
| 79-80 | Punch same 2 digit decimal number as in title card. |

## D. Custom PROM/ROM Order Forms

All orders for PROMs/ROMs which are to be electrically or mask programmed at Intel must be submitted with the order forms shown on the following pages. Additional forms are available from Intel Literature Department, 3065 Bowers Ave., Santa Clara, California 95051. The ROM Order Forms for the 4001 and 4308 are shown on pages $8-97$ and 8-108, respectively.

The order forms for the individual PROMs/ROMs are listed in Table II below.

Table II

| PROM/ROM <br> Part Number | Order Form <br> Number |
| :---: | :---: |
| MOS EPROMs | A |
| 8748,8755 | A |
| $2316 \mathrm{E}, 8316 \mathrm{~A}, 8316 \mathrm{AL}$ | B |
| 8048 | C |
| 8308 | D |
| 8355 | E |
| Bipolar PROMs/ROMs | F |


| Company |  |
| :--- | :--- |
| Company Contact | Phone |
| P.O. \# |  |

All custom MOS EPROM orders must be submitted on this form. Programming information
should be sent in the form of computer punched cards or punched paper tape per the
formats described in the Programming Instruction section of the Intel Data Catalog. Addi-
tional forms are available from Intel.

## MARKING

The marking will consist of the Intel Logo, the product and package type (B1702A), the 4-digit Intel pattern number (WWWW), an internal manufacturing traceability code (XXYY), and the customer part number ( $Z \ldots . . Z$ ). The customer part number is limited to a maximum of 9 digits or spaces.

1702A MARKING EXAMPLE

```
        For Intel Use Only
S#
```

$\qquad$

```
STD
APP
Date
```

$\qquad$

## CUSTOMER PART NUMBER

## Customer P/N

(Please Fill-In)

## Intel Pattern Number

(Please Do Not Use)

| 2 | $1 \times 11$ |
| :---: | :---: |
| 3 | $1 \times 11$ |
| 4 | 111 |
| 5 | $1 \times 11$ |
| 6 | $1 \times 11111$ |
| 7 | $1 \times 1$ |
| 8 | 1 |
| 9 | 1 |
| 10 | 1 |
| 11 |  |
| 12 | 1 |
| 13 |  |
| 14 | $1 \times 1$ |
| 15 | L 1 |
| 16 | 1 |
| 17 | $1 \times 1$ |
| 18 | 1 |
| 19 | 1 L |



## CUSTOMER 16K ROM ORDER FORM <br> B

| Company <br> Company Contact <br> P.O. \# Phone \# |  |
| :--- | :--- | :--- |


| A custom 16 K ROM order must be submitted on this form. Programming information |
| :--- |
| should be sent in the form of computer punched cards or punched paper tape per the |

formats described in the Programming Instruction section of the Intel Data Catalog. Addi-
tional forms are available from Intel.

## MARKING

The marking will consist of the Intel Logo, the product and package type (P2316E), the 4-digit Intel pattern number (WWWW), a date code (XXYY), and the customer part number (Z....Z). The customer part number is limited to a maximum of 9 digits or spaces.


1
P2316E MARKING EXAMPLE

## IMPORTANT MASK OPTION SPECIFICATION

The chip select inputs are mask programmable and must be specified by the user. The chip select logic levels must be specified with one of the below Chip Numbers. The Chip Number will be coded in terms of positive logic where a logic " 1 " is a high level input. It should be noted that Chip Number 4 for the 2316E is compatible to Intel's 2716 EPROM.

| Chip Number | CS3 | CS2 | CS1 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 2 | 0 | 1 | 0 |
| 3 | 0 | 1 | 1 |
| 4 | 1 | 0 | 0 |
| 5 | 1 | 0 | 1 |
| 6 | 1 | 1 | 0 |
| 7 | 1 | 1 | 1 |

## CUSTOMER PART NUMBER



## Chip Number

(Please Fill-In)
$1 \underset{\sim}{1}$
2 L
$3 ட \perp \perp \perp$
$41+1$
$5 L \perp \perp$
$6 L \perp \perp \perp \perp \perp$
$7 ட \perp \mid$
$8 \stackrel{\perp}{ } 8$
9 بـ_
10
$11 L \mathcal{L}$

## Intel Pattern Number

(Please Do Not Use)

| 2 L |
| :---: |
| $3 L \perp$ |
| 4 L |
| $5 L \perp$ |
| 6 L |
| 7 L |
| 8 ¢ |
| 9 ¢ 1 |
| 10 ¢ |
| 11 |

## CUSTOMER 8308 ROM ORDER FORM <br> D

|  | For Intel Use Only |
| :---: | :---: |
| Company P__ Phone \# | S\# |
| Company Contact __ Date | STD |
| P.O. \# __ Intel P/N \& Pkg | APP |
| All custom 8308 ROM orders must be submitted on this form. Programming information should be sent in the form of computer punched cards or punched paper tape per the formats designated on this order form. Additional forms are available from Intel. |  |

## MARKING

The marking will consist of the Intel logo, the product type (C8308), the 4-digit Intel pattern number (WWWW), a date code ( $X X Y Y$ ), and a maximum 9 -digit number ( $Z \ldots . \mathrm{Z}$ ) which is specified by the user. The 9-digit number may be a part number or the 8308 chip number.


1
C8308 MARKING EXAMPLE

## IMPORTANT MASK OPTION SPECIFICATION

The $\mathrm{CS}_{2}$ chip select input is mask programmable and must be specified by the user. The chip select logic level must be specified with one of the below Chip Numbers. The Chip Number will be coded in terms of positive logic where a " 1 " is a high level input.

Chip Number
$0 \quad 0$
10
$\mathrm{CS}_{2}$
(programmable)
0
1

## CUSTOMER PART NUMBER

Customer P/N
(Please Fill-In)

## Chip Number

(Please Fill-In)

## Intel Pattern Number

(Please Do Not Use)


## CUSTOMER 8355 ROM ORDER FORM

E

| Company ___ Phone \#____ | S\# For Intel Use Only |
| :---: | :---: |
| Company Contact __ Date |  |
| P.O. \#__ Package Type: $\square$ Plastic $\square$ Cerdip | STD <br> APP |
| All custom 8355 orders must be submitted on this form. Programming information should be sent in the form of computer punched cards or punched paper tape per the formats described in the Programming Instruction sectin of the Intel Data Catalog. Additional forms are available from Intel. | Date |
|  |  |

## MARKING

All devices will be marked as shown at the right figure. The marking will consist of the Intel Logo, the product and package type (P8355), the 4-digit Intel pattern number (WWWW), a date code ( XXYY ), and the customer part number ( $Z \ldots \mathrm{Z}$ ). The customer part number is limited to a maximum of 9 digits or spaces.


## CUSTOMER PART NUMBER



## Intel Pattern Number

(Please Do Not Use)


## II. MOS EPROMs

## A. Erasure Procedure

As stated in the EPROM related data sheets, the recommended erasure procedure to use with EPROMs is to illuminate the window with a UV lamp which has a wavelength of 2537 Angstroms ( $\AA$ ). The data sheets specify a distance of 1 inch and erase times of $10-45$ minutes, depending on the type of device and UV lamp. Actually, the amount of time required to erase a device can be concisely stated in terms of the amount of UV energy incident to the window, expressed in Watt-seconds per square centimeter ( $\mathrm{W}-\mathrm{sec} / \mathrm{cm}^{2}$ ). Table III lists the required integrated dosgae (UV intensity $X$ exposure time) for the EPROMs currently in production by Intel.

Table III. Required Erase Energy for Device Types

| Device Type | $2537 \AA$ Erase Energy |
| :--- | :---: |
| $1702 A / 4702 \mathrm{~A}$ | $6 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$ |
| $2708 / 8708$ | $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$ |
| 2716 | $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$ |
| 8748 | $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$ |
| 8755 | $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$ |

The erase energy expressed in Table III includes a guardband to ensure complete erasure of all bits. It is not sufficient to monitor "first bit" erasure to determine erasure time, as some other bits in the array may not be erased.

## A1. UV Sources

There are several models of UV lamps that can be used to erase EPROMs (see Table IV). The model numbers in the table refer to lamps manufactured by Ultra Violet Products of San Gabriel, California. In addition, there are several other manufacturers, including Data I/O (Issaquah, Wash.), PROLOG (Monterey, Calif.). Prometrics (Chicago, III.), and Turner Designs (Mt. View, Calif.). The individual manufacturers should be consulted for detailed product descriptions. Also shown in the table are typical erase times for various combinations of Intel PROMs and lamp intensities.

Table IV.

| Model | Power Rating | Minimum Erase Time for Indicated Dosage Without a Filter Over the Bulb |  |
| :---: | :---: | :---: | :---: |
|  |  | 6 W-sec 1702A, 4702A | 15 W-sec 2708, 8708, 8755 2716, 8748 |
| R-52 | $13000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ | 7.7 min | 19.2 min |
| S-52 | $12000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ | 8.3 min | 20.7 min |
| S-68 | $12000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ | 8.3 min | 20.7 min |
| UVS-54 | $5700 \mu \mathrm{~W} / \mathrm{cm}^{2}$ | 17.5 min | 43.8 min |
| UVS-11 | $5500 \mu \mathrm{~W} / \mathrm{cm}^{2}$ | 18.2 min | 45.6 min |

According to the manufacturers, the output of the UV lamp bulbs decrease with age. The output of the lamp should be verified periodically to ensure that adequate intensities are maintained. If this is not done, bits may be partially erased which will interfere with later programming and/or operation at high temperature.
For lamps other than those listed, the erase time can be determined by using a UV intensity meter, such as the Ultra Violet Products Model J-225. When a meter is used, the intensity should be measured at the same position (distance from the lamp) as the EPROMs to be erased. This will require careful positioning to insure that the sensor will receive the same amount of UV light that the window of the EPROM will receive.
The sensors used with most UV intensity meters show reduced output with constant exposure to UV light. Therefore, they should not be permanently placed inside the erasure enclosure, they should only be used for periodic measurements.

## B. 2708/2704 Family Programming

Initially, and after each erasure, all 8192/4096 bits of the 2708/2704 are in the " 1 " state (output high). Information is introduced by selectively programming " 0 " into the desired bit locations. A programmed " 0 " can only be changed to a " 1 " by UV erasure.

The circuit is set up for programming operation by raising the CS/WE input (pin 20) to +12 V . The word address is selected in the same manner as in the read mode. Data to be programmed are presented, 8 bits in parallel, to the data output lines $\left(\mathrm{O}_{1}-\mathrm{O}_{8}\right)$. Logic levels for address and data lines and the supply voltages are the same as for the read mode. After address and data set up, one program pulse per address is applied to the program input (pin 18). One pass through all addresses is defined as a program loop. The number of loops ( N ) required is a function of the program pulse width ( $\mathrm{t}_{\mathrm{pW}}$ ) according to $\mathrm{N} \times \mathrm{t}_{\mathrm{PW}}$ $\geqslant 100 \mathrm{~ms}$.
The width of the program pulse is from 0.1 to 1 ms . The number of loops $(\mathrm{N})$ is from a minimum of 100 ( $\mathrm{t}_{\mathrm{PW}}=1 \mathrm{~ms}$ ) to greater than 1000 ( $\mathrm{t}_{\mathrm{PW}}=0.1 \mathrm{~ms}$ ). There must be N successive loops throuhg all 1024 addresses. It is not permitted to apply N program pulses to an address and then change to the next address to be programmed. Caution should be observed regarding the end of a program sequence. The CS/WE falling edge transition must occur before the first address transition when changing from a program to a read cycle. The program pin should also be pulled down to $V_{\text {ILP }}$ with an active instead of a passive device. This pin will source a small amount of current (IILL) when CS/WE is at $\mathrm{V}_{\text {IHW }}\left(12 \mathrm{~V}\right.$ ) and the program pulse is at $\mathrm{V}_{\text {ILP }}$.

## Programming Examples (Using $\mathbf{N} \times \mathrm{t}_{\mathrm{PW}} \geqslant \mathbf{1 0 0} \mathbf{m s}$ )

Example 1: All 8096 bits are to be programmed with a 0.5 ms program pulse width.
The minimum number of program loops is 200 . One program loop consists of words 0 to 1023.
Example 2: Words 0 to 100 and 500 to 600 are to be programmed. All other bits are "don't care". The program pulse width is 0.75 ms .

The minimum number of program loops is 133 . One program loop consists of words 0 to 1023. The data entered into the "don't care" bits should be all 1's.

Example 3: Same requirements as example 2, but the PROM is now to be updated to include data for words 750 to 770. The minimum number of program loops is 133 . One program loop consists of words 0 to 1023. The data entered into the "don't care" bits should be all 1's. Addresses 0 to 100 and 500 to 600 must be re-programmed with their original data pattern.

## 2704, 2708

## PROGRAM CHARACTERISTICS

$T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted.

## D.C. Programming Characteristics

| Symbol | Parameter | Min. | Typ. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {LI }}$ | Address and $\overline{\mathrm{CS}} / \mathrm{WE}$ Input Sink Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ |
| IPPL | Program Pulse Source Current |  |  | 3 | mA |  |
| IIPH | Program Pulse Sink Current |  |  | 20 | mA |  |
| IDD | $V_{\text {DD }}$ Supply Current |  | 50 | 65 | mA | Worst Case Supply Currents: <br> All Inputs High $\overline{C S} / W E=5 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 6 | 10 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}$ | $V_{\text {BB }}$ Supply Current |  | 30 | 45 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level (except Program) | $V_{\text {SS }}$ |  | 0.65 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Level for all Addresses and Data | 3.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\text {IHW }}$ | $\overline{\text { CS/WE Input High Level }}$ | 11.4 |  | 12.6 | V | Referenced to $\mathrm{V}_{\text {SS }}$ |
| $\mathrm{V}_{\text {IHP }}$ | Program Pulse High Level | 25 |  | 27 | V | Referenced to $\mathrm{V}_{\text {SS }}$ |
| $V_{\text {ILP }}$ | Program Pulse Low Level | $\mathrm{V}_{\mathrm{SS}}$ |  | 1 | V | $\mathrm{V}_{\text {IHP }}-\mathrm{V}_{\text {ILP }}=25 \mathrm{~V}$ min. |

## A.C. Programming Characteristics

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {AS }}$ | Address Setup Time | 10 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{CSS}}$ | $\overline{\mathrm{CS}} /$ WE Setup Time | 10 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Setup Time | 10 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{AH}}$ | Address Hold Time | 1 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{CH}}$ | $\overline{\mathrm{CS}}$ WE Hold Time | .5 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time | 1 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip Deselect to Output Float Delay | 0 |  | 120 | ns |
| $\mathrm{t}_{\mathrm{DPR}}$ | Program To Read Delay |  |  | 10 | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\text {PW }}$ | Program Pulse Width | .1 |  | 1.0 | ms |
| $\mathrm{t}_{\text {PR }}$ | Program Pulse Rise Time | .5 |  | 2.0 | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\text {PF }}$ | Program Pulse Fall Time | .5 |  | 2.0 | $\mu \mathrm{~s}$ |

NOTE: Intel's standard product warranty applies only to devices programmed to specifications described herein.

## 2704, 2708 <br> Programming Waveforms



NOTE 1. THE $\overline{C S} / W E$ TRANSITION MUST OCCUR AFTER THE PROGRAM PULSE TRANSITION AND BEFORE THE ADDRESS TRANSITION.
NOTE 2. NUMBERS IN () INDICATE MINIMUM TIMING IN $\mu$ S UNLESS OTHERWISE SPECIFIED.

## C. 2716 Programming

Initially, and after each erasure, all 16,384 bits of the 2716 are in the " 1 " state. Information is introduced by selectively programming " 0 " into the desired bit locations. A programmed " 0 " can only be changed to a " 1 " by UV erasure.
The 2716 is programmed by applying a 50 ms , TTL programming pulse to the PD/PGM pin with the $\overline{C S}$ input high and the $V_{\text {PP supply }}$ at $25 \mathrm{~V} \pm 1 \mathrm{~V}$. Any location may be programmed at any time - either indvidually, sequentially, or randomly. The programming time for a single bit is only 50 ms and for all 16,384 bits is approximately 100 sec . The detailed programming specifications and timing waveforms are given in the following tables and figures.

CAUTION: The $V_{C C}$ and $V_{P P}$ supplies must be sequenced on and off such that $V_{C C}$ is applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$ to prevent damage to the 2716. The maximum allowable voltage during programming which may be applied to the $V_{\text {Pp }}$ with respect to ground is +26 V . Care must be taken when switching the $V_{P P}$ supply to prevent overshoot exceeding the 26 -volt maximum specification. For convenience in programming, the 2716 may be verified with the $\mathrm{V}_{\mathrm{PP}}$ supply at $25 \mathrm{~V} \pm 1 \mathrm{~V}$. During normal read operation, however, $\mathrm{V}_{\text {Pp }}$ must be at $\mathrm{V}_{\mathrm{CC}}$.

## 2716 PROGRAM CHARACTERISTICS ${ }^{(1)}$

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}{ }^{[2]}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}{ }^{[2,3]}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

## D.C. Programming Characteristics

| Symbol | Parameter | Min. | Typ. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {LI }}$ | Input Current (for Any Input) |  |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=5.25 \mathrm{~V} / 0.45$ |
| $\mathrm{I}_{\text {PP } 1}$ | $\mathrm{~V}_{\text {PP }}$ Supply Current |  |  | 5 | mA | $\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{I}_{\text {PP2 }}$ | $\mathrm{V}_{\text {PP }}$ Supply Current During <br> Programming Pulse |  |  | 30 | mA | $\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{\text {IH }}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  |  | 100 | mA |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Level | -0.1 |  | 0.8 | V |  |
| $\mathrm{~V}_{\text {IH }}$ | Input High Level | 2.2 |  | $\mathrm{~V}_{\mathrm{CC}}+1$ | V |  |

## A.C. Programming Characteristics

| Symbol | Parameter | Min. | Typ. | Max. | Units |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {AS }}$ | Address Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {c }}$ CSS | $\overline{\text { CS }}$ Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\text {AH }}$ | Address Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ CSH | $\overline{\mathrm{CS}}$ Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip Deselect to Output Float Delay | 0 |  | 120 | ns | $\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Select to Output Delay |  |  | 120 | ns | $\mathrm{PD} / \mathrm{PGM}=\mathrm{V}_{\text {IL }}$ |
| ${ }_{\text {t }}$ PW | Program Pulse Width | 45 | 50 | 55 | ms |  |
| tPRT | Program Pulse Rise Time | 5 |  |  | ns |  |
| tpFT | Program Pulse Fall Time | 5 |  |  | ns |  |

NOTES: 1. Intel's standard product warranty applies only to devices programmed to specifications described herein.
2. VCC must be applied simultaneously or before VPP and removed simultaneously or after VPP. The 2716 must not be inserted into or removed from a board with VPP at $25 \pm 1 \mathrm{~V}$ to prevent damage to the device.
3. The maximum allowable voltage which may be applied to the VPP pin during programming is +26 V . Care must be taken when switching the VPP supply to prevent overshoot exceeding this 26 V maximum specification.
A.C. Conditions of Test:
$V_{\text {CC }}$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $5 \mathrm{~V} \pm 5 \%$
V $_{\text {pp. . . . . . . . . . . . . . . . . . . . . . . . . . . . . } 25 \mathrm{~V} \pm 1 \mathrm{~V}}$
Input Rise and Fall Times ( $10 \%$ to $90 \%$ ) . . . . . . . . . 20 ns

## PROGRAMMING WAVEFORMS



NOTE: ALL TIMES SHOWN IN PARENTHESES ARE MINIMUM TIMES AND ARE $\mu$ SEC UNLESS OTHERWISE NOTED.
D. 8748/8755 Programming

Initially, and after each erasure, all bits of the EPROM portions of the 8748 and 8755 are in the " 1 " state. Information is introduced by selectively programming " 0 " into the desired bit locations. A programmed " 0 " can only be changed to a " 1 " by UV erasure.
The EPROM portions of the 8748 and 8755 are programmed on the Intel ${ }^{\circledR}$ Universal PROM Programmer (UPP). The UPP and its related personality cards for the 8748 and 8755 are described beginning on page 7-15 of this catalog.

## 2316E 16K ROM



## 2708 8K UV EPROM



## 2716 16K EPROM



RAMs


## RAMs

8101A-4 1024-Bit RAM with I/O ..... 6-95
8102A-4 1024-Bit MOS RAM ..... 6-98
8111A-4 1024-Bit RAM with I/O ..... 6-102
$5101256 \times 4$ CMOS RAM ..... 6-105
M5101-4/M5101L-4 256x4-Bit Static CMOS RAM ..... 6-109
2114 1024×4 Static MOS RAM ..... 6-112
2142 1024×4-Bit Static RAM ..... 6-116
2104A 4096x1 Dynamic MOS RAM ..... 6-120
2107B 4096x1 Dynamic MOS RAM ..... 6-128
2116 16,384×1 Dynamic MOS RAM ..... 6-134
3222 4K Dynamic RAM Refresh Cont. ..... 6-142
3232 4K Dynamic RAM Multiplexer and Refresh Counter ..... 6-148
3242 16K Dynamic RAM Multiplexer and Refresh Counter ..... 6-152

# 8101A-4 <br> 1024 BIT STATIC MOS RAM WITH SEPARATE I/O 

## * 450 nsec Access Time Maximum <br> * 256 Word by 4 Bit Organization

\author{

- Single +5 V Supply Voltage <br> - Directly TTL Compatible: All Inputs and Outputs <br> - Static MOS: No Clocks or Refreshing Required <br> - Simple Memory Expansion: Chip Enable Input
}

The Intel® $8101 \mathrm{~A}-4$ is a 256 word by 4 -bit static random access memory element using N -channel MOS devices integrated on a monolithic array. It uses fully DC stable (static) circuitry and therefore requires no clocks or refreshing to operate. The data is read out nondestructively and has the same polarity as the input data.
The $8101 \mathrm{~A}-4$ is designed for memory applications 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 +5 V supply. Two chip-enables allow easy selection of an individual package when outputs are OR-tied. An output disable is provided so that data inputs and outputs can be tied for common I/O systems. The output disable function eliminates the need for bi-directional logic in a common I/O system.

The Intel@ 8101A-4 is fabricated with N-channel silicon gate technology. This technology allows the design and production of high performance, easy-to-use MOS circuits and provides a higher functional density on a monolithic chip than either conventional MOS technology or P-channel silicon gate technology.
Intel's silicon gate technology also provides excellent protection against contamination. This permits the use of low cost plastic packaging.


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias . . . . $-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$
Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

Voltage On Any Pin
With Respect to Ground . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . 1 Watt
*COMMENT:
Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $l_{\text {LI }}$ | Input Current |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\mathrm{I}_{\mathrm{LOH}}$ | I/O Leakage Current ${ }^{[2]}$ |  | 1 | 10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{\text {OUT }}=4.0 \mathrm{~V}$ |
| $\mathrm{I}_{\text {LOL }}$ | I/O Leakage Current ${ }^{[2]}$ |  | -1 | -10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}$ |
| $I_{\text {CC1 }}$ | Power Supply <br> Current |  | 35 | 55 | mA | $\begin{aligned} & V_{I N}=5.25 \mathrm{~V}, \mathrm{I}_{\mathrm{O}}=0 \mathrm{~mA} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Power Supply <br> Current |  |  | 60 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}, \mathrm{I}_{\mathrm{O}}=0 \mathrm{~mA} \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \end{aligned}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage | -0.5 |  | +0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output "Low" Voltage |  |  | +0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & \text { Output "High" } \\ & \text { Voltage } \end{aligned}$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |

## TYPICAL D.C. CHARACTERISTICS




NOTES: 1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. Input and Output tied together.

## A.C. CHARACTERISTICS

READ CYCLE $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%$, unless otherwise specified.


## WRITE CYCLE



## A.C. CONDITIONS OF TEST

$\mathrm{t}_{\mathrm{r}, \mathrm{tf}}$. . . . . . . . . . . . . . . . . . . . . . . . . . 20 ns
Input Levels . . . . . . . . . . . . . . . . . . 0.8 V or 2.0 V
Timing Reference . . . . . . . . . . . . . . . . . 1.5 V
Load . . . . . . . . . . . 1 TTL Gate and $C_{L}=100 \mathrm{pF}$

CAPACITANCE ${ }^{[3]} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Limits (pF) |  |
| :--- | :--- | :---: | :---: |
|  |  | Typ. ${ }^{[1]}$ | Max. |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance <br> (All Input Pins) $V_{\text {IN }}=0 V$ | 4 | 8 |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 8 | 12 |

## WAVEFORMS

## READ CYCLE



I NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage
2. tDF is with respect to the trailing edge of $\overline{C E}_{1}, C E_{2}$, or $O D$, whichever occurs first.
3. This parameter is periodically sampled and is not $100 \%$ tested.

WRITE CYCLE

4. OD should be tied low for separate I/O operation.

## 1024 BIT FULLY DECODED STATIC MOS RANDOM ACCESS MEMORY

- Access Time - 450 ns Max.
- Single +5 Volts Supply Voltage
- Directly TTL Compatible - All Inputs and Output
- Static MOS - No Clocks or Refreshing Required
- Low Power - Typically 150 mW
- Three-State Output - OR-Tie Capability
- Simple Memory Expansion - Chip Enable Input
- Fully Decoded - On Chip Address Decode
- Inputs Protected - All Inputs Have Protection Against Static Charge
- Low Cost Packaging - 16 Pin Plastic Dual-In-Line Configuration

The Intel ${ }^{\circledR} 8102 \mathrm{~A}-4$ is a 1024 word by one 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.
The 8102A-4 is designed for microcomputer memory applications where high performance, low cost, large bit storage, and simple interfacing are important design objectives.
It is directly TTL compatible in all respects: inputs, output, and a single +5 volt supply. A separate chip enable ( $\overline{C E}$ ) lead allows easy selection of an individual package when outputs are OR-tied.
The Intel 8102A-4 is fabricated with N -channel silicon gate technology. This technology allows the design and production of high performance, easy-to-use MOS circuits and provides a higher functional density on a monolithic chip than either conventional MOS technology or P -channel silicon gate technology.
Intel's silicon gate technology also provides excellent protection against contamination. This permits the use of low cost silicone packaging.

PIN CONFIGURATION


LOGIC SYMBOL

PIN NAMES

| $D_{\text {IN }}$ | DATA INPUT | $\overline{C E}$ | CHIP ENABLE |
| :--- | :--- | :--- | :--- |
| $A_{\sigma} \cdot A_{g}$ | ADDRESS INPUTS | $D_{\text {OUT }}$ | DATA OUTPUT |
| R/W | READ $W R$ ITE INPUT | $V_{C C}$ | POWER $(+5 V)$ |

BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$

## Storage Temperature

 $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$Voltage On Any Pin
With Respect To Ground

$$
-0.5 \mathrm{~V} \text { to }+7 \mathrm{~V}
$$

1 Watt
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%$ unless otherwise specified

| SYMBOL | PARAMETER | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | TYP. ${ }^{(1)}$ | MAX. |  |  |
| ${ }^{\text {LI }}$ | INPUT LOAD CURRENT (ALL INPUT PINS) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\mathrm{I}_{\text {LOH }}$ | OUTPUT LEAKAGE CURRENT |  |  | 5 | $\mu \mathrm{A}$ | $\overline{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=2.4$ to $\mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\text {LOL }}$ | OUTPUT LEAKAGE CURRENT |  |  | -10 | $\mu \mathrm{A}$ | $\overline{\mathrm{CE}}=2.0 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.4 \mathrm{~V}$ |
| ${ }^{\text {CCC1 }}$ | POWER SUPPLY CURRENT |  | 30 | 50 | mA | ALL INPUTS $=5.25 \mathrm{~V}$ DATA OUT OPEN $T_{A}=25^{\circ} \mathrm{C}$ |
| ${ }^{\prime} \mathrm{CC} 2$ | POWER SUPPLY CURRENT |  |  | 55 | mA | ALL INPUTS $=5.25 \mathrm{~V}$ DATA OUT OPEN $T_{A}=0^{\circ} \mathrm{C}$ |
| $V_{\text {IL }}$ | INPUT "LOW" VOLTAGE | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | INPUT "HIGH" VOLTAGE | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | OUTPUT "LOW" VOLTAGE |  |  | 0.4 | V | $\mathrm{I}^{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | OUTPUT "HIGH" VOLTAGE | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |

(1) Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.

## TYPICAL D.C. CHARACTERISTICS

POWER SUPPLY CURRENT VS. AMBIENT TEMPERATURE


POWER SUPPLY CURRENT VS. SUPPLY VOLTAGE

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ unless otherwise specified

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. |  |
| READ CYCLE |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 450 |  |  | ns |
| $t_{A}$ | Access Time |  |  | 450 | ns |
| ${ }^{\text {c }}$ CO | Chip Enable to Output Time |  |  | 230 | ns |
| $\mathrm{t}_{\mathrm{OH} 1}$ | Previous Read Data Valid with Respect to Address | 40 |  |  | ns |
| ${ }^{\text {toH2 }}$ | Previous Read Data Valid with Respect to Chip Enable | 0 |  |  | ns |
| WRITE CYCLE |  |  |  |  |  |
| $t_{\text {w }}$ | Write Cycle | 450 |  |  | ns |
| ${ }^{\text {a }}$ W | Address to Write Setup Time | 20 |  |  | ns |
| $t_{\text {WP }}$ | Write Pulse Width | 300 |  |  | ns |
| $t_{W R}$ | Write Recovery Time | 0 |  |  | ns |
| $t_{\text {DW }}$ | Data Setup Time | 300 |  |  | ns |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time | 0 |  |  | ns |
| ${ }^{\text {c }} \mathrm{CW}$ | Chip Enable to Write Setup Time | 300 |  |  | ns |

NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.

CAPACITANCE ${ }^{[2]} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| SYMBOL | TEST | LIMITS (pF) |  |
| :--- | :--- | :---: | :---: |
|  | TYP.[1] | MAX. |  |
| $\mathrm{C}_{\text {IN }}$ | INPUT CAPACITANCE <br> (ALL INPUT PINS) $\mathrm{V}_{\text {IN }}=0 \mathrm{OV}$ | 3 | 5 |
| $\mathrm{C}_{\text {OUT }}$ | OUTPUT CAPACITANCE <br> $V_{\text {OUT }}=0 \mathrm{O}$ | 7 | 10 |

NOTE: 2. This parameter is periodically sampled and is not $100 \%$ tested.

## WAVEFORMS

## READ CYCLE



## WRITE CYCLE



OUTPUT SOURCE CURRENT VS.


VIN LIMITS VS. TEMPERATURE


ACCESS TIME VS. AMBIENT TEMPERATURE


OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE


ACCESS TIME VS. $V_{\text {CC }}$ NORMALIZED TO $\mathrm{V}_{\mathbf{C c}}=5.0 \mathrm{~V}$


ACCESS TIME VS. LOAD CAPACITANCE


# 8111A-4 <br> 1024 BIT STATIC MOS RAM WITH COMMON I/O 

## * 450 nsec Access Time Maximum <br> * 256 Word by 4 Bit Organization

\author{

- Single +5 V Supply Voltage <br> - Directly TTL Compatible: All Inputs and Outputs <br> Static MOS: No Clocks or Refreshing Required <br> - Simple Memory Expansion: Chip Enable Input
}

Powerful Output Drive Capability

- Low Cost Packaging: 18 Pin Plastic Dual In-Line Configuration
Low Power: Typically 150mW
Three-State Output: OR-Tie Capability
- Output Disable Provided for Ease of Use in Common Data Bus Systems

The Intel® 8111 A-4 is a 256 word by 4 -bit static random access memory element using N-channel MOS devices integrated on a monolithic array. It uses fully DC stable (static) circuitry and therefore requires no clocks or refreshing to operate. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided.
The $8111 \mathrm{~A}-4$ 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 +5 V supply. Separate chip enable ( $\overline{\mathrm{CE}}$ ) leads allow easy selection of an individual package when outputs are OR-tied.
The Intel ${ }^{\circledR}$ 8111A-4 is fabricated with N -channel silicon gate technology. This technology allows the design and production of high performance, easy-to-use MOS circuits and provides a higher functional density on a monolithic chip than either conventional MOS technology or P-channel silicon gate technology.

Intel's silicon gate technology also provides excellent protection against contamination. This permits the use of low cost plastic packaging.
CIN CONFIGURATION

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias . . . . $-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$
Storage Temperature $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage On Any Pin
With Respect to Ground . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . 1 Watt
${ }^{*}$ COMMENT:
Stresses above those listed under 'Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise specified.

| Symbol | Parameter | Min. | Typ. ${ }^{11]}$ | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  | 1 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=0$ to 5.25 V |
| $\mathrm{I}_{\mathrm{LOH}}$ | $\mathrm{I} / \mathrm{O}$ Leakage Current |  | 1 | 10 | $\mu \mathrm{~A}$ | Output Disabled, $\mathrm{V}_{\mathrm{I} / \mathrm{O}}=4.0 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{LOL}}$ | $\mathrm{I} / \mathrm{O}$ Leakage Current |  | -1 | -10 | $\mu \mathrm{~A}$ | Output Disabled, $\mathrm{V}_{\mathrm{I} / \mathrm{O}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Power Supply <br> Current | 35 | 55 | mA | $\mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}$ <br> $\mathrm{I}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |  |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Power Supply <br> Current |  |  | 60 | mA | $\mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}$ <br> $\mathrm{I}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High <br> Voltage | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |  |  |



NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.

## A.C. CHARACTERISTICS

READ CYCLE $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise specified.

| Symbol | Parameter | Min. | $\text { Typ. }{ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {RC }}$ | Read Cycle | 450 |  |  | ns | (See Below) |
| $t_{\text {A }}$ | Access Time |  |  | 450 | ns |  |
| ${ }^{\text {t }}$ CO | Chip Enable To Output |  |  | 310 | ns |  |
| $\mathrm{t}_{\mathrm{OD}}$ | Output Disable To Output |  |  | 250 | ns |  |
| ${ }_{\text {t }}{ }^{\text {[2] }}$ | Data Output to High Z State | 0 |  | 200 | ns |  |
| ${ }^{\text {toH }}$ | Previous Read Data Valid after change of Address | 40 |  |  | ns |  |

## WRITE CYCLE

| Symbol | Parameter | Min. | $\text { Typ. }{ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {t }}$ c | Write Cycle | 270 |  |  | ns | (See Below) |
| ${ }^{\text {taw }}$ | Write Delay | 20 |  |  | ns |  |
| ${ }^{\text {t }}$ CW | Chip Enable To Write | 250 |  |  | ns |  |
| ${ }_{\text {t }}$ W | Data Setup | 250 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold | 0 |  |  | ns |  |
| ${ }_{\text {twp }}$ | Write Pulse | 250 |  |  | ns |  |
| twr | Write Recovery | 0 |  |  | ns |  |
| ${ }^{t}{ }_{\text {DS }}$ | Output Disable Setup | 20 |  |  | ns |  |

## A.C. CONDITIONS OF TEST

$\mathrm{t}_{\mathrm{r}, \mathrm{tf}}$. . . . . . . . . . . . . . . . . . . . . . . . . . 20 ns
Input Levels . . . . . . . . . . . . . . . . . . 0.8 V or 2.0 V
Timing Reference . . . . . . . . . . . . . . . . . . 1.5 V
Load . . . . . . . . . . . 1 TTL Gate and $C_{L}=100$ pF

CAPACITANCE ${ }^{[3]} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Limits (pF) |  |
| :--- | :--- | :---: | :---: |
|  | Typ. ${ }^{[1]}$ |  | Max. |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance <br> (All Input Pins) $V_{I N}=0 \mathrm{~V}$ | 4 | 8 |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance $\mathrm{V}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~V}$ | 10 | 15 |

## WAVEFORMS

## READ CYCLE



WRITE CYCLE


NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. ${ }^{t} D F$ is with respect to the trailing edge of $\overline{C_{1}}, \overline{C E_{2}}$, or $O D$, whichever occurs first.
3. This parameter is periodically sampled and is not $100 \%$ tested.

## 5101 FAMILY

 256 X 4 BIT STATIC CMOS RAM| P/N | Typ. Current @ 2V <br> $(\mu \mathrm{A})$ | Typ. Current @ 5V <br> $(\mu \mathrm{A})$ | Max Access <br> $(\mathrm{ns})$ |
| :--- | :---: | :---: | :---: |
| 5101 L | 0.14 | 0.2 | 650 |
| $5101 \mathrm{~L}-1$ | 0.14 | 0.2 | 450 |
| $5101 \mathrm{~L}-3$ | 0.70 | 1.0 | 650 |
| $5101-8$ | - | 10.0 | 800 |

## - Single +5V Power Supply <br> - Ideal for Battery Operation (5101L)

## Directly TTL Compatible: All Inputs and Outputs <br> - Three-State Output

The Intel ${ }^{\circledR} 5101$ is an ultra-low power 1024-bit ( 256 words $\times 4$ bits) static RAM fabricated with an advanced ion-implanted silicon gate CMOS technology. The device has two chip enable inputs. Minimum standby current is drawn by this device when CE2 is at a low level. When deselected the 5101 draws from the single 5 -volt supply only 10 microamps. This device is ideally suited for low power applications where battery operation or battery backup for non-volatility are required.
The 5101 uses fully DC stable (static) circuitry; it is not necessary to pulse chip select for each address transition. The data is read out non-destructively and has the same polarity as the input data. All inputs and outputs are directly TTL compatible. The 5101 has separate data input and data output terminals. An output disable function is provided so that the data inputs and outputs may be wire OR-ed for use in common data I/O systems.

The 5101 L has the additional feature of guaranteed data retention at a power supply voltage as low as 2.0 volts.
A pin compatible N -channel static RAM, the Intel ${ }^{\circledR} 2101 \mathrm{~A}$, is also available for low cost applications where a $256 \times 4$ organization is needed.
The Intel ion-implanted, silicon gate, Complementary MOS (CMOS) process allows the design and production of ultra-low power, high performance memories.


## Absolute Maximum Ratings *

Ambient Temperature Under Bias . . . . $-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$
Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage On Any Pin
With Respect to Ground . . . . -0.3 V to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$
Maximum Power Supply Voltage . . . . . . . . . +7.0V
Power Dissipation . . . . . . . . . . . . . . . . . . 1 Watt

## *COMMENT.

Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D. C. and Operating Characteristics

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| Symbol | Parameter | 5101L <br> Min. | and 51 <br> Limits <br> Typ.[1] | 01L-1 <br> Max. | Min. | $\begin{aligned} & \text { 5101L-3 } \\ & \text { Limits } \\ & \text { Typ.[1] } \end{aligned}$ | Max. | Min. | 5101-8 <br> Limits <br> Typ.[1] | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{L} 2}{ }^{[2]}$ | Input Current |  | 5 |  |  | 5 |  |  | 5 |  | nA |  |
| $\\|_{\text {LO }}{ }^{\text {[ } 2]}$ | Output Leakage Current |  |  | 1 |  |  | 1 |  |  | 2 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CE1}}=2.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}= \\ & 0 \text { to } \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Operating Current |  | 9 | 22 |  | 9 | 22 |  | 11 | 25 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}, \text { Except } \\ & \mathrm{CE} 1 \leqslant 0.65 \mathrm{~V}, \\ & \text { Outputs Open } \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Operating Current |  | 13 | 27 |  | 13 | 27 |  | 15 | 30 | mA | $\mathrm{V}_{\mathrm{IN}}=2.2 \mathrm{~V}$, Except $\overline{\mathrm{CE}} \leqslant 0.65 \mathrm{~V}$, Outputs Open |
| $\mathrm{ICCL}^{[2]}$ | Standby Current |  |  | 10 |  |  | 200 |  |  | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{CE} 2 \leqslant 0.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}= \\ & 70^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.3 |  | 0.65 | -0.3 |  | 0.65 | -0.3 |  | 0.65 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}$ | 2.2 |  | $\mathrm{V}_{\text {CC }}$ | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | 2.4 |  |  | 2.4 |  |  | V | $\mathrm{IOH}^{\prime}=-1.0 \mathrm{~mA}$ |

Low $\mathrm{V}_{\mathrm{Cc}}$ Data Retention Characteristics (For 5101L, 5101L-1 and 5101L-3) $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | Min. | Typ. [1] | Max. | Units | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {DR }}$ | $\mathrm{V}_{\text {CC }}$ for Data Retention | 2.0 |  |  | V | $C E 2 \leqslant 0.2 \mathrm{~V}$ |  |
| ICCDR1 | 5101 L or $5101 \mathrm{~L}-1$ Data Retention Current |  | 0.14 | 10 | $\mu \mathrm{A}$ |  | $\begin{aligned} & \mathrm{V}_{\mathrm{DR}}=2.0 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=70^{\circ} \mathrm{C} \end{aligned}$ |
| ICCDR2 | 5101 L-3 Data Retention Current |  | 0.70 | 200 | $\mu \mathrm{A}$ |  | $\begin{aligned} & V_{D R}=2.0 \mathrm{~V}, \\ & T_{A}=70^{\circ} \mathrm{C} \end{aligned}$ |
| ${ }^{\text {t }}$ CDR | Chip Deselect to Data Retention Time | 0 |  |  | ns |  |  |
| $\mathrm{t}_{\mathrm{R}}$ | Operation Recovery Time | $\mathrm{t}_{\mathrm{RC}}{ }^{[3]}$ |  |  | ns |  |  |

NOTES:

1. Typical values are $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. Current through all inputs and outputs included in ICCL measurement.
3. $\mathrm{t}_{\mathrm{R}} \mathrm{C}=$ Read Cycle Time.

## Low VCC Data Retention Waveform



Typical ICCDR Vs. Temperature

A.C. Characteristics $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise specified.

## READ CYCLE

|  | Parameter | 5101L-1 <br> Limits (ns) |  | 5101L and 5101L-3 <br> Limits (ns) |  | $\begin{aligned} & 5101-8 \\ & \text { Limits (ns) } \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 450 |  | 650 |  | 800 |  |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time |  | 450 |  | 650 |  | 800 |
| ${ }^{\text {c }} \mathrm{CO} 1$ | Chip Enable ( $\overline{\mathrm{CE} ~ 1)}$ ) to Output |  | 400 |  | 600 |  | 800 |
| ${ }^{\text {c }} \mathrm{CO} 2$ | Chip Enable (CE 2) to Output |  | 500 |  | 700 |  | 850 |
| tod | Output Disable to Output |  | 250 |  | 350 |  | 450 |
| $t_{\text {DF }}$ | Data Output to High Z State | 0 | 130 | 0 | 150 | 0 | 200 |
| $\mathrm{t}_{\mathrm{OH} 1}$ | Previous Read Data Valid with Respect to Address Change | 0 |  | 0 |  | 0 |  |
| tOH 2 | Previous Read Data Valid with Respect to Chip Enable | 0 |  | 0 |  | 0 |  |

## WRITE CYCLE

| $t_{\text {WC }}$ | Write Cycle | 450 | 650 | 800 |
| :--- | :--- | :--- | :--- | :--- |
| $t_{\text {AW }}$ | Write Delay | 130 | 150 | 200 |
| $\mathrm{t}_{\mathrm{CW} 1}$ | Chip Enable (言E 1) to Write | 350 | 550 | 650 |
| $\mathrm{t}_{\mathrm{CW} 2}$ | Chip Enable (CE 2) to Write | 350 | 550 | 650 |
| $\mathrm{t}_{\mathrm{DW}}$ | Data Setup | 250 | 400 | 450 |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold | 50 | 100 | 100 |
| $t_{\text {WP }}$ | Write Pulse | 250 | 400 | 450 |
| $\mathrm{t}_{\text {WR }}$ | Write Recovery | 50 | 50 | 100 |
| $\mathrm{t}_{\mathrm{DS}}$ | Output Disable Setup | 130 | 150 | 200 |

A. C. CONDITIONS OF TEST
Input Pulse Levels: $\quad+0.65$ Volt to 2.2 Volt Input Pulse Rise and Fall Times: 20 nsec Timing Measurement Reference Level: 1.5 Volt Output Load: $\quad 1 \mathrm{TTL}$ Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

Capacitance ${ }^{\{2]} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Limits (pF) |  |
| :--- | :--- | :---: | :---: |
|  | Typ. | Max. |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance <br> (All Input Pins) $V_{\text {IN }}=0 V$ | 4 | 8 |
| COUT | Output Capacitance $V_{\text {OUT }}=0 V$ | 8 | 12 |

[^4]
## Waveforms

READ CYCLE


WRITE CYCLE


NOTES:

1. $O D$ may be tied low for separate $I / O$ operation.
2. During the write cycle, OD is "high" for common I/O and "don't care" for separate I/O operation.

## M5101-4, M5101L-4

## $256 \times 4$ BIT STATIC CMOS RAM

- Military Temperature

Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

## - Ultra Low Standby

Current: 200 nA/Bit

- Fast Access Time-800ns
- Single +5V Power Supply
- CE2 Controls Unconditional Standby Mode
- Three-State Output

The Intel ${ }^{(8)}$ M5101 is an ultra-low power $256 \times 4$ CMOS RAM specified over the $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range. The RAM uses fully DC stable (static) circuitry and therefore requires no clocks or refreshing to operate. When deselected with CE2 low, the M5101 draws from the single 5 -volt supply only 200 microamps at $125^{\circ} \mathrm{C}$.
The Intel ${ }^{\circledR}$ M5101 is fabricated with an ion-implanted, silicon gate, Complementary MOS (CMOS) process. This technology allows the design and production of ultra-low power, high performance memories.



#### Abstract

Absolute Maximum Ratings * Ambient Temperature Under Bias . . $-65^{\circ} \mathrm{C}$ to $135^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage On Any Pin

With Respect to Ground $\ldots-0.3 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}+0.3 \mathrm{~V}$ Maximum Power Supply Voltage . . . . . . . . . +7.0 V Power Dissipation ...................... . . 1 Watt *COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.


## D. C. and Operating Characteristics for M5101-4, M5101L-4

$T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{L}}{ }^{[2]}$ | Input Current |  | 8 |  | nA | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\mathrm{I}_{\mathrm{LOH}^{[2]}}$ | Output High Leakage |  |  | 2 | $\mu \mathrm{A}$ | $\overline{\mathrm{CE1}}=2.2 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\text {LOL }}{ }^{[2]}$ | Output Low Leakage |  |  | 2 | $\mu \mathrm{A}$ | $\overline{\mathrm{CE} 1}=2.2 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.0 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Operating Current |  | 11 | 25 | mA | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \text { Except } \overline{\mathrm{CE} 1} \leqslant 0.01 \mathrm{~V}$ Outputs Open |
| ${ }^{\text {ICC2 }}$ | Operating Current |  | 20 | 32 | mA ${ }^{\prime}$ | $\mathrm{V}_{\mathrm{IN}}=2.2 \mathrm{~V} \text { Except } \overline{\mathrm{CE1}} \leqslant 0.5 \mathrm{~V}$ Outputs Open |
| $I_{\text {CCL }}{ }^{\text {2] }}$ | Standby Current |  | 2 | 200 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0$ to $V_{C C}$, Except $C E 2 \leqslant 0.2 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage | -0.3 |  | 0.5 | V |  |
| $V_{\text {IH }}$ | Input "High" Voltage | $\mathrm{V}_{\text {cc }}-2.0$ |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output "Low" Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output "High" Voltage | $\mathrm{V}_{\text {cc- }}$ 2.0 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=1.0 \mathrm{~mA}$ |

NOTES: 1. Typical values are $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. Current through all inputs and outputs included in $I^{\mathrm{C}} \mathrm{CL}$.

Low VCC Data Retention Characteristics (For M5101L-4) $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$

| Symbol | Parameter | Min. | Typ. [1] | Max. | Unit | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {DR }}$ | $\mathrm{V}_{\text {CC }}$ for Data Retention | 2.0 |  |  | V | CE2 $\leqslant 0.2 \mathrm{~V}$ |  |
| ICCDR | Data Retention Current |  | 2 | 200 | $\mu \mathrm{A}$ |  | $V_{D R}=2.0 \mathrm{~V}$ |
| ${ }^{\text {t }}$ CDR | Chip Deselect to Data Retention Time | 0 |  |  | ns |  |  |
| $\mathrm{t}_{\mathrm{R}}$ | Operation Recovery Time | $\mathrm{t}_{\mathrm{RC}}{ }^{[2]}$ |  |  | ns |  |  |

NOTES: 1. Typical values are $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. $\mathrm{t}_{\mathrm{R} C}=$ Read Cycle Time.

## A.C. Characteristics for M5101-4, M5101L-4

READ CYCLE $T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise specified.

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 800 |  |  | ns | (See below) |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time |  |  | 800 | ns |  |
| ${ }^{\text {t }} \mathrm{CO} 1$ | Chip Enable ( $\overline{\mathrm{CE}}$ ) to Output |  |  | 700 | ns |  |
| ${ }^{\text {c }} \mathrm{CO2}$ | Chip Enable (CE2) to Output |  |  | 850 | ns |  |
| ${ }_{\text {tod }}$ | Output Disable To Output |  |  | 350 | ns |  |
| ${ }^{\text {t }}$ DF | Data Output to High Z State | 0 |  | 150 | ns |  |
| ${ }^{\text {toH1 }}$ | Previous Read Data Valid with Respect to Address Change | 0 |  |  | ns |  |
| ${ }^{\text {toH2 }}$ | Previous Read Data Valid with Respect to Chip Enable | 0 |  |  | ns |  |

WRITE CYCLE

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {WC }}$ | Write Cycle | 800 |  |  | ns |  |
| $\mathrm{t}_{\text {AW }}$ | Write Delay | 150 |  |  | ns |  |
| $\mathrm{t}_{\text {CW1 }}$ | Chip Enable (CE1) To Write | 550 |  |  | ns |  |
| $\mathrm{t}_{\text {CW }}$ 2 | Chip Enable (CE2) To Write | 550 |  |  | ns |  |
| $\mathrm{t}_{\text {DW }}$ | Data Setup | 400 |  |  | ns |  |
| $\mathrm{t}_{\text {DH }}$ | Data Hold | (See below) |  |  |  |  |
| $\mathrm{t}_{\text {WP }}$ | Write Pulse | 100 |  |  | ns |  |
| $\mathrm{t}_{\text {WR }}$ | Write Recovery | 400 |  |  | ns |  |
| $\mathrm{t}_{\text {DS }}$ | Output Disable Setup | 50 |  |  | ns |  |

## A. C. CONDITIONS OF TEST

| Input Pulse Levels: $\quad 0.5$ Volt to $V_{C C}-2.0 \mathrm{Volt}$ |  |
| :--- | ---: |
| Input Pulse Rise and Fall Times: | 20 nsec |
| Timing Measurement Reference Level: $\quad 1.5 \mathrm{Volt}$ |  |
| Output Load: $\quad 1 \mathrm{TTL}$ Gate and $C_{L}=100 \mathrm{pF}$ |  |

Capacitance ${ }^{[3]}{ }_{T A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| Symbol | Test | Limits (pF) |  |
| :--- | :--- | :---: | :---: |
|  |  | Typ. | Max. |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance <br> (All Input Pins) $V_{\text {IN }}=0 \mathrm{~V}$ | 4 | 8 |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 8 | 12 |

NOTE: 3. This parameter is periodically sampled and is not $100 \%$ tested.

## Waveforms

## WRITE CYCLE



NOTES: 1. OD may be tied low for separate I/O operation.
2. During the write cycle, OD is "high" for common I/O and "don't care" for separate I/O operation.

## Low $\mathrm{V}_{\mathrm{Cc}}$ Data Retention



|  | $2114-2$ | $2114-3$ | 2114 | 2114 L 3 | 2114 L |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 200 | 300 | 450 | 300 | 450 |
| Max. Power Dissipation (mw) | 710 mw | 710 mw | 710 mw | 370 mw | 370 mw |

- High Density 18 Pin Package
- Identical Cycle and Access Times

■ Single +5V Supply

- No Clock or Timing Strobe Required

■ Completely Static Memory

- Directly TTL Compatible: All Inputs and Outputs
- Common Data Input and Output Using Three-State Outputs
- Pin-Out Compatible with 3605 and 3625 Bipolar PROMs

The Intel® 2114 is a 4096-bit static Random Access Memory organized as 1024 words by 4 -bits using N-channel Silicon-Gate MOS technology. It uses fully DC stable (static) circuitry throughout - in both the array and the decoding - and therefore requires no clocks or refreshing to operate. Data access is particularly simple since address setup times are not required. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided.

The 2114 is designed for memory applications where high performance, low cost, large bit storage, and simple interfacing are important design objectives. The 2114 is placed in an 18-pin package for the highest possible density.
It is directly TTL compatible in all respects: inputs, outputs, and a single +5 V supply. A separate Chip Select ( $\overline{C S}$ ) lead allows easy selection of an individual package when outputs are or-tied.
The 2114 is fabricated with Intel's N -channel Silicon-Gate technology - a technology providing excellent protection against contamination permitting the use of low cost plastic packaging.

PIN CONFIGURATION


LOGIC SYMBOL


## PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{9}$ | ADDRESS INPUTS | $\mathrm{V}_{\mathrm{CC}}$ POWER $(+5 \mathrm{~V})$ |
| :--- | :--- | :--- |
| $\overline{\mathrm{WE}}$ | WRITE ENABLE | GND GROUND |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |  |
| $\mathrm{I} / \mathrm{O}_{1}-\mathrm{I} / \mathrm{O}_{4}$ | DATA INPUT/OUTPUT |  |

BLOCK DIAGRAM


## 2114 FAMILY

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise noted.

| SYMBOL | PARAMETER | 2114-2, 2114-3, 2114 |  |  | 2114L3, 2114L |  |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |  |
| $I_{\text {LI }}$ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\\|_{\text {LO }}$ | I/O Leakage Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=2.4 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{I} / \mathrm{O}}=0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| $I_{\text {CC1 }}$ | Power Supply Current |  | 80 | 120 |  |  | 65 | mA | $\begin{aligned} & V_{I N}=5.25 \mathrm{~V}, I_{I / O}=0 \mathrm{~mA}, \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Power Supply Current |  | 90 | 135 |  |  | 70 | mA | $\begin{aligned} & V_{I N}=5.25 \mathrm{~V}, I_{I / O}=0 \mathrm{~mA}, \\ & T_{A}=0^{\circ} \mathrm{C} \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{cc}}$ | 2.4 |  | $\mathrm{V}_{\text {cc }}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{cc}}$ | 2.4 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |

## CAPACITANCE

| $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ |  |  |  |  |
| :--- | :--- | :---: | :---: | :--- |
| SYMBOL | TEST | MAX | UNIT | CONDITIONS |
| $\mathrm{C}_{\text {I/O }}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{\text {I/O }}=\mathrm{OV}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ |

NOTE: This parameter is periodically sampled and not $100 \%$ tested.
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise noted.

READ CYCLE ${ }^{[1]}$

|  | PARAMETER | 21142 |  | 2114.3, 2114L3 |  | 2114, 2114L |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle Time | 200 |  | 300 |  | 450 |  | ns |
| $\mathrm{t}_{\text {A }}$ | Access Time |  | 200 |  | 300 |  | 450 | ns |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Selection to Output Valid |  | 70 |  | 100 |  | 100 | ns |
| ${ }^{\text {t }} \mathrm{CX}$ | Chip Selection to Output Active | 0 |  | 0 |  | 0 |  | ns |
| totd | Output 3-state from Deselection | 0 | 40 | 0 | 80 | 0 | 100 | ns |
| toha | Output Hold from Address Change | 10 |  | 10 |  | 10 |  | ns |

WRITE CYCLE [2]

| SYMBOL | PARAMETER | 2114-2 |  | 2114-3, 2114L3 |  | 2114, 2114L |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| twc | Write Cycle Time | 200 |  | 300 |  | 450 |  | ns |
| tw | Write Time | 100 |  | 150 |  | 200 |  | ns |
| tWR | Write Release Time | 20 |  | 0 |  | 0 |  | ns |
| totw | Output 3-state from Write | 0 | 40 | 0 | 80 | 0 | 100 | ns |
| ${ }^{\text {d }}$ W | Data to Write Time Overlap | 100 |  | 150 |  | 200 |  | ns |
| ${ }^{\text {D }}$ H | Data Hold From Write Time | 0 |  | 0 |  | 0 |  | ns |

NOTES: 1. A Read occurs during the overlap of a low $\overline{\mathrm{CS}}$ and a high $\overline{W E}$.
2. A Write occurs during the overlap of a low $\overline{\mathrm{CS}}$ and a low $\overline{\mathrm{WE}}$.

## A.C. CONDITIONS OF TEST



## WAVEFORMS

## READ CYCLE (1)



## WRITE CYCLE

NOTES:

(1) $\overline{W E}$ is high for a Read Cycle.
(2) tw is measured from the latter of $\overline{C S}$ or $\overline{W E}$ going low to $\overline{W E}$ going high.
(3) WE must be high during all address transitions.
(4) tWR is referenced to the high transition of $\overline{W E}$.

## DATA STORAGE

When $\overline{W E}$ is high, the data input buffers are inhibited to prevent erroneous data from getting into the array. As long as $\overline{W E}$ remains high, the data stored cannot be affected by the address, Chip Select, or data I/O voltage levels and timing transitions. The block diagram also shows data storage cannot be affected by $\overline{W E}$, the addresses, nor the I/O ports as long as $\overline{\mathrm{CS}}$ is high. Either $\overline{\mathrm{CS}}$ or $\overline{\mathrm{WE}}$ by itself - or in conjunction with the other can prevent extraneous writing due to signal transitions.

Data within the array can only be changed during a Write time - defined as the overlap of $\overline{\mathrm{CS}}$ low and $\overline{\mathrm{WE}}$ low. To prevent the loss of data, the addresses must be properly established during the entire Write time plus $\mathrm{t}_{\text {WR }}$.

Internal delays on the 2114 are established such that address decoding propagates ahead of data inputs (keyed by the Write time). Therefore, it is permissable to establish the addresses coincident to the selection of a Write time, but no later. If the Write time precedes the addresses, the data in the previously addressed locations, or some other location, may be inadvertently changed.
While it is important that the addresses remain stable for the entire Write cycle, the data inputs are not required to remain stable. Appropriate voltage levels will be written into the cells as long as the data is stable for $\mathrm{t}_{\mathrm{DW}}$ at the end of the Write time.

|  | $2142-2$ | $2142-3$ | 2142 | 2142 L 2 | 2142 L 3 | 2142 L |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 200 | 300 | 450 | 200 | 300 | 450 |
| Max. Power Dissipation (mw) | 525 | 525 | 525 | 370 | 370 | 370 |

## - High Density 20 Pin Package

- Access Time Selections From 200-450ns
- Identical Cycle and Access Times

■ Low Operating Power Dissipation .1mW/Bit Typical
■ Single +5 V Supply

## - No Clock or Timing Strobe Required

- Completely Static Memory
- Directly TTL Compatible: All Inputs and Outputs


## - Common Data Input and Output Using Three-State Outputs

The Intel® 2142 is a 4096-bit static Random Access Memory organized as 1024 words by 4 -bits using N-channel SiliconGate MOS technology. It uses fully DC stable (static) circuitry throughout - in both the array and the decoding - and therefore requires no clocks or refreshing to operate. Data access is particularly simple since address setup times are not required. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided.
The 2142 is designed for memory applications 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 +5 V supply.
The 2142 is placed in a 20-pin package. Two Chip Selects $\left(\overline{C S}_{1}\right.$ and $\left.\mathrm{CS}_{2}\right)$ are provided for easy and flexible selection of individual packages when outputs are OR-tied. An Output Disable is included for direct control of the output buffers.
The 2142 is fabricated with Intel's N -channel Silicon-Gate technology - a technology providing excellent protection against contamination permitting the use of low cost plastic packaging.

## PIN CONFIGURATION

LOGIC SYMBOL


PIN NAMES

| $\mathrm{A}_{0}-\mathrm{Ag}$ | ADDRESS INPUTS | OD | OUTPUT DISABLE |
| :--- | :--- | :--- | :--- |
| $\overline{\mathrm{WE}}$ | WRITE ENABLE | VCC $^{2}$ | POWER ( +5 V ) |
| $\overline{\mathrm{CS}} 1, \mathrm{CS} 2$ | CHIP SELECT | GND | GROUND |
| $1 / \mathrm{O}_{1}-\mathrm{I} / \mathrm{O}_{4}$ | DATA INPUT/OUTPUT |  |  |

## BLOCK DIAGRAM



## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | $-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.5 V to +7 V |
| Power Dissipation | 1.0 W |
| D.C. Output Current | 10 mA |

*COMMENT: Stresses above those listed under"Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise noted.

| SYMBOL | PARAMETER | 2142-2, 2142-3, 2142 |  |  | 2142L2, 2142L3, 2142L |  |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {LI }}$ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0$ to 5.25 V |
| $\\|_{\text {LO }}$ | I/O Leakage Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=2.4 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{I} / \mathrm{O}}=0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Power Supply Current |  | 80 | 95 |  |  | 65 | mA | $\begin{aligned} & \mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}, \mathrm{I}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Power Supply Current |  |  | 100 |  |  | 70 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}, \mathrm{I}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |
| lOL | Output Low Current | 2.1 | 6.0 |  | 2.1 | 6.0 |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| IOH | Output High Current |  | -1.4 | -1.0 |  | -1.4 | -1.0 | mA | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| $\mathrm{lOS}^{[2]}$ | Output Short Circuit Current |  |  | 40 |  |  | 40 | mA | $\mathrm{V}_{1 / \mathrm{O}}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}$ |

NOTE: 1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{C}}=5.0 \mathrm{~V}$.
2. Duration not to exceed 30 seconds.

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$

| SYMBOL | TEST | MAX | UNIT | CONDITIONS |
| :--- | :--- | :---: | :---: | :--- |
| $\bar{ธ}_{\text {I/O }}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{1 / \mathrm{O}}=\mathrm{OV}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ |

NOTE: This parameter is periodically sampled and not $100 \%$ tested.
A.C. CONDITIONS OF TEST
Input Pulse Levels ..... 0.8 Volt to 2.4 Volt
Input Rise and Fall Times ..... 10 nsec
Input and Output Timing Levels ..... 1.5 Volts
Output Load1 TTL Gate and $C_{L}=100 \mathrm{pF}$
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise noted.

READ CYCLE ${ }^{[1]}$

| SYMBOL | PARAMETER | $\begin{gathered} \text { 2142-2, } 2142 \text { L2 } \\ \text { Min. Max. } \end{gathered}$ | $\begin{gathered} \text { 2142-3, 2142L3 } \\ \text { Min. Max. } \end{gathered}$ | $2142,2142 \mathrm{~L}$ <br> Min. Max. | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {RC }}$ | Read Cycle Time | 200 | 300 | 450 | ns |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time | 200 | 300 | 450 | ns |
| ${ }_{\text {tod }}$ | Output Enable to Output Valid | 70 | 100 | 120 | ns |
| todx | Output Enable to Output Active | 20 | 20 | 20 | ns |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Selection to Output Valid | 70 | 100 | 120 | ns |
| ${ }^{\text {t }}$ C ${ }^{\text {c }}$ | Chip Selection to Output Active | 20 | 20 | 20 | ns |
| $\mathrm{t}_{\text {OTD }}$ | Output 3-state from Disable | 60 | 80 | 100 | ns |
| toha | Output Hold from Address Change | 50 | 50 | 50 | ns |

WRITE CYCLE [2]

|  | PARAMETER | 2142-2, 2142L2 |  | 2142-3, 2142L3 |  | 2142, 2142L |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| twc | Write Cycle Time | 200 |  | 300 |  | 450 |  | ns |
| tw | Write Time | 120 |  | 150 |  | 200 |  | ns |
| $t_{\text {WR }}$ | Write Release Time | 0 |  | 0 |  | 0 |  | ns |
| totd | Output 3-state from Disable |  | 60 |  | 80 |  | 100 | ns |
| ${ }^{\text {t }}$ DW | Data to Write Time Overlap | 120 |  | 150 |  | 200 |  | ns |
| ${ }^{\text {t }}$ DH | Data Hold From Write Time | 0 |  | 0 |  | 0 |  | ns |

## NOTES:

1. A Read occurs during the overlap of a low $\overline{C S}$ and a high $\overline{W E}$.
2. A Write occurs during the overlap of a low $\overline{\mathrm{CS}}$ and a low $\overline{\mathrm{WE}}$.

## WAVEFORMS

READ CYCLE ${ }^{(3)}$

## WRITE CYCLE



NOTES:
(3) $\overline{W E}$ is high for a Read Cycle.
(4) $\overline{W E}$ must be high during all address transitions.


## TYPICAL D.C. AND A.C. CHARACTERISTICS

NORMALIZED ACCESS TIME VS.
SUPPLY VOLTAGE


NORMALIZED ACCESS TIME VS. OUTPUT LOAD CAPACITANCE


OUTPUT SOURCE CURRENT VS. OUTPUT VOLTAGE


NORMALIZED ACCESS TIME VS. AMBIENT TEMPERATURE


NORMALIZED POWER SUPPLY CURRENT VS. AMBIENT TEMPERATURE


OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE


2104A FAMILY
$4096 \times 1$ BIT DYNAMIC RAM

|  | $2104 A-1$ | $2104 A-2$ | $2104 A-3$ | $2104 \mathrm{~A}-4$ |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 150 | 200 | 250 | 300 |
| Read, Write Cycle (ns) | 320 | 320 | 375 | 425 |
| Max. IDD (mA) | 35 | 32 | 30 | 30 |

Highest Density 4K RAM Industry Standard 16 Pin Package<br>- Low Power 4K RAM<br>- All Inputs Including Clocks TTL Compatible<br>■ $\pm 10 \%$ Tolerance on All Power Supplies +12V, +5V, -5V

## Refresh Period: 2 ms

- On-Chip Latches for Addresses, Chip Select and Data In
Simple Memory Expansion: Chip Select
- Output is Three-State, TTL Compatible; Data is Latched and Valid into Next Cycle
Compatible with Intel ${ }^{\circledR} 2116$ 16K RAM

The Intel ${ }^{\circledR} 2104 \mathrm{~A}$ is a 4096 word by 1 bit MOS RAM fabricated with N -channel silicon gate technology for high performance and high functional density.
The efficient design of the 2104A allows it to be packaged in the industry standard 16 pin dual-in-line package. The 16 pin package provides the highest system bit densities and is compatible with widely available automated handling equipment.

The use of the 16 pin package is made possible by multiplexing the 12 address bits (required to address 1 of 4096 bits) into the 2104A on 6 address input pins. The two 6 bit address words are latched into the 2104A by the two TTL clocks, Row Address Strobe ( $\overline{\mathrm{RAS}}$ ) and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ). Non-critical clock timing requirements allow use of the multiplexing technique while maintaining high performance.
A new unique dynamic storage cell provides high speed along with low power dissipation and wide voltage margins. The memory cell requires refreshing for data retention. Refreshing is most easily accomplished by performing a read cycle at each of the 64 row addresses every 2 milliseconds.
The 2104A is designed for page mode operation, " $\overline{R A S}-$ only refreshing," and " $\overline{\mathrm{CAS}}-$ only deselection." Thus it is compatible with the Intel ${ }^{\circledR}$ 2116, 16K RAM.


PIN NAMES

| $A_{0} \cdot A_{5}$ | ADDRESS INPUTS | $\overline{\text { WE }}$ | WRITE ENABLE |
| :--- | :--- | :--- | :--- |
| $\overline{\text { CAS }}$ | COLUMN ADDRESS STROBE | $V_{B B}$ | POWER $(-5 \mathrm{~V})$ |
| $\overline{C S}$ | CHIP SELECT | $\mathrm{V}_{\mathrm{CC}}$ | POWER $(+5 \mathrm{~V})$ |
| IN $_{\text {IN }}$ | DATA IN | $\mathrm{V}_{\text {DD }}$ | POWER $(+12 \mathrm{~V})$ |
| DOUT | DATA OUT | $\mathrm{V}_{\text {SS }}$ | GROUND |
| RAS | ROW ADDRESS STROBE |  |  |



## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias ..... $-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on any Pin Relative to $V_{B B}$
$\left(V_{S S}-V_{B B} \geqslant 4.5 \mathrm{~V}\right) \ldots . . . . . . . . . .-2.3 V$ to +20 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 1.0W
Data Out Current . . . . . . . . . . . . . . . . . . . . . . . 50 mA

## *COMMENT:

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS ${ }^{[1]}$

$T_{A}=0^{\circ}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=+12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{(2)}$ | Max. |  |  |  |
| $\mathrm{I}_{\text {LI }}$ | Input Load Current (any input) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IL MIN }}$ to $\mathrm{V}_{\text {IH MAX }}$ |  |
| \|tol | Output Leakage Current for High Impedance State |  |  | 10 | $\mu \mathrm{A}$ | Chip deselected: $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{1 \mathrm{H}}$ $\mathrm{V}_{\text {OUT }}=0$ to 5.5 V |  |
| $\mathrm{IDD1}^{[3]}$ | $V_{\text {DD }}$ Standby Current |  | 0.7 | 2 | mA | $V_{\text {DD }}=13.2 \mathrm{~V}$ | $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{\mathrm{IH}}$. <br> Chip deselected prior to measurement. <br> See Note 5. |
|  |  |  | 0.7 | 1.5 | mA | $V_{D D}=12.6 \mathrm{~V}$ |  |
| ${ }^{\text {BB1 }}$ | $\mathrm{V}_{\text {BB }}$ Standby Current |  | 5 | 50 | $\mu \mathrm{A}$ | $V_{\text {DD }}=13.2 \mathrm{~V}$ |  |
| $\mathrm{IDD2}^{[3]}$ | Operating VDD Current (Device Selected) |  | 24 | 35 | mA | 2104A-1 | $\mathrm{t}_{\mathrm{CYC}}=320 \mathrm{~ns}$ |
|  |  |  | 22 | 32 | mA | 2104A-2 | $\mathrm{t}_{\mathrm{CYC}}=320 \mathrm{~ns}$ |
|  |  |  | 20 | 30 | mA | 2104A-3, 4 | $\mathrm{t}_{\mathrm{CYC}}=375 \mathrm{~ns}$ |
| $\mathrm{I}_{\mathrm{BB} 2}$ | Operating $\mathrm{V}_{\text {BB }}$ Current |  | 160 | 400 | $\mu \mathrm{A}$ | Device Selected. Min cycle time. |  |
| $\mathrm{ICC1}^{[4]}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current when Deselected |  |  | 10 | $\mu \mathrm{A}$ |  |  |
| IDD3 | Operating V ${ }_{\text {DD }}$ Current ( $\overline{\mathrm{RAS}}$-only cycle) |  | 12 | 25 | mA | 2104A-1, 2 | $\mathrm{t}_{\mathrm{CYC}}=320 \mathrm{~ns}$ |
|  |  |  | 10 | 22 | mA | 2104A-3, 4 | $\mathrm{t}_{\mathrm{CYC}}=375 \mathrm{~ns}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (any input) | -1.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.4 |  | 7.0 | V |  |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage | 0.0 |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{IOH}_{\mathrm{OH}}=-5 \mathrm{~mA}$ |  |

CAPACITANCE ${ }^{[6]}$
$T_{A}=25^{\circ} \mathrm{C}$

| Symbol | Test | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Input Capacitance ( $\mathrm{A}_{0}-\mathrm{A}_{5}$ ), $\mathrm{D}_{\text {IN }}, \overline{\mathrm{CS}}$ | 3 | 7 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |
| $\mathrm{C}_{12}$ | Input Capacitance $\overline{\text { RAS }}$, WRITE | 3 | 7 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |
| $\mathrm{C}_{0}$ | Output Capacitance (DOUT) | 4 | 7 | pF | $V_{\text {OUT }}=0 \mathrm{~V}$ |
| $\mathrm{C}_{13}$ | Input Capacitance $\overline{\mathrm{CAS}}$ | 6 | 7 | pF | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\text {SS }}$ |

Notes: 1. All voltages referenced to $V_{S S}$. The only requirement for the sequence of applying voltages to the device is that $V_{D D}, V_{C C}$, and $V_{\text {SS }}$ should never be 0.3 V or more negative than $V_{\text {BB }}$. After the application of supply voltages or after extended periods of operation without clocks, the device must perform a minimum of one initialization cycle (any vaiid memory cycles containing both $\overline{\mathrm{RAS}}$ and CAS) prior to normal operation.
2. Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal power supply voltages.
3. The I DD current flows to $\mathrm{V}_{\mathrm{SS}}$.
4. When chip is selected $V_{C C}$ supply current is dependent on output loading. $V_{C C}$ is connected to output buffer only.
5. The chip is deselected; i.e., output is brought to high impedance state by $\overline{\mathrm{CAS}}$-only cycle or by a read cycle with $\overline{\mathrm{CS}}$ at $\mathrm{V}_{1 H}$.
6. Capacitance measured with Boonton Meter.

## A.C.CHARACTERISTICS ${ }^{[1]}$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

## READ, WRITE, AND READ MODIFY WRITE CYCLES

| Symbol | Parameter | 2104A-1 |  | 2104A-2 |  | 2104A-3 |  | 2104A-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {treF }}$ | Time Between Refresh |  | 2 |  | 2 |  | 2 |  | 2 | ms |
| $t_{\text {R }} \mathrm{P}$ | $\overline{\text { RAS Precharge Time }}$ | 100 |  | 115 |  | 115 |  | 125 |  | ns |
| ${ }^{\text {t }} \mathrm{CP}$ | $\overline{\text { CAS Precharge Time }}$ | 60 |  | 80 |  | 110 |  | 110 |  | ns |
| $t_{\text {thCL }}{ }^{[2]}$ | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ Leading Edge Lead Time | 20 | 50 | 25 | 70 | 35 | 110 | 80 | 135 | ns |
| ${ }^{\text {t }}$ CRP | $\overline{\text { CAS }}$ to $\overline{\text { RAS }}$ Precharge Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| tren | $\overline{\text { RAS Hold Time }}$ | 100 |  | 130 |  | 140 |  | 165 |  | ns |
| ${ }^{\text {t }}$ CSH | $\overline{\text { CAS }}$ Hold Time | 150 |  | 200 |  | 250 |  | 300 |  | ns |
| ${ }^{\text {t }}$ AR | $\overline{\mathrm{RAS}}$ to Address or $\overline{\mathrm{CS}}$ Hold Time | 95 |  | 120 |  | 160 |  | 215 |  | ns |
| ${ }^{t}$ ASR | Row Address Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {taSC }}$ | Column Address or $\overline{\mathrm{CS}}$ Set-Up Time | -5 |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {traH }}$ | Row Address Hold Time | 20 |  | 25 |  | 35 |  | 80 |  | ns |
| ${ }^{\text {t }}$ CAH | Column Address or $\overline{\mathrm{CS}}$ Hold Time | 45 |  | 50 |  | 50 |  | 80 |  | ns |
| ${ }_{\text {t }}$ | Rise or Fall Time |  | 50 |  | 50 |  | 50 |  | 50 | ns |
| toff | Output Buffer Turn-Off Delay | 0 | 50 | 0 | 60 | 0 | 60 | 0 | 80 | ns |
| ${ }^{\text {t }}{ }^{\text {cac }}{ }^{[3]}$ | Access Time From $\overline{\mathrm{CAS}}$ |  | 100 |  | 130 |  | 140 |  | 165 | ns |
| $t_{\text {trAC }}{ }^{[3]}$ | Access Time From $\overline{\mathrm{RAS}}$ |  | 150 |  | 200 |  | 250 |  | 300 | ns |

## READ CYCLE

| Symbol | Parameter | 2104A-1 |  | 2104A-2 |  | 2104A-3 |  | 2104A-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Random Read or Write Cycle Time | 320 |  | 320 |  | 375 |  | 425 |  | ns |
| tras | $\overline{\text { RAS }}$ Fulse Width | 150 | 32000 | 200 | 32000 | 250 | 32000 | 300 | 32000 | ns |
| ${ }^{\text {t }}$ CAS | $\overline{\text { CAS }}$ Pulse Width | 100 |  | 130 |  | 140 |  | 165 |  | ns |
| tres | Read Command Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| tren | Read Command Hold Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| tDOH | Data Out Hold Time | 32 |  | 32 |  | 32 |  | 32 |  | $\mu \mathrm{s}$ |

## WRITE CYCLE ${ }^{[4]}$

| Symbol | Parameter | 2104A-1 |  | 2104A-2 |  | 2104A-3 |  | 2104A-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{R}} \mathrm{C}$ | Random Read or Write Cycle Time | 320 |  | 320 |  | 375 |  | 425 |  | ns |
| tras | $\overline{\text { RAS }}$ Pulse Width | 150 | 32000 | 200 | 32000 | 250 | 32000 | 300 | 32000 | ns |
| tcas | $\overline{\text { CAS }}$ Pulse Width | 100 |  | 130 |  | 140 |  | 165 |  | ns |
| twCs | Write Command Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| twCH | Write Command Hold Time | 55 |  | 75 |  | 75 |  | 80 |  | ns |
| tWCR | Write Command Hold Time Referenced to $\overline{\mathrm{RAS}}$ | 105 |  | 145 |  | 185 |  | 215 |  | ns |
| twp | Write Command Pulse Width | 45 |  | 55 |  | 75 |  | 80 |  | ns |
| trwL | Write Command to $\overline{\text { RAS }}$ Lead Time | 100 |  | 130 |  | 140 |  | 150 |  | ns |
| ${ }^{\text {t }}$ CWL | Write Command to $\overline{\mathrm{CAS}}$ Lead Time | 100 |  | 130 |  | 140 |  | 150 |  | ns |
| tDS | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }}$ D | Data-In Hold Time | 55 |  | 75 |  | 75 |  | 80 |  | ns |
| ${ }^{\text {t }}$ DHR | Data-In Hold Time Referenced to $\overline{\mathrm{RAS}}$ | 105 |  | 145 |  | 185 |  | 215 |  | ns |

## Notes: 1. All voltages referenced to $V_{S S}$. Minimum timings do not allow for $\mathrm{t}^{T}$ or skews.

2. $\overline{C A S}$ must remain at $V_{i H}$ a minimum of $t_{R C L}$ MIN after RAS switches to $V_{I L}$. To achieve the minimum guaranteed access time ( $t_{R A C}$ ), $\overline{C A S}$ must switch to $V_{I L}$ at or before $t_{R C L}$ of $t_{R A C}-t_{T}-t_{C A C}$ as described in the Applications Information on page 2-45. $t_{\text {t }}$ RCL MAX is given for reference only as tRAC - t CAC.
3. Load $=2$ TTL and 100 pF . See Applications Information.
4. In a write cycle DOUT latch will contain data written into cell. In a read-modify-write cycle DOUT latch will contain data read from ce!!. !f $\overline{W E}$ goes low after $\overline{\text { CAS }}$ and prior to TCAC, DOUT is indeterminate.

## WAVEFORMS

READ CYCLE


WRITE CYCLE


## A.C.CHARACTERISTICS ${ }^{[1]}$

$T_{A}=0^{\circ}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$, unless otherwise noted.

## READ-MODIFY-WRITE CYCLE

| Symbol | Parameter | 2104A-1 |  | 2104A-2 |  | 2104A-3 |  | 2104A-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {RWC }}$ | Read Modify Write Cycle Time ${ }^{\text {[2] }}$ | 350 |  | 445 |  | 505 |  | 575 |  | ns |
| tcrw | RMW Cycle $\overline{\text { CAS }}$ Width | 200 |  | 260 |  | 280 |  | 315 |  | ns |
| $t_{\text {RRW }}$ | RMW Cycle $\overline{\mathrm{RAS}}$ Width | 250 |  | 330 |  | 390 |  | 450 |  | ns |
| $\mathrm{t}_{\text {RWL }}$ | RMW Cycle $\overline{\mathrm{RAS}}$ Lead Time | 100 |  | 130 |  | 140 |  | 150 |  | ns |
| ${ }^{\text {t }}$ W ${ }^{\text {ch }}$ | RMW Cycle $\overline{\text { CAS }}$ Hold Time | 250 |  | 330 |  | 390 |  | 450 |  | ns |
| ${ }^{\text {t }}$ CWL | Write Command to $\overline{\mathrm{CAS}}$ Lead Time | 100 |  | 130 |  | 140 |  | 150 |  | ns |
| $t_{\text {WP }}$ | Write Command Pulse Width | 45 |  | 55 |  | 75 |  | 80 |  | ns |
| $\mathrm{t}_{\mathrm{RCS}}$ | Read Command Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {MOD }}$ | Modify Time | 0 | 10 | 0 | 10 | 0 | 10 | 0 | 10 | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ D | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }{ }_{\text {DH }}}$ | Data-In Hold Time | 55 |  | 75 |  | 75 |  | 80 |  | ns |

Notes: 1. All voltages referenced to $V_{\text {SS }}$.
2. The minimum cycle timing does not allow for ${ }^{t_{T}}$ or skews.

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE



Notes: 1.2. $V_{I H M I N}$ and $V_{I L M A X}$ are reference levels for measuring timing of input signals.
3,4. $V_{\text {OHMIN }}$ and VOLMAX are reference levels for measuring timing of DOUT.
5. In a write cycle DOUT latch will contain data written into cell. In a read-modify-write cycle DOUT latch will contain data read from cell. If $\overline{W E}$ goes low after $\overline{C A S}$ and prior to $I_{C A C, ~ D O U T ~ i s ~ i n d e t e r m i n a t e . ~}^{\text {O }}$

## TYPICAL CHARACTERISTICS



## APPLICATIONS

## ADDRESSING

Two externally applied negative going TTL clocks, Row Address Strobe ( $\overline{\mathrm{RAS}}$ ), and Column Address Strobe (टAS), are used to strobe the two sets of 6 addresses into internal address buffer registers. The first clock, $\overline{\mathrm{RAS}}$, strobes in the six low order addresses ( $\mathrm{A}_{0}-\mathrm{A}_{5}$ ) which selects one of 64 rows and begins the timing which enables the column sense amplifiers. The second clock, $\overline{\text { CAS, strobes in the six high order addresses }\left(A_{6}-A_{11}\right) \text { to }}$ select one of 64 column sense amplifiers and Chip Select ( $\overline{\mathrm{CS}}$ ) which enables the data out buffer.

An address map of the 2104A is shown below. Address " 0 "* corresponds to all addresses at $\mathrm{V}_{\text {IL }}$. All addresses are sequentially located on the chip.


## DATA CYCLES/TIMING

A memory cycle begins with addresses stable and a negative transition of $\overline{\text { RAS }}$. See the waveforms on page 4. It is not necessary to know whether a Read or Write cycle is to be performed until $\overline{\mathrm{CAS}}$ becomes valid.
Note that Chip Select ( $\overline{\mathrm{CS}}$ ) does not have to be valid until the second clock, $\overline{C A S}$. It is, therefore, possible to start a memory cycle before it is known which device must be selected. This can result in a significant improvement in
system access time since the decode time for chip select does not enter into the calculation for access time.

Both the $\overline{R A S}$ and $\overline{\text { CAS }}$ clocks are TTL compatible and do not require level shifting and driving at high voltage MOS levels. Buffers internal to the 2104A convert the TTL level signals to MOS levels inside the device. Therefore, the delay associated with external TTL-MOS level converters is not added to the 2104A system access time.

## READ CYCLE

A Read cycle is performed by maintaining Write Enable ( $\overline{\mathrm{WE}}$ ) high during $\overline{\mathrm{CAS}}$. The output pin of a selected device will unconditionally go to a high impedance state immediately following the leading edge of $\overline{\mathrm{CAS}}$ and remain in this state until valid data appears at the output at access time. The selected output data is internally latched and will remain valid until a subsequent $\overline{\mathrm{CAS}}$ is given to the device by a Read, Write, Read-Modify-Write, CAS only or Refresh cycle. Data-out goes to a high impedance state for all non-selected devices.
Device access time, $\mathrm{t}_{\mathrm{ACC}}$, is the longer of two calculated intervals:

$$
\text { 1. } t_{\mathrm{ACC}}=\mathrm{t}_{\mathrm{RAC}} \quad O R \text { 2. } \quad \mathrm{t}_{\mathrm{ACC}}=\mathrm{t}_{\mathrm{RCL}}+\mathrm{t}_{\mathrm{T}}+\mathrm{t}_{\mathrm{CAC}}
$$

Access time from $\overline{R A S}, t_{\text {RAC }}$, and access time from $\overline{\text { CAS }}$, $t_{\text {CAC }}$, are device parameters. Row to column address strobe lead time, $t_{\text {RCL }}$, and transition time, $t_{T}$, are system dependent timing parameters. For example, substituting the device parameters of the 2104A-4 and assuming a TTL level transition time of 5 ns yields:
3. $t_{\mathrm{ACC}}=\mathrm{t}_{\mathrm{RAC}}=300 \mathrm{~ns}$ for $80 \mathrm{nsec} \leqslant \mathrm{t}_{\mathrm{RCL}} \leqslant 130 \mathrm{nsec}$ OR
4. $t_{\mathrm{ACC}}=\mathrm{t}_{\mathrm{RCL}}+\mathrm{t}_{\mathrm{T}}+\mathrm{t}_{\mathrm{CAC}}=\mathrm{t}_{\mathrm{RCL}}+170 \mathrm{~ns}$ for $\mathrm{t}_{\mathrm{RCL}}>130 \mathrm{~ns}$.

Note that if 80 nsec $\leqslant t_{R C L} \leqslant 130$ nsec, device access time is determined by equation 3 and is equal to $t_{\text {RAC }}$. If $t_{R C L}>130$ nsec, access time is determined by equation 4 . This 50 ns interval (shown in the $t_{\text {RCL }}$ inequality in equation 3 ) in which the falling edge of $\overline{\mathrm{CAS}}$ can occur without affecting access time is provided to allow for system timing skew in the generation of CAS. This allowance for a $t_{\text {RCL }}$ skew is designed in at the device level to allow minimum access times to be achieved in practical system designs.

## WRITE CYCLE

A Write Cycle is generally performed by bringing Write Enable ( $\overline{\mathrm{WE}}$ ) low before $\overline{\mathrm{CAS}}$. Dout will be the data written into the cell addressed. If $\overline{W E}$ goes low after $\overline{\mathrm{CAS}}$ and prior to $t_{C A C}$, Dout will be indeterminate.

## READ-MODIFY-WRITE CYCLE

A Read-Modify-Write Cycle is performed by bringing Write Enable (WE) low after access time, $t_{\text {RAC }}$, with $\overline{R A S}$ and $\overline{C A S}$ low. Data in must be valid at or before the falling edge of $\overline{W E}$. In a read-modify-write cycle Dout is data read and does not change during the modify-write portion of the cycle.

## CAS ONLY (DESELECT) CYCLE

In some applications, it is desirable to be able to deselect all memory devices without running a regular memory cycle. This may be accomplished with the 2104A by performing a $\overline{\text { CAS }}$-Only Cycle. Receipt of a $\overline{\mathrm{CAS}}$ without $\overline{\mathrm{RAS}}$ deselects the 2104A and forces the Data Output to the high-impedance state. This places the 2104A in its lowest power, standby condition. I ${ }_{D D}$ will be about twice $I_{D D 1}$ for the first cycle of $\overline{C A S}$-only deselection and IDD1 for any additional $\overline{\mathrm{CAS}}$-only cycles. The cycle timing and $\overline{\mathrm{CAS}}$ timing should be just as if a normal RAS/CAS cycle was being performed.

## CHIP SELECTION/DESELECTION

The 2104A is selected by driving $\overline{\mathrm{CS}}$ low during a Read,


Write, or Read-Modify-Write cycle. A device is deselected by 1) driving $\overline{\mathrm{CS}}$ high during a Read, Write, or Read-Modify-Write cycle or 2) performing a $\overline{\mathrm{CAS}}$ Only cycle independent of the state of $\overline{\mathrm{CS}}$.

## REFRESH CYCLES

Each of the 64 rows internal to the 2104A must be refreshed every 2 msec to maintain data. Any data cycle (Read, Write, Read-Modify-Write) refreshes the entire selected row (defined by the low order row addresses). The refresh operation is independent of the state of chip select. It is evident, of course, that if a Write or Read-Modify-Write cycle is used to refresh a row, the device should be deselected ( $\overline{\mathrm{CS}}$ high) if it is desired not to change the state of the selected cell.

## $\overline{\text { RAS }} / \overline{\mathbf{C A S}}$ TIMING

The device clocks, $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$, control operation of the 2104A. The timing of each clock and the timing relationships of the two clocks must be understood by the user in order to obtain maximum performance in a memory system.

The $\overline{R A S}$ and $\overline{\text { CAS }}$ have minimum pulse widths as defined by $t_{\text {RAS }}$ and $t_{\text {Cas }}$ respectively. These minimum pulse widths must be maintained for proper device operation and data integrity. A cycle, once begun by driving $\overline{\text { RAS }}$ and/or $\overline{\mathrm{CAS}}$ low must not be ended or aborted prior to fulfilling the minimum clock signal pulse width(s). A new cycle must not begin until the minimum precharge time, $t_{R P}$, has been met.

## PAGE MODE OPERATION

The 2104A is designed for page mode operation and is presently being characterized for that mode. Specifications will be available at a later date.

## POWER SUPPLY

Typical power supply current waveforms versus time are shown below for both a $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ cycle and a $\overline{\mathrm{CAS}}$ only cycle. $I_{D D}$ and $I_{B B}$ current surges at $\overline{R A S}$ and $\overline{C A S}$ edges make adequate decoupling of these supplies important. Due to the high frequency noise component content of the current waveforms, the decoupling capacitors should be low inductance, ceramic units selected for their high frequency performance.

It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be connected between $V_{D D}$ and $V_{S S}$ at every other device in the memory array. A $0.1 \mu \mathrm{~F}$ ceramic capacitor should also be connected between $V_{B B}$ and $V_{S S}$ at every other device (preferably the alternate devices to the $\mathrm{V}_{D D}$ decoupling). For each 16 devices, a $10 \mu \mathrm{~F}$ tantalum or equivalent capacitor should be connected between $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ near the array. An equal or slightly smaller bulk capacitor is also recommended between $V_{B B}$ and $V_{S S}$ for every 32 devices.
A $0.01 \mu \mathrm{~F}$ ceramic capacitor is recommended between $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\text {SS }}$ at every eighth device to prevent noise coupling to the $V_{\text {CC }}$ line which may affect the TTL peripheral logic in the system.

Due to the high frequency characteristics of the current waveforms, the inductance of the power supply distribution system on the array board should be minimized. It is recommended that the $V_{D D}, V_{B B}$, and $V_{S S}$ supply lines be
gridded both horizontally and vertically at each device in the array. This technique allows use of double-sided circuit boards with noise performance equal to or better than multi-layered circuit boards.


DECOUPLING CAPACITORS
$D=0.1 \mu \mathrm{~F}$ to $\mathrm{V}_{\mathrm{DD}}$ TO $\mathrm{V}_{\mathrm{SS}}$
$B=0.1 \mu \mathrm{~F} \mathrm{~V}_{\mathrm{BB}}$ TO $\mathrm{V}_{\mathrm{SS}}$
$\mathrm{C}=0.01 \mu \mathrm{~F} \mathrm{~V}_{\mathbf{C C}}$ TO $\mathrm{V}_{\text {SS }}$

# 2107B 4096 BIT DYNAMIC RAM 

|  | 2107 B | $2107 \mathrm{~B}-4$ | $2107 \mathrm{~B}-5$ |
| :--- | :---: | :---: | :---: |
| Access Time | 200 ns | 270 ns | 300 ns |
| Read,Write Cycle | 400 ns | 470 ns | 590 ns |
| RMW Cycle | 520 ns | 590 ns | 750 ns |

- Low Cost Per Bit
- Low Standby Power
- Easy System Interface
- Only One High Voltage Input Signal - Chip Enable
- TTL Compatible - All Address, Data, Write Enable, Chip Select Inputs
- Refresh Period-2ms for 2107B, 2107B-4, 1ms for 2107B-5 @70 ${ }^{\circ} \mathrm{C}$
- Address Registers Incorporated on the Chip
- Simple Memory Expansion - Chip Select Input Lead
- Fully Decoded - On Chip Address Decode
- Output is Three State and TTL Compatible - Industry Standard 22-Pin Configuration

The Intel 2107 B is a 4096 word by 1 bit dynamic n -channel MOS RAM. It was designed for memory applications where very low cost and large bit storage are important design objectives. The 2107 B uses dynamic circuitry which reduces the standby power dissipation.

Reading information from the memory is non-destructive. Refreshing is most easily accomplished by performing one read cycle on each of the 64 row addresses. Each row address must be refreshed every two milliseconds. The memory is refreshed whether Chip Select is a logic one or a logic zero.

The 2107 B is fabricated with $n$-channel silicon gate technology. This technology allows the design and production of high performance, easy to use MOS circuits and provides a higher functional density on a monolithic chip than other MOS technologies. The 2107B uses a single transistor cell to achieve high speed and low cost. It is a replacement for the 2107A.

PIN CONFIGURATION


LOGIC SYMBOL


PIN NAMES

| $A_{0} \cdot A_{11}$ | ADDRESS INPUTS* | $V_{B B}$ | POWER (-5V) |
| :---: | :---: | :---: | :---: |
| CE | CHIP ENABLE | $V_{c c}$ | POWER ( +5 V ) |
| $\overline{\text { CS }}$ | CHIP SELECT | $V_{D D}$ | POWER ( +12 V ) |
| $\mathrm{D}_{\text {IN }}$ | DATA INPUT | $\mathrm{V}_{\text {SS }}$ | GROUND |
| $\overline{\text { OUT }}$ | DATA OUTPUT | WE | WRITE ENABLE |
| NC | NOT CONNECTED |  |  |

-Refresh Address $A_{0} \cdot A_{5}$.

## Absolute Maximum Ratings*

| Temperature Under Bias | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages with Respect to the most Negative Supply Voltage, $V_{B B}$ | +25 V to -0.3 V |
| Supply Voltages $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{CC}}$, and $\mathrm{V}_{\mathrm{SS}}$ with Respect to $\mathrm{V}_{\mathrm{BB}}$ | +20 V to -0.3 V |
| Power Dissipation | 1.25 W |

*COMMENT:
Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for ex tended periods may affect device reliability.

## D.C. and Operating Characteristics

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}{ }^{[1]}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [2] | Max. |  |  |
| ${ }_{L L I}{ }^{[6]}$ | Input Load Current (all inputs except CE) |  | . 01 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=V_{\text {IL MIN }} \text { to } V_{\text {IH MAX }} \\ & C E=V_{\text {ILC }} \text { or } V_{\text {IHC }} \end{aligned}$ |
| ILC | Input Load Current |  | . 01 | 2 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IL MIN }}$ to $\mathrm{V}_{\text {IH MAX }}$ |
| \|lol | Output Leakage Current for high impedance state |  | . 01 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & C E=V_{I L C} \text { or } \overline{C S}=V_{I H} \\ & V_{O}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \end{aligned}$ |
| IDD1 | $V_{D D}$ Supply Current during CE off[3] |  | 110 | $200{ }^{[5]}$ | $\mu \mathrm{A}$ | $C E=-1 V$ to +.6 V |
| IDD2 | $V_{\text {DD }}$ Supply Current during CE on |  |  | 60 | mA | $C E=V_{I H C}, \overline{C S}=V_{I L}$ |
| IdDAV | Average $\mathrm{V}_{\text {DD }}$ Current |  | 38 | 54 | mA | $\begin{aligned} \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}} ; \mathrm{T}_{\mathrm{A}}= & 25^{\circ} \mathrm{C}: \text { Min cycle time, } \\ & \text { Min } \mathrm{t}_{\mathrm{CE}} \end{aligned}$ |
| $\mathrm{ICC1}^{[4]}$ | $V_{C C}$ Supply Current during CE off |  | . 01 | 10 | $\mu \mathrm{A}$ | $C E=V_{\text {ILC }}$ or $\overline{C S}=V_{1 H}$ |
| $\mathrm{I}_{\mathrm{BB}}$ | VBB Supply Current |  | 5 | 400 | $\mu \mathrm{A}$ |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -1.0 |  | 0.6 | V | $\mathrm{t}_{T}=20 \mathrm{~ns}, \mathrm{~V}_{\text {ILC }}=+1.0 \mathrm{~V}$ |
| $\mathrm{V}_{1 \text { H }}$ | Input High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V | $\mathrm{t}_{\mathrm{T}}=20 \mathrm{~ns}$ |
| $\mathrm{V}_{\text {ILC }}$ | CE Input Low Voltage | -1.0 |  | +1.0 | V |  |
| $\mathrm{V}_{\text {IHC }}$ | CE Input High Voltage | $V_{D D-1}$ |  | $\mathrm{V}_{D D}+1$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage | 0.0 |  | 0.45 | V | $\mathrm{IOL}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V | $\mathrm{IOH}=-2.0 \mathrm{~mA}$ |

## NOTES:

1. The only requirement for the sequence of applying voltage to the device is that $V_{D D}, V_{C C}$, and $V_{S S}$ should never be .3 V or more negative than $\mathrm{V}_{\mathrm{BB}}$.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply voltages.
3. The IDD and ICC currents flow to $V_{S S}$. The I $I_{B B}$ current is the sum of all leakage currents.
4. During CE on $V_{C C}$ supply current is dependent on output loading, $\mathrm{V}_{\mathrm{C}}$ is connected to output buffer only.
5. Maximum IDD1 for 2107B-5 is $250 \mu \mathrm{~A}$.
6. During CE high a current of 0.5 mA typical, 1.5 mA maximum will be drawn from any address pin which is switched from low to high.
A. C. Characteristics $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%, V_{C C}=5 \mathrm{~V} \pm 10 \%, V_{B B}=-5 \mathrm{~V} \pm 5 \%$,

READ, WRITE, AND READ MODIFY/WRITE CYCLE $V_{S S}=0 V$, unless otherwise noted.

| Symbol | Parameter | 2107B |  | 2107B-4 |  | 2107B-5 |  | Units | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\text {REF }}$ | Time Between Refresh |  | 2 |  | 2 |  | 1 | ms | 7 |
| $\mathrm{t}_{\mathrm{AC}}$ | Address to CE Set Up Time | 0 |  | 0 |  | 10 |  | ns | 3 |
| ${ }^{\text {t }}$ AH | Address Hold Time | 100 |  | 100 |  | 100 |  | ns |  |
| $\mathrm{t}_{\mathrm{CC}}$ | CE Off Time | 130 |  | 130 |  | 200 |  | ns |  |
| ${ }^{\text {t }}$ | CE Transition Time | 10 | 40 | 10 | 40 | 10 | 40 | ns |  |
| ${ }^{\text {t }}$ CF | CE Off to Output High Impedance State | 0 |  | 0 |  | 0 |  | ns |  |

READ CYCLE

| Symbol | Parameter | 2107B |  | 2107B-4 |  | 2107B-5 |  | Units | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\mathrm{C}} \mathrm{Y}$ | Cycle Time | 400 |  | 470 |  | 590 |  | ns | 4 |
| $\mathrm{t}_{\text {ce }}$ | CE On Time | 230 | 4000 | 300 | 4000 | 350 | 3000 | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | CE Output Delay |  | 180 |  | 250 |  | 280 | ns | 5 |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to Output Access |  | 200 |  | 270 |  | 300 | ns | 6 |
| twL | CE to $\overline{\mathrm{WE}}$ | 0 |  | 0 |  | 0 |  | ns |  |
| twc | $\overline{W E}$ to CE On | 0 |  | 0 |  | 0 |  | ns |  |

## WRITE CYCLE

| Symbol | Parameter | 2107B |  | 2107B-4 |  | 2107B-5 |  | Units | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| ${ }^{\text {t }} \mathrm{CY}$ | Cycle Time | 400 |  | 470 |  | 590 |  | ns | 4 |
| $\mathrm{t}_{\mathrm{CE}}$ | CE On Time | 230 | 4000 | 300 | 4000 | 350 | 3000 | ns |  |
| $t_{W}$ | $\overline{W E}$ to CE Off | 125 |  | 150 |  | 200 |  | ns |  |
| ${ }_{\text {t }}{ }_{\text {W }}$ | CE to $\overline{\mathrm{WE}}$ | 150 |  | 150 |  | 150 |  | ns |  |
| tow | $\mathrm{D}_{\text {IN }}$ to WE Set Up | 0 |  | 0 |  | 0 |  | ns | 1 |
| ${ }^{\text {D }}$ H | $\mathrm{D}_{\text {IN }}$ Hold Time | 0 |  | 0 |  | 0 |  | ns |  |
| twP | $\overline{\text { WE Pulse Width }}$ | 50 |  | 50 |  | 75 |  | ns |  |
| ${ }^{t}$ ww | $\overline{\text { WE Delay }}$ | 75 |  | 75 |  | 75 |  | ns |  |

Capacitance ${ }^{[2]} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Test | Plastic And Ceramic Pkg. Typ. Max. |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {AD }}$ | Address Capacitance, $\overline{\mathrm{CS}}$ | 4 | 6 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |
| $\mathrm{C}_{\text {CE }}$ | CE Capacitance | 17 | 25 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |
| Cout | Data Output Capacitance | 5 | 7 | pF | $V_{\text {OUT }}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\text {IN }}$ | $\mathrm{DIN}_{\text {IN }}$ and WE Capacitance | 8 | 10 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |

Notes: 1. If $\overline{W E}$ is low before $C E$ goes high then $D_{I N}$ must be valid when $C E$ goes high.
2. Capacitance measured with Boonton Meter or effective capacitance calculated from the equation. $C=\frac{I \Delta t}{\Delta V}$ with the current equal to a constant 20 mA .
3. $\mathrm{t}_{\mathrm{AC}}$ is measured from end of address transition.
4. $\mathbf{t}_{\mathrm{T}}=20 \mathrm{~ns}$
5. $\mathrm{C}_{\text {LOAD }}=50 \mathrm{pF}$, Load $=$ One TTL Gate, Ref $=2.0 \mathrm{~V}$.
6. $t_{A C C}=t_{A C}+t_{C O}+1 t_{T}$
7. $\mathrm{t}_{\text {REF }}=\mathbf{2 m s}$ at $\mathrm{T}_{A}=55^{\circ} \mathrm{C}$ for the 2107B-5.

Read and Refresh Cycle ${ }^{[1]}$


## Write Cycle



NOTES: 1. For Refresh cycle row and column addresses must be stable before $t_{A C}$ and remain stable for entire $t_{A H}$ period.
2. $V_{I L} M A X$ is the reference level for measuring timing of the addresses, $\overline{C S}, \overline{W E}$, and $D_{I N}$.
3. $V_{I H}$ MIN is the reference level for measuring timing of the addresses, $\overline{C S}, \overline{W E}$, and $D_{I N}$.
4. $\mathrm{V}_{\mathrm{SS}}+2.0 \mathrm{~V}$ is the reference level for measuring timing of CE .
5. $V_{D D}-2 V$ is the reference level for measuring timing of $C E$.
6. $\mathrm{V}_{\mathrm{SS}}+2.0 \mathrm{~V}$ is the reference level for measuring the timing of $\overline{\mathrm{DOUT}_{\mathrm{OS}}}$.
7. During CE high typically 0.5 mA will be drawn from any address pin which is switched from low to high.

## Read Modify Write Cycle ${ }^{[1]}$

| Symbol | Parameter | 2107B |  | 2107B-4 |  | 2107B-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| trwC | Read Modify Write (RMW) Cycle Time | 520 |  | 590 |  | 750 |  | ns |
| $\mathrm{t}_{\text {CRW }}$ | CE Width During RMW | 350 | 4000 | 420 | 4000 | 510 | 3000 | ns |
| twc | $\overline{W E}$ to CE on | 0 |  | 0 |  | 0 |  | ns |
| ${ }_{\text {t }}$ W | $\overline{W E}$ to CE off | 150 |  | 150 |  | 200 |  | ns |
| $t_{W P}$ | $\overline{\text { WE Pulse Width }}$ | 50 |  | 50 |  | 100 |  | ns |
| tow | $\mathrm{D}_{\text {IN }}$ to $\overline{\mathrm{WE}}$ Set Up | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{DH}}$ | DIN Hold Time | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{CO}}$ | CE to Output Delay |  | 180 |  | 250 |  | 280 | ns |
| ${ }^{\text {t }}$ ACC | Access Time $\left(\mathrm{t}_{\mathrm{ACC}}=\mathrm{t}_{\mathrm{AC}}+\mathrm{t}_{\mathrm{CO}}+1 \mathrm{t}_{\mathrm{T}}\right)$ |  | 200 |  | 270 |  | 300 | ns |



NOTES: 1. Minimum cycle timing is based on $\mathrm{t}_{\mathrm{T}}$ of 20 ns .
2. $V_{I L} M A X$ is the reference level for measuring timing of the addresses, $\overline{C S}, \overline{W E}$, and $D_{I N}$
3. $V_{I H}$ MIN is the reference level for measuring timing of the addresses, $\overline{C S}, \overline{W E}$, and $D_{I N}$.
4. $V_{S S}+2.0 \mathrm{~V}$ is the reference level for measuring timing of $C E$.
5. $V_{D D}-2 V$ is the reference level for measuring timing of $C E$.
6. $V_{S S}+2.0 \mathrm{~V}$ is the reference level for measuring the timing of $\overline{D_{O U T}} . C_{L O A D}=50 p F$. Load $=O n e T T L$ Gate.
7. WE must be at $V_{1 H}$ until end of $t_{C O}$.
8. During CE high typically 0.5 mA will be drawn from any address pin which is switched from low to high.

## Typical Characteristics

Fig. 1. 'DD AV VS. TEMPERATURE


Fig. 3. IDD2 VS. TEMPERATURE


Fig. 2. TYPICAL IDD AVERAGE VS. CYCLE TIME


Fig. 4. TYPICAL VIL MAX VS. CE RISE TIME


## Typical Current Transients vs. Time



For additional typical characteristics and applications information please refer to Intel Application Note AP-10, "Memory System Design With the Intel 2107B 4K RAM' or Intel's Memory Design Handbook.

## 2116 FAMILY

## 16,384 X 1 BIT DYNAMIC RAM

|  | $2116-2$ | $2116-3$ | $2116-4$ |
| :--- | :---: | :---: | :---: |
| Max. Access Time (ns) | 200 | 250 | 300 |
| Read, Write Cycle (ns) | 350 | 375 | 425 |
| Read-Modify-Write Cycle (ns) | 400 | 525 | 595 |

## Highest Density 16K RAM: Industry Standard 16 Pin Package <br> - Low Standby Power <br> - All Inputs Including Clocks TTL Compatible - $\pm 10 \%$ Tolerance on all Power Supplies +12V, $+5 \mathrm{~V},-5 \mathrm{~V}$

> On-Chip Latches for Address and Data In
> - Only 64 Refresh Cycles Required Every 2 ms
> - Output is Three-State, TTL Compatible; Data is Latched and Valid into Next Cycle

## Absolute Maximum Ratings*

*COMMENT:
Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. and Operating Characteristics [1],[2]

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{(3)}$ | Max. |  |  |  |
| $I_{\text {LI }}$ | Input Load Current (any input) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IL MIN }}$ to $\mathrm{V}_{\text {IH MAX }}$ |  |
| \|lol | Output Leakage Current for high impedance state |  | 0.1 | 10 | $\mu \mathrm{A}$ | Chip deselected: $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{1 H}$ $\mathrm{V}_{\text {OUT }}=0$ to 5.5 V |  |
| IDD1 | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 1.2 | 2 | mA | $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{\text {IH }}$ or $\overline{\text { CAS-only }}$ cycle. Chip deselected prior to measurement. See Note 5. |  |
| $\mathrm{I}_{\mathrm{BB} 1}$ | $\mathrm{V}_{\text {BB }}$ Supply Current |  | 1 | 50 | $\mu \mathrm{A}$ |  |  |
| $1 \mathrm{IDD2}^{[4]}$ | Operating $\mathrm{V}_{\text {DD }}$ Current |  | 53 | 69 | mA | 2116-2 ${ }^{\text {t }} \mathrm{CYC}=350 \mathrm{~ns}$ | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> Device selected. See Note 6. |
|  |  |  | 51 | 68 | mA | 2116-3 $t_{C Y C}=375 \mathrm{~ns}$ |  |
|  |  |  | 49 | 65 | mA | 2116-4 $\mathrm{t}_{\mathrm{CYC}}=425 \mathrm{~ns}$ |  |
| $\mathrm{I}_{\mathrm{BB} 2}$ | Operating V ${ }_{\text {BB }}$ Current |  | 120 | 400 | $\mu \mathrm{A}$ | Device selected |  |
| $\mathrm{ICC1}^{[7]}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current when deselected |  |  | 10 | $\mu \mathrm{A}$ |  |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage (any input) | -1.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (any input) | 2.4 |  | $\mathrm{V}_{\mathrm{CC}^{+1}}$ | V |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | 0.0 |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=4.1 \mathrm{~mA}$ (Read Cyc | Only) |
| VOH | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V | $\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}$ (Read Cyc | Only) |

Capacitance ${ }^{[8]} T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Typ. | Max. | Unit | Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Address, Data In \& $\overline{\mathrm{WE}}$ Capacitance | 4 | 7 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |
| $\mathrm{C}_{12}$ | $\overline{\mathrm{RAS}}$ Capacitance | 3 | 5 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |
| $\mathrm{C}_{13}$ | $\overline{\mathrm{CAS}}$ Capacitance | 6 | 10 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ |
| $\mathrm{C}_{\mathrm{O}}$ | Data Output Capacitance | 3 | 7 | pF | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ |

## Notes:

1. All voltages referenced to $\mathrm{V}_{\mathrm{SS}}$. No power supply sequencing is required but $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{CC}}$, and $\mathrm{V}_{\mathrm{SS}}$ should never be 0.3 V or more negative than $\mathrm{V}_{\mathrm{BB}}$.
2. To avoid self-clocking, $\overline{\mathrm{RAS}}$ should not be allowed to float.
3. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply voltages.
4. For $\overline{\mathrm{RAS}}$-only refresh IDD $=0.78 \mathrm{I}_{\mathrm{DD} 2}$. For $\overline{\mathrm{CAS}}$-before- $\overline{\mathrm{RAS}}\left(64\right.$ cycle refresh) IDD $=0.96 \mathrm{I}_{\mathrm{DD}}$.
5. The chip is deselected (i.e., output is brought to high impedance state) by $\overline{C A S}-$ only cycle or by $\overline{\mathrm{CAS}}$-before- $\overline{\mathrm{RAS}}$ cycle. The current flowing in a selected (i.e., output on) chip with $\overline{\text { RAS }}$ and $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{I H}$ is approximately twice IDD1.
6. See Page $2-98$ for typical IDD characteristics under other conditions.
7. When chip is selected $V_{C C}$ supply current is dependent on output loading; $\mathrm{V}_{\mathrm{CC}}$ is connected to output buffer only.
8. Capacitance measured with Boonton Meter.

## Typical Characteristics

IBB2 AND IDD2 VS. TEMPERATURE


Figure 1.
IDD2 VS. CYCLE TIME


Figure 2.

## Standby Power Calculations:

$P_{\text {REF }}=P_{O P}\left(N \frac{t^{t} Y C}{t_{\text {REF }}}\right)+P_{S B}\left(1-N \frac{t^{t} C Y C}{t_{R E F}}\right)$ where
$P_{O P}=$ Power dissipation (continuous operation) $\cong V_{D D} \times I_{D D 2}$.
$\mathrm{N}=$ Number of refresh cycles (64 or 128)
$t_{C Y C}=$ Cycle time for a refresh cycle.
$t_{\text {REF }}=$ Time between refreshes
$P_{S B}=$ Standby power dissipation $=V_{D D} \times I_{D D 1}+\left|V_{B B}\right| \times I_{B B}$
Note that IDD2 depends upon refresh as follows:

1. For 128 cycle ( $\overline{\operatorname{RAS}}$ before $\overline{\mathrm{CAS}}$ ) use IDD2 from Figures 1 and 2.
2. For 64 cycle ( $\overline{\mathrm{CAS}}$ before $\overline{\mathrm{RAS}}$ ) multiply IDD2 determined in (1) by 0.96 .
3. For 128 cycle ( $\overline{\mathrm{RAS}}$ only) multiply IDD2 determined in (1) by 0.78.

Examples of typical calculations for $\mathrm{V}_{B B}=-5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=12.0 \mathrm{~V}$,
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}_{\mathrm{C} Y \mathrm{C}}=0.425 \mu \mathrm{~s}, \mathrm{t}_{\mathrm{RAS}}=0.3 \mu \mathrm{~s} . \mathrm{t}_{\text {REF }}=2000 \mu \mathrm{~s}$ :

1. 128 cycle ( $\overline{\mathrm{RAS}}$ before $\overline{\mathrm{CAS}}$ ): $\mathrm{P}_{\mathrm{OP}}=12.0 \mathrm{~V} \times 43 \mathrm{~mA}=516 \mathrm{~mW}$

$$
\begin{aligned}
& P_{\text {REF }}=516\left(128 \frac{0.425}{2000}\right)+(12 \times 1.2+5 \times 0.001)\left(1-128 \frac{0.425}{2000}\right) \\
& P_{\text {REF }}=28.0 \mathrm{~mW}
\end{aligned}
$$

2. 64 cycle ( $\overline{\mathrm{CAS}}$ before $\overline{\mathrm{RAS}})$; $\mathrm{P}_{\mathrm{OP}}=12.0 \mathrm{~V} \times 43(0.96) \mathrm{mA}=$ 495 mW .
$P_{\text {REF }}=495\left(64 \frac{0.425}{2000}\right)+(12 \times 1.2+5 \times 0.001)\left(1-64 \frac{0.425}{2000}\right)=$
$P_{\text {REF }}=20.9 \mathrm{~mW}$
3. 128 cycle ( $\overline{\mathrm{RAS}}$ only): $\mathrm{P}_{\mathrm{OP}}=12.0 \mathrm{~V} \times 43(0.78) \mathrm{mA}=402 \mathrm{~mW}$
$P_{\text {REF }}=\mathbf{2 5 . 0} \mathrm{mW}$


Note 1: Increase in current due to $\overline{W E}$ going low. Width of this current pulse is independent of WE pulse width.

Figure 3. Supply Current Waveforms.
A.C. Characteristics ${ }^{[1]}$
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.
READ, WRITE, READ-MODIFY-WRITE AND REFRESH CYCLES

| Symbol | Parameter | 2116-2 |  | 2116-3 |  | 2116-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {REF }}$ | Time Between Refresh |  | 2 |  | 2 |  | 2 | ms |
| $t_{\text {R }}$ | $\overline{\text { RAS Precharge Time }}$ | 75 |  | 75 |  | 95 |  | ns |
| ${ }^{\text {t }}$ CP | $\overline{\text { CAS }}$ Precharge Time | 100 |  | 125 |  | 125 |  | ns |
| $\mathrm{t}_{\mathrm{RCL}}{ }^{[2]}$ | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ Leading Edge Lead Time | 45 | 75 | 50 | 110 | 60 | 110 | ns |
| $\mathrm{t}_{\text {CRP }}{ }^{[3]}$ | $\overline{\text { CAS }}$ to $\overline{\mathrm{RAS}}$ Precharge Time | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {RSH }}$ | $\overline{\text { RAS }}$ Hold Time | 160 |  | 200 |  | 220 |  | ns |
| ${ }^{\text {t }}$ CSH | CAS Hold Time | 200 |  | 250 |  | 300 |  | ns |
| ${ }^{\text {t }}$ ASR | Row Address Set-Up Time | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {ASC }}$ | Column Address Set-Up Time | -10 |  | -10 |  | -10 |  | ns |
| ${ }^{t}{ }_{\text {AH }}$ | Address Hold Time | 45 |  | 50 |  | 60 |  | ns |
| $\mathrm{t}_{\mathrm{T}}$ | Transition Time (Rise and Fall) |  | 50 |  | 50 |  | 50 | ns |
| toff | Output Buffer Turn Off Delay | 0 | 60 | 0 | 60 | 0 | 80 | ns |
| $\mathrm{t}_{\mathrm{CAC}}{ }^{[4]}$ | Access Time From $\overline{\mathrm{CAS}}$ |  | 125 |  | 150 |  | 190 | ns |
| $\mathrm{t}_{\text {RAC }}{ }^{[4]}$ | Access Time From $\overline{\mathrm{RAS}}$ |  | 200 |  | 250 |  | 300 | ns |

READ AND REFRESH CYCLES

| Symbol | Parameter | 2116-2 |  | 2116-3 |  | 2116-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{CYC}}{ }^{[5]}$ | Random Read Cycle Time | 350 |  | 375 |  | 425 |  | ns |
| $t_{\text {RAS }}$ | $\overline{\text { RAS Pulse Width }}$ | 275 | 32000 | 300 | 32000 | 330 | 32000 | ns |
| ${ }^{\text {t }}$ CAS | $\overline{\text { CAS Pulse Width }}$ | 125 | 10000 | 150 | 10000 | 190 | 10000 | ns |
| ${ }_{\text {t }}$ CH | $\overline{\text { CAS }}$ Hold Time for $\overline{\text { RAS }}$-Only Refresh | 30 |  | 30 |  | 30 |  | ns |
| ${ }^{\text {t }}$ CPR | $\overline{\text { CAS }}$ Precharge for 64 Cycle Refresh | 30 |  | 30 |  | 30 |  | ns |
| $t_{\text {RCH }}$ | Read Command Hold Time | 20 |  | 20 |  | 20 |  | ns |
| $\mathrm{t}_{\text {RCS }}$ | Read Command Set-Up Time | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {DOH }}$ | Datà-Out Hold Time | 32 |  | 32 |  | 32 |  | $\mu \mathrm{s}$ |

WRITE CYCLE

| Symbol | Parameter | 2116-2 |  | 2116-3 |  | 2116-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{CYC}}{ }^{[5]}$ | Random Write Cycle Time | 350 |  | 375 |  | 425 |  | ns |
| $t_{\text {RAS }}$ | $\overline{\text { RAS }}$ Pulse Width | 275 | 32000 | 300 | 32000 | 330 | 32000 | ns |
| ${ }^{\text {t }}$ CAS | CAS Pulse Width | 125 | 10000 | 150 | 10000 | 190 | 10000 | ns |
| twCH | Write Command Hold Time | 75 |  | 100 |  | 100 |  | ns |
| $t_{\text {WP }}$ | Write Command Pulse Width | 50 |  | 100 |  | 100 |  | ns |
| $\mathrm{t}_{\text {RWL }}$ | Write Command to $\overline{\mathrm{RAS}}$ Lead Time | 125 |  | 200 |  | 200 |  | ns |
| ${ }^{\text {chew }}$ | Write Command to CAS Lead Time | 100 |  | 150 |  | 160 |  | ns |
| $\mathrm{t}_{\mathrm{DS}}{ }^{[6]}$ | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{DH}}{ }^{[6]}$ | Data-In Hold Time | 100 |  | 100 |  | 125 |  | ns |

Notes: 1. All voltages referenced to $\mathrm{V}_{\mathrm{SS}}$.
2. $\overline{C A S}$ must remain at $V_{I H}$ a minimum of $t_{R C L}$ MIN after $\overline{R A S}$ switches to $V_{I L}$. To achieve the minimum guaranteed access time ( $t_{R A C}$ ), $\overline{C A S}$ must switch to $V_{I L}$ at or before $t_{R C L}(M A X)=t_{R A C}{ }^{-t} C A C$. Device operation is not guaranteed for $t_{R C L}>2 \mu s$.
3. The $t_{C R P}$ specification is less restrictive than the $t_{C R L}$ range which was specified in the 2116 preliminary data sheet.
4. Load $=1 \mathrm{TTL}$ and 50 pF .
5. The minimum cycle timing does not allow for ${ }^{\mathrm{t}} \mathrm{T}$ or skews.
6. Referenced to CAS or $\overline{W E}$, whichever occurs last.

## Waveforms

## READ CYCLE



## WRITE CYCLE



Notes: $\quad 1,2 . V_{I H}$ MIN and $V_{I L}$ MAX are reference levels for measuring timing of input signals.
3.4. VOH MIN and VOL MAX are reference levels for measuring timing of DOUT-
5. DOUT follows DIN when writing, with $\overline{W E}$ before $\overline{C A S}$.
6. Referenced to $\overline{\mathrm{CAS}}$ or $\overline{\mathrm{WE}}$, whichever occurs last.
7. TOFF is measured to IOUT $\leqslant \mid$ LIO $\mid$.

## A.C. Characteristics

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.
READ-MODIFY-WRITE CYCLE

| Symbol | Parameter | 2116-2 |  | 2116-3 |  | 2116-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {RMW }}$ | Read-Modify-Write Cycle Time | 400 |  | 525 |  | 595 |  | ns |
| ${ }^{\text {t }}$ CRW | RMW Cycle $\overline{\text { CAS }}$ Width | 225 | 10000 | 310 | 10000 | 350 | 10000 | ns |
| $t_{\text {RRW }}$ | RMW Cycle $\overline{\mathrm{RAS}}$ Width | 325 | 32000 | 450 | 32000 | 500 | 32000 | ns |
| $\mathrm{t}_{\text {RWH }}$ | RMW Cycle $\overline{\mathrm{RAS}}$ Hold Time | 250 |  | 350 |  | 390 |  | ns |
| ${ }^{\text {t }}$ CWH | RMW Cycle $\overline{\text { CAS }}$ Hold Time | 300 |  | 410 |  | 460 |  | ns |
| $\mathrm{t}_{\text {RWL }}$ | Write Command to $\overline{\mathrm{RAS}}$ Lead Time | 125 |  | 200 |  | 200 |  | ns |
| ${ }^{\text {t }}$ CWL | Write Command to $\overline{\mathrm{CAS}}$ Lead Time | 100 |  | 160 |  | 160 |  | ns |
| $t_{W P}$ | Write Command Pulse Width | 50 |  | 100 |  | 100 |  | ns |
| $\mathrm{t}_{\mathrm{RCS}}$ | Read Command Set-Up Time | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {MOD }}$ | Modify Time | 0 | 10 | 0 | 10 | 0 | 10 | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ D | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {DHM }}$ | Data-In Hold Time (RMW Cycle) | 50 |  | 100 |  | 125 |  | ns |

## Waveforms

READ MODIFY WRITE CYCLE


Notes:
1,2. $V_{\text {IHMIN }}$ and $V_{\text {ILMAX }}$ are reference levels for measuring timing of input signals.
3.4. VOHMIN and VOLMAX are reference levels for measuring timing of DOUT.
5. tOFF is measured to IOUT $\leqslant\left|I_{\text {LO }}\right|$.

## Refresh Cycle Waveforms

## $\overline{\text { CAS }}$ BEFORE $\overline{\text { RAS }}$ CYCLES. ( 64 CYCLE REFRESH)



## $\overline{R A S}$ ONLY CYCLES (128 CYCLE REFRESH)



Notes: 1,2. $V_{\text {IHMIN }}$ and $V_{\text {ILMAX }}$ are reference levels for measuring timing of input signais.
3. $\overline{\mathrm{CAS}}$ must be high or low as appropriate for the next cycle.

## Applications Information

## REFRESH MODES

The 2116 may be refreshed in any of three modes. Read/Refresh cycles and RAS-only cycles refresh the row addressed by $A_{0}$ through $A_{6}$ and therefore require 128 cycles to refresh the stored data. Assuming a 500 nsec system cycle time, the refresh operations require $64 \mu \mathrm{sec}$ out of each 2.0 msec refresh period or $3.2 \%$ of the available memory time. The third 2116 refresh mode, $\overline{\text { CAS-before- }}$ $\overline{\mathrm{RAS}}$, allows refresh of the stored data in only 64 cycles and requires only $32 \mu \mathrm{sec}$ or $1.6 \%$ of the available memory time
(equal to the 64-cycle refresh 4K RAMs). While some 2116 aplications would not be impacted by the $3.2 \%$ memory lockout time using 128 cycle refresh, most large mainframe memory applications would suffer throughput degradation in that refresh mode. Intel designed the 2116 to allow either 128-cycle or 64-cycle refresh, allowing the system designer to choose the refresh mode which fits his system needs. In addition to allowing higher memory throughput, the $\overline{\mathrm{CAS}}-$ before-RAS 64 -cycle refresh mode dissipates approximately $14 \%$ less power than the 128-cycle $\overline{\mathrm{RAS}}$-only mode and $23 \%$ less power than the 128-cycle Read/Refresh mode (refer to the Standby Power Calculation section).

## POWER SUPPLY DECOUPLING/ DISTRIBUTION

Power supply current waveforms for the 2116 are shown in Figure 3. The $\mathrm{V}_{\mathrm{DD}}$ supply provides virtually all of the operating current for the 2116 . The $\mathrm{V}_{\mathrm{DD}}$ supply current, IDD, has two components: transient current peaks when the clocks change state and a DC component while the clocks are active (low). When selecting the decoupling capacitors for the $V_{D D}$ supply, the characteristics of capacitors as well as the current waveform must be considered. Suppression of transient or pulse currents require capacitors with small physical size and low inherent inductance. Monolithic and other ceramic capacitors exhibit these desirable characteristics. When the current waveform indicates a DC component, bulk capacity must be located near the current load to supply the load power. Inductive effects of PC board traces and bus bars preclude supplying the DC component from bulk capacitors at the periphery of a memory matrix without voltage droop during the active portion of a memory cycle. This means that some bulk capacity in the form of electrolytic or large ceramic capacitors should be distributed around or within the memory matrix.

The $\mathrm{V}_{\mathrm{BB}}$ supply current, $\mathrm{I}_{\mathrm{BB}}$, has high transient current peaks, with essentially no DC component (less than 400 microamperes). The $\mathrm{V}_{\text {BB }}$ capacitors should be selected for transient suppression characteristics. The following capacitance values and locations are recommended for the 2116:

1. A $0.33 \mu \mathrm{~F}$ ceramic capacitor between $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ (ground) at every other device.
2. A $0.1 \mu \mathrm{~F}$ ceramic capacitor between $\mathrm{V}_{\mathrm{BB}}$ and $\mathrm{V}_{\text {SS }}$ at every other device (preferably alternate devices to the $\mathrm{V}_{\mathrm{DD}}$ decoupling above).
3. A $4.7 \mu \mathrm{~F}$ electrolytic capacitor between $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ for each eight devices and located adjacent to the devices.

The $V_{\text {CC }}$ supply is connected only to the 2116 output buffer and is not used internally. The load current from the $\mathrm{V}_{\mathrm{CC}}$ supply is dependent only upon the output loading and is usually only the input high level current to a TTL gate and the output leakage currents of any OR-tied 2116s (typically $100 \mu \mathrm{~A}$ or less total). Intel recommends that a 0.1 or $0.01 \mu \mathrm{~F}$ ceramic capacitor be connected between $\mathrm{V}_{\text {cc }}$ and $\mathrm{V}_{\text {ss }}$ for every eight devices to preclude coupled noise from affecting the TTL devices in the system.
intel recommends a power supply distribution system such that each power supply is grided both horizontally and vertically at each memory device. This technique minimizes the power distribution system impedance and enhances the effect of the decoupling capacitors.

## OUTPUT DATA LATCH

The 2116 contains an output data latch eliminating the need for an external system data latch and the timing circuitry required to strobe an external latch. The 2116 output latch operates identically to the output latch found on all industry standard $16-\mathrm{pin}, 4 \mathrm{~K}$ RAMs and enhances the system compatibility of the 16 K and 4 K devices.
Operation of the output latch is controlled by $\overline{\mathrm{CAS}}$. The data output will go to the high-impedance state immediately following the CAS leading edge during each data cycle and will either go to valid data at access time on selected devices (devices receiving both $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ ) or will remain in the high impedance state on unselected devices (devices receiving only $\overline{\mathrm{CAS}}$ ). During $\overline{\mathrm{RAS}}$-only refresh cycles, the data output remains in the state it was prior to the $\overline{\text { RAS }}$-only cycle. This unique feature of latched output RAMs allows a refresh cycle to be hidden among data cycles without impacting data availability. For instance, a $\overline{R A S}-o n l y$ refresh cycle could follow each data cycle in a microprocessor system but the accessed data would remain at the device output and the microprocessor could take the data at any time within the cycle. Non-latched output devices do not provide this type of hidden refresh capability since their data output would go to the high impedance state at the end of the data cycle.

## PAGE MODE OPERATION

The 2116 is designed for page mode operation and is presently being characterized for that mode. Specifications will be available at a later date.

# REFRESH CONTROLLER FOR 4K DYNAMIC RANDOM ACCESS MEMORIES 

\author{

- Ideal for use in 2107A, 2107B Systems <br> Simplifies System Design <br> Reduces Package Count <br> Standard 22-Pin DIP
}


## - Adjustable Refresh Timing Oscillator

- 6-Bit Address Multiplexer
- 6-Bit Refresh Address Counter

Refresh Cycle Controller

The Intel® 3222 is a refresh controller for dynamic RAMs requiring refresh of up to 6 input addresses (or 4 K bits for $64 \times 64$ organization). The device contains an accurate refresh timer (whose frequency can be set by an external resistor and capacitor), plus all necessary control and I/O circuitry to provide for the refresh requirements of dynamic RAMs. The chip's high performance makes it especially suitable for use with high speed $N$-channel RAMs like the Intel® 2107B. The 3222 is well suited for asynchronous dynamic memory systems.
The 3222 operates from a single +5 volt power supply and is specified for operation over a $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ ambient temperature range. It is fabricated by means of Intel's highly reliable Schottky bipolar process.

PIN CONFIGURATION


PIN NAMES

| $A_{0}$ - A5 | ADDRESS INPUTS | $\overline{0}_{0} \cdot \bar{O}_{5}$ | ADDRESS OUTPUTS |
| :---: | :---: | :---: | :---: |
| $\overline{\text { ACK }}$ | ACKNOWLEDGE OUTPUT | $\overline{0}$ | INTERNAL REFRESH REQUEST LATCH OUTPUT |
| BUSY | BUSY INPUT | REFON | REFRESH ON OUTPUT |
| CYREO | CYCLE REQUEST INPUT | REFREO | REFRESH REOUEST INPUT |
|  |  | RxCx | RC TIE POINT |
|  |  | STARTCY | START CYCLE OUTPUT |
|  |  | $\mathrm{V}_{\mathrm{cc}}$ | +5V SUPPLY |

## BLOCK DIAGRAM



## Absolute Maximum Ratings*

Temperature Under Bias . . . . . . . . . . . . $-65^{\circ}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . $-65^{\circ}$ to $+160^{\circ} \mathrm{C}$
All Input, Output or Supply Voltages . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . . . . . . -1.0 V to +5.5 V
Output Currents . . . . . . . . . . . . . . . . . . . . . 100 mA
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 1 W

## *COMMENT

Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied.
D.C. Characteristics All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $I_{\text {FB }}$ | Input Load Current BUSY |  | 0.40 | 1 | mA | $\mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {FO }}$ | Input Load Current All Other Inputs |  | 0.05 | 0.25 | mA | $\mathrm{V}_{\text {IN }}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RB }}$ | Input Leakage Current $\overline{\text { BUSY }}$ |  | <1 | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{RO}}$ | Input Leakage Current All Other Inputs |  | <1 | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ |
| $V_{\text {CLAMP }}$ | Input Clamp Voltage |  | -0.76 | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 91 | 120 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $I_{\text {SC }}$ | Output High Short Circuit Current |  | -48 | -70 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.32 | 0.45 | V | $\mathrm{IOL}=5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ ) | 2.6 | 3.1 |  | V | $\begin{aligned} & \mathrm{l}_{\mathrm{OH}}=-1 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (All Other Outputs) | 2.4 | 3.0 |  | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |

Note 1: Typical values are for $\mathrm{T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$ and nominal power supply voltages.

Capacitance ${ }^{[2]}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol |  | Limits (pF) | Conditions |  |
| :--- | :--- | :---: | :---: | :--- |
|  |  |  |  | Conciance |
| $\mathrm{C}_{\text {IN }}$ (Address) | Input Capacitan | 5 | 10 | $\mathrm{~V}_{\text {bias }}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\text {IN }}(\overline{\mathrm{CYREO}})$ | Input Capacitance | 6 | 10 | $\mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\text {IN }}(\overline{\mathrm{BUSY}})$ | Input Capacitance | 20 | 30 | $\mathrm{f}=1 \mathrm{MHz}$ |

Note 2: This parameter is periodically sampled and is not $100 \%$ tested.
A.C. Characteristics All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$. Load $=1 \mathrm{TTL}, \mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$. Conditions of Test:Input pulse amplitude: 3 V , Input rise and fall times: 5 ns between 1 V and 2 V . Measurements are made at 1.5 V .

| Symbol | Parameter | Min. | Typ. ${ }^{1}$ | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ A | Address In to Address Out |  | 7 | 12 | ns | $\overline{\text { BUSY }}=\mathrm{V}_{1 H}$ |
| $t_{\text {BAM }}$ | $\overline{\text { BUSY }}$ In to Address Out |  | 21 | 28 | ns |  |
| $t_{\text {BAR }}$ | $\overline{\text { BUSY }}$ In to Counter Out |  | 18 | 27 | ns |  |
| $\mathrm{t}_{\mathrm{BK}}$ | $\overline{\mathrm{BUSY}}$ In to $\overline{\mathrm{ACK}}$ Out |  | 14 | 20 | ns | $\overline{\text { REFREQ }}=\mathrm{V}_{\text {IH }}, \overline{\text { CYREQ }}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{t}_{\mathrm{BR}}$ | $\overline{\text { BUSY }}$ In to $\overline{\text { REFON Out }}$ |  | 15 | 24 | ns |  |
| $t_{B S}$ | $\overline{\text { BUSY }}$ In to STARTCY Out | 4 | 7 | 14 | ns | $\overline{\text { CYREQ }}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{t}_{\text {HOLD }}$ | $\overline{\text { BUSY Hold Time }}$ | 50 |  |  | ns | External Delay between STARTCY and $\overline{B U S Y}$ |
| $\mathrm{t}_{\mathrm{RH}}$ | $\overline{\text { CYREO }}$ or $\overline{\text { REFREQ }}$ Hold Time | 0 |  |  | ns | External Delay after BUSY |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\text { REFREQ }}$ to $\overline{\text { REFON }}$ |  | 18 | 26 | ns | $\overline{\mathrm{CYREQ}}$ and $\overline{\mathrm{BUSY}}=\mathrm{V}_{\mathrm{IH}}$, No priority contention between REFREQ and $\overline{\text { CYREQ }}$ |
| $t_{\text {RRC }}$ |  |  | 33 | 45 | ns | $\overline{\text { BUSY }}=\mathrm{V}_{1 H}$ |
| $\mathrm{t}_{\text {RS }}$ | CYREQ or REFREQ In to STARTCY Out | 9 | 14 | 21 | ns | $\overline{\text { BUSY }}=\mathrm{V}_{1 H}$ |
| ${ }^{\text {t }}$ Setup | $\overline{\text { BUSY Setup Time }}$ | 120 |  |  | ns | $\overline{\text { BUSY }}=\mathrm{V}_{\text {IL }}$ During Refresh |

Note 1: Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply voltages.

## A. SYSTEM MEMORY CYCLE WITH MEMORY NOT BUSY <br> B. SYSTEM MEMORY CYCLE WITH MEMORY BUSY (FOLLOWING REFRESH CYCLE)

(Numbers in parentheses are minimum values in $n s$ unless otherwise specified.)

C. REFRESH MEMORY CYCLE WITH MEMORY NOT BUSY

## D. REFRESH MEMORY CYCLE WITH MEMORY BUSY (FOLLOWING SYSTEM CYCLE)

(Numbers in parentheses are minimum values in ns unless otherwise specified.)


NOTE 1: $t_{R R}$ (26ns MAX) IF PRIORITY CONTENTION IS ELIMINATED; $t_{\text {RRC }}$
E. TYPICAL APPLICATION OF 3222 REFRESH CONTROLLER IN A 2107B SYSTEM



## F. USE OF 3222 FOR REFRESH TIMING AND CONTROL IN A 2104A SYSTEM



| PIN NAMES AND FUNCTIONS |  |  |
| :---: | :---: | :---: |
| Pin No. | Pin Name | Function |
| 1 | $\overline{\mathbf{Q}}$ | Output of the internal Refresh Request latch. This pin may be connected to the Refresh Request input (REFREQ) directly for asynchronous sequential mode refresh or indirectly through control logic for burst mode or synchronous mode refresh (see text). |
| 2 | $\overline{\text { REFREQ }}$ | Refresh Request input (active when low). The request is honored only if the memory is not presently executing a cycle (BUSY high) and if a system cycle request did not occur first. |
| 3 | $\overline{\text { CYREQ }}$ | System Memory Cycle Request input (active when low). The request is honored only if the memory is not presently executing a cycle ( $\overline{\mathrm{BUSY}}$ high) and if a refresh request did not occur first. |
| 4 | $\overline{\text { STARTCY }}$ | Output signal indicating to external circuitry that a memory cycle (system or refresh) is to begin. See text for timing considerations for a refresh cycle. |
| $\begin{aligned} & 5-7 \\ & 15-17 \end{aligned}$ | $\mathrm{A}_{0}-\mathrm{A}_{5}$ | Low order system address inputs. These addresses are multiplexed to the address output pins ( $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ ) during a system cycle. |
| 8-10 | $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ | Low order memory address outputs. During a system cycle these outputs give the low order ( $\mathrm{A}_{0}-\mathrm{A}_{5}$ ) address of a memory access. During a refresh cycle these outputs give the refresh address (generated internal to the 3222). |
| 11 | GROUND | Ground. |
| 18 | $\overline{\text { BUSY }}$ | An externally generated signal which the 3222 monitors to determine memory system status. If BUSY is high the memory is not busy and a system or refresh cycle may begin. If $\overline{B U S Y}$ is low the memory is being accessed for a data I/O or refresh cycle and no other cycle may begin. |
| 19 | $\overline{\text { REFON }}$ | The 3222 output which when low indicates the memory system is either ready to begin or is in a refresh cycle (Refresh On). |
| 20 | $\overline{\text { ACK }}$ | The 3222 output which when low indicates the memory system is either ready to begin or is in a system cycle (system cycle request accepted and acknowledged). |


| Pin <br> No. | Pin <br> Name | Function |
| :--- | :--- | :--- |
| 21 | $R X / C X$ | Connection point for the RC net- <br> work which determines the refresh <br> period for sequential refresh mode. <br> (See Refresh Control section). |
| 22 | $V_{C C}$ | +5 volt supply. |

## FUNCTIONAL DESCRIPTION

The Intel® 3222 performs the four basic functions of a refresh controller by:

1. Providing a refresh timing oscillator.
2. Generating six bit refresh addresses.
3. Multiplexing refresh and system addresses to the six low order address inputs ( $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ ).
4. Providing control signals for both refresh and memory cycle accesses.
As shown in the pin configuration figure, the 3222 has as inputs the six low order $\left(\mathrm{A}_{0}-\mathrm{A}_{5}\right)$ system addresses. These addresses are internally multiplexed with six internally generated refresh addresses. The output of these multiplexers provide the six low order addresses to the memory array.
The block diagram shows the four main circuit categories of the 3222. An explanation of the workings of each of these categories is given in the Device Operation section from a users point of view.

## DEVICE OPERATION

Operation of the Intel® 3222 Refresh Controller is most easily explained by considering five conditions presented by the three input control lines Cycle Request (CYREQ), Refresh Request ( $\overline{R E F R E Q}$ ), and System Busy ( $\overline{\mathrm{BUSY}}$ ). These conditions are:

1. System memory cycle request - memory not busy (BUSY $=$ High)
2. System memory cycle request - memory busy ( $\overline{\mathrm{BUSY}}=$ Low)
3. Refresh cycle request - memory not busy ( $\overline{B U S Y}=$ High $)$
4. Refresh cycle request - memory busy ( $\overline{\mathrm{BUSY}}=$ Low)
5. Simultaneous system memory cycle and refresh cycle requests.
Condition 5 is actually a subset of the four previous conditions and is included for completeness.
As is implied in the five conditions, the response of the 3222 to both refresh and memory cycles is dependent on the state of the $\overline{B U S Y}$ input. The $\overline{B U S Y}$ signal is generated externally to the 3222 and, when low, defines the time when the memory is performing a cycle (refresh or memory access). It is important to assure that $\overline{B U S Y}$ is low for the entire memory cycle time. Interference may occur in asynchronous memory systems if the $\overline{B U S Y}$ input goes high prematurely. (An asynchronous memory system is one in which the refresh and memory cycle requests occur independent of each other.)

## System Memory Cycle Request - Memory Not Busy

This section details operation of the 3222 when the memory is not busy and a request for a system memory cycle is made (See Figure A for timing sequences). The request for a memory cycle is made by the CYREQ input going low. The Start Cycle output STARTCY goes low at $\mathrm{t}_{\text {RS }}$ after $\overline{\text { CYREQ. }}$ STARTCY is used for two purposes:

1. To set the external $\overline{\text { BUSY }}$ latch. (See Figure E.)
2. To initiate memory system timing (after appropriate delay).

The required delay time depends on system configuration and associated delay paths for both Chip Enable (2107B input signal) and system addresses.
The low going $\overline{B U S Y}$ input causes the internally generated Start Cycle output to go high and the Acknowledge output $\overline{A C K}$ to go low (after $t_{B K}$ time). The Acknowledge output confirms that the requested system memory cycle has been accepted by the 3222. Note that the cycle request input may be returned to the high state when the $\overline{B U S Y}$ input goes low. However, at the designer's discretion, the cycle request line may remain low until "just prior" to BUSY returning high. (If $\overline{B U S Y}$ goes high before $\overline{\text { CYREQ }}$ goes high, another memory access may inadvertently be started.)

When the memory is not busy and a cycle request has been made, the low order system address delay through the 3222 is $t_{A A}$ nsec. When the 3222 is not busy, the low order system addresses $\left(\mathrm{A}_{0}-\mathrm{A}_{5}\right)$ are gated through to the output $\left(\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}\right)$ independent of any other input.

## System Memory Cycle Request - Memory Busy

The major differences between a system memory cycle request when the system is busy and when it is not busy (as previously described) are:

1. The Start Cycle output $\overline{\text { STARTCY }}$ does not go low until $t_{B S}$ after the rising edge of the $\overline{B U S Y}$ input. (Even though the CYREQ input is low.)
2. Output addresses $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ change at or before $t_{\mathrm{AA}}$ time if the previous cycle was a system cycle request and change at or before $t_{\text {BAM }}$ if the previous cycle was a Refresh Cycle request. (Note that the longer delay is after a refresh cycle.) See Figure B for definition of terms.
Note that for a system memory cycle following a refresh cycle, the refresh on output $\overline{\text { REFON }}$ goes high at or before $t_{B R}$ relative to $\overline{B U S Y}$ going high. Since the Acknowledge output $\overline{A C K}$ can not go low until after $t_{\text {HOLD }}$ there is no ambiguity between $\overline{R E F O N}$ and $\overline{\mathrm{ACK}}$. The memory is always defined as being in a refresh cycle, system cycle or no cycle.

## Refresh Cycle - Memory Not Busy

Operation of the 3222 for a refresh request with the memory not busy (see Figure C ) is similar to a system cycle request under the same condition. A refresh cycle is initiated by the Refresh Request input (REFREQ) going low. This low going input causes both the Start Cycle output, STARTCY, and Refresh On output, $\overline{\text { REFON, }}$, go go low at $t$
and trRc (or trR) time respectively. The low going edge of $\overline{\text { STARTCY }}$ is used to set the external $\overline{B U S Y}$ latch low. As in the previous two cases, the $\overline{B U S Y}$ input must remain low for the entire cycle required by the memory. As in the previous two cases, the low going BUSY drives the STARTCY output high.

## Refresh Cycle - Memory Busy

For this condition, it is assumed that the previous cycle was a system access cycle. Timing conditions for this operation are shown in Figure D. Here, the STARTCY input goes low $t_{B S}$ after $\overline{B U S Y}$ returns high from the previous cycle. As before, $\overline{R E F O N}$ goes low $t_{B R}$ after $\overline{B U S Y}$ goes high. After $\mathrm{t}_{\text {HOLD }}$, relative to STARTCY, $\overline{B U S Y}$ again goes low and places the low order refresh addresses on the address outputs $\left(\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}\right)$ after $\mathrm{t}_{\mathrm{BAR}}$ time. Internal refresh timing is performed in a manner identical to that described in Refresh Cycle-Memory Not Busy section.

## Simultaneous Refresh and Memory System Cycle Request

The simultaneous request for a refresh and memory system access is almost a certainty in asynchronous systems. It is, therefore, necessary to have circuitry in any refresh controller capable of resolving the attendent ambiguity with minimum additional delay. The Intel ${ }^{\circledR} 3222$ Refresh Controller has just such a circuit. (All timing parameters specified for asynchronous operation assume that a refresh and memory system request can occur at the same time.) A latch internal to the 3222 decides which signal ( $\overline{C Y R E Q}$ or $\overline{R E F R E Q})$ it will accept if both occur simultaneously, and conditions the other control circuits appropriately. If a refresh cycle was accepted, $\overline{R E F O N}$ will go low at the appropriate time. If a memory system access was accepted then $\overline{\mathrm{ACK}}$ will go low at the appropriate time.

## Refresh Control

The 3222 controls both burst and distributed refresh modes. The burst refresh mode requires that REFREQ be generated externally to the 3222 since refresh is completed in 64 consecutive cycles every 2 ms . A system requiring distributed refresh timing, however can be controlled either by the 3222 or by external circuitry. If refresh timing is to be controlled by the 3222 the output $\bar{Q}$ is tied to the $\overline{\text { REFREQ }}$ input. Timing is controlled by an oscillator internal to the 3222. The desired refresh timing interval is determined by:

1. $\frac{t_{\text {REF }}}{r}=.63 R_{x} C_{x}$

Where:
$t_{\text {REF }}=$ the total time between refreshes (e.g. 2 msec ) in msec.
$r=$ the number of rows to be refreshed on the memory device (for the 2107B r=64).
$R_{X}=$ external timing resistance in $K \Omega$ ( 3 K to 10 K )
$\mathrm{C}_{\mathrm{x}}=$ external timing capacitance in $\mu \mathrm{f}$. $(0.005 \mu \mathrm{f}$ to $0.02 \mu \mathrm{f}$ )
The 3222's oscillator stability is guaranteed to be $\pm 2 \%$ for a given part and $\pm 6 \%$ from part to part, both over the ranges $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 75^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$.
Figure $F$ shows how the 3222 may be used to control refresh in a 2104A system.

## ADDRESS MULTIPLEXER AND REFRESH COUNTER FOR 4K DYNAMIC RAMs

\author{

- Ideal For 2104A <br> - Simplifies System Design <br> Reduces Package Count <br> - Standard 24-Pin DIP
}

The Intel® 3232 contains an address multiplexer and refresh counter for multiplexed address dynamic RAMs requiring refresh of up to 6 input addresses (or 4 K bits for $64 \times 64$ organization). It multiplexes twelve bits of system supplied address to six output address pins. The device also contains a 6 bit refresh counter which is externally controlled so that either distributed or burst refresh may be used. The high performance of the 3232 makes it especially suitable for use with high speed N -channel RAMs like the 2104A.
The 3232 operates from a single +5 volt power supply and is specified for operation over a 0 to $+75^{\circ} \mathrm{C}$ ambient temperature range.


NOTE: $A_{0}$ THROUGH $A_{5}$ ARE ROW ADDRESSES. $A_{6}$ THROUGH $A_{11}$ ARE COLUMN ADDRESSES.

TRUTH TABLE AND DEFINITIONS:

| REFRESH <br> ENABLE | ROW <br> ENABLE | OUTPUT |
| :---: | :---: | :--- |
| $H$ | X | REFRESH ADDRESS <br> (FROM INTERNAL COUNTER) |
| $L$ | $H$ | ROW ADDRESS <br> $\left(A_{0}\right.$ THROUGH $A_{5}$ ) |
| $L$ | L | COLUMN ADDRESS <br> (A $A_{\epsilon}$ THROUGH $A_{1!}$ ! |

COUNT - ADVANCES INTERNAL REFRESH COUNTER.
ZERO DETECT - INDICATES A ZERO IN THE REFRESH ADDRESS
(USED IN BURST REFRESH MODE).
> - Address Input to Output Delay: 9ns Maximum Driving 15pF, 25ns Maximum Driving 250pF
> - Suitable For Either Distributed Or Burst Refresh
> - Single Power Supply: +5 Volts $\pm 10 \%$

## Absolute Maximum Ratings*

| Temperature Under Bias | $-65^{\circ}$ to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature $\ldots . . . . . . . . . . . . . .{ }^{-65^{\circ}}$ to $+160^{\circ} \mathrm{C}$All Input, Output, or |  |
|  |  |
| Supply Voltages | 0.5 V to +7 Volts |
| Output Currents | 100mA |
| Power Dissipation | W |

*COMMENT:
Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. and Operating Characteristics

All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. 11$)$ | MAX. |  |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current |  | -0.04 | -0.25 | m |  |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current |  | 0 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  |  | V |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.25 | 0.40 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage $\left(\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}\right)$ | 2.8 | 4.0 |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH} 1}$ | Output High Voltage <br> $($ Zero Detect $)$ | 2.4 | 3.3 |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 100 | 150 | mA | $\mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |

Note 1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.

## A.C. Characteristics

All Limits Apply for $\mathrm{V}_{\mathrm{Cc}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$, Load $=1 \mathrm{TTL}, \mathrm{C}_{\mathrm{L}}=250 \mathrm{pF}$, Unless Otherwise Specified.

| SYMBOL | PARAMETER | MIN. | TYP.! ${ }^{(1)}$ | MAX. | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{AO}}$ | Address Input to Output Delay |  | 6 | 9 | ns | Refresh Enable $=$ Low $^{(1)(2)}$ |
| $\mathrm{t}_{\mathrm{AOO}}$ | Address Input to Output Delay |  | 16 | 25 | ns | Refresh Enable = Low |
| too | Row Enable to Output Delay | 7 | 12 | 27 | ns | Refresh Enable $=$ Low ${ }^{(1)(2)}$ |
| tool | Row Enable to Output Delay | 12 | 28 | 41 | ns | Refresh Enable = Low |
| $\mathrm{t}_{\mathrm{EO}}$ | Refresh Enable to Output Delay | 7 | 14 | 27 | ns | Note 1, 2 |
| $\mathrm{t}_{\text {EOI }}$ | Refresh Enable to Output Delay | 12 | 30 | 45 | ns |  |
| $t_{\text {co }}$ | $\overline{\text { Count to Output }}$ | 15 | 40 | 60 | ns | Refresh Enable $=$ High $^{(1)(2)}$ |
| $\mathrm{tcol}^{\prime}$ | $\overline{\text { Count }}$ to Output | 20 | 55 | 80 | ns | Refresh Enable $=$ High |
| $f_{C}$ | Counting Frequency | 5 |  |  | MHz |  |
| $t_{\text {cpw }}$ | $\overline{\text { Count Pulse Width }}$ | 35 |  |  | ns |  |
| $\mathrm{t}_{\mathbf{c z}}$ |  | 15 |  | 70 | ns | Note 2 |

Note 1: $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

$$
\text { 2: } C_{L}=15 \mathrm{pF}
$$

A.C. TIMING WAVEFORMS (Typically used with 2104A)

NORMAL CYCLE


## REFRESH CYCLE



| Pin. <br> No. | Pin <br> Name | Function |
| :---: | :---: | :---: |
| 1 | $\overline{\text { Count Input }}$ | Active low input increments internal six bit counter by one for each count pulse in. |
| 2 | Refresh Enable Input | Active high input which determines whether the 3232 is in refresh mode (H) or address enable (L). |
| $\begin{aligned} & 7,3,5,18, \\ & 20,22 \end{aligned}$ | $\mathrm{A}_{0}-\mathrm{A}_{5}$ Inputs | Row Address inputs. |
| $\begin{aligned} & 8,4,6,17, \\ & 19,21 \end{aligned}$ | $\mathrm{A}_{6}-\mathrm{A}_{11}$ Inputs | Column address inputs. |
| $\begin{aligned} & 9,11,10 \\ & 15,15,14 \end{aligned}$ | $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ Outputs | Address outputs to memories. Inverted with respect to address inputs. |
| 12 | GND | Power supply ground. |
| 13 | $\overline{\text { Zero }} \overline{\text { Detect }}$ Output | Active low output which senses that all six bits of refresh address in the counter are zero. Can be used in the burst mode to sense refresh completion. |
| 23 | Row Enable Input | High input selects row, low input selects column addresses of the driven memories. |
| 24 | $\mathrm{V}_{\mathrm{cc}}$ | +5 V power supply input. |

## DEVICE OPERATION

The Intel ${ }^{\circledR} 3232$ Address Multiplexer/Refresh Counter performs the following functions:

1. Row, Column and Refresh Address multiplexing
2. Address counting for burst or distributed refresh.

These functions are controlled by two signals: Refresh Enable and Row Enable, both of which are active high TTL
inputs. The truth table on page 1 shows the levels required to multiplex to the output:

1. Refresh addresses (from internal counter)
2. Row addresses ( $A_{0}$ through $A_{5}$ )
3. Column addresses ( $A_{6}$ through $A_{11}$ )

## Burst Refresh Mode

When refresh is requested, the refresh enable input is high. This input is ANDed with the 6 outputs of the internal 6 bit counter. At each Count pulse the counter increments by one, sequencing the outputs ( $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ ) through all 64 row addresses. When the counter sequences to all zeros, the $\overline{Z e r o} \overline{\text { Detect output goes low signaling the end of the refresh }}$ sequence. Due to counter decoding spikes, the $\overline{Z e r o} \overline{\text { Detect }}$ output is valid only after $\mathrm{t}_{\mathrm{cz}}$ following the low going edge of Count.

## Distributed Refresh Mode

In the distributed refresh mode, one row is selected for refresh each ( $\mathrm{t}_{\text {REFRESH }} / \mathrm{n}$ ) time where $\mathrm{n}=$ number of rows in the device and $t_{\text {REFRESH }}$ is the specified refresh rate for the device. For the 2104A $\mathrm{t}_{\text {REFRESH }}=2 \mathrm{msec}$ and $\mathrm{n}=64$, therefore one row is refreshed each $31 \mu \mathrm{sec}$. Following the refresh cycle at row $n_{x}$, the Count input is pulsed, advancing the refresh address by one row so that the next refresh cycle will be performed on row $n_{x+1}$. The Count input may be pulsed following each refresh cycle or within the refresh cycle after the specified memory device address hold time.

## Row and Column Address

All twelve system address lines are applied to the inputs of the 3232. When Refresh Enable is low and Row Enable is high, input addresses $\mathrm{A}_{0}-\mathrm{A}_{5}$ are gated to the outputs and applied to the driven memories. Conversely, when Row Enable is low (with Refresh Enable still low), input addresses $\mathrm{A}_{6}-\mathrm{A}_{11}$ are gated to the outputs and applied to the driven memories.
Figure 1 shows a typical connection between the 3232 and the 2104 A 4 K dynamic RAM. When the memory devices are driven directly by the 3232 , the address applied to the memory devices is the inverse of the address at the 3232 inputs due to the inverted outputs of the 3232 . This should be remembered when checking out the memory system.


Figure 1. Typical Connection of 3232 and 2104 Memories.

# 3242 <br> ADDRESS MULTIPLEXER AND REFRESH COUNTER FOR 16K DYNAMIC RAMs 

- Ideal For 2116
- Simplifies System Design
- Reduces Package Count
- Standard 28-Pin DIP


## - Suitable For Either Distributed Or Burst Refresh

## - Single Power Supply: +5 Volts $\pm 10 \%$ <br> - Address Input to Output Delay: 9ns Driving 15 pF, 25ns Driving 250pF

The Intel® 3242 is an address multiplexer and refresh counter for multiplexed address dynamic RAMs requiring refresh of 64 or 128 cycles. It multiplexes 14 bits of system supplied address to 7 output address pins. The device also contains a 7 bit refresh counter which is externally controlled so that either distributed or burst refresh may be used. The high performance of the 3242 makes it especially suitable for use with high speed N-channel RAMs like the 2116.
The 3242 operates from a single +5 volt power supply and is specified for operation over a 0 to $+75^{\circ} \mathrm{C}$ ambient temperature range. It is fabricated by means of Intel's highly reliable Schottky bipolar process and is packaged in a hermetically sealed 28 pin Type D package.

PIN CONFIGURATION


NOTE: $A_{0}$ THROUGH $A_{6}$ ARE ROW ADDRESSES. $A_{7}$ THROUGH $A_{13}$ ARE COLUMN ADDRESSES.

TRUTH TABLE AND DEFINITIONS:

| REFRESH <br> ENABLE | ROW <br> ENABLE | OUTPUT |
| :---: | :---: | :--- |
| $H$ | X | REFRESH ADDRESS <br> (FROM INTERNAL COUNTER) |
| $L$ | H | ROW ADDRESS <br> $\left(\mathrm{A}_{0}\right.$ THROUGH $\mathrm{A}_{6}$ ) |
| L | L | COLUMN ADDRESS <br> $\left(\mathrm{A}_{7}\right.$ THROUGH $\left.\mathrm{A}_{13}\right)$ |

COUNT - ADVANCES INTERNAL REFRESH COUNTER ZERO DETECT - INDICATES ZERO IN THE FIRST 6 SIGNIFICANT REFRESH COUNTER SIGNIFICANT REFRESH COUNTER
BITS (USED IN BURST REFRESH MODE)

LOGIC DIAGRAM


## A.C. Characteristics

All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$, Load $=1 \mathrm{TTL}, \mathrm{C}_{\mathrm{L}}=250 \mathrm{pF}$, Unless Otherwise Specified.

| SYMBOL | PARAMETER | MIN. | TYP. ${ }^{(1)}$ | MAX. | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{AO}}$ | Address Input to Output Delay |  | 6 | 9 | ns | Refresh Enable $=$ Low $^{(2)(3)}$ |
| $\mathrm{t}_{\mathrm{AO}}$ | Address Input to Output Delay |  | 16 | 25 | ns | Refresh Enable = Low |
| $\mathrm{t}_{0}$ | Row Enable to Output Delay | 7 | 12 | 27 | ns | Refresh Enable $=$ Low $^{(2)(3)}$ |
| $\mathrm{t}_{(0) 1}$ | Row Enable to Output Delay | 12 | 28 | 41 | ns | Refresh Enable = Low |
| $\mathrm{t}_{\mathrm{E},}$ | Refresh Enable to Output Delay | 7 | 14 | 27 | ns | Notes 2, 3 |
| $\mathrm{t}_{\mathrm{E}, 01}$ | Refresh Enable to Output Delay | 12 | 30 | 45 | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | $\overline{\text { Count }}$ to Output | 15 | 40 | 60 | ns | Refresh Enable $=\mathrm{High}^{(2)(3)}$ |
| $\mathrm{t}_{\mathrm{CO}}$ | $\overline{\text { Count }}$ to Output | 20 | 55 | 80 | ns | Refresh Enable $=$ High |
| $\mathrm{f}_{\mathrm{c}}$ | Counting Frequency |  |  | 5 | MHz |  |
| $\mathrm{t}_{\text {cPW }}$ | Count Pulse Width | 35 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{Cz}}$ |  | 15 |  | 70 | ns | Note 3 |

Notes: 1. Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
2. $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
3. $C_{L}=15 \mathrm{pF}$.
A.C. TIMING WAVEFORMS (Typically used with 2116)

## NORMAL CYCLE



## REFRESH CYCLE


Absolute Maximum Ratings*
Temperature Under Bias ..... $-10^{\circ}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature ..... $-65^{\circ}$ to $+150^{\circ} \mathrm{C}$
All Input, Output, or
Supply Voltages ..... -0.5 V to +7 Volts
Output Currents ..... 100 mA
Power Dissipation ..... 1W

## *COMMENT:

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. and Operating Characteristics

All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | TYP. 11$)$ | MAX. |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current |  | -0.04 | -0.25 | $\mathrm{~V}_{\mathrm{IN}}=0.45 \mathrm{~V}$, Note 2 |  |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current |  | 0.01 | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  |  | V |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.25 | 0.40 | V | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage $\left(\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{6}\right)$ | 3.0 | 4.0 |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH} 1}$ | Output High Voltage <br> (Zero Detect $)$ | 2.4 | 3.3 |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 105 | 165 | mA | $\mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |

Notes: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{C C}=5.0 \mathrm{~V}$.
2. Inputs are high impedance, TTL compatible, and suitable for bus operation.

| PI | AND | NCTIONS |
| :---: | :---: | :---: |
| Pin No. | Pin <br> Name | Function |
| 1 | Count Input* | Active low input increments internal 7 bit counter by one for each count pulse in. |
| 2 | Refresh Enable Input* | Active high input which determines whether the 3242 is in refresh mode ( H ) or address enable (L). |
| $\begin{aligned} & 9,5,7,21 \\ & 23,25,27 \end{aligned}$ | $A_{0}-A_{6}$ Inputs* | Row address inputs. |
| $\begin{aligned} & \text { 10,6,8,20, } \\ & 22,24,26 \end{aligned}$ | $\begin{aligned} & \mathrm{A}_{7}-\mathrm{A}_{13} \\ & \text { Inputs } \end{aligned}$ | Column address inputs. |
| $\begin{aligned} & 11,13,12, \\ & 18,17,16, \\ & 19 \end{aligned}$ | $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{6}$ <br> Outputs | Address outputs to memories. Inverted with respect to address inputs. |
| 14 | GND | Power supply ground. |
| 15 | $\begin{aligned} & \overline{\overline{\text { Eero }}} \\ & \overline{\text { Detect }} \\ & \text { Output } \end{aligned}$ | Active low output which senses that the six low order bits of refresh address in the counter are zero. Can be used in the burst mode to sense refresh completion. |
| 3 | Row <br> Enable <br> Input* | High input selects row, low input selects column addresses of the driven memories. |
| 28 | $V_{\text {cc }}$ | +5V power supply input. |

*The inputs are high impedance, TTL compatible, and suitable for bus operation.

## DEVICE OPERATION

The Intel ${ }^{\left({ }^{( }\right)} 3242$ Address Multiplexer/Refresh Counter performs the following functions:

1. Row, Column and Refresh Address multiplexing.
2. Address Counting for burst or distributed refresh.

These functions are controlled by two signals: Refresh Enable and Row Enable, both of which are active high TTL inputs. The truth table on page 1 shows the levels required to multiplex to the output:

1. Refresh addresses (from internal counter).
2. Row addresses $\left(A_{0}\right.$ through $\left.A_{6}\right)$.
3. Column addresses $\left(A_{7}\right.$ through. $\left.A_{13}\right)$.

## Burst Refresh Mode

When refresh is requested, the refresh enable input is high. This input is ANDed with the seven outputs of the internal 7 -bit counter. At each $\overline{\text { Count }}$ pulse the counter increments by one, sequencing the outputs $\left(\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{6}\right)$ through 128 row addresses. When the first six significant bits of the counter sequence to all zeros, the $\overline{\text { Zero }} \overline{\text { Detect }}$ output goes low, signaling the end of the refresh sequence. Due to counter decoding spikes, the $\overline{\text { Zero }} \overline{\text { Detect }}$ output is valid only after $\mathrm{t}_{\mathrm{CZ}}$ following the low-going edge of $\overline{\text { Count. }}$. The $\overline{\text { Zero }} \overline{\text { Detect out- }}$ put used in this manner signals the completion of 64 refresh cycles. To use the 128 -cycle burst refresh mode, an external flip-flop must be driven by the Zero $\overline{\text { Detect. }}$

## Distributed Refresh Mode

In the distributed refresh mode, one row is selected for refresh each ( $\mathrm{t}_{\text {REFRESH }} / \mathrm{n}$ ) time where $\mathrm{n}=$ number of refresh cycles required for the device and trefresh is the specified refresh rate for the device. For the $2116 \mathrm{t}_{\text {REFRESH }}=2 \mathrm{msec}$ and $\mathrm{n}=$ 128 or 64 , therefore, one row is refreshed each 15.5 or 31 $\mu \mathrm{sec}$, respectively. Following the refresh cycle at row $\mathrm{n}_{\mathrm{x}}$, the Count input is pulsed, advancing the refresh address by one row so that the next refresh cycle will be performed on row $\mathrm{n}_{\mathrm{x}+1}$. The Count input may be pulsed following each refresh cycle or within the refresh cycle after the specified memory device address hold time.

## Row and Column Address

All 14 system address lines are applied to the inputs of the 3242. When Refresh Enable is low and Row Enable is high, input addresses $A_{0}-A_{6}$ are gated to the outputs and applied to the driven memories. Conversely, when Row Enable is low (with Refresh Enable still low), input addresses $A_{7}-A_{13}$ are gated to the outputs and applied to the driven memories. Figure 1 shows a typical connection between the 3242 and the 2116 16K dynamic RAM. When the memory devices are driven directly by the 3242, the address applied to the memory devices is the inverse of the address at the 3242 inputs due to the inverted outputs of the 3242. This should be remembered when checking out the memory system.


Figure 1. Typical Connection of 3242 and 2116 Memories.

## PERIPHERALS and SUPPORT CIRCUITS

## PERIPHERALS and SUPPORT CIRCUITS

8205 High Speed 1 out of 8 Binary Decoder ..... 6-159
8212 8-Bit Input/Output Port ..... 6-165
M8212 8-Bit Input/Output Port (MIL) ..... 6-174
8214 Priority Interrupt Control ..... 6-179
M8214 Priority Interrupt Control (MIL) ..... 6-183
8216/8226 4-Bit Parallel Bi-Directional Bus Driver ..... 6-186
M8216 4-Bit Parallel Bi-Directional Bus Driver (MIL) ..... 6-191
8251A Programmable Communication Interface ..... 6-194
M8251 Communication Interface ..... 6-209
8253/8253-5 Programmable Interval Timer ..... 6-212
8255A/8255A-5 Programmable Peripheral Interface ..... 6-223
M8255A Programmable Peripheral Interface (MIL) ..... 6-244
8257/8257-5 DMA Controller ..... 6-247
8259/8259-5 Interrupt Controller ..... 6-265
8271 Floppy Disk Controller ..... 6-281
8273 SDLC Protocol Controller ..... 6-285
8275 CRT Controller ..... 6-289
8279/8279-5 Keyboard/Display Interface ..... 6-293

## 8205

# HIGH SPEED 1 OUT OF 8 BINARY DECODER 

- I/O Port or Memory Selector
- Simple Expansion - Enable Inputs
- High Speed Schottky Bipolar Technology - 18ns Max. Delay
- Directly Compatible with TTL Logic Circuits
- Low Input Load Current - . 25 mA max., 1/6 Standard TTL Input Load
- Minimum Line Reflection - Low Voltage Diode Input Clamp
- Outputs Sink 10 mA min.
- 16-Pin Dual-In-Line Ceramic or Plastic Package

The 8205 decoder can be used for expansion of systems which utilize input ports, output ports, and memory components with active low chip select input. When the 8205 is enabled, one of its eight outputs goes "low", thus a single row of a memory system is selected. The 3 chip enable inputs on the 8205 allow easy system expansion. For very large systems, 8205 decoders can be cascaded such that each decoder can drive eight other decoders for arbitrary memory expansions.
The Intel ${ }^{\circledR} 8205$ is packaged in a standard 16 pin dual-in-line package; and its performance is specified over the temperature range of $0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$, ambient. The use of Schottky barrier diode clamped transistors to obtain fast switching speeds results in higher performance than equivalent devices made with a gold diffusion process.

## PIN CONFIGURATION



PIN NAMES

| $A_{0} \cdot A_{2}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{E_{1}} \cdot \overline{E_{3}}$ | ENABLE INPUTS |
| $\overline{O_{0}} \cdot \overline{O_{7}}$ | DECODED OUTPUTS |

LOGIC SYMBOL


| ADDRESS |  |  | ENABLE |  |  | OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0}$ | $\mathrm{A}_{1}$ | $\mathrm{A}_{2}$ | $\mathrm{E}_{1}$ | $\mathrm{E}_{2}$ | $\mathrm{E}_{3}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| L | L | 1 | L | L | H | L | H | H | H | H | H | H | H |
| H | L | L | L | L | H | H | L | H | H | H | H | H | H |
| L | H | L | L | L | H | H | H | L | H | H | H | H | H |
| H | H | 1 | L | L | H | H | H | H | L | H | H | H | H |
| L | L | H | L | L | H | H | H | H | H | L | H | H | H |
| H | L | H | 1 | L | H | H | H | H | H | H | L | H | H |
| L | H | H | L | L | H | H | H | H | H | H | H | 1 | H |
| H | H | H | L | L | H | H | H | H | H | H | H | H | L |
| x | $x$ | X | L | L | L | H | H | H | H | H | H | H | H |
| $\times$ | X | X | H | L | L | H | H | H | H | H | H | H | H |
| $\times$ | X | X | L. | H | L | H | H | H | H | H | H | H | H |
| X | $\times$ | X | H | H | L | H | H | H | H | H | H | H | H |
| $x$ | $x$ | X | H | L | H | H | H | H | H | H | H | H | H |
| $x$ | $x$ | $x$ | L | H | H | H | H | H | H | H | H | H | H |
| X | x | $x$ | H | H | H | H | H | H | H | H | H | H | H |

## FUNCTIONAL DESCRIPTION

## Decoder

The 8205 contains a one out of eight binary decoder. It accepts a three bit binary code and by gating this input, creates an exclusive output that represents the value of the input code.

For example, if a binary code of 101 was present on the A0, A1 and A2 address input lines, and the device was enabled, an active low signal would appear on the $\overline{05}$ output line. Note that all of the other output pins are sitting at a logic high, thus the decoded output is said to be exclusive. The decoders outputs will follow the truth table shown below in the same manner for all other input variations.

## Enable Gate

When using a decoder it is often necessary to gate the outputs with timing or enabling signals so that the exclusive output of the decoded value is synchronous with the overall system.
The 8205 has a built-in function for such gating. The three enable inputs ( $\overline{E 1}, \overline{E 2}, E 3$ ) are ANDed together and create a single enable signal for the decoder. The combination of both active "high" and active "low" device enable inputs provides the designer with a powerfully flexible gating function to help reduce package count in his system.


| ADDRESS |  |  | ENABLE |  |  | OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0}$ | $\mathrm{A}_{1}$ | $\mathrm{A}_{2}$ | $\mathrm{E}_{1}$ | $E_{2}$ | $E_{3}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| L | L | L | L | L | H | L | H | H | H | H | H | H | H |
| H | L | L | L | L | H | H | L | H | H | H | H | H | H |
| L | H | L | L | L | H | H | H | L | H | . H | H | H | H |
| H | H | L | L | L | H | H | H | H | L | H | H | H | H |
| L | L | H | L | L | H | H | H | H | H | L | H | H | H |
| H | L | H | L | L | H | H | H | H | H | H | L | H | H |
| L | H | H | L | L | H | H | H | H | H | H | H | L | H |
| H | H | H | L | L | H | H | H | H | H | H | H | H | L |
| X | X | $\times$ | L | L | L | H | H | H | H | H | H | H | H |
| $x$ | X | X | H | L | L | H | H | H | H | H | H | H | H |
| X | X | X | L | H | L | H | H | H | H | H | H | H | H |
| X | X | X | H | H | L | H | H | H | H | H | H | H | H |
| X | X | X | H | L | H | H | H | H | H | H | H | H | H |
| X | X | X | L | H | H | H | H | H | H | H | H | H | H |
| X | X | X | H | H | H | H | H | H | H | H | H | H | H |

## APPLICATIONS OF THE 8205

The 8205 can be used in a wide variety of applications in microcomputer systems. I/O ports can be decoded from the address bus, chip select signals can be generated to select memory devices and the type of machine state such as in 8008 systems can be derived from a simple decoding of the state lines (S0, S1, S2) of the 8008 CPU.

## I/O Port Decoder

Shown in the figure below is a typical application of the 8205. Address input lines are decoded by a group of 8205 s (3). Each input has a binary weight. For example, A0 is assigned a value of 1 and is the LSB; A4 is assigned a value of 16 and is the MSB. By connecting them to the decoders as shown, an active low signal that is exclusive in nature and represents the value of the input address lines, is available at the outputs of the 8205s.

This circuit can be used to generate enable signals for I/O ports or any other decoder related application.

Note that no external gating is required to decode up to 24 exclusive devices and that a simple addition of an inverter or two will allow expansion to even larger decoder networks.

## Chip Select Decoder

Using a very similar circuit to the I/O port decoder, an ar-


I/O Port Decoder
ray of 8205 s can be used to create a simple interface to a 24 K memory system.
The memory devices used can be either ROM or RAM and are 1 K in storage capacity. 8308 s and 8102 s are the devices typically used for this application. This type of memory device has ten (10) address inputs and an active "low" chip select ( $\overline{\mathrm{CS}}$ ). The lower order address bits A0-A9 which come from the microprocessor are "bussed" to all memory elements and the chip select to enable a specific device or group of devices comes from the array of 8205 s . The output of the 8205 is active low so it is directly compatible with the memory components.

Basic operation is that the CPU issues an address to identify a specific memory location in which it wishes to "write" or "read" data. The most significant address bits A10-A14 are decoded by the array of 8205 s and an exclusive, active low, chip select is generated that enables a specific memory device. The least significant address bits A0-A9 identify a specific location within the selected device. Thus, all ad: dresses throughout the entire memory array are exclusive in nature and are non-redundant.
This technique can be expanded almost indefinitely to support even larger systems with the addition of a few inverters and an extra decoder (8205).


24K Memory Interface

## Logic Element Example

Probably the most overlooked application of the 8205 is that of a general purpose logic element. Using the "on-chip" enabling gate, the 8205 can be configured to gate its decoded outputs with system timing signals and generate strobes that can be directly connected to latches, flip-flops and one-shots that are used throughout the system.

An excellent example of such an application is the "state decoder" in an 8008 CPU based system. The 8008 CPU issues three bits of information (S0, S1, S2) that indicate the nature of the data on the Data Bus during each machine state. Decoding of these signals is vital to generate strobes that can load the address latches, control bus discipline and general machine functions.
In the figure below a circuit is shown using the 8205 as the "state decoder" for an 8008 CPU that not only decodes the S0, S1, S2 outputs but gates these signals with the clock (phase 2) and the SYNC output of the 8008 CPU . The $\overline{\mathrm{T} 1}$
and $\overline{\mathrm{T} 2}$ decoded strobes can connect directly to devices like 8212s for latching the address information. The other decoded strobes can be used to generate signals to control the system data bus, memory timing functions and interrupt structure. RESET is connected to the enable gate so that strobes are not generated during system reset, eliminating accidental loading.
The power of such a circuit becomes evident when a single decoded strobe is logically broken down. Consider $\overline{T 1}$ output, the boolean equation for it would be:

$$
\overline{\mathrm{T} 1}=(\overline{\mathrm{S} 0} \cdot \mathrm{~S} 1 \cdot \overline{\mathrm{~S} 2}) \cdot(\overline{\mathrm{SYNC}} \cdot \text { Phase } 2 \cdot \overline{\mathrm{Rese} \mathrm{t}})
$$

A six input NAND gate plus a few inverters would be needed to implement this function. The seven remaining outputs would need a similar circuit to duplicate their function, obviously a substantial savings in components can be achieved when using such a technique.



## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias:
Ceramic $\quad-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

Storage Temperature
All Output or Supply Voltages
All Input Voltages
Output Currents

Plastic $\quad-65^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ -0.5 to +7 Volts
-1.0 to +5.5 Volts
125 mA
*COMMENT
Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

| SYMBOL | PARAMETER | LIMIT |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. |  |  |
| $I_{\text {F }}$ | INPUT LOAD CURRENT |  | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $I_{\text {R }}$ | INPUT LEAKAGE CURRENT |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | INPUT FORWARD CLAMP VOLTAGE |  | -1.0 | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=-5.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | OUTPUT "LOW" VOLTAGE |  | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=10.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | OUTPUT HIGH VOLTAGE | 2.4 |  | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-1.5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | INPUT "LOW" VOLTAGE |  | 0.85 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | INPUT "HIGH" VOLTAGE | 2.0 |  | $\checkmark$ | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |
| $\mathrm{I}_{\text {SC }}$ | OUTPUT HIGH SHORT CIRCUIT CURRENT | -40 | -120 | mA | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {Ox }}$ | OUTPUT "LOW" VOLTAGE <br> @ HIGH CURRENT |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OX}}=40 \mathrm{~mA}$ |
| ${ }^{\text {cc }}$ | POWER SUPPLY CURRENT |  | 70 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |

## TYPICAL CHARACTERISTICS



## SWITCHING CHARACTERISTICS

CONDITIONS OF TEST:
Input pulse amplitudes: 2.5 V
Input rise and fall times: 5 nsec between 1 V and 2 V

Measurements are made at 1.5 V


8212

## EIGHT-BIT INPUT/OUTPUT PORT

\author{

- Fully Parallel 8-Bit Data Register and Buffer <br> - Service Request Flip-Flop for Interrupt Generation <br> ■ Low Input Load Current - . 25 mA Max. <br> - Three State Outputs <br> - Outputs Sink 15 mA
}

The 8212 input/output port consists of an 8 -bit latch with 3 -state output buffers along with control and device selection logic. Also included is a service request flip-flop for the generation and control of interrupts to the microprocessor.
The device is multimode in nature. It can be used to implement latches, gated buffers or multiplexers. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with this device.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{DI}_{1} \cdot \mathrm{DI}_{8}$ | DATA IN |
| :--- | :--- |
| $\mathrm{DO}_{1} \cdot \mathrm{DO}_{8}$ | DATA OUT |
| $\overline{\mathrm{DS}} \cdot \mathrm{DS}_{2}$ | DEVICE SELECT |
| $M D$ | MODE |
| STB | STROBE |
| $\overline{\mathrm{INT}}$ | INTERRUPT (ACTIVE LOW) |
| $\overline{\mathrm{CLR}}$ | CLEAR (ACTIVE LOW) |

LOGIC DIAGRAM


## FUNCTIONAL DESCRIPTION

## Data Latch

The 8 flip-flops that make up the data latch are of a " $D$ " type design. The output $(Q)$ of the flip-flop will follow the data input (D) while the clock input (C) is high. Latching will occur when the clock (C) returns low.
The data latch is cleared by an asynchronous reset input ( $\overline{C L R}$ ). (Note: Clock (C) Overides Reset (CLR).)

## Output Buffer

The outputs of the data latch $(Q)$ are connected to 3 -state, non-inverting output buffers. These buffers have a common control line (EN); this control line either enables the buffer to transmit the data from the outputs of the data latch ( $Q$ ) or disables the buffer, forcing the output into a high impedance state. (3-state)
This high-impedance state allows the designer to connect the 8212 directly onto the microprocessor bi-directional data bus.

## Control Logic

The 8212 has control inputs $\overline{\mathrm{DS} 1}, \mathrm{DS} 2, \mathrm{MD}$ and STB. These inputs are used to control device selection, data latching, output buffer state and service request flip-flop.

## DS1, DS2 (Device Select)

These 2 inputs are used for device selection. When $\overline{\mathrm{DS} 1}$ is low and DS2 is high ( $\overline{\mathrm{DS}} \cdot \mathrm{DS} 2$ ) the device is selected. In the selected state the output buffer is enabled and the service request flip-flop (SR) is asynchronously set.

## MD (Mode)

This input is used to control the state of the output buffer and to determine the source of the clock input (C) to the data latch.

When MD is high (output mode) the output buffers are enabled and the source of clock (C) to the data latch is from the device selection logic ( $\overline{\mathrm{DS} 1} \cdot \mathrm{DS} 2$ ). When MD is low (input mode) the output buffer state is determined by the device selection logic ( $\overline{\mathrm{DS} 1}$. DS2) and the source of clock ( $C$ ) to the data latch is the STB (Strobe) input.

## STB (Strobe)

This input is used as the clock (C) to the data latch for the input mode $\mathrm{MD}=0$ ) and to synchronously reset the service request flip-flop (SR).
Note that the SR flip-flop is negative edge triggered.

## Service Request Flip-Flop

The (SR) flip-flop is used to generate and control interrupts in microcomputer systems. It is asynchronously set by the CLR input (active low). When the (SR) flip-flop is set it is in the non-interrupting state.
The output of the (SR) flip-flop (Q) is connected to an inverting input of a "NOR" gate. The other input to the "NOR" gate is non-inverting and is connected to the device selection logic ( $\overline{\mathrm{DS} 1} \cdot \mathrm{DS} 2$ ). The output of the "NOR" gate ( $\overline{\mathrm{NT}}$ ) is active low (interrupting state) for connection to active low input priority generating circuits.


## Applications Of The 8212 -- For Microcomputer Systems

I Basic Schematic Symbol
II Gated Buffer
III Bi-Directional Bus Driver
IV Interrupting Input Port
V Interrupt Instruction Port
VI Output Port

## I. Basic Schematic Symbols

Two examples of ways to draw the 8212 on system schematics-(1) the top being the detailed view showing pin numbers, and (2) the bottom being the symbolic view showing the system input or output

VII 8080 Status Latch
VIII 8008 System
IX 8080 System:
8 Input Ports
8 Output Ports
8 Level Priority Interrupt
as a system bus (bus containing 8 parallel lines). The output to the data bus is symbolic in referencing 8 parallel lines.

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 DS1 and DS2.
When the device selection logic is false, the outputs are 3 -state.
When the device selection logic is true, the input data from the system is directly transferred to the output. The input data load is 250 micro amps. The output data can sink 15 milli amps. The minimum high output is 3.65 volts.

GATED BUFFER
3-STATE


## 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 $\overline{\mathrm{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


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

INTERRUPTING INPUT PORT


## V. Interrupt Instruction Port

The 8212 can be used to gate the interrupt instruction, normally RESTART instructions, onto the data bus. The device is enabled from the interrupt acknowledge signal from the microprocessor and from a port selection signal. This signal is normally tied to ground. ( $\overline{\mathrm{DS} 1}$ could be used to multiplex a variety of interrupt instruction ports onto a common bus).

INTERRUPT INSTRUCTION PORT


## 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. ( $\overline{\mathrm{DS} 1} \cdot \mathrm{DS} 2$ )

## OUTPUT PORT (WITH HAND-SHAKING)



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


## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias Plas | $-65^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ |
| :---: | :---: |
| All Output or Supply Voltages | -0.5 to +7 Volts |
| All Input Voltages | 0 to 5.5 Volts |
| Output Currents | ...... 125 mA |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C} \quad \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current ACK, DS ${ }_{2}$, CR, DI, -DI ${ }_{8}$ Inputs |  |  | -. 25 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current MD Input |  |  | $-.75$ | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current DS, Input |  |  | -1.0 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current ACK, DS, CR, $\mathrm{DI}_{1}-\mathrm{DI}_{8}$ Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $I_{R}$ | Input Leakage Current MO Input |  |  | 30 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $I_{R}$ | Input Leakage Current DS, Input |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{c}}$ | Input Forward Voltage Clamp |  |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {L }}$ | Input "Low" Voltage |  |  | . 85 | V |  |
| $\mathrm{V}_{1+}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output "Low" Voltage |  |  | . 45 | V | $\mathrm{IOL}=15 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output "High" Voltage | 3.65 | 4.0 |  | V | $\mathrm{I}_{\text {OH }}=-1 \mathrm{~mA}$ |
| $\mathrm{I}_{\text {sc }}$ | Short Circuit Output Current | -15 |  | -75 | mA | $\mathrm{V}_{0}=0 \mathrm{~V}$ |
| \| 1 | | Output Leakage Current High Impedance State |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{0}=.45 \mathrm{~V} / 5.25 \mathrm{~V}$ |
| 1 lc | Power Supply Current |  | 90 | 130 | mA |  |

## TYPICAL CHARACTERISTICS

input current vs. input voltage


OUTPUT CURRENT VS.
OUTPUT "HIGH" VOLTAGE


DATA TO OUTPUT DELAY
VS. TEMPERATURE


OUTPUT CURRENT VS. OUTPUT "LOW" VOLTAGE


DATA TO OUTPUT DELAY VS. LOAD CAPACITANCE


WRITE ENABLE TO OUTPUT DELAY VS. TEMPERATURE


TIMING DIAGRAM

$\overline{\mathrm{DS}}_{1} \cdot \mathrm{DS}_{2}$


## A.C. CHARACTERISTICS

$T_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C} \quad \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $t_{\text {pw }}$ | Pulse Width | 30 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{pd}}$ | Data To Output Delay |  |  | 30 | ns |  |
| $\mathrm{t}_{\text {we }}$ | Write Enable To Output Delay |  |  | 40 | ns |  |
| $\mathrm{t}_{\text {set }}$ | Data Setup Time | 15 |  |  | ns |  |
| $t_{\text {h }}$ | Data Hold Time | 20 |  |  | ns |  |
| $\mathrm{t}_{\text {}}$ | Reset To Output Delay |  |  | 40 | ns |  |
| $\mathrm{t}_{5}$ | Set To Output Delay |  |  | 30 | ns |  |
| $\mathrm{t}_{\text {e }}$ | Output Enable/Disable Time |  |  | 45 | ns |  |
| $\mathrm{t}_{\mathrm{c}}$ | Clear To Output Delay |  |  | 55 | ns |  |

CAPACITANCE ${ }^{*} F=1 \mathrm{MHz} \quad V_{B \mid A S}=2.5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \quad T_{A}=25^{\circ} \mathrm{C}$

| Symbol | Test | LIMITS |  |
| :--- | :--- | :---: | :---: |
|  |  | Typ. | Max. |
| $\mathrm{C}_{\mathbb{I N}}$ | $\mathrm{DS}, \mathrm{MD}$ Input Capacitance | 9 pF | 12 pF |
| $\mathrm{C}_{\mathrm{IN}}$ | $\mathrm{DS}_{2}, \mathrm{CK}, \mathrm{ACK}, \mathrm{DI}_{1}-\mathrm{DI}_{8}$ <br> Input Capacitance | 5 pF | 9 pF |
| $\mathrm{C}_{\text {OUT }}$ | $\mathrm{DO}_{1}-\mathrm{DO}_{8}$ Output Capacitance | 8 pF | 12 pF |

*This parameter is sampled and not $100 \%$ tested.

## SWITCHING CHARACTERISTICS

CONDITIONS OF TEST
Input Pulse Amplitude $=2.5 \mathrm{~V}$
Input Rise and Fall Times 5 ns
Between 1 V and 2 V Measurements made at 1.5 V with 15 mA \& 30 pF Test Load

TEST LOAD
$15 \mathrm{~mA} \& 30 \mathrm{pF}$


## EIGHT-BIT INPUT/OUTPUT PORT

## ■ 3.4V Output High Voltage for Direct Interface to M8080A CPU

- Asynchronous Register Clear
- Replaces Buffers, Latches and Multiplexers in Microcomputer Systems
- Reduces System Package Count
- $\pm 10 \%$ Power Supply Tolerance
- 24-Pin Dual In-Line Package

The M8212 input/output port consists of an 8 -bit latch with 3 -state output buffers along with control and device selection logic. Also included is a service request flip-flop for the generation and control of interrupts to the microprocessor.

The device is multimode in nature. It can be used to implement latches, gated buffers or multiplexers. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with this device.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{DI}_{1} \cdot \mathrm{DI}_{8}$ | DATA IN |
| :--- | :--- |
| $\mathrm{DO}_{1} \cdot \mathrm{DO}_{8}$ | DATA OUT |
| $\overline{\mathrm{DS}} \cdot \mathbf{D} \cdot \mathrm{DS}_{2}$ | DEVICE SELECT |
| MD | MODE |
| STB | STROBE |
| $\overline{\mathrm{INT}}$ | INTERRUPT (ACTIVE LOW) |
| $\overline{\mathrm{CLR}}$ | CLEAR (ACTIVE LOW) |

LOGIC DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} \quad \mathrm{V}_{\mathrm{cc}}=+5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current ACK, DS ${ }_{2}, \mathrm{CR}, \mathrm{DI}_{1}-\mathrm{DI}_{8}$ Inputs |  |  | -. 25 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $I_{F}$ | Input Load Current MD Input |  |  | -. 75 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current DS, Input |  |  | -1.0 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current ACK, DS, CR, $\mathrm{DI}_{1}-\mathrm{DI}_{8}$ Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current MD Input |  |  | 30 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current DS, Input |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{c}}$ | Input Forward Voltage Clamp |  |  | -1.2 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | . 80 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output "Low" Voltage |  |  | . 45 | V | $\mathrm{I}_{\mathrm{ol}}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OH }}$ | Output "High" Voltage | 3.4 | 4.0 |  | V | $\mathrm{I}_{\text {OH }}=-.5 \mathrm{~mA}$ |
| Ios | Short Circuit Output Current | -15 |  | -75 | mA | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\|10\|$ | Output Leakage Current High Impedance State |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| Icc | Power Supply Current |  | 90 | 145 | mA |  |

## A.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} \quad \mathrm{V}_{\mathrm{Cc}}=+5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | Min. | Max. |  |  |
| $t_{\text {PW }}$ | Pulse Width | 40 |  | ns |  |
| $\mathrm{t}_{\mathrm{PD}}$ | Data To Output Delay |  | 30 | ns | NOTE 1 |
| $\mathrm{t}_{\mathrm{WE}}$ | Write Enable To Output Delay |  | 50 | ns | NOTE 1 |
| $\mathrm{t}_{\text {SET }}$ | Data Setup Time | 20 |  | ns |  |
| $\mathrm{t}_{\mathrm{H}}$ | Data Hold Time | 30 |  | ns |  |
| $\mathrm{t}_{\mathrm{R}}$ | Reset To Output Delay |  | 55 | ns | NOTE 1 |
| $\mathrm{t}_{\mathrm{S}}$ | Set To Output Delay |  | 35 | ns | NOTE 1 |
| $\mathrm{t}_{\mathrm{E}}$ | Output Enable/Disable Time |  | 50 | ns | NOTE 1 |
| $\mathrm{t}_{\mathrm{C}}$ | Clear To Output Delay |  | 65 | ns | NOTE 1 |



## SWITCHING CHARACTERISTICS

CONDITIONS OF TEST
TEST LOAD
Input Pulse Amplitude $=2.5 \mathrm{~V}$
Input Rise and Fall Times: 5 ns between 1 V and 2 V


NOTE 1:

| TEST | $\mathbf{C}_{\mathrm{L}}$ | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :--- | :---: | :---: | :---: |
| $\mathrm{t}_{\text {PD }}, \mathrm{t}_{W E}, \mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathbf{s}}, \mathrm{t}_{\mathrm{C}}$ | 30 pF | $300 \Omega$ | $600 \Omega$ |
| $\mathrm{t}_{\mathrm{E}}, \mathrm{ENABLE} \uparrow$ | 30 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| $\mathrm{t}_{\mathrm{E}}, \mathrm{ENABLE} \downarrow$ | 30 pF | $300 \Omega$ | $600 \Omega$ |
| $\mathrm{t}_{\mathrm{E}}, \mathrm{DISABLE} \uparrow$ | 5 pF | $300 \Omega$ | $600 \Omega$ |
| $\mathrm{t}_{\mathrm{E}}, \mathrm{DISABLE} \downarrow$ | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

TIMING DIAGRAM


## TYPICAL CHARACTERISTICS

INPUT CURRENT VS. INPUT VOLTAGE


OUTPUT CURRENT VS. OUTPUT "HIGH" VOLTAGE


DATA TO OUTPUT DELAY VS. TEMPERATURE


OUTPUT CURRENT VS. OUTPUT "LOW" VOLTAGE


OUTPUT "LOW" VOLTAGE (V)

DATA TO OUTPUT DELAY
VS. LOAD CAPACITANCE


WRITE ENABLE TO OUTPUT DELAY VS. TEMPERATURE


# 8214 <br> PRIORITY INTERRUPT CONTROL UNIT 

\author{

- Eight Priority Levels <br> - Current Status Register <br> - Priority Comparator
}

\author{

- Fully Expandable <br> - High Performance (50ns) <br> - 24-Pin Dual In-Line Package
}

The 8214 is an eight level priority interrupt control unit designed to simplify interrupt driven microcomputer systems.

The PICU can accept eight requesting levels; determine the highest priority, compare this priority to a software controlled current status register and issue an interrupt to the system along with vector information to identify the service routine.

The 8214 is fully expandable by the use of open collector interrupt output and vector information. Control signals are also provided to simplify this function.

The PICU is designed to support a wide variety of vectored interrupt structures and reduce package count in interrupt driven microcomputer systems.


## D.C. AND OPERATING CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages . . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . .
Output Currents . . . . . . . . . . . . . . . . . . . 100 mA
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$.

| Symbol | Parameter |  | Limits |  |  | Unit |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
2. $B_{0}-B_{2}, \overline{\mathrm{SGS}}, C L K, \overline{R_{0}} \cdot \overline{R_{4}}$ grounded, all other inputs and all outputs open.
A.C. CHARACTERISTICS AND WAVEFORMS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. |  |
| ${ }^{t} \mathrm{CY}$ | $\overline{\text { CLK }}$ Cycle Time | 80 | 50 |  | ns |
| $t_{\text {PW }}$ | $\overline{C L K}, \overline{\text { ECS }}, \overline{\text { INT }}$ Pulse Width | 25 | 15 |  | ns |
| $\mathrm{t}_{\text {ISS }}$ | INTE Setup Time to $\overline{C L K}$ | 16 | 12 |  | ns |
| $\mathrm{t}_{\text {ISH }}$ | INTE Hold Time after $\overline{\text { CLK }}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{\text {ETCS }}{ }^{[2]}$ | ETLG Setup Time to $\overline{\text { CLK }}$ | 25 | 12 |  | ns |
| $\mathrm{t}_{\mathrm{ETCH}}{ }^{[2]}$ | ETLG Hold Time After $\overline{\text { CLK }}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{\text {ECCS }}{ }^{[2]}$ | $\overline{\mathrm{ECS}}$ Setup Time to $\overline{\mathrm{CLK}}$ | 80 | 50 |  | ns |
| $\mathrm{t}_{\mathrm{ECCH}}{ }^{[3]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{C L K}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {ECRS }}{ }^{[3]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{C L K}$ | 110 | 70 |  | ns |
| ${ }^{\text {E ECRH }}{ }^{[3]}$ | $\overline{\text { ECS }}$ Hold Time After CLK | 0 |  |  |  |
| $\mathrm{t}_{\text {ECSS }}{ }^{[2]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{C L K}$ | 75 | 70 |  | ns |
| $\mathrm{t}_{\mathrm{ECSH}}{ }^{[2]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{C L K}$ | 0 |  |  | ns |
| ${ }^{\text {D }}$ ( ${ }^{\text {[ }}{ }^{[2]}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Setup Time to $\overline{\mathrm{CLK}}$ | 70 | 50 |  | ns |
| ${ }^{\mathrm{DCH}^{[2]}}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Hold Time After $\overline{\mathrm{CLK}}$ | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{RCS}}{ }^{[3]}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ Setup Time to $\overline{C L K}$ | 90 | 55 |  | ns |
| $\mathrm{t}_{\mathrm{RCH}}{ }^{[3]}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ Hold Time After $\overline{C L K}$ | 0 |  |  | ns |
| tics |  | 55 | 35 |  | ns |
| ${ }^{\mathrm{Cl}}$ | $\overline{\mathrm{CLK}}$ to $\overline{\mathrm{NT}}$ Propagation Delay |  | 15 | 25 | ns |
| $\mathrm{t}_{\text {RIS }}{ }^{[4]}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to $\overline{\text { INT }}$ | 10 | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RIH}}{ }^{[4]}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Hold Time After $\overline{\mathrm{NNT}}$ | 35 | 20 |  | ns |
| $t_{\text {RA }}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ to $\overline{A_{0}} \cdot \overline{A_{2}}$ Propagation Delay |  | 80 | 100 | ns |
| $t_{\text {ELA }}$ | $\overline{\mathrm{ELR}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 40 | 55 | ns |
| $t_{\text {ECA }}$ | $\overline{\mathrm{ECS}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 100 | 120 | ns |
| ${ }^{\text {E ETA }}$ | ETLG to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 35 | 70 | ns |
| $\mathrm{t}_{\text {DECS }}{ }^{[4]}$ | $\overline{\mathrm{SGS}}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Setup Time to $\overline{\mathrm{ECS}}$ | 15 | 10 |  | ns |
| ${ }^{\text {D }}$ DECH ${ }^{[4]}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Hold Time After $\overline{\mathrm{ECS}}$ | 15 | 10 |  | ns |
| $t_{\text {REN }}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ to ENLG Propagation Delay |  | 45 | 70 | ns |
| teTEN | ETLG to ENLG Propagation Delay |  | 20 | 25 | ns |
| $\mathrm{t}_{\text {ECRN }}$ | $\overline{\text { ECS }}$ to ENLG Propagation Delay |  | 85 | 90 | ns |
| ${ }^{\text {t ECSN }}$ | $\overline{\text { ECS }}$ to ENLG Propagation Delay |  | 35 | 55 | ns |

## CAPACITANCE ${ }^{[5]}$

| Symbol | Parameter | Limits |  |  | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  | Input Capacitance | Min. | Typ. ${ }^{[1]}$ | Max |  |
|  | Output Capacitance |  | 5 | 10 | pF |

TEST CONDITIONS: $V_{B I A S}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$
NOTE 5. This parameter is periodically sampled and not $100 \%$ tested.

## WAVEFORMS



NOTES:
(1) Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
(2) Required for proper operation if ISE is enabled during next clock pulse.
${ }^{(3)}$ These times are not required for proper operation but for desired change in interrupt flip-flop.
${ }^{(4)}$ Required for new request or status to be properly loaded.

## TEST CONDITIONS:

Input pulse amplitude: 2.5 volts.
Input rise and fall times: 5 ns between 1 and 2 volts.
Output loading of 15 mA and 30 pf .
Speed measurements taken at the 1.5 V levels.


## PRIORITY INTERRUPT CONTROL UNIT

- Eight Priority Levels
- Fully Expandable
- Current Status Register
- Priority Comparator

24-Pin Dual In-Line Package
■ Full Military Temperature Range $-55^{\circ} \mathrm{C}$ To $+125^{\circ} \mathrm{C}$
$\pm 10 \%$ Power Supply Tolerance

The M8214 is an eight level priority interrupt control unit designed to simplify interrupt driven microcomputer systems.

The PICU can accept eight requesting levels; determine the highest priority, compare this priority to a software controlled current status register and issue an interrupt to the system along with vector information to identify the service routine.

The M8214 is fully expandable by the use of open collector interrupt output and vector information. Control signals are also provided to simplify this function.

The PICU is designed to support a wide variety of vectored interrupt structures and reduce package count in interrupt driven microcomputer systems.

PIN CONFIGURATION


PIN NAMES

| INPUTS |  |
| :---: | :---: |
| $\overline{\mathrm{R}_{0}-\mathrm{R}_{7}}$ | REQUEST LEVELS (R, HIGHEST PRIORITY) |
| $\overline{B_{0}-B_{2}}$ | CURRENT STATUS |
| $\overline{\text { SGS }}$ | STATUS GROUP SELECT |
| $\overline{\text { ECS }}$ | ENABLE CURRENT STATUS |
| INTE | INTERRUPT ENABLE |
| $\overline{\text { CLK }}$ | CLOCK (INT F-F) |
| ELR | ENABLE LEVEL READ |
| ETLG | ENABLE THIS LEVEL GROUP |
| OUTPUTS: |  |
| $\overline{A_{0} \cdot A_{2}}$ | $\left.\begin{array}{l}\text { REQUEST LEVELS } \\ \text { interruipt (ACT. LOW) }\end{array}\right]$ OPEN |
| ENLG | ENABLE NEXT LEVEL GROUP |

LOGIC DIAGRAM


## D.C. AND OPERATING CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$
All Output and Supply Voltages . . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . -1.0 V to +5.5 V
Output Currents . . . . . . . . . . . . . . . . . . 100 mA
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
$\mathrm{T}_{\mathrm{A}}=55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C} \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter |  | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage (all inputs) |  |  |  | -1.2 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Forward Current: | ETLG input all other inputs |  | $\begin{aligned} & -.15 \\ & -.08 \end{aligned}$ | $\begin{gathered} -0.5 \\ -0.25 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $V_{F}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Input Reverse Current: | ETLG input all other inputs |  |  | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| $V_{\text {IL }}$ | Input LOW Voltage: | all inputs |  |  | 0.8 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input HIGH Voltage: | all inputs | 2.0 |  |  | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  |  | 90 | 130 | mA | See Note 2. |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage: | all outputs |  | . 3 | . 45 | V | $1 \mathrm{OL}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage: | ENLG output | 2.4 | 3.0 |  | V | $\mathrm{IOH}^{=-1 m A}$ |
| los | Short Circuit Output Current: ENLG output |  | -15 | -35 | -55 | mA | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| ICEX | Output Leakage Current: $\overline{\mathrm{NT}}, \overline{\mathrm{A}_{0}}, \overline{\mathrm{~A}_{1}}, \overline{\mathrm{~A}_{2}}$ |  |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CEX }}=5.5 \mathrm{~V}$ |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}$.
2. $\mathrm{B}_{0}-\mathrm{B}_{2}, \overline{\mathrm{SGS}}, \mathrm{CLK}, \overline{\mathrm{R}}_{0}-\overline{\mathrm{R}}_{4}$ grounded, all other inputs and all outputs open.

## A.C. CHARACTERISTICS $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |
| ${ }^{\text {t }}$ CY | $\overline{\text { CLK }}$ Cycle Time | 85 |  |  | ns |
| tPW | $\overline{\mathrm{CLK}}, \overline{\mathrm{ECS}}, \overline{\text { INT }}$ Pulse Width | 25 | 15 |  | ns |
| $\mathrm{t}_{\text {ISS }}$ | INTE Setup Time to $\overline{\text { CLK }}$ | 16 | 12 |  | ns |
| $\mathrm{t}_{\text {ISH }}$ | INTE Hold Time after CLK | 20 | 10 |  | ns |
| $\mathrm{t}_{\text {ETCS }}{ }^{[2]}$ | ETLG Setup Time to $\overline{\text { CLK }}$ | 25 | 12 |  | ns |
| $\mathrm{t}_{\text {ETCH }}{ }^{\text {[2] }}$ | ETLG Hold Time After $\overline{\text { CLK }}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{\mathrm{ECCS}}{ }^{[2]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{\text { CLK }}$ | 85 | 25 |  | ns |
| $\mathrm{t}_{\mathrm{ECCH}}{ }^{[3]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{\text { CLK }}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {ECRS }}{ }^{[3]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{\text { CLK }}$ | 110 | 70 |  | ns |
| $\mathrm{t}_{\text {ECRH }}{ }^{[3]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{C L K}$ | 0 |  |  |  |
| $\mathrm{t}_{\text {ECSS }}{ }^{[2]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{\text { CLK }}$ | 85 | 70 |  | ns |
| $\mathrm{t}_{\mathrm{ECSH}}{ }^{[2]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{\mathrm{CLK}}$ | 0 |  |  | ns |
| ${ }^{\text {D }}$ ( ${ }^{\text {[2] }}{ }^{\text {[2] }}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Setup Time to $\overline{\mathrm{CLK}}$ | 90 | 50 |  | ns |
| $\mathrm{t}_{\mathrm{DCH}^{[2]}}$ | $\overline{\mathrm{SGS}}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Hold Time After $\overline{\mathrm{CLK}}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {RCS }}{ }^{[3]}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to $\overline{\mathrm{CLK}}$ | 100 | 55 |  | ns |
| $\mathrm{t}_{\mathrm{RCH}^{[3]}}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ Hold Time After $\overline{\mathrm{CLK}}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {ICS }}$ | $\overline{\text { INT Setup Time to } \overline{\mathrm{CLK}} \text { }}$ | 55 | 35 |  | ns |
| ${ }^{\text {t }} \mathrm{Cl}$ | $\overline{\mathrm{CLK}}$ to $\overline{\mathrm{INT}}$ Propagation Delay |  | 15 | 30 | ns |
| $\mathrm{t}_{\mathrm{RIS}}{ }^{[4]}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to $\overline{\mathrm{INT}}$ | 10 | 0 |  | ns |
| $\mathrm{t}_{\text {RIH }}{ }^{\text {[4] }}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Hold Time After $\overline{\mathrm{INT}}$ | 35 | 20 |  | ns |
| $t_{\text {RA }}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 80 | 100 | ns |
| $t_{\text {ELA }}$ | $\overline{\mathrm{ELR}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 40 | 55 | ns |
| teca | $\overline{\mathrm{ECS}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 100 | 130 | ns |
| $t_{\text {ETA }}$ | ETLG to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 35 | 70 | ns |
| $\mathrm{t}_{\text {DECS }}{ }^{[4]}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Setup Time to $\overline{\mathrm{ECS}}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{\mathrm{DECH}}{ }^{[4]}$ | $\overline{\mathrm{SGS}}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Hold Time After $\overline{\mathrm{ECS}}$ | 20 | 10 |  | ns |
| tren | $\overline{R_{0}} \cdot \overline{\mathrm{R}_{7}}$ to ENLG Propagation Delay |  | 45 | 70 | ns |
| teTEN | ETLG to ENLG Propagation Delay |  | 20 | 30 | ns |
| tecrn | $\overline{\text { ECS }}$ to ENLG Propagation Delay |  | 85 | 110 | ns |
| $\mathrm{t}_{\text {ECSN }}$ | $\overline{\mathrm{ECS}}$ to ENLG Propagation Delay |  | 35 | 55 | ns |

WAVEFORMS (See 8214 Waveforms, page 10-131)

## CAPACITANCE

|  | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Typ. ${ }^{\text {[1] }}$ | Max |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 5 | 10 | pF |
| Cout | Output Capacitance |  | 7 | 12 | pF |

TEST CONDITIONS: $V_{B I A S}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

## 8216/8226 <br> 4-BIT PARALLEL BI-DIRECTIONAL 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.
All inputs are low power TTL compatible. For driving MOS, the DO outputs provide a high $3.65 \mathrm{~V} \mathrm{~V}_{\mathrm{OH}}$, and for high capacitance terminated bus structures, the DB outputs provide a high $50 \mathrm{~mA} \mathrm{I}_{\mathrm{OL}}$ capability.
A non-inverting (8216) and an inverting (8226) are available to meet a wide variety of applications for buffering in microcomputer systems.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{DB}_{0}-\mathrm{DB}_{3}$ | DATA BUS <br> BI-DIRECTIONAL |
| :--- | :--- |
| $\mathrm{DI}_{0}-\mathrm{DI}_{3}$ | DATA INPUT |
| $\mathrm{DO}_{0}-\mathrm{DO}_{3}$ | DATA OUTPUT |
| $\overline{\text { DIEN }}$ | DATA IN ENABLE <br> DIRECTION CONTROL |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |

LOGIC DIAGRAM
8216


LOGIC DIAGRAM 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.

The $8216 / 8226$ is a four bit bi-directional bus driver specifically designed to buffer microcomputer system components.

## 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 drive $(50 \mathrm{~mA})$. 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.65 V ) so that direct interface to the 8080 and 8008 CPUs is achieved with an adequate amount of noise immunity ( 350 mV worst case) .

## Control Gating DIEN, CS

The $\overline{\mathrm{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 $\overline{\text { 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 a device that will reduce component count in microcomputer systems and at the same time enhance noise immunity to assure reliable, high performance operation.

(a) 8216

(b) 8226

| DIEN | $\overline{C S}$ |  |
| :---: | :---: | :--- |
| 0 | 0 | $D 1 ; D B$ |
| 1 | 0 | $D B=D O$ |
| 0 | 1 | - HIGH IMPEDANCE |
| 1 | 1 |  |

Figure 1. 8216/8226 Logic Diagrams

## APPLICATIONS OF 8216/8226

## 8080 Data Bus Buffer

The 8080 CPU Data Bus is capable of driving a single TTL load and is more than adequate for smail, single board systems. When expanding such a system to more than one board to increase $1 / 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.

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 drive capability ( 50 mA ) 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 350 mV (worst case).
The DIEN inputs to $8216 / 8226$ is connected directly to the 8080. DIEN is tied to DBIN so that proper bus flow is maintained, and $\overline{\mathrm{CS}}$ is tied to $\overline{B U S E N}$ so that 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 microcomputer 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.
The interface to Memory is simple and direct. The memories used are typically Intel ${ }^{\circledR} 8102,8102 \mathrm{~A}, 8101$ or $8107 \mathrm{~B}-4$ and have separate data inputs and outputs. The DI and DO lines of the $8216 / 8226$ tie to them directly and under control of the $\overline{M E M R}$ signal, which is connected to the $\overline{\text { DIEN }}$ 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 ${ }^{(8)} 8255$ s, and can be used for both input and output ports. The $\overline{1 / O R}$ signal is connected directly to the $\overline{D I E N}$ input so that proper data flow from the I/O device to the Data Bus is maintained.

The $8216 / 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 systems.


Figure 2. 8080 Data Bus Buffer.


Figure 3. Memory and I/O Interface to a Bi-Directional Bus.

## D.C. AND OPERATING CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages -0.5 V to +7 V
All Input Voltages -1.0 V to +5.5 V
Output Currents 125 mA
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{F} 1}$ | Input Load Current $\overline{\text { DIEN, }} \overline{\mathrm{CS}}$ |  | -0.15 | -. 5 | mA | $V_{F}=0.45$ |
| $\mathrm{I}_{\mathrm{F} 2}$ | Input Load Current All Other Inputs |  | -0.08 | -. 25 | mA | $V_{F}=0.45$ |
| $\mathrm{I}_{\mathrm{R} 1}$ | Input Leakage Current $\overline{\text { DIEN, }}$, $\overline{\text { CS }}$ |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $I_{R 2}$ | Input Leakage Current DI Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Voltage Clamp |  |  | -1 | V | $I_{C}=-5 m A$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | . 95 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| 1101 | Output Leakage Current DO <br> (3-State) DB |  |  | $\begin{gathered} 20 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=0.45 \mathrm{~V} / 5.25 \mathrm{~V}$ |
| ${ }^{\text {I CC }}$ | Power Supply Current |  | 95 | 130 | mA |  |
|  |  |  | 85 | 120 | mA |  |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output "Low" Voltage |  | 0.3 | . 45 | V | DO Outputs $\mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA}$ DB Outputs $\mathrm{I}_{\mathrm{OL}}=25 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output "Low" Voltage $\frac{8216}{8226}$ |  | 0.5 | . 6 | V | DB Outputs $\mathrm{I}_{\mathrm{OL}}=55 \mathrm{~mA}$ |
|  |  |  | 0.5 | . 6 | V | DB Outputs $\mathrm{I}_{\mathrm{OL}}=50 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output "High" Voltage | 3.65 | 4.0 |  | V | DO Outputs $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output "High" Voltage | 2.4 | 3.0 |  | V | DB Outputs $\mathrm{I}_{\mathrm{OH}}=-10 \mathrm{~mA}$ |
| los | Output Short Circuit Current | $\begin{aligned} & -15 \\ & -30 \end{aligned}$ | $\begin{aligned} & -35 \\ & -75 \end{aligned}$ | $\begin{gathered} -65 \\ -120 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | DO Outputs $\mathrm{V}_{\mathrm{O}} \cong 0 \mathrm{~V}$, DB Outputs $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |

NOTE: Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.

## WAVEFORMS



## A.C. CHARACTERISTICS

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{\text {[1] }}$ | Max. |  |  |
| TPD1 | Input to Output Delay DO Outputs |  | 15 | 25 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}, \mathrm{R}_{1}=300 \Omega \\ & \mathrm{R}_{2}=600 \Omega \end{aligned}$ |
| TPD2 | Input to Output Delay DB Outputs 8216 |  | 20 | 30 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}, \mathrm{R}_{1}=90 \Omega \\ & \mathrm{R}_{2}=180 \Omega \end{aligned}$ |
|  | 8226 |  | 16 | 25 | ns |  |
| $\mathrm{T}_{\mathrm{E}}$ | $\begin{array}{ll}\text { Output Enable Time } \\ & \\ & 8216 \\ & 8226\end{array}$ |  | 45 | 65 | ns | (Note 2) |
|  |  |  | 35 | 54 | ns | (Note 3) |
| $\mathrm{T}_{\mathrm{D}}$ | Output Disable Time |  | 20 | 35 | ns | (Note 4) |

## TEST CONDITIONS:

Input pulse amplitude of 2.5 V .
Input rise and fall times of 5 ns between 1 and 2 volts. Output loading is 5 mA and 10 pF .
Speed measurements are made at 1.5 volt levels.

CAPACITANCE ${ }^{[5]}$


| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 4 | 8 | pF |
| Cout1 | Output Capacitance |  | 6 | 10 | pF |
| Cout2 | Output Capacitance |  | 13 | 18 | pF |

## TEST CONDITIONS: $V_{B I A S}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$.

NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}$.
2. DO Outputs, $C_{L}=30 p F, R_{1}=300 / 10 \mathrm{~K} \Omega, R_{2}=180 / 1 \mathrm{~K} \Omega$; $D B$ Outputs, $C_{L}=300 \mathrm{pF}, R_{1}=90 / 10 \mathrm{~K} \Omega, R_{2}=180 / 1 \mathrm{~K} \Omega$.
3. DO Outputs, $C_{L}=30 p F, R_{1}=300 / 10 \mathrm{~K} \Omega, R_{2}=600 / 1 \mathrm{~K} ; D B$ Outputs, $C_{L}=300 \mathrm{pF}, R_{1}=90 / 10 \mathrm{~K} \Omega, R_{2}=180 / 1 \mathrm{~K} \Omega$.
4. DO Outputs, $C_{L}=5 p F, R_{1}=300 / 10 \mathrm{~K} \Omega, R_{2}=600 / 1 \mathrm{~K} \Omega ; D B$ Outputs, $C_{L}=5 p F, R_{1}=90 / 10 \mathrm{~K} \Omega, R_{2}=180 / 1 \mathrm{~K} \Omega$.
5. This parameter is periodically sampled and not $100 \%$ tested.

## Data Bus Buffer Driver for 8080 CPU

■ Low Input Load Current: . 25 mA Maximum

## ■ High Output Drive Capability for Driving System Data Bus

16-Pin Dual In-Line Package

## - 3.40V Output High Voltage for Direct Interface to $\mathbf{8 0 8 0}$ CPU

- Three-State Outputs
- Full Military Temperature Range $-55^{\circ} \mathrm{C}$ To $+125^{\circ} \mathrm{C}$
- $\pm 10 \%$ Power Supply Tolerance

The M8216 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.40 \mathrm{~V} \mathrm{~V}_{\mathrm{OH}}$, and for high capacitance terminated bus structures, the DB outputs provide a high $50 \mathrm{~mA} \mathrm{l}_{\mathrm{OL}}$ capability.

The M8216 is used to meet a wide variety of applications for buffering in microcomputer systems.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{DB}_{0}-\mathrm{DB}_{3}$ | DATA BUS <br> BI-DIRECTIONAL |
| :--- | :--- |
| $\mathrm{DI}_{0}-\mathrm{DI}_{3}$ | DATA INPUT |
| $\mathrm{DO}_{0} \cdot \mathrm{DO}_{3}$ | DATA OUTPUT |
| $\overline{\text { DIEN }}$ | DATA IN ENABLE <br> DIRECTION CONTROL |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |

## LOGIC DIAGRAM

8216


## D.C. AND OPERATING CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages . . . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . -1.0 V to +5.5 V
Output Currents . . . . . . . . . . . . . . . 125 mA
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{F} 1}$ | Input Load Current DIEN, $\overline{\text { CS }}$ |  | -0.15 | -. 5 | mA | $V_{F}=0.45$ |
| $\mathrm{I}_{\mathrm{F} 2}$ | Input Load Current All Other Inputs |  | -0.08 | -. 25 | mA | $V_{F}=0.45$ |
| $\mathrm{l}_{\mathrm{R} 1}$ | Input Leakage Current $\overline{\text { DIEN, }}$, $\overline{\mathrm{CS}}$ |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R} 2}$ | Input Leakage Current DI Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Voltage Clamp |  |  | -1.2 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input 'Low' Voltage |  |  | . 95 | V | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High' Voltage | 2.0 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| $\mid 101$ | Output Leakage Current DO <br> (3-State) DB |  |  | $\begin{gathered} 20 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| ICC | Power Supply Current |  | 95 | 130 | mA |  |
| $\mathrm{V}_{\text {OL1 }}$ | Output "Low" Voltage |  | 0.3 | . 45 | V | DO Outputs $\mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA}$ <br> DB Outputs $\mathrm{I}_{\mathrm{OL}}=25 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output "Low' Voltage |  | 0.5 | . 6 | V | DB Outputs $\mathrm{I}_{\mathrm{OL}}=50 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output "High" Voltage | 3.4 | 3.8 |  | V | DO Outputs $\mathrm{I}_{\mathrm{OH}}=-.5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output "High" Voltage | 2.4 | 3.0 |  | V | DO Outputs $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ DB Outputs $\mathrm{I}_{\mathrm{OH}}=-5.0 \mathrm{~mA}$ |
| los | Output Short Circuit Current | $\begin{aligned} & -15 \\ & -30 \end{aligned}$ | $\begin{aligned} & -35 \\ & -75 \end{aligned}$ | $\begin{gathered} -65 \\ -120 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | DO Outputs $V_{C C}=5.0 \mathrm{~V}$ <br> DB Outputs $V_{C C}=5.0 \mathrm{~V}$ |

NOTE: Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.

## WAVEFORMS



## A.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$

| Symbol | Limits |  |  |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  | Parameter | Min. | Typ.[1] |  |  | Conditions |
| $\mathrm{T}_{\text {PD1 }}$ | Input to Output Delay DO Outputs |  | 15 | 25 | ns | (NOTE 2) |
| $\mathrm{T}_{\text {PD2 }}$ | Input to Output Delay DB Outputs |  | 20 | 33 | ns | (NOTE 2) |
| $\mathrm{T}_{E}$ | Output Enable Time |  | 45 | 75 | ns | (NOTE 2) |
| $\mathrm{T}_{\mathrm{D}}$ | Output Disable Time |  | 20 | 40 | ns | (NOTE 2) |

## TEST CONDITIONS:

## TEST LOAD CIRCUIT

Input pulse amplitude of 2.5 V .
Input rise and fall times of 5 ns between 1 and 2 volts.


## CAPACITANCE

| Symbol | Parameter |  | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. ${ }^{\text {1] }}$ | Max. |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  |  | 4 | 6 | pF |
| Cout1 | Output Capacitance | DO Outputs |  | 6 | 10 | pF |
| Cout2 | Output Capacitance | DB Outputs |  | 13 | 18 | pF |

TEST CONDITIONS: $V_{B I A S}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$.
NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, V_{C C}=5.0 \mathrm{~V}$.
2.

| TEST | $\mathrm{C}_{\mathrm{L}}$ | $\mathrm{R}_{1}$ | $\mathrm{R}_{2}$ |
| :---: | :---: | :---: | :---: |
| TPD1 | 30 pF | $300 \Omega$ | $600 \Omega$ |
| TPD2 | 300 pF | $90 \Omega$ | 180S2 |
| $T_{\text {E }}$ ( $D$ O, ENABLET) | 30 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega 2$ |
| $T_{E},(D O, E N A B L E \downarrow$ ) | 30 pF | $300 \Omega$ | $600 \Omega$ |
| $T_{E},(D B, E N A B L E \uparrow)$ | 300pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| $T_{E},(\mathrm{DB}, \mathrm{ENABLE} \downarrow$ ) | 300 pF | $90 \Omega$ | $180 \Omega 2$ |
| T ${ }_{\text {, ( }}$ (DO, DISABLE $\uparrow$ ) | 5 pF | $300 \Omega$ | 60082 |
| T ${ }_{\text {D }}$ ( $D O$, DISABLE $\downarrow$ ) | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| TD, (DB, DISABLE $\uparrow$ ) | 5 pF | 90, 2 | $180 \Omega 2$ |
| TD, (DB, DISABLE ${ }^{\text {d }}$ | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

# 8251A <br> PROGRAMMABLE COMMUNICATION INTERFACE 

- Synchronous and Asynchronous
Operation
- Synchronous:

5-8 Bit Characters
Internal or External Character Synchronization
Automatic Sync Insertion

- Asynchronous:

5-8 Bit Characters
Clock Rate - 1,16 or 64 Times
Baud Rate
Break Character Generation
1, $11 / 2$, or 2 Stop Bits
False Start Bit Detection
Automatic Break Detect and Handling

- Baud Rate - DC to 64 k Baud
- Full Duplex, Double Buffered, Transmitter and Receiver
- Error Detection - Parity, Overrun, and Framing
- Fully Compatible with 8080/8085 CPU
- 28-Pin DIP Package
- All Inputs and Outputs Are TTL Compatible
- Single 5 Volt Supply
- Single TTL Clock

The 8251A is the enhanced version of the industry standard, Intel ${ }^{\circledR} 8251$ Universal Synchronous/Asynchronous Receiver/Transmitter (USART), designed for data communications with Intel's new high performance family of microprocessors such as the 8085. The 8251A is used as a peripheral device and is programmed by the CPU to operate using virtually any serial data transmission technique presently in use (including IBM Bi-Sync). The USART accepts data characters from the CPU in parallel format and then converts them into a continuous serial data stream for transmission. Simultaneously, it can receive serial data streams and convert them into parallel data characters for the CPU. The USART will signal the CPU whenever it can accept a new character for transmission or whenever it has received a character for the CPU. The CPU can read the complete status of the USART at any time. These include data transmission errors and control signals such as SYNDET, TxEMPTY. The chip is constructed using N -channel silicon gate technology.

PIN CONFIGURATION


BLOCK DIAGRAM


## 8251A BASIC FUNCTIONAL DESCRIPTION

## General

The 8251A is a Universal Synchronous/Asynchronous Receiver/Transmitter designed specifically for the 80/85 Microcomputer Systems. Like other I/O devices in a Microcomputer System, its functional configuration is programmed by the system's software for maximum flexibility. The 8251A can support virtually any serial data technique currently in use (including IBM "bi-sync").

In a communication environment an interface device must convert parallel format system data into serial format for transmission and convert incoming serial format data into parallel system data for reception. The interface device must also delete or insert bits or characters that are functionally unique to the communication technique. In essence, the interface should appear "transparent" to the CPU, a simple input or output of byte-oriented system data.

## Data Bus Buffer

This 3 -state, bidirectional, 8 -bit buffer is used to interface the 8251A to the system Data Bus. Data is transmitted or received by the buffer upon execution of INput or OUTput instructions of the CPU. Control words, Command words and Status information are also transferred through the Data Bus Buffer. The command status and data in, and data out are separate 8 -bit registers to provide double buffering.

This functional block accepts inputs from the system Control bus and generates control signals for overall device operation. It contains the Control Word Register and Command Word Register that store the various control formats for the device functional definition.

## RESET (Reset)

A "high" on this input forces the 8251A into an "Idle" mode. The device will remain at "Idle" until a new set of control words is written into the 8251A to program its functional definition. Minimum RESET pulse width is $6 \mathrm{t}_{\mathrm{CY}}$ (clock must be running).

## CLK (Clock)

The CLK input is used to generate internal device timing and is normally connected to the Phase 2 (TTL) output of the 8224 Clock Generator. No external inputs or outputs are referenced to CLK but the frequency of CLK must be greater than 30 times the Receiver or Transmitter data bit rates.

## $\overline{W R}$ (Write)

A "low" on this input informs the 8251A that the CPU is writing data or control words to the 8251A.

## $\overline{\mathrm{RD}}$ (Read)

A "low" on this input informs the 8251A that the CPU is reading data or status information from the 8251A.

## $C / \bar{D}$ (Control/Data)

This input, in conjunction with the $\overline{W R}$ and $R \overline{R D}$ nputsd informs the 8251A that the word on the Data Bus is either a data character, control word or status information.
$1=$ CONTROL/STATUS $0=$ DATA

## $\overline{\mathrm{CS}}$ (Chip Select)

A "low" on this input selects the 8251A. No reading or writing will occur unless the device is selected. When $\overline{\mathrm{CS}}$ is high, the Data Bus in the float state and $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ will have no effect on the chip.


| C/D | $\overline{\mathrm{RD}}$ | $\overline{W R}$ | $\overline{\mathrm{CS}}$ |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | 0 | 8251A DATA $\Rightarrow$ DATA BUS |
| 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow 8251$ A DATA |
| 1 | 0 | 1 | 0 | STATUS $\Rightarrow$ DATA BUS |
| 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ CONTROL |
| $x$ | 1 | 1 | 0 | DATA BUS $\Rightarrow 3-S T A T E$ |
| X | X | X | 1 | DATA BUS $\Rightarrow$ 3-STATE |

## Modem Control

The 8251A has a set of control inputs and outputs that can be used to simplify the interface to almost any Modem. The Modem control signals are general purpose in nature and can be used for functions other than Modem control, if necessary.

## $\overline{\text { DSR }}$ (Data Set Ready)

The $\overline{\mathrm{DSR}}$ input signal is a general purpose, 1 -bit inverting input port. Its condition can be tested by the CPU using a Status Read operation. The $\overline{\mathrm{DSR}}$ input is normally used to test Modem conditions such as Data Set Ready.

## $\overline{\text { DTR }}$ (Data Terminal Ready)

The $\overline{\mathrm{DTR}}$ output signal is a general purpose, 1 -bit inverting output port. It can be set "low" by programming the appropriate bit in the Command Instruction word. The $\overline{\mathrm{DTR}}$ output signal is normally used for Modem control such as Data Terminal Ready or Rate Select.

## $\overline{\text { RTS }}$ (Request to Send)

The $\overline{\mathrm{RTS}}$ output signal is a general purpose, 1 -bit inverting output port. It can be set "low" by programming the appropriate bit in the Command Instruction word. The $\overline{\mathrm{RTS}}$ output signal is normally used for Modem control such as Request to Send.

## $\overline{\mathrm{CTS}}$ (Clear to Send)

A "low" on this input enables the 8251A to transmit serial data if the Tx Enable bit in the Command byte is set to a "one." If either a Tx Enable off or CTS off condition occurs while the $T x$ is in operation, the $T x$ will transmit all the data in the USART, written prior to Tx Disable command before shutting down.

## Transmitter Buffer

The Transmitter Buffer accepts parallel data from the Data Bus Buffer, converts it to a serial bit stream, inserts the appropriate characters or bits (based on the communication technique) and outputs a composite serial stream of data on the TxD output pin on the falling edge of $\overline{T x C}$. The transmitter will begin transmission upon being enabled if $\overline{\mathrm{CTS}}=0$. The TxD line will be held in the marking state immediately upon a master Reset or when Tx Enable/ $\overline{C T S}$ off or TxEMPTY.

## Transmitter Control

The transmitter Control manages all activities associated with the transmission of serial data. It accepts and issues signals both externally and internally to accomplish this function.

## TxRDY (Transmitter Ready)

This output signals the CPU that the transmitter is ready to accept a data character. The TxRDY output pin can be used as an interrupt to the system, since it is masked by Tx Disabled, or, for Polled operation, the CPU can check TxRDY using a Status Read operation. TxRDY is automatically reset by the leading edge of $\overline{W R}$ when a data character is loaded from the CPU.

Note that when using the Polled operation, the TxRDY status bit is not masked by Tx Enabled, but will only indicate the Empty/Full Status of the Tx Data Input Register.

## TxE (Transmitter Empty)

When the 8251A has no characters to transmit, the T×EMP. TY output will go "high". It resets automatically upon re ceiving a character from the CPU. TxEMPTY can be used to indicate the end of a transmission mode, so that the CPU "knows" when to "turn the line around" in the halfduplexed operational mode. TxEMPTY is independent of the Tx Enable bit in the Command instruction.
In SYNChronous mode, a "high" on this output indicates that a character has not been loaded and the SYNC character or characters are about to be or are being transmitted automatically as "fillers". TxEMPTY does not go low when the SYNC characters are being shifted out.


## $\overline{\mathrm{TxC}}$ (Transmitter Clock)

The Transmitter Clock controls the rate at which the character is to be transmitted. In the Synchronous transmission mode, the Baud Rate ( $1 x$ ) is equal to the $\overline{T x C}$ frequency. In Asynchronous transmission mode the baud rate is a fraction of the actual $\overline{T x C}$ frequency. A portion of the mode instruction selects this factor; it can be $1,1 / 16$ or $1 / 64$ the $\overline{T x C}$.

## For Example:

$$
\begin{aligned}
& \text { If Baud Rate equals } 110 \text { Baud, } \\
& \overline{T x C} \text { equals } 110 \mathrm{~Hz}(1 x) \\
& \overline{T x C} \text { equals } 1.76 \mathrm{kHz}(16 x) \\
& \overline{T x C} \text { equals } 7.04 \mathrm{kHz}(64 x) \text {. }
\end{aligned}
$$

The falling edge of $\overline{T x C}$ shifts the serial data out of the 8251A.

## Receiver Buffer

The Receiver accepts serial data, converts this serial input to parallel format, checks for bits or characters that are unique to the communication technique and sends an "assembled" character to the CPU. Serial data is input to RxD pin, and is clocked in on the rising edge of $\overline{\mathrm{R} \times \mathrm{C}}$.

## Receiver Control

This functional block manages all receiver-related activities which consist of the following features:

The RxD initialization circuit prevents the 8251A from mistaking an unused input line for an active low data line in the "break condition". Before starting to receive serial characters on the RxD line, a valid " 1 " must first be detected after a chip master Reset. Once this has been determined, a search for a valid low (Start bit) is enabled. This feature is only active in the asynchronous mode, and is only done once for each master Reset.
The False Start bit detection circuit prevents false starts due to a transient noise spike by first detecting the falling edge and then strobing the nominal center of the Start bit ( $\mathrm{R} \times \mathrm{D}=$ low).
The Parity Toggle F/F and Parity Error F/F circuits are used for parity error detection and set the corresponding status bit.
The Framing Error Flag F/F is set if the Stop bit is absent at the end of the data byte (asynchronous mode), and also sets the corresponding status bit.

## RxRDY (Receiver Ready)

This output indicates that the 8251A contains a character that is ready to be input to the CPU. Rx RDY can be connected to the interrupt structure of the CPU or, for Polled operation, the CPU can check the condition of RxRDY using a Status Read operation.

Rx Enable off both masks and holds RxRDY in the Reset Condition. For Asynchronous mode, to set RxRDY, the Receiver must be Enabled to sense a Start Bit and a complete character must be assembled and transferred to the Data Output Register. For Synchronous mode, to set RxRDY, the Receiver must be enabled and a character must finish assembly and be transferred to the Data Output Register.

Failure to read the received character from the $R \times$ Data Output Register prior to the assembly of the next Rx Data character will set overrun condition error and the previous character will be written over and lost. If the Rx Data is being read by the CPU when the internal transfer is occurring, overrun error will be set and the old character will be lost.

## $\overline{\mathrm{RxC}}$ (Receiver Clock)

The Receiver Clock controls the rate at which the character is to be received. In Synchronous Mode, the Baud Rate (1x) is equal to the actual frequency of $\overline{\mathrm{RxC}}$. In Asynchronous Mode, the Baud Rate is a fraction of the actual $\overline{\mathrm{RXC}}$ fre-
quency. A portion of the mode instruction selects this factor; $1,1 / 16$ or $1 / 64$ the $\overline{\mathrm{RXC}}$.
For Example:
Baud Rate equals 300 Baud, if
$\overline{\mathrm{RxC}}$ equals 300 Hz (1x)
$\overline{\mathrm{RxC}}$ equals 4800 Hz (16x)
$\overline{\mathrm{RxC}}$ equals 19.2 kHz ( 64 x ).
Baud Rate equals 2400 Baud, if
$\overline{\mathrm{RxC}}$ equals 2400 Hz (1x)
$\overline{R \times C}$ equals 38.4 kHz (16x)
$\overline{R \times C}$ equals 153.6 kHz ( 64 x ).
Data is sampled into the 8251A on the rising edge of $\overline{\mathrm{RxC}}$.
NOTE: In most communications systems, the 8251A will be handling both the transmission and reception operations of a single link. Consequently, the Receive and Transmit Baud Rates will be the same. Both $\overline{T \times C}$ and $\overline{R \times C}$ will require identical frequencies for this operation and can be tied together and connected to a single frequency source (Baud Rate Generator) to simplify the interface.

## SYNDET (SYNC Detect)/BRKDET (Break Detect)

This pin is used in SYNChronous Mode for SYNDET and may be used as either input or output, programmable through the Control Word. It is reset to output mode low upon RESET. When used as an output (internal Sync mode), the SYNDET pin will go "high" to indicate that the 8251A has located the SYNC character in the Receive mode. If the 8251 A is programmed to use double Sync characters (bisync), then SYNDET will go "high" in the middle of the last bit of the second Sync character. SYNDET is automatically reset upon a Status Read operation.


When used as an input (external SYNC detect mode), a positive going signal will cause the 8251A to start assembling data characters on the rising edge of the next $\overline{\mathrm{RxC}}$. Once in SYNC, the "high" input signal can be removed. the period of $\overline{\mathrm{R} \times \mathrm{C}}$. When External SYNC Detect is programmed, the Internal SYNC Detect is disabled.

## Break Detect (Async Mode Only)

This output will go high whenever an all zero word of the programmed length (including start bit, data bit, parity bit, and one stop bit) is received. Break Detect may also be read as a Status bit. It is reset only upon a master chip Reset or Rx Data returning to a "one" state.


## 8251 A Interface to 8080 Standard System Bus

## DETAILED OPERATION DESCRIPTION

## General

The complete functional definition of the 8251A is programmed by the system's software. A set of control words must be sent out by the CPU to initialize the 8251A to support the desired communications format. These control words will program the: BAUD RATE, CHARACTER LENGTH, NUMBER OF STOP BITS, SYNCHRONOUS or ASYNCHRONOUS OPERATION, EVEN/ODD/OFF PARITY, etc. In the Synchronous Mode, options are also provided to select either internal or external character synchronization.

Once programmed, the 8251A is ready to perform its communication functions. The TxRDY output is raised "high" to signal the CPU that the 8251A is ready to receive a data character from the CPU. This output (TxRDY) is reset automatically when the CPU writes a character into the 8251A. On the other hand, the 8251A receives serial data from the MODEM or I/O device. Upon receiving an entire character, the RxRDY output is raised "high" to signal the CPU that the 8251A has a complete character ready for the CPU to fetch. RxRDY is reset automatically upon the CPU data read operation.

The 8251A cannot begin transmission untli the Tx Enable (Transmitter Enable) bit is set in the Command Instruction and it has received a Clear To Send (CTS) input. The $\overline{\mathrm{C}} \times \mathrm{D}$ output will be held in the marking state upon Reset.

## Programming the 8251A

Prior to starting data transmission or reception, the 8251A must be loaded with a set of control words generated by the CPU. These control signals define the complete functional definition of the 8251A and must immediately follow a Reset operation (internal or external).
The control words are split into two formats:

1. Mode Instruction
2. Command Instruction

## Mode Instruction

This format defines the general operational characteristics of the 8251A. It must follow a Reset operation (internal or external). Once the Mode Instruction has been written into the 8251A by the CPU, SYNC characters or Command Instructions may be inserted.

## Command Instruction

This format defines a status word that is used to control the actual operation of the 8251A.
Both the Mode and Command Instructions must conform to a specified sequence for proper device operation. The Mode Instruction must be inserted immediately following a Reset operation, prior to using the 8251A for data communication.
All control words written into the 8251A after the Mode Instruction will load the Command Instruction. Command Instructions can be written into the 8251A at any time in the data block during the operation of the 8251 A . To return to the Mode Instruction format, the master Reset bit in the Command Instruction word can be set to initiate an internal Reset operation which automatically places the 8251A back into the Mode Instruction format. Command Instructions must follow the Mode Instructions or Sync characters.


## Typical Data Block

## Mode Instruction Definition

The 8251A can be used for either Asynchronous or Synchronous data communication. To understand how the Mode Instruction defines the functional operation of the 8251 A , the designer can best view the device as two separate components sharing the same package, one Asynchronous the other Synchronous. The format definition can be changed only after a master chip Reset. For explanation purposes the two formats will be isolated.

NOTE: When parity is enabled it is not considered as one of the data bits for the purpose of programming the word length. The actual parity bit received on the Rx Data line cannot be read on the Data Bus. In the case of a programmed character length of less than 8 bits, the least significant Data Bus bits will hold the data; unused bits are "don't care" when writing data to the 8251A, and will be "zeros" when reading the data from the 8251A.

## Asynchronous Mode (Transmission)

Whenever a data character is sent by the CPU the 8251A automatically adds a Start bit (low level) followed by the data bits (least significant bit first), and the programmed number of Stop bits to each character. Also, an even or odd Parity bit is inserted prior to the Stop bit(s), as defined by the Mode Instruction. The character is then transmitted as a serial data stream on the TxD output. The serial data is shifted out on the falling edge of $\overline{T \times C}$ at a rate equal to $1,1 / 16$, or $1 / 64$ that of the $\overline{T \times C}$, as defined by the Mode Instruction. BREAK characters can be continuously sent to the $T_{x D}$ if commanded to do so.

When no data characters have been loaded into the 8251A the TxD output remains "high" (marking) unless a Break (continuously low) has been programmed.

## Asynchronous Mode (Receive)

The RxD line is normally high. A falling edge on this line triggers the beginning of a START bit. The validity of this START bit is checked by again strobing this bit at its nominal center (16X or 64 X mode only). If a low is detected again, it is a valid START bit, and the bit counter will start counting. The bit counter thus locates the center of the data bits, the parity bit (if it exists) and the stop bits. If parity error occurs, the parity error flag is set. Data and parity bits are sampled on the RxD pin with the rising edge of $\overline{\mathrm{RxC}}$. If a low level is detected as the STOP bit, the Framing Error flag will be set. The STOP bit signals the end of a character. Note that the receiver requires only one stop bit, regardless of the number of stop bits programmed. This character is then loaded into the parallel I/O buffer of the 8251A. The RxRDY pin is raised to signal the CPU that a character is ready to be fetched. If a previous character has not been fetched by the CPU, the present character replaces it in the I/O buffer, and the OVERRUN Error flag is raised (thus the previous character is lost). All of the error flags can be reset by an Error Reset Instruction. The occurrence of any of these errors will not affect the operation of the 8251A.


## Asynchronous Mode



TRANSMISSION FORMAT


RECEIVE FORMAT

*NOTE: IF CHARACTER LENGTH IS DEFINED AS 5, 6 OR 7 BITS THE UNUSED BITS ARE SET TO "ZERO"

## Synchronous Mode (Transmission)

The $\operatorname{TxD}$ output is continuously high until the CPU sends its first character to the 8251A which usually is a SYNC character. When the $\overline{\text { CTS }}$ line goes low, the first character is serially transmitted out. All characters are shifted out on the falling edge of $\overline{T x C}$. Data is shifted out at the same rate as the $\overline{T \times C}$.
Once transmission has started, the data stream at the TxD output must continue at the $\overline{T \times C}$ rate. If the CPU does not provide the 8251A with a data character before the 8251A Transmitter Buffers become empty, the SYNC characters (or character if in single SYNC character mode) will be automatically inserted in the TxD data stream. In this case, the TxEMPTY pin is raised high to signal that the 8251 A is empty and SYNC characters are being sent out. TxEMPTY does not go low when the SYNC is being shifted out (see figure below). The TxEMPTY pin is internally reset by a data character being written into the 8251A.


## Synchronous Mode (Receive)

In this mode, character synchronization can be internally or externally achieved. If the SYNC mode has been programmed, ENTER HUNT command should be included in the first command instruction word written. Data on the $R \times D$ pin is then sampled in on the rising edge of $\overline{\mathrm{RxC}}$. The content of the Rx buffer is compared at every bit boundary with the first SYNC character until a match occurs. If the 8251A has been programmed for two SYNC characters, the subsequent received character is also compared; when both SYNC characters have been detected, the USART ends the HUNT mode and is in character synchronization. The SYNDET pin is then set high, and is reset automatically by a STATUS READ. If parity is programmed, SYNDET will not be set until the middle of the parity bit instead of the middle of the last data bit.
In the external SYNC mode, synchronization is achieved by applying a high level on the SYNDET pin, thus forcing the 8251A out of the HUNT mode. The high level can be removed after one $\overline{\mathrm{RxC}}$ cycle. An ENTER HUNT command has no effect in the asynchronous mode of operation.
Parity error and overrun error are both checked in the same way as in the Asynchronous Rx mode. Parity is checked when not in Hunt, regardless of whether the Receiver is enabled or not.
The CPU can command the receiver to enter the HUNT mode if synchronization is lost. This will also set all the used character bits in the buffer to a "one", thus preventing a possible false SYNDET caused by data that happens to be in the Rx Buffer at ENTER HUNT time. Note that
the SYNDET F/F is reset at each Status Read, regardless of whether internal or external SYNC has been programmed. This does not cause the 8251A to return to the HUNT mode. When in SYNC mode, but not in HUNT, Sync Detection is still functional, but only occurs at the "known" word boundaries. Thus, if one Status Read indicates SYNDET and a second Status Read also indicates SYNDET, then the programmed SYNDET characters have been received since the previous Status Read. (If double character sync has been programmed, then both sync characters have been contiguously received to gate a SYNDET indication.) When external SYNDET mode is selected, internal Sync Detect is disabled, and the SYNDET F/F may be set at any bit boundary.

Mode Instruction Format


NOTE: IN EXTERNAL SYNC MODE, PROGRAMMING DOUBLE CHARACTER SYNC WILL AFFECT ONLY THE Tx.

Data Format, Synchronous Mode


RECEIVE FORMAT


## COMMAND INSTRUCTION DEFINITION

Once the functional definition of the 8251A has been programmed by the Mode Instruction and the Sync Characters are loaded (if in Sync Mode) then the device is ready to be used for data communication. The Command Instruction controls the actual operation of the selected format. Functions such as: Enable Transmit/Receive, Error Reset and Modem Controls are provided by the Command Instruction.

Once the Mode Instruction has been written into the 8251A and Sync characters inserted, if necessary, then all further "control writes" (C/ $\bar{D}=1$ ) will load a Command Instruction. A Reset Operation (internal or external) will return the 8251A to the Mode Instruction format.


[^5]
## Command Instruction Format

## STATUS READ DEFINITION

In data communication systems it is often necessary to examine the "status" of the active device to ascertain if errors have occurred or other conditions that require the processor's attention. The 8251A has facilities that allow the programmer to "read" the status of the device at any time during the functional operation. (The status update is inhibited during status read).

A normal "read" command is issued by the CPU with $C / \bar{D}=1$ to accomplish this function.
Some of the bits in the Status Read Furmat have identical meanings to external output pins so that the 8251A can be used in a completely Polled environment or in an interrupt driven environment. TxRDY is an exception.

Note that status update can have a maximum delay of 28 clock periods from the actual event affecting the status.


## Status Read Format

Note 1: TXRDY status bit has different meanings from the TXRDY output pin: The former is not conditioned by $\overline{\mathrm{CTS}}$ and TxEN; the latter is conditioned by both $\overline{C T S}$ and TxEN.
i.e. $T x R D Y$ status bit $=\mathrm{DB}$ Buffer Empty
$T \times R D Y$ pin out $=D B$ Buffer Empty $\cdot(C T S=0) \cdot(T \times E N=1)$

APPLICATIONS OF THE 8251A


Asynchronous Serial Interface to CRT Terminal, DC-9600 Baud


Synchronous Interface to Terminal or Peripheral Device


Asynchronous Interface to Telephone Lines


Synchronous Interface to Telephone Lines

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias. . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage On Any Pin

With Respect to Ground $\qquad$ -0.5 V to +7 V
Power Dissipation $\qquad$ 1 Watt
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{OFL}}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \mathrm{TO} 0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ TO 0.45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 100 | mA | All Outputs $=$ High |

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  | 20 | pF | Unmeasured pins returned to GND |

## TEST LOAD CIRCUIT:



Figure 1.

TYPICAL $\triangle$ OUTPUT DELAY VS. $\triangle$ CAPACITANCE (dB)


## A.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{GND}=0 \mathrm{~V}$
BUS PARAMETERS: (Note 1)

## READ CYCLE

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A R}$ | Address Stable Before $\overline{\text { READ }}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | 0 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RA}}$ | Address Hold Time for $\overline{\mathrm{READ}}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | 0 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\text { READ Pulse Width }}$ | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Delay from $\overline{\text { READ }}$ |  | 200 | ns | $3, \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | $\overline{\text { READ }}$ to Data Floating | 10 | 100 | ns |  |

## WRITE CYCLE

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {AW }}$ | Address Stable Before $\overline{\text { WRITE }}$ | 0 |  | ns |  |
| $\mathrm{t}_{\text {WA }}$ | Address Hold Time for $\overline{\text { WRITE }}$ | 0 |  | ns |  |
| $\mathrm{t}_{\text {WW }}$ | WRITE Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\text {DW }}$ | Data Set Up Time for $\overline{\text { WRITE }}$ | 150 |  | ns |  |
| $\mathrm{t}_{\text {WD }}$ | Data Hold Time for $\overline{\text { WRITE }}$ | 0 |  | ns |  |
| $\mathrm{t}_{\text {RV }}$ | Recovery Time Between WRITES | 6 |  | $\mathrm{t}_{C Y}$ | Note 4 |

NOTES: 1. AC timings measured $\mathrm{V}_{\mathrm{OH}}=2.0, \mathrm{~V}_{\mathrm{OL}}=0.8$, and with load circuit of Figure 1.
2. Chip Select ( $\overline{C S}$ ) and Command/Data (C/D) are considered as Addresses.
3. Assumes that Address is valid before $\overline{R_{\mathrm{D}}} \downarrow$.
4. This recovery time is for Mode Initialization only. Write Data is allowed only when TxRDY $=1$. Recovery Time between Writes for Asynchronous Mode is $8 \mathrm{t}_{\mathrm{CY}}$ and for Synchronous Mode is 16 t CY .

INPUT waveforms for AC tests:


OTHER TIMINGS:

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{C} Y}$ | Clock Period | 320 | 1.35 | $\mu \mathrm{s}$ | Notes 5, 6 |
| ${ }_{\text {t }}$ | Clock High Pulse Width | 120 | ${ }_{\text {t }} \mathrm{C} \mathrm{Y}-90$ | ns |  |
| t $\bar{\phi}$ | Clock Low Pulse Width | 90 |  | ns |  |
| $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ | Clock Rise and Fall Time | 5 | 20 | ns |  |
| $\mathrm{t}_{\text {DTX }}$ | TxD Delay from Falling Edge of $\overline{T \times C}$ |  | 1 | $\mu \mathrm{s}$ |  |
| $\mathrm{tSR}_{\mathrm{x}}$ | Rx Data Set-Up Time to Sampling Pulse | 2 |  | $\mu \mathrm{s}$ |  |
| $t_{\text {HR }}{ }_{\text {c }}$ | Rx Data Hold Time to Sampling Pulse | 2 |  | $\mu \mathrm{s}$ |  |
| $\mathrm{f}_{\mathrm{T} \times}$ | Transmitter Input Clock Frequency <br> 1x Baud Rate <br> 16x Baud Rate <br> 64x Baud Rate | DC <br> DC <br> DC | $\begin{array}{r} 64 \\ 310 \\ 615 \end{array}$ | kHz <br> kHz <br> kHz |  |
| ${ }_{\text {t }}^{\text {TPW }}$ | Transmitter Input Clock Pulse Width 1x Baud Rate 16x and 64x Baud Rate | $\begin{array}{r} 12 \\ 1 \end{array}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| ${ }^{\text {T TPD }}$ | Transmitter Input Clock Pulse Delay <br> 1x Baud Rate <br> $16 x$ and $64 x$ Baud Rate | $\begin{array}{r} 15 \\ 3 \end{array}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| $\mathrm{f}_{\mathrm{Rx}}$ | Receiver Input Clock Frequency <br> 1x Baud Rate <br> 16x Baud Rate <br> 64x Baud Rate | DC <br> DC <br> DC | $\begin{array}{r} 64 \\ 310 \\ 615 \end{array}$ | kHz <br> kHz <br> kHz |  |
| $t_{\text {RPW }}$ | Receiver Input Clock Pulse Width 1x Baud Rate 16x and $64 x$ Baud Rate | $\begin{array}{r} 12 \\ 1 \end{array}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| ${ }_{\text {tr }}$ | Receiver Input Clock Pulse Delay 1x Baud Rate 16x and 64x Baud Rate | $\begin{array}{r} 15 \\ 3 \end{array}$ |  | $\mathrm{t}_{\mathrm{C}} \mathrm{Y}$ $t_{C}$ |  |
| $\mathrm{t}_{\text {T } \times R D Y}$ | TxRDY Pin Delay from Center of last Bit |  | 8 | ${ }_{\text {t }}^{\text {c }}$ Y | Note 7 |
| $\mathrm{t}_{\text {TXRDY CLEAR }}$ | TxRDY $\downarrow$ from Leading Edge of $\overline{W R}$ |  | 150 | ns | Note 7 |
| $t_{\text {RXRD }}$ | RxRDY Pin Delay from Center of last Bit |  | 24 | ${ }_{\text {t }}^{\text {c }}$ Y | Note 7 |
| $\mathrm{t}_{\mathrm{RX}_{\times} \mathrm{RDY} \mathrm{CLEAR}}$ | R×RDY $\downarrow$ from Leading Edge of $\overline{\mathrm{RD}}$ |  | 150 | ns | Note 7 |
| ${ }_{\text {I }} \mathrm{S}$ | Internal SYNDET Delay from Rising Edge of $\overline{\mathrm{RxC}}$ |  | 24 | ${ }^{\text {t }} \mathrm{C} Y$ | Note 7 |
| $t_{\text {ES }}$ | External SYNDET Set-Up Time Before Falling Edge of $\overline{\mathrm{R} \times C}$ |  | 16 | ${ }^{t} \mathrm{C} Y$ | Note 7 |
| $\mathrm{t}_{\text {TXEMPTY }}$ | TxEMPTY Delay from Center of Data Bit |  | 20 | ${ }^{\text {t }} \mathrm{CY}$ | Note 7 |
| $t_{\text {W }}$ | Control Delay from Rising Edge of WRITE (TxEn, $\overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}$ ) |  | 8 | ${ }^{\text {t }} \mathrm{CY}$ | Note 7 |
| ${ }^{\text {t }}$ CR | Control to READ Set-Up Time ( $\overline{\mathrm{DSR}}, \overline{\mathrm{CTS}}$ ) |  | 20 | ${ }_{\text {t }}^{\text {c }}$ | Note 7 |

5. The $T \times C$ and $R \times C$ frequencies have the following limitations with respect to CLK.

For $1 \times$ Baud Rate, $f_{T_{x}}$ or $f_{R_{x}} \leqslant 1 /\left(30 t_{C Y}\right)$
For $16 x$ and $64 x$ Baud Rate, $f_{T x}$ or $f_{R x} \leqslant 1 /\left(4.5 t_{C Y}\right)$
6. Reset Pulse Width $=6{ }^{t} \mathrm{CY}$ minimum; System Clock must be running during Reset.
7. Status update can have a maximum delay of 28 clock periods from the event affecting the status.

## SYSTEM CLOCK INPUT



TRANSMITTER CLOCK \& DATA


## RECEIVER CLOCK \& DATA



WRITE DATA CYCLE $(C P U \rightarrow$ USART)


READ DATA CYCLE (CPU $\leftarrow$ USART)



## READ CONTROL OR INPUT PORT (CPU $\longleftarrow$ USART)



NOTE \#1: $T_{\text {WC }}$ INCLUDES THE RESPONSE TIMING OF A CONTROL bYte, NOTE \#2: $T_{C R}$ INCLUDES THE EFFECT OF CTS ON THE TXENBL CIRCUITRY.

TRANSMITTER CONTROL \& FLAG TIMING (ASYNC MODE)



TRANSMITTER CONTROL \& FLAG TIMING (SYNC MODE)


EXAMPLE FORMAT $=5$ BIT CHARACTER WITH PARITY, 2 SYNC CHARACTERS.

RECEIVER CONTROL \& FLAG TIMING (SYNC MODE)


NOTE $=1$ : INTERNAL SYNC, 2 SYNC CHARACTERS, 5 BITS, WITH PARITY
NOTE $=2$ : EXTERNAL SYNC, 5 BITS, WITH PARITY

# PROGRAMMABLE COMMUNICATION INTERFACE 

## - Synchronous and Asynchronous Operation

## - Synchronous:

## 5-8 Bit Characters

Internal or External Character Synchronization
Automatic Sync Insertion

- Asynchronous:

5-8 Bit Characters
Clock Rate - 1,16 or 64 Times Baud Rate
Break Character Generation
1, 11/2, or 2 Stop Bits
False Start Bit Detection

- Baud Rate - DC to 56k Baud (Sync Mode)
DC to 8.1k Baud (Async Mode)
- Full Duplex, Double Buffered, Transmitter and Receiver
- Error Detection - Parity, Overrun, and Framing
- Fully Compatible with 8080 CPU
- All Inputs and Outputs Are TTL Compatible
- Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- $\pm 10 \%$ Power Supply Tolerance

The M8251 is a Universal Synchronous/Asynchronous Receiver/Transmitter (USART) Chip designed for data communications in microcomputer systems. The USART is used as a peripheral device and is programmed by the CPU to operate using virtually any serial data transmission technique presently in use (including IBM Bi-Sync). The USART accepts data characters from the CPU in parallel format and then converts them into a continuous serial data stream for transmission. Simultaneously it can receive serial data streams and convert them into parallel data characters for the CPU. The USART will signal the CPU whenever it can accept a new character for transmission or whenever it has received a character for the CPU. The CPU can read the complete status of the USART at any time. These include data transmission errors and control signals such as SYNDET, TxEMPT. The chip is constructed using N -channel silicon gate technology.

PIN CONFIGURATION


| Pin Name | Pin Function |
| :--- | :--- |
| $D_{7}-D_{0}$ | Data Bus (8 bits) |
| $\mathbf{C / D}$ | Control or Data is to be Written or Read |
| $\overline{R D}$ | Read Data Command |
| $\overline{W R}$ | Write Data or Control Command |
| $\overline{C S}$ | Chip Enable |
| CLK | Clock Pulse (TTL) |
| RESET | Reset |
| $\overline{T \times C}$ | Transmitter Clock |
| $T \times D$ | Transmitter Data |
| $\overline{R \times C}$ | Receiver Clock |
| RxD | Receiver Data |
| RxRDY | Receiver Ready (has character for 8080) |
| TxRDY | Transmitter Ready (ready for char. from 8080) |


| Pin Name | Pin Function |
| :--- | :--- |
| $\overline{\overline{D S R}}$ | Data Set Ready |
| $\overline{\text { DTR }}$ | Data Terminal Ready |
| SYNDET | Sync Detect |
| $\overline{\text { RTS }}$ | Request to Send Data |
| $\overline{\text { CTS }}$ | Clear to Send Data |
| TxE | Transmitter Empty |
| VCC | +5 Volt Supply |
| GND | Ground |

M8251 BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage On Any Pin
With Respect to GND . . . . . . . . . . . . . . -0.5V to +7V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -.5 |  | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{DL}}$ | Data Bus Leakage |  |  | -50 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=.45 \mathrm{~V}$ |
|  |  |  |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 45 | 80 |  |  |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{G}_{\mathrm{N}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to GND. |

## TEST LOAD CIRCUIT:



Figure 1.

TYPICAL $\triangle$ OUTPUT DELAY VS. $\triangle$ CAPACITANCE (dB)


## A.C. CHARACTERISTICS ${ }^{[2]}$

$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }} \mathrm{C}$ | Clock Period | . 420 |  | 1.35 | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\phi} \mathrm{W}$ | Clock Pulse Width | 220 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ | Clock Rise and Fall Time | 0 |  | 50 | ns |  |
| $t_{\text {WR }}$ | $\overline{\text { WRITE Pulse Width }}$ | 400 |  |  | ns |  |
| ${ }^{t}{ }_{\text {D }}$ | Data Set-Up Time for WRITE | 200 |  |  | ns |  |
| ${ }_{\text {t }}^{\text {D }}$ H | Data Hold Time for $\overline{\text { WRITE }}$ | 40 |  |  | ns |  |
| ${ }^{\text {AW }}$ | Address Stable before $\overline{\text { WRITE }}$ | 20 |  |  | ns |  |
| $t_{\text {WA }}$ | Address Hold Time for WRITE | 20 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | READ Pulse Width | 430 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{DD}}$ | Data Delay from $\overline{\mathrm{READ}}$ |  |  | 350 | ns |  |
| ${ }_{t}{ }_{\text {D }}$ | $\overline{\mathrm{READ}}$ to Data Floating [3] | 25 |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$ to 100 pF |
| $\mathrm{t}_{\text {AR }}$ | Address (CE, C/ $\overline{\mathrm{D}}$ ) Stable before $\overline{\mathrm{READ}}$ | 50 |  |  | ns |  |
| $t_{\text {RA }}$ | Address (CE, C/D) Hold Time for $\overline{\text { READ }}$ | 5 |  |  | ns |  |
| ${ }^{\text {t }{ }_{\text {T }} \times}$ | TxD Delay from Falling Edge of TxC |  |  | 1 | $\mu \mathrm{s}$ |  |
| ${ }_{\text {t }}^{\text {SR }} \mathrm{x}$ | Rx Data Set-Up Time to Sampling Pulse | 2 |  |  | $\mu \mathrm{s}$ |  |
| $t_{\text {HRx }}$ | Rx Data Hold Time to Sampling Pulse | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{f}_{\mathrm{TX} \text { [1]}}$ | Transmitter Clock Frequency 1X Baud Rate 16X and 64X Baud Rate | $\begin{aligned} & \text { DC } \\ & \text { DC } \end{aligned}$ |  | $\begin{gathered} 56 \\ 529 \end{gathered}$ | $\begin{aligned} & \mathrm{KHz} \\ & \mathrm{KHz} \end{aligned}$ |  |
| $\mathrm{f}_{\mathrm{Rx}}[1]$ | Receiver Clock Frequency 1X Baud Rate 16X and 64X Baud Rate | $\begin{aligned} & \text { DC } \\ & \text { DC } \end{aligned}$ |  | $\begin{gathered} 56 \\ 529 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{KHz} \\ & \mathrm{KHz} \\ & \hline \end{aligned}$ |  |
| ${ }^{\text {T }}$ ${ }_{\text {x }}$ | TxRDY Delay from Center of Data Bit |  |  | 16 | CLK Period |  |
| $t_{\text {R }} \mathrm{x}$ | RxRDY Delay from Center of Data Bit | 15 |  | 20 | CLK Period |  |
| $\mathrm{t}_{\text {IS }}$ | Internal Syndet Delay from Center of Data Bit | 20 |  | 25 | CLK Period |  |
| $t_{\text {ES }}$ | External Syndet Set-Up Time before Falling Edge of RxC |  |  | 16 | CLK Period |  |

Note 1: The $T \times C$ and $R \times C$ frequencies have the following limitation with respect to CLK.
For ASYNC Mode, $\mathrm{t}_{\mathrm{T}}$ or $\mathrm{t}_{\mathrm{Rx}} \geqslant 4.5 \mathrm{t}_{\mathrm{C}} \mathrm{C}$
For SYNC Mode, $\mathrm{t}_{\mathrm{T}}$ or $\mathrm{t}_{\mathrm{R}_{\mathrm{x}} \geqslant} \geqslant 30 \mathrm{t}_{\mathrm{C}} \mathrm{Y}$
2. AC timings are measured at $\mathrm{VOH}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.8 \mathrm{~V}$, and load circuit of Figure 1.
3. Float timings are measured at $\mathrm{V}_{\mathrm{OH}}=2.48 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=2.08 \mathrm{~V}$

Figure 1. Test Load Circuit.


## 8253, 8253-5 PROGRAMMABLE INTERVAL TIMER

## MCS-85 ${ }^{\text {TM }}$ Compatible 8253-5

3 Independent 16-Bit Counters
DC to $2 \mathbf{M H z}$
Programmable Counter Modes

- Count Binary or BCD

Single +5V Supply
24 Pin Dual-In-Line Package

The 8253 is a programmable counter/timer chip designed for use as an Intel Microcomputer peripheral. It uses nMOS technology with a single +5 V supply and is packaged in a 24 -pin plastic DIP.

It is organized as three independent 16 -bit counters, each with a count rate of up to 2 MHz . All modes of operation are software programmable.

PIN CONFIGURATION


PIN NAMES

| $D_{7}-D_{0}$ | DATA BUS (8-BIT) |
| :--- | :--- |
| CLKN | COUNTER CLOCK INPUTS |
| GATE N | COUNTER GATE INPUTS |
| OUT N | COUNTER OUTPUTS |
| RD | READ COUNTER |
| WR | WRITE COMMAND OR DATA |
| CS | CHIP SELECT |
| $\mathrm{A}_{0}-\mathrm{A}_{1}$ | COUNTER SELECT |
| $\mathrm{V}_{\mathrm{CC}}$ | +5 VOLTS |
| GND | GROUND |

BLOCK DIAGRAM


## 8253 BASIC FUNCTIONAL DESCRIPTION

## General

The 8253 is a programmable interval timer/counter specifically designed for use with the Intel ${ }^{\text {™ }}$ Microcomputer systems. Its function is that of a general purpose, multi-timing element that can be treated as an array of I/O ports in the system software.
The 8253 solves one of the most common problems in any microcomputer system, the generation of accurate time delays under software control. Instead of setting up timing loops in systems software, the programmer configures the 8253 to match his requirements, initializes one of the counters of the 8253 with the desired quantity, then upon command the 8253 will count out the delay and interrupt the CPU when it has completed its tasks. It is easy to see that the software overhead is minimal and that multiple delays can easily be maintained by assignment of priority levels.

Other counter/timer functions that are non-delay in nature but also common to most microcomputers can be implemented with the 8253.

- Programmable Rate Generator
- Event Counter
- Binary Rate Multiplier
- Real Time Clock
- Digital One-Shot
- Complex Motor Controller


## Data Bus Buffer

This 3-state, bi-directional, 8-bit buffer is used to interface the 8253 to the system data bus. Data is transmitted or received by the buffer upon execution of INput or OUTput CPU instructions. The Data Bus Buffer has three basic functions.

1. Programming the MODES of the 8253 .
2. Loading the count registers.
3. Reading the count values.

## Read/Write Logic

The Read/Write Logic accepts inputs from the system bus and in turn generates control signals for overall device operation. It is enabled or disabled by CS so that no operation can occur to change the function unless the device has been selected by the system logic.

## $\overline{\mathbf{R D}}$ (Read)

A "low" on this input informs the 8253 that the CPU is inputting data in the form of a counters value.

## $\overline{\mathrm{WR}}$ (Write)

A "low" on this input informs the 8253 that the CPU is outputting data in the form of mode information or loading counters.

## A0, A1

These inputs are normally connected to the address bus. Their function is to select one of the three counters to be operated on and to address the control word register for mode selection.

## $\overline{\mathbf{C S}}$ (Chip Select)

A "low" on this input enables the 8253. No reading or writing will occur unless the device is selected. The $\overline{\mathrm{CS}}$ input has no effect upon the actual operation of the counters.


8253 BLOCK DIAGRAM

| $\overline{\mathbf{C S}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathrm{WR}}$ | $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | 0 | 0 | Load Counter No. 0 |
| 0 | 1 | 0 | 0 | 1 | Load Counter No. 1 |
| 0 | 1 | 0 | 1 | 0 | Load Counter No. 2 |
| 0 | 1 | 0 | 1 | 1 | Write Mode Word |
| 0 | 0 | 1 | 0 | 0 | Read Counter No. 0 |
| 0 | 0 | 1 | 0 | 1 | Read Counter No. 1 |
| 0 | 0 | 1 | 1 | 0 | Read Counter No. 2 |
| 0 | 0 | 1 | 1 | 1 | No-Operation 3-State |
| 1 | X | X | X | X | Disable 3-State |
| 0 | 1 | 1 | X | X | No-Operation 3-State |

## Control Word Register

The Control Word Register is selected when A0, A1 are 11. It then accepts information from the data bus buffer and stores it in a register. The information stored in this register controls the operational MODE of each counter, selection of binary or BCD counting and the loading of each count register.
The Control Word Register can only be written into; no read operation of its contents is available.

## Counter \#0, Counter \#1, Counter \#2

These three functional blocks are identical in operation so only a single Counter will be described. Each Counter consists of a single, 16-bit, pre-settable, DOWN counter. The counter can operate in either binary or BCD and its input, gate and output are configured by the selection of MODES stored in the Control Word Register.

The counters are fully independent and each can have separate Mode configuration and counting operation, binary or BCD. Also, there are special features in the control word that handle the loading of the count value so that software overhead can be minimized for these functions.

The reading of the contents of each counter is available to the programmer with simple READ operations for event counting applications and special commands and logic are included in the 8253 so that the contents of each counter can be read "on the fly" without having to inhibit the clock input.

## 8253 SYSTEM INTERFACE

The 8253 is a component of the Intel ${ }^{\text {TM }}$ Microcomputer Systems and interfaces in the same manner as all other peripherals of the family. It is treated by the systems software as an array of peripheral I/O ports; three are counters and the fourth is a control register for MODE programming.
Basically, the select inputs A0, A1 connect to the A0, A1 address bus signals of the CPU. The $\overline{\mathrm{CS}}$ can be derived directly from the address bus using a linear select method. Or it can be connected to the output of a decoder, such as an Intel ${ }^{\circledR} 8205$ for larger systems.


8253 BLOCK DIAGRAM


8253 SYSTEM INTERFACE

## 8253 DETAILED <br> OPERATIONAL DESCRIPTION

## General

The complete functional definition of the 8253 is programmed by the systems software. A set of control words must be sent out by the CPU to initialize each counter of the 8253 with the desired MODE and quantity information. These control words program the MODE, Loading sequence and selection of binary or BCD counting.
Once programmed, the 8253 is ready to perform whatever timing tasks it is assigned to accomplish.
The actual counting operation of each counter is completely independent and additional logic is provided on-chip so that the usual problems associated with efficient monitoring and management of external, asynchronous events or rates to the microcomputer system have been eliminated.

## Programming the 8253

All of the MODES for each counter are programmed by the systems software by simple I/O operations.
Each counter of the 8253 is individually programmed by writing a control word into the Control Word Register.
( $\mathrm{A} 0, \mathrm{~A} 1=11$ )

## Control Word Format

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{\mathbf{4}}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC 1 | $\mathrm{SC0}$ | RL 1 | RLO | M 2 | M 1 | MO | BCD |

## Definition of Control Fields

## SC-Select Counter

| SC1 |
| :---: | :---: | :--- |
| 0 0 Select Counter 0 <br> 0 1 Select Counter 1 <br> 1 0 Select Counter 2 <br> 1 1 Illegal |

## RL-Read/Load

RL1 RL0

| 0 | 0 | Counter Latching operation (see <br> READ/WRITE Procedure Section) |
| :---: | :---: | :--- |
| 1 | 0 | Read/Load most significant byte only. |
| 0 | 1 | Read/Load least significant byte only. |
| 1 | 1 | Read/Load least significant byte first, <br> then most significant byte. |

## M-MODE

M2 M1 M0

| 0 | 0 | 0 | Mode 0 |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | Mode 1 |
| $X$ | 1 | 0 | Mode 2 |
| $X$ | 1 | 1 | Mode 3 |
| 1 | 0 | 0 | Mode 4 |
| 1 | 0 | 1 | Mode 5 |

## BCD

| 0 | Binary Counter 16-bits |
| :--- | :--- |
| 1 | Binary Coded Decimal (BCD) Counter <br> (4 Decades) |

## MODE Definition

MODE 0: Interrupt on terminal count.
The OUTput will be initially low after the Mode set operation. After the count is loaded into the selected count register, the OUTput will remain low and the counter will count. When terminal count is reached the OUTput will go high and remain high until the selected count register is reloaded with the Mode.
Reloading a counter register during counting results in the following:
(1) Load 1st byte stops the current counting.
(2) Load 2nd byte starts the new count.

The GATE input will enable the counting when high and inhibit counting when low.

## MODE 1: Programmable One-Shot.

The OUTput will go low on the count following the rising edge of the GATE input.
The OUTput will go high on the terminal count. If a new count value is loaded while the OUTput is low it will not affect the duration of the One-Shot pulse until the succeeding trigger. The current count can be read at any time without affecting the one-shot pulse.
The one-shot is retriggerable, hence the output will remain low for the full count after any rising edge of the gate input.

## MODE 2: Rate Generator

Divide by N counter. The OUTput will be low for one period of the input clock. The period from one output pulse to the next equals the number of input counts in the count register. If the count register is reloaded between output pulses the present period will not be affected, but the subsequent period will reflect the new value.

The GATE input, when low, will force the OUTput high. When the GATE input goes high, the counter will start from the initial count. Thus, the GATE input can be used to synchronize the counter.
When this MODE is set, the output will remain high until after the count register is loaded. The output then can also be synchronized by software.

## MODE 3: Square Wave Rate Generator.

Similar to MODE 2 except that the OUTput will remain high until one half the count has been completed (for even numbers) and go low for the other half of the count. If the count is odd, the OUTput will be high for ( $\mathrm{N}+1$ )/2 counts and low for ( $\mathrm{N}-1$ )/2 counts.
If the counter register is reloaded with a new value during counting, this new value will be reflected immediately after the output transition of the current count.

## MODE 4: Software triggered strobe.

After the mode is set, the output will be high. When the count is loaded, the counter will begin counting. On terminal count, the output will go low for one input clock period, then will go high again.
If the count register is reloaded between output pulses the present period will not be affected, but the subsequent period will reflect the new value. The count will be inhibited while the gate input is low. Reloading the counter register will restart counting beginning with the new number.

## MODE 5: Hardware triggered strobe.

The counter will start counting after the rising edge of the trigger input and will go low for one clock period when the terminal count is reached. The counter is retriggerable. The output will not go low until the full count after the rising edge of any trigger.

GATE Pin Operations Summary

|  | $\begin{aligned} & \text { Low } \\ & \text { Or Going } \\ & \text { Low } \end{aligned}$ | Rising | High |
| :---: | :---: | :---: | :---: |
| 0 | Disables counting | -- | Enables counting |
| 1 | -- | 1) Initiates counting <br> 2) Resets output after next clock | -- |
| 2 | 1) Disables counting <br> 2) Sets output immediately high | Initiates counting | Enables counting |
| 3 | 1) Disables counting <br> 2) Sets output immediately high | Initiates counting | Enables counting |
| 4 | Disables counting | -- | Enables counting |
| 5 | -- | Initiates counting | -- |

MODE 0


## MODE 1



MODE 2


MODE 3


## MODE 4





MODE 5

 OUTPUT $(n=4) \quad$| GATE |
| :--- | :--- | :--- | :--- | :--- |



## 8253 READ/WRITE PROCEDURE

## Write Operations

The systems software must program each counter of the 8253 with the mode and quantity desired. The programmer must write out to the 8253 a MODE control word and the programmed number of count register bytes (1 or 2) prior to actually using the selected counter.
The actual order of the programming is quite flexible. Writing out of the MODE control word can be in any sequence of counter selection, e.g., counter \#0 does not have to be first or counter \#2 last. Each counter's MODE control word register has a separate address so that its loading is completely sequence independent. (SC0, SC1)
The loading of the Count Register with the actual count value, however, must be done in exactly the sequence programmed in the MODE control word (RL0, RL1). This loading of the counter's count register is still sequence independent like the MODE control word loading, but when a selected count register is to be loaded it must be loaded with the number of bytes programmed in the MODE control word (RL0, RL1). The one or two bytes to be loaded in the count register do not have to follow the associated MODE control word. They can be programmed at any time following the MODE control word loading as long as the correct number of bytes is loaded in order.
All counters are down counters. Thus, the value loaded into the count register will actually be decremented. Loading all zeroes into a count register will result in the maximum count ( $2^{16}$ for Binary or $10^{4}$ for BCD). In MODE 0 the new count will not restart until the load has been completed. It will accept one of two bytes depending on how the MODE control words (RL0, RL1) are programmed. Then proceed with the restart operation.

## Programming Format

|  | MODE Control Word <br> Counter $n$ |
| :---: | :---: |
| LSB | Count Register byte <br> Counter $n$ |
| MSB | Count Register byte <br> Counter $n$ |

Note: Format shown is a simple example of loading the 8253 and does not imply that it is the only format that can be used.

## Alternate Programming Formats

Example:

| No. 1 |  |  | A1 | A0 |
| :---: | :---: | :---: | :---: | :---: |
|  | MODE Control Word Counter 0 |  | 1 | 1 |
| No. 2 | MODE Control Word Counter 1 |  | 1 | 1 |
| No. 3 | MODE Control Word Counter 2 |  | 1 | 1 |
| No. 4 | LSB Count Register Byte <br> Counter 1 |  | 0 | 1 |
| No. 5 | Count Register Byte Counter 1 |  | 0 | 1 |
| No. 6 | LSB Count Register Byte Counter 2 |  | 1 | 0 |
| No. 7 | MSB Count Register Byte |  | 1 | 0 |
| No. 8 | LSB Count Register ByteCounter 0 |  | 0 | 0 |
| No. 9 | MSB | Count Register Byte Counter 0 | 0 | 0 |

Note: The exclusive addresses of each counter's count register make the task of programming the 8253 a very simple matter, and maximum effective use of the device will result if this feature is fully utilized.

## 8253 READ/WRITE PROCEDURE

## Read Operations

In most counter applications it becomes necessary to read the value of the count in progress and make a computational decision based on this quantity. Event counters are probably the most common application that uses this function. The 8253 contains logic that will allow the programmer to easily read the contents of any of the three counters without disturbing the actual count in progress.
There are two methods that the programmer can use to read the value of the counters. The first method involves the use of simple 1/O read operations of the selected counter. By controlling the A0, A1 inputs to the 8253 the programmer can select the counter to be read (remember that no read operation of the mode register is allowed A0, A1-11). The only requirement with this method is that in order to assure a stable count reading the actual operation of the selected counter must be inhibited either by controlling the Gate input or by external logic that inhibits the clock input. The contents of the counter selected will be available as follows:
first I/O Read contains the least significant byte (LSB).
second I/O Read contains the most significant byte (MSB).
Due to the internal logic of the 8253 it is absolutely necessary to complete the entire reading procedure. If two bytes are programmed to be read then two bytes must be read before any loading WR command can be sent to the same counter.

## Read Operation Chart

| A1 | A0 | RD |  |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Read Counter No. 0 |
| 0 | 1 | 0 | Read Counter No. 1 |
| 1 | 0 | 0 | Read Counter No. 2 |
| 1 | 1 | 0 | Illegal |

## Reading While Counting

In order for the programmer to read the contents of any counter without effecting or disturbing the counting operation the 8253 has special internal logic that can be accessed using simple WR commands to the MODE register. Basically, when the programmer wishes to read the conterits of a selected counter "on the fly" he loads the MODE register with a special code which latches the present count value into a storage register so that its contents contain an accurate, stable quantity. The programmer then issues a normal read command to the selected counter and the contents of the latched register is available.

## MODE Register for Latching Count

$$
A 0, A 1=11
$$

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 | SC0 | 0 | 0 | X | X | X | X |

SC1,SC0 - specify counter to be latched.
D5,D4 - 00 designates counter latching operation.
X - don't care.
The same limitation applies to this mode of reading the counter as the previous method. That is, it is mandatory to complete the entire read operation as programmed.

MCS-85 ${ }^{\text {TM }}$ Clock Interface *

*If an 8085 clock output is to drive an $8253-5$ clock input, it must be reduced to 2 MHz or less.

## ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature Under Bias | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage On Any Pin |  |
| With Respect to Ground | -0.5 V to +7 V |
| Power Dissipation | 1 Watt |

${ }^{*}$ COMMENT: Stresses above those listed undere's Amsplute Maximum Ratings" may cause permanent damage ere the device. This is a stress rating only and functional operarongen . $8_{O_{n g}}$ tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{I L}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.2 | $\mathrm{~V}_{\mathrm{CC}}+.5 \mathrm{~V}$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{OFL}}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 1.40 | mA |  |

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $V_{S S}$ |

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$; $\mathrm{GND}=0 \mathrm{~V}$

BUS PARAMETERS: (Note 1)
READ CYCLE

| SYMBOL | PARAMETER | 8253 |  | 8253-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| ${ }^{\text {taR }}$ | Address Stable Before $\overline{\text { READ }}$ | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{RA}}$ | Address Hold Time for $\overline{\text { READ }}$ | 5 |  | 5 |  | ns |
| $t_{\text {RR }}$ | $\overline{\text { READ Pulse Width }}$ | 400 |  | 300 |  | ns |
| $t_{\text {R }}$ | Data Delay From $\overline{\mathrm{READ}}{ }^{\text {[2] }}$ |  | 300 |  | 200 | ns |
| ${ }^{\text {t }}$ F | $\overline{\text { READ }}$ to Data Floating | 25 | 125 | 25 | 100 | ns |

## WRITE CYCLE

| SYMBOL | PARAMETER | 8253 |  | 8253-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| ${ }^{\text {taw }}$ | Address Stable Before $\overline{\text { WRITE }}$ | 50 |  | 50 |  | ns |
| twA | Address Hold Time for $\overline{\text { WRITE }}$ | 30 |  | 30 |  | ns |
| $t_{\text {WW }}$ | $\overline{\text { WRITE Pulse Width }}$ | 400 |  | 300 |  | ns |
| $t_{\text {DW }}$ | Data Set Up Time for WRITE | 300 |  | 250 |  | ns |
| ${ }^{\text {W }}$ W | Data Hold Time for $\overline{\text { WRITE }}$ | 40 |  | 30 |  | ns |
| $t_{\text {R } V}$ | Recovery Time Between प्WRITES | 1 |  | 1 |  | $\mu \mathrm{s}$ |

Notes: 1. AC timings measured at $\mathrm{V}_{\mathrm{OH}}=2.2, \mathrm{~V}_{\mathrm{OL}}=0.8$, and with load circuit of $F$ igure 1.
2. Test Conditions: $8253, C_{L}=100 \mathrm{pF} ; 8253-5: C_{L}=150 \mathrm{pF}$.

## WRITE TIMING



READ TIMING


INPUT WAVEFORMS FOR A.C. TESTS:

A.C. CHARACTERISTICS (Cont' d ): $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{GND}=0 \mathrm{~V}$

CLOCK AND GATE TIMING

| SYMBOL | PARAMETER | 8253 |  | 8253-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| ${ }_{\text {t CLK }}$ | Clock Period | 380 | dc | 380 | dc | ns |
| $t_{\text {PWH }}$ | High Pulse Width | 230 |  | 230 |  | ns |
| $t_{\text {PWL }}$ | Low Pulse Width | 150 |  | 150 |  | ns |
| ${ }^{\text {t }}$ GW | Gate Width High | 150 |  | 150 |  | ns |
| $\mathrm{t}_{\mathrm{GL}}$ | Gate Width Low | 100 |  | 100 |  | ns |
| $\mathrm{t}_{\mathrm{GS}}$ | Gate Set Up Time to CLK $\uparrow$ | 100 |  | 100 |  | ns |
| $\mathrm{t}_{\mathrm{GH}}$ | Gate Hold Time After CLK $\uparrow$ | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{OD}}$ | Output Delay From CLK $\downarrow^{[1]}$ |  | 400 |  | 400 | ns |
| todg | Output Delay From Gate $\downarrow^{[1]}$ |  | 300 |  | 300 | ns |

Note 1: Test Conditions: 8253: $C_{L}=100 \mathrm{pF} ; 8253-5: C_{L}=150 \mathrm{pF}$.


## 8255A, 8255A-5 <br> PROGRAMMABLE PERIPHERAL INTERFACE

MCS-85 ${ }^{\text {TM }}$ Compatible 8255A-5

- 24 Programmable I/O Pins
- Completely TTL Compatible
- Fully Compatible with Intel Microprocessor Families
Improved Timing Characteristics


## - Direct Bit Set/Reset Capability Easing Control Application Interface <br> - 40 Pin Dual-In-Line Package <br> - Reduces System Package Count <br> Improved DC Driving Capability

The 8255A is a general purpose programmable I/O device designed for use with Intel® microprocessors. It has 24 I/O pins which may be individually programmed in two groups of twelve and used in three major modes of operation. In the first mode (Mode 0 ), each group of twelve I/O pins may be programmed in sets of 4 to be input or output. In Mode 1 , the second mode, each group may be programmed to have 8 lines of input or output. Of the remaining four pins three are used for handshaking and interrupt control signals. The third mode of operation (Mode 2 ) is a Bi-directional Bus mode which uses 8 lines for a bi-directional bus, and five lines, borrowing one from the other group, for handshaking.

## PIN CONFIGURATION



PIN NAMES

| $D_{7}-D_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| RESET | RESET INPUT |
| $\overline{C S}$ | CHIP SELECT |
| $\overline{R D}$ | READ INPUT |
| $\overline{\text { WR }}$ | WRITE INPUT |
| AO, AI | PORT ADDRESS |
| PA7-PAO | PORT A (BIT) |
| PB7-PB0 | PORT B (BIT) |
| PC7-PC0 | PORT C (BIT) |
| VCC | +5 VOLTS |
| GND | IVOLTS |

8255A BLOCK DIAGRAM


## 8255 BASIC FUNCTIONAL DESCRIPTION

## General

The 8255 is a Programmable Peripheral Interface (PPI) device designed for use in Intel Microcomputer Systems. Its function is that of a general purpose I/O component to interface peripheral equipment to the microcomputer system bus. The functional configuration of the 8255 is programmed by the system software so that normally no external logic is necessary to interface peripheral devices or structures.

## Data Bus Buffer

This 3-state, bi-directional, eight bit buffer is used to interface the 8255 to the system data bus. Data is transmitted or received by the buffer upon execution of INput or OUTput instructions by the CPU. Control Words and Status information are also transferred through the Data Bus buffer.

## Read/Write and Control Logic

The function of this block is to manage all of the internal and external transfers of both Data and Control or Status words. It accepts inputs from the CPU Address and Control busses and in turn, issues commands to both of the Control Groups.

## (CS)

Chip Select: A "low" on this input pin enables the communication between the 8255 and the CPU.
( $\overline{\mathrm{RD}})$
Read: A "low" on this input pin enables the 8255 to send the Data or Status information to the CPU on the Data Bus. In essence, it allows the CPU to "read from" the 8255.

## (WR)

Write: A "low" on this input pin enables the CPU to write Data or Control words into the 8255.

## ( $A_{0}$ and $A_{1}$ )

Port Select 0 and Port Select 1: These input signals, in conjunction with the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs, control the selection of one of the three ports or the Control Word Register. They are normally connected to the least significant bits of the Address Bus ( $A_{0}$ and $A_{1}$ ).

8255 BASIC OPERATION

| $A_{1}$ | $A_{0}$ | $\overline{\mathbf{R D}}$ | $\overline{W R}$ | $\overline{\mathbf{C S}}$ | INPUT OPERATION (READ) |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 1 | 0 | PORT A $\Rightarrow$ DATA BUS |
| 0 | 1 | 0 | 1 | 0 | PORT B $\Rightarrow$ DATA BUS |
| 1 | 0 | 0 | 1 | 0 | PORT C $\Rightarrow$ DATA BUS |
|  |  |  |  |  | OUTPUT OPERATION <br> (WRITE) |
| 0 | 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT A |
| 0 | 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT B |
| 1 | 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT $C$ |
| 1 | 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ CONTROL |
|  |  |  |  |  | DISABLE FUNCTION |
| X | X | X | X | 1 | DATA BUS $\Rightarrow 3-$ STATE |
| 1 | 1 | 0 | 1 | 0 | ILLEGAL CONDITION |
| X | X | 1 | 1 | 0 | DATA BUS $\Rightarrow 3-$ STATE |



## (RESET)

Reset: A "high" on this input clears all internal registers including the Control Register and all ports (A, B, C) are set to the input mode.

## Group A and Group B Controls

The functional configuration of each port is programmed by the systems software. In essence, the CPU "outputs" a control word to the 8255. The control word contains information such as "mode", "bit set", "bit reset" etc. that initializes the functional configuration of the 8255.

Each of the Control blocks (Group A and Group B) accepts "commands" from the Read/Write Control Logic, receives "control words" from the internal data bus and issues the proper commands to its associated ports.

Control Group A - Port A and Port C upper (C7-C4)
Control Group B - Port B and Port C lower (C3-C0)
The Control Word Register can Only be written into. No Read operation of the Control Word Register is allowed.

## Ports A, B, and C

The 8255 contains three 8 -bit ports ( $\mathrm{A}, \mathrm{B}$, and C ). All can be configured in a wide variety of functional characteristics by the system software but each has its own special features or "personality" to further enhance the power and flexibility of the 8255.

Port A: One 8 -bit data output latch/buffer and one 8 -bit data input latch.

Port B: One 8-bit data input/output latch/buffer and one 8 -bit data input buffer.

Port C: One 8-bit data output latch/buffer and one 8 -bit data input buffer (no latch for input). This port can be divided into two 4-bit ports under the mode control. Each 4bit port contains a 4-bit latch and it can be used for the control signal outputs and status signal inputs in conjunction with Ports A and B .

8255 BLOCK DIAGRAM


PIN CONFIGURATION


## PIN NAMES

| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| RESET | RESET INPUT |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |
| $\overline{\mathrm{RD}}$ | READ INPUT |
| $\overline{\mathrm{WR}}$ | WRITE INPUT |
| $A 0, A 1$ | PORT ADDRESS |
| PA7-PA0 | PORT A (BIT) |
| PB7-PBO | PORT B (BIT) |
| PC7-PCO | PORT C (BIT) |
| VCC | +5 VOLTS |
| GND | $\emptyset V O L T S ~$ |

## 8255 DETAILED OPERATIONAL DESCRIPTION

## Mode Selection

There are three basic modes of operation that can be selected by the system software:

```
Mode 0 - Basic Input/Output
Mode 1 - Strobed Input/Output
Mode 2 - Bi-Directional Bus
```

When the RESET input goes "high" all ports will be set to the Input mode (i.e., all 24 lines will be in the high impedance state). After the RESET is removed the 8255 can remain in the Input mode with no additional initialization required. During the execution of the system program any of the other modes may be selected using a single OUTput instruction. This allows a single 8255 to service a variety of peripheral devices with a simple software maintenance routine.
The modes for Port A and Port B can be separately defined, while Port $C$ is divided into two portions as required by the Port A and Port B definitions. All of the output registers, including the status flip-flops, will be reset whenever the mode is changed. Modes may be combined so that their functional definition can be "tailored" to almost any I/O structure. For instance; Group B can be programmed in Mode 0 to monitor simple switch closings or display computational results, Group A could be programmed in Mode 1 to monitor a keyboard or tape reader on an interrupt-driven basis.


Basic Mode Definitions and Bus Interface


## Mode Definition Format

The Mode definitions and possible Mode combinations may seem confusing at first but after a cursory review of the complete device operation a simple, logical 1/O approach will surface. The design of the 8255 has taken into account things such as efficient PC board layout, control signal definition vs PC layout and complete functional flexibility to support almost any peripheral device with no external logic. Such design represents the maximum use of the available pins.

## Single Bit Set/Reset Feature

Any of the eight bits of Port $C$ can be Set or Reset using a single OUTput instruction. This feature reduces software requirements in Control-based applications.


## Bit Set/Reset Format

## Operating Modes

## Mode 0 (Basic Input/Output)

This functional configuration provides simple Input and Output operations for each of the three ports. No "handshaking" is required, data is simply written to or read from a specified port.

When Port C is being used as status/control for Port A or B, these bits can be set or reset by using the Bit Set/Reset operation just as if they were data output ports.

## Interrupt Control Functions

When the 8255 is programmed to operate in Mode 1 or Mode 2, control signals are provided that can be used as interrupt request inputs to the CPU. The interrupt request signals, generated from Port C, can be inhibited or enabled by setting or resetting the associated INTE flip-flop, using the Bit set/reset function of Port C .

This function allows the Programmer to disallow or allow a specific I/O device to interrupt the CPU without affecting any other device in the interrupt structure.

## INTE flip-flop definition:

(BIT-SET) - INTE is SET - Interrupt enable
(BIT-RESET) - INTE is RESET - Interrupt disable
Note: All Mask flip-flops are automatically reset during mode selection and device Reset.

Mode 0 Basic Functional Definitions:

- Two 8-bit ports and two 4-bit ports.
- Any port can be input or output.
- Outputs are latched.
- Inputs are not latched.
- 16 different Input/Output configurations are possible in this Mode.



## Mode 0 (Basic Input)



## MODE 0 PORT DEFINITION CHART

| A |  | B |  | GROUP A |  |  | GROUP B |  |
| :---: | :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{D}_{\mathbf{4}}$ | $\mathbf{D}_{\mathbf{3}}$ | $\mathbf{D}_{\mathbf{1}}$ | $\mathbf{D}_{\mathbf{0}}$ | PORT A | PORT C <br> (UPPER) | $\#$ | PORT B | PORT C <br> (LOWER) |
| 0 | 0 | 0 | 0 | OUTPUT | OUTPUT | 0 | OUTPUT | OUTPUT |
| 0 | 0 | 0 | 1 | OUTPUT | OUTPUT | 1 | OUTPUT | INPUT |
| 0 | 0 | 1 | 0 | OUTPUT | OUTPUT | 2 | INPUT | OUTPUT |
| 0 | 0 | 1 | 1 | OUTPUT | OUTPUT | 3 | INPUT | INPUT |
| 0 | 1 | 0 | 0 | OUTPUT | INPUT | 4 | OUTPUT | OUTPUT |
| 0 | 1 | 0 | 1 | OUTPUT | INPUT | 5 | OUTPUT | INPUT |
| 0 | 1 | 1 | 0 | OUTPUT | INPUT | 6 | INPUT | OUTPUT |
| 0 | 1 | 1 | 1 | OUTPUT | INPUT | 7 | INPUT | INPUT |
| 1 | 0 | 0 | 0 | INPUT | OUTPUT | 8 | OUTPUT | OUTPUT |
| 1 | 0 | 0 | 1 | INPUT | OUTPUT | 9 | OUTPUT | INPUT |
| 1 | 0 | 1 | 0 | INPUT | OUTPUT | 10 | INPUT | OUTPUT |
| 1 | 0 | 1 | 1 | INPUT | OUTPUT | 11 | INPUT | INPUT |
| 1 | 1 | 0 | 0 | INPUT | INPUT | 12 | OUTPUT | OUTPUT |
| 1 | 1 | 0 | 1 | INPUT | INPUT | 13 | OUTPUT | INPUT |
| 1 | 1 | 1 | 0 | INPUT | INPUT | 14 | INPUT | OUTPUT |
| 1 | 1 | 1 | 1 | INPUT | INPUT | 15 | INPUT | INPUT |

## MODE 0 CONFIGURATIONS

CONTROL WORD \#0


CONTROL WORD \#2


CONTROL WORD \#1


CONTROL WORD \#3


CONTROL WORD \#4

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

CONTROL WORD \#8

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |



CONTROL WORD \#5

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |



CONTROL WORD \#6

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |



CONTROL WORD \#7

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 1 | 1 |



CONTROL WORD \#9

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |



CONTROL WORD \#10


CONTROL WORD \#11

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |



CONTROL WORD \#12

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |



CONTROL WORD \#14

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 |



CONTROL WORD \#15


CONTROL WORD \#13

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 |



## Operating Modes

## Mode 1 (Strobed Input/Output)

This functional configuration provides a means for transferring I/O data to or from a specified port in conjunction with strobes or "handshaking" signals. In Mode 1, Port A and Port B use the lines on Port C to generate or accept these "handshaking" signals.

## Mode 1 Basic Functional Definitions:

- Two Groups (Group A and Group B)
- Each group contains one 8-bit data port and one 4-bit control/data port.
- The 8 -bit data port can be either input or output. Both inputs and outputs are latched.
- The 4-bit port is used for control and status of the 8 -bit data port.


## Input Control Signal Definition

## $\overline{\text { STB }}$ (Strobe Input)

A "low" on this input loads data into the input latch.

## IBF (Input Buffer Full F/F)

A "high" on this output indicates that the data has been loaded into the input latch; in essence, an acknowledgement IBF is set by STB input being low and is reset by the rising edge of the RD input.

## INTR (Interrupt Request)

A 'high" on this output can be used to interrupt the CPU when an input device is requesting service. INTR is set by the STB is a "one", IBF is a "one" and INTE is a "one". It is reset by the falling edge of $\overline{\mathrm{RD}}$. This procedure allows an input device to request service from the CPU by simply strobing its data into the port.

## INTE A

Controlled by bit set/reset of $\mathrm{PC}_{4}$.
INTE B
Controlled by bit set/reset of $\mathrm{PC}_{2}$.


Mode 1 Input


Mode 1 (Strobed Input)

## Output Control Signal Definition

## $\overline{\text { OBF (Output Buffer Full F/F) }}$

The $\overline{O B F}$ output will go "low" to indicate that the CPU has written data out to the specified port. The OBF F/F will be set by the rising edge of the WR input and reset by $\overline{A C K}$ input being low.

## $\overline{\text { ACK }}$ (Acknowledge Input)

A "low" on this input informs the 8255 that the data from Port A or Port B has been accepted. In essence, a response from the peripheral device indicating that it has received the data output by the CPU.

## INTR (Interrupt Request)

A "high" on this output can be used to interrupt the CPU when an output device has accepted data transmitted by the CPU. INTR is set when $\overline{A C K}$ is a "one", $\overline{O B F}$ is a "one" and INTE is a "one". It is reset by the falling edge of $\overline{W R}$.

INTE A
Controlled by bit set/reset of $\mathrm{PC}_{6}$.
INTE B
Controlled by bit set/reset of $\mathrm{PC}_{2}$.


Mode 1 Output


Mode 1 (Strobed Output)

## Combinations of Mode 1

Port A and Port B can be individually defined as input or output in Mode 1 to support a wide variety of strobed I/O applications.


## Operating Modes

## Mode 2 (Strobed Bi-Directional Bus I/O)

This functional configuration provides a means for communicating with a peripheral device or structure on a single 8 -bit bus for both transmitting and receiving data (bi-directional bus I/O). "Handshaking" signals are provided to maintain proper bus flow discipline in a similar manner to Mode 1. Interrupt generation and enable/disable functions are also available.

## Mode 2 Basic Functional Definitions:

- Used in Group A only.
- One 8-bit, bi-directional bus Port (Port A) and a 5-bit control Port (Port C).
- Both inputs and outputs are latched.
- The 5-bit control port (Port C) is used for control and status for the 8 -bit, bi-directional bus port (Port A).


## Bi-Directional Bus I/O Control Signal Definition INTR (Interrupt Request)

A high on this output can be used to interrupt the CPU for both input or output operations.

## Output Operations

## $\overline{\text { OBF }}$ (Output Buffer Full)

The $\overline{\text { OBF }}$ output will go "low" to indicate that the CPU has written data out to Port A.

## ACK (Acknowiedge)

A "low" on this input enables the tri-state output buffer of Port A to send out the data. Otherwise, the output buffer will be in the high-impedance state.

INTE 1 (The INTE Flip-Flop associated with $\overline{O B F}$ )
Controlled by bit set/reset of $\mathrm{PC}_{6}$.

## Input Operations

## $\overline{\text { STB }}$ (Strobe Input)

A "low" on this input loads data into the input latch.

## IBF (Input Buffer Full F/F)

A "high" on this output indicates that data has been loaded into the input latch.

## INTE 2 (The INTE Flip-Flop associated with IBF)

Controlled by bit set/reset of $\mathrm{PC}_{4}$.


Mode 2 Control Word


Mode 2


Mode 2 (Bi-directional)

NOTE: Any sequence where $\overline{W R}$ occurs before $\overline{A C K}$ and $\overline{S T B}$ occurs before $\overline{R D}$ is permissible. $(I N T R=I B F \cdot \overline{M A S K} \cdot \overline{S T B} \cdot \overline{R D}+\overline{O B F} \cdot \overline{M A S K} \cdot \overline{A C K} \cdot \overline{W R})$

MODE 2 AND MODE 0 (INPUT)


MODE 2 AND MODE 0 (OUTPUT)

$$
\begin{aligned}
& \text { CONTROL WORD }
\end{aligned}
$$

MODE 2 AND MODE 1 (INPUT)





MODE 2 AND MODE 1 (OUTPUT)

CONTROL WORD

## MODE DEFINITION SUMMARY TABLE

|  | MODE O |  |
| :--- | :--- | :--- |
|  | IN | OUT |
| $\mathrm{PA}_{0}$ | IN | OUT |
| $\mathrm{PA}_{1}$ | IN | OUT |
| $\mathrm{PA}_{2}$ | IN | OUT |
| $\mathrm{PA}_{3}$ | IN | OUT |
| $\mathrm{PA}_{4}$ | IN | OUT |
| $\mathrm{PA}_{5}$ | IN | OUT |
| $\mathrm{PA}_{6}$ | IN | OUT |
| $\mathrm{PA}_{7}$ | IN | OUT |
| $\mathrm{PB}_{0}$ | IN | OUT |
| $\mathrm{PB}_{1}$ | IN | OUT |
| $\mathrm{PB}_{2}$ | IN | OUT |
| $\mathrm{PB}_{3}$ | IN | OUT |
| $\mathrm{PB}_{4}$ | IN | OUT |
| $\mathrm{PB}_{5}$ | IN | OUT |
| $\mathrm{PB}_{6}$ | IN | OUT |
| $\mathrm{PB}_{7}$ | IN | OUT |
| $\mathrm{PC}_{0}$ | IN | OUT |
| $\mathrm{PC}_{1}$ | IN | OUT |
| $\mathrm{PC}_{2}$ | IN | OUT |
| $\mathrm{PC}_{3}$ | IN | OUT |
| $\mathrm{PC}_{4}$ | IN | OUT |
| $\mathrm{PC}_{5}$ | IN | OUT |
| $\mathrm{PC}_{6}$ | IN | OUT |
| $\mathrm{PC}_{7}$ | IN | OUT |


| MODE 1 |  |
| :---: | :---: |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| $\mathrm{INTR}_{\mathrm{B}}$ | $\mathrm{INTR}_{\mathrm{B}}$ |
| $\mathrm{IBF}_{B}$ | $\overline{O B F}_{B}$ |
| $\overline{S T B}_{B}$ | $\overline{\mathrm{ACK}}_{\mathrm{B}}$ |
| $\mathrm{INTR}_{A}$ | INTR $_{\text {A }}$ |
| $\overline{S T B}_{A}$ | 1/O |
| $\mathrm{IBF}_{\text {A }}$ | 1/0 |
| 1/O | $\overline{\mathrm{ACK}}_{\mathrm{A}}$ |
| 1/0 | $\overline{\mathrm{OBF}}_{\mathrm{A}}$ |

MODE 2

## Special Mode Combination Considerations

There are several combinations of modes when not all of the bits in Port C are used for control or status. The remaining bits can be used as follows:

## If Programmed as Inputs -

All input lines can be accessed during a normal Port C read.

If Programmed as Outputs -
Bits in $C$ upper ( $\mathrm{PC}_{7}-\mathrm{PC}_{4}$ ) must be individually accessed using the bit set/reset function.

Bits in C lower ( $\mathrm{PC}_{3}-\mathrm{PC}_{0}$ ) can be accessed using the bit set/reset function or accessed as a threesome by writing into Port C .

## Source Current Capability on Port B and Port C

Any set of eight output buffers, selected randomly from Ports B and C can source 1 mA at 1.5 volts. This feature allows the 8255 to directly drive Darlington type drivers and high-voltage displays that require such source current.

## Reading Port C Status

In Mode 0, Port C transfers data to or from the peripheral device. When the 8255 is programmed to function in Modes 1 or 2, Port C generates or accepts "hand-shaking" signals with the peripheral device. Reading the contents of Port C
allows the programmer to test or verify the "status" of each peripheral device and change the program flow accordingly.

There is no special instruction to read the status information from Port C. A normal read operation of Port C is executed to perform this function.


Mode 2 Status Word Format

## APPLICATIONS OF THE 8255

The 8255 is a very powerful tool for interfacing peripheral equipment to the microcomputer system. It represents the optimum use of available pins and is flexible enough to interface almost any I/O device without the need for additional external logic.

Each peripheral device in a microcomputer system usually has a "service routine" associated with it. The routine manages the software interface between the device and the CPU. The functional definition of the 8255 is programmed by the 1/O service routine and becomes an extension of the systems software. By examining the I/O devices interface characteristics for both data transfer and timing, and matching this information to the examples and tables in the Detailed Operational Description, a control word can easily be developed to initialize the 8255 to exactly "fit" the application. Here are a few examples of typical applications of the 8255.


## Printer Interface



Keyboard and Display Interface


Keyboard and Terminal Address Interface


Digital to Analog, Analog to Digital

## Basic Floppy Disc Interface



## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias. . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin
$\quad$ With Respect to Ground . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . Watt
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \quad \pm 5 \% ; \mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}(\mathrm{DB})$ | Output Low Voltage (Data Bus) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OL}}(\mathrm{PER})$ | Output Low Voltage (Peripheral Port) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.7 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}(\mathrm{DB})$ | Output High Voltage (Data Bus) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OH}}(\mathrm{PER})$ | Output High Voltage (Peripheral Port) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{DAR}}[1]$ | Darlington Drive Current | -1.0 | -4.0 | mA | $\mathrm{R}_{\mathrm{EXT}}=750 \Omega ; \mathrm{V}_{\mathrm{EXT}}=1.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 120 | mA |  |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{OFL}}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |

Note 1: Available on any 8 pins from Port $B$ and $C$.

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to GND |

## TEST LOAD CIRCUIT (FOR DB)



[^6]
## A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \% ; \mathrm{GND}=0 \mathrm{~V}$

BUS PARAMETERS:
READ:


|  | PARAMETER | 8255A |  | 8255A-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | MIN. | MAX. | MIN. | MAX. |  |
| $\mathrm{t}_{\text {AR }}$ | Address Stable Before READ | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | Address Stable After READ | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | READ Pulse Width | 300 |  | 300 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Valid From READ ${ }^{\text {1] }}$ |  | 250 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{DF}}$ | Data Float After READ | 10 | 150 | 10 | 100 | ns |
| $\mathrm{t}_{\mathrm{R} V}$ | Time Between READs and/or WRITEs | 850 |  | 850 |  | ns |

WRITE:

| SYMBOL | PARAMETER | 8255A |  | 8255A-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| ${ }^{\text {taw }}$ | Address Stable Before WRITE | 0 |  | 0 |  | ns |
| twa | Address Stable After WRITE | 20 |  | 20 |  | ns |
| tww | WRITE Pulse Width | 400 |  | 300 |  | ns |
| ${ }^{\text {t }}$ W | Data Valid to WRITE (T.E.) | 100 |  | 100 |  | ns |
| twD | Data Valid After WRITE | 30 |  | 30 |  | ns |

## OTHER TIMINGS:

| SYMBOL | PARAMETER | 8255A |  | 8255A. 5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| ${ }_{\text {t }}$ WB | WR = 1 to Output ${ }^{[1]}$ | , | 350 |  | 350 | ns |
| $\mathrm{t}_{\text {IR }}$ | Peripheral Data Before RD | 0 |  | 0 |  | ns |
| ${ }_{\text {t }}^{\text {HR }}$ | Peripheral Data After RD | 0 |  | 0 |  | ns |
| ${ }_{\text {t }}^{\text {AK }}$ | ACK Pulse Width | 300 |  | 300 |  | ns |
| $\mathrm{t}_{\text {ST }}$ | STB Pulse Width | 500 |  | 500 |  | ns |
| $t_{P S}$ | Per. Data Before T.E. of STB | 0 |  | 0 |  | ns |
| $t_{\text {PH }}$ | Per. Data After T.E. of STB | 180 |  | 180 |  | ns |
| tad | ACK $=0$ to Output ${ }^{[1]}$ |  | 300 |  | 300 | ns |
| $\mathrm{t}_{\text {KD }}$ | ACK $=1$ to Output Float | 20 | 250 | 20 | 250 | ns |
| ${ }^{\text {twob }}$ | $W \mathrm{R}=1$ to OBF $=0^{[1]}$ |  | 650 |  | 650 | ns |
| ${ }^{\text {t }}$ AOB | $\mathrm{ACK}=0$ to $\mathrm{OBF}=1{ }^{[1]}$ |  | 350 |  | 350 | ns |
| ${ }^{\text {S SIB }}$ | STB $=0$ to $\mathrm{IBF}=1{ }^{[1]}$ |  | 300 |  | 300 | ns |
| $\mathrm{t}_{\text {RIB }}$ | $\mathrm{RD}=1$ to $\mathrm{IBF}=0^{[1]}$ |  | 300 |  | 300 | ns |
| ${ }_{\text {trit }}$ | $\mathrm{RD}=0$ to $\mathrm{INTR}=0^{[1]}$ |  | 400 |  | 400 | ns |
| ${ }_{\text {t SIT }}$ | $\mathrm{STB}=1$ to $\mathrm{INTR}=1^{[1]}$ |  | 300 |  | 300 | ns |
| ${ }^{\text {t }}$ AIT | ACK $=1$ to INTR $=1{ }^{[1]}$ |  | 350 |  | 350 | ns |
| ${ }^{\text {t WIT }}$ | $W R=0$ to 1 NTR $=0^{[1]}$ |  | 850 |  | 850 | ns |

Notes: 1. Test Conditions: $8255 \mathrm{~A}: \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} ; 8255 \mathrm{~A}-5: \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
2. Period of Reset pulse must be at least $50 \mu \mathrm{~s}$ during or after power on. Subsequent Reset pulse can be 500 ns min.


Input Waveforms For A.C. Tests


Mode 0 (Basic Input)


Mode 0 (Basic Output)


Mode 1 (Strobed Input)


Mode 1 (Strobed Output)


Mode 2 (Bi-directional)

NOTE: Any sequence where $\overline{W R}$ occurs before $\overline{A C K}$ and $\overline{S T B}$ occurs before $\overline{R D}$ is permissible. $(\mathrm{INTR}=\mathrm{IBF} \cdot \overline{\mathrm{MASK}} \cdot \overline{\mathrm{STB}} \cdot \overline{\mathrm{RD}}+\overline{\mathrm{OBF}} \cdot \overline{\mathrm{MASK}} \cdot \overline{\mathrm{ACK}} \cdot \overline{\mathrm{WR}})$

## PROGRAMMABLE PERIPHERAL INTERFACE

## 24 Programmable I/O Pins <br> - Completely TTL Compatible <br> - Fully Compatible with MCS"'-80 Microprocessor Family <br> - Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

\author{

- Direct Bit Set/Reset Capability Easing Control Application Interface <br> - 40 Pin Dual In-Line Package <br> - Reduces System Package Count <br> $\pm 10 \%$ Power Supply Tolerance
}

The M8255A is a general purpose programmable I/O device designed for use with microprocessors. It has 24 I/O pins which may be individually programmed in two groups of twelve and used in three major modes of operation. In the first mode (Mode 0), each group of twelve I/O pins may be programmed in sets of 4 to be input or output. In Mode 1, the second mode, each group may be programmed to have 8 lines of input or output. Of the remaining four pins three are used for handshaking and interrupt control signals. The third mode of operation (Mode 2) is a Bi -directional Bus mode which uses 8 lines for a bi-directional bus, and five lines, borrowing one from the other group, for handshaking.

Other features of the M8255A include bit set and reset capability and the ability to source 1 mA of current at 1.5 volts. This allows darlington transistors to be directly driven for applications such as printers and high voltage displays.

## PIN CONFIGURATION



PIN NAMES

| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :---: | :---: |
| RESET | RESET INPUT |
| CS | CHIP SELECT |
| $\overline{\mathrm{RD}}$ | READ INPUT |
| $\overline{\text { WR }}$ | WRITE INPUT |
| A0, A1 | PORT ADDRESS |
| PA7.PA0 | PORT A (BIT) |
| PB7-PB0 | PORT B (BIT) |
| PC7-PC0 | PORT C (BIT) |
| $\mathrm{V}_{\text {cc }}$ | +5 VOLTS |
| GND | $\emptyset$ VOLTS |

M8255A BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

```
Ambient Temperature Under Bias . . . . -55 ' C to +125 }\mp@subsup{}{}{\circ}\textrm{C
Storage Temperature . . . . . . . . . . . . - 65 ' C to +150 }\mp@subsup{}{}{\circ}\textrm{C
Voltage On Any Pin
    With Respect to GND . . . . . . . . . . . . . . -0.5V to +7V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
```

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$; GND $=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -.5 |  | .8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | .45 | V | $\mathrm{I}_{\mathrm{OL}}=1.7 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}(-100 \mu \mathrm{~A}$ for $\mathrm{D} . \mathrm{B}$. Port $)$ |
| $\mathrm{I}_{\mathrm{OH}}{ }^{[1]}$ | Darlington Drive Current | 1.0 |  | 4.0 | mA | $\mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}, \mathrm{R}_{\mathrm{EXT}}=750 \Omega$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  |  | 120 | mA |  |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\left\|\mathrm{I}_{\mathrm{OFL}}\right\|$ | Output Float Leakage |  |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0.45 \mathrm{~V} / \mathrm{V}_{\mathrm{CC}}$ |

NOTE:

1. Available on 8 pins only.

## A.C. CHARACTERISTICS $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \% ; \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twp | Pulse Width of $\overline{W R}$ |  |  | 400 | ns |  |
| ${ }^{\text {t }}$ W | Time D.B. Stable Before $\overline{W R}$ | 50 |  |  | ns |  |
| ${ }^{\text {W }}$ WD | Time D.B. Stable After $\overline{W R}$ | 35 |  |  | ns |  |
| $t_{\text {AW }}$ | Time Address Stable Before $\bar{W} \bar{R}$ | 20 |  |  | ns |  |
| ${ }^{\text {W WA }}$ | Time Address Stable After $\overline{W R}$ | 20 |  |  | ns |  |
| ${ }^{\text {c }}$ W | Time $\overline{\mathrm{CS}}$ Stable Before $\overline{W R}$ | 20 |  |  | ns |  |
| twC | Time $\overline{\mathrm{CS}}$ Stable After $\overline{W R}$ | 35 |  |  | ns |  |
| twB | Delay From $\overline{W R}$ To Output |  |  | 500 | ns | $C_{L}=50 \mathrm{pF}$ |
| $t_{R P}$ | Pulse Width of $\overline{R D}$ | 405 |  |  | ns |  |
| $t_{\text {IR }}$ | $\overline{R D}$ Set-Up Time | 0 |  |  | ns |  |
| $t_{\text {HR }}$ | Input Hold Time | 0 |  |  | ns |  |
| $t_{\text {RD }}$ | Delay From $\overline{\mathrm{RD}}=0$ To System Bus |  |  | 295 | ns | $C_{L}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{OD}}$ | Delay From $\overline{\mathrm{RD}}=1$ To System Bus | 10 |  | 150 | ns | $C_{L}=15 p F / 100 p F$ |
| ${ }^{\text {taR }}$ | Time Address Stable Before $\overline{\mathrm{RD}}$ | 50 |  |  | ns |  |
| $t_{C R}$ | Time $\overline{\mathrm{CS}}$ Stable Before $\overline{\mathrm{RD}}$ | 50 |  |  | ns |  |
| $\mathrm{t}_{\text {AK }}$ | Width Of $\overline{\text { ACK }}$ Pulse | 500 |  |  | ns |  |
| ${ }^{\text {t }}$ S $T$ | Width Of $\overline{\text { STB }}$ Pulse | 500 |  |  | ns |  |
| $t_{\text {PS }}$ | Set-Up Time For Peripheral | 60 |  |  | ns |  |
| ${ }^{\text {PrH }}$ | Hold Time For Peripheral | 180 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{RA}}$ | Hold Time for $A_{1}, A_{0}$ After $\overline{R D}=1$ | 0 |  |  | ns |  |

## A.C. CHARACTERISTICS (Continued)

| $\mathrm{t}_{\mathrm{RC}}$ | Hold Time For CS After $\overline{\mathrm{RD}}=1$ |
| :--- | :--- |
| $\mathrm{t}_{\mathrm{AD}}$ | Time From $\overline{\mathrm{ACK}}=0$ To Output (Mode 2) |
| $\mathrm{t}_{\mathrm{KD}}$ | Time From $\overline{\mathrm{ACK}}=1$ To Output Floating |
| $\mathrm{t}_{\mathrm{WO}}$ | Time From $\overline{\mathrm{WR}}=1$ To $\overline{\mathrm{OBF}}=0$ |
| $\mathrm{t}_{\mathrm{AO}}$ | Time From $\overline{\mathrm{ACK}}=0$ To $\overline{\mathrm{OBF}}=1$ |
| $\mathrm{t}_{\mathrm{SI}}$ | Time From $\overline{\mathrm{STB}}=0$ To $\mathrm{IBF}=1$ |
| $\mathrm{t}_{\mathrm{RI}}$ | Time From $\overline{\mathrm{RD}}=1$ To $\mathrm{IBF}=0$ |




# 8257, 8257-5 PROGRAMMABLE DMA CONTROLLER 

\author{

- MCS-85 ${ }^{\text {TM }}$ Compatible 8257-5 <br> - Four Channel DMA Controller <br> - Priority DMA Request Logic <br> - Channel Inhibit Logic <br> - Terminal Count and Modulo 128 Outputs
}

\author{

- Auto Load Mode <br> - Single TTL Clock <br> ■ Single +5V Supply <br> - Expandable <br> ■ 40 Pin Dual-In-Line Package
}

The 8257 is a four-channel Direct Memory Access (DMA) controller. It is specifically designed to simplify the transfer of data at high speeds for the Intel® Microcomputer Systems. Its primary function is to generate, upon a peripheral request, a sequential memory address which will allow the peripheral to read or write data directly to or from memory. Acquisition of the system bus is accomplished via the CPU's HOLD function. The 8257 has priority logic that resolves the peripherals requests and issues a composite HOLD request to the CPU. It maintains the DMA cycle count for each channel and outputs a control signal to notify the peripheral that the programmed number of DMA cycles is complete. Other output control signals simplify sectored data transfers and expansion to other 8257 devices for systems that require more than four channels of DMA controlled transfer. The 8257 represents a significant savings in component count for DMA-based microcomputer systems and greatly simplifies the transfer of data at high speed between peripherals and memories.

PIN CONFIGURATION


PIN NAMES

| $D_{7}-D_{0}$ | DATA BUS |
| :--- | :--- |
| $A_{7}-A_{0}$ | ADDRESS BUS |
| $\overline{\overline{T O R}}$ | I/O $\overline{\text { READ }}$ |
| $\overline{\overline{/ T O W}}$ | I/O $\overline{\text { WRITE }}$ |
| $\overline{\text { MEMR }}$ | MEMORY $\overline{\text { MEAD }}$ |
| $\overline{\text { MEMW }}$ | MEMORY $\overline{\text { WRITE }}$ |
| CLK | CLOCK INPUT |
| RESET | RESET INPUT |
| READY | READY |
| HRQ | HOLD REQUEST <br> (TO 8080A) |
| HLDA | HOLD ACKNOWLEDGE <br> (FROM 8080A) |


| AEN | ADDRESS ENABLE |
| :---: | :---: |
| ADSTB | ADDRESS STROBE |
| TC | TERMINAL COUNT |
| MARK | MODULO 128 MARK |
| $\mathrm{DRO}_{3}$ - $\mathrm{DRO}_{0}$ | DMA REQUEST INPUT |
| $\overline{\text { DACK }}_{3}$ DACK $_{0}$ | DMA ACKNOWLEDGE OUT |
| $\overline{\text { Cs }}$ | CHIP SELECT |
| $\mathrm{V}_{\text {cc }}$ | +5 VOLTS |
| GND | GROUND |

BLOCK DIAGRAM


## 8257 BASIC FUNCTIONAL DESCRIPTION

## General

The 8257 is a programmable, Direct Memory Access (DMA) device which, when coupled with a single Intel ${ }^{(8)}$ 8212 I/O port device, provides a complete four-channel DMA controller for use in Intel ${ }^{-3}$ microcomputer systems. After being initialized by software, the 8257 can transfer a block of data, containing up to 16,384 bytes, between memory and a peripheral device directly, without further intervention required of the CPU. Upon receiving a DMA transfer request from an enabled peripheral, the 8257: 8257:

- Acquires control of the system bus.
- Acknowledges that requesting peripheral which is connected to the highest priority channel.
- Outputs the least significant eight bits of the memory address onto system address lines $\mathrm{A}_{0}-\mathrm{A}_{7}$, outputs the most significant eight bits of the memory address to the 8212 I/O port via the data bus (the 8212 places these address bits on lines $A_{8}-A_{15}$, and
- Generates the appropriate memory and I/O read/ write control signals that cause the peripheral to receive or deposit a data byte directly from or to the addressed location in memory.

The 8257 will retain control of the system bus and repeat the transfer sequence, as long as a peripheral maintains its DMA request. Thus, the 8257 can transfer a block of data to/from a high speed peripheral (e.g., a sector of data on a floppy disk) in a single "burst". When the specified number of data bytes have been transferred, the 8257 activates its Terminal Count (TC) output, informing the CPU that the operation is complete.

The 8257 offers three different modes of operation: (1) DMA read, which causes data to be transferred from memory to a peripheral; (2) DMA write, which causes data to be transferred from a peripheral to memory; and (3) DMA verify, which does not actually involve the transfer of data. When an 8257 channel is in the DMA verify mode, it will respond the same as described for transfer operations, except that no memory or I/O read/write control signals will be generated, thus preventing the transfer of data. The 8257, however, will gain control of the system bus and will acknowledge the peripheral's DMA request for each DMA cycle. The peripheral can use these acknowledge signals to enable an internal access of each byte of a data block in order to execute some verification procedure, such as the accumulation of a CRC (Cyclic Redundancy Code) checkword. For example, a block of DMA verify cycles might follow a block of DMA read cycles (memory to peripheral) to allow the peripheral to verify its newly acquired data.

## Block Diagram Description

## 1. DMA Channels

The 8257 provides four separate DMA channels (labeled $\mathrm{CH}-0$ to $\mathrm{CH}-3$ ). Each channel includes two sixteen-bit registers: (1) a DMA address register, and (2) a terminal count register. Both registers must be initialized before a channel is enabled. The DMA address register is loaded with the address of the first memory location to be accessed. The value loaded into the low-order 14-bits of the terminal count register specifies the number of DMA cycles minus one before the Terminal Count (TC) output is activated. For instance, a terminal count of 0 would cause the TC output to be active in the first DMA cycle for that channel. In general, if $\mathbf{N}=$ the number of desired DMA cycles, load the value N - 1 into the low-order 14-bits of the terminal count register. The most significant two bits of the terminal count register specify the type of DMA operation for that channel:


8257 BLOCK DIAGRAM

These two bits are not modified during a DMA cycle, but can be changed between DMA blocks.
Each channel accepts a DMA Request (DRQn) input and provides a DMA Acknowledge (DACKn) output:

## (DRQ 0 - DRQ 3)

DMA Request: These are individual asynchronous channel request inputs used by the peripherals to obtain a DMA cycle. If not in the rotating priority mode then DRQ 0 has the highest priority and DRQ 3 has the lowest. A request can be generated by raising the request line and holding it high until DMA acknowledge. For multiple DMA cycles (Burst Mode) the request line is held high until the DMA acknowledge of the last cycle arrives.

## (DACK 0-DACK 3)

DMA Acknowledge: An active low level on the acknowledge output informs the peripheral connected to that channel that it has been selected for a DMA cycle.

## 2. Data Bus Buffer

This three-state, bi-directional, eight bit buffer interfaces the 8257 to the system data bus:

## ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ )

Data Bus Lines: These are bi-directional three-state lines. When the 8257 is being programmed by the CPU, eightbits of data for a DMA address register, a terminal count register or the Mode Set register are received on the data bus. When the CPU reads a DMA address register, a terminal count register or the Status register, the data is sent to the CPU over the data bus. During DMA cycles (when the 8257 is the bus master), the 8257 will output the most significant eight-bits of the memory address (from one of the DMA address registers) to the 8212 latch via the data bus. These address bits will be transferred at the beginning of the DMA cycle; the bus will then be released to handle the memory data transfer during the balance of the DMA cycle.

| BIT 15 | BIT 14 | TYPE OF DMA OPERATION |
| :---: | :---: | :---: |
| 0 | 0 | Verify DMA Cycle |
| 0 | 1 | Write DMA Cycle |
| 1 | 0 | Read DMA Cycle |
| 1 | 1 | (Illegal) |



8257 BLOCK DIAGRAM

## 3. Read/Write Logic

When the CPU is programming or reading one of the 8257's register (i.e., when the 8257 is a "slave" device on the system bus), the Read/Write Logic accepts the I/O Read (I/OR) or I/O Write ( $\overline{\mathrm{I} / \mathrm{OW}})$ signal, decodes the least significant four address bits, ( $A_{0}-A_{3}$ ), and either writes the contents of the data bus into the addressed register (if $\overline{\mathrm{I} O W}$ is true) or places the contents of the addressed register onto the data bus (if $\overline{\mathrm{I} O R}$ is true).

During DMA cycles (i.e., when the 8257 is the bus "master"), the Read/Write Logic generates the I/O read and memory write (DMA write cycle) or I/O Write and memory read (DMA read cycle) signals which control the data link with the peripheral that has been granted the DMA cycle.

Note that during DMA transfers Non-DMA I/O devices should be de-selected (disabled) using "AEN" signal to inhibit I/O device decoding of the memory address as an erroneous device address.

## (I/OR)

I/O Read: An active-low, bi-directional three-state line. In the "slave" mode, it is an input which allows the 8-bit status register or the upper/lower byte of a 16-bit DMA address register or terminal count register to be read. In the "master" mode, I/OR is a control output which is used to access data from a peripheral during the DMA write cycle.

## (1/OW)

I/O Write: An active-low, bi-directional three-state line. In the "slave" mode, it is an input which allows the contents of the data bus to be loaded into the 8-bit mode set register or the upper/lower byte of a 16-bit DMA address register or terminal count register. In the "master" mode, $\overline{\mathrm{I} O W}$ is a control output which allows data to be output to a peripheral during a DMA read cycle.

## (CLK)

Clock Input: Generally from an Intel ${ }^{\circledR 3} 8224$ Clock Generator device. ( $\phi 2$ TTL)

## (RESET)

Reset: An asynchronous input (generally from an 8224 device) which clears all registers and control lines.

## $\left(\mathrm{A}_{0}-\mathrm{A}_{3}\right)$

Address Lines: These least significant four address lines are bi-directional. In the "slave" mode they are inputs which select one of the registers to be read or programmed. In the "master" mode, they are outputs which constitute the least significant four bits of the 16-bit memory address generated by the 8257 .

## ( $\overline{\mathrm{CS}})$

Chip Select: An active-low input which enables the I/O Read or I/O Write input when the 8257 is being read or programmed in the "slave" mode. In the "master" mode, $\overline{\mathrm{CS}}$ is automatically disabled to prevent the chip from selecting itself while performing the DMA function.


8257 BLOCK DIAGRAM

## 4. Control Logic

This block controls the sequence of operations during all DMA cycles by generating the appropriate control signals and the 16-bit address that specifies the memory location to be accessed.

## ( $\mathrm{A}_{4}-\mathrm{A}_{7}$ )

Address Lines: These four address lines are three-state outputs which constitute bits 4 through 7 of the 16 -bit memory address generated by the 8257 during all DMA cycles.

## (READY)

Ready: This asynchronous input is used to elongate the memory read and write cycles in the 8257 with wait states if the selected memory requires longer cycles.

## (HRQ)

Hold Request: This output requests control of the system bus. In systems with only one 8257, HRQ will normally be applied to the HOLD input on the CPU.

## (HLDA)

Hold Acknowledge: This input from the CPU indicates that the 8257 has acquired control of the system bus.

## (MEMR)

Memory Read: This active-low three-state output is used to read data from the addressed memory location during DMA Read cycles.

## (MEMW)

Memory Write: This active-low three-state output is used to write data into the addressed memory location during DMA Write cycles.

## (ADSTB)

Address Strobe: This output strobes the most significant byte of the memory address into the 8212 device from the data bus.

## (AEN)

Address Enable: This output is used to disable (float) the System Data Bus and the System Control Bus. It may also be used to disable (float) the System Address Bus by use of an enable on the Address Bus drivers in systems to inhibit non-DMA devices from responding during DMA cycles. It may be further used to isolate the 8257 data bus from the System Data Bus to facilitate the transfer of the 8 most significant DMA address bits over the 8257 data I/O pins without subjecting the System Data Bus to any timing constraints for the transfer. When the 8257 is used in an I/O device structure (as opposed to memory mapped), this AEN output should be used to disable the selection of an I/O device when the DMA address is on the address bus. The I/O device selection should be determined by the DMA acknowledge outputs for the 4 channels.

## (TC)

Terminal Count: This output notifies the currently selected peripheral that the present DMA cycle should be the last cycle for this data block. If the TC STOP bit in the Mode Set register is set, the selected channel will be automatically disabled at the end of that DMA cycle. TC is activated when the 14 -bit value in the selected channel's terminal count register equals zero. Recall that the loworder 14-bits of the terminal count register should be loaded with the values ( $n-1$ ), where $n=$ the desired number of the DMA cycles.

## (MARK)

Modulo 128 Mark: This output notifies the selected peripheral that the current DMA cycle is the 128th cycle since the previous MARK output. MARK always occurs at 128 (and all multiples of 128) cycles from the end of the data block. Only if the total number of DMA cycles ( $n$ ) is evenly divisable by 128 (and the terminal count register was loaded with $n-1$ ), will MARK occur at 128 (and each succeeding multiple of 128) cycles from the beginning of the data block.


8257 BLOCK DIAGRAM

## 5. Mode Set Register

When set, the various bits in the Mode Set register enable each of the four DMA channels, and allow four different options for the 8257:


The Mode Set register is normally programmed by the CPU after the DMA address register(s) and terminal count register(s) are initialized. The Mode Set Register is cleared by the RESET input, thus disabling all options, inhibiting all channels, and preventing bus conflicts on power-up. A channel should not be left enabled unless its DMA address and terminal count registers contain valid values; otherwise, an inadvertent DMA request (DRQn) from a peripheral could initiate a DMA cycle that would destroy memory data.

The various options which can be enabled by bits in the Mode Set register are explained below:

## Rotating Priority Bit 4

In the Rotating Priority Mode, the priority of the channels has a circular sequence. After each DMA cycle, the priority of each channel changes. The channel which had just been serviced will have the lowest priority.


If the ROTATING PRIORITY bit is not set (set to a zero), each DMA channel has a fixed priority. In the fixed priority mode, Channel 0 has the highest priority and Channel 3 has the lowest priority. If the ROTATING PRIORITY bit is set to a one, the priority of each channel changes after each DMA cycle (not each DMA request). Each channel moves up to the next highest priority assignment, while the channel which has just been serviced moves to the lowest priority assignment:

|  | CHANNEL $\rightarrow$ JUST SERVICED | $\mathrm{CH}-0$ | CH-1 | CH-2 | CH-3 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Priority $\longrightarrow$ Assignments |  | CH-1 | CH-2 | CH-3 | CH-O |
|  |  | CH-2 | CH-3 | CH-O | CH-1 |
|  |  | CH-3 | CH-O | CH-1 | CH-2 |
|  |  | CH-O | CH-1 | CH-2 | CH-3 |

Note that rotating priority will prevent any one channel from monopolizing the DMA mode; consecutive DMA cycles will service different channels if more than one channel is enabled and requesting service. All DMA operations began with Channel 0 initially assigned to the highest priority for the first DMA cycle.

## Extended Write Bit 5

If the EXTENDED WRITE bit is set, the duration of both the $\overline{M E M W}$ and $\overline{\text { IOW }}$ signals is extended by activating them earlier in the DMA cycle. Data transfers within microcomputer systems proceed asynchronously to allow use of various types of memory and I/O devices with different access times. If a device cannot be accessed within a specific amount of time it returns a "not ready" indication to the 8257 that causes the 8257 to insert one or more wait states in its internal sequencing. Some devices are fast enough to be accessed without the use of wait states, but if they generate their READY response with the leading edge of the $\overline{1 / O W}$ or $\overline{M E M W}$ signal (which generally occurs late in the transfer sequence), they would normally cause the 8257 to enter a wait state because it does not receive READY in time. For systems with these types of devices, the Extended Write option provides alternative timing for the I/O and memory write signals which allows the devices to return an early READY and prevents the unnecessary occurrence of wait states in the 8257 , thus increasing system throughput.

## TC Stop Bit 6

If the TC STOP bit is set, a channel is disabled (i.e., its enable bit is reset) after the Terminal Count (TC) output goes true, thus automatically preventing further DMA operation on that channel. The enable bit for that channel must be re-programmed to continue or begin another DMA operation. If the TC STOP bit is not set, the occurrence of the TC output has no effect on the channel enable bits. In this case, it is generally the responsibility of the peripheral to cease DMA requests in order to terminate a DMA operation.

## Auto Load Bit 7

The Auto Load mode permits Channel 2 to be used for repeat block or block chaining operations, without immediate software intervention between blocks. Channel 2 registers are initialized as usual for the first data block; Channel 3 registers, however, are used to store the block re-initialization parameters (DMA starting address, terminal count and DMA transfer mode). After the first block of DMA cycles is executed by Channel 2 (i.e., after the TC output goes true), the parameters stored in the Channel 3 registers are transferred to Channel 2 during an "update" cycle. Note that the TC STOP feature, described above, has no effect on Channel 2 when the Auto Load bit is set.

If the Auto Load bit is set, the initial parameters for Channel 2 are automatically duplicated in the Channel 3 registers when Channel 2 is programmed. This permits repeat block operations to be set up with the programming of a single channel. Repeat block operations can be used in applications such as CRT refreshing. Channels 2 and 3 can still be loaded with separate values if Channel 2 is loaded before loading Channel 3. Note that in the Auto Load mode, Channel 3 is still available to the user if the Channel 3 enable bit is set, but use of this channel will change the values to be auto loaded into Channel 2 at update time. All that is necessary to use the Auto Load feature for chaining operations is to reload Channel 3 registers at the conclusion of each update cycle with the new parameters for the next data block transfer.

Each time that the 8257 enters an update cycle, the update flag in the status register is set and parameters in Channel 3 are transferred to Channel 2, non-destructively for Channel 3. The actual re-initialization of Channel 2 occurs at the beginning of the next channel 2 DMA cycle after the TC cycle. This will be the first DMA cycle of the new data block for Channel 2. The update flag is cleared at the conclusion of this DMA cycle. For chaining operations, the update flag in the status register can be monitored by the CPU to determine when the re-initialization process has been completed so that the next block parameters can be safely loaded into Channel 3.

## 6. Status Register

The eight-bit status register indicates which channels have reached a terminal count condition and includes the update flag described previously.


The TC status bits are set when the Terminal Count (TC) output is activated for that channel. These bits remain set until the status register is read or the 8257 is reset. The UPDATE FLAG, however, is not affected by a status register read operation. The UPDATE FLAG can be cleared by resetting the 8257, by changing to the non-auto load mode (i.e., by resetting the AUTO LOAD bit in the Mode Set register) or it can be left to clear itself at the completion of the update cycle. The purpose of the UPDATE FLAG is to prevent the CPU from inadvertently skipping a data block by overwriting a starting address or terminal count in the Channel 3 registers before those parameters are properly auto-loaded into Channel 2.


## AUTOLOAD TIMING

## 8257 DETAILED OPERATIONAL SUMMARY <br> Programming and Reading the 8257 Registers

There are four pairs of "channel registers": each pair consisting of a 16-bit DMA address register and a 16-bit terminal count register (one pair for each channel). The 8257 also includes two "general registers": one 8-bit Mode Set register and one 8-bit Status register. The registers are loaded or read when the CPU executes a write or read instruction that addresses the 8257 device and the appropriate register within the 8257 . The 8228 generates the appropriate read or write control signal (generally I/OR or I/OW while the CPU places a 16-bit address on the system address bus, and either outputs the data to be written onto the system data bus or accepts the data being read from the data bus. All or some of the most significant 12 address bits $\mathrm{A}_{4}-\mathrm{A}_{15}$ (depending on the systems memory, I/O configuration) are usually decoded to produce the chip select ( $\overline{\mathrm{CS}}$ ) input to the 8257. An I/O Write input (or Memory Write in memory mapped I/O configurations, described below) specifies that the addressed register is to be programmed, while an I/O Read input (or Memory Read) specifies that the addressed register is to be read. Address bit 3 specifies whether a "channel register" $\left(A_{3}=0\right)$ or the Mode Set (program only)/Status (read only) register ( $A_{3}=1$ ) is to be accessed.

The least significant three address bits, $\mathrm{A}_{0}-\mathrm{A}_{2}$, indicate the specific register to be accessed. When accessing the Mode Set or Status register, $\mathrm{A}_{0}-\mathrm{A}_{2}$ are all zero. When accessing a channel register bit $A_{0}$ differentiates between the DMA address register ( $\mathrm{A}_{0}=0$ ) and the terminal count register ( $A_{0}=1$ ), while bits $A_{1}$ and $A_{2}$ specify one of the

| CONTROL INPUT | $\overline{\mathrm{CS}}$ | $\overline{\overline{/ O W}}$ | $\overline{\mathrm{I/OR}}$ | $\mathrm{~A}_{3}$ |
| :--- | :---: | :---: | :---: | :---: |
| Program Half of a <br> Channel Register | 0 | 0 | 1 | 0 |
| Read Half of a <br> Channel Register | 0 | 1 | 0 | 0 |
| Program Mode Set <br> Register | 0 | 0 | 1 | 1 |
| Read Status Register | 0 | 1 | 0 | 1 |

four channels. Because the "channel registers" are 16bits, two program instruction cycles are required to load or read an entire register. The 8257 contains a first/last ( $F / L$ ) flip flop which toggles at the completion of each channel program or read operation. The F/L flip flop determines whether the upper or lower byte of the register is to be accessed. The F/L flip flop is reset by the RESET input and whenever the Mode Set register is loaded. To maintain proper synchronization when accessing the "channel registers" all channel command instruction operations should occur in pairs, with the lower byte of a register always being accessed first. Do not allow $\overline{\mathrm{CS}}$ to clock while either $\overline{\mathrm{I} O R}$ or $\overline{\mathrm{I} O W}$ is active, as this will cause an erroneous $\mathrm{F} / \mathrm{L}$ flip flop state. In systems utilizing an interrupt structure, interrupts should be disabled prior to any paired programming operations to prevent an interrupt from splitting them. The result of such a split would leave the F/L F/F in the wrong state. This problem is particularly obvious when other DMA channels are programmed by an interrupt structure.

## 8257 REGISTER SELECTION

\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{REGISTER} \& \multirow[b]{2}{*}{BYTE} \& \multicolumn{4}{|l|}{ADDRESS INPUTS} \& \multirow[b]{2}{*}{F/L} \& \multicolumn{8}{|c|}{*BI-DIRECTIONAL DATA BUS} <br>
\hline \& \& $\mathrm{A}_{3}$ \& $\mathbf{A}_{2}$ \& $\mathrm{A}_{1}$ \& $\mathbf{A}_{0}$ \& \& $\mathbf{D}_{7}$ \& $\mathrm{D}_{6}$ \& D 5 \& D 4 \& $\mathrm{D}_{3}$ \& $\mathrm{D}_{2}$ \& D ${ }_{1}$ \& $\mathrm{D}_{0}$ <br>
\hline CH-0 DMA Address \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 0 \& 0
0 \& 0 \& 0 \& 0 \& $\mathbf{A}_{7}$
$\mathbf{A}_{15}$ \& $\mathbf{A}_{6}$
$\mathbf{A}_{14}$ \& $$
\begin{gathered}
\mathbf{A}_{5} \\
\mathbf{A}_{13}
\end{gathered}
$$ \& $\mathbf{A}_{4}$
$\mathbf{A}_{12}$ \& $\mathbf{A}_{3}$
$\mathbf{A}_{11}$ \& $\mathbf{A}_{2}$
$\mathbf{A}_{10}$ \& $\mathbf{A}_{1}$
$\mathbf{A} 9$ \& $\mathbf{A}_{0}$
$\mathbf{A}_{8}$ <br>
\hline CH-0 Terminal Count \& LSB MSB \& 0 \& 0 \& 0 \& 1 \& 0 \& C
R
Rd \& C
Wr \& $\mathrm{C}_{5}$ \& $\mathrm{C}_{4}$ \& C

$\mathrm{C}_{11}$ \& $\mathrm{C}_{2}$
$\mathrm{C}_{10}$ \& $\mathrm{C}_{1}$
$\mathrm{C}_{9}$ \& C
C
8 <br>

\hline CH-1 DMA Address \& | LSB |
| :--- |
| MSB | \& 0 \& 0 \& 1 \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$
\] \& 0 \& \multicolumn{4}{|l|}{Same as Channel 0} \& \& \& \& <br>

\hline CH-1 Terminal Count \& LSB MSB \& 0 \& 0 \& 1 \& $$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$ \& \[

$$
\begin{aligned}
& 0 \\
& 1
\end{aligned}
$$
\] \& \& \& \& \& \& \& \& <br>

\hline CH-2 DMA Address \& | LSB |
| :--- |
| MSB | \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& 0 \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$
\] \& 1

1 \& \multicolumn{3}{|l|}{Same as Channel 0} \& \& \& \& \& <br>

\hline CH-2 Terminal Count \& | LSB |
| :--- |
| MSB | \& 0 \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 1
\end{aligned}
$$
\] \& \& \& \& \& \& \& \& <br>

\hline CH-3 DMA Address \& LSB MSB \& $$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$ \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$
\] \& 1 \& \multicolumn{3}{|l|}{Same as Channel 0} \& \& \& \& \& <br>

\hline CH-3 Terminal Count \& | LSB |
| :--- |
| MSB | \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 1
\end{aligned}
$$
\] \& \& \& \& \& \& \& \& <br>

\hline MODE SET (Program only) \& - \& 1 \& 0 \& 0 \& 0 \& 0 \& AL \& TCS \& EW \& RP \& EN3 \& EN2 \& EN1 \& ENO <br>
\hline STATUS (Read only) \& - \& 1 \& 0 \& 0 \& 0 \& 0 \& 0 \& 0 \& 0 \& UP \& TC3 \& TC2 \& TC1 \& TCO <br>
\hline
\end{tabular}

[^7]
## DMA Operation

Internal 8257 operations may proceed through seven different states. The duration of a state is defined by the clock input. When the 8257 is not executing a DMA cycle, it is in the idle state, $\mathrm{S}_{\mathrm{I}}$. A DMA cycle begins when one or more DMA Request (DRQn) lines become active. The 8257 then enters state $\mathrm{S}_{0}$, sends a Hold Request (HRQ) to the CPU and waits for as many $\mathrm{S}_{0}$ states as are necessary for the CPU to return a Hold Acknowledge (HLDA). For each $\mathrm{S}_{0}$ state, the DMA Request lines are again sampled and DMA priority is resolved (according to the fixed or rotating priority scheme). When HLDA is received, the DMA Acknowledge ( $\overline{\mathrm{DACKn}}$ ) line for the highest priority requesting channel is activated, thus selecting that channel and its peripheral for the DMA cycle. The 8257 then proceeds to state $S_{1}$. Note that the DMA Request (DRQn) input should remain high until either DACKn is received for a single DMA cycle service, or until both the $\overline{\text { DACKn }}$ and TC outputs are received when transferring an entire data block in a "burst" mode. If the 8257 should lose control of the system bus (i.e., if HLDA goes false), the DMA Acknowledge will be removed after the current DMA cycle is completed and no more DMA cycles will occur until the 8257 again acquires control of the system bus.
Each DMA cycle will consist of at least four internal states: $S_{1}, S_{2}, S_{3}$, and $S_{4}$. If the access time for the memory or I/O devices involved is not fast enough to return the required READY response and complete a byte transfer within the specified amount of time, one or more wait states (SW) are inserted between states $\mathrm{S}_{3}$ and $\mathrm{S}_{4}$. Recall that in certain cases the Extended Write option can eliminate the need for a wait state. Note that a READY response is not required during DMA verify cycles. Specified minimum/maximum values for READY setup time ( $t_{\mathrm{RS}}$ ), write data setup time ( $\mathrm{t}_{\mathrm{DW}}$ ), read data access time ( $\mathrm{t}_{\mathrm{RD}}$ ) and HLDA setup time ( $\mathrm{t}_{\mathrm{QS}}$ ) are listed under A.C. CHARACTERISTICS and are illustrated in the accompanying timing diagrams.

During DMA write cycles, the I/O Read ( $\overline{\mathrm{I} O R}$ ) output is generated at the beginning of state $S_{2}$ and the Memory Write ( $\overline{M E M W}$ ) output is generated at the beginning of $S_{3}$. During DMA read cycles, the Memory Read (MEMR) output is generated at the beginning of state $\mathrm{S}_{2}$ and the I/O Write (I/OW) output goes true at the beginning of of state $\mathrm{S}_{3}$. Recall that no read or write control signals are generated during DMA verify cycles. Extended $\overline{W R}$ for MEM and I/O will be generated in $\mathrm{S}_{2}$.


DMA OPERATION STATE DIAGRAM

## Memory Mapped I/O Configurations

The 8257 can be connected to the system bus as a memory device instead of as an I/O device for memory mapped I/O configurations by connecting the system memory control lines to the 8257's I/O control lines and the system I/O control lines to the 8257's memory control lines.
This configuration permits use of the 8080's considerably larger repertoire of memory instructions when reading or loading the 8257's registers. Note that with this connection, the programming of the Read (bit 15) and Write (bit 14) bits in the terminal count register will have a different meaning:


SYSTEM INTERFACE FOR MEMORY MAPPED I/O

| BIT 15 <br> READ | BIT 14 <br> WRITE |  |
| :---: | :---: | :---: |
| 0 | 0 | DMA Verify Cycle |
| 0 | 1 | DMA Read Cycle |
| 1 | 0 | DMA Write Cycle |
| 1 | 1 | Illegal |

TC REGISTER FOR MEMORY MAPPED I/O ONLY

DETAILED SYSTEM INTERFACE SCHEMATIC


## DETAILED SYSTEM INTERFACE SCHEMATIC



## SYSTEM APPLICATION EXAMPLES



DMA CONTROLLER

FLOPPY DISK CONTROLLER (4 DRIVES)


HIGH-SPEED COMMUNICATION CONTROLLER



7/7/77/7/77/7/1L = high Impedance

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias. . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on Any Pin
With Respect to Ground . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional opera tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, G N D=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | Volts |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+.5$ | Volts |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | Volts | $\mathrm{IOL}^{\text {a }}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | V cc | Volts | $l_{O H}=-150 \mu A$ for $A B$, DB and AEN $\mathrm{I}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ for others |
| $\mathrm{V}_{\mathrm{HH}}$ | HRQ Output High Voltage | 3.3 | $V_{\text {cc }}$ | Volts | $\mathrm{l}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ |
| ICC | $V_{\text {cc }}$ Current Drain |  | 120 | mA |  |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ to 0 V |
| IOFL | Output Leakage During Float |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ to 0 V |

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{I / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins <br> returned to GND |

## A.C. CHARACTERISTICS: PERIPHERAL (SLAVE) MODE

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{GND}=0 \mathrm{~V}$ (Note 1 ).
8080 BUS PARAMETERS:
READ CYCLE

|  | Parameter | 8257 |  | 8257-5 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{T}_{\text {AR }}$ | Adr or $\overline{\mathrm{CS}} \downarrow$ Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {RA }}$ | Adr or $\overline{\mathrm{CS}} \uparrow$ Hold from $\overline{\mathrm{RD}} \uparrow$ | 0 |  | 0 |  | ns |  |
| $\mathrm{T}_{\text {RD }}$ | Data Access from $\overline{\mathrm{RD}} \downarrow$ | 0 | 300 | 0 | 200 | ns | (Note 2) |
| $\mathrm{T}_{\text {DF }}$ | $\mathrm{DB} \rightarrow$ Float Delay from $\overline{\mathrm{RD}} \uparrow$ | 20 | 150 | 20 | 100 | ns |  |
| $\mathrm{T}_{\text {RR }}$ | $\overline{\mathrm{RD}}$ Width | 250 |  | 250 |  | ns |  |

WRITE CYCLE:

| Symbol | Parameter | 8257 |  | 8257-5 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{T}_{\text {AW }}$ | Adr Setup to $\overline{W R} \downarrow$ | 20 |  | 20 |  | ns |  |
| TWA | Adr Hold from $\overline{W R} \uparrow$ | 0 |  | 0 |  | ns |  |
| T DW | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 200 |  | 200 |  | ns |  |
| TWD | Data Hold from $\overline{W R} \uparrow$ | 0 |  | 0 |  | ns |  |
| TWW | $\overline{\text { WR Width }}$ | 200 |  | 200 |  | ns |  |

OTHER TIMING:

| Symbol | Parameter | 8257 |  | 8257-5 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| T RSTW | Reset Pulse Width | 300 |  | 300 |  | ns |  |
| $\mathrm{T}_{\text {RSTD }}$ | Power Supply $\uparrow\left(\mathrm{V}_{\mathrm{CC}}\right)$ Setup to Reset $\downarrow$ | 500 |  | 500 |  | $\mu \mathrm{s}$ |  |
| $\mathrm{T}_{\mathrm{r}}$ | Signal Rise Time |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\mathrm{f}}$ | Signal Fall Time |  | 20 |  | 20 | ns |  |
| TRSTS | Reset to First $\overline{\text { OWR }}$ | 2 |  | 2 |  | ${ }^{\mathrm{t}_{\mathrm{Cr}}}$ |  |

Notes: 1. All timing measurements are made at the following reference voltages unless specified otherwise: Input " 1 " at 2.0 V , " 0 " at 0.8 V
2. $8257: C_{L}=100 p F, 8257-5: C_{L}=150 p F$.

Output " 1 " at $2.0 \mathrm{~V}, ~ " ~ 0$ " at 0.8 V
8257 PERIPHERAL MODE TIMING DIAGRAM WRITE TIMING:


READ TIMING:

input Waveform for a.c. tests:


## A.C. CHARACTERISTICS: DMA (MASTER) MODE $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$, GND 0 OV

| SYMBOL | PARAMETER | 8257 |  | 8257-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| $\mathrm{T}_{\mathrm{CY}}$ | Cycle Time (Period) | 320 | 4 | 320 | 4 | $\mu \mathrm{s}$ |
| T $\theta$ | Clock Active (High) | 120 | ${ }^{.8} \mathrm{~T}_{\mathrm{CY}}$ | 80 | .$^{8} \mathrm{~T}_{\mathrm{CY}}$ | ns |
| Tos | DRQ $\uparrow$ Setup to $\theta \downarrow$ (SI, S4) | 120 |  | 120 |  |  |
| $\mathrm{T}_{\mathrm{OH}}$ | DRQ $\downarrow$ Hold from HLDA ${ }^{[4]}$ | 0 |  | 0 |  |  |
| TDO | HRQ $\uparrow$ or $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI}, \mathrm{S} 4)$ (measured at 2.0 V ) ${ }^{[1]}$ |  | 160 |  | 160 | ns |
| TDQ1 | HRQ $\uparrow$. or $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI}, \mathrm{S} 4)$ (measured at 3.3V) ${ }^{[3]}$ |  | 250 |  | 250 | ns |
| THS | HLDA $\uparrow$ or $\downarrow$ Setup to $\theta \downarrow$ (SI,S4) | 100 |  | 100 |  | ns |
| $\mathrm{T}_{\text {AEL }}$ | AEN $\uparrow$ Delay from $\theta \downarrow(\mathrm{S} 1)^{[1]}$ |  | 300 |  | 300 | ns |
| $\mathrm{T}_{\text {AET }}$ | AEN $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI})^{[1]}$ |  | 200 |  | 200 | ns |
| TAEA | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Active) Delay from AEN $\uparrow$ (S1) ${ }^{[4]}$ | 20 |  | 20 |  | ns |
| T FAAB | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Active) Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\text {AFAB }}$ | $\operatorname{Adr}(\mathrm{AB})$ (Float) Delay from $\theta \uparrow(\mathrm{SI})^{[2]}$ |  | 150 |  | 150 | ns |
| $\mathrm{T}_{\text {ASM }}$ | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Stable) Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\text {AH }}$ | $\operatorname{Adr}(\mathrm{AB})$ (Stable) Hold from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ | $\mathrm{T}_{\text {ASM }}$-50 |  | $\mathrm{T}_{\text {ASM }}$-50 |  |  |
| $\mathrm{T}_{\text {AHR }}$ | Adr (AB)(Valid) Hold from $\overline{\operatorname{Rd}} \uparrow(\mathrm{S} 1, \mathrm{SI})[4]$ | 60 |  | 60 |  | ns |
| $\mathrm{T}_{\text {AHW }}$ | Adr (AB) (Valid) Hold from $\overline{\mathrm{Wr}} \uparrow(\mathrm{S} 1, \mathrm{SI})^{[4]}$ | 300 |  | 300 |  | ns |
| T ${ }_{\text {FADB }}$ | Adr (DB)(Active) Delay from $\theta \uparrow$ (S1) ${ }^{[2]}$ |  | 300 |  | 300 | ns |
| T ${ }_{\text {AFDB }}$ | $\operatorname{Adr}$ (DB)(Float) Delay from $\theta \uparrow$ (S2) ${ }^{[2]}$ | $\mathrm{T}_{\mathrm{STT}}+20$ | 250 | $\mathrm{T}_{\mathrm{STT}}+20$ | 170 | ns |
| $\mathrm{T}_{\text {ASS }}$ | Adr (DB) Setup to AdrStb $\downarrow$ (S1-S2) ${ }^{\text {[4] }}$ | 100 |  | 100 |  | ns |
| $\mathrm{T}_{\text {AHS }}$ | Adr (DB) (Valid) Hold from AdrStb $\downarrow$ (S2) ${ }^{[4]}$ | 50 |  | 50 |  | ns |
| $T_{\text {STL }}$ | AdrStb $\uparrow$ Delay from $\theta \uparrow(\mathrm{S} 1)^{[1]}$ |  | 200 |  | 200 | ns |
| $\mathrm{T}_{\text {STT }}$ | AdrStb $\downarrow$ Delay from $\theta \uparrow(\mathrm{S} 2)^{[1]}$ |  | 140 |  | 140 | ns |
| $\mathrm{T}_{\text {SW }}$ | AdrStb Width (S1-S2) ${ }^{[4]}$ | $T_{\text {CY-100 }}$ |  | $\mathrm{T}_{\mathrm{CY} \text {-100 }}$ |  | ns |
| TASC | $\overline{\mathrm{R}} \overline{\mathrm{d}} \downarrow$ or $\overline{\mathrm{Wr}}$ (Ext) $\downarrow$ Delay from AdrStb $\downarrow$ (S2) ${ }^{[4]}$ | 70 |  | 70 |  | ns |
| $\mathrm{T}_{\mathrm{DBC}}$ | $\begin{aligned} & \overline{\mathrm{Rd}} \downarrow \text { or } \overline{\mathrm{Wr}_{r}}(\mathrm{Ext}) \downarrow \text { Delay from Adr (DB) } \\ & \text { (Float)(S2)[4] } \end{aligned}$ | 20 |  | 20 |  | ns |
| $\mathrm{T}_{\text {AK }}$ | DACK $\uparrow$ or $\downarrow$ Delay from $\theta \downarrow(S 2, S 1)$ and TC/Mark $\uparrow$ Delay from $\theta \uparrow(S 3)$ and TC/Mark $\downarrow$ Delay from $\theta \uparrow$ (S4) ${ }^{[1,5]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\mathrm{DCL}}$ | $\overline{\mathrm{Rd}} \downarrow$ or $\overline{\mathrm{Wr}}($ Ext $) \downarrow$ Delay from $\theta \uparrow(\mathrm{S} 2)$ and $\overline{W r} \downarrow$ Delay from $\theta \uparrow(S 3)^{[2,6]}$ |  | 200 |  | 200 | ns |
| TDCT | $\overline{\mathrm{Rd}} \uparrow$ Delay from $\theta \downarrow(\mathrm{S} 1, \mathrm{SI})$ and $\bar{W} \uparrow \uparrow$ Delay from $\theta \uparrow(S 4)^{[2,7]}$ |  | 200 |  | 200 | ns |
| TFAC | $\overline{\mathrm{Rd}}$ or $\overline{\mathrm{Wr}}$ (Active) from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 300 |  | 300 | ns |
| TAFC | $\overline{\mathrm{Rd}}$ or $\overline{\mathrm{Wr}}$ (Float) from $\theta \uparrow$ (SI)[2] |  | 150 |  | 150 | ns |
| TRWM | $\overline{\mathrm{Rd}}$ Width (S2-S1 or SI)[4] | $2 \mathrm{~T}_{C Y}+\mathrm{T}_{\theta}-50$ |  | $2 \mathrm{~T}_{\mathrm{CY}}+\mathrm{T}_{\theta}-50$ |  | ns |
| TWWM | $\overline{\text { Wr Width (S3-S4) }}{ }^{[4]}$ | $\mathrm{T}_{\text {CY-50 }}$ |  | $\mathrm{T}_{\text {CY }} 50$ |  | ns |
| TWWME | $\overline{\text { Wr }}$ (Ext) Width (S2-S4)[4] | $2 \mathrm{~T}_{\mathrm{CY}}-50$ |  | $2 \mathrm{~T}_{\mathrm{CY}}-50$ |  | ns |
| $\mathrm{T}_{\text {RS }}$ | READY Set Up Time to $\theta \uparrow(\mathrm{S} 3, \mathrm{Sw}$ ) | 30 |  | 30 |  | ns |
| TRH | READY Hold Time from $\theta \uparrow$ (S3, Sw) | 20 |  | 20 |  | ns |

[^8]
# 8259, 8259-5 PROGRAMMABLE INTERRUPT CONTROLLER 

- MCS-85 ${ }^{\text {™ }}$ Compatible 8259-5
- Eight Level Priority Controller
- Expandable to 64 Levels

Programmable Interrupt Modes

- Individual Request Mask Capability
- Single +5 V Supply (No Clocks)
- 28 Pin Dual-In-Line Package
- Fully Compatible with Intel CPUs

The 8259 handles up to eight vectored priority interrupts for the CPU. It is cascadable for up to 64 vectored priority interrupts, without additional circuitry. It will be packaged in a 28 -pin plastic DIP, uses nMOS technology and requires a single +5 V supply. Circuitry is static, requiring no clock input.
The 8259 is designed to minimize the software and real time overhead in handling multi-level priority interrupts. It has several modes, permitting optimization for a variety of system requirements.

## PIN CONFIGURATION



PIN NAMES

| $D_{7}-D_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| $\overline{R D}$ | READ INPUT |
| $\overline{\text { WR }}$ | WRITE INPUT |
| $A_{0}$ | COMMAND SELECT ADDRESS |
| $\overline{C S}$ | CHIP SELECT |
| $C A S 1-C A S O$ | CASCADE LINES |
| $\overline{S P}$ | SLAVE PROGRAM INPUT |
| INT | INTERRUPT OUTPUT |
| $\overline{\text { INTA }}$ | INTERRUPT ACKNOWLEDGE INPUT |
| IRO-IR7 | INTERRUPT REQUEST INPUTS |

## BLOCK DIAGRAM



## INTERRUPTS IN MICROCOMPUTER SYSTEMS

Microcomputer system design requires that I/O devices such as keyboards, displays, sensors and other components receive servicing in an efficient method so that large amounts of the total system tasks can be assumed by the microcomputer with little or no effect on throughput.

The most common method of servicing such devices is the Polled approach. This is where the processor must test each device in sequence and in effect "ask" each one if it needs servicing. It is easy to see that a large portion of the main program is looping through this continuence polling cycle and that such a method would have a serious, detrimental effect on system throughput thus limiting the tasks that could be assumed by the microcomputer and reducing the cost effectiveness of using such devices.

A more desireable method would be one that would allow the microprocessor to be executing its main program and only stop to service peripheral devices when it is told to do so by the device itself. In effect, the method would provide an external asynchronous input that would inform the processor that it should complete whatever instruction that is currently being executed and fetch a new routine that will service the requesting device. Once this servicing is complete however the processor would resume exactly where it left off.
This method is called Interrupt. It is easy to see that system throughput would drastically increase, and thus more tasks could be assumed by the microcomputer to further enhance its cost effectiveness.
The Programmable Interrupt Controller (PIC) functions as an overall manager in an Interrupt-Driven system environment. It accepts requests from the peripheral equipment, determines which of the incoming requests is of the highest importance (priority), ascertains whether the incoming request has a higher priority value than the level currently being serviced and issues an Interrupt to the CPU based on this determination.
Each peripheral device or structure usually has a special program or "routine" that is associated with its specific functional or operational requirements; this is referred to as a "service routine": The PIC, after issuing an Interrupt to the CPU, must somehow input information into the CPU that can "point" the Program Counter to the service routine associated with the requesting device. The PIC does this by providing the CPU with a 3-byte CALL instruction.


## POLLED METHOD



## INTERRUPT METHOD

## 8259 BASIC FUNCTIONAL DESCRIPTION

## General

The 8259 is a device specifically designed for use in real time, interrupt driven, microcomputer systems. It manages eight levels or requests and has built-in features for expandability to other 8259s (up to 64 levels). It is programmed by the system's software as an I/O peripheral. A selection of priority modes is available to the programmer so that the manner in which the requests are processed by the 8259 can be configured to match his system requirements. The priority modes can be changed or reconfigured dynamically at any time during the main program. This means that the complete interrupt structure can be defined as required, based on the total system environment.

## Interrupt Request Register (IRR) and In-Service Register (ISR)

The interrupts at the IR input lines are handled by two registers in cascade, the Interrupt Request Register (IRR) and the In-Service Register (ISR). The IRR is used to store all the interrupt levels which are requesting service; and the ISR is used to store all the interrupt levels which are being serviced.

## Priority Resolver

This logic block determines the priorities of the bits set in the IRR. The highest priority is selected and strobed into the corresponding bit of the ISR during $\overline{\text { INTA }}$ pulse.

## INT (Interrupt)

This output goes directly to the CPU interrupt input. The VOH level on this line is designed to be fully compatible with the 8080 input level.

## $\overline{\text { INTA }}$ (Interrupt Acknowledge)

Three INTA pulses will cause the 8259 to release a 3-byte CALL instruction onto the Data Bus.

## Interrupt Mask Register (IMR)

The IMR stores the bits of the interrupt lines to be masked. The IMR operates on the ISR. Masking of a higher priority input will not affect the interrupt request lines of lower priority.


8259 BLOCK DIAGRAM


8259 INTERFACE TO STANDARD SYSTEM BUS

## Data Bus Buffer

This 3-state, bi-directional, 8-bit buffer is used to interface the 8259 to the system Data Bus. Control words and status information are transferred through the Data Bus Buffer.

## Read/Write Control Logic

The function of this block is to accept OUTput commands from the CPU. It contains the Initialization Command Word (ICW) registers and Operation Command Word (OCW) registers which store the various control formats for device operation. This function block also allows the status of the 8259 to be transferred onto the Data Bus.

## $\overline{\mathbf{C S}}$ (Chip Select)

A "low" on this input enables the 8259. No reading or writing of the chip will occur unless the device is selected.

## $\overline{W R}$ (Write)

A "low" on this input enables the CPU to write control words (ICWs and OCWs) to the 8259.

## $\overline{\mathbf{R D}}$ (Read)

A "low" on this input enables the 8259 to send the status of the Interrupt Request Register (IRR), In Service Register (ISR), the Interrupt Mask Register (IMR) or the BCD of the Interrupt level on to the Data Bus.

## AO

This input signal is used in conjunction with $\overline{W R}$ and $\overline{R D}$ signals to write commands into the various command registers as well as reading the various status registers of the chip. This line can be tied directly to one of the address lines.


8259 BLOCK DIAGRAM

8259 BASIC OPERATION

| $\mathrm{A}_{\mathbf{0}}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{WR}}$ | $\overline{\mathrm{CS}}$ | INPUT OPERATION (READ) |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 0 |  |  | 0 | 1 | 0 | IRR, ISR or Interrupting Level $\Rightarrow$ DATA BUS (Note 1) |
| 1 |  |  | 0 | 1 | 0 | IMR $\Rightarrow$ DATA BUS |
|  |  |  |  |  |  | OUTPUT OPERATION (WRITE) |
| 0 | 0 | 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ OCW2 |
| 0 | 0 | 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ OCW3 |
| 0 | 1 | X | 1 | 0 | 0 | DATA BUS $\Rightarrow$ ICW1 |
| 1 | X | X | 1 | 0 | 0 | DATA BUS $\Rightarrow$ OCW1, ICW2, ICW3 (Note 2) |
|  |  |  |  |  |  | DISABLE FUNCTION |
| X | X | X | 1 | 1 | 0 | DATA BUS $\Rightarrow 3-S T A T E$ |
| X | X | X | X | X | 1 | DATA BUS $\Rightarrow 3-S T A T E$ |

Note 1: Selection of IRR, ISR or Interrupting Level is based on the content of OCW3 written before the READ operation.
Note 2: On-chip sequencer logic queues these commands into proper sequence.

## $\overline{\mathbf{S P}}$ (Slave Program)

More than one 8259 can be used in the system to expand the priority interrupt scheme up to 64 levels. In such case, one 8259 acts as the master, and the others act as slaves. A "high" on the $\overline{S P}$ pin designates the 8259 as the master, a "low" designates it as a slave.

## The Cascade Buffer/Comparator

This function block stores and compares the IDs of all 8259 used in the system. The associated three I/O pins (CAS0-2) are outputs when the 8259 is used as a master ( $\overline{S P}=1$ ), and are inputs when the 8259 is used as a slave ( $\overline{\mathrm{SP}}=0$ ). As a master, the 8259 sends the ID of the interrupting slave device onto the CASO-2 lines. The slave thus selected will send its preprogrammed subroutine addressed onto the Data Bus during next two consecutive INTA pulses. (See section "Cascading the 8259".)


8259 BLOCK DIAGRAM

## 8259 DETAILED OPERATIONAL SUMMARY

## General

The powerful features of the 8259 in a microcomputer system are its programmability and its utilization of the CALL instruction to jump into any address in the memory map. The normal sequence of events that the 8259 interacts with the CPU is as follows:

1. One or more of the INTERRUPT REQUEST lines (IR70 ) are raised high, setting the corresponding IRR bit(s).
2. The 8259 accepts these requests, resolves the priorities, and sends an INT to the CPU.
3. The CPU acknowledges the INT and responds with an INTA pulse.
4. Upon receiving an INTA from the CPU group, the highest priority ISR bit is set, and the corresponding IRR bit is reset. The 8259 will also release a CALL instruction code (11001101) onto the 8-bit Data Bus through its D7-0 pins.
5. This CALL instruction will initiate two more $\overline{\mathrm{NTA}}$ pulses to be sent to the 8259 from the CPU group.
6. These two INTA pulses allow the 8259 to release its preprogrammed subroutine address onto the Data Bus. The lower 8-bit address is released at the first $\overline{\text { INTA }}$ pulse and the higher 8-bit address is released at the second INTA pulse.
7. This completes the 3-byte CALL instruction released by the 8259 . ISR bit is not reset until the end of the subroutine when an EOI (End of interrupt) command is issued to the 8259.

## Programming The 8259

The 8259 accepts two types of command words generated by the CPU:

1. Initialization Command Words (ICWs):

Before normal operation can begin, each 8259 in the system must be brought to a starting point - by a sequence of 2 or 3 bytes timed by $\overline{W R}$ pulses. This sequence is described in Figure 1.
2. Operation Command Words (OCWs):

These are the command words which command the 8259 to operate in various interrupt modes. These modes are:
a. Fully nested mode
b. Rotating priority mode
c. Special mask mode
d. Polled mode

The OCWs can be written into the 8259 at anytime after initialization.


FIGURE 1. INITIALIZATION SEQUENCE

Initialization Command Words 1 and 2: (ICW1 and ICW2)
Whenever a command is issued with $\mathrm{A} 0=0$ and $\mathrm{D} 4=1$, this is interpreted as Initialization Command Word 1 (ICW1), and initiates the initialization sequence. During this sequence, the following occur automatically:
a. The edge sense circuit is reset, which means that following initialization, an interrupt request (IR) input must make a low to high transition to generate an interrupt.
b. The interrupt Mask Register is cleared.
c. IR 7 input is assigned priority 7.
d. Special Mask Mode Flip-flop and status Read Flipflop are reset.

The 8 requesting devices have 8 addresses equally spaced in memory. The addresses can be programmed at intervals of 4 or 8 bytes; the 8 routines thus occupying a page of 32 or 64 bytes respectively in memory.

The address format is:


A0-4 are automatically inserted by the 8259, while A15-6 are programmed by ICW1 and ICW2. When interval $=8$, A5 is fixed by the 8259 . If interval $=4$, A5 is programmed in ICW1. Thus, the interrupt service routines can be located anywhere in the memory space. The 8 byte interval will maintain compatibility with current 8080 RESTART instruction software, while the 4 byte interval is best for compact jump table.
The address format inserted by the 8259 is described in Table 1.
The bits $F$ and $S$ are defined by ICW1 as follows:
F: Call address interval. $F=1$, then interval $=4 ; \quad F=0$, then interval $=8$.
S: Single. $S=1$ means that this is the only 8259 in the system. It avoids the necesity of programming ICW3.

| INTERVAL = 4 |  |  |  |  |  |  |  |  | INTERVAL $=8$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOWER MEMORY ROUTINE ADDRESS |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
| IR 7 | A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 | A7 | A6 | 1 | 1 | 1 | 0 | 0 | 0 |
| IR 6 | A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 | A7 | A6 | 1 | 1 | 0 | 0 | 0 | 0 |
| IR 5 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 | A7 | A6 | 1 | 0 | 1 | 0 | 0 | 0 |
| IR 4 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 | A7 | A6 | 1 | 0 | 0 | 0 | 0 | 0 |
| IR 3 | A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 | A7 | A6 | 0 | 1 | 1 | 0 | 0 | 0 |
| IR 2 | A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 | A7 | A6 | 0 | 1 | 0 | 0 | 0 | 0 |
| IR 1 | A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 | A7 | A6 | 0 | 0 | 1 | 0 | 0 | 0 |
| IR 0 | A7 | A6 | A5 | 0 | 0 | 0 | 0 | 0 | A7 | A6 | 0 | 0 | 0 | 0 | 0 | 0 |

TABLE 1.

## Example of Interrupt Acknowledge Sequence

Assume the 8259 is programmed with $F=1$ (CALL address interval $=4$ ), and IR5 is the interrupting level. The 3 byte sequence released by the 8259 timed by the INTA pulses is as follows:

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1st $\overline{\text { INTA }}$ | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | CALL <br> CODE |
| 2nd $\overline{\text { INTA }}$ | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 | LOWER <br> ROUTINE <br> ADDRESS |
| 3rd INTA | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | HIGHER <br> ROUTINE <br> ADDRESS |

## Initialization Command Word 3 (ICW3)

This will load the 8 -bit slave register. The functions of this register are as follows:
a. If the 8259 is the master, a " 1 " is set for each slave in the system. The master then will release byte 1 of the CALL sequence and will enable the corresponding slave to release bytes 2 and 3 , through the cascade lines.
b. If the 8259 is a slave, bits $2-0$ identify the slave. The slave compares its CASO-2 inputs (sent by the master) with these bits. If they are equal, bytes 2 and 3 of the CALL sequence are released.

If bit $S$ is set in ICW1, there is no need to program ICW3.


NOTE 1: SLAVE ID IS EQUAL TO THE CORRESPONDING MASTER IR INPUT.

## Operation Command Words (OCWs)

After the Initialization Command Words (ICWs) are programmed into the 8259, the chip is ready to accept interrupt requests at its input lines. However, during the 8259 operation, a selection of algorithms can command the 8259 to operate in various modes through the Operation Command Words (OCWs). These various modes and their associated OCWs are described below.

## Interrupt Masks

Each Interrupt Request input can be masked individually by the Interrupt Masked Register (IMR) programmed through OCW1.
The IMR operates on the In-Service Register. Note that if an interrupt is already acknowledged by the 8259 (an INTA pulse has occurred), then the Interrupting level, although masked, will inhibit the lower priorities. To enable these lower priority interrupts, one can do one of two things: (1) Write an End of Interrupt (EOI) command (OCW2) to reset the IST bit or (2) Set the special mask mode using OCW3 (as will be explained later in the special mask mode.)

## Fully Nested Mode

The 8259 will operate in the fully nested mode after the execution of the initialization sequence without any OCW being written. In this mode, the interrupt requests are ordered in priorities from 0 through 7 . When an interrupt is acknowledged, the highest priority request is determined and its address vector placed on the bus. In addition, a bit of the Interrupt service register (IS 7-0) is set. This bit remains set until the CPU issues an End of Interrupt (EOI) command immediately before returning from the service routine. While the IS bit is set, all further interrupts of lower priority are inhibited, while higher levels will be able to generate an interrupt (which will only be acknowledged if the CPU has enabled its own interrupt input through software).
After the Initialization sequence, IRO has the highest priority and IR7 the lowest. Priorities can be changed, as will be explained in the rotating priority mode.

## Rotating Priority Commands

There are two variations of rotating priority: auto rotate and specific rotate.

1. Auto Rotate - Executing the Rotate-at-EOI (Auto) command, resets the highest priority ISR bit and assigns that input the lowest priority. Thus, a device requesting an interrupt will have to wait, in the worst case, until 7 other devices are serviced at most once each, i.e., if the priority and "in-service" status is:



In this example, the In-Service FF corresponding to line 4 (the highest priority FF set) was reset and line 4 became the lowest priority, while all the other priorities rotated correspondingly.
The Rotate command is issued in OCW2, where: $R=$ $1, \mathrm{EOI}=1, \mathrm{SEOI}=0$.
2. Specific Rotate - The programmer can change priorities by programming the bottom priority, and by doing this, to fix the highest priority: i.e., if IR5 is programmed as the bottom priority device, the IR6 will have the highest one. This command can be used with or without resetting the selected ISR bit.

The Rotate command is issued in OCW2 where: $R=1$, SEOI $=1 . \operatorname{L2}, \mathrm{L} 1$, LO are the BCD priority level codes of the bottom priority device. If EOI = 1 also, the ISR bit selected by L2-L0 is reset.

Observe that this mode is independent of the End of Interrupt Command and priority changes can be executed during EOI command or independently from the EOI command.

## End of Interrupt (EOI) and Specific End of Inierrupt (SEOI)

An End of Interrupt command word must be issued to the 8259 before returning from a service routine, to reset the appropriate IS bit.

There are two forms of EOI command: Specific and nonSpecific. When the 8259 is operated in modes which preserve the fully nested structure, it can determine which IS bit to reset on EOI. When a non-Specific EOI command is issued the 8259 will automatically reset the highest is bit of those that are set, since in the nested mode, the highest IS level was necessarily the last level acknowledged and will necessarily be the next routine level returned from.
However, when a mode is used which may disturb the fully nested structure, such as in the rotating priority case, the 8259 may no longer be able to determine the last level acknowledged. In this case, a specific EOI (SEOI) must be issued which includes the IS level to be reset as part of the command. The End of the Interrupt is issued whenever $\mathrm{EOI}=$ " 1 " in OCW2. For specific EOI, SEOI = " 1 ", and EOI = 1. L2, L1, L0 is then the BCD level to be reset. As explained in the Rotate Mode earlier, this can also be the bottom priority code. Note that although the Rotate command can be issued during an $\mathrm{EOI}=1$, it is not necessarily tied to it.


## Special Mask Mode (SMM)

This mode is useful when some bit(s) are set (masked) by the Interrupt Mask Register (IMR) through OCW1. If, for some reason, we are currently in an interrupt service routine which is masked (this could happen when the subroutine intentionally mask itself off), it is still possible to enable the lower priority lines by setting the Special Mask mode. In this mode the lower priority lines are enabled until the SMM is reset. The higher priorities are not affected.

The special mask mode FF is set by OCW3 where ESMM = $1, S M M=1$, and reset where: $E S S M=1$ and $S M M=0$.

## Polled Mode

In this mode, the CPU must disable its interrupt input. Service to device is achieved by programmer initiative by a Poll command.

The poll command is issued by setting $P=" 1$ " in OCW3 during a $\overline{W R}$ pulse.
The 8259 treats the next $\overline{\mathrm{RD}}$ pulse as an interrupt acknowledge, sets the appropriate IS Flip-flop, if there is a request, and reads the priority level.

For polling operation, an OCW3 must be written before every read.

The word enabled onto the data bus during $\overline{\mathrm{RD}}$ is:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I | - | - | - | - | W2 | w1 | w0 |

W0 - 2: BCD code of the highest priority level requesting service.
I: Equal to a " 1 " if there is an interrupt.
This mode is useful if there is a routine common to several levels - so that the $\overline{\mathrm{NTA}}$ sequence is not needed (and this saves ROM space). Another application is to use the poll mode to expand the number of priority levels to more than 64.

## SUMMARY OF OPERATION COMMAND WORD PROGRAMMING

|  | A0 D4 D3 |  |  |
| :---: | :---: | :---: | :---: |
| OCW1 | 1 | M7-M0 | IMR (Interrupt Mask Register). $\overline{W R}$ will load it while status can be read with $\overline{\mathrm{RD}}$. |
| OCW2 | 000 | R  SEOI <br> 0 EOI  <br> 0 0 0 <br> 0 1 1 <br> 0 1 1 <br> 1 0 0 <br> 1 0 1 <br> 1 1 0 <br> 1 1 1 | No Action. <br> Non-specific End of Interrupt. <br> No Action. <br> Specific End of Interrupt. L2, L1, LO is the BCD level to be reset. <br> No Action. <br> Rotate priority at EOI. (Auto Mode) <br> Rotate priority, L2, L1, LO becomes bottom priority without <br> Ending of Interrupt. <br> Rotate priority at EOI (Specific Mode), L2, L1, LO becomes bottom priority, and its corresponding IS FF is reset. |
| OcW3 | $0 \quad 0 \quad 1$ | ESMM SMM <br> 0 0 <br> 0 1 <br> 1 0 <br> 1 1 <br> ERIS RIS <br> 0 0 <br> 0 1 <br> 1 0 <br> 1 1 | Special Mask not Affected. <br> Reset Special Mask. Set Special Mask. <br> Read IR Register Status. Read IS Register Status. |

[^9]
## Reading 8259 Status

The input status of several internal registers can be read to update the user information on the system. The following registers can be read by issuing a suitable OCW3 and reading with $\overline{\text { RD }}$.

Interrupt Requests Register (IRR): 8-bit register which contains the levels requesting an interrupt to be acknowledged. The highest request level is reset from the IRR when an interrupt is acknowledged. (Not affected by IMR).

In-Service Register (ISR): 8-bit register which contains the priority levels that are being serviced. The ISR is updated when an End of Interrupt command is issued.
Interrupt Mask Register: 8-bit register which contains the interrupt request lines which are masked.
The IRR can be read when prior to the $\overline{R D}$ pulse, an $\overline{W R}$ pulse is issued with OCW3, and ERIS $=1$, RIS $=0$.
The ISR can be read in a similar mode, when ERIS $=1$, RIS $=1$.

There is no need to write an OCW3 before every status read operation as long as the status read corresponds with the previous one, i.e. the 8259 "remembers" whether the IRR or ISR has been previously selected by the OCW3.
For reading the IMR, a $\overline{W R}$ pulse is not necessary to preceed the $\overline{R D}$. The output data bus will contain the IMR whenever $\overline{\mathrm{RD}}$ is active and $\mathrm{A} 0=1$.

Polling overrides status read when $P=1$, ERIS $=1$ in OCW3.

## Cascading

The 8259 can be easily interconnected in a system of one master with up to eight slaves to handle up to 64 priority levels.

A typical system is shown in Figure 2. The master controls, through the 3 line cascade bus, which one of the slaves will release the corresponding address.
As shown in Figure 2, the slaves interrupt outputs are connected to the master interrupt request inputs. When a slave request line is activated and afterwards acknowledged, the master will release the 8080 CALL code during byte 1 of INTA and will enable the corresponding slave to release the device routine address during bytes 2 and 3 of INTA.

The cascade bus lines are normally low and will contain the slave address code from the trailing edge of the first $\overline{I N T A}$ pulse to the trailing edge of the third pulse. It is obvious that each 8259 in the system must follow a separate initialization sequence and can be programmed to work in a different mode. An EOI command must be issued twice: once for the master and once for the corresponding slave. An address decoder is required to activate the Chip Select ( $\overline{\mathrm{CS}}$ ) input of each 8259. The slave program pin ( $\overline{\mathrm{SP}}$ ) must be at a "low" level for a slave (and then the cascade lines are inputs) and at a "high" level for a master (and then the cascade lines are outpus).


INTERRUPT REQUESTS

## 8259 INSTRUCTION SET

| INST. |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NO. |  | A0 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | OPERATION DESCRIPTION |
| 1 | ICW1 A | 0 | A7 | A6 | A5 | 1 | 0 | 1 | 1 | 0 | Byte 1 initialization, format $=4$, single. |
| 2 | ICW1 B | 0 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 | Byte 1 initialization, format $=4$, not single. |
| 3 | ICW1 C | 0 | A7 | A6 | A5 | 1 | 0 | 0 | 1 | 0 | Byte 1 initialization, format $=8$, single. |
| 4 | ICW1 D | 0 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 | Byte 1 initialization, format $=8$, not single. |
| 5 | ICW2 | 1 | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | Byte 2 initialization (Address No. 2) |
| 6 | ICW3 M | 1 | S7 | S6 | S5 | S4 | S3 | S2 | S1 | SO | Byte 3 initialization - master. |
| 7 | ICW3 S | 1 | 0 | 0 | 0 | 0 | 0 | S2 | S1 | SO | Byte 3 initialization - slave. |
| 8 | OCW1 | 1 | M7 | M6 | M5 | M4 | M3 | M2 | M1 | MO | Load mask reg, read mask reg. |
| 9 | OCW2 E | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | Non specific EOI. |
| 10 | OCW2 SE | 0 | 0 | 1 | 1 | 0 | 0 | L2 | L1 | LO | Specific EOI. L2, L1, LO code of IS FF to be reset. |
| 11 | OCW2 RE | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | Rotate at EOI (Auto Mode). |
| 12 | OCW2 RSE | 0 | 1 | 1 | 1 | 0 | 0 | L2 | L1 | L0 | Rotate at EOI (Specific Mode). L2, L1, L0, code of line to be reset and selected as bottom priority. |
| 13 | OCW2 RS | 0 | 1 | 1 | 0 | 0 | 0 | L2 | L1 | LO | L2, L1, L0 code of bottom priority line. |
| 14 | OCW3 P | 0 | - | 0 | 0 | 0 | 1 | 1 | 0 | 0 | Poll mode. |
| 15 | OCW3 RIS | 0 | - | 0 | 0 | 0 | 1 | 0 | 1 | 1 | Read IS register. |
| 16 | OCW3 RR | 0 | - | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Read requests register. |
| 17 | OCW3 SM | 0 | - | 1 | 1 | 0 | 1 | 0 | 0 | 0 | Set special mask mode. |
| 18 | OCW3 RSM | 0 | - | 1 | 0 | 0 | 1 | 0 | 0 | 0 | Reset special mask mode. |

## Notes:

1. In the master mode $\overline{\mathrm{SP}} \mathrm{pin}=1$, in slave mode $\overline{\mathrm{SP}}=0$.
2. $(-)=$ do not care.

## ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature Under Bi | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage On Any Pin |  |
| With Respect to Ground | -0.5 V to +7 V |
| Power Dissipation | 1 Watt |

Ambient Temperature Under Bias ........ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature With Respect to Ground ............... -0.5 V to +7 V Power Dissipation
*COMMENT:
Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -. 5 | . 8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{Cc}^{+} .5 \mathrm{~V}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| VOH-INT | Interrupt Output High Voltage | $\begin{aligned} & 2.4 \\ & 3.5 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & I_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & I_{\mathrm{OH}}=-50 \mu \mathrm{~A} \end{aligned}$ |
| $\mathrm{I}_{1 /\left(\mathrm{IR}_{0-7}\right)}$ | Input Leakage Current for $\mathrm{IR}_{0-7}$ |  | $\begin{gathered} -300 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0 V \\ & V_{I N}=V_{C C} \end{aligned}$ |
| IIL | Input Leakage Current for Other Inputs |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ to 0 V |
| IOFL | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| 1 CC | $V_{\text {cc }}$ Supply Current |  | 100 | mA |  |

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $V_{S S}$ |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}\right)$ BUS PARAMETERS
READ

|  |  | 8259 |  | $8259-5$ |  |  |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN. | MAX. | MIN. | MAX. | UNIT |
| $\mathrm{t}_{\mathrm{AR}}$ | $\overline{\mathrm{CS}} / \mathrm{A}_{0}$ Stable Before $\overline{\mathrm{RD}}$ or $\overline{\mathrm{INTA}}$ | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\text {RA }}$ | $\overline{\mathrm{CS}} / \mathrm{A}_{0}$ Stable After $\overline{\mathrm{RD}}$ or $\overline{\mathrm{INTA}}$ | 5 |  | 30 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\mathrm{RD}}$ Pulse Width | 420 |  | 300 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Valid From $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}[1]$ |  | 300 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{DF}}$ | Data Float After $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}$ | 20 | 200 | 20 | 100 | ns |

## WRITE

| SYMBOL | PARAMETER | 8259 |  | 8259-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| $\mathrm{t}_{\text {AW }}$ | $\mathrm{A}_{0}$ Stable Before $\overline{\mathrm{WR}}$ | 50 |  | 50 |  | ns |
| twa | $\mathrm{A}_{0}$ Stable After $\overline{\mathrm{WR}}$ | 20 |  | 30 |  | ns |
| ${ }^{\text {tww }}$ | $\overline{\text { WR Pulse Width }}$ | 400 |  | 300 |  | ns |
| ${ }^{\text {t }}$ W | Data Valid to $\overline{W R}$ (T.E.) | 300 |  | 250 |  | ns |
| ${ }^{\text {tw }}$ | Data Valid After $\overline{\text { WR }}$ | 40 |  | 30 |  | ns |

## OTHER TIMINGS

| SYMBOL | PARAMETER | 8259 |  | 8259-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| $\mathrm{t}_{\mathrm{IW}}$ | Width of Interrupt Request Pulse | 100 |  | 100 |  | ns |
| tint | INT $\uparrow$ After IR $\uparrow$ | 400 |  | 350 |  | ns |
| $\mathrm{t}_{1 \mathrm{C}}$ | Cascade Line Stable After $\overline{\text { INTA }} \uparrow$ | 400 |  | 400 |  | ns |

Note 1: 8259: $C_{L}=100 p F, 8259-5: C_{L}=150 p F$.
INPUT WAVEFORMS FOR A.C. TESTS


## WAVEFORMS

## READ TIMING



## WRITE TIMING



## OTHER TIMING



Note: Interrupt Request must remain "HIGH" (at least) until leading edge of first INTA.

## READ STATUS/POLL MODE



IBM 3740 Soft Sectored Format Compatible<br>Programmable Record Lengths<br>Multi-Sector Capability<br>- Maintain Dual Drives with Minimum Software Overhead Expandable to 4 Drives<br>- Automatic Read/Write Head Positioning and Verification

\author{

- Internal CRC Generation and Checking <br> ■ Programmable Step Rate, Settle-Time, Head Load Time, Head Unload Index Count <br> - Single +5 Volt Supply <br> - 40 Pin Package Count
}


# 8271 

The 8271 Floppy Disk Controller (FDC) is an LSI Component designed to interface one to four floppy disk drives to an 8-bit microcomputer system. Its powerful control functions minimize both hardware and software overhead normally associated with floppy disk controllers.

PIN CONFIGURATION
BLOCK DIAGRAM


## 8271 BASIC FUNCTIONAL DESCRIPTION <br> General

The FDC supports a soft sectored format that is IBM 3740 compatible. This component is a high level controller that relieves the CPU (and user) of many of the control tasks associated with implementing a floppy disk interface. The FDC supports a variety of high level instructions which allow the user to store and retrieve data on a floppy disk without dealing with the low level details of the disk operation.
In addition to the standard read/write commands a scan command is supported. The scan command allows the user program to specify a data pattern and instruct the FDC to search for that pattern on a track. Any application that is required to search the disk (such as point of sale price lookup, disk directory search, etc.) for information may use the scan command to reduce the CPU overhead. Once the scan operation is initiated, no CPU intervention is required.

## Hardware Description

The 8271 is packaged in a 40 pin DIP. The following is a functional description of each pin.

| Pin Name | I/O | Description |
| :---: | :---: | :---: |
| $V_{c c}$ |  | +5V supply |
| GND |  | Ground |
| 4 MHz Clock | 1 | A 4 MHz square wave clock |
| Reset | 1 | A high signal on the reset input will force the 8271 to an idle state. The 8271 will remain idle until a command is issued by the CPU. The drive interface output signals are forced low. |
| $\overline{\mathrm{CS}}$ | 1 | The I/O Read and I/O Write inputs are enabled by the chip select signal. |
| $\mathrm{DB}_{7}-\mathrm{DB}_{0}$ | I/O | The Data Bus lines are bidirectional three-state lines. |
| $\overline{W R}$ | 1 | The Write signal is used to signal the control logic that a transfer of data from the data bus to the 8271 is required. |
| $\overline{\mathrm{RD}}$ | 1 | The Read signal is used to signal the control logic that a transfer of data from the 8271 to the data bus is required. |
| INT | 0 | The interrupt signal indicates that the 8271 requires service. |


| Pin Name | 1/0 | Description |
| :---: | :---: | :---: |
| $\mathrm{A}_{1}-\mathrm{A}_{0}$ | 1 | These two lines are used to select the destination of source of data to be accessed by the control logic. |
| DRQ | 0 | The DMA request signal is used to request a transfer of data between the 8271 and memory. |
| $\overline{\text { DACK }}$ | 1 | The DMA ACK signal notifies the 8271 that a DMA cycle has been granted. |
| Select 1- <br> Select 0 | 0 | These lines are used to specify the selected drive. |
| Fault Reset/ OPO | 0 | The fault reset line is used to reset an error condition which is latched by the drive, otherwise the pin is a user specified optional output. |
| Write Enable | 0 | This signal enables the drive write logic. |
| Seek/Step | 0 | This multi-function line is used during drive seeks. |
| Direction | 0 | The direction line specifies the seek direction. |
| Load Head | 0 | The load head line causes the drive to load the Read/Write head load pad against the diskette. |
| Low Current | 0 | This line notifies the drive that track 43 or greater is selected. |
| $\frac{\overline{\text { Ready } 1}}{\overline{\text { Ready } 0}}$ | 1 | These two lines indicate that the specified drive is ready. |
| $\overline{\text { Fault }}$ | 1 | This line is used by the drive to specify a file unsafe condition. |
| $\overline{\text { Count/OPI }}$ | 1 | If the seek / direction / count seek mode is selected, the count pin is pulsed for each track. Otherwise this pin is user specified optional input. |
| $\overline{\text { Write Protect }}$ | 1 | This signal is used to specify if the drive/diskette may be written. |
| $\overline{\text { TRKO }}$ | 1 | This signal indicates when the R/W head is positioned over track zero. |
| $\overline{\text { Index }}$ | 1 | The index signal gives an indication of the relative position of the diskette. |
| $\overline{\text { PLO/SS }}$ | 1 | This pin is used to specify the type of data separator used. |
| Write Data | 0 | Composite write data. |
| Unseparated Data | 1 | This input is the unseparated data and clocks. |
| $\overline{\text { Data Window }}$ | 1 | This is a data window established by the single-shot or phase-locked oscillator data separator. |
| $\overline{\text { PLOC }}$ | 0 | This line is low when the 8271 is searching for input data sync. |

## Principles of Operation

The 8271 is fully compatible with Intel microprocessors. It accepts commands from the CPU, executes these Commands and provides a Result at the end of execution.

Communication with the CPU are through the activating of $\overline{\mathrm{CS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ pins. The $\mathrm{A}_{1}, \mathrm{~A}_{0}$ select the appropriate registers on chip:

| $\mathbf{A}_{\mathbf{3}}$ | $\mathbf{A}_{\mathbf{3}}$ | CS RD | CS WR |
| :---: | :---: | :--- | :--- |
| 0 | 0 | Status Reg | Command Reg |
| 0 | 1 | Result Reg | Parameter Reg |

The FDC chip operation is composed of the following general sequence of events:

## The Command Phase

During the Command Phase, the CPU issues a command byte to the 8271. The command byte provides a general description of the type of operation requested. Many operations require more detailed information about the comand. In such case, from zero to five parameters are written following the command byte to provide such information. The various commands that the 8271 can recognize are listed in the Software Operation Section.

## The Execution Phase

Soon as the last parameter is written into the 8271, the FDC enters the Execution Phase. During this phase there is no need for CPU involvement. The FDC may optionally interface with the 8257 (DMA controller) for high speed data transfers (See System Diagram).

## The Result Phase

During the Result Phase, the FDC chip notified the CPU of the outcome of the command execution. This phase may be initiated by:

1. The successful completion of an operation.
2. An error detected during an operation.
3. An illegal command or parameter detected during the Command Phase.
In the Result Phase, the CPU Reads the Status Register which provides the following information:


After reading the Status Register, the CPU then Reads the Result Register for more information.



## Software Operation

The 8271 can accept many powerful commands from the CPU. The following is a list of Basic Commands (associated Parameters not shown).

SCAN DATA
SCAN DATA AND DELETED DATA
WRITE DATA
WRITE DATA AND DELETED DATA
READ DATA
READ DATA AND DELETED DATA
READ ID
VERIFY DATA AND DELETED DATA
FORMAT
SEEK
READ DRIVE STATUS
SPECIFY

As an example, the SPECIFY command is associated with 4 parameters:


RESET

## EXECUTION PHASE BASIC CHARACTERISTICS

The following table summarizes the various commands with corresponding execution phase characteristics.

| COMMANDS | Deleted Data | 2 Head | 3 Ready |  | 5 Seek |  | 7 Result | $\square$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SCAN DATA | SKIP | LOAD | $\checkmark$ | x | YES | YES | YES | YES |
| SCAN DATA AND | XFER | LOAD | $\checkmark$ | x | YES | YES | YES | YES |
| DEL DATA |  |  |  |  |  |  |  |  |
| WRITE DATA | $x$ | LOAD | $\checkmark$ | $\checkmark$ | YES | YES | YES | YES |
| WRITE DEL DATA | XFER | LOAD | $\checkmark$ | $\checkmark$ | YES | YES | YES | YES |
| READ DATA | SKIP | LOAD | $\checkmark$ | x | YES | YES | YES | YES |
| READ DATA AND | XFER | LOAD | $\checkmark$ | x | YES | YES | YES | YES |
| DEL DATA |  |  |  |  |  |  |  |  |
| READ ID | x | LOAD | $\checkmark$ | x | YES | NO | YES | YES |
| VERIFY DATA AND | XFER | LOAD | $\checkmark$ | x | YES | YES | YES | YES |
| DEL DATA |  |  |  |  |  |  |  |  |
| FORMAT | $x$ | LOAD | $\checkmark$ | $\checkmark$ | YES | NO | YES | YES |
| SEEK | x | - | x | x | YES | NO | YES | YES |
| READ DRIVE STAT | x | - | $x$ | x | NO | NO | YES | NO |
| SPECIFY | x | - | $x$ | x | NO | NO | NO | NO |
| RESET | x | UNLOAD | X | x | NO | NO | NO | NO |
| Note: 1. " $x$ " $\rightarrow$ DON'T CARE <br> 2. " $\mathrm{J} " \rightarrow$ check <br> 3. "-" $\rightarrow$ No change |  |  |  |  |  |  |  |  |

## 8273 <br> SDLC PROTOCOL CONTROLLER

IBM (SDLC) Compatible<br>- Full Duplex Operation-56K BAUD<br>SDLC Loop Operation<br>- User Programmable Modem Control Ports<br>- Programmable NRZI Encode/Decode<br>■ N-Bit Reception Capability

The 8273 SDLC (Synchronous Data Link Control) Protocol controller is a single chip device designed to support the SDLC protocol within a microcomputer system environment. Its internal supervisory instruction set is oriented to frame level (SDLC) functions with a minimum of CPU overhead.

## PIN CONFIGURATION

BLOCK DIAGRAM


## General

The IBM Synchronous Data Link Control (SDLC) communication protocol is a bit oriented communication protocol vs the BI-SYNC protocol which is character or code oriented. The SDLC protocol greatly reduces the overall CPU software on one hand and increases the throughput on the other because of its ability to go full-duplexed mode.
The 8273 SDLC chip is designed to handle the IBM SDLC protocol with minimum CPU software. The 8273 handles the zero-insertion technique used in SDLC protocol, as well as performing NRZI encoding and decoding for the data. Modem handshake signals are provided so that the CPU intervention is minimized. The FCS (Frame check sequence) is also generated and checked by the SDLC chip as well as Flags (01111110) and Idle characters.
One implementation of SDLC is the Loop-configuration typified by IBM 3650 Retail Store System which can also be handled by the 8273 by going into 1 -bit delay mode. In such configuration a two wire pair can be effectively used for data transfer between controllers and loop stations. Digital phase Locked Loop pin-out can be used by the loop station without the presence of an accurate 1X clock.

## Hardware Description

The 8273 is packaged in a 40 pin DIP. The following is a functional description of each pin.

| Pin Name | $I / O$ | Description |
| :--- | :--- | :--- |
| VcC | +5 V supply |  |

GND Ground

RESET I A high signal on this pin will force the 8273 to an idle state. The 8273 will remain idle until a command is issued by the CPU. The modem interface output signals are forced high.
$\overline{\mathrm{CS}} \quad 1$ The I/O Read and I/O Write inputs are enabled by the chip.
$D B_{7}-D B_{0} \quad I / O$ The Data Bus lines are bidirectional three-state lines.
$\overline{W R} \quad 1 \quad$ The Write signal is used to control the transfer of either a command or data from CPU to the 8273.
$\overline{R D} \quad I \quad$ The Read signal is used to control the transfer of either a data byte or a status word from the 8273 to the CPU.
TXINT $O$ The Transmitter interrupt signal indicates that the transmitter logic requires service.
RxINT
O The Receiver interrupt signal indicates that the Receiver logic requires service.

| Pin Name | 1/0 | Description |
| :---: | :---: | :---: |
| TxDRQ | 0 | The Transmitter DMA Request signa indicates the transmitter Buffer is empty and is ready to transmit another data byte. |
| RxRDQ | 0 | The Receiver DMA Request signal indicates the Receiver Buffer is full. |
| $\overline{\text { TxDACK }}$ | 1 | The Transmitter DMA acknowledge sig nal notifies the 8273 that the TxDMA cycle has been granted. |
| $\overline{\text { RxDACK }}$ | 1 | The Receiver DMA acknowledge signa notifies the 8273 that the RxDMA cycle has been granted. |
| $\mathrm{A}_{1}-\mathrm{A}_{0}$ | 1 | These two lines are used to select the destination or source of data to be accessed by the control logic. |
| TxD | 0 | The NRZI encoded data are transmitted through the TxD line. |
| $\overline{\text { TxC }}$ | 1 | The transmitter clock controls the TxD BAUD rate. |
| RxD | 1 | The Receiver Data line receives the NRZI encoded data from the communication data channel. |
| $\overline{\mathrm{RxC}}$ | 1 | The Receiver clock is the 1X BAUD rate that RxD is received. |
| $\overline{32 X ~ C L K}$ | 1 | The 32X clock is used to provide clock recovery when Asynchronous modem is used. In loop configuration the loop station can run without an accurate 1X clock by using the 32X CLK. |
| $\overline{\text { DPLL }}$ | 0 | Digital Phase Locked Loop output can be tied to RxC and/or TxC when 1X clock is not available. DPLL is used with 32X CLK. |
| $\overline{\text { FLAG DET }}$ | 0 | Flag Detect signals that a flag (01111110) has been detected. |
| $\overline{\text { RTS }}$ | 0 | Request to send signals the terminal is ready to transmit Data. |
| $\overline{\text { CTS }}$ | 1 | Clear to send signals that the modem is ready to accept data for transmission. |
| $\overline{C D}$ | 1 | Carrier Detect signals that the line transmission has started and the 8273 may begin sample data on RxD line. |
| $\overline{\mathrm{PA}}_{0-2}$ | 1 | General Purpose input Ports. The logic levels on these lines can be Read by the CPU through the Data Bus Buffer. |
| $\overline{\mathrm{PB}}_{0-3}$ | 0 | General Purpose output Ports. The CPU can write these output lines through Data Bus Buffer. |
| ${ }_{\phi}$ CLK | 1 | A 4 MHz Square Wave Clock. |

## Principles of Operation

The 8273 is fully compatible with Intel microprocessors. It accepts commands from the CPU, executes these Commands and provides a Result at the end of execution. Communication with CPU is through the activating of $\overline{C S}$, $\overline{R D}, \overline{W R}$ pins. The $A_{1} A_{0}$ select the appropriate registers on chip:

| A1 | A0 | CS•RD | CS•WR |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Status Reg | Command Reg |
| 0 | 1 | Result Reg | Parameter Reg |
| 1 | 0 | TXReg | - |
| 1 | 1 | RXReg | - |

The SDLC chip operation is composed of the following general sequence of events:

## The Command Phase

During the Command Phase, the CPU issues a command byte to the 8273. The command byte provides a general description of the type of operation requested. Many operations require more detailed information about the command. In such case, from zero to four parameters are written following the command byte to provide such information. The various commands that the 8273 can recognize are listed in the Software Operation Section.

## The Execution Phase

After the last parameter is written into the 8273, the SDLC chip enters the Execution Phase. During this phase there is no need for CPU involvement. The system might interface with the 8257 (DMA controller) if programmed to do so, for high speed data transfers (see System Diagram). On the other hand for low speed data rate communication TxINT and RxINT can be used.

## The Result Phase

During the Result Phase, the SDLC chip notifies the CPU of the outcome of the command execution. This phase may be initiated by:

1. The successful completion of an operation.
2. An error detected during an operation.

In the Result Phase, the CPU Reads the Status Register which provides the following information.


Based on the status of the Status Register, the CPU may Read the Tx Reg, Rx Reg, or Result Register, if more information is needed.

## Software Operation

The 8273 can accept many powerful commands from the CPU. The following is a list of such commands (associated parameters not shown).

General Receive<br>Selective Receive<br>Selective Loop Receive<br>End of Polling Search<br>Receive Disable<br>Transmit Frame<br>Loop Transmit<br>Transparent Transmit<br>Abort Tx Frame<br>Abort Loop Tx<br>Abort Transparent Tx<br>Read Port A<br>Read Port B<br>Set/Reset 1 Bit Delay<br>Set/Reset Serial I/O<br>Set/Reset Operating Mode<br>Set/Reset Port A/B Bit



CPU WRITES COMMAND AND PARAMETERS INTO THE 8273 COMMAND AND PARAMETER REGISTERS.

THE 8273 IS ON ITS OWN TO CARRY OUT THE COMMAND.

THE 8273 SIGNALS THE CPU THAT THE EXECUTION
HAS FINISHED. THE CPU WILL PERFORM A READ
OPERATION OF ONE OR MORE OF THE REGISTERS.


## 8273 SYSTEM DIAGRAM



SYNCHRONOUS MODEM - DUPLEX OR HALF DUPLEX OPERATION


ASYNCHRONOUS MODEMS - DUPLEX OPERATION


ASYNCHRONOUS MODEMS - HALF DUPLEX OPERATION


ASYNCHRONOUS OPERATION - NO MODEMS - DUPLEX OR HALF DUPLEX


8275

## PROGRAMMABLE CRT CONTROLLER

- Light Pen Detection and Registers
- Dual Row Buffers
- Programmable DMA Burst Mode
- Single +5 Volt Supply
- 40 Pin Package
- Programmable Screen and Character Formats
- Six Indepependent Visual Field Attributes
- Eleven Visual Character Attributes (Graphic Capability)
- Cursor Control (4 Types)

The 8275 Programmable CRT Controller is a single chip device to interface CRT Raster Scan Displays with Intel ${ }^{\circledR}$ Microcomputer Systems. Its primary function is to refresh the display by buffering the information from main memory and keeping track of the display position of the screen. The flexibility designed into the 8275 will allow simple interface to almost any Raster Scan CRT Display with a minimum of external hardware and software overhead.

PIN CONFIGURATION


BLOCK DIAGRAM


## General

The CRT Controller (8275) is a single chip, programmable, NMOS-LSI device which is designed to provide an interface for microcomputers to a large class of CRT character displays. The chip provides the display row buffering, raster timing, cursor timing, light pen detection and visual attribute decoding. It is programmable to a large number of different display formats. The controller can be interfaced to standard character generator ROMs for dot matrix decoding.
The controller can generate a screen format size of from 1 to 80 characters per row, 1 to 64 rows per screen and from 1 to 16 horizontal lines per character row.
The device has 7 character code address bits allowing 6 or 7 bit ASCII capability or can be used with other 7 bit codes to generate up to 128 characters.

## Hardware Description

The 8275 is Packaged in a 40 pin DIP. The following is a functional description of each pin.

| Pin Name | I/O | Description |
| :---: | :---: | :---: |
| $V_{c c}$ | - | +5 V power supply |
| GND | - | Ground |
| CCLK | 1 | Character Clock (from dot/timing logic) |
| $\mathrm{DB}_{7}-\mathrm{DB}_{0}$. | I/O | Bi -directional three-state data bus lines. The outputs are enabled during a read of the C or P ports. |
| $\overline{\mathrm{CS}}$ | 1 | Chip select. The read and write are enabled by $\overline{\mathrm{CS}}$. |
| $\overline{R D}$ | 1 | Read input. A control signal to read registers. |
| $\overline{W R}$ | 1 | Write input. A control signal to write commands into the control registers or write data into the row buffers during a DMA cycle. |
| $A_{0}$ | 1 | Port Address. A high input on Ao selects the " $C$ " port or command registers and a low input selects the "P" port or parameter registers. |
| INT | 0 | Interrupt request. |
| DRQ | 0 | DMA request. Output signal to the 8257 DMA controller requesting a DMA cycle. |
| $\overline{\text { DACK }}$ | 1 | DMA acknowledge. Input signal from the 8257 DMA controller acknowledging that the requested DMA cycle has been granted. |
| LPEN | 1 | Light pen. Input Signal from the CRT system signifying that a light pen signal has been detected. |
| HRTC | 0 | Horizontal retrace. Output signal which is active during the programmed horizontal retrace interval. During this period the VSP output is high and the LTEN output is low. |

## Pin Name I/O Description

VRTC $\quad 0 \quad$ Vertical retrace. Output signal which is active during the programmed vertical retrace interval. During this period the VSP output is high and the LTEN output is low.
LCo-LC3 O Line count. Output from the line counter which is used to address the character generator for the line positions on the screen.
CC0-CC6 O Character codes. Output from the row buffers used for character selection in the character generator.
GPAO, $\quad \mathrm{O}$ General purpose attribute codes. OutGPA1

LAO, LA1
O Line attribute codes. These attribute codes have to be decoded externally by the dot/timing logic to generate the horizontal and vertical line combinations for the graphic displays specified by the character attribute codes.
HLGT
O Highlight. Output signal used to intensify the display at particular positions on the screen as specified by the character attribute codes or field attribute codes.
RVV O Reverse video. Output signal used to indicate the CRT circuitry to reverse the video signal. This output is active at the cursor position if a reverse video block cursor is programmed or at the positions specified by the field attribute codes.
LTEN $O$ Light enable. Output signal used to enable the video signal to the CRT. This output is active at the programmed underline cursor position, and at positions specified by the character attribute codes during generation of graphics display.
VSP
O Video suppression. Output signal used to blank the video signal to the CRT. This output is active:

- during the horizontal and vertical retrace intervals.
- at the top and bottom lines of rows if the number of lines/row are greater than or equal to 9.
- when an end of row or end of screen code is detected.
- when a DMA underrun occurs.
- at regular intervals (1/16 frame frequency for cursor, 1/32 frame frequency for character and field attributes) -to create blinking displays as specified by cursor, character attribute, or field attribute programming.


## Principles of Operation

The basic elements of the CRT controller are the two row buffers ( $80 \times 8$ ), cursor position, light pen position, and visual attribute decode and control logic. The CRT controller is used with the DMA chip (8257) to provide the high speed controlling function of a CRT.
Two row buffers are utilized to provide display row refresh. Each buffer is alternately loaded from main memory and then used to provide characters to the external character generator and internal visual attribute decode logic during row display. Each buffer is loaded from main memory by DMA cycles which are requested by the CRT controller at programmable intervals. The controller can also be programmed to request a single DMA at a time or bursts of 2, 4, or 8 bytes.

## Raster Control and Timing

The raster logic provides the proper video scan timing for the CRT. The various parameters of the raster timing are programmable at controller reset. Raster timing is derived from the basic character interval clock which is provided to the controller from the external dot timing logic. The following count functions are performed by the raster logic:

Character Count
Horizontal Retrace Interval Count
Line Count
Row Count
Vertical Retrace Interval Count
Blink Timing

## Cursor

The cursor location is determined by the cursor line and character position registers which are loaded by command to the controller. The cursor can be programmed to appear on the display as 1) a blinking underline, 2) a blinking reverse video block, 3) a non-blinking underline, or 4) a non-blinking reverse video block.

## Light Pen

When the controller detects a light pen signal, the row and character position coordinates of the raster are stored in a pair of registers. On command to the controller, these registers can be read by the microprocessor. The registers are loaded on the 0-1 transition of the light pen input which is internally synchronized with the character clock. The horizontal address will be off three character positions (more if external delays are present) and has to be corrected in the software. In addition, the controller has a status flag to indicate that the light pen signal was detected.

## Visual Attributes

Visual attributes are generated and timed by the CRT controller without the intervention of the external character generator. They are actuated and controlled by special code combinations. These attribute codes can affect the display for just the character position in which they appear (character type) or they may affect a field of characters (field type).

## Field Attributes

The field attributes are control codes which will affect the visual characteristics for a field of characters starting at the character following the field attribute code up to the character which precedes the next field attribute code. A field attribute code does not have to occupy a display position. Any of the following field display can be independently selected for a field:

Blink
Highlight
Reverse Video
Underline

## Character Attributes

A character attribute generates a graphics symbol in the character position without the use of an external character generator. A character attribute is generated through the Line Attribute outputs together with the Video Suppress and Light Enable outputs. The external logic then can generate the proper symbol. Character attributes can be programmed to blink or be highlighted.

## Software Operation

The 8275 can accept commands from the CPU at any time to perform the CRT controlling functions. A command ( $A_{0}=1$ ) from the CPU to the 8275 chip may be followed by up to 4 bytes of parameters ( $\mathrm{A}_{0}=0$ ). The list of commands and their associated parameters are summarized below:

| C// $/ \overline{\mathbf{P}}$ | DB |  |
| :---: | :---: | :---: |
| 1 | $000 \times \times \times \times \mathrm{C}$ | RESET \& STOP DISPLAY |
| 0 | SHHHHHHH | SCREEN COMPOSITION \#1 |
| 0 | V VRRRRRR | SCREEN COMPOSITION \#2 |
| 0 | UUUULLLL | SCREEN COMPOSITION \#3 |
| 0 | D F C C Z Z Z Z | SCREEN COMPOSITION \#4 |
| 1 | 001 SSSBB | START DISPLAY |
| 1 | $010 \times \times \times \times \times$ | STOP DISPLAY |
| 1 | $011 \times \times \times \times \times$ | READ LIGHT PEN (*2 $\overline{\mathrm{RD}}$ ) |
| 1 | $100 \times \times \times \times \times$ | LOAD CURSOR POSITION |
| 0 | хccccccc | CURSOR X-POSITION |
| 0 | X X C C C Ccc | CURSOR Y-POSITION |
| 1 | $101 \times \times \times \times \mathrm{C}$ | ENABLE INTERRUPT |
| 1 | $110 \times \times \times \times \times$ | DISABLE INTERRUPT |



# 8279, 8279-5 <br> PROGRAMMABLE KEYBOARD/DISPLAY INTERFACE 

\author{

- MCS-85™ Compatible 8279-5 <br> - Simultaneous Keyboard Display Operations <br> - Scanned Keyboard Mode <br> - Scanned Sensor Mode <br> - Strobed Input Entry Mode <br> - 8 Character Keyboard FIFO <br> \section*{- 2 Key Lockout or N Key Rollover with Contact Debounce}
}

■ Dual 8 or 16 Numerical Display<br>- Single 16 Character Display<br>■ Right or Left Entry 16 Byte Display RAM<br>- Mode Programmable from CPU<br>- Programmable Scan Timing<br>- Interrupt Oputput on Key Entry

The 8279 is a general purpose programmable keyboard and display I/O interface device designed for use with Intel® microprocessors. The keyboard portion can provide a scanned interface to a 64 contact key matrix which can be expanded to 128. The keyboard portion will also interface to an array of sensors or a strobed interface keyboard, such as the Hall effect and Ferrite variety. Key depressions can be 2 key lockout or $N$ key rollover. Keyboard entries are debounced and strobed in an 8 character FIFO. If more than 8 characters are entered, over run status is set. Key entries set the interrupt output line to the CPU.
The display portion provides a scanned display interface for LED, incandescent and other popular display technologies. Both numeric and alphanumeric segment displays may be used as well as simple indicators. The 8279 has a $16 \times 8$ display RAM which can be organized into a dual $16 \times 4$. The RAM can be loaded or interrogated by the CPU. Both right entry, calculator and left entry typewriter display formats are possible. Both read and write of the display RAM can be done with auto-increment of the display RAM address.

## PIN CONFIGURATION




## 8279 BASIC FUNCTIONAL DESCRIPTION

## Introduction

Since data input and display are an integral part of many microprocessor designs, the system designer needs an interface that can control these functions without placing a large load on the CPU. The 8279 provides this function for 8-bit microprocessors.
The 8279 has two sections: keyboard and display. The keyboard section can interface to regular typewriter style keyboards or random toggle or thumb switches. The display section drives alphanumeric displays or a bank of indicator lights. Thus the CPU is relieved from scanning the keyboard or refreshing the display.
The 8279 is designed to directly connect to the microprocessor bus. The CPU can program all operating modes for the 8279. These modes include:

## Input Modes

- Scanned Keyboard - with encoded ( $8 \times 8 \times 4$ key keyboard) or decoded ( $4 \times 8 \times 4$ key keyboard) scan lines. A key depression generates a 6-bit encoding of key position. Position and shift and control status are stored in the FIFO. Keys are automatically debounced with 2-key lockout or N-key rollover.
- Scanned Sensor Matrix - with encoded ( $8 \times 8$ matrix switches) or decoded ( $4 \times 8$ matrix switches) scan lines. Key status (open or closed) stored in RAM addressable by CPU.
- Strobed Input - Data on return lines during control line strobe is transferred to FIFO.


## Output Modes

- 8 or 16 character multiplexed displays that can be organized as dual 4-bit or single 8-bit.
- Right entry or left entry display formats.

Other features of the 8279 include:

- Mode programming from the CPU.
- Programmable clock to match the 8279 scan times to the CPU cycle time.
- Interrupt output to signal CPU when there is keyboard or sensor data available.
- An 8 byte FIFO to store keyboard information.
- 16 byte internal Display RAM for display refresh. This RAM can also be read by the CPU.



## Hardware Description

The 8279 is packaged in a 40 pin DIP. The following is a functional description of each pin.

| No. Of Pins | Designation | Function |
| :---: | :---: | :---: |
| 8 | $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ | Bi -directional data bus. All data and commands between the CPU and the 8279 are transmitted on these lines. |
| 1 | CLK | Clock from system used to generate internal timing. |
| 1 | RESET | A high signal on this pin resets the 8279. |
| 1 | $\overline{\mathrm{CS}}$ | Chip Select. A low on this pin enables the interface functions to receive or transmit. |
| 1 | A0 | Buffer Address. A high on this line indicates the signals in or out are interpreted as a command or status. A low indicates that they are data. |
| 2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | Input/Output read and write. These signals enable the data buffers to either send data to the external bus or receive it from the external bus. |
| 1 | IRQ | Interrupt Request. In a keyboard mode, the interrupt line is high when there is data in the FIFO/ Sensor RAM. The interrupt line goes low with each FIFO/ Sensor RAM read and returns high if there is still information in the RAM. In a sensor mode, the interrupt line goes high whenever a change in a sensor is detected. |
| 2 | $\mathrm{V}_{\mathrm{SS}}, \mathrm{V}_{\text {cc }}$ | Ground and power supply pins. |
| 4 | SLo-SL3 | Scan Lines which are used to scan the key switch or sensor matrix and the display digits. These lines can be either encoded (1 of 16) or decoded (1 of 4). |
| 8 | RLo-RL7 | Return line inputs which are connected to the scan lines through the keys or sensor switches. They have active internal pullups to keep them high until a switch closure pulls one low. They also serve as an 8-bit input in the Strobed Input mode. |
| 1 | SHIFT | The shift input status is stored along with the key position on key closure in the Scanned |

$\begin{array}{ll}\text { No. Of } \\ \text { Pins } & \text { Designation Function }\end{array}$
Keyboard modes. It has an active internal pullup to keep it high until a switch closure pulls it low.
$1 \mathrm{CNTL} / \mathrm{STB}$
For keyboard modes this line is used as a control input and stored like status on a key closure. The line is also the strobe line that enters the data into the FIFO in the Strobed Input mode. (Rising Edge). It has an active internal pullup to keep it high until a switch closure pulls it low.
4 OUT A0-OUT A3 These two ports are the outputs
4 OUT $B_{0}$-OUT $B_{3}$ for the $16 \times 4$ display refresh registers. The data from these outputs is synchronized to the scan lines ( $\mathrm{SLO}_{0}-\mathrm{SL}_{3}$ ) for multiplexed digit displays. The two 4 bit ports may be blanked independently. These two ports may also be considered as one 8 bit port.
Blank Display. This output is used to blank the display during digit switching or by a display blanking command.

## Principles of Operation

The following is a description of the major elements of the 8279 Programmable Keyboard/Display interface device. Refer to the block diagram in Figure 1.

## I/O Control and Data Buffers

The I/O control section uses the $\overline{C S}, A_{0}, \overline{R D}$ and $\overline{W R}$ lines to control data flow to and from the various internal registers and buffers. All data flow to and from the 8279 is enabled by $\overline{\mathrm{CS}}$. The character of the information, given or desired by the CPU, is identified by Ao. A logic one means the information is a command or status. A logic zero means the information is data. $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ determine the direction of data flow through the Data Buffers. The Data Buffers are bi-directional buffers that connect the internal bus to the external bus. When the chip is not selected ( $\overline{C S}=1$ ), the devices are in a high impedance state. The drivers input during WR $\bullet \overline{\mathrm{CS}}$ and output during RD $\cdot \overline{\mathrm{CS}}$.

## Control and Timing Registers and Timing Control

These registers store the keyboard and display modes and other operating conditions programmed by the CPU. The modes are programmed by presenting the proper command on the data lines with $\mathrm{A}_{0}=1$ and then sending $a \overline{W R}$. The command is latched on the rising edge of $\overline{W R}$.

The command is then decoded and the appropriate function is set. The timing control contains the basic timing counter chain. The first counter is a $\div \mathrm{N}$ prescaler that can be programmed to match the CPU cycle time to the internal timing. The prescaler is software programmed to a value between 2 and 31. A value which yields an internal frequency of 100 kHz gives a 5.1 ms keyboard scan time and a 10.3 ms debounce time. The other counters divide down the basic internal frequency to provide the proper key scan, row scan, keyboard matrix scan, and display scan times.

## Scan Counter

The scan counter has two modes. In the encoded mode, the counter provides a binary count that must be externally decoded to provide the scan lines for the keyboard and display. In the decoded mode, the scan counter decodes the least significant 2 bits and provides a decoded 1 of 4 scan. Note than when the keyboard is in decoded scan, so is the display. This means that only the first 4 characters in the Display RAM are displayed.
In the encoded mode, the scan lines are active high outputs. In the decoded mode, the scan lines are active low outputs.

## Return Buffers and Keyboard Debounce and Control

The 8 return lines are buffered and latched by the Return Buffers. In the keyboard mode, these lines are scanned, looking for key closures in that row. If the debounce circuit detects a closed switch, it waits about 10 msec to check if the switch remains closed. If it does, the address of the switch in the matrix plus the status of SHIFT and CONTROL are transferred to the FIFO. In the scanned Sensor Matrix modes, the contents of the return lines is directly transferred to the corresponding row of the Sensor RAM (FIFO) each key scan time. In Strobed Input mode, the contents of the return lines are transferred to the FIFO on the rising edge of the CNTL/STB line pulse.

## FIFO/Sensor RAM and Status

This block is a dual function $8 \times 8$ RAM. In Keyboard or Strobed Input modes, it is a FIFO. Each new entry is written into successive RAM positions and each is then read in order of entry. FIFO status keeps track of the number of characters in the FIFO and whether it is full or empty. Too many reads or writes will be recognized as an error. The status can be read by an RD with $\overline{\mathrm{CS}}$ low and Ao high. The status logic also provides an IRQ signal when the FIFO is not empty. In Scanned Sensor Matrix mode, the memory is a Sensor RAM. Each row of the Sensor RAM is loaded with the status of the corresponding row of sensor in the sensor matrix. In this mode, IRQ is high if a change in a sensor is detected.

## Display Address Registers and Display RAM

The Display Address Registers hold the address of the word currently being written or read by the CPU and the two 4-bit nibbles being displayed. The read/write addresses are programmed by CPU command. They also can be set to auto increment after each read or write. The Display RAM can be directly read by the CPU after the correct mode and address is set. The addresses for the A and $B$ nibbles are automatically updated by the 8279 to match data entry by the CPU. The $A$ and $B$ nibbles can be entered independently or as one word, according to the mode that is set by the CPU. Data entry to the display can be set to either left or right entry. See Interface Considerations for details.

## Software Operation

## 8279 Commands

The following commands program the 8279 operating modes. The commands are sent on the Data Bus with $\overline{\mathrm{CS}}$ low and $A_{0}$ high and are loaded to the 8279 on the rising edge of $\overline{W R}$.

## Keyboard/Display Mode Set

| MSB |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Code: |  |  |  |  |  |  |  |
| 0 0 0 L D K K K |  |  |  |  |  |  |  |

Where DD is the Display Mode and KKK is the Keyboard Mode.

DD
0 0 8-bit character display - Left entry
01168 -bit character display - Left entry*
1088 -bit character display - Right entry
116 8-bit character display - Right entry
For description of right and left entry, see Interface Considerations. Note that when decoded scan is set in keyboard mode, the display is reduced to 4 characters independent of display mode set.

## KKK

000 Encoded Scan Keyboard - 2 Key Lockout
$0 \quad 0 \quad 1$ Decoded Scan Keyboard - 2-Key Lockout
010 Encoded Scan Keyboard - N-Key Rollover
$\begin{array}{llll}0 & 1 & 1 & \text { Decoded Scan Keyboard - N-Key Rollover }\end{array}$
100 Encoded Scan Sensor Matrix
101 Decoded Scan Sensor Matrix
$1 \begin{array}{llll}1 & 1 & 0 & \text { Strobed Input, Encoded Display Scan }\end{array}$
$\begin{array}{lll}1 & 1 & 1\end{array}$ Strobed Input, Decoded Display Scan
Program Clock

Code: $\quad$| $\mathbf{0}$ | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{P}$ | $\mathbf{P}$ | $\mathbf{P}$ | $\mathbf{P}$ | $\mathbf{P}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Where PPPPP is the prescaler value 2 to 31 . The programmable prescaler divides the external clock by PPPPP to get the basic internal frequency. Choosing a divisor that yields 100 KHz will give the specified scan and debounce times. Default after a reset pulse (but not a program clear) is 31.

## Read FIFO/Sensor RAM

Code: | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{0}$ | AI | X | A | A | A |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| X | $\mathrm{X}=$ Don't Care |  |  |  |  |  |  |

Where $A 1$ is the Auto-Increment flag for the Sensor RAM and AAA is the row that is going to be read by the CPU. AI and AAA are used only if the mode is set to Sensor Matrix. This command is used to specify that the source of data reads ( $\overline{\mathrm{CS}} \bullet \mathrm{RD} \bullet \overline{\mathrm{A}_{0}}$ ) by the CPU is the FIFO/Sensor RAM. No additional commands are necessary as long as *Default after reset.
data is desired from the FIFO/Sensor RAM. Another command is necessary if reading is desired from a different row than has been selected. If Al is a one, the row select counter will be incremented after each read so the next read will be from the next Sensor RAM row.

In the Auto Increment mode for reading data from the FIFO/Sensor RAM, each read advances the address by one so that the next read is from the next character. This Auto Incrementing has no effect on the display.

## Read Display RAM

Code:

| 0 | 1 | 1 | $A I$ | $A$ | $A$ | $A$ | $A$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Where $A 1$ is the Auto-Increment flag for the Display RAM and AAAA is the character that the CPU is going to read next. Since the CPU uses the same counter for reading and writing, this command also sets the next write location and Auto-Increment mode. This command is used to specify the display RAM as the data source for CPU data reads. If Al is set, the character address will be incremented after each read (or write) so that the next read (or write) will be from (to) the next character.

## Write Display RAM

Code:


Where $A I$ is the Auto-Increment flag for the Display RAM and AAAA is the character that the CPU is going to write next. The addressing and Auto-Increment are identical to Read Display RAM. The difference is that Write Display RAM does not affect the source of CPU reads. The CPU will read from whichever RAM (Display or FIFO/Sensor) was last specified. This command will, however, change the location the next Display RAM read will be from if that source was specified.

## Display Write Inhibit/Blanking

Code:


Where IW is Inhibit Writing (nibble A or B) and BL is Blanking (nibble A or B). If the display is being used as a dual 4-bit display, then it is necessary to mask one of the 4bit halves so that entries to the Display from the CPU do not affect the other half. The IW flags allow the programmer to do this. It is also useful to be able to blank either half when that half is not to be displayed. The BL flags blank the display. The next command sets the output code to be used as a "blank". Default after reset is all zeros. Note that to blank a display formatted as a single 8-bit output, it is necessary to set both BL flags to entirely blank the display. A "1" sets the flag. Reissuing the command with a " 0 " resets the flag.

## Clear

Code:


Where $C_{D}$ is Clear Display, $C_{F}$ is Clear FIFO Status (including interrupt), and $C_{A}$ is Clear All. $C_{D}$ is used to
clear all positions of the Display RAM to a programmable code. All ones, all zeros and hexadecimal 20 are possitble.


Clearing the display takes one display scan. During this time the CPU cannot write to the Display RAM. The MSB of the FIFO status word will be set during this time.
$C_{F}$ set the FIFO status to empty and resets the interrupt output line. After execution of a clear command with $\mathrm{C}_{\mathrm{F}}$ set, the Sensor Matrix mode RAM pointer will be set to row 0.
$C_{A}$ has the combined effect of $C_{D}$ and $C_{F} . C_{A}$ uses the $C_{D}$ clearing code to determine how to clear the Display RAM. $C_{A}$ also resets the internal timing chain to resynchronize it.

## End Interrupt/Error Mode Set

Code: $\quad$| 1 | 1 | 1 | $E$ | $X$ | $X$ | $X$ | $X$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |$\quad X=$ Don't care.

For the sensor matrix modes this command lowers the IRQ line and enables further writing into RAM. (The IRQ line would have been raised upon the detection of a change in a sensor value. This would have also inhibited further writing into the RAM until reset).

For the N -key rollover mode - if the E bit is programmed to "1" the chip will operate in the special Error mode. (For further details, see Interface Considerations Section.)

## Status Word

The status word contains the FIFO status, error, and display unavailable signals. This word is read by the CPU when $A_{0}$ is high and $\overline{\mathrm{CS}}$ and $\overline{\mathrm{RD}}$ are low. See Interface Considerations for more detail on status word.

## Data Read

Data is read when $A_{0}, \overline{C S}$ and $\overline{R D}$ are all low. The source of the data is specified by the Read FIFO or Read Display commands. The trailing edge of $\overline{R D}$ will cause the address of the RAM being read to be incremented if the AutoIncrement flag is set. FIFO reads always increment (if no error occurs) independent of AI.

## Data Write

Data that is written with $A_{0}, \overline{C S}$ and $\overline{W R}$ low is always written to the Display RAM. The address is specified by the latest Read Display or Write Display command. AutoIncrementing on the rising edge of WR occurs if AI set by the latest display command.

## INTERFACE CONSIDERATIONS

## A. Scanned Keyboard Mode, 2-Key Lockout

There are three possible combinations of conditions that can occur during debounce scanning. When a key is depressed, the debounce logic is set. A full scan of the keyboard is ignored, then other depressed keys are looked for. If none are encountered, it is a single key depression and the key position is entered into the FIFO along with the status of CNTL and SHIFT lines. If the FIFO was empty, IRQ will be set to signal the CPU that there is an entry in the FIFO. If the FIFO was full, the key will not be entered and the error flag will be set. If another closed switch is encountered, no entry to the FIFO can occur. If all other keys are released before this one, then it will be entered to the FIFO. If this key is released before any other, it will be entirely ignored. A key is entered to the FIFO only once per depression, no matter how many keys were pressed along with it or in what order they were released. If two keys are depressed within the debounce cycle, it is a simultaneous depression. Neither key will be recognized until one key remains depressed alone. The last key will be treated as a single key depression.

## B. Scanned Keyboard Mode, N-Key Rollover

With N-key Rollover each key depression is treated independently from all others. When a key is depressed, the debounce circuit waits 2 keyboard scans and then checks to see if the key is still down. If it is, the key is entered into the FIFO. Any number of keys can be depressed and another can be recognized and entered into the FIFO. If a simultaneous depression occurs, the keys are recognized and entered according to the order the keyboard scan found them.

## C. Scanned Keyboard - Special Error Modes

For N -key rollover mode the user can program a special error mode. This is done by the "End Interrupt/Error Mode Set" command. The debounce cycle and key-validity check are as in normal N-key mode. If during a single debounce cycle, two keys are found depressed, this is considered a simultaneous multiple depression, and sets an error flag. This flag will prevent any further writing into the FIFO and will set interrupt (if not yet set). The error flag could be read in this mode by reading the FIFO STATUS word. (See "FIFO STATUS" for further details.) The error flag is reset by sending the normal CLEAR command with $C F=1$.

## D. Sensor Matrix Mode

In Sensor Matrix mode, the debounce logic is inhibited. The status of the sensor switch is inputted directly to the Sensor RAM. In this way the Sensor RAM keeps an image of the state of the switches in the sensor matrix. Although debouncing is not provided, this mode has the advantage that the CPU knows how long the sensor was closed and when it was released. A keyboard mode can only indicate a validated closure. To make the software easier, the designer should functionally group the sensors by row since this is the format in which the CPU will read them. The IRQ line goes high if any sensor value change is detected at the end of a sensor matrix scan. The IRQ line is cleared by the first data read operation if the Auto-

Increment flag is set to zero, or by the End Interrupt
command if the Auto-Increment flag is set to one.
Note: Multiple changes in the matrix Addressed by (SLo-3 $=0$ ) may cause multiple interrupts. ( $S_{0}=0$ in the Decoded Mode). Reset may cause the 8279 to see multiple changes.

## E. Data Format

In the Scanned Keyboard mode, the character entered into the FIFO corresponds to the position of the switch in the keyboard plus the status of the CNTL and SHIFT lines. CNTL is the MSB of the character and SHIFT is the next most significant bit. The next three bits are from the scan counter and indicate the row the key was found in. The last three bits are from the column counter and indicate to which return line the key was connected.


In Sensor Matrix mode, the data on the return lines is entered directly in the row of the Sensor RAM that corresponds to the row in the matrix being scanned. Therefore, each switch postion maps directly to a Sensor RAM position. The SHIFT and CNTL inputs are ignored in this mode. Note that switches are not necessarily the only thing that can be connected to the return lines in this mode. Any logic that can be triggered by the scan lines can enter data to the return line inputs. Eight multiplexed input ports could be tied to the return lines and scanned by the 8279.


In Strobed Input mode, the data is also entered to the FIFO from the return lines. The data is entered by the rising edge of a CNTL/STB line pulse. Data can come from another encoded keyboard or simple switch matrix. The return lines can also be used as a general purpose strobed input.

\[

\]

## F. Display

## Left Entry

Left Entry mode is the simplest display format in that each display position directly corresponds to a byte (or nibble) in the Display RAM. Address 0 in the RAM is the left-most display character and address 15 (or address 7 in 8 character display) is the right most display character. Entering characters from position zero causes the display to fill from the left. The 17th (9th) character is entered back in the left most position and filling again proceeds from there.


Right Entry
Right entry is the method used by most electronic calculators. The first entry is placed in the right most display character. The next entry is also placed in the right most character after the display is shifted left one character. The left most character is shifted off the end and is lost.


Note that now the display position and register address do not correspond. Consequently, entering a character to an arbitrary position in the Auto Increment mode may have unexpected results. Entry starting at Display RAM address 0 with sequential entry is recommended.

## Auto Increment

In the Left Entry mode, Auto Incrementing causes the address where the CPU will next write to be incremented by one and the character appears in the next location. With non-Auto Incrementing the entry is both to the same RAM address and display position. Entry to an arbitrary address in the Auto Increment mode has no undesirable side effects and the result is predictable:

1st entry
 Address


Enter next at Location 5 Auto Increment


## LEFT ENTRY MODE (AUTO INCREMENT)

In the Right Entry mode, Auto Incrementing and non Incrementing have the same effect as in the Left Entry except if the address sequence is interrupted:


RIGHT ENTRY MODE (AUTO INCREMENT)
Starting at an arbitrary location operates as shown below:


RIGHT ENTRY MODE (AUTO INCREMENT)

Entry appears to be from the initial entry point.

## 8/16 Character Display Formats

If the display mode is set to an 8 character display, the on duty-cycle is double what it would be for a 16 character display (e.g., 5.1 ms scan time for 8 characters vs. 10.3 ms for 16 characters with 100 kHz internal frequency).

## G. FIFO Status

FIFO status is used in the Keyboard and Strobed Input modes to indicate the number of characters in the FIFO and to indicate whether an error has occurred. There are two types of errors possible: overrun and underrun. Overrun occurs when the entry of another character into a full FIFO is attempted. Underrun occurs when the CPU tries to read an empty FIFO.

The FIFO status word also has a bit to indicate that the Display RAM was unavailable because a Clear Display or Clear All command had not completed its clearing operation.

In a Sensor Matrix mode, a bit is set in the FlFO status word to indicate that at least one sensor closure indication is contained in the Sensor RAM.

In Special Error Mode the S/E bit is showing the error flag and serves as an indication to whether a simultaneous multiple closure error has occurred.


## APPLICATIONS



FIGURE 2. GENERAL BLOCK DIAGRAM

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Voltage on any Pin with
Respect to Ground . . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*COMMENT: Stresses above those listed under"Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional opera. tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, $\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$, Note 1

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {ILI }}$ | Input Low Voltage for Shift Control and Return Lines | -0.5 | 1.4 | V |  |
| $V_{\text {IL2 }}$ | Input Low Voltage for All Others | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{1+1}$ | Input High Voltage for Shift, Control and Return Lines | 2.2 |  | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | Input High Voltage for All Others | 2.0 |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | Note 2 |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage on Interrupt Line | 3.5 |  | V | Note 3 |
| IIL1 | Input Current on Shift, Control and Return Lines |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=V_{C C} \\ & V_{\text {IN }}=0 V \end{aligned}$ |
| IIL2 | Input Leakage Current on All Others |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\text {CC }}$ to 0 V |
| IOFL | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ to 0 V |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 120 | mA |  |

Notes:

1. $8279, V_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$; $8279-5, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$.
2. $8279, \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} ; 8279-5, \mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$.
3. $8279, \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} ; 8279-5, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.

## CAPACITANCE

| SYMBOL | TEST | TYP. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\text {in }}$ | Input Capacitance | 5 | 10 | pF | $\mathrm{V}_{\text {in }}=\mathrm{V}_{\text {CC }}$ |
| $\mathrm{C}_{\text {out }}$ | Output Capacitance | 10 | 20 | pF | $\mathrm{V}_{\text {out }}=\mathrm{V}_{\mathrm{CC}}$ |

## A.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$, (Note 1 )
BUS PARAMETERS


READ CYCLE:

| Symbol | Parameter | 8279 |  | 8279-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {AR }}$ | Address Stable Before $\overline{\mathrm{READ}}$ | 50 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RA}}$ | Address Hold Time for READ | 5 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\text { READ Pulse Width }}$ | 420 |  | 250 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}{ }^{[2]}$ | Data Delay from $\overline{\text { READ }}$ |  | 300 |  | 150 | ns |
| $\mathrm{t}_{\text {AD }}{ }^{[2]}$ | Address to Data Valid |  | 450 |  | 250 | ns |
| $t_{\text {dF }}$ | $\overline{\text { READ }}$ to Data Floating | 10 | 100 | 10 | 100 | ns |
| $\mathrm{t}_{\mathrm{RCY}}$ | Read Cycle Time | 1 |  | 1 |  | $\mu \mathrm{s}$ |

WRITE CYCLE:

| Symbol | Parameter | 8279 |  | 8279-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {taw }}$ | Address Stable Before WRITE | 50 |  | 0 |  | ns |
| $t_{\text {WA }}$ | Address Hold Time for $\overline{\text { WRITE }}$ | 20 |  | 0 |  | ns |
| ${ }^{\text {tww }}$ | WRITE Pulse Width | 400 |  | 250 |  | ns |
| ${ }^{\text {d }}$ W | Data Set Up Time for $\overline{\text { WRITE }}$ | 300 |  | 150 |  | ns |
| ${ }^{\text {w }}$ W | Data Hold Time for WRITE | 40 |  | 0 |  | ns |

Notes:

1. $8279, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \% ; 8279-5, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$.
2. $8279, C_{L}=100 \mathrm{pF} ; 8279-5, C_{L}=150 \mathrm{pF}$.

## OTHER TIMINGS:

|  |  | 8279 |  | $8279-5$ |  |
| :---: | :--- | :--- | :--- | :--- | :---: |
| Symbol | Parameter | Min. $\quad$ Max. | Min. $\quad$ Max. | Unit |  |
| $\mathrm{t}_{\phi \mathrm{W}}$ | Clock Pulse Width | 230 | 120 | nsec |  |
| $\mathrm{t}_{\mathrm{C} Y}$ | Clock Period | 500 | 320 | nsec |  |

Keyboard Scan Time: Keyboard Debounce Time:
Key Scan Time:
Display Scan Time:
5.1 msec
10.3 msec
$80 \mu \mathrm{sec}$
10.3 msec

Digit-on Time:
$480 \mu \mathrm{sec}$
Blanking Time:
Internal Clock Cycle:
$160 \mu \mathrm{sec}$
$10 \mu \mathrm{sec}$

## INPUT WAVEFORMS FOR A.C. TESTS:



## WAVEFORMS

## 1. Read Operation


2. Write Operation


## 3. Clock Input



## MEMORY and I/O EXPANDERS FOR MCS-85"

## MEMORY and I/O EXPANDERS FOR MCS-85

8155/8156 2048-Bit Static MOS RAM with I/O Ports and Timer ..... 6-307
8355 16,384-Bit ROM with I/O ..... 6-319
8755 16,384-Bit EPROM with I/O ..... 6-326

## 8155/8156

## 2048 BIT STATIC MOS RAM WITH I/O PORTS AND TIMER

## 8155 - Active Low Chip Enable ( $\overline{\mathrm{CE}}$ ) <br> 8156 - Active High Chip Enable (CE)

## *Directly Compatible With 8085 CPU

- 256 Word x 8 Bits
- Single +5 V Power Supply
- Completely Static Operation
- Internal Address Latch
- 2 Programmable 8 Bit I/O Ports
- 1 Programmable 6 Bit I/O Port
- Programmable 14 Bit Binary Counter/ Timer
- Multiplexed Address and Data Bus
- 40 Pin DIP

The 8155 and 8156 are RAM and I/O chips to be used in the MCS- $85^{\text {TM }}$ microcomputer system. The RAM portion is designed with 2 K bit static cells organized as $256 \times 8$. They have a maximum access time of 400 ns to permit use with no wait states in 8085 CPU.
The I/O portion consists of three general purpose I/O ports. One of the three ports can be programmed to be status pins, thus allowing the other two ports to operate in handshake mode.
A 14 bit programmable counter/timer is also included on chip to provide either a square wave or terminal count pulse for the CPU system. It operates in binary countdown mode, and its timer modes are programmable.

PIN CONFIGURATION


BLOCK DIAGRAM


* : $8155=\overline{\mathrm{CE}}, 8156=\mathrm{CE}$


## 8155/8156 FUNCTIONAL PIN DEFINITION

The following describes the functions of all of the $8155 / 8156$ pins.

| Symbol | Function |
| :---: | :---: |
| RESET | The Reset signal is a pulse provided by the 8085 to initialize the system. Input high on this line resets the chip and initializes the three I/O ports to input mode. The width of RESET pulse should typically be 600 nsec . (Two 8085 clock cycle times). |
| $A D_{0-7}$ | These are 3-state Address/Data lines that interface with the CPU lower 8bit Address/Data Bus. The 8 -bit address is latched into the address latch on the falling edge of the ALE. The address can be either for the memory section or the I/O section depending on the polarity of the $1 O / \bar{M}$ input signal. The 8 -bit data is either written into the chip or Read from the chip depending on the status of $\overline{\text { WRITE or }} \overline{\text { READ }}$ input signal. |
| CE or $\overline{C E}$ | Chip Enable: On the 8155, this pin is $\overline{C E}$ and is ACTIVE LOW. On the 8156 , this pin is CE and is ACTIVE HIGH. |
| $\overline{\mathrm{RD}}$ | Input low on this line with the Chip Enable active enables the $A D_{0-7}$ buffers. If $10 / \bar{M}$ pin is low, the RAM content will be read out to the AD bus. Otherwise the content of the selected I/O port will be read to the AD bus. |
| $\overline{W R}$ | Input low on this line with the Chip Enable active causes the data on the AD lines to be written to the RAM or I/O ports depending on the polarity of $10 / \bar{M}$. |
| ALE | Address Latch Enable: This control signal latches both the address on the $A D_{0-7}$ lines and the state of the Chip Enable and $10 / \bar{M}$ into the chip at the falling edge of ALE. |
| $10 / \bar{M}$ | 10/Memory Select: This line selects the memory if low and selects the IO if high. |


| Symbol | Function |
| :---: | :---: |
| $\mathrm{PA}_{0-7}(8)$ | These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the Command Status Register. |
| $\mathrm{PB}_{0-7}(8)$ | These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the Command/ Status Register. |
| $\mathrm{PC}_{0-5}(6)$ | These 6 pins can function as either input port, output port, or as control signals for PA and PB. Programming is done through the C/S Register. When $\mathrm{PC}_{0-5}$ are used as control signals, they will provide the following: |
|  | PCo - A INTR (Port A Interrupt) PC1 - A BF (Port A Buffer full) |
|  | PC2 - $\overline{\mathrm{ASTB}}$ (Port A Strobe) |
|  | $\begin{aligned} & \text { PC3 - B INTR (Port B Interrupt) } \\ & \text { PC4 - B BF (Port B Buffer Full) } \\ & \text { PC5 - B STB (Port B Strobe) } \end{aligned}$ |
| TIMER IN | This is the input to the counter timer. |
| TIMER OUT | This pin is the timer output. This output can be either a square wave or a pulse depending on the timer mode. |
| $\mathrm{V}_{\mathrm{CC}}$ | +5 volt supply. |
| $\mathrm{V}_{\text {SS }}$ | Ground Reference. |

These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the Command/ Status Register.
These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the Command/ Status Register.
These 6 pins can function as either input port, output port, or as control ignals for PA and PB. Programming When PC 0 are signals, they will provide the follow ing:

PC1 - A BF (Port A Buffer full)
PC2 - $\overline{\text { A STB }}$ (Port A Strobe)
PC3 - B INTR (Port B Interrupt)
PC4 - B BF (Port B Buffer Full)
PC5 - B STB (Port B Strobe)
This is the input to the counter timer.
This pin is the timer output. This outputcan be either a square wave or
+5 volt supply.

Ground Reference.

## OPERATIONAL DESCRIPTION

The 8155/8156 includes the following operational features:

- 2 K Bit Static RAM organized as $256 \times 8$
- Two 8-bit I/O ports (PA \& PB) and one 6-bit I/O port (PC)
- 14-bit binary down counter

The I/O portion contains four registers (Command/ Status, $\mathrm{PA}_{0-7}, \mathrm{~PB}_{0-7}, \mathrm{PC}_{0-5}$ ). The $1 \mathrm{O} / \mathrm{M}$ (IO/Memory Select) pin selects the I/O or the memory (RAM) portion. Detailed descriptions of memory, I/O ports and timer functions will follow.

The 8-bit address on the AD lines, the Chip Enable input, and $I O / \bar{M}$ are all latched on chip at the falling edge of ALE. A low on the IO/ $\bar{M}$ must be provided to select the memory section.


NOTE: FOR DETAILED TIMING DIAGRAM INFORMATION, SEE FIGURE 7 AND A.C. CHARACTERISTICS.

FIGURE 1. MEMORY READ/WRITE CYCLE.

## PROGRAMMING OF THE COMMAND/ STATUS REGISTER

The command register consists of eight latches one for each bit. Four bits ( $0-3$ ) define the mode of the ports, two bits (4-5) enable or disable the interrupt from port $C$ when it acts as control port, and the last two bits (6-7) are for the timer.
The C/S register contents can be altered at any time by using the I/O address XXXXX000 during a WRITE operation. The meaning of each bit of the command byte is defined as follows:


FIGURE 2. COMMAND/STATUS REGISTER BIT ASSIGNMENT.

## READING THE COMMAND/STATUS REGISTER

The status register consists of seven latches one for each bit; six (0-5) for the status of the ports and one (6) for the status of the timer.
The status of the timer and the I/O section can be polled by reading the C/S Register (Address XXXXX000). Status word format is shown below:


FIGURE 3. COMMAND/STATUS REGISTER STATUS WORD FORMAT.

## INPUT/OUTPUT SECTION

The I/O section of the 8155/8156 consists of four registers as described below.

- Command/Status Register (C/S) - This register is assigned the address XXXXXOOO. The C/S address serves the dual purpose.
When the C/S register is selected during WRITE operation, a command is written into the command register. The contents of this register are not accessible through the pins.
When the C/S (XXXXX000) is selected during a READ operation, the status information of the I/O ports and the timer become available on the $A D_{0-7}$ lines.
- PA Register - This register can be programmed to be either input or output ports depending on the status of the contents of the C/S Register. Also depending on the command, this port can operate in either the basic mode or the strobed mode (See timing diagram). The I/O pins assigned in relation to this register are $\mathrm{PA}_{0-7}$. The address of this register is XXXXX001.
- PB Register - This register functions the same as PA Register. The $\mathrm{I} / \mathrm{O}$ pins assigned are $\mathrm{PB}_{0-7}$. The address of this register is $\mathrm{XXXXX010}$.
- PC Register - This register has the address XXXXX011 and contains only 6 -bits. The 6 -bits can be programmed to be either input ports, output ports or as control signals for $P A$ and $P B$ by properly programming the $A D_{2}$ and $A D_{3}$ bits of the $C / S$ register.
When $\mathrm{PC}_{0-5}$ is used as a control port, 3-bits are assigned for Port A and 3 for Port B. The first bit is an interrupt that the 8155 sends out. The second is an output signal indicating whether the buffer is full or empty, and the third is an input pin to accept a strobe for the strobed input mode. See Table 1.
When the ' $C$ ' port is programmed to either ALT3 or ALT4, the control signals for PA and PB are initialized as follows:

The following diagram shows how I/O PORTS A and $B$ are structured within the 8155 and 8156 :

8155/8156
ONE BIT OF PORT A OR PORT B


Note in the diagram that when the I/O ports are programmed to be output ports, the contents of the output ports can still be read by a READ operation when appropriately addressed.
Note also that the output latch is cleared when the port enters the input mode. The output latch cannot be loaded by writing to the port if the port is in the input mode. The result is that each time a port mode is changed from input to output, the output pins will go low. When the $8155 / 56$ is RESET, the output latches are all cleared and all 3 ports enter the input mode.
When in the ALT 1 or ALT 2 modes, the bits of PORT C are structured like the diagram above in the simple input or output mode, respectively.
Reading from an input port with nothing connected to the pins will provide unpredictable results.

| CONTROL | INPUT MODE | OUTPUT MODE |
| :---: | :---: | :---: |
| BF | Low | Low |
| $\frac{\text { INTR }}{\text { High }}$ |  |  |
| STB | Low | Input Control |$\quad$ Input Control |  |
| :---: |

TABLE 1. TABLE OF PORT CONTROL ASSIGNMENT.

| Pin | ALT 1 | ALT 2 | ALT 3 | ALT 4 |
| :---: | :---: | :---: | :---: | :---: |
| PC0 | Input Port | Output Port | A INTR (Port A Interrupt) | A INTR (Port A Interrupt) |
| PC1 | Input Port | Output Port | A BF (Port A Buffer Full) | A BF (Port A Buffer Full) |
| PC2 | Input Port | Output Port | A STB (Port A Strobe) | A STB (Port A Strobe) |
| PC3 | Input Port | Output Port | Output Port | B INTR (Port B Interrupt) |
| PC4 | Input Port | Output Port | Output Port | B BF (Port B Buffer Full) |
| PC5 | Input Port | Output Port | Output Port | B STB (Port B Strobe) |

The set and reset of INTR and BF with respect to $\overline{S T B}, \overline{W R}$ and $\overline{R D}$ timing is shown in Figure 8.
To summarize, the registers' assignments are:

| Address | Pinouts | Functions | No. of Bits |
| :---: | :---: | :--- | :---: |
| XXXXX000 | Internal | Command/Status Register | 8 |
| XXXXX001 | PA0-7 | General Purpose 1/O Port | 8 |
| XXXXX010 | PB0-7 | General Purpose I/O Port | 8 |
| XXXXX011 | PC0-5 | General Purpose I/O Port or <br>  | 6 |

## TIMER SECTION

The timer is a 14-bit counter that counts the 'timer input' pulses and provides either a square wave or pulse when terminal count (TC) is reached.
The timer has the I/O address XXXXX100 for the low order byte of the register and the I/O address XXXXX101 for the high order byte of the register.
The timer addresses serve a dual purpose. During WRITE operation, a COUNT LENGTH REGISTER (CLR) with a count length (bits 0-13) and a timer mode (bits 14-15) are loaded. During READ operation the contents of the counter (the present count) and the mode blts are read.
To be sure that the right content of the counter is read, it is preferable to stop counting, read it, and then load it again and continue counting.
To program the timer, the COUNT LENGTH REG is loaded first, one byte at a time, by selecting the timer addresses. Bits $0-13$ will specify the length of the next count and bits 14-15 will specify the timer output mode.
There are four modes to choose from:
0 . Puts out low during second half of count.

1. Square wave
2. Single pulse upon TC being reached
3. Repetitive single pulse everytime TC is readied and automatic reload of counter upon TC being reached, until instructed to stop by a new command loaded into C/S.

Bits 6-7 of Command/Status Register Contents are used to start and stop the counter. There are four commands to choose from:

Note: See the further description on Command/Status Register.

$$
\begin{array}{ccc}
\frac{\text { C/S7 }}{0} & \frac{\text { C/S6 }}{0} & \\
0 & 1 & \begin{array}{l}
\text { NOP - Do not affect counter operation. } \\
\text { STOP - NOP if timer has not started; stop } \\
\text { Counting if the timer is running. }
\end{array} \\
1 & 0 & \begin{array}{l}
\text { STOP AFTER TC - Stop immediately after } \\
\text { present TC is reached (NOP if timer has not }
\end{array} \\
1 & 1 & \begin{array}{l}
\text { started) }
\end{array} \\
\begin{array}{lll}
\text { START - Load mode and CNT length and } \\
\text { start immediately after loading (if timer is } \\
\text { not presently running). If timer is running, } \\
\text { start the new mode and CNT length } \\
\text { immediately after present TC is reached. }
\end{array}
\end{array}
$$



## FIGURE 4. TIMER FORMAT

M2 M1 defines the timer mode as follows:

| $\frac{\mathbf{M 2}}{0}$ | $\frac{\mathbf{M 1}}{0}$ | Puts out low during second half of <br> count. |
| :---: | :---: | :---: |
| 0 | 1 | Square wave, i.e., the period of the <br> square wave equals the count <br> length programmed with auto- <br> matic reload at terminal count. |
| 1 | 0 | Single pulse upon TC being <br> reached. <br> Automatic reload, i.e., single pulse <br> everytime TC is reached. |
| 1 | 1 | ent |

Note: In case of an asymmetric count, i.e. 9, larger half of the count will be high, the larger count will stay active as shown in Figure 5.


Note: 5 and 4 refer to the number of clock cycles in that time period.

FIGURE 5. ASYMMETRIC COUNT.

The timer in the 8155 is not initialized to any particular mode when hardware RESET occurs, but RESET does stop the counting. Therefore, counting cannot begin following RESET until the desired mode and count length and START command are issued.

## 8085 MINIMUM SYSTEM CONFIGURATION

Figure 6 shows that a minimum system is possible using only three chips:

- 256 Bytes RAM
- $2 K$ Bytes ROM
- 38 I/O Pins
- 1 Interval Timer
- 4 Interrupt Levels


FIGURE 6. 8085 MINIMUM SYSTEM CONFIGURATION.

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.3 V to +7V |
| Power Dissipation | 1.5W |

*COMMENT: Stresses above those listed under" Absolute
Maximum Ratings" may cause permanent damagesto the device. This is a stress rating only and functional operar tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\text {CC }}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\text {OH }}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\text {LO }}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 180 | mA |  |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ )

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS ${ }^{\circ} \mathrm{O}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ AL | Address to Latch Set Up Time | 50 |  | ns | 150 pF Load |
| $t_{\text {LA }}$ | Address Hold Time after Latch | 80 |  | ns |  |
| ${ }_{\text {L }}^{\text {LC }}$ | Latch to READ/WRITE Control | 100 |  | ns |  |
| $t_{\text {RD }}$ | Valid Data Out Delay from READ Control |  | 150 | ns |  |
| ${ }^{\text {A }}$ AD | Address Stable to Data Out Valid |  | 400 | ns |  |
| ${ }_{t}$ LL | Latch Enable Width | 100 |  | ns |  |
| $\mathrm{t}_{\text {RDF }}$ | Data Bus Float After READ | 0 | 100 | ns |  |
| ${ }^{\text {t }}$ CL | READ/WRITE Control to Latch Enable | 20 |  | ns |  |
| ${ }^{\text {c }}$ c | READ/WRITE Control Width | 250 |  | ns |  |
| ${ }^{\text {t }}$ W | Data In to WRITE Set Up Time | 150 |  | ns |  |
| two | Data In Hold Time After WRITE | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RV}}$ | Recovery Time Between Controls | 300 |  | ns |  |
| $t_{\text {WP }}$ | WRITE to Port Output |  | 400 | ns |  |
| $t_{\text {PR }}$ | Port Input Setup Time | 50 |  | ns |  |
| $t_{\text {RP }}$ | Port Input Hold Time | 50 |  | ns |  |
| ${ }_{\text {t }}^{\text {SBF }}$ | Strobe to Buffer Full |  | 400 | ns |  |
| ${ }^{\text {t }}$ S | Strobe Width | 200 |  | ns |  |
| $t_{\text {RBE }}$ | READ to Buffer Empty |  | 400 | ns |  |
| $\mathrm{t}_{\mathrm{SI}}$ | Strobe to INTR On |  | 400 | ns |  |
| $t_{\text {RDI }}$ | READ to INTR Off |  | 400 | ns |  |
| tPSS | Port Setup Time to Strobe Strobe | 50 |  | ns |  |
| $t_{\text {PHS }}$ | Port Hold Time After Strobe | 100 |  | ns |  |
| ${ }^{\text {t }}$ SBE | Strobe to Buffer Empty |  | 400 | ns |  |
| $t_{\text {WBF }}$ | WRITE to Buffer Full |  | 400 | ns |  |
| $\mathrm{t}_{\text {WI }}$ | WRITE to INTR Off |  | 400 | ns |  |
| ${ }_{\text {t }}^{\text {TL }}$ | TIMER-IN to TIMER-OUT Low | 400 |  | ns |  |
| ${ }_{\text {t }}^{\text {TH }}$ | TIMER-IN to $\overline{\text { TIMER-OUT High }}$ | 400 |  | ns |  |
| $\mathrm{t}_{\text {RDE }}$ | Data Bus Enable from READ Control | 10 |  | ns |  |

Note: For Timer Input Specification, see Figure 10.
A. READ CYCLE

B. WRITE CYCLE


FIGURE 7. 8155/8156 READ/WRITE TIMING DIAGRAMS.

B. STROBED OUTPUT MODE


FIGURE 8. STROBED I/O TIMING.
A. BASIC INPUT MODE

B. BASIC OUTPUT MODE

*DATA BUS TIMING IS SHOWN IN FIGURE 7.

FIGURE 9. BASIC I/O TIMING WAVEFORM.


FIGURE 10. TIMER OUTPUT WAVEFORM.

# 8355 16,384 BIT ROM WITH I/O 

## *Directly Compatible With 8085 CPU

\author{

- 2048 Words x 8 Bits <br> - Single +5V Power Supply <br> ■ Internal Address Latch
}
- 2 General Purpose 8 Bit I/O Ports

The 8355 is a ROM and I/O chip to be used in the MCS $-85^{\text {TM }}$ microcomputer system. The ROM portion is organized as 2048 x 8. It has maximum access time of 400 ns to permit use with no wait states in 8085 CPU.

The I/O portion consists of two general purpose I/O ports. Each I/O port has 8 port lines, and each I/O port line is individually programmable as input or output.

PIN CONFIGURATION
BLOCK DIAGRAM


## 8355 FUNCTIONAL PIN DEFINITION

| Symbol | Function | Symbol |
| :---: | :---: | :---: |
| ALE | When ALE (Address Latch Enable) is high, $\mathrm{AD}_{0-7}, \mathrm{IO} / \overline{\mathrm{M}}, \mathrm{A}_{8-10}, \mathrm{CE}$, and $\overline{\mathrm{CE}}$ enter address latched. The signals ( $\mathrm{AD}, \mathrm{IO} / \overline{\mathrm{M}}, \mathrm{A}_{8-10}, \mathrm{CE}, \overline{\mathrm{CE}}$ ) are latched in at the trailing edge of ALE. | CLK READY |
| $\mathrm{AD}_{0-7}$ | Bi-directional Address/Data bus. The lower 8-bits of the ROM or I/O address are applied to the bus lines when ALE is high. |  |
|  | During an I/O cycle, Port A or B are selected based on the latched value of $A D_{0}$. If $\overline{R D}$ or $\overline{O R}$ is low when latched Chip Enables are active, the output buffers present data on the bus. | $\mathrm{PA}_{0-7}$ |
| $A_{8-10}$ | These are the high order bits of the ROM address. They do not affect I/O operations. |  |
| $\begin{aligned} & \overline{\mathrm{CE}} \\ & \mathrm{CE} \end{aligned}$ | Chip Enable Inputs: $\overline{\mathrm{CE}}$ is active low and CE is active high. The 8355 can be accessed only when BOTH Chip Enables are active at the time the ALE signal latches them up. If either Chip Enable input is not active, the $A D_{0-7}$ and READY outputs will be in a high impedance state. |  |
| $10 / \bar{M}$ | If the latched $1 O / \bar{M}$ is high when $\overline{R D}$ is low, the output data comes from an I/O port. If it is low the output data comes from the ROM. | PB0-7 RESET |
| $\overline{\mathrm{RD}}$ | If the latched Chip Enables are active when $\overline{\mathrm{RD}}$ goes low, the $\mathrm{AD}_{0-7}$ output buffers are enabled and output either the selected ROM location or I/O port. When both $\overline{R D}$ and $\overline{I O R}$ are high, the $A D_{0-7}$ output buffers are tristated. | $\overline{\text { IOR }}$ |
| $\overline{\text { IOW }}$ | If the latched Chip Enables are active, a low on $\overline{\mathrm{OW}}$ causes the output port pointed to by the latched value of $A D_{0}$ to be written with the data on $A D_{0-7}$. The state of $I O / \bar{M}$ is ignored. | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}} \\ & \mathrm{v}_{\mathrm{SS}} \end{aligned}$ |

## FUNCTIONAL DESCRIPTION

## ROM Section

The ROM section of the chip is addressed by an 11-bit address and the Chip Enables. The address and levels on the Chip Enable pins are latched into the address latches on the falling edge of ALE. If the latched Chip Enables are active and $\mathrm{IO} / \overline{\mathrm{M}}$ is low when $\overline{\mathrm{RD}}$ goes low, the contents of the ROM location addressed by the latched address are put out through AD $0-7$ output buffers.

## I/O Section

The $1 / O$ section of the chip is addressed by the latched value of $A D_{0-1}$. Two 8-bit Data Direction Registers in 8355 determine the input/output status of each pin in the corresponding ports. A 0 specifies an input mode, and a 1 specifies an output mode. The table summarizes port and DDR designation. DDR's cannot be read.

| $A D_{1}$ | $A D_{0}$ | Selection |
| :---: | :---: | :--- |
| 0 | 0 | Port A |
| 0 | 1 | Port B |
| 1 | 0 | Port A Data Direction Register (DDR A) |
| 1 | 1 | Port B Data Direction Register (DDR B) |

When $\overline{\text { OWW }}$ goes low and the Chip Enables are active, the data on the $\mathrm{AD}_{0-7}$ is written into $1 / O$ port selected by the latched value of $A D_{0-1}$.

During this operation all I/O bits of the selected port are affected, regardless of their $1 / O$ mode and the state of $I O / \bar{M}$. The actual output level does not change until $\overline{I O W}$ returns high (glitch free output).
A port can be read out when the latched Chip Enables are active and either $\overline{R D}$ goes low with $1 O / \bar{M}$ high, or $\overline{\mathrm{IOR}}$ goes low. Both input and output mode bits of a selected port will appear on lines $A D_{0-7}$.

To clarify the function of the I/O ports and Data Direction Registers, the following diagram shows the configuration of one bit of PORT A and DDR A. The same logic applies to PORT B and DDR B.

8355
ONE BIT OF PORT A AND DDR A:


WRITE PA $=(\overline{10 W}-0) \cdot($ CHIP ENABLES ACTIVE $) \cdot($ PORT A ADDRESS SELECTED $)$



Note that hardware RESET or writing a zero to the DDR latch will cause the output latch's output buffer to be disabled, preventing the data in the output latch from being passed through to the pin. This is equivalent to putting the port in the input mode. Note also that the data can be written to the Output Latch even though the Output Buffer has been disabled. This enables a port to be initialized with a value prior to enabling the output.
The diagram also shows that the contents of PORT A and PORT B can be read even when the ports are configured as outputs.

## System Interface with 8085

A system using the 8355 can use either one of the two I/O Interface techniques:

- Standard I/O
- Memory Mapped I/O

If a standard I/O technique is used, the system can use the feature of both CE and $\overline{\mathrm{CE}}$. By using a combination of unused address lines $A_{11-15}$ and the Chip Enable inputs, the 8085 system can use up to 5 each 8355's without requiring a CE decoder. See Figure 1.

If a memory mapped I/O approach is used the 8355 will be selected by the combination of both the Chip Enables and $I O / \bar{M}$ using the $A D_{8-15}$ address lines. See Figure 2.


FIGURE 2. 8355 IN 8085 SYSTEM (MEMORY-MAPPED I/O).


Note: Use $\overline{C E}$ for the first 8355 in the system, and CE for the other $8355^{\prime}$ 's. Permits up to 5 ea. 8355's in a system without CE decoder.

FIGURE 1. 8355 IN 8085 SYSTEM (STANDARD I/O).

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.3 V to +7 V |
| Power Dissipation | 1.5 W |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the
 tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High VoItage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\text {LO }}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{OUT}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 180 | mA |  |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\mathrm{t}} \mathrm{CYC}$ | Clock Cycle Time | 320 |  | ns | $C_{\text {LOAD }}=150 \mathrm{pF}$ <br> (See Figure 3) |
| $\mathrm{T}_{1}$ | CLK Pulse Width | 80 |  | ns |  |
| $\mathrm{T}_{2}$ | CLK Pulse Width | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{f}}, \mathrm{t}_{\mathrm{r}}$ | CLK Rise and Fall Time |  | 30 | ns |  |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | ns | 150 pF Load |
| $t_{\text {LA }}$ | Address Hold Time after Latch | 80 |  | ns |  |
| $t_{\text {LC }}$ | Latch to READ/WRITE Control | 100 |  | ns |  |
| $t_{\text {RD }}$ | Valid Data Out Delay from READ Control |  | 150 | ns |  |
| $t_{\text {AD }}$ | Address Stable to Data Out Valid |  | 400 | ns |  |
| $t_{\text {LL }}$ | Latch Enable Width | 100 |  | ns |  |
| trdF | Data Bus Float after READ | 0 | 100 | ns |  |
| ${ }^{\text {t }}$ CL | READ/WRITE Control to Latch Enable | 20 |  | ns |  |
| ${ }^{\text {t C }}$ | READ/WRITE Control Width | 250 |  | ns |  |
| $t_{\text {DW }}$ | Data In to WRITE Set Up Time | 150 |  | ns |  |
| twD | Data In Hold Time After WRITE | 0 |  | ns |  |
| twp | WRITE to Port Output |  | 400 | ns |  |
| $t_{\text {PR }}$ | Port Input Set Up Time | 50 |  | ns |  |
| $t_{\text {RP }}$ | Port Input Hold Time | 50 |  | ns |  |
| $t_{\text {RYH }}$ | READY HOLD TIME | 0 | 120 | ns |  |
| ${ }^{\text {t ARY }}$ | ADDRESS (CE) to READY |  | 160 | ns |  |
| $\mathrm{t}_{\mathrm{R} V}$ | Recovery Time between Controls | 300 |  | ns |  |
| $t_{\text {RDE }}$ | Data Out Delay from READ Control | 10 |  | ns |  |



FIGURE 4. CLOCK SPECIFICATION FOR 8355.


FIGURE 5. ROM READ AND I/O READ AND WRITE.


FIGURE 6. WAIT STATE TIMING (READY = 0).
A. INPUT MODE

B. OUTPUT MODE

*DATA BUS TIMING IS SHOWN IN FIGURE 3.

FIGURE 7. I/O PORT TIMING.

# 16,384 BIT EPROM WITH I/O 

## *Directly Compatible With 8085 CPU

## 2048 Words x 8 Bits

- Single +5 V Power Supply (Vcc)
- U.V. Erasable and Electrically Reprogrammable
- Internal Address Latch
- 2 General Purpose 8 bit I/O Ports
- Each I/O Port Line Individually Programmable as Input or Output
- Multiplexed Address and Data Bus
- 40 Pin DIP

The 8755 is an erasable and electrically reprogrammable ROM (EPROM) and I/O chip to be used in the MCS-85 ${ }^{\text {ru }}$ microcomputer system. The PROM portion is organized as $2048 \times 8$. It has maximum access time of 400 ns to permit use with no wait states in 8085 CPU.
The I/O portion consists of two general purpose I/O ports. Each I/O port has 8 port lines, and each I/O port line is individually programmable as input or output.

PIN CONFIGURATION
BLOCK DIAGRAM


## 8755 FUNCTIONAL PIN DESCRIPTION

| Symbol |
| :---: |
| ALE |
| $A D_{0}$ |

$10 / \bar{M} \quad$ If the latched $I O / \bar{M}$ is high when $\overline{R D}$ is low, the output data comes from an
I/O port. If it is low the output data low, the output data comes from an
I/O port. If it is low the output data comes from the PROM.
$\overline{\mathrm{RD}} \quad$ If the latched Chip Enables are active when $\overline{R D}$ goes low, the $A D_{0-7}$ output buffers are enabled and output either the selected PROM location or I/O port. When both $\overline{R D}$ and $\overline{I O R}$ are high, the $A D_{0-7}$ output buffers are tristated.
$\overline{\text { IOW If the latched Chip Enables are active, }}$ a low on $\overline{\text { IOW }}$ causes the output port pointed to by the latched value of $A D_{0}$ to be written with the data on $\mathrm{AD}_{0-7}$. The state of $10 / \bar{M}$ is ignored.
CLK The CLK is used to force the READY into its high impedance state after it has been forced low by $\overline{\mathrm{CE}}$ low, CE high, and ALE high.
READY READY is a 3-state output controlled by CE, $\overline{C E}$, ALE and CLK. READY is forced low when the Chip Enables are active during the time ALE is high, and remains low until the rising edge of the next CLK (see Figure 2.).
$\mathrm{PA}_{0-7}$
Function
When Address Latch Enable is high, $A D_{0-7}, I O / \bar{M}, A_{8-10}, C E$, and $\overline{C E}$ enter the address latches. The signals (AD, $10 / \mathrm{M}, \mathrm{A}_{8-10}, \mathrm{CE}$ ) are latched in at the trailing edge of ALE.

Bi-directional Address/Data bus. The lower 8-bits of the PROM or I/O address are applied to the bus lines when ALE is high.
During an I/O cycle, Port A or B are selected based on the latched value of $A D_{0}$. If $\overline{R D}$ or $\overline{O R}$ is low when the latched Chip Enables are active, the output buffers present data on the bus.
These are the high order bits of the PROM address. They do not affect I/O operations.

CHIP ENABLE INPUTS: $\overline{C E}$ is active low and CE is active high. Both chip enables must be active to permit accessing the PROM. $\overline{C E}$ is also used as a programming pin (see section on programming).


These are general purpose I/O pins. Their input/output direction is determined by the contents of Data Direction Register (DDR). Port A is selected for write operations when the Chip Enables are active and $\overline{\mathrm{IOW}}$ is low and a 0 was previously latched from $A D_{0}$.

Read operation is selected by either $\overline{\mathrm{IOR}}$ low and active Chip Enables and $A D_{0}$ low, or $10 / \bar{M}$ high, $\overline{R D}$ low, active Chip Enables, and $A D_{0}$ low.
This general purpose I/O port is identical to Port A except that it is selected by a 1 latched from $A D_{0}$.
In normal operation, an input high on RESET causes all pins in Ports A and $B$ to assume input mode (clear DDR register).
$\overline{\mathrm{IOR}}$
$\mathrm{V}_{\mathrm{CC}}$
$V_{S S}$
$V_{D D}$
When the Chip Enables are active, a low on $\overline{\text { IOR }}$ will output the selected I/O port onto the AD bus. $\overline{O R}$ low performs the same function as the combination of $1 \mathrm{O} / \overline{\mathrm{M}}$ high and $\overline{\mathrm{RD}}$ low. When $\overline{\mathrm{OR}}$ is not used in a system, $\overline{\mathrm{OR}}$ should be tied to $\mathrm{V}_{\mathrm{CC}}$ ("1").
+5 volt supply.
Ground Reference.
$V_{D D}$ is a programming voltage, and it is normally grounded.
For programming, a high voltage is supplied with $\mathrm{V}_{\mathrm{DD}},=25 \mathrm{~V}$, typical.

## FUNCTIONAL DESCRIPTION

## PROM Section

The 8755 contains an 8-bit address latch which allows it to interface directly to MCS-48 and MCS-85 Microcomputers without additional hardware.
The PROM section of the chip is addressed by the 11-bit address and $C E$. The address, $\overline{C E}$ and $C E$ are latched into the address latches on the falling edge of ALE. If the latched Chip Enables are active and $I O / \bar{M}$ is low when $\overline{R D}$ goes low, the contents of the PROM location addressed by the latched address are put out on the $A D_{0-7}$ lines.

## I/O Section

The I/O section of the chip is addressed by the latched value of $A D_{0-1}$. Two 8 -bit Data Direction Registers determine the input/output status of each pin in the corresponding port. A 0 specifies an input mode, and a 1 specifies an output mode. The table summarizes port and DDR designation. Contents of the DDR's cannot be read.

| $\mathbf{A D _ { 1 }}$ | $\mathbf{A D _ { 0 }}$ | Selection |
| :---: | :---: | :--- |
| 0 | 0 | Port A |
| 0 | 1 | Port B |
| 1 | 0 | Port A Data Direction Register (DDR A) |
| 1 | 1 | Port B Data Direction Register (DDR B) |

When IOW goes low and the Chip Enables are active, the data on the AD is written into I/O port selected by the latched value of $A D_{0-1}$. During this operation all I/O bits of the selected port are affected, regardless of their I/O mode and the state of $10 / \bar{M}$. The actual output level does not change until $\overline{\mathrm{OW}}$ returns high. (glitch free output).
A port can be read out when the latched Chip Enables are active and either $\overline{R D}$ goes low with IO/ $\bar{M}$ high, or $\overline{\text { IOR }}$ goes low. Both input and output mode bits of a selected port will appear on lines $A D_{0-7}$.
To clarify the function of the I/O Ports and Data Direction Registers, the following diagram shows the configuration of one bit of PORT A and DDR A. The same logic applies to PORT B and DDR B.


WRITE PA $=(\overline{10 W}=0) \cdot($ CHIP ENABLES ACTIVE $) \bullet$ (PORT A ADDRESS SELECTED)
WRITE DDR A $=(\overline{10 W}=0) \bullet($ CHIP ENABLES ACTIVE) • (DDR A ADDRESS SELECTED)
READ PA $=\{[(10 / \bar{M}=1) \bullet(\mathrm{RD}=0)]+(\overline{\mathrm{IOR}}=0)\} \bullet($ CHIP ENABLES ACTIVE $) \bullet($ PORT A ADDRESS SELECTED)

Note that hardware RESET or writing a zero to the DDR latch will cause the output latch's output buffer to be disabled, preventing the data in the Output Latch from being passed through to the pin. This is equivalent to putting the port in the input mode. Note also that the data can be written to the Output Latch even though the Output Buffer has been disabled. This enables a port to be
initialized with a value prior to enabling the oftput.
The diagram also shows that the contents of PORTA And PORT B can be read even when the ports are configưred
as outputs.

## ERASURE CHARACTERISTICS

The erasure characteristics of the 8755 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms $(\AA)$. It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000-4000 \AA$ range. Data show that constant exposure to room level flourescent lighting could erase the typical 8755 in approximately 3 years while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 8755 is to be exposed to these types of lighting conditions for extended periods of time, opaque labels are available from Intel which should be placed over the 8755 window to prevent unintentional erasure.
The recommended erasure procedure (see page 3-55) for the 8755 is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity X exposure time) for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a $12000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ power rating. The 8755 should be placed within one inch from the lamp tubes during erasure. Some lamps have a filter on their tubes and this filter should be removed before erasure.

## PROGRAMMING

Initially, and after each erasure, all bits of the EPROM portions of the 8755 are in the " 1 " state. Information is introduced by selectively programming " 0 " into the desired bit locations. A programmed " 0 " can only be changed to a " 1 " by UV erasure.
The 8755 is programmed on the Intel ${ }^{(8}$ Universal PROM Programmer (UPP). The UPP and its related personality cards for the 8755 are described beginning on page 13-45 of the 1977 Intel Data Catalog.

## SYSTEM APPLICATIONS


*USE $\overline{C E}$ FOR FIRST 8755 IN SYSTEM, AND CE FOR OTHERS. BY CONNECTING CE OF EACH 8755 CHIP TO EACH OF A 11 THROUGH $A_{15}$, THE MINIMUM SYSTEM CAN USE 5-8755's (10K BYTES) WITHOUT REQUIRING CE DECODER.

FIGURE 1. 8755 IN 8085 SYSTEM (STANDARD I/O).

FIGURE 2. 8755 IN 8085 SYSTEM (MEMORY-MAPPED I/O).

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | $-10^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.5 V to +7 V |
| Power Dissipation |  |

*COMMENT: Stresses above those listed under" Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional opera tion of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{~V} \cdot$ | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{OUT}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 180 | mA |  |

A.C. CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ )

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ CYC | Clock Cycle Time | 320 |  | ns | $\begin{aligned} & \mathrm{C}_{\text {LOAD }}=150 \mathrm{pF} \\ & (\text { See Figure } 3 \text { ) } \end{aligned}$ |
| $\mathrm{T}_{1}$ | CLK Pulse Width | 80 |  | ns |  |
| $\mathrm{T}_{2}$ | CLK Pulse Width | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{f}}, \mathrm{t}_{\mathrm{r}}$ | CLK Rise and Fall Time |  | 30 | ns |  |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | ns | 150 pF Load |
| ${ }_{\text {t }}^{\text {LA }}$ | Address Hold Time after Latch | 80 |  | ns |  |
| $t_{\text {LC }}$ | Latch to READ/WRITE Control | 100 |  | ns |  |
| $t_{R D}$ | Valid Data Out Delay from READ Control |  | 150 | ns |  |
| ${ }^{\text {t }}$ AD | Address Stable to Data Out Valid |  | 400 | ns |  |
| $t_{\text {LL }}$ | Latch Enable Width | 100 |  | ns |  |
| $\mathrm{t}_{\text {RDF }}$ | Data Bus Float after READ | 0 | 100 | ns |  |
| ${ }^{\text {t }}$ CL | READ/WRITE Control to Latch Enable | 20 |  | ns |  |
| ${ }_{\text {t CC }}$ | READ/WRITE Control Width | 250 |  | ns |  |
| ${ }_{\text {t }}$ W | Data In to WRITE Set Up Time | 150 |  | ns |  |
| twD | Data In Hold Time After WRITE | 0 |  | ns |  |
| $t_{W P}$ | WRITE to Port Output |  | 400 | ns |  |
| $t_{\text {PR }}$ | Port Input Set Up Time | 50 |  | ns |  |
| $t_{\text {RP }}$ | Port Input Hold Time | 50 |  | ns |  |
| $t_{\text {RYH }}$ | READY HOLD TIME | 0 | 120 | ns |  |
| $t_{\text {AR }}$ | ADDRESS (CE) to READY |  | 160 | ns |  |
| $t_{\text {R } V}$ | Recovery Time between Controls | 300 |  | ns |  |
| $t_{\text {RDE }}$ | Data Out Delay from READ Control | 10 |  | ns |  |



FIGURE 3. CLOCK SPECIFICATION FOR 8755


FIGURE 4. PROM READ, I/O READ, AND WRITE TIMING.
Please note that $\overline{C E 1}$ must remain low for the entire cycle. This is due to the fact that the programming enable function common to this pin will disrupt internal data bus levels if $\overline{C E 1}$ is taken high during the read.

## A. INPUT MODE


B. OUTPUT MODE

*DATA BUS TIMING IS SHOWN IN FIGURE 4.

FIGURE 5. I/O PORT TIMING.


FIGURE 6. WAIT STATE TIMING (READY = 0).

Chapter 7

## SUPPORT PRODUCTS



## PROMPT 80 DESIGN AID



# INTELLEC ${ }^{\circledR}$ PROMPT 80 ${ }^{\text {T. }}$ 8080 MICROCOMPUTER DESIGN AID 

## Simplifies microcomputing

Enter, run, debug and save machine language programs with calculator-like ease

Complete, fully-assembled microcomputer, including:

CPU Standard 8080A on popular SBC 80/10 Single Board Computer
Memory 1 K byte RAM, 3 K byte ROM, and two spare 1 K byte 8708 EPROMs
I/O 24 programmable parallel I/O (TTL) lines, including two:
8-bit ports, fully implemented switches, displays Programmable serial I/O interfaces directly with most terminals
Power Only 110 or 230 VAC required

Low Cost

PROM Programmer for 8708/2708/2704 UV Erasable, Electrically Reprogrammable ROMs (EPROMs)

Integral keyboard and 16-digit display (no teletypewriter or CRT terminal required)

Extensive system monitor software in ROM:
Examine/Display/Modify
Registers and Memory
Enter, Run, Test, Single-Step programs
Hex Calculator
Move, Search Memory Blocks
Self-programmable - user can add functions
Comprehensive design library

Intellec ${ }^{\circledR 8}$ PROMPT $80^{T M}$ is a low-cost, fully assembled microcomputer design aid. PROMPT 80 simplifies the programming of SBC 80 and System 80 microcomputers, as well as 8080 processors, 8708/2708/2704 EPROMs and 8255/8251 programmable I/O devices. 8080 programs can be entered and debugged with calculator-like ease on the large, informative display and keyboard panel. The comprehensive design library with tutorial manual is ideal for newcomers to microcomputing.
PROMPT 80's SBC 80/10 can be expanded using the SBC modular cardcage. And PROMPT 80 can serve as an economical 8708 Specialized PROM Programmer (SPP) peripheral in Intellec Microcomputer Development Systems.


## PROMPT SIMPLIFIES MICROCOMPUTING

Intellec PROMPT 80 simplifies the programming of 8080 processors, SBC 80 and System 80 microcomputers, as well as 8708 EPROMs and 8255/8251 programmable I/O devices.
PROMPT is a low-cost programming tool. It is a microcomputer design aid - not a development system with sophisticated software and peripherals.
PROMPT encourages the preparation and verification of small, modular routines which together may comprise sizable programs. These are written in assembly language, then entered in machine language and debugged with calculator-like ease on the large, informative display and keyboard panel.
Many 8080 operations can be specified with only two key strokes. Once entered, programs can be exercised one instruction (single step) or many instructions at a time. And, any of the 8080 registers can be watched while single-stepping.
Programs are readily saved and instantly reloaded via UV Erasable, Electrically Reprogrammable ROMs (EPROMs). PROMPT 80 can program the popular 8708 EPROMs in small blocks, so routines can be debugged and saved incrementally. Several programs are pre-recorded as examples on PROMPT's spare 8708 EPROMs.
PROMPT 80 is a complete, fully assembled and powered 8080 microcomputer, including RAM, I/O, and system monitor in ROM. Twenty-four lines of programmable, TTL-compatible, parallel I/O are easily accessed on a panel connector. Two 8-bit ports are fully implemented, one with displays for output, the other with displays and switches for input. PROMPT's programmable serial I/O interfaces directly with most terminals. A teletypewriter or CRT can be used, but neither is required because of PROMPT's built-in keyboard and display.
The PROMPT 80 manual includes chapters for the reader with little or no programming experience. Topics treated range from the 'number system to microcomputer hardware design. A novel, unifying set of tutorial diagrams MICROMAP ${ }^{T M}$ - simplify microcomputer concepts.


PROMPT's handy, pocket-sized reference cardlet can be affixed to the mainframe. Programming pads aid in the organization and documentation of programs. These features, plus a comprehensive design library of manuals, articles, and applications notes, make Intellec PROMPT 80 ideal for the newcomer to microcomputing.

## A COMPLETE COMPUTER

The heart of PROMPT 80 is the popular SBC 80/10 Single Board Computer, a complete computer on a single printed circuit board. The SBC 80/10 includes an 8080A, 1 K bytes of static RAM memory, and sockets for 4 K bytes of EPROM memory. Signals to the SBC 80/10 include 48 programmable, parallel I/O lines with sockets for interchangeable line drivers and terminators, a programmable serial channel, a multi-source single level interrupt network, and bus drivers for memory and I/O expansion. Read-only-memory may be added in 1 K byte increments using Intel 8708 EPROMs or 8308 ROMs.
The central processor for PROMPT's SBC 80/10 is Intel's powerful 8 -bit n-channel MOS 8080A CPU. The 8080A contains six 8 -bit general-purpose registers and an accumulator. The six general-purpose registers may be addressed individually or in pairs, providing both single and double precision operations.
The 8080A has a 16 -bit address bus which allows direct addressing of up to 64 K bytes of memory. An external stack, located anywhere in read/write memory, may be used as a last-in/first-out store. The contents of the program counter, accumulator, flags, and all of the generalprupose registers are stacked using a 16 -bit pointer. Subroutine nesting is bounded only by memory size.

## EXPANDING PROMPT $80^{T M}$



PROMPT 80's SBC 80/10 can be expanded via the SBC 604 Modular Cardcage. The cardcage houses the SBC 80/10 and up to three expansion boards. Memory and I/O can be added in various combinations. Additional power may be required.


A Specialized PROM Programmer kit, the PROMPT-SPP, allows PROMPT 80 to serve as an economical 8708 Specialized PROM Programmer peripheral in Intellec Microcomputer Development Systems. The PROMPT-SPP cable plugs directly into the rear panel of the Intellec Microcomputer Development System.

## PROM PROGRAMMER

8708 UV Erasable, Electrically Reprogrammable ROMs (EPROMs) can be easily programmed, compared, and transferred to RAM using the zero-insertion force socket on the panel. A new technique allows 8708 to be partially programmed in multiple blocks of 16 bytes. Thus, small, modular routines can be entered, tested, and readily saved using EPROM.
EPROMs can also be conveniently duplicated. The master (original) device plugs into the SBC 80/10 inside PROMPT 80 , and can be copied to the panel programming socket.

## REGISTER/DISPLAY GROUP

All 8080 registers can be displayed, even while singlestepping programs. The registers are shown in three rows:

| first row: | B | C | D | E |
| :--- | :---: | :---: | :---: | :---: |
| second row: | H | L | Flags | A |
| third row: | Program Counter | Stack | Pointer |  |

One register row is visible at a time. Three small LEDs to the left of these rows indicate which row is displayed. The SCROLL REGISTER DISPLAY command displays the next row (first, second, third, etc.)

## RESET, INTERRUPTS

SYS RST resets the system, initializes the PROMPT 80 registers and enters the monitor. MON INT interrupts a user program and enters the monitor saving the user registers. USR INT is a user interrupt which traps PROMPT 80 to location 3C02 ${ }_{16}$.

## MONITOR

A comprehensive system monitor resides in three 1 K ROMs. It drives PROMPT's keyboard, displays, and responds to COMMANDS and FUNCTIONS. The monitor is modular, organized so that the third ROM may be removed if F FUNCTIONS are not required. This allows sizable user routines - as much as 2 K ROM/EPROM and nearly 1 K RAM - to be exercised.


## COMMANDS

PROMPT 80 commands are compatible with those used by Intel's SDK, SBC, and Intellec monitors.
You can EXAMINE/MODIFY a REGISTER, or DISPLAY/MODIFY MEMORY. Then either the NEXT or PREVIOUS register and memory locations can be opened with one button.

The GO command executes programs, allowing multiple, optional breakpoints. Or a program can be SINGLE STEPped, executed one instruction at a time.

The SCROLL REGISTER DISPLAY command displays the next row of the REGISTER/DISPLAY GROUP.


Commands are entered naturaliy, like phrases in a sentence: the NEXT parameters are separated bycommas $\square$ and command sentences end withEXECUTE/END.

The commands do what makes sense. For example:

## GO $\square$ 回回•EXECUTE/END

starts the program at address 100.
 starts the program at 100, but stops if you get to 200, a breakpoint.

## INPUT/OUTPUT GROUP

The INPUT/OUTPUT (I/O) GROUP features two fully implemented 8 -bit ports, both with displays, and with latch switches for the input port E9. The port addresses are clearly marked E8 and E9. Those two ports and a third, at EA, are easily accessible on the I/O PORTS CONNECTOR. Negative true logic is used throughout the I/O GROUP and PORTS CONNECTOR to enhance noise immunity and allow wire-ANDing.

## PARALLEL I/O

The I/O PORTS CONNECTOR provides easy access to 24 parallel, TTL-compatible lines. These lines are addressed as three ports (each 8 lines), port E8, E8, and EA.

These ports can be defined to be input or output by software. Defining control words, tabulated in "Specifications", are sent OUT to port EB, the control word register.

## SERIAL I/O

PROMPT's programmable serial I/O readily interfaces with most terminals. Jumpers select either 20 mA teletypewriter (TTY) current loop or RS-232C operation, and the appropriate communications frequency. Asynchronous or synchronous transmission, data format, control characters, parity, and transmission rate can be programmed.
A serial cable kit, PROMPT-SER, connects PROMPT to either a teletypewriter or RS-232C standard (CRT) terminal through a rear chassis access slot. Teletypewriters may require minor reader control modifications.

## COMMAND/FUNCTION DISPLAYS

The COMMAND/FUNCTION displays show addresses and data when DISPLAYing MEMORY, and parameters for COMMANDS and FUNCTIONS are entered.

## FUNCTIONS

Eight FUNCTIONS are provided by PROMPT. Others may be added by the user. Pressing a HEX DATA/FUNCTIONS key ( $0-7$ ) starts a function.

| 0 is | F0 | Read Paper Tape |
| :---: | :---: | :---: |
| [1] is | F1 | Write Paper Tape |
| [2] is | F2 | Program EPROM, Compare |
| [3 is | F3 | Compare EPROM |
| [4] is | F4 | Transfer EPROM to RAM |
| [5 is | F5 | Move Block Memory |
| [6) is | F6 | Hexadecimal Calculator, +, - |
| [7 is | F7 | Byte Search Memory, optional mask |
| [8] is | F8 | Word Search Memory, optional mask |

## SPECIFICATIONS

WORD SIZE
Instruction: 8, 16, or 24 bits
Data: 8 bits
TIMING
Basic Instruction: $1.95 \mu \mathrm{sec}$
Cycle Time: $\quad \mathrm{t}_{\mathrm{C}} \mathrm{Y}=488 \mathrm{nsec}$
Clock: $\quad 2.058 \mathrm{MHz} \pm 0.1 \%$
$\begin{array}{cccc}\text { MEMORY BYTES } & \text { Addressing } & \text { On Board } & \text { Monitor Uses } \\ \text { ROM/PROM } & 0-\text { OFFF }_{16} & 4096 & 2048 \text { or } 3072 \\ \text { RAM } & 3 C 00-3 F F F_{16} & 1024 & 114\end{array}$
Up to 48 K bytes may be added using optional RAM, ROM, or PROM expansion boards and the SBC 604 Cardcage.

## I/O ADDRESSING

Ports E4 to E7 are dedicated to PROMPT's display/keyboard groups. Ports E8 to EB drive the panel I/O PORTS CONNECTOR and PROM SOCKET.

|  | Dedicated to Display/Keyboard |  |  |  | 1/O Ports Connector/ PROM Socket |  |  |  | Serial I/O USART |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A | B | C | Con- <br> trol | A | B | C | Control | Data | Control |
| PORT | E4 | E5 | E6 | E7 | E8 | E9 | EA | EB | EC | ED |

PARALLEL I/O
The panel I/O ports can be defined input or output by OUTputing control words to port address EB.

| HEX Control Word (OUT this to EB) | Port E8 <br> Bits 7-0 | Port E9 Bits 7-0 | Port EA |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Bits 7-4 | Bits 3-0 |
| 80 | OUTPUT | OUTPUT | OUTPUT | OUTPUT |
| 81 | OUTPUT | OUTPUT | OUTPUT | INPUT |
| 82 | OUTPUT | InPUT | OUTPUT | OUTPUT |
| 83 | OUTPUT | INPUT | OUTPUT | INPUT |
| 84 or 86 | OUTPUT | STROBED OUTPUT | OUTPUT | Bits 2, 1, |
| 85 or 87 | OUTPUT | STROBED INPUT | OUTPUT | 0 are strobes |

All input ports are TTL-compatible. Ports E8 and EA are oneload fully TTL-compatible as output. Port E9 is ordinarily used as input. When used as output, E9 can sink at least one low-power TTL load.

## SERIAL I/O

The serial I/O port is defined by software and jumpers. PROMPT is configured at the factory for 20 mA current loop TTY interface, but can easily be jumpered for RS-232C levels. Asynchronous or synchronous transmission, data format, control characters, parity and transmission rate can be programmed.

## INTERRUPTS

PROMPT 80 provides a panel user interrupt to $3 \mathrm{C} 02_{16}$. The SBC 80/10 supports single level vectoring to location 3816 . Requests may originate from user-specified I/O (2), the parallel ports (2), or serial port (2).

## EPROM PROGRAMMING

8708/2708/2704 EPROMs can be programmed in multiple blocks of 16 bytes. Starting and ending memory address need only differ by a multiple of 16, and starting EPROM address end $X \times 0$ hexadecimal ( $X=$ don't care). Programming time is 115 sec for 1 K byte, 3 sec for 16 bytes.
The 8708 may be erased by exposure to high intensity shortwave ultraviolet light at a wavelength of $2537 \AA$. The recommended integrated dose (UV intensity $X$ exposure time) is 10 W -sec $/ \mathrm{cm}^{2}$.

## SYSTEM MONITOR

Resides in three 8308 ROMs, 0 to $3 \mathrm{FF}_{16}, 400_{16}$ to $7 \mathrm{FF}_{16}$, and $800_{16}$ to $\mathrm{BFF}_{16}$. The third ROM implements F FUNCTIONS, and can be removed. PROMPT has an unused ROM/ EPROM socket at address $\mathrm{COO}_{16}$ to $\mathrm{FFF}_{16}$.

## COMMANDS

Examine/Modify Register Display/Modify Memory
Go (with optional breakpoints) Single Step
Scroll Register Display
Next $\square$

## FUNCTIONS

(0) Read Tape

1 Write Tape
(2) Program EPROM, Compare

3 Compare EPROM
4 Transfer EPROM to RAM
5 Move Block Memory
6 Hexadecimal Calculator, +, -
7 Byte Search Memory, optional mask
8 Word Search Memory, optional mask

## SOFTWARE DRIVERS

Panel Keyboard Input
Console Terminal Input
TTY Reader Input

Panel Display Output Console Terminal Output TTY Punch Output

## CONNECTORS

PROMPT Panel I/O Ports 3M 3425 Flat
SBC 80/10 Parallel I/O 3M 3415 Flat
SBC 80/10 Serial I/O 3M 3462 Flat
SBC 80/10 Bus CDC VPB01E43D00A1
SBC 80/10 Auxiliary Bus TI H312130

## EQUIPMENT SUPPLIED

PROMPT 80 mainframe with SBC 80/10, display/keyboard,
PROM Programmer, power supply, cabinet, and ROM-based system monitor
(2) 8708 EPROMs with pre-recorded example programs

110 VAC power cable, 110 or 220 VAC fuse
PROMPT 80 User's Manual, PROMPT 80 Monitor Listing
PROMPT 80 Reference Cardlist, PROMPT 80 Programming Pads
8080 Systems User's Guide, 8080 Assembly Language Manual System 80/10 Hardware Reference Manual
Design Library of Application Notes, Article Reprints
PROMPT 80 Schematics
ORDERING INFORMATION, COMPATIBLE EQUIPMENT
PROMT-80 - Complete PROMPT 80 set 110 VAC
PROMT-80-220V - Complete PROMPT 80 set 220 VAC
PROMT-SER - Serial Cable connects PROMPT to TTY, CRT
PROMT-SPP - Specialized PROM Programmer Kit connects PROMPT 80 to Intellec ${ }^{\circledR}$ Microcomputer Development Systems for 8708 EPROM programming.
All SBC products ladditional memory, I/O, wire-wrap, and other boards) are compatible with PROMPT's SBC 80/10.
Additional PROMPT 80 Programming Pads can be ordered from Intel Literature Department.
PHYSICAL CHARACTERISTICS
Maximum Height: 13.5 cm ( 5.3 in )
Width: $\quad 43.2 \mathrm{~cm} \quad(17 \mathrm{in}$.
Maximum Depth: $43.2 \mathrm{~cm} \quad(17 \mathrm{in}$.
Weight: $\quad 9.6 \mathrm{~kg} \quad(21 \mathrm{lb})$

## ELECTRICAL REQUIREMENTS

Either 115 or 230 VAC ( $\pm 10 \%$ ) may be switch-selected on the mainframe. 1.8 amps max current (at 125 VAC )
Frequency is $47-63 \mathrm{~Hz}$.

| Voltage | Internal PROMPT 80 <br> Supply | PROMPT 80 Requires |
| :---: | :---: | :---: |
| +26.5 | 0.1 A | 0.03 A |
| +12 | 1.2 A | 0.5 A |
| +5 | 6.0 A | 5.0 A |
| -5 | 0.3 A | 0.1 A |
| -12 | 0.3 A | 0.2 A |

Fixed over-voltage protect on 5 V supply $6.2-6.7$ volts.

## ENVIRONMENTAL

Operating Temperature: $\quad 10^{\circ} \mathrm{C}$ to $40^{\circ} \mathrm{C}$
Non-operating Temperature: $-20^{\circ} \mathrm{C}$ to $65^{\circ} \mathrm{C}$

## INTELLEC <br> MICROCOMPUTER DEVELOPMENT SYSTEM

Modular microcomputer development system for development and implementation of MCS ${ }^{\top}$ M -80 and Series 3000 Microcomputer Systems

Intel ${ }^{\circledR} 8080$ microprocessor, with $2 \mu$ s cycle time and 78 instructions, controls all Intellec MDS functions

16 K bytes RAM memory expandable to 64 K bytes
2 K bytes ROM memory expandable to 14 K bytes
Hardware interfaces and software drivers provided for TTY, CRT, line printer, high-speed paper tape reader, high-speed paper tape punch, and Universal PROM Programmer

Universal bus structure with multiprocessor and DMA capabilities

Eight level nested, maskable, priority interrupt system

Optional PROM programmer peripheral capable of programming all Intel PROMs

ICE (In-Circuit Emulator) options extend Intellec MDS diagnostic capabilities into user configured system allowing real-time emulation of user processors

Optional I/O modules expandable in groups of four 8 -bit input and output ports to a maximum of 88 ports (all TTL compatible)

ROM resident system monitor includes all necessary functions for program loading, debugging, and execution

RAM resident macro assembler used to assemble all 8080 machine instructions with full macro and conditional assembly capabilities

RAM resident text editor with powerful string search, substitution, insertion, and deletion commands

The Intellec ${ }^{\circledR}$ MDS is a modular microcomputer development system containing all necessary hardware and software to develop and implement Intel MCS ${ }^{\text {T.M. }} 80$ and Series 3000 microcomputer systems. The addition of MDS options and peripherals provides the user with a complete in-circuit microcomputer development system, supporting product design from program development through prototype debug, to production and field test.


## INTELLEC HARDWARE

The standard Intellec ${ }^{\circledR}$ MDS consists of four microcomputer modules (CPU, 16K RAM Memory, Front Panel Control, and Monitor), an interconnecting printed circuit motherboard, power supplies, fans, a chassis, and a front panel. Modular expansion capability is provided by 14 additional sockets on the motherboard.

The CPU module uses Intel's powerful NMOS 8-bit 8080 microprocessor. The 8080's $2 \mu$ s cycle time, 78 instructions, unlimited subroutine nesting, vectored interrupt, and DMA capabilities are fully utilized by the Intellec MDS. Bus control logic resolves bus contention conflicts between the CPU module and other modules capable of acquiring control of the bus. The CPU module interfaces with a sixteen line address bus and a bidirectional eight line data bus. 8080 status signals are decoded and utilized for memory and I/O operations. An eight-level, nested interrupt priority system, complete with an interrupt priority push-down stack, resolves contention for 8080 interrupt servicing.
The RAM memory module contains 16 K bytes of Intel 2107A dynamic RAM which operates at full processor speed. All necessary address decoding and refresh logic is contained on the module.

The front panel control module provides system initialization, priority arbitration, and real time clock functions. System initialization routines reside in a 256 byte, PROM resident, bootstrap loader. An eight-level priority arbitration network resolves bus contention requests among potential bus masters. A 1 ms interrupt request generator, which can be disabled under program control, provides real time clock functions. A 10 ms automatic time-out feature is also provided to force an interrupt request if nonexistent memory or I/O is addressed.

The Monitor module contains the Intellec MDS system monitor and all Intellec MDS peripheral interface hardware. The system monitor resides in a 2 K byte Intel 8316 ROM. The module contains all necessary control and data transfer circuitry to interface with the following Intellec MDS peripherals:

- Teletype
- CRT
- High Speed Paper Tape Reader
- High Speed Paper Tape Punch
- PROM Programmer
- Line Printer

The Intellec MDS universal bus structure enables several CPU and DMA devices to share the bus by operating at different priority levels. Resolution of bus exchanges is synchronized by a bus clock signal which is derived independently from processor clocks. Read/write transfers may take place at rates up to 5 MHz . The bus structure contains provisions for up to 16 -bit address and data transfers and is not limited to any one Intel microcomputer family.
The Intellec MDS front panel is intended to augment the primary user interaction medium, the system console. The simplicity of the front panel coupled with the power of the system monitor provides an efficient user/Intellec interface. The front panel contains eight interrupt request switches with corresponding indicators, CPU RUN and HALT status
indicators, a bootstrap loader switch, RESET switch, and a POWER ON switch and indicator.
The basic Intellec MDS capabilities may be significantly enhanced by the addition of the following optional features.

ICE (In-Circuit Emulator) extends Intellec MDS diagnositc capabilities into user configured systems. The Intellec MDS resident ICE processor operates in conjunction with the MDS host CPU and interfaces to the user system via an external cable. The ICE processor replaces the user system processor providing real time emulation capability. MDS resident memory and I/O may be substituted for equivalent user system elements, allowing the hardware designer to sequentially develop his system by integrating MDS and user system hardware. MDS display and debug hardware eliminate the need for specially constructed user system equivalents. Augmenting these capabilities are such powerful ICE debug functions as setting breakpoints, tracing program flow, single stepping, examining and altering CPU registers and memory locations.
The Universal PROM Programmer is an Intellec MDS peripheral capable of programming and verifying the following Intel PROMs: 1702A, 2704, 2708, 3601, 3604, 3624, 8702A, 8704, and 8708. Programming and verification operations are initiated from the Intellec MDS system console and are controlled by programs resident in the Intellec MDS and Universal PROM Programmer.
The addition of a single or dual drive Diskette Operating System significantly reduces program development time. An intelligent controller, constructed around Intel's powerful Series 3000 computing elements, provides diskette interface and control. Intel's software operating system (IDOS) in conjunction with the diskette operating system hardware provides a highly efficient and easy to use method of assembling, editing, and executing programs.
Customized user I/O requirements may be satisfied by adding I/O modules. Each 1/O module contains four 8 -bit input ports (latched or unlatched), four 8-bit latched output ports (with adjustable strobe pulses), and eight system interrupt lines. All inputs and outputs are TTL compatible. Optional I/O may be expanded to a maximum of 44 input and 44 output ports.

Memory may be expanded by adding RAM or PROM modules in user defined combinations. Up to 64 K bytes of RAM may be added in 16K byte increments. PROM (Intel 8702A) may be added in 256 byte increments by adding PROM modules with socket capacity for 6K bytes and populating each module with the desired number of PROMs. Maximum PROM capacity is 12 K bytes. RAM/PROM memory overlap is resolved by giving PROM priority.

DMA (direct memory access) modules work in conjunction with the Intellec MDS universal bus to maximize the efficiency of data transfers between MDS memory and selected I/O devices. Each module contains all the necessary control and data transfer logic to implement a complete DMA channel.
A ROM simulator composed of high speed bipolar RAM emulates Series 3000 bipolar microprogram ROM memory. Each ROM simulator module may be used in $512 \times 16$ or $1024 \times 8$ configurations.

## INTELLEC SOFTWARE

Resident software provided with the Intellec MDS includes the system monitor, 8080 macro assembler and text editor. Used together, these three programs simplify program preparation and speed the debugging task.
The system monitor provides complete control over operation of the Intellec MDS. All necessary functions for program loading and execution are provided. Additional commands provide extensive debug facilities and PROM programming functions. System peripherals may be dynamically assigned either via monitor commands or through calls to the system monitor's I/O subroutines.
Programs may be loaded from the reader device in either BNPF or hexadecimal format. Utility commands which aid in the execution and checkout of programs include:

- initialize memory to a constant
- move a block of memory to another location
- display memory
- modify RAM memory
- examine and modify CPU registers
- set breakpoints
- initiate execution at any given address
- perform hexadecimal arithmetic
- examine and modify the interrupt mask

The Intellec MDS System Monitor contains a powerful and easily expandable input/output system, which is built around four logical device types; console device, reader device, punch device and list device. Associated with each logical device may be any one of four physical devices. The user controls physical device assignment to each logical device through a System command.
Drivers are provided in the system monitor for the Universal PROM Programmer, ASR 33 teletype, high speed paper tape reader, high speed paper tape punch, line printer, and CRT. The user may write his own drivers for other peripheral devices and easily link them to the system monitor.

All system peripherals may be accessed simply by calling I/O subroutines in the system monitor. In addition, the user may dynamically reconfigure his system by monitor commands or by calling system subroutines which can assign a different physical device to each logical device. The user may also determine the current system peripheral configuration, check I/O status and determine the size of available memory.

The monitor is written in 8080 Assembly Language and resides in 2 K bytes of ROM memory.
The Intellec MDS Resident Assembler translates symbolic 8080 assembly language instructions into the appropriate machine operation codes. In addition to eliminating the errors of hand translation, the ability to refer to program addresses with symbolic names makes it easy to modify programs by adding or deleting instructions. Full macro capability eliminates the need to rewrite similar sections of code repeatedly and simplifies program documentation.

Conditional assembly permits the assembler to include or delete sections of code which may vary from system to system, such as the code required to handle optional external devices.

The assembler performs its function in three passes. The first pass builds the symbol table. The second pass produces a source listing and provides error diagnostics. The third pass produces the object code. If the punch and list devices are separate (e.g. a high speed punch or printer is available) passes 2 and 3 may be combined into one pass.
Object code produced by the assembler is in hexadecimal format. It may be loaded directly into the Intellec MDS for execution and debugging or may be converted by the system monitor to BNPF format for ROM programming.
The assembler is written in PL/M ${ }^{\text {T.M. }}-80$, Intel's high level systems programming language. It occupies 12 K bytes of RAM memory including space for over 800 symbols. The symbol table size may be expanded to a maximum of 6500 symbols by adding RAM memory. All I/O in the assembler is done through the system monitor, enabling the assembler to take advantage of the monitor's I/O system. The assembler is shipped in hexadecimal object format on paper tape or diskette and is standard with each Intellec MDS.

The Intellec MDS editor is a comprehensive tool for the entry and correction of assembly language programs for the Intel 8080 microcomputer. Its command set allows manipulation of either entire lines of text or individual characters within a line.
Programs may be entered directly from the console keyboard or from the system reader device. Text is stored internally in the editor's workspace, and may be edited with the following commands:

- string insertion or deletion
- string search
- string substitution

To facilitate the use of these editing commands, utility commands are used to change positions in the workspace. These include:

- move pointer by line or by character
- move pointer to start of workspace
- move pointer to end of workspace

The contents of the workspace may be listed to the system console or written to the system list or punch device for future use.
The text editor is written in PL/M ${ }^{\text {T.M. }}$. 80 . It occupies 8 K bytes of RAM memory, including over 4500 bytes of workspace. The workspace may be expanded to a maximum of 58 K bytes by adding RAM memory. All I/O in the editor is done through the system monitor, enabling the editor to take advantage of the monitor's I/O system. The editor is shipped in hexadecimal object format on paper tape or diskette and is standard with each Intellec MDS.


## HARDWARE SPECIFICATIONS

## WORD SIZE

Host Processor (Intel 8080)
Data: 8 bits
Instruction, 8, 16, or 24 bits

## MEMORY SIZE

RAM: 16K bytes expandable to 64 K bytes using optional modules.

ROM: 2 K bytes expandable to 14 K bytes in 256 byte increments using optional PROM modules.

PROM: 256 bytes expandable to 12 K bytes using optional modules.
Total: RAM, ROM and PROM may be combined in user defined configurations up to a maximum of 64 K bytes.

## MACHINE CYCLE TIME

Host Processor (Intel 8080): $2.0 \mu \mathrm{~S}$

## BUS TRANSFER RATE

Maximum bus transfer rate of 5 MHz .

## SYSTEM CLOCKS

Host Processor (Intel 8080) Clock: Crystal controlled at $2 \mathrm{MHz} \pm 0.1 \%$.
Bus Clock: Crystal controlled at $9.8304 \mathrm{MHz} \pm 0.1 \%$.
I/O INTERFACES
CRT:
Baud Rates: 110/300/600/1200/2400/4800/9600 (selectable)
Code Format: 7-12 level code (programmable).
Parity: Odd/even (programmable).
Interface: TTL/RS232C (selectable).
TTY:
Baud Rate: 110
Code Format:

| Input: | 10 level or greater. |
| :--- | :--- |
| Output: | 11 level. |
| Parity: | Odd. |
| Interface: | 20 mA current loop. |

High Speed Paper Tape Reader:
Transfer Rate: 200 cps .
Control: 2-bit output.

Data:
Interface: TTL
Punch:
Transfer Rate: 75 cps
Control: 2-bit output
1-bit input
Data: $\quad 8$-bit byte
interface: TTL

Printer:

| Transfer Rate: | 165 cps |
| :--- | :--- |
| Control: | 2-bit status input |
|  | 1-bit output |
| Data: | ASCII |
| Interface: | TTL |

PROM Programmer:

| Control: | 3 strobes for multiplexed output data. |
| :--- | :--- |
| Data: | 8 -bit bidirectional |
| Interface: | TTL |

## GENERAL PURPOSE I/O (OPTIONAL)

Input Ports: 8 -bit TTL compatible (latched or unlatched); expandable in 4 port increments to 44 input ports.
Output Ports: 8-bit TTL compatible (latched); expandable in 4 port increments to 44.
Interrupts: 8 TTL compatible interrupt lines.

## INTERRUPT

8-level, maskable, nested priority interrupt network initiated from front panel or user selected devices.

## DIRECT MEMORY ACCESS

Standard capability on Intellec bus; implemented for user selected DMA devices through optional DMA module maximum transfer rate of 2 MHz .

## MEMORY ACCESS TIME

RAM: 450 ns
PROM: $1.3 \mu$ s using Intel 8708A PROM.

PHYSICAL CHARACTERISTICS
Dimensions: $8.5^{\prime \prime} \times 19^{\prime \prime} \times 17^{\prime \prime}$

$$
21.6 \mathrm{~cm} \times 48.3 \mathrm{~cm} \times 43.2 \mathrm{~cm}
$$

Weight: $\quad 65 \mathrm{lb}(29.5 \mathrm{~kg})$

ELECTRICAL CHARACTERISTICS

| DC POWER <br> SUPPLY <br> (Volts) | POWER SUPPLY <br> CURRENT <br> (Amps) | BASIC SYSTEM CURRENT <br> REQUIREMENTS <br> (Amps) |  |
| :---: | :---: | :---: | :---: |
|  |  | Maximum | Typical |
| $+5 \pm 5 \%$ | 35.0 | 9.0 | 6.6 |
| $+12 \pm 5 \%$ | 3.0 | 0.7 | 0.4 |
| $-10 \pm 5 \%$ | 3.0 | 0.2 | 0.2 |
| $-12 \pm 5 \%$ | 0.5 | -- | -- |

## AC POWER REQUIREMENTS

$50-60 \mathrm{~Hz}$; 115/230 VAC; 150 Watts
ENVIRONMENTAL CHARACTERISTICS
Operating Temperature: 0 to $55^{\circ} \mathrm{C}$

## SOFTWARE SPECIFICATIONS

## CAPABILITIES

System Monitor:
Devices supported include:
ASR 33 teletype
Intel high speed paper tape reader
Paper tape punch

## CRT

Printer
Universal PROM programmer
4 logical devices recognized
16 physical devices maximum allowed
Macro Assembler:
800 symbols in standard system; automatically expand-
able with additional RAM memory to 6500 symbols maximum.
Assembles all seventy-eight 8080 machine instructions plus 10 pseudo-operators.
Text Editor:
12 K bytes of workspace in standard system; automatically expandable with additional RAM memory to 58 K bytes.

OPERATIONAL ENVIRONMENTAL
System Monitor:
Required hardware:
Intellec MDS
331 bytes RAM memory
2 K bytes ROM memory
System console
Macro Assembler:
Required hardware:
Intellec MDS
12 K bytes RAM memory
System console
Reader device
Punch device
List device
Required software:
System moni.tor
Text Editor:
Required hardware:
Intellec MDS
8K bytes RAM memory
System console
Reader device
Punch device
Required software:
System monitor
Tape Format:
Hexadecimal object format.

## MDS OPTIONS

MDS-016 16K Dynamic RAM
MDS-406 6K PROM (sockets and logic)
MDS-501 DMA Channel Controller
MDS-504 General Purpose I/O Module
MDS-600 Prototype Module
MDS-610 Extender Module
MDS-620 Rack Mounting Kit
MDS EMULATORS/SIMULATOR
MDS-ICE-30 3001 In -Circuit Emulator
MDS-ICE-80 8080 In-Circuit Emulator
MDS-SIM-100 Bipolar ROM Simulator
MDS PERIPHERALS
MDS-UPP Universal PROM Programmer
MDS-PTR High Speed Paper Tape Reader
MDS-DOS Diskette Operating System
MDS INTERFACE CABLES/CONNECTORS
MDS-900 CRT Interface Cable
MDS-910 Line Printer Interface Cable
MDS-915 High Speed Reader Interface Cable
MDS-920 High Speed Punch Interface Cable
MDS-930 Peripheral Extension Cable
MDS-940 DMA Cable
MDS-950 General Purpose I/O Cable
MDS-960 25-pin Connector Pair
MDS-970 37-pin Connector Pair
MDS-980 60-pin Motherboard Auxiliary Connector
MDS-985 86-pin Motherboard Main Connector
MDS-990 100-pin Connector Hood

## EQUIPMENT SUPPLIED

Central Processor Module
RAM Memory Module
Monitor Module (System I/O)
Front Panel Control Module
Chassis with Motherboard
Power Supplies
Finished Cabinet
Front Panel
ROM Resident System Monitor
RAM Resident Macro Assembler
RAM Resident Text Editor
Hardware Reference Manual
Reference Schematics
Operator's Manual
8080 Assembly Language Programming Manual
System Monitor Source Listing
8080 Assembly Language Reference Card
TTY Cable
European AC Adapter
AC Cord

# ICE-80 8080 IN-CIRCUIT EMULATOR 

Connects Intellec ${ }^{\circledR}$ MDS to user configured system via an external cable and 40 -pin plug, replacing the user 8080

Allows real-time ( 2 MHz ) emulation of the user system 8080

Allows user configured system to share Intellec ${ }^{\circledR}$ MDS RAM, ROM and PROM memory and Intellec ${ }^{\circledR}$ MDS I/O facilities

Checks for up to three hardware and four software break conditions

Offers full symbolic debugging capabilities
Eliminates the need for extraneous debugging tools residing in the user system

Provides address, data and 8080 status information on last 44 machine cycles emulated

Provides capability to examine and alter CPU registers, main memory, pin and flag values

Integrates hardware and software development efforts

Available in diskette or paper tape versions

The Intellec ${ }^{\circledR}$ MDS In-Circuit Emulator/80 (ICE-80) is an Intellec ${ }^{\circledR}$ MDS resident module that interfaces to any user configured 8080 system. With ICE-80 as a replacement for a prototype system 8080, the designer can emulate the system's 8080 in real time, single-step the system's program, and substitute Intellec ${ }^{\circledR}$ MDS memory and I/O for user system equivalents. Powerful Intellec ${ }^{\circledR}$ MDS debug functions are extended into the user system. For the first time the designer may examine and modify his sytem with symbolic references instead of absolute values.


## INTEGRATED HARDWARE/ SOFTWARE DEVELOPMENT

The user prototype need consist of no more than an 8080 CPU socket and a user bus to begin integration of software and hardware development efforts. Through ICE-80 mapping capabilities, MDS equivalents can be accessed for missing prototype hardware. Hardware designs can be tested using the system software which will drive the final product.
The system integration phase, which can be so costly and frustrating when attempting to mesh completed hardware and software products, becomes a convenient two-way debug tool when begun early in the design cycle.

## SYMBOLIC DEBUGGING

ICE-80 allows the user to make symbolic references to memory addresses and data in his program. Symbols may be substituted for numeric values in any of the ICE-80 commands. The user is relieved from looking up addresses of variables or program subroutines.
The user symbol table generated along with the object file during a PL/M compilation or a MAC80 or MDS assembly, is loaded to MDS memory along with the user program which is to be emulated. The user may add to this symbol table any additional symbolic values for memory addresses, constants, or variables that are found useful during system debugging. By referring to symbolic memory addresses, the user can be assured of examining, changing, or breaking at the intended location.
ICE-80 provides symbolic definition of all 8080 registers, flags, and selected pins. The following symbolic references are also provided for user convenience: TIMER, a 16 -bit register containing the number of $\phi_{2}$ clock pulses elapsed during emulation; ADDRESS, the address of the last instruction emulated; INTERRUPTENABLED, the user 8080 interrupt mechanism status; and UPPERLIMIT, the highest MDS RAM address that can be occupied by user memory.

## DEBUG CAPABILITY INSIDE USER SYSTEM

ICE-80 provides the user with the ability to debug a full prototype or production system without introducing extraneous hardware or software test tools.

ICE-80 connects to the user system through the socket provided for the user 8080 in the user system. Intellec ${ }^{\circledR}$ MDS memory is used for the execution of the ICE-80 software, while MDS I/O provides the user with the ability to communicate with ICE-80 and receive information on the operation of the user system.

## MEMORY AND I/O MAPPING

Memory and I/O for the user system can be resident in the user system or "borrowed" from the MDS through ICE-80's mapping capability.
ICE-80 separates user memory into 164 K blocks. User I/O is divided into 1616 -port blocks. Each block of memory or I/O can be defined independently. The user may assign MDS equivalents to take the place of devices not yet designed for the user system during prototyping. In addition, proven MDS memory or I/O can be accessed in place of suspect user system devices during prototype or production checkout.

The user can also designate a block of memory or I/O as nonexistent. ICE-80 issues error messages when memory or $1 / O$ designated as nonexistent is accessed by the user program.


## ICE-80 INSTALLED IN USER SYSTEM

## REAL TIME TRACE

ICE-80 captures valuable trace information while the user is executing programs in real time. The 8080 status, the user memory or port addressed, and the data read or written (snap data), is stored for the last 44 machine cycles executed. This provides ample data for determining how the user system was reacting prior to emulation break. It is available whether the break was user initiated or the result of an error condition.
For detailed information on the actions of CPU registers, flags, or other system operations, the user may operate in single or multiple-step sequences tailored to system debug needs.

## HARDWARE

The heart of ICE-80 is a microcomputer system utilizing Intel's 8080 microprocessor as its nucleus. This system communicates with the Intellec ${ }^{\circledR}$ MDS host processor via I/O commands. Host processor commands and ICE-80 status are interchanged through registers on the ICE-80 Trace Board. ICE-80 and the MDS also communicate through a Control Block resident in the Intellec ${ }^{\circledR}$ MDS main memory which contains detailed configuration and status information transmitted at an emulation break.
ICE-80 hardware consists of two PC boards, the Processor and Trace Boards, residing in the Intellec ${ }^{\circledR}$ MDS chassis, and a 6 -foot cable which interfaces to the user system. The Trace and Processor Boards communicate with the MDS on the MDS bus, and also with each other on a separate ICE-80 bus. ICE-80 connects to the user system through a cable that plugs directly into the socket provided for the user's 8080.

## TRACE BOARD

The Trace Board talks to the MDS as a peripheral device. It receives MDS commands to ICE-80 and returns ICE-80 responses.
While ICE-80 is executing the user program, the Trace Board collects data for each machine cycle emulated (snap data). The information is continuously stored in highspeed bipolar memory.
The Trace Board also contains two 24-bit hardware breakpoint registers which can be loaded by the user. While in emulation mode, a hardware comparitor is constantly monitoring address and status lines for a match which will terminate an emulation. A user probe is also available which can be attached to any user signal. When this signal goes true a break condition is recognized.
The Trace Board signals the Processor Board when an MDS command to ICE-80 or a break condition has been detected. The ICE-80 CPU then sends data stored on the Trace Board to the Control Block in MDS memory. Snap data, along with information on 8080 registers and pin status, and the reason for the emulation break are then available for access during interrogation mode. Error conditions, if present, are transmitted and automatically displayed for the user.

## PROCESSOR BOARD

An 8080 CPU resides on the Processor Board. During emulation it executes instructions from the user's program. At all other times it executes instructions from the control program in the Trace Module's ROM.
The Processor Board contains an internal Clock Generator that provides the clocks to the user emulation CPU at 2

MHz . The CPU can alternately be driven by a clock derived from user system signal lines. The clock source is selected by a jumper option on the board. A timer on the Trace Board counts the $\phi_{2}$ clock pulses during emulation and can provide the user with the exact timing of the emulation.
The Processor Board turns on an emulation when ICE-80 has received a RUN command from the MDS. It terminates emulation when a break condition is detected on the Trace Board, or the user's program attempts to access memory or I/O ports designated as nonexistent in the user system, or the user 8080 is inactive for a quarter of a second.
The Address Map located on the Processor Board stores the assigned location of each user memory or I/O block. During emulation the Processor Board determines whether to send/receive information on the MDS or User bus by consulting the Address Map. The Processor Board allows the ICE-80 CPU to gain access to the MDS bus as a master to "borrow" MDS facilities. At an emulation break, the Processor Board stores the status of specified 8080 input and output signals, disables all interaction with the user bus, and commands the Trace Board to send stored information to a Control Block in MDS memory for access during interrogation mode.

## CABLE CARD

The Cable Card is included for cable driving. It transmits address and data bus information to the user system through a 40-pin connector which plugs into the user system in the socket designed for the 8080 when enabled by the Processor Module's user bus control logic.

## SOFTWARE

The ICE-80 software driver (ICE80SD) is an MDS RAMbased program which provides the user with easy-to-use English language commands for defining breakpoints, initiating emulation, and interrogating and altering user system status recorded during emulation. ICE-80 commands are configured with a broad range of modifiers which provide the user with maximum flexibility in describing the operation to be performed.
ICE80SD is available in both paper tape and diskettebased versions. The diskette-based version, which is supplied on a System Diskette for operation with the Intellec ${ }^{\circledR}$ MDS Diskette Operating System, provides expanded capabilities for retrieving and storing user programs, as well as the standard MDS peripherals available in the paper tape version.

EMULATION COMMANDS:
GO
STEP

RANGE Delimits blocks of instructions for which register dump or tailored diagnostics are to occur.
$\begin{array}{ll}\text { CONTINUE } & \text { Resume real-time emulation. } \\ \text { CALL } & \text { Emulate user system interrupt. }\end{array}$

## INTERROGATION COMMANDS:

BASE Establish mode of display for output data.
DISPLAY Print contents of memory, 8080 registers, input ports, 8080 flags, 8080 pins, snap data, symbol table, or other diagnostic data on list device. Can also be used for base-to-base conversion, or addition or subtraction in any base.

CHANGE

XFORM
SEARCH

Alter contents of memory, register, output port, or 8080 flag.
Define memory and I/O status.
Look through memory range for specified value.

## UTILITY COMMANDS:

LOAD

SAVE

EQUATE

FILL
MOVE

TIMEOUT Enable/disable user CPU 1/4 second wait state timeout.
LIST Define list device (diskette-based version only).
EXIT Return program control to MDS monitor.


FUNCTIONAL BLOCK DIAGRAM OF ICE-80 MODULE

## SAMPLE, ICE-80 DEBUG SESSION



1. Set up user memory and $1 / \mathrm{O}$. The program is set up to execute in block $1(1000 \mathrm{H}-1 \mathrm{FFFH})$ of user memory, and requires access to the SDK-80 monitor (block 0 ) and I/O ports in block OFH. Both ports and memory are defined as available to the user system. All other memory and I/O is initialized by ICE-80 as nonexistent (guarded).
2. A load command generates an error. The type and command numbers indicate that a data mismatch occurred on a write to memory command. The data to be written to address 1320 H should have been 06 H . When ICE- 80 read the data after writing it, a 04 H was detected. A change command to a different memory address hints that bit 1 does not go to 1 anywhere in this memory block. Examination indicates that a pin was shorted on the RAM located at $1300 \mathrm{H}-13 \mathrm{FFH}$ in the prototype system. The problem is fixed and a subsequent load succeeds.
3. A real-time emulation is begun. The program is executed FROM 'START' $(1320 H)$ and continues UNTIL 'RSLT' is written (in location 1328 H , the contents of the accumulator is stored in (written into) 'RSLT').
4. An error condition results: TYPE 07, CMND 02 indicate the program accessed a guarded area.
5. The last 5 machine cycles executed are displayed. The last instruction executed was a call (CDH). The fourth and fifth cycles are a push operation (designated by status 04 H ) to store the program counter before executing the call. The stack pointer was not initialized in the program and is accessing memory location FFFFH.
6. After making a note to initialize the stack pointer in the next assembly, a temporary fix is effected by setting the stack pointer to the top of user available memory.
7. After setting the base for displays to hex and adding the symbol 'STOP' to the symbol table, emulation is started which will terminate when the instruction at 1333 H ('STOP') is executed. When emulation terminates, a DUMP of the contents of user 8080 registers is requested. One can see that the value of the accumulator is set at 40 H , the stack pointer is set at 13 FFH , the last address executed (*) is 1333 H , and the program counter has been set to 1320 H .
8. EXIT returns control to the MDS monitor.

## ICE80SD OPERATING ENVIRONMENT

## Paper Tape-Based ICE80SD

Required Hardware:
Intellec ${ }^{\circledR}$ MDS
System console
MDS Reader device
MDS Punch device
ICE-80
Required Software:
System monitor
Diskette-Based ICE80SD
Required Hardware:
Intellec ${ }^{\text {® }}$ MDS
32 K bytes RAM memory
System console
MDS-DOS Diskette Operating System
ICE-80
Required Software:
System monitor
ISIS
EQUIPMENT SUPPLIED
Printed Circuit Modules (2)
Interface Cables and Buffer Board
Hardware Reference Manual
Operator's Manual
Schematic Diagram
ICE-80 Software Driver, paper tape version
(ICE-80 Software Driver, disketted-based version is supplied with MDS Diskette Operating System)

## SYSTEM CLOCK

Crystal controlled $2.185 \mathrm{MHz} \pm 0.01 \%$. May be replaced by user clock through jumper selection.

## PHYSICAL CHARACTERISTICS

Width: $12.00 \mathrm{in} .(30.48 \mathrm{~cm})$
Height: $6.75 \mathrm{in} .(17.15 \mathrm{~cm})$
Depth: 0.50 in . $(1.27 \mathrm{~cm})$
Weight: $8.00 \mathrm{lb}(3.64 \mathrm{~kg})$

## ELECTRICAL CHARACTERISTICS

## DC Power:

$V_{C C}=+5 \mathrm{~V}, \pm 5 \%$
$\mathrm{I}_{\mathrm{CC}}=9.81 \mathrm{~A}$ maximum; 6.90A typical
$V_{D D}=+12 \mathrm{~V}, \pm 5 \%$
$I_{D D}=79 \mathrm{~mA}$ maximum; 45 mA typical
$V_{B B}=-9 \mathrm{~V}, \pm 5 \%$
$I_{B B}=1 \mathrm{~mA}$ maximum; $1 \mu \mathrm{~A}$ typical

## ENVIRONMENTAL CHARACTERISTICS

Operating Temperature: $0^{\circ} \mathrm{C}$ to $40^{\circ} \mathrm{C}$
Operating Humidity: Up to $95 \%$ relative humidity without condensation
CONNECTORS
Edge Connector: CDC VPB01E32A00A1
ORDERING INFORMATION

## Part Number Description

MDS-80-ICE 8080 CPU In-Circuit Emulator. Cable Assembly and Interactive Software included

## UPP UNIVERSAL PROM PROGRAMMER

Intellec ${ }^{\circledR}$ MDS peripheral capable of programming the following Intel ${ }^{\circledR}$ PROMs: 1702A, 2704, 2708, 3601, 3604, 3624, 8702A, 8704 and 8708
Personality cards used for specific Intel ${ }^{\circledR}$ PROM programming requirements
Zero insertion force sockets for both 16 -pin and 24-pin PROMs

Flexible power source for system logic and programming pulse generation

## PROM programming verification facility

Stand-alone or rack-mountable

The Universal PROM Programmer is an Intellec MDS peripheral capable of programming and verifying the following Intel PROMs: 1702A, 2704, 2708, 3601, 3604, 3624, 8702A, 8704, and 8708. Programming and verification operations are initiated from the Intellec MDS system console and are controlled by programs resident in the Intellec MDS and Universal PROM Programmer.

The basic MDS-UPP consists of a controller module, two personality card sockets, front panel, power supplies, chassis, and an Intellec MDS interconnection cable. An Intel 4040 based intelligent controller monitors the Intellec MDS interface and controls the command generation and data transfer interface between the selected PROM personality card and the Intellec MDS. The 4040 CPU operates in conjunction with a fixed central control program residing in an Intel 4001 ROM. Each Intel PROM to be programmed is driven by a unique personality card which contains the appropriate pulse generation functions and driver circuitry. Hence, programming and verifying any Intel PROM may be accomplished by selecting and plugging in the appropriate personality card option. The front panel contains a power-on switch and indicator, reset switch, and two zero-force insertion sockets (one 16 -pin and one 24 -pin or two 24 -pin). A central power supply provides regulated power for system logic and $\pm 40$ and +70 volts for PROM programming pulse generation.

PROM programming commands are initiated from the Intellec MDS system console and are implemented by programs in the Intellec MDS. The desired PROM image is loaded into Intellec MDS RAM through a user selected input medium (e.g., TTY, diskette drive, high speed paper tape reader). Next, the PROM programming command is issued specifying the location of the programming data, the socket option, the "nibble" option (upper or lower four bits of an 8-bit RAM data byte), and PROM starting address. The PROM programming algorithm programs each specified PROM location, compares the resulting PROM word with the source data, and regenerates program pulses when necessary. The Intellec MDS system monitor contains a compare feature which allows specified sections of programmed PROM to be compared with MDS resident RAM. A transfer feature which can be used to copy the contents of a PROM to MDS RAM for PROM duplication is also included.

The Universal PROM Programmer may be used as a table top unit or mounted in a standard 19" RETMA cabinet.


## SPECIFICATIONS

## INTERFACE

Data: Two 8-bit unidirectional buses
Commands: 3 Write Commands
2 Read Commands
Initiate Command

## AVERAGE PROGRAMMING TIME

1702A/8702A: 40 seconds
2708/8708: $\quad 5$ minutes
3601: 2 seconds
3604: $\quad 10$ seconds
3624: $\quad 10$ seconds
2704/8704: 2.5 minutes
PHYSICAL CHARACTERISTICS
Dimensions: $6^{\prime \prime} \times 7^{\prime \prime} \times 17^{\prime \prime}$
$14.7 \mathrm{~cm} \times 17.2 \mathrm{~cm} \times 41.7 \mathrm{~cm}$
Weight: $18 \mathrm{lb}(8.2 \mathrm{~kg})$
ELECTRICAL CHARACTERISTICS
DC Power Supplies:

| Voltage | Current |
| ---: | :--- |
| 5 V | 2.5 A |
| -10 V | 0.75 A |
| $\pm 40 \mathrm{~V}$ | 0.5 A |
| 70 V | 0.4 A |

AC Power Requirements:
$50-60 \mathrm{~Hz} ; 115 / 230$ VAC; 80 Watts

## ENVIRONMENTAL CHARACTERISTICS

Operating Temperature: $0^{\circ}$ to $70^{\circ} \mathrm{C}$.

## OPTIONS

Personality Cards:
MDS-UPP-361:3601 Personality Card
MDS-UPP-864:8604/3604/3624 Personality Card
MDS-UPP-872:8702A/1702A Personality Card
MDS-UPP-878:8708/8704/2708/2704 Personality Card
PROM Programming Sockets:
MDS-UPP-501: 16-pin/24-pin pair
MDS-UPP-502: 24-pin/24-pin pair

## EQUIPMENT SUPPLIED

Cabinet
Power Supplies
4040 Intelligent Controller Module
Specified Zero Insertion Force Socket Pair
Intellec MDS Interface Cable
Hardware Reference Manual
Reference Schematics

## $\mu$ SCOPE $^{\text {M }} 820$ <br> MICROPROCESSOR SYSTEM CONSOLE

Provides an interface to microcomputer systems for troubleshooting system problems

Monitors, displays, and alters register, memory and $\mathrm{I} / \mathrm{O}$ values for system under test

Executes diagnostic routines from $\mu$ Scope 820 console overlay memory

Executes instrument resident software patch routines even when microcomputer system is ROM-based

Provides a 32-bit hardware breakpoint with bit masking and a 256 -word trace memory

Is a stand-alone, self-contained, rugged portable unit

Human engineered with easy to read 9 -segment hexadecimal displays and extensive operator prompting

Gives complete control over microprocessor including single step, run with display, or run real-time capability

Designed to support many different microprocessors

## Has built-in, self-test operation

The $\mu$ Scope ${ }^{T M} 820$ Microprocessor System Console is a portable, self-contained instrument designed to provide the control, monitoring, and interaction necessary to effectively and quickly evaluate and debug 8 -bit microcomputer-based systems in the lab, on the production line, or in the field. Connection to the user's system is through a personality probe that is plugged into the microprocessor socket. Each personality probe is unique to each microprocessor type. The instrument features many different operating and control modes which allow the operator to carry out a number of functional checks on the microcomputer System Under Test (SUT).

The unit has been specificially designed to ease the task of microcomputer system check-out for the lab, production line, and field technician. It also provides the more powerful analytical capabilities necessary to troubleshoot difficult problems by the more experienced, sophisticated user. Preprogrammed test routines resident in front panel PROMs, dedicated high level command keys, visual prompting, and simplified data entry sequences all ease the check-out of microcomputer hardware. For more rigorous diagnostic tasks, the unit provides a 32 -bit maskable hardware breakpoint with optional course of action after a breakpoint match, a $256 \times 32$-bit trace memory and a $128 \times 8$ overlay RAM that allows real-time entry of test routines via the $\mu$ Scope 820 Microprocessor System Console keyboard.


## CPU CONTROL

The instrument provides complete control over the operation of the microprocessor in the System Under Test (SUT). The user CPU can be forced to HALT, SINGLE STEP, RESET, RUN REAL TIME, or RUN WITH DISPLAY. All of the above CPU commands can be issued without impacting other operational parameters or diagnostic sequences that have been set up.

## ADDRESS DISPLAY/SELECT

A dedicated, 4-digit hexadecimal address display allows the following address information to be displayed:

- The address of any memory location.
- The I/O port number of any I/O port.
- The address of any overlay memory location.
- The address of the overlay memory origin assignment.
- The address at which the breakpoint is to occur.
- The address portion of the breakpoint mask.
- The address of the given trace record element.

An additional feature of the address display/select logic is that once the operator has initiated a given memory, trace, or I/O examination, it is possible to continue the examination in a sequential fashion either in an ascending or descending address value.

## RESET/SELF-TEST

The RESET and SELF-TEST features of the unit allow the operator to either initialize the instrument to a known state or quickly verify that the instrument is operating correctly. When the console is RESET, the breakpoint and overlay memory are disabled, the display registers are cleared and the specific examine modes are aborted.
When the operator initiates the SELF-TEST of the unit, a sequence of operations take place which serve to confirm proper operation of a majority of the instrument.

## BREAKPOINT CONTROL

The hardware breakpoint of the instrument allows the operator to alter the normal program flow of the SUT. Breakpoint logic is implemented in hardware, thereby eliminating any throughput degradation of the SUT. All 32 bits of the breakpoint condition word are maskable in order to allow the breakpoint condition to be as specific or as general as may be desired.
The occurrence of a breakpoint match can cause an unconditional halt, incrementing of the pass counter, calling of a subroutine, or the recording of a single cycle of trace data. All of these options are selectable via the EXAM ACTION key prior to enabling the breakpoint.

## TRACE MEMORY

The console has a full 32 -bit word trace memory that records 256 cycles of SUT operation without causing any delays. The trace memory provides information about CPU operation just prior to a CPU halt or just prior to the initiation of a panel freeze via the trace DISPLAY key.

The operator can alternatively elect to have data recorded on all SUT microprocessor cycles or only when program execution of the SUT microprocessor generates a breakpoint match. Once the data is recorded, sequential examination of the data can be accomplished simply by depressing the EXAM NEXT or EXAM LAST keys.


## VALUE DISPLAY/SELECT

The value displays provide clear and easy to use informa tion. Together with the address display, they provide simultaneous readout of trace vectors, breakpoint conditions and breakpoint mask values, memory contents and I/O port contents. In addition, the display allows readout of all single and double byte register values, the state of CPU pins and flags, information regarding the course of action following the occurrence of a breakpoint, as well as information regarding the breakpoint pass count.

The information displayed by the 4-digit hexadecimal value readouts is selected via the hexadecimal keypad in conjunction with any of the instrument's 11 dedicated examine keys. Further, the information is either displayed statically or is continually updated 10 times $/ \mathrm{sec}$ if the unit is in the run with display mode.
|IIIL/IIIIIIIIIIII1.11|II


944




## uscope 820



PROM/ROM SOCKET
A front panel socket is provided for mounting 2K PROMs or ROMs that serve as storage for preprogrammed test subroutines. The actual useable program space of the PROM/ROM is 1920 bytes. The remaining 128 bytes of storage, shadowed by RAM, are used by the unit to identify up to 16 separate subroutines in the PROM/ROM and to define the specific instrument states and conditions under which the subroutine will be called. Each of the separate subroutines is uniquely enabled by the SUBR SELECT key and the hex keypad.

## POWER SUPPLY

The system console is complete with its own fully regulated DC power supply that provides all the DC power required by the unit itself, as well as that which is required by the associated microprocessor probe. The supply is completely self-contained, including its own AC on/off switch, line fuse, line filter and power cord. An additional feature of the power supply is that it has been designed to permit line voltage selection in the field to facilitate operation with a wide range of $A C$ line voltages and frequencies.

## BREAKPOINT ACTION

Following the occurrence of a breakpoint match, the operator has the flexibility to execute a number of different diagnostic operations. The selection of these alternate courses of action is accomplished by pushing the EXAM ACTION key and then entering the assigned value of the specific action desired via the hex keypad. Further keypad entries specify the parametric value of the action selected such as the number of breakpoint pass counts or the start address of a subroutine call following a breakpoint.

## PROBE CONNECTION

The instrument is intended to work with many of the microprocessors that are available today. This is accom plished by standardized interface logic which transmits and receives various address, data, and control signals between the system console and the circuitry of the particular probe. The interconnect circuitry between the instrument and probe has been designed to drive a 6 -foot cable that permits convenient positioning of the panel and the SUT.

In addition, a board edge connector has been provided for a personality ROM that provides front panel definition and interpretation of specific control signals for different types of microprocessors. This personality ROM is supplied with each probe kit.

BINARY DATA DISPLAY/MODIFICATION
All 8-bit values can be displayed in binary format on the instrument. The binary display operates in parallel with the hexadecimal display and it is provided for those instances where operator recognition is enhanced by binary presentation. The selection procedure for the binary data display is identical to that for the hexadecimal value display. Once the selection has been made, the operator can alter the value by means of further hex keypad entries or by changing the binary state of any of the data bits via the 8 binary data switches.

FRONT PANEL
The front panel of the $\mu$ Scope $^{\text {TM }} 820$ Microprocessor System Console has been designed to be rugged and durable as well as easy to use and understand. A plastic overlay that employs membrane switch contacts provides long lasting durability as well as protection from accidental spills. Audio and tactile feedback for the membrane switches is provided for operator convenience.
Ease of use of the front panel has been further enhanced by human engineering with functional grouping of switches as well as LEDs that prompt the operator during data entry sequences. Graphics have also been added to reinforce the functional switch groupings as well as data entry procedures.

## CHARACTERISTICS

## COMMANDS

## Reset

Self Test
CPU Reset
Run Real Time
Run with Display
Halt
Single Step
Enable/Disable Breakpoint
Enable/Disable Overlay
Enable Trace All Cycles
Enable Trace at Breakpoint
Examine/Modify Value

> - Single Registers

- Double Registers
- CPU States
- Breakpoint Pass Count

Examine/Modify Memory
Examine/Modify I/O
Examine/Modify Overlay Memory
Examine/Modify Next Location
Examine/Modify Last Location
Examine/Modify Breakpoint Condition
Examine/Modify Breakpoint Mask
Examine/Modify Breakpoint Action
Examine/Modify Overlay Origin
Display Trace Data
Clear Entry
Continue
End/Execute
Subroutine Select

## CPU CONTROLS

User-selectable commands permit one of four possible CPU operating modes

1. Run Real Time - User's CPU runs at full speed set by user clock. No wait states or cycle stealing are required.
2. Run with Display -- User's CPU runs at full speed, except that 10 times $/ \mathrm{sec}$ the instrument halts user's CPU temporarily to acquire display data. Worse case throughput is $95 \%$ of real time operation.
3. Halt - User CPU halted at next opcode fetch. DMA activity is permitted during HALT.
4. Single Step - User CPU executes one instruction then halts.

## BREAKPOINT

The breakpoint condition is set by a 32 -bit word (16-bit address, 8 -bit data, 8 -bit status). The breakpoint mask is also set by a 32 -bit word which is bit-selectable. There are three courses of action following a breakpoint match:

1. Halt on first opcode fetch following breakpoint match.
2. Halt on first opcode fetch following Nth breakpoint match $1 \leqslant N \leqslant 256$.
3. Execute subroutine beginning at first opcode fetch following breakpoint match.
All breakpoint actions following a match is controlled by the breakpoint enable/disable switch except for trace recording and the sync trigger output. The sync output is a positive true TTL output that occurs whenever a breakpoint match occurs.
```
Pulse Width = 50 nsec typ
Output High = 2.5V min, -1.2 mA
Output Low = 0.5V max, 24.0 mA
```


## trace

The trace memory is a 256 -word memory with each word consisting of 16 address bits, 8 data bits and 8 status bits. The memory is a circular buffer which records the last 256 cycles (words) prior to a user CPU halt or DISPLAY TRACE command. Trace data can be recorded on all CPU cycles or only when breakpoint matches occur (independent of breakpoint enable/disable status). In addition, the operator can initiate a panel freeze which temporarily stops all trace data recording, and allows display of previously recorded data without halting the user CP .

## DATA ENTRY

All single and double byte items can be entered via the front panel hexadecimal keypad. In addition, all single byte items can be optionally entered via eight binary input keys.

## MEMORY OVERLAY

The $\mu$ Scope ${ }^{\text {TM }} 820$ Microprocessor System Console allows memory read/writes of the user CPU in any assigned 1 K or 2 K block to be made to the instrument's overlay memory. For 1 K block assignments, the first 128 bytes reside in the instrument's RAM memory while the remaining 896 bytes reside in the interchangeable front panel ROM/EPROM (either Intel's 2716 EPROM or Intel's 2316E ROM). For 2 K block assignments, again the first 128 bytes are from RAM and the remaining 1920 bytes are from the front panel 2716/2316E.

## DATA DISPLAY

Eight hexadecimal 0.5 in . LEDs are provided for the simultaneous display of 4 bytes of information. The displays are physically separated into two groups. The first group displays 2 bytes of address, while the second group displays CPU data, status, single and double byte register values, or single and double byte breakpoint values. In addition, eight binary displays are used to provide quick recognition of single byte binary data patterns.

## SELF TEST

The necessary hardware and software has been incorporated into the instrument to facilitate the self-checking of the majority of its operations. Included in these self tests are:

- Bit tests of all breakpoint condition and mask latches.
- Bit tests of all RAM.
- Verifies checksum on all operating system ROMs.
- Clears trace memory and performs bit test on trace RAM.
- Checks miscellaneous I/O ports and peripheral components.
- Lights all front panel displays for user verification.


## CONNECTION

Four external connections to the $\mu$ Scope 820 Microprocessor System Console are provided:

- 50-pin board edge connector for the microprocessor probe cable.
- 20-pin board edge connector for the probe personality PROM.
- 24-pin zero force insertion sockets for overlay EPROM/ROM.
- One recessed pin for breakpoint sync output.


## PHYSICAL CHARACTERISTICS

| Width: | 479 mm | $(18-7 / 8 \mathrm{in})$. |
| :--- | :--- | :--- |
| Length: | 394 mm | $(15-1 / 2 \mathrm{in})$. |
| Height (top closed): | 168 mm | $(6-5 / 8 \mathrm{in})$. |
| Height (top removed): | 117 mm | $(4-5 / 8 \mathrm{in})$. |
| Weight: | 9.1 kg | $(20 \mathrm{lb})$ |

## ELECTRICAL REQUIREMENTS

Voltage: $\quad 100,120,220,240-10 \%+5 \%, 110 \mathrm{VA} \max$ Frequency: $\quad 48-63 \mathrm{~Hz}$

## ENVIRONMENTAL CONDITIONS

Operating Temperature: $\quad 0^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}\left(32^{\circ} \mathrm{F}\right.$ to $\left.130^{\circ} \mathrm{F}\right)$
Storage Temperature: $\quad-40^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}\left(-40^{\circ} \mathrm{F}\right.$ to $\left.167^{\circ} \mathrm{F}\right)$ Humidity: $\quad 95 \% \mathrm{RH}, 15^{\circ} \mathrm{C}$ to $40^{\circ} \mathrm{C}\left(59^{\circ} \mathrm{F}\right.$ to $104^{\circ} \mathrm{F}$ ) non condensing

## ACCESSORIES SUPPLIED

One $2.3 \mathrm{~m}(7.5 \mathrm{ft})$ power cord
One Operator's Manual
One Hardware Reference Manual

## ORDERING INFORMATION

## Part Number Description

USC-820 Microprocessor System Console

## $\mu$ SCOPE $^{\text {M }}$ PROBE 8080A

Provides interconnection for 8080A Microproces-sor-based Systems to the $\mu$ Scope $^{\text {TM }} 820$ Microprocessor System Console

Comes complete with cable, buffer box, personality ROM, and $\mu$ Scope 820 system console overlay

Has user system interconnect cable with integral ground plane for low noise operation

Includes a 6-foot cable for convenient positioning of $\mu$ Scope 820 console

Operates over a broad range of environmental conditions

Provides complete control over the system under test, yet causes minimal interference with system under test operation

Fits securely in the console carrying case during transit

Provides complete protection for plug pins during transit

The probe 8080A provides the $\mu$ Scope 820 console with the ability to interact with 8080A Microcomputer-based Systems. The purpose of the probe is to interface the $\mu$ Scope 820 console to the CPU of the System Under Test (SUT). All of the interface signals and the associated circuitry have been designed to be effectively transparent to the SUT. CPU data, address, and clock lines are sensed by the probe 8080A, with only the CPU control lines being switched. In addition, all SUT loading and timing degradations have been minimized by specially designed buffer circuitry.
The mechanical design of the probe is compact, rugged, and allows proper operation of the probe and the console over the full ambient range specified. The buffer circuitry and the ground plane design of the interconnect cable provide low noise electrical signals while allowing the SUT to be 6 feet from the system console.


## GENERAL

## $\mu$ SCOPE 820 CONSOLE INTERCONNECT

The probe interconnection to the $\mu$ Scope 820 console is accomplished via a $1.8 \mathrm{~m}(6 \mathrm{ft})$ flat cable. $50-\mathrm{pin}$ mating connectors plug into a board edge connector in the power cord compartment of the instrument and into a flat cable connector on the buffer box.

## SYSTEM UNDER TEST (SUT) INTERCONNECT

Interconnection from the buffer box to the SUT is accomplished with a 305 mm (12 in.) flat cable, complete with an integral ground plane, which is terminated with a low profile 40-pin DIP connector. The DIP connector is inserted into the SUT 8080A socket and the 8080A itself is plugged into the $40-\mathrm{pin}$ socket provided on the probe buffer box.

## $\mu$ SCOPE 820 CONSOLE CONFIGURATION

Several features of the console are directly determined by the probe being used with it. The instrument features that are determined by the 8080A interface probe are:

- Single Registers: A, B, C, D, E, H, L
- Double Registers: BC, DE, HL, PC, SP
- CPU States: Flags, CPU pins (SYNC, RESET, HLDA, HOLD, READY, INT, INTE)
- Trace/Breakpoint Word Size: 32 bits with 16 bits of address, 8 bits of data and 8 bits of CPU status.


## ELECTRICAL SPECIFICATIONS

All DC specifications are in addition to user system parameters. All capacitance values include cables and connectors.

## Non-Intercepted Signals

$\phi 1, \phi 2$
$\pm 10 \mu \mathrm{~A}$ max; 55 pF typical
$A_{15}-A_{0}, D_{7}-D_{0}$
$-0.25 \mathrm{~mA} \max @ 0.45 \mathrm{~V}$; $10 \mu \mathrm{~A}$ max @ $5.25 \mathrm{~V} ; 45 \mathrm{pF}$ typical
+12V Supply
WAIT

$$
15 \mu \mathrm{~A} \max
$$

35 pF typical (capacitive loading only)

## Intercepted Signals

Outputs to user system:

$$
\begin{array}{ll}
\text { SYNC } & 20 \mathrm{~mA} \mathrm{~min} @ 0.5 \mathrm{~V} ;-1 \mathrm{~mA} \min @ \\
& 2.7 \mathrm{~V} ; 40 \mathrm{pF} \text { typical } \\
\text { HOLDA, INTE, } & 4 \mathrm{~mA} \mathrm{~min} @ 0.4 \mathrm{~V} ;-0.2 \mathrm{~mA} \min @ \\
\text { DBIN, and } \overline{W R} & 2.7 \mathrm{~V} ; 40 \mathrm{pF} \text { typical }
\end{array}
$$

Inputs from user system:

| INT, READY, | $40 \mu \mathrm{~A} \max @ 2.7 \mathrm{~V} ;-0.72 \mathrm{~mA} \max @$ |
| :--- | :--- |
| RESET | $0.4 \mathrm{~V} ; 50 \mathrm{pF}$ typical |
| HOLD | $60 \mu \mathrm{~A} \max @ 2.7 \mathrm{~V} ;-1.08 \mathrm{~mA} \max @$ |
|  | $0.4 \mathrm{~V} ; 50 \mathrm{pF}$ typical |

## CONNECTIONS

Three external connections to the probe are provided:

- 50-pin flat cable connector on buffer box
- 40-pin zero insertion socket for the 8080A
- 40-pin low profile replaceable IC DIP connector for connection to SUT


## CHARACTERISTICS

## PHYSICAL CHARACTERISTICS

Probe Buffer Box:

| Height: | 19 mm | (3/4 in.) |
| :--- | ---: | :--- |
| Length: | 184 mm | (7-1/4 in.) |
| Width: | 95 mm | (3-3/4 in.) |

User System Interconnect Cable:
Width: $\quad 57 \mathrm{~mm}(2-1 / 4 \mathrm{in}$.)
Length: 381 mm ( 15 in .) flat cable
$\mu$ Scope 820 Console Personality ROM PC Card:

| Height: | 19 mm | (3/4 in.) |
| :--- | :--- | :--- |
| Width: | 57 mm | $(2-1 / 4 \mathrm{in})$. |
| Length: | 86 mm | $(3-1 / 4 \mathrm{in})$. |

## POWER REQUIREMENTS

Power supplied by $\mu$ Scope ${ }^{\text {TM }} 820$ Microprocessor System Console.

## ENVIRONMENTAL CONDITIONS

Operating Temperature: $0^{\circ}$ to $55^{\circ} \mathrm{C}\left(32^{\circ}\right.$ to $\left.130^{\circ} \mathrm{F}\right)$
Storage Temperature: $\quad-40^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}\left(-40^{\circ}\right.$ to $\left.167^{\circ} \mathrm{F}\right)$
Humidity:
$95 \% \mathrm{RH}, 15^{\circ}$ to $40^{\circ} \mathrm{C}\left(59^{\circ}\right.$ to $104^{\circ} \mathrm{F}$ ) noncondensing

## ACCESSORIES SUPPLIED

One $\mu$ Scope 820 System Console Overlay
One Personality ROM
One Hardware Reference Manual

## ORDERING INFORMATION

| Part Number | Description |
| :--- | :--- |
| PRB-80 | 8080A Interface Probe |

Chapter 8

## GENERAL INFORMATION



Semiconductor components are identified as follows:

## Example:



## Examples:

P5101L CMOS $256 \times 4$ RAM, low power selection, plastic package, commercial temperature range.
C8080A2 8080A Microprocessor with $1.5 \mu$ s cycle time, hermetic package Type C, commercial temperature range.
MD3604/C $512 \times 8$ PROM, hermetic package Type D, military temperature range, MIL-STD-883 Level C processing.*

MC8080A/B 8080A Microprocessor, hermetic package Type C, military temperature range, MIL-STD-883 Level B processing.*

Kits, boards and systems may be ordered using the part number designations in this catalog.
The latest Intel OEM price book should be consulted for availability of various options. These may be obtained from your local Intel representative or by writing directly to Intel Corporation, 3065 Bowers Avenue, Santa Clara, CAlifornia 95051.
*On military temperature devices, B suffix indicates MIL-STD-883 Level B processing. Suffix C indicates MIL-STD-883 Level $C$ processing. " $S$ " number suffixes must be specified when entering any order for military temperature devices. All orders requesting source inspection will be rejected by Intel.

## PLASTIC DUAL IN-LINE PACKAGE TYPE P

16-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


18-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


22-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


## PLASTIC DUAL IN-LINE PACKAGE TYPE P

## 24-LEAD PLASTIC DUAL IN-LINE

 PACKAGE TYPE P

28-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


40-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


## CERAMIC DUAL IN-LINE PACKAGE TYPE D

16-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D


18-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D


22-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D


## CERAMIC DUAL IN-LINE PACKAGE TYPE D



28-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D



40-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D


## CERAMIC DUAL IN-LINE PACKAGE TYPE C

16-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


18-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


22-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


CERAMIC DUAL IN-LINE PACKAGE TYPE C
24-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


28-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


40-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


## CERAMIC DUAL IN-LINE PACKAGE TYPE B

22-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE B


24-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE B


## INTEL MILITARY PRODUCTS IC 38510 PROGRAM


#### Abstract

Intel offers selected products in full conformance with requirements for military components. Effort is underway by agencies of the Department of Defense with full Intel cooperation to establish "JAN" standards for several of our products. Intel has led these standards by emulating the anticipated "JAN" processing and lot acceptance requirements with the Intel in-house IC 38510 Program. Intel Specifications are available which document general and detailed requirements for each of the military products. Detail specifications are organized by generic family and provide all information necessary for non-standard parts submissions in accordance with MIL-STD-749, Step I, Step II, and Step III. These documents are available from your local Intel Sales Office or authorized Intel Distributor. Three levels of product assurance are offered: Level B, Level C, and Military Temperature Only. The Military Temperature level products have guaranteed operating characteristics over the specified temperature range and have undergone Intel's rigid product assurance requirements. Level C and Level B products are in conformance with MIL-STD-883, Method 5004 requirements, and in addition, have a specified maximum rebond criteria ( $10 \%$ ) and a specified burn-in PDA $(10 \%)$, all documented in the detail specifications, consistent with 38510 requirements. Lot conformance tests are performed in accordance with MIL-STD-883A, Method 5005.


## Available now.

Qualification in progress. Check with local Intel Sales Office or Distributor for availability.

MC8080A
MB8101A
MD8102A-4
MD8111A
MD8212
MD8214
MD8216
MD8224
MD8226
MD8228
MD8251
MD8255
MD8316A
MC8702A
MC8708

MD8238
MD8253
MD8259
MD8316E
MC8748
MC8755

LEVEL B AND C MILITARY PRODUCTS MANUFACTURING FLOW


MILITARY PRODUCTS MANUFACTURING FLOW (Cont'd)


| *Outgoing Acceptance (Plant Clearance) | Inspections: |  |
| :--- | :---: | :---: |
| $\frac{\text { Test }}{}$ | $\frac{\text { LTPD }}{2}$ | $\frac{\text { ACC }}{2}$ |
| 1. Hermeticity | 5 | 2 |
| 2. Centrifuge | 5 | 2 |
| 3. X-Ray | 7 | 1 |
| 4. Lead Fatigue | 20 | 0 |
| 5. Acoustic (Loose Particles) AQL $=.04 \%$ |  |  |


| ** Incoming Inspection Testing: |  |  |
| :--- | :---: | :---: |
| Test | $\frac{\text { LTPD }}{}$ | $\frac{\text { ACC }}{1}$ |
| 1. X-Ray, Die Attach and <br> Seal Quality | 7 | 1 |
| 2. External Visual | 7 | 1 |
| 3. Opens and Shorts | 7 | 1 |
| 4. Hermeticity | 7 | 1 |
| 5. Lead Fatigue | 20 | 0 |
| 6. Internal Visual | 10 | 0 |
| 7. Bond Pull | 7 | 1 |
| 8. Acoustic (1000 Particles) AQL $=.04 \%$ |  |  |



NOTES: 1. DDD or SSS - $000 \mathrm{~B}-001 \mathrm{C}-010 \mathrm{D}-011 \mathrm{E}-100 \mathrm{H}-101 \mathrm{~L}-110$ Memory - 111 A .
2. Two possible cycle times, $(5 / 11)$ indicate instruction cycles dependent on condition flags.

Summary of Processor Instructions
By Alphabetical Order

|  |  | Instruction Code ${ }^{11}$ |  |  |  |  |  | $\mathrm{D}_{1} \quad \mathrm{D}_{0} \quad \begin{gathered}\text { Clock } \\ \\ \text { Cl2 } \\ \text { Cyclas }\end{gathered}$ |  |  | Mnemonic | Description | Instruction Coda [1] |  |  |  |  |  |  |  | Clock ${ }^{[2]}$ Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Description | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ |  |  |  | D7 |  | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $D_{1}$ | $\mathrm{D}_{0}$ |  |
| ACl | Add immediate to A with | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |  |  | Move immediate memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 |
|  | carry |  |  |  |  |  |  |  |  |  | MVIr | Move immediate register | 0 | 0 | D | D | D | 1 | 1 | 0 | 7 |
| ADC M | Add memory to A with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 7 | MOV M, r | Move register to memory | 0 | 1 | 1 | 1 | 0 | S | S | S | 7 |
| $A D C r$ | Add register to $A$ with carry | 1 | 0 | 0 | 0 | 1 | S | S | S | 4 | MOVr, M | Move memory to register | 0 | 1 | D | D | D | 1 | 1 | 0 | 7 |
| ADD M | Add memory to $A$ | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 7 | MOV ${ }_{\text {r1, } 22}$ | Move register to register | 0 | 1 | 0 | D | 0 | S | S | 5 | 5 |
| ADD r | Add register to $A$ | 1 | 0 | 0 | 0 | 0 | S | S | S | 4 | NOP | No-operation | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
| ADI | Add immediate to A | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 7 | ORAM | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| ANA M | And memory with $A$ | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 | ORA | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S | S | 4 |
| ANA ${ }^{\text {r }}$ | And register with $A$ | 1 | 0 | 1 | 0 | 0 | S | S | S | 4 | ORI | Or immediate with A | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 |
| ANI | And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 | OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| CALL | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 17 | PCHL | H \& L to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 5 |
| CC | Call on carry | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 11/17 | POPB | Pop register pair B \& C off | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |
| CM | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 11/17 |  | stack |  |  |  |  |  |  |  |  |  |
| CMA | Compliment A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 4 | POP D | Pop register pair D \& E off | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 |
| CMC | Compliment carry | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |  | stack |  |  |  |  |  |  |  |  |  |
| CMP M | Compare memory with A | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 7 | POP H | Pop register pair H \& L off | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |
| CMP r | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | S | S | 4 |  | stack |  |  |  |  |  |  |  |  |  |
| CNC | Call on no carry | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 11/17 | POP PSW | Pop A and Flags | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |
| CNZ | Call on no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 11/17 |  | off stack |  |  |  |  |  |  |  |  |  |
| CP | Call on positive | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 11/17 | PUSH B | Push register Pair B \& C on | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 11 |
| CPE | Call on parity even | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 11/17 |  | stack |  |  |  |  |  |  |  |  |  |
| CPI | Compare immediate with A | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 7 | PUSH D | Push register Pair D \& E on | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 11 |
| CPO | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 11/17 |  | stack |  |  |  |  |  |  |  |  |  |
| CZ | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 11/17 | PUSH H | Push register Pair H \& L on | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 11 |
| DAA | Decimal adjust $A$ | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |  | stack |  |  |  |  |  |  |  |  |  |
| DAD B | Add B \& C to H \& L | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 | PUSH PSW | Push A and Flags | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 11 |
| DAD D | Add D \& E to H \& L | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 10 |  | on stack . |  |  |  |  |  |  |  |  |  |
| DAD H | Add H\&L to H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 | RAL | Rotate A left through carry | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 |
| DAD SP | Add stack pointer to H \& L | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 | RAR | Rotate $A$ right through | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 |
| DCR M | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 |  | carry |  |  |  |  |  |  |  |  |  |
| DCR r | Decrement register | 0 | 0 | D | 0 | D | 1 | 0 | 1 | 5 | RC | Return on carry | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 5/11 |
| DCX B | Decrement B \& C | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 5 | RET | Return | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| DCX D | Decrement D \& E | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 5 | RLC | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 4 |
| DCXH | Decrement H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 5 | RM | Return on minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 5/11 |
| DCX SP | Decrement stack pointer | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 5 | RNC | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 5/11 |
| DI | Disable Interrupt | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 | RNZ | Return on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 5/11 |
| El | Enable Interrupts | 1. | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 | RP | Return on positive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 5/11 |
| HLT | Halt | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 | RPE | Return on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 5/11 |
| IN | Input | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 | RPO | Return on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 5/11 |
| INR M | Increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 | RRC | Rotate A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 |
| INR r | Increment register | 0 | 0 | D | D | D | 1 | 0 | 0 | 5 | RST | Restart . | 1 | 1 | A | A | A | 1 | 1 | 1 | 11 |
| INX B | Increment B \& C registers | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 5 | RZ | Return on zero | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 5/11 |
| INX D | Increment D \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 5 | SBB M | Subtract memory from A | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| INXH | Increment H \& L registers | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 5 |  | with borrow |  |  |  |  |  |  |  |  |  |
| INX SP | Increment stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 5 | SBB r | Subtract register from A | 1 | 0 | 0 | 1 | 1 | S | S | S | 4 |
| JC | Jump on carry | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 10 |  | with borrow |  |  |  |  |  |  |  |  |  |
| JM | Jump on minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 10 | SBI | Subtract immediate from A | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 10 |  | with borrow |  |  |  |  |  |  |  |  |  |
| JNC | Jump on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 10 | SHLD | Store H \& L direct | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 |
| JNZ | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 10 | SPHL | $H \& L$ to stack pointer | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 5 |
| JP | Jump on positive | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 10 | STA | Store A direct | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 |
| JPE | Jump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 10 | STAX B | Store A indirect | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 7 |
| JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 10 | STAX́ D | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 7 |
| JZ | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 10 | STC | Set carry | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| LDA | Load A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 | SUB M | Subtract memory from A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| LDAX B | Load A indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 7 | SUB r | Subtract register from A | 1 | 0 | 0 | 1 | 0 | S | S | S | 4 |
| LDAX D | Load A indirect | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 7 | SUI | Subtract immediate from A | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| LHLD | Load H \& L direct | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 | XCHG | Exchange D \& E, H \& L | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 |
| LXIB | Load immediate register | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 |  | Registers |  |  |  |  |  |  |  |  |  |
|  | Pair B \& C |  |  |  |  |  |  |  |  |  | XRAM | Exclusive Or memory with A | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| LXID | Load immediate register | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 | XRA ${ }^{\text {r }}$ | Exclusive Or register with A | 1 | 0 | 1 | 0 | 1 | S | S | S | 4 |
|  | Pair D \& E |  |  |  |  |  |  |  |  |  | XRI | Exclusive Or immediate with | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 |
| LXIH | Load immediate register | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 10 |  | A |  |  |  |  |  |  |  |  |  |
|  | Pair H \& L |  |  |  |  |  |  |  |  |  | XTHL | Exchange top of stack, H \& L | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 18 |
| LXI SP | Load immediate stack pointer | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 10 |  |  |  |  |  |  |  |  |  |  |  |

NOTES: 1. DDD or SSS - $000 \mathrm{~B}-001 \mathrm{C}-010 \mathrm{D}-011 \mathrm{E}-100 \mathrm{H}-101 \mathrm{~L}-110$ Memory - 111 A .
2. Two possible cycle times, ( $5 / 11$ ) indicate instruction cycles dependent on condition flags.

Notes


| EUROPEAN MARKETING OFFICES |  |
| :---: | :---: |
| belgium | france |
| Inter ${ }^{\text {International* }}$ | ${ }_{\substack{\text { Intel Corporation, S.A.R.L. } \\ 5 \text { Place de la Belance }}}$ |
| 51-Boite 9 \% ${ }^{\text {a }}$ | c 223 |
| B-1160 Brussels |  |
| (02) 6603010 | Tel: (01) 68722 |
| TELEX: 24814 | TEL.EX: 270475 |



| 474 Thurston Road Tel: (716) 328-7340 TWX:510-253-3841 -Squared 4054 Newcourt Avenue Syracuse 13206 Tel: (315) 463-8592 TWX: $710-541-0554$ T-Squared 642 Kreag Road P.O. Box W Pittsford 14534 Tel: (716) 248-5005 TELEX: $97-8289$ Intel Corp. 85 Market Street Poughkeepsie 12601 Tel: (914) 473-2303 Tel: (914) 473-2303 TWX: 510-248-0060 $\qquad$ <br> Ter: (516) 482-3500 <br> MORTH CAROLINA Pen-Tech Associates, Inc. P.O. Box 5382 <br> Highpoint 27262 Tei: (919) 883-9125 <br> Glen White Associates 3700 Computer Drive <br> Suite Raleigh Tel: <br> aleigh 27609 <br> OH H Intel Cor Cor <br> 8312 North Main Street Dayton 45415 <br> Tel: (513) 890-5350 TWX: 810-450-2528 <br> Intel Corp. Chagrin-Brainard Bldg 28001 Chagrin Bid <br> 28001 Chagrin Blvd. Cleveland 44122 Tel (218) $464-2738$ <br> Lowry \& Assoclates, In 42 East Rahn Road <br> Dayton 45429 Tel: (513) 435 <br> Lowry \& Associates, I <br> Suite 146 Cleveland 44122 Tel: (216) 464-8113 <br> OREGON <br> ES/Chase Company 4095 SW 144th St. <br> Tel: (503) 641-4111 <br> PENNSYLVANIA <br> 275 Commerce Dr. <br> Fort Washington 19034 Tel: (215) 542-9444 TWX: $510-681-2077$ <br> Q.E.D. Electronics 300 N. York Road Hatboro 19040 <br> Tel: (215) 674-9600 |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |



|  |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |


GERMANY
Intel Semicon
intel Semicender anis.









MICROCOMPUTER AND MEMORY COMPONENT SALES AND MARKETING OFFICES




3065 Bowers Avenue Santa Clara, California 95051
U.S. AND CANADIAN DISTRIBUTORS
el: (408) 987-8080
TELEX: 34-6372

## U.S. AND CANADIAN DISTRIBUTORS

*Hamilton/Avnet Electronics 305 Oser Drive NW
Huntsville 35805
Tel: (205) $533-1170$
1207 Put
1207 Putman Drive NW Tel: (205) 837-9300

## ARIZONA

$\dagger^{*}$ Hamilton/Avnet Electronics
8155 North 21 st Street hoenix 85021 el: (602) 275-785 Liberty/Arizona
8155 N .24 th A Phoenix 85021 Tel: (602) 257-1272
TELEX: 910-951-4282

## CALIFORNIA

$\dagger^{\star}$ Avnet Electronics
Costa Mesa 92626
Tel: (714) $754-6111$
Tel: (714)
Tei: (213)
$558-2345$
** Hamilton/Avnet Electronics
575 E. Middlefield Roed 75 E. Middlefield Road Tel: (415) 961-8600
$\dagger$ *Hamilton/Avnet Electronics 8917 Complex Drive San Diego 92123
Tel: (714) 279-2421 $\dagger$ *Hamilton Electro Sales 10912 W. Washington Boulevard Culver City 90230
Cramer/San Francisco 720 Palomar Avenue Sunnyvale 94086 Cramer/Los Angeles 17201 Daimler St Tel: (714) 979-3000 Liberty Electronics Segundo 90245 el: (213) 322-8100 WX: 910-348-7140 Liberty/San Diego
San Diego 92111 Tel: (714) 565-9171
TELEX: $910-335-1590$ ${ }_{\dagger}$ Elmar Electronics 288 Charleston Road Tel: (415) $961-3611$,

COLORADO
Elmar/Denver 777 E. 50th Avenue Tel: (303) 287-9611
*Hamilton/Avnet Electronics
5921 No. Broadway
Denver 80216
Tel: (303) 545-1212
CONNECTICUT
Cramer/Connecticut 35 Dodge Avenue Tel: (203) 239-5641 Hamilton/Avnet Electronics 643 Danbury Road Teil: (203) $762-0361$
Harvey Electronics
Harvey Electron
12 Main Street
Norwalk 06851
Tel: (203) 853-1515
FLORIDA
ramer/E.W. Hollywood
035 No. 29th Aven
Hollywood 33020
Tel: (305) 921-7878
Hamilton/Avnet Electronics
8800 Northwest 20th Ave.
t. Lauderdale 3330
l: (305) 971-2900
Cramer/EW Orlando
345 No. Graham Ave.
rlando 32814
el: (305) 894-1
Pioneer
Pioneer
6220 S . Orange Blossom Trail
Suite 412
Suite 412
Triando 32809
Tel: (305) 859-3600

## GEORGIA

Cramer
Warren Drive
Norcross 30071

[^10]GEORGIA (cont.)
Hamilton/Avnet Electronics
700 I 85 , Access Road, $\# 11$
Norcross 30071
Tel: (404) 448-0800
illinois
+Cramer/Chicag
Mt. Prospect 60056
Tel: (312) 593-8230
$\dagger^{*}$ Hamilton/Avnet Electronics
Schiller Park 60176
Tel: (312) 678-6310
Pioneer/Chicago
Elk Grove Village 60006

## INDIANA

## Pioneer/Indiana

dianapolis 46250
el: (317) 849-7300
Sheridan Sale
Indianapolis 46268
Tel: (317) 297-3146

## KANSAS

Hamilton/Avnet Electronic
219 Quivira Road
Tel: (913) 888-8900
MARYLAND
Cramer/EW Washington
6021 Industrial Drive
Gaithersburg 20760
*Hamilton Avnet
235 Standard Drive
Hanover 21076
Tel: (301) $796-5000$
Pioneer/Washington
Gaithersburg 20760
el: ( 301 ) 948-0710
MASSACHUSETTS
Cramer Electronics Inc.
85 Wells Avenue
Tel: (617) 969-7700
$\dagger^{*}$ Hamilton/Avnet Electronics
100 E. Commerce W
Tel: (617) 933-8000

## MICHIGAN

Sheridan Sales Co.
4543 Indoplex Circle
armington Hills 480
el. (313) 477-3800
3485 Stamford
Livonia 48150
Tel: (313) 525-1800
*Hamilton/Avnet Electronic
2487 Schoolcraft Road
Livonia 48150
TWX: 810-242-8775
MINNESOTA
Industrial Component
280 West 74th Stre
Tel: ( 612 ) $831-2666$
Cramer/Bonn
7275 Bush Lake Road
Edina 55435
*Hamilton/Avnet Electronic
83 Washington Avenue So.
Edina 55435

## missouri

$\dagger$ *Hamilton/Avnet Electronic 96 Brookes Lane Tal: (314) 731-1144
heridan Sale
110 S. Hwy. 67, Suite 10 Florissant 63031

## NEW JERSEY

Cramer/Pennsylvania, Inc.
Cherry Hill Industrial Center Cherry Hill 08034 Tel: (609) 424-5993 WX: 710-896-090
*Hamilton/Avnet Electronics
8 Little Falls Roa
Tel: (201) 239-0800
TWX: 710-994-5787
Cramer/New Jersey
Cardinal Drive ittle Falls 07424

| NEW JERSEY (cont.) | PENNSYLVANIA (cont.) |
| :---: | :---: |
| $\dagger$ Harvey Electronics | Pioneer/Delaware |
| 389 Passaic Avenue | 141 Gibraltar Road |
| Fairfield 07006 | Horsham 19044 |
| Tel: (201) 227-1262 | Tel: (215) 674-4000 |
| $\dagger$ *Hamilton/Avnet Electronics | TWX: 510-665-6778 |
| 113 Gaither Drive | tennessee |
| East Gate Industrial Park | Sheridan Sales Co. |
| Mt. Laurel 08057 | 6900 Office Park Circle |
| Tel: (609) 234-2133 | Knoxville 37919 |
| TWX: 710-897-1405 | Tel: (615) 588-5386 |
| NEW MEXICO |  |
| ${ }^{+}$*Hamilton/Avnet Electronic | TEXAS |
| 2524 Baylor Drive, S.E. | Component Specialties Inc. |
| Albuquerque 87119 | 8330 Burnett Road, Suite 101 |
| Tel: (505) 765-1500 | Austin 78758 |
| new york | Tel: (512) 459-3308 |
| $\dagger$ Cramer/Rochester | $\dagger$ Cramer Electronics |
| 3000 Winton Road South | 13740 Midway Road |
| Rochester 14 |  |
| Tel: (716) 275-0300 | Tel: (214) 661-9300 |
| $\dagger$ *Hamilton/Avnet Electronics 167 Clay Road | ${ }_{4}{ }^{*}$ * Hamis Sigma Road |
| Rochester 14623 | Dallas 75240 |
| Tel: (716) 442-7820 | Tel: (214) 661-8661 |
| Cramer/Syracuse | $\dagger$ + Hamilton/Avnet Electronics |
| 6716 Joy Road | - |
| East Syracuse 13057 | Tel: Toution 780 -17 |
| Tel: (315) 437-667 |  |
| ${ }^{*}$ * Hamilton/Avnet Electronics | 10907 Shady Trail, Suite 101 |
| E. Syracuse 13057 | Dallas 75220 |
| Tel: (315) 437-2641 | Tel: (214) 357-6511 |
| ${ }^{+}$Cramer/Long Island | $\dagger$ Component Specialtios, Inc. |
| 129 Oser Avenue | Houstom 77036 |
| Hauppauge, L.1. 11787 | Tole ( 713 ) 771-7237 |
| Tel:(516) 231-5600 |  |
| $\dagger$ *Hamilton/Avnet Electronics | $\dagger$ +Hamilton/Avnet Electronics |
| 70 State Street | 1585 West 2100 South |
| Westbury, L.I. 11590 | Salt Lake City, 84119 |
| Tel: (516) $333-5800$ | Tel: (801) 972-2800 |
| TWX: 510-222-8237 | WASHINGTON |
| 60 Crossways Park West | $\dagger$ Hamilton/Avnet Electronics |
| Woodbury 11797 | 13407 Northrup Way |
| Tel: (516) 921-8700 | Bellevue 98005 |
| NORTH CAROLINA |  |
| $\dagger$ †ramer Electronics | 5811 Sixth Ave South |
| 938 Burke Street | Seattle 98108. |
| Winston-Salem 27102 | Tel: (206) 763-2300 |
| Pioneer/Carolina | $\dagger$ Liberty Electronics |
|  | 1750 132nd Avenue NE |
| Greensboro 27406 |  |
| Tel: (919) 273-4441 | Tel: (206) 763-8200 |
| TWX: 510-925-1114 | WISCONSIN |
| Hamilton/Avnet Electronics, Inc. | ${ }^{*}$ Hamilton/Avnet |
| 2803 Industrial Drive | 2975 Moorland Road |
| Raleigh 27609 | New Berlin 53151 |
| Tel: (919) 829-8030 | Tel: (414) 784-4510 |
| OHIO |  |
| $\dagger$ Sheridan Sales Co. |  |
| 2501 Neff Road | CANADA |
| Dayton 45414 |  |
|  | alberta |
| †Cramer/Cleveland 5835 Harper Road | +L. A. Varah Ltd. |
| Cleveland 44139 | Calgary T2E 6LT |
| Tel: (216) 248-8400 | Tel: ( 403 ) $276-8818$ |
| $\dagger^{*}$ *Hamilton/Avnet Electronics | Telex: 138258977 |
| 954 Senate Drive Dayton 45459 | british columbia |
| Telt (513) 433-0610 | †L.A. Varah Litd. |
| TWX: 810-450-2531 | 2077 Alberta Street |
| ${ }^{\text {+Pioneer/Dayton }}$ | Tel: (604) 873-3211 |
| 1900 Troy Street | TWX: 610-929-1068 |
| $\text { Tel: (513) } 236-9900$ | Telex: 0453167 |
| $\dagger$ Sheridan Sales Co. | ONTARIO |
| 10 Knollcrest Drive | L.A. Varah, Ltd. |
| Cincinnati 45222 | 505 Kenora Avenue |
| Tel: (513) 761-5432 | Hamitton LBE-3P2 |
| TWX: 810-461-2670 | Tel: (416) 561-9311 |
| ${ }_{4}+$ Pioneer/Cleveland | TELEX: 061-8349 |
| 4800 E. 131 st Street | $\dagger$ *Hamilton/Avnet Electronics |
| Cleveland ${ }^{44105}$ | 3688 Nashua Drive, Unit GH |
| Tel: (216) 587-3600 | Mississauga L4V IM5 |
| $\dagger *$ Hamitton/Avnet Electronics | Tel: (416) 677-7432 |
| 761 Beta Drive, Suite E | TWX: 610-492-8867 |
| Cleveland 44143 <br> Tel: (216) 461-1400 | ${ }^{+}{ }^{*}$ * Hamilton/Avnet Electronics |
| $\dagger$ Sheridan Sales Co . | Ottawa K2C 3J2 |
| 23224 Commerce Park Road | Tel: (613) 226-1700 |
| Beachwood 44122 | TWX: 610 562-1906 |
| Tel: (216) 831-0130 | $\dagger$ Zentronics |
| OXLAHOMA |  |
| ¡Components Specialties, Inc. | Ottawa, Ontario K2P 1C3 <br> Tel: (613) 238-6411 |
| 7920 E. 40 th Street | $\dagger$ Zentronics |
| Tel: (918) 664-2820 | 99 Norfinch Dr. |
| OREGON | Downsview, Ontario M3N 1W8 Tel: (416) 635-2822 |
| $\dagger$ Almac/Stroum Electronics | Telex: 02-021694 |
| 4475 S.W. Scholls Ferry Rd. Portland 97225 | Quebec |
| Tel: (503) 292-3534 | $\dagger$ *Hamilton/Avnet Electronics |
| Pennsylvania | St. Laurent H4S 1G2 |
| +Sheridan Sales Co. | Tel: (514) $331-6443$ |
| 1717 Penn Avenue, Suite 5009 | TWX: 610-421-3731 |
| Pittsburgh 15221 |  |
| Tel: (412) 244-1640 |  |
| Pioneer/Pittsburgh 560 Alpha Drive Pittsburgh 15238 |  |
|  | System Technical Demonstrator Centers System Spares Order Point |

## intel

INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, California 95051 (408) 987-8080 Printed in U.S.A./T205/0878/30K CP


[^0]:    *'"Module" refers to a functional block, it does not reference a printed circuit board manufactured by INTEL.
    $\dagger$ "Bus" refers to a set of signals grouped together because of the similarity of their functions.

[^1]:    MCS-85™ BASIC SYSTEM

[^2]:    Note 1: Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.

[^3]:    | $A_{0} \cdot A_{9}$ | ADDRESS INPUTS |
    | :--- | :--- |


    | $\mathrm{O}_{1} \cdot \mathrm{O}_{8}$ | DATA OUTPUTS |
    | :--- | :--- |


    | $\overline{\text { CS}}$ WE | CHIP SELECT/WRITE ENABLE INPUT |
    | :--- | :--- |

[^4]:    NOTES: 1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
    2. This parameter is periodically sampled and is not $100 \%$ tested.

[^5]:    Note: Error Reset must be performed whenever RxEnable and Enter Hunt are programmed.

[^6]:    * $V_{\text {EXT }}$ IS SET AT VARIOUS VOLTAGES DURING TESTING TO GUARANTEE THE SPECIFICATION.

[^7]:    * $\mathrm{A}_{0}-\mathrm{A}_{15}$ : DMA Starting Address, $\mathrm{C}_{0}-\mathrm{C}_{13}$ : Terminal Count value ( $\mathrm{N}-1$ ), Rd and Wr: DMA Verify (00), Write (01) or Read (10) cycle selection, AL: Auto Load, TCS: TC STOP, EW: EXTENDED WRITE,RP: ROTATING PRIORITY, EN3-ENO: CHANNEL ENABLE MASK,UP: UPDATE FLAG, TC3-TC0: TERMINAL COUNT STATUS BITS.

[^8]:    Notes: 1. Load $=1 \mathrm{TTL}$. 2. Load $=1 \mathrm{TTL}+50 \mathrm{pF}$. 3. Load $=1 \mathrm{~T}, \mathrm{~L}+\left(\mathrm{R}_{\mathrm{L}}=3.3 \mathrm{~K}\right), \mathrm{VOH}_{\mathrm{OH}}=3.3 \mathrm{~V}$. 4. Tracking Specification. 5. $\Delta T_{A K}<50$ ns. 6. $\Delta T_{D C L}<50$ ns. 7. $\Delta T_{D C T}<50 \mathrm{~ns}$. 6-264

[^9]:    Note: The CPU interrupt input must be disabled during:

    1. Initialization sequence for all the 8259 in the system.
    2. Any control command execution.
[^10]:    *Note New Telephone Number

