Intel was organized in 1968 to utilize the rapidly expanding technology of Integrated Electronics. During its 10-year history, Intel has become the world's largest supplier of MOS circuits, and is in the top five of the world's producers of all semiconductor devices.
This Component Data Catalog provides complete specifications on most of Intel standard memory, microprocessor, peripheral and telecommunication components. Industrial grade products are detailed in Sec-
tion 13, military products in Section 14. Margin tabs provide quick guides to major
product categories; indexes located in Section 1 and at the beginning of
each section allow location of specific circuit types. Ordering,
packaging, product flow information and available literature may be found in Section 2.
The following are trademarks of Intel Corporation and may be used only to describe Intel products: Intel, ICE, INSITE, Intellec, iSBC, Library Manager, MCS, Megachassis, MICROMAP, MULTIBUS, PROMPT, RM, UPI, $\mu$ Scope, PROMWARE,
iCS and the combination of MCS, RMX, ICE, iSBC or iCS with a numerical

## intel ${ }^{\circ}$ <br> Component Data Catalog 1979

$\square$

## inted

## Component

Data Catalog 1979

Numerical and Functional Indexes

## General Information

Random Access
Memory
Read Only Memory
Memory Support
Telecom
MCS－4／40 ${ }^{\text {TM }}$
Microprocessors


## MCS－80／85 ${ }^{\text {TM }}$ Microprocessors

## 10

Microprocessor



# Numerical and Functional Indexes 1 



## FUNCTIONAL INDEX

| GENERAL INFORMATION |  |  |
| :---: | :---: | :---: |
| Table of Contents |  | 2-2 |
| Ordering Information |  | 2-3 |
| Packaging Information |  | 2-4 |
| Standard Product Flow |  | 2-12 |
| Intel Technical Library |  | 2-14 |
| Sales Offices |  | 2-17 |
| Distributors |  | 2-19 |
| RANDOM ACCESS MEMORIES |  |  |
| SELECTOR GUIDE |  | 3-2 |
| 2101A/8101A-4* | $256 \times 4$-Bit Static RAM | 3-4 |
| 2102A/2102AL/ |  |  |
| 8102A-4* | $1 \mathrm{~K} \times 1$ - Bit Static RAM | 3-8 |
| 2104A Family | $4096 \times 1$-Bit Dynamic RAM | 3-12 |
| 2104A Family | $4096 \times 1$-Bit Dyanmic RAM | 3-20 |
| 2107C Family | 4096-Bit Dynamic RAM | 3-28 |
| 2109 Family | 8,912 $\times 1$-Bit Dynamic RAM | 3-33 |
| 2111A/8111A-4* | $256 \times 4$-Bit Static RAM | 3-45 |
| 2112A | $256 \times 4$-Bit Static RAM | 3-49 |
| 2114 | $1024 \times 4$-Bit Static RAM | 3-54 |
| 2115A/2125A |  |  |
| Family | High Speed $1 \mathrm{~K} \times 1$-Bit Static RAM | 3-58 |
| 2115H, 2125H |  |  |
| Family | High Speed $1 \mathrm{~K} \times 1$-Bit Static Ram | 3-63 |
| 2117 Family | $16,384 \times 1$-Bit Dynamic RAM | 3-64 |
| 2117-5 | $16,384 \times 1$-Bit Dynamic RAM | 3-76 |
| 2118 Family | $16,384 \times 1$-Bit Dynamic RAM | 3-88 |
| 2141 | $4096 \times 1$-Bit Static RAM | $3-89$ |
| 2142 | $1024 \times 4$-Bit Static RAM | 3-95 |
| 2147 | $4096 \times 1$-Bit Static RAM | 3-99 |
| 2147H | High Speed $4096 \times 1$-Bit Static RAM | 3-105 |
| 2148 | $1024 \times 4$-Bit Static RAM | 3-106 |
| 3101/3101A | $16 \times 4$-Bit High Speed RAM | 3-107 |
| 5101 Family | $256 \times 4$ - it Static CMOS RAM | 3-111 |

## PROGRAMMABLE READ ONLY MEMORIES/ READ ONLY MEMORIES

| SELECTOR GUIDE |  | $4-2$ |
| :--- | :--- | ---: |
| BIPOLAR CROSS REFERENCE | $4-4$ |  |
| $1702 A$ | $2 K(256 \times 8)$ UV Erasable PROM | $4-5$ |
| 1702 AL/1702AL-2 | $2 K(256 \times 8)$ UV Erasable Low Power PROM | $4-9$ |
| $2316 E$ | $16 K(2 K \times 8)$ ROM | $4-12$ |
| $2332 A$ | $32 K(4 K \times 8)$ ROM | $4-15$ |
| $2364 A$ | $64 K(8 K \times 8)$ Bit ROM | $4-16$ |
| 2608 | $8 K(1 K \times 8)$ Factory Programmable PROM | $4-17$ |
| $2708 / 8708$ | $8 K$ and 4 K UV Erasable PROM | $4-20$ |
| 2716 | $16 K(2 K \times 8)$ UV Erasable PROM | $4-23$ |
| 2732 | $32 K(4 K \times 8)$ UV Erasable PROM | $4-28$ |
| 2758 | $8 K(1 K \times 8)$ UV Erasable Low Power PROM | $4-31$ |
| $3604 A / 3624 A$ |  |  |
| Family | 4K $(512 \times 8)$ High-Speed PROM | $4-36$ |
| $3605 A / 3625 A$ | 4K $(1 K \times 4)$ PROM | $4-39$ |
| 3628 | $8 K(1 K \times 8)$ Bipolar PROM | $4-42$ |
| 3636 | $16 K(2 K \times 8)$ Bipolar PROM | $4-45$ |
| PROM AND ROM PROGRAMMING INSTRUCTIONS | $4-48$ |  |

## MEMORY SUPPORT

| SELECTOR GUIDE |  | $5-2$ |
| :--- | :--- | :--- |
| 3205 | 1 of 8 Binary Decoder | $5-3$ |
| $3207 A$ | Quad Bipolar to MOS Level Shifter and Driver | $5-7$ |


| $3207 A-1$ | Quad Bipolar to MOS Level Shifter and Driver | $5-11$ |
| :--- | :--- | ---: |
| 3222 | 4K Dynamic RAM Refresh Controller | $5-13$ |
| 3232 | 4K Dynamic RAM Address Multiplexer and |  |
|  | Refresh Counter | $5-19$ |
| 3242 | 16K Dynamic RAM Address Multiplexer and |  |
|  | Refresh Counter | $5-23$ |
| 3245 | Quad TTL to MOS Driver to 4K RAMs | $5-27$ |
| 3404 | High Speed 6-Bit Latch | $5-3$ |
|  |  |  |
| TELCOM |  |  |
| 2910 | PCM CODEC - |  |
| 2911 | PCM Law | $6-3$ |
| 2912 | PCM Line Filters | $6-15$ |
|  |  | $6-26$ |

MCS-4/40 ${ }^{\text {TM }}$ MICROPROCESSOR
4040
4004
4003
4265
4269
$4201 A$
4289
4002
4001

4308

| Single Chip 4-Bit P-Channel Microprocessor | $7-3$ |
| :--- | ---: |
| Single Chip 4-Bit P-Channel Microprocessor | $7-4$ |
| 10-Bit Shift Register/Output Expander | $7-5$ |
| Programmable General Purpose I/O Device | $7-6$ |
| Programmable Keyboard Display Device | $7-7$ |
| Clock Generator | $7-8$ |
| Standard Memory Interface | $7-9$ |
| 320-Bit RAM and 4-Bit Output Port | $7-10$ |
| $256 \times 8$ Mask Programmable ROM and 4-Bit |  |
| 1/0 Port |  |
| 1024 x 8 Mask Programmable ROM and | $7-11$ |
| 4-Bit I/O Ports |  |

MCS-48 ${ }^{\text {TM }}$ MICROCOMPUTERS

| SINGLE COMPONENT 8-BIT MICROCOMPUTERS |  |  |
| :---: | :---: | :---: |
| 8021 | Single Component 8-Bit Microcomputer | 8-4 |
| 8022 | Single Component 8-Bit Microcomputer with $A / D$ | 8-10 |
| 8048/8648/ |  |  |
| 8748/8035 | Single Component 8-Bit Microcomputer | 8-22 |
| 8049/8039/ |  |  |
| 8039-6 | Single Component 8-Bit Microcomputer | 8-31 |
| INPUT/OUTPUT |  |  |
| 8243 | MCS-48 ${ }^{\text {TM }}$ Input/Output Expander | 8-36 |

MCS-80/85 ${ }^{\text {TM }}$ MICROPROCESSORS
Recommended Products for New 8085A Applications 9-4
8008/8008-1 8-Bit Microprocessor 9-5

8080A/8080A-1/
8080A-2 8-Bit N-Channel Microprocessor 9-11
8224 Clock Generator and Driver for 8080A CPU 9-19
8801 Clock Generator Crystal for 8224/8080A 9-23

8228/8238 | System Controller and Bus Driver for |  |
| :--- | :--- |
|  | 8080 A CPU |

$8205 \quad$ High Speed 1 out of 8 Binary Decoder 9-29
8212 8-Bit Input/Output Port 9-35
$8214 \quad$ Priority Interrupt Control Unit $9-45$
8216/8226 4-Bit Parallel Bidirectional Bus Driver 9-49

8085A/8085A-2 \begin{tabular}{lll}

| Single Chip 8-Bit N-Channel |
| :--- |
| Microprocessors | \& $9-54$

\end{tabular}

8155/8156/
8155-2/8156-2 2048-Bit Static MOS RAM with I/O Ports and Timer

9-70
8185/8185-2 $1024 \times 8$-Bit Static RAM for MCS-85 9-77
8218/8219 Bipolar Microcomputer Bus Controllers for MCS-80 and MCS-85

[^0]| 8257/8257-5 | Programmable DMA Controiler | $9-92$ |
| :--- | :--- | ---: |
| 8259 A | Programmable Interrupt Controller | $9-109$ |
| $8355 / 8355-2$ | $16,384-$ Bit ROM with I/0 | $9-127$ |
| 8755 A | 16,384-Bit EPROM with I/O | $9-132$ |

## MCS-86 MICROPROCESSOR

| $8086 / 8086-4$ | 16-Bit HMOS Microprocessor | $10-4$ |
| :--- | :--- | ---: |
| $8282 / 8283$ | Octal Latch | $10-23$ |
| 8284 | Clock Generator and Drive for 8086 CPU | $10-27$ |
| $8286 / 8287$ | Octal Bus Transceiver | $10-33$ |
| 8288 | Bus Controller for the 8086 CPU | $10-37$ |

## MICROPROCESSOR PERIPHERALS

| 8041A/8741A | Universal Peripheral Interface 8-Bit <br>  <br>  <br> Microcomputer | $11-3$ |
| :--- | :--- | ---: |
| 8202 | Dynamic RAM Controller | $11-14$ |
| 8251 A | Programmable Communication Interface | $11-24$ |
| $8253 / 8253-5$ | Programmable Intrerval Timer | $11-32$ |
| $8255 A / 8255 A-5$ | Programmable Peripheral Interface | $11-43$ |
| 8271 | Programmable Floppy Disk Controller | $11-64$ |
| 8273 | Programmable HDLC/SDLC Protocol |  |
|  | Controller | $11-93$ |
| 8275 | Programmable CRT Controller | $11-118$ |
| 8278 | Programmable Keyboard Interface | $11-142$ |
| $8279 / 8279-5$ | Programmable Keyboard/Display Interface | $11-152$ |
| 8291 | GPIB Talker/Listener | $11-164$ |
| 8292 | GPIB Controller | $11-188$ |
| 8294 | Data Encryption Unit | $11-190$ |
| 8295 | Dot Matrix Printer Controller | $11-201$ |

## MICROCOMPUTER DEVELOPMENT SYSTEMS

## MICROCOMPUTER DEVELOPMENT SYSTEMS

| Model 210 Intellec ${ }^{\left({ }^{( } \text {Series II Microcomputer Development System }\right.}$ | 12-3 |
| :---: | :---: |
| Model 220 Intellec ${ }^{\circledR}$ Series II Microcomputer Development System | 12-6 |
| Model 230 Intellec ${ }^{\left({ }^{( }\right)}$Series II Microcomputer Development System | 12-10 |
| Expansion Chassis Intellec® ${ }^{\circledR}$ Series II Microcomputer Development System | 12-14 |
| Model 770 Printer Intellec ${ }^{\circledR}$ Series \|| Microcomputer Development System | 12-16 |
| Intellec Printer | 12-18 |
| MCS-48 Diskette-Based Software Support Package | 12-20 |
| PL/M-80 High Level Programming Language Intellec ${ }^{\circledR}$ | 22 |
| MDS-311 8086 Software Development Package | 12-25 |
| FORTRAN-80 8080/8085 ANS FORTRAN 77 Intellec |  |
| Resident Compiler | 12-36 |
| Basic-80 Extended ANS 1978 Basic Intellec ${ }^{\text {® }}$ Resident Interpreter | 12-40 |
| Intellec ${ }^{\text {® }}$ Single/Double Density Flexible Disk System | 12-43 |
| ISIS-II Diskette Operating System Microcomputer |  |
| Development System | 12-47 |
| Intellec Prompt 48 MCS-48 Microcomputer Design Aid | 12-50 |
| ICE-49 MCS-48 In-Circuit Emulator | 12-56 |
| ICE-80 8080 In-Circuit Emulator | 12-61 |
| ICE-85 MCS-85 In-Circuit Emulator | 12-67 |
| ICE-86 8086 In-Circuit Emulator | 12-71 |
| EM1 8021 Emulation Board | 12-77 |
| EM2 8022 Emulation Board | 12-80 |
| UPP-103 Universal PR0M Programmer | 12-83 |
| SDK-85 MCS-85 System Design Kit | 12-85 |


| SDK-86 MCS-86 System Design Kit | $12-91$ |
| :--- | :---: |
| SDK-C86 MCS-86 System Design Kit Software and Cable Interface |  |
| to Intellec ${ }^{\circledR}$ Development System | $12-97$ |
| Insite User's Program Library | $12-99$ |

## TEST AND INSTRUMENTATION SYSTEMS

| $\mu$ Scope 820 Microprocessor System Console | $12-103$ |
| :--- | :---: |
| $\mu$ Scope Probe $8080 A$ | $12-103$ |
| $\mu$ Scope Probe 8085 | $12-110$ |
|  |  |
| MICROCOMPUTER TRAINING PROGRAMS | $12-112$ |

## INDUSTRIAL GRADE PRODUCTS

| 12114 | $1024 \times 4$-Bit Static RAM | 13-3 |
| :---: | :---: | :---: |
| 12708/18708 | 8K UV Erasable PROM | 13-4 |
| 12716 | 16 K (2K x 8) UV Erasable PROM | 13-5 |
| 18048/18648/ |  |  |
| 18748/18035 | Single Component 8-Bit Microcomputer | 13-6 |
| 18155/18156 | 2048-Bit Static MOS RAM With I/0 Ports |  |
|  | and Timer | 13-7 |
| 18212 | 8-Bit Input/Output Port | 13-8 |
| 18216/8226 | 4-Bit Parallel Bidirectional Bus Driver | 13-9 |
| 18243 | MCS-48 Input/Output Expander | 13-10 |
| 18251 | Programmable Communication Interface | 13-11 |
| 18255A | Programmable Peripheral Interface | 13-12 |
| 18259 | Programmable Interrupt Controller | 13-13 |
| 18279 | Programmable Keyboard/Display Interface | 13-14 |
| 18355 | 16,384-Bit ROM With I/0 | 13-15 |
| 18755A-8 | 16,384-Bit EPROM With I/O | 13-16 |

## MILITARY PRODUCTS

| M1702A | $2 \mathrm{~K}(256 \times 8)$ UV Erasable PROM | 14-4 |
| :---: | :---: | :---: |
| M2114 | $1024 \times 4$-Bit Static RAM | 14-6 |
| M2115A/M2125A |  |  |
| Family | High Speed $1 \mathrm{~K} \times 1-\mathrm{Bit}$ Static RAM | 14-10 |
| M2147 | $4096 \times 1$-Bit Static RAM | 14-15 |
| M2708 | 8 K and 4K UV Erasable PROM | 14-21 |
| M2716 | $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ UV Erasable PROM | 14-27 |
| M3604A/M3624A | $4 \mathrm{~K}(512 \times 8)$ High Speed PROM | 14-32 |
| M3625A | 4K ( $1 \mathrm{~K} \times 4$ ) PROM | 14-34 |
| M3636 | 16K (2K x 8) Bıpolar PROM | 14-37 |
| M5101-4/ |  |  |
| M5101L-4 | $256 \times 4$-Bit Static CMOS RAM | 14-40 |
| M8080A | 8-Bit N-Channel Microprocessor | 14-43 |
| M8212 | 8-Bit Input/Output Port | 14-48 |
| M8214 | Priority Interrupt Control Unit | 14-53 |
| M8216/M8226 | 4-Bit Parallel Bidirectional Bus Driver | 14-56 |
| M8224 | Clock Generator and Driver for 8080A CPU | 14-59 |
| M8228 | System Controller and Bus Driver for |  |
|  | 8080A CPU | 14-63 |
| M8251 | Programmable Communication Interface | 14-68 |
| M8255A | Programmable Peripheral Interface | 14-71 |
| M8085A | Single Chip 8-Bit N-Channel Microprocessor | 14-74 |
| M8155 | 2048-Bit Static MOS RAM With I/O Ports and Timer | 14-87 |
| M8257 | Programmable DMA Controller | 14-98 |
| M8259 | Programmable Interrupt Controller | 14-105 |
| M8048/M8748/ |  |  |
| M8035 | Single Component 8-Bit Microcomputer | 14-110 |


| 1702A | 2K (256 $\times 8$ ) UV Erasable PROM | 4-5 | 3636 | 16K (2K $\times 8$ ) Bipolar PROM | 4-45 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| M1702A | $2 \mathrm{~K}(256 \times 8)$ UV Erasable PROM | 14-4 | M3636 | $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ Bipolar PROM | 14-37 |
| 1702AL-2/ |  |  | 4001 | $256 \times 8$ Mask Programmable ROM and 4-Bit |  |
| 1702AL-2 | 2K (256 x 8) UV Erasable Low Power PROM | 4-9 |  | 1/0 Port | 7-11 |
| 2101A/8101A-4* | $256 \times 4$-Bit Static RAM | $3-4$ | 4002 | 320-Bit RAM and 4-Bit Output Port | $7 \cdot 10$ |
| 2102A/2102AL/ |  |  | 4003 | 10-Bit Shift Register/Output Expander | 7-5 |
| 8102A-4* | $1 \mathrm{~K} \times 1$-Bit Static RAM | 3-8 | 4004 | Single Chip 4-Bit P-Channel Microprocessor | 7-4 |
| 2104A Family | $4096 \times 1$-Bit Dynamic RAM | 3-12 | 4040 | Single Chip 4-Bit P-Channel Microprocessor | 7-3 |
| 2104A Family | $4096 \times 1$-Bit Dynamic RAM | 3.20 | 4201A | Clock Generator | 7-8 |
| 2107C Family | $4096 \times 1$-Bit Dynamic RAM | 3-28 | 4265 | Programmable General Purpose I/O Device | 7-6 |
| 2109 Family | $8,192 \times 1$-Bit Dynamic RAM | 3.33 | 4269 | Programmable Keyboard Display Device | 7-7 |
| 2111A/8111A-4* | $256 \times 4$-Bit Static RAM | 3.45 | 4289 | Standard Memory Interface | 7-9 |
| 2112A | $256 \times 4$-Bit Static RAM | 3-49 | 4308 | $1024 \times 8$ Mask Programmable ROM and |  |
| 2114 | $1024 \times 4$-Bit Static RAM | 3-54 |  | 4-Bit 1/0 Ports | 7-13 |
| 12114 | $1024 \times 4$-Bit Static RAM | 13.3 | 5101 Family | $256 \times 4$-Bit Static CMOS RAM | 3-111 |
| M2114 | $1024 \times 4$-Bit Static RAM | 14-16 | M5101-4/ |  |  |
| 2115A/2125A |  |  | M5101L-4 | $256 \times 4$-Bit Static CMOS RAM | 14-40 |
| Family | High Speed $1 \mathrm{~K} \times 1$-Bit Static RAM | 3-58 | 8008/8008-1 | 8-Bit Microprocessor | 9-5 |
| M2115A/M2125A |  |  | 8021 | Single Component 8-Bit Microcomputer | 8-4 |
| Family | High Speed $1 \mathrm{~K} \times 1-\mathrm{Bit}$ Static RAM | 14-10 | 8022 | Single Component 8-Bit Microcomputer |  |
| 2115H, 2125H |  |  |  | with A/D | 8-10 |
| Family | High Speed $1 \mathrm{~K} \times 1$-Bit Static RAM | 3.63 | 8041A/8741A | Universal Peripheral Interface 8-Bit |  |
| 2117 Family | 16,384 $\times 1$-Bit Dynamic RAM | 3-64 |  | Microcomputer | 11-3 |
| 2117-5 | $16,384 \times 1$-Bit Dynamic RAM | 3-76 | 8048/8648/ |  |  |
| 2118 Family | $16.384 \times 1$-Bit Dynamic RAM | 3-88 | 8748/8035 | Single Component 8-Bit Microcomputer | $8-22$ |
| 2141 | $4096 \times 1$-Bit Static RAM | 3-89 | 18048/18648/ |  |  |
| 2142 | $1024 \times 4$-Bit Static RAM | 3-95 | 18748/18035 | Single Component 8-Bit Microcomputer | $13-16$ |
| 2147 | $4096 \times 1$-Bit Static RAM | 3-99 | M8048/M8748/ |  |  |
| M 2147 | $4096 \times 1$-Bit Static RAM | 14-14 | M8035 | Single Component 8-Bit Microcomputer | 14-110 |
| 2146 | High Speed $4096 \times 1$-Bit Static RAM | 3-105 | 8049/8039-6 | Single Component 8-Bit Microcomputer | 8-31 |
| 2148 | $1024 \times 4$-Bit Static RAM | 3-106 | 8080A/8080A-1/ |  |  |
| 2316 E | 16K (2K $\times 8$ ) ROM | 4-12 | 8080A-2 | 8-Bit N -Channel Microprocessor | 9-11 |
| 2332A | $32 \mathrm{~K}(4 \mathrm{~K} \times 8) \mathrm{ROM}$ | 4-15 | M8080A | 8-Bit N-Channel Microprocessor | 14-43 |
| 2364A | $64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ Bit ROM | 4-16 | 8085A/8085A-2 | Single Chip 8-Bit N -Channel Microprocessor | 9.54 |
| 2608 | $8 \mathrm{~K}(1 \mathrm{~K} \times 8)$ Factory Programmable PROM | 4-17 | M8085A | Single Chip 8-Bit N -Channel Microprocessor | 14-74 |
| 2708/8708 | 8 K and 4K UV Erasable PROM | 4-20 | 8086/8086-4 | 16-Bit HMOS Microprocessor | 10.4 |
| 12708/18708 | 8K UV Erasable PROM | 13.4 | 8155/8156/ |  |  |
| M2708 | 8 K and 4K UV Erasable PROM | 14-2.7 | 8155-2/8156-2 | 2048-Bit Static MOS RAM With 1/0 Ports |  |
| 2716 | 16K (2K x 8) UV Erasable PROM | 4-23 |  | and Timer | 9-70 |
| 12716 | $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ UV Erasable PROM | 13.5 | 18155/18156 | 2048-Bit Static MOS RAM With 1/0 Ports |  |
| M2716 | 16K (2K x 8) UV Erasable PROM | 14-17 |  | and Timer | 13.7 |
| 2732 | $32 \mathrm{~K}(4 \mathrm{~K} \times 8)$ UV Erasable PROM | 4-28 | M8155 | 2048-Bit Static MOS RAM With 1/0 Ports |  |
| 2758 | $8 \mathrm{~K}(1 \mathrm{~K} \times 8)$ UV Erasable Low Power PROM | 4-31 |  | and Timer | 14-87 |
| 2910 | PCM CODEC - $\mu$ Law | 6-3 | 8185/8185-2 | $1024 \times 8$-Bit Static RAM for MCS-85 | 9-77 |
| 2911 | PCM CODEC - A Law | 6-15 | 8202 | Dynamic RAM Controller | 11-14 |
| 2912 | PCM Line Filters | 6-26 | 8205 | High Speed 1-out-of-8 Binary Decoder | 9-29 |
| 3101/3101A | $16 \times 4$-Bit High Speed RaM | 3-107 | 8212 | 8-Bit Input/Output Port | 9-35 |
| 3205 | 1 of 8 Binary Decoder | 5-3 | 18212 | 8-Bit Input/Output Port | 13.6 |
| 3207A | Quad Bipolar to MOS Level Shifter and Driver | 5-7 | M8212 | 8-Bit Input/Output Port | 14-48 |
| 3207A-1 | Quad Bipolar to MOS Level Shifter and Driver | 5-11 | 8214 | Priority Interrupt Control Unit | 9.45 |
| 3222 | 4K Dynamic RAM Refresh Controller | 5-13 | M8214 | Priority Interrupt Control Unit | 14-53 |
| 3232 | 4K Dynamic RAM Address Multiplexer |  | 8216/8226 | 4-Bit Parallel Bidirectional Bus Driver | 9-49 |
|  | and Refresh Counter | 5-19 | 18216/8226 | 4-Bit Parallel Bidirectional Bus Driver | 13-9 |
| 3242 | 16K Dynamic RAM Address Multiplexer |  | M8216/M8226 | 4-Bit Parallel Bidirectional Bus Driver | 14-56 |
|  | and Refresh Counter | 5-23 | 8218/8219 | Bipolar Microcomputer Bus Controllers for |  |
| 3245 | Quad TTL to MOS Driver for 4K RAMs | 5-27 |  | MCS-80 and MCS-85 | 9-81 |
| 3404 | High Speed 6-Bit Latch | 5-3 | 8224 | Clock Generator and Driver for 8080A CPU | 9-19 |
| 3604A/3624A |  |  | M8224 | Clock Generator and Driver for 8080A CPU | 14-59 |
| Family | 4K (512 $\times 8$ ) High Speed PROM | 4-36 | 8228/8238 | System Controlier and Bus Driver for |  |
| M3604A/M3624A | $4 \mathrm{~K}(512 \times 8)$ High Speed PROM | 14-32 |  | 8080A CPU | 9-25 |
| 3605A/3625A | $4 \mathrm{~K}(1 \mathrm{~K} \times 4)$ PROM | 4-39 | M8228/M8238 | System Controller and Bus Driver for |  |
| M3625A | $4 \mathrm{~K}(1 \mathrm{~K} \times 4)$ PROM | 14-34 |  | 8080A CPU | 14-63 |
| 3628 | $8 \mathrm{~K}(1 \mathrm{~K} \times 8)$ Bipolar PROM | 4-42 | 8243 | MCS-48 ${ }^{\text {TM }}$ Input/Output Expander | 8-36 |

NUMERICAL INDEX

| 18243 | MCS-48 ${ }^{\text {TM }}$ Input/Output Expander | 13-10 |
| :---: | :---: | :---: |
| 8251A | Programmable Communication Interface | 11-24 |
| 18251A | Programmable Communication Interface | 13-11 |
| M8251A | Programmable Communication Interface | 14-68 |
| 8253/8253-5 | Programmable Interval Timer | 11-32 |
| 8255A/8255A-5 | Programmable Peripheral Interface | 11-43 |
| 18255A | Programmable Peripheral interface | 13-12 |
| M8255A | Programmable Peripheral Interface | 14-71 |
| 8257/8257-5 | Programmable DMA Controller | 9-92 |
| M8257 | Programmable DMA Controller | 14-98 |
| 8259A | Programmable Interrupt Controller | 9-109 |
| 18259 | Programmable Interrupt Controller | 13-13 |
| M8259 | Programmable Interrupt Controller | 14-105 |
| 8271 | Programmable Floppy Disk Controller | 11-64 |
| 8273 | Programmable HDLC/SDLC Protocol |  |
|  | Controller | 11-93 |
| 8275 | Programmable CRT Controller | $11-118$ |
| 8278 | Programmable Keyboard Interface | 11-142 |
| 8279/8279-5 | Programmable Keyboard/Display Interface | 11-152 |
| 18279 | Programmable Keyboard/Display Interface | 13-14 |
| 8282/8283 | Octal Latch | 10-23 |
| 8284 | Clock Generator and Drive for 8086 CPU | 10-27 |
| 8286/8287 | Octal Bus Tranceiver | 10-33 |
| 8288 | Bus Controller for the 8086 CPU | 10-37 |
| 8291 | GPIB Talker/Listener | 11-164 |
| 8292 | GPIB Controller | 11-188 |
| 8294 | Data Encryption Unit | 11-190 |
| 8295 | Dot Matrix Printer Controller | 11-201 |
| 8355/8355-2 | 16,384-Bit ROM With 1/0 | 9-127 |
| 18355 | 16,384-Bit ROM With I/O | 13-15 |
| 8755A | 16,384-Bit EPROM With I/O | 9-132 |
| 18755A-8 | 16,384-Bit EPROM With 1/0 | 13-18 |
| 8801 | Clock Generator Crystal for 8224/8080A | 9-23 |
| Available Literature |  | 2-14 |
| Basic-80 Extended ANS 1978 Basic Intellec* Resident Interpreter |  | 12.40 |
| Bipolar Cross Reference |  | 4-4 |
| Development Systems |  | 12-2 |
| Distributors |  | 2-19 |
| EM1 Emulation Board |  | 12-77 |
| EM2 Emulation Board |  | 12-80 |


| Expansion Chassis Intellec® ${ }^{\text {® }}$ Series 11 | 12-14 |
| :---: | :---: |
| FORTRAN-80 Intellec® ${ }^{\text {R }}$ Resident Compiler | 12-36 |
| ICE-49 MCS-48 In-Circuit Emulator | 12-56 |
| ICE-80 8080 ln -Circuit Emulator | 12-61 |
| ICE-85 MCS-85 In -Circuit Emulator | 12-67 |
| ICE-86 8086 ln -Circuit Emulator | 12-71 |
| Insite Users Library | 12.99 |
| Intel Technical Library | 2-14 |
| Intellec ${ }^{\text {® }}$ Printer | 12-18 |
| Intellec® Single/Double Density Flexible Disk System | 12-43 |
| Intellec® Prompt 48 MCS-48 Design Aid | 12-50 |
| ISIS-II Diskette Operating System | 12-47 |
| MCS-48 Diskette-Based Sottware Support Package | 12-20 |
| MDS-311 8086 Software Development Package | 12-25 |
| Memory Support Circuits | 5-2 |
| Microcomputer Training Programs | 12-112 |
| Military Products | 14-2 |
| Model 210 Intellec ${ }^{\text {® }}$ Series II | 12-3 |
| Model 220 Intellec® ${ }^{\text {® }}$ Series II | 12-6 |
| Model 230 Intellec ${ }^{\text {® }}$ Series II | 12-10 |
| Model 770 Printer Intellec® ${ }^{\text {® }}$ Series II | 12-16 |
| Ordering Information | 2-3 |
| Packaging Information | 2-4 |
| Peripherals | 11-2 |
| PL/M-80 High Level Programming Language Intellec® |  |
| Resident Compiler | 12-22 |
| PROM/ROM Programming Instructions | 4-48 |
| Sales Offices | 2-17 |
| SDK-85 MCS-85 System Design Kit | 12.85 |
| SDK-86 MCS-86 System Design Kit | 12-91 |
| SDK-C86 MCS-86 System Design Kit Software and Cable |  |
| Standard Product Flow | 2-12 |
| Technical Library | 2-14 |
| $\mu$ Scope 820 Microprocessor System Console | 12-103 |
| $\mu$ Scope Probe 8080A | 12-108 |
| $\mu$ Scope Probe 8085 | $12 \cdot 110$ |
| UPP-103 Universal PROM Programmer | 12-83 |
| Users Library | 12.99 |



## General Information

2


## GENERAL INFORMATION

## TABLE OF CONTENTS

Ordering Information ..... 2-3
Packaging Information ..... 2-4
Standard Product Flow ..... 2-12
Intel Technical Library. ..... 2-14
Sales and Marketing Offices ..... 2-17
Distributors ..... 2-19

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



18-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


20-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


22-LEAD PLASTIC DUAL IN-LINE
PACKAGE TYPE P 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


20-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D
 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


20-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


22-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


## CERAMIC DUAL IN－LINE PACKAGE TYPE D



28－LEAD HERMETIC DUAL IN－LINE PACKAGE TYPE D


28－LEAD HERMETIC DUAL IN－LINE PACKAGE TYPE D


## CERAMIC DUAL IN-LINE PACKAGE TYPE D

40-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D


40-LEAD HERMETIC DUAL IN-LINE
PACKAGE TYPE D
40-LEAD HERMETIC DUAL IN-LINE
PACKAGE TYPE D


## CERAMIC DUAL IN-LINE PACKAGE TYPE C



40-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


## CERAMIC DUAL IN-LINE PACKAGE TYPE B



## 24-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE B



28-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE B


40-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE B



Hermeticity Testing to

1st Optical Inspection For Fab Defects eliminate devices which
show insufficient hermeticity. (Monitored by QA)
Fine leak C DIPs,CERDIPs, and Metal cans (MIL-STD-883 Method 1014.2B).* Gross Leak C DIPs and Cerdips only (Method
 1014.2C, vacuum omitted and 1 hour pressurization).

Electrical Wafer Sort



## INIEL トKUUUCI LIIERAIURE

The accelerating rate of new developments in microprocessors and memories has created the need for concise, up-to-the-minute design information. To assist customers in maintaining expertise in state of the art systems, Intel provides a variety of sales and technical literature including brochures, data sheets, application notes, handbooks, and technical manuals containing comprehensive information on microprocessors, microcomputers, memories, development systems, and software.

If you wish to receive Intel literature, contact your local Intel sales office, representative, distributor or Intel Corporation, Literature Department. International locations also provide selected literature in Japanese, French or German.

To order literature by mail, please enclose check or money order payable to Intel Corporation. Purchase Orders are accepted for amounts of $\$ 100.00$ or more. You can also order Intel documentation with your Master Charge or BankAmericard/Visa credit card. Include your card number, expiration date and signature on the order form. Volume and educational discounts are available. A maximum of five complimentary (N/C) items may be ordered. Mail to:

Intel Corporation Literature Department<br>3065 Bowers Avenue<br>Santa Clara, California 95051

## SALES LITERATURE

## Catalogs

6102001978 System Data Catalog

## Brochures

Microcomputer Product Line

## Brochure

Microcomputer Components Brochure
Memory Components Brochure Growing Static RAM Family Album
MOS RAMs Brochure
$\mu$ Scope 820 Brochure 1979 Intel Microcomputer Workshops Brochure

## Application Notes

AP-4
2107A Application Note
N/C
AP-12 5101 Application Note
AP-15 8255 Programmable Peripheral Interface

N/C
AP-16
Using the 8251 Application Note
N/C
AP17 2709 8K Erasable PROM Application Note

N/C
AP-22 Which Way for 16K N/C
AP-23 2104A 4K RAM N/C
AP-24 MCS-48 Family-9800413B
N/C
AP-26 iSBC 80/10 \& System 80/10 N/C

AP-27 Control With UPI-41 N/C
AP-27 Control With UPI-41 N/C
AP-28 Multibus Interfacing—9800587A N/C
AP-29 Using The Intel 8085 Serial I/O Lines

N/C
AP-30 Applications of 5 Volt EPROM and ROM Family for Microprocessor Systems
AP-31 Using the 8259-9800658A
AP-33 RMX/80-9800577A
AP-35 CRYSTALS: Specifications9800652A
AP-36 Using the 8273-9800667A
AP-40 Keyboard/Display Scanning With Intel's MCS-48 Microcomputers
AP-42 Writing Diagnostics for the $\mu$ Scope
AP-43 Using the iSBC ${ }^{\text {TM }} 957 \ldots 9800816$
AP-45 Using the $8202 \ldots 9800809$

## N/C

N/C
N/C
N/C
N/C
N/C

## Product Descriptions

| 9800365 | MCS-85 Product Description | N/C |
| :--- | :--- | :--- |
| 9800600 | Peripherals Product Description <br> 9800606 | N/C |
|  | Intellec Series II Microcomputer <br> Development Systems Functional <br> Description and Specifications | N/C |
| 9800615 | MCS-48 Single Chip Family of <br> Microcomputers Product <br> Description | N/C |
| 9800723 | MCS-86 Product Description | N/C |
| Reference Guides |  |  |
| 9800774 | BASIC 80 Reference Guide <br> 9800749 | MCS-86 Assembly Language <br> Reference Guide |
|  | N/C |  |

## Reference Cards

9800404 PROMPT 48 Reference Cardlet $\$ 1.50$

| 9800438 8085/8080 Assembly Language |  |
| :--- | :--- |
|  | Reference Card |

9800547 FORTRAN-80 Reference Card
N/C

9800582 | $\mu$ Scope 820 8080A Operator's |
| :--- |
| Reference Card | N/C

9800653 MCS-48 In-Circuit Emulator | Reference Card |
| :--- |
| R/C |

9800412 MCS-48 Assembly Language Reference Card N/C UPI-41 Assembly Language Reference Card N/C

## Reliability Reports

RR 7
RR 8
RR 9
RR 10
RR 11
RR 12
RR 14 2115/2125 MOS Static RAMs
RR 15 2104A 4K Dynamic RAM N/C 2116 16K Dynamic RAM iSBC 80/10 Single Board Computer
RR 18 HMOS Reliability
2107A/2107B 4K Dynamic RAM N/C
Polysilicon Fuse Bipolar PROM
MOS Static RAMs N/C
8080/8080A Microcomputer N/C
2416 16K CCD Memory N/C
2708 8K Erasable PROM N/C
RR 15 2104A 4K Dynamic RAM N/C
RR 16
RR 17

N/C
N/C
N/C

## TECHNICAL LITERATURE

## User's Guides

| 9800016 | High Speed Paper Tape Reader Installation and Operation Guide | \$2.50 |
| :---: | :---: | :---: |
| 9800203 | MCS-80 System Design Kit User's |  |
|  | Guide | \$5.00 |
| 9800223 | iSBC 80P and iSBC 80P10 Prototyping Package User's Guide | \$5.00 |
| 9800298 | iSBC 635 Power Supply User's |  |
|  | Guide | \$5.00 |
| 9800306 | ISIS-II User's Guide | \$30.00 |
| 9800338 | SBC 80P20 User's Guide | \$5.00 |
| 9800350 | iSBC 915 Go/No Go Diskette |  |
|  | Diagnostic and Monitor Program |  |
|  | User's Guide | \$5.00 |
| 9800508 | iSBC 80P05 User's Guide | \$5.00 |
| 9800522 | RMX/80 User's Guide | \$15.00 |
| 9800557 | Intellec Series II Model 210 |  |
|  | User's Guide | \$15.00 |
| 9800558 | A Guide to Intellec Microcomputer Development Systems, by |  |
|  | Daniel D. McCracken | \$2.00 |
|  | A Guide to PL/M Programming for |  |
|  | Microcomputer Applications, by Daniel D. McCracken | \$9.95 |
| 9800698 | MCS-86 System Design Kit User's |  |
|  | Guide | \$7.50 |
| 9800743 | iSBC 957-Intellec iSBC 86/12 |  |
|  | User's Guide | \$5.00 |
| 9800826 | $\mu$ Scope 820 Microcomputer Console |  |
|  | Key Sequence Guide | \$2.00 |
| Manuals |  |  |
| 9800017 | MCS-8 User's Manual | \$2.50 |
| 9800019 | 8008 Assembly Language Programming Manual | \$5.00 |
| 9800025 | 4004/4040 Assembly Language Programming Manual | \$5.00 |
| 9800042 | MCS-40 User's Manual | \$5.00 |
| 9800129 | Intellec 800 Microcomputer Development System Operator's Manual | \$15.00 |
| 9800132 | Intellec Microcomputer Development System Reference Manual | \$40.00 |
| 9800133 | Universal PROM Programmer Reference Manual | \$40.00 |
| 9800153 | MCS-80 User's Manual | \$7.50 |
| 9800167 | In-Circuit Emulator/80 Microcomputer Development System Hardware Reference Manual | \$35.00 |
| 9800172 | ROM Simulator Microcomputer |  |
|  | Development System ROM SIM |  |
|  | Reference Manual | \$25.00 |
| 9800185 | In/Circuit Emulator/80 Operator's |  |
|  | Manual | \$15.00 |
| 9800206 | ISIS-I Diskette Operating System |  |
|  | Operator's Manual | \$15.00 |
| 9800210 | Series 3000 Microprogramming |  |
|  | Manual | \$5.00 |
| 9800212 | Diskette Operating System Microcomputer Development System MDS DOS Hardware Reference |  |
|  | Manual | \$35.00 |


| 9800220 | In-Circuit Emulator/30 Microcomputer Development System ICE-30 Hardware Reference Manual | \$25.00 |
| :---: | :---: | :---: |
| 9800221 | Series 3000 Reference Manual | \$5.00 |
| 9800230 | iSBC 80/10 and ISBC 80/10A Single Board Computer Hardware Reference Manual | \$10.00 |
| 9800255 | MCS-48 and UPI-41 Assembly |  |
| 9800265 | Language Programming Manual iSBC 416 16K PROM/ROM Expansion Board Hardware Reference | \$10.0 |
|  | Manual | 5.0 |
| 980026 | PL/M Programming Manual | \$10.00 |
| 9800270 | MCS-48 Family of Single Chip |  |
|  | Microcomputers User's Manual | \$7.50 |
| 9800277 | iSBC 104/108/116 Combination Memory and I/O Expansion Boards |  |
|  | Hardware Reference Manual | \$5.0 |
| 9800278 | iSBC 508 I/O Expansion Board |  |
|  | Hardware Reference Manual | \$5.0 |
| 9800279 | iSBC 016 16K RAM Expansion |  |
|  | Board Hardware Reference Manual | \$5.0 |
| 9800292 | ISIS-II 8080/8085 Macro Assembler |  |
|  | Operator's Manual | \$10.00 |
| 9800294 | iSBC 501 Direct Memory Access |  |
|  | Manual | \$5.00 |
| 9800297 | iSBC 630 Power Supply User's |  |
|  | Manual | \$5.00 |
| 9800300 | ISIS-II PL/M-80 Compiler Operator's |  |
|  | Manual | \$15.00 |
| 9800301 | 8080/8085 Assembly Language |  |
|  | Programming Manual | \$10.00 |
| 9800307 | Intellec PROMPT 80/85 User's |  |
|  | Manual | \$5.00 |
| 9800316 | System 80/10 Microcomputer |  |
|  | Hardware Reference Manual | \$15.00 |
| 9800317 | iSBC 80/20 and iSBC 80/20-4 Single |  |
|  | Board Computer Hardware |  |
|  | Reference Manual | \$10.00 |
| 9800349 | iSBC 211/212 Disk |  |
|  | System Hard |  |
|  | Manual | 5.00 |
| 9800366 | MCS-85 User's Manual | \$5.00 |
| 9800385 | iSBC 519 Programmable I/O Expansion Board Hardware Reference |  |
|  | Manual | \$7.50 |
| 9800386 | Intellec Mirocomputer Development |  |
|  | System Diagnostic Confidence Test Operator's Manual | \$5.00 |
| 9800388 | iSBC 517 Combination I/O Expansion Board Hardware Reference |  |
|  | Manual | \$7.50 |
| 9800402 | PROMPT 48 Microcomputer User's |  |
|  | Manual | \$7.50 |
| 9800410 | iSBC 310 High-Speed Mathematics |  |
|  | Unit Hardware Reference Manual | \$5.0 |
| 9800420 | iSBC 202 Double Density Diskette |  |
|  | Controller Hardware Reference |  |
|  | Manual | \$5.0 |
| 9800422 | Intellec Double Density Diskette |  |
|  | Operating System Hardware |  |
|  | Reference Manual |  |


| 9800449 | iSBC 094 4K Byte CMOS RAM/ Battery Backup Board Hardware Reference Manual | \$5.00 |
| :---: | :---: | :---: |
| 9800450 | iSBC 534 Four Channel Communications Expansion Board Hardware |  |
|  | Reference Manual | \$5.00 |
| 9800451 | SDK-85 User's Manual | \$5.00 |
| 9800452 | 8080/8085 Floating Point Arithmetic Library User's Manual | \$5.00 |
| 9800463 | ICE 85 In -Circuit Emulator Operating Instructions for ISIS-II Users | \$25.00 |
| 9800464 | ICE-48 Operator's Manual | \$20.00 |
| 9800465 | In-Circuit Emulator/41 Operator's Manual | \$15.00 |
| 9800466 | PL/M-86 Programming Manual | \$10.00 |
| 9800467 | PROMPT-SPP Specialized PROM Programming User's Manual | \$5.00 |
| 9800478 | ISIS-II PL/M-86 Compiler Operator's Manual | \$15.00 |
| 9800480 | ISIS-II FORTRAN-80 Compiler Operator's Manual | \$20.00 |
| 9800481 | FORTRAN 80 Programming Manual | \$10.00 |
| 9800482 | iSBC 80/04 Single Board Computer Hardware Reference Manual | \$7.50 |
| 9800483 | iSBC 80/05 Single Board Computer Hardware Reference Manual | \$7.50 |
| 9800484 | System 80/20-4 Microcomputer Hardware Reference Manual | \$15.00 |
| 9800485 | iSBC 711 Analog Input Board Hardware Reference Manual | \$5.00 |
| 9800486 | iSBC 724 Analog Output Board Hardware Reference Manual | \$5.00 |
| 9800487 | iSBC 732 Combination Analog Input/Output Board Hardware |  |
|  | Reference Manual | \$5.00 |
| 9800488 | iSBC 032/048/064 Random Access Memory Boards Hardware |  |
|  | Reference Manual | \$5.00 |
| 9800489 | iSBC 556 Optically Isolated Programmable I/O Board Hardware |  |
|  | Reference Manual | \$5.00 |
| 9800504 | UPI-41 User's Manual | \$5.00 |
| 9800505 | iSBC 660 System Chassis Hardware |  |
|  | Reference Manual | \$5.00 |
| 9800556 | Intellec Series II Hardware |  |
|  | Reference Manual | \$25.00 |


| 9800559 | Intellec Series II Installation and <br>  <br> Service Manual | $\$ 15.00$ |
| :--- | :--- | ---: |
| 9800592 | $\mu$ Scope 8080A Probe Service <br> Manual | $\$ 15.00$ |
| 9800593 | $\mu$ Scope 820 Microprocessor System <br> Console Service Manual | $\$ 15.00$ |
| 9800611 | iSBC 80/30 Single Board Computer <br> Hardware Reference Manual <br> iSBC 544 Hardware Reference | $\$ 10.00$ |
| 9800616 | $\$ 7.50$ |  |
|  | Manual |  |
| 9800639 | MCS-86 Software Development <br>  <br>  <br>  <br>  <br> ISilities Operating Instructions for |  |
| 9800641 | MCS-86 Assembler Operating | $\$ 20.00$ |
|  | Instructions for ISIS-II Users |  |$\quad \$ \$ 15.00$


| Handbooks |  |  |
| :--- | :--- | ---: |
| 9800526 | $\mu$ Scope 820 Microprocessor System |  |
|  | Console Operator's Handbook | $\$ 15.00$ |
| 9800676 | Peripheral Design Handbook - 1979 | $\$ 7.50$ |
| 111100 | Memory Design Handbook | $\$ 5.00$ |

Specifications
$\begin{array}{ll}9800199 & \text { External Reference Specification } \\ & \text { ROM Simulator }\end{array} \$ 2.50$

|  |  |
| :--- | :--- |
| 9800222 | External Reference Specification |
| ICE-30 Software Driver |  |

9800606 Intellec Series II Microcomputer Development Systems Functional Description and Specifications

N/C

3065 Bowers Avenue
Santa Clara, California 95051
Santa Clara, (408) $987-8080$
TWX. 910-338-0026
TELEX: 34-6372

## ALABAMA

Intel Corp
3322 S. Parkway, Ste. 71
Holiday Office Center
Huntsville 35802
Tel: (205) 883-2430
Glen White Associates
3502 9th Avenue
Huntsville 35805
Tel: (205) 883-9394
$\dagger$ Pen-Tech Associates, Inc.
Holiday Office Center
3322 S. Memorial Pkwy.
Huntsville 35801
Tel: (205) 533-0090

## ARIZONA

Intel Corp
8650 N. 35th Avenue, Suite 101
Phoenix 85021
Tel. (602) 242-7205
+BFA
4426 North Saddle Bag Trail
Scottsdale 85251
Tel: (602) 994-5400

## CALIFORNIA

Intel Corp.
7670 Opportunity Rd
Suite 135
San Diego 92111
Tel: (714) 268-3563
Intel Corp.*
1651 East 4th Street
Suite 105
Santa Ana 92701
Tel: (714) 835-9642
TWX: 910-595-1114
Intel Corp.*
15335 Morrison
Suite 345
Sherman Oaks 91403
(213) 986-9510

TWX: 910-495-2045
Intel Corp.*
3375 Scott Blvd.
Santa Clara 95051
Tel: (408) 987-8086
TWX: 910-338-0255
Earle Associates, Inc
4805 Mercury Street
Suite L
San Diego 92111
Tel: (714) 287-5441
$\mathrm{Mac}-1$
2576 Shattuck Ave
Suite 4B
Berkeley 94704
Tel: (415) 843-7625
Mac-I
P.O. Box 1420

Cupertino 95014
Tel: (408) 257-9880
Mac-1
P.O. Box 8763

Fountain Valley 92708
Tel: (714) 839-3341
Mac-1
20121 Ventura Blvd., Suite 240E
Woodland Hilis 9136
Tel: (213) 347-5900

## COLORADO

6000 East Evans Ave
Bldg. 1, Sutte 260
Denver 80222
Tel: (303) 758-8086
TWX: 910-931-2289
$\dagger$ Westex
27972 Meadow Drive
P.O. Box 1355

Evergreen 80439
Tel: (303) 674-5255

## CONNECTICUT

## Intel Corp.

Peacock Alley
1 Padanaram Road, Suite 146
Danbury 06810
Tel: (203) 792-8366
TWX: 710-456-1199

## FLORIDA

Intel Corp.
1001 N.W. 62 nd Street, Suite 406
Ft. Lauderdale 33309
, Lauderdale 3330
TWX -510-956-9407
Intel Corp.
5151 Adanson Street, Suite 203
Orlando 32804
TWX: (305) 628-2393
Pen-Tech Associ
Pen-Tech Associates, Inc.
201 S.E. 15th Terrace, Suite F
Tel: (305) 421-4989

Pen-Tech Associates, Inc
111 So. Maitland Ave., Suite 202 Maitland 32751
Tel: (305) 645-3444

## GEORGIA

tPen-Tech Associates, Inc.
Suite 305 C
2101 Powers Ferry Road
Atlanta 30339
Tel: (404) 955-0293

## ILLINOIS . <br> Intel Corp.*

900 Jorie Boulevard
Suite 220
Oakbrook 60521
Tel. (312) 325-9510
TWX: 910-651-5881
$\dagger$ Dytek-Central, Inc.
Suite 304
Arlington Heights 60005
Tel. (312) 394-3380
TWX: 910-687-2267

## INDIANA

Electro Reps Inc.
941 E. 86th Street, Suite 101
Indianapolis 46240
Tel: (317) 255-4147

## IOWA

Technical Representatives, Inc.
St. Andrews Building
1930 St. Andiews Drive N.E.
Cedar Rapids 52405
Tel. (319) 393-5510

## KANSAS

Technical Representatives, Inc.
8245 Nieman Road, Suite \#100
Lenexa 66214
Tel: (913) 888-0212, 3, \& 4
TWX: 910-749-6412
KENTUCKY
†Lowry \& Associates, Inc.
3351 Commodore
Lexington 40502
Tel: (606) 269-6329

## MARYLAND

Intel Corp.*
7257 Parkway Drive
Hanover 21076
Tel: (301) 796-7500
TWX: 710-862-1944
TWX. 710-862-1944
Glen White Associates
57 W. Timonium Road, Suite 307
Timonium 21093
Tel: (301) 252-6360
$\dagger$ Mesa Inc.
11900 Parklawn Drive
Rockville 20852
el: Wash. (301) 881-8430 Balto. (301) 792-0021

## MASSACHUSETTS

Intel Corp.*
187 Billerica Road, Suite 14A
Chelmsford 01824
TWX: 710-343-633
$\dagger$ Computer Marketing, Inc.
257 Crescent Street
257 Crescent St
Tel: (617) 894-7000

## MICHIGAN <br> Intel Corp.

26500 Northwestern Hwy.
Suite 401
Southfield 48075
Tel: (313) 353-0920
TWX: 910-420-1212
TELEX: 231143
thowry \& Associates, Inc.
135 W. North Street
Suite 4
Brighton 48116
Tel: (313) 227-7067

## MINNESOTA

Intel Corp.
8200 Normandale Avenue
Suite 422
Bloomington 55437
Tel: (612) 835-6722
$\dagger$ Dytek North
1821 University Ave.
Room 163 N
St Paul 5510
Tel: (612) 645-5816

PENNSYLVANIA
Intel Corp.*
275 Commerce Dr.
200 Office Center
Suite 212
Fort Washington 19034
Tel' (215) 542-9444
TWX 510-661-2077
$\dagger$ Lowry \& Associates, Inc
Seven Parkway Center
Suite 455
Pittsburgh 15520
Tel: (412) 922-5110
tQ.E.D. Electronics
300 N. York Road
Hatboro 19040
Tel' (215) 674-9600
TENNESSEE
Glen White Associates
Rt. \#12, Norwood S/D
Jonesboro 37659
Tel: (615) 477-8850
Glen White Associates
Germantown 38138
German1 7540483
Tel: (901) 754-0
Glen White Associates
6446 Ridge Lake Road
Hixon 37343
Tel: (615) 842-7799

## TEXAS

2925 L.B.J. Freeway
Suite 175
Dallas 75234
Tel: (214) 241-9521
TWX: 910-860-5487
Intel Corp.*
6776 S.W. Freeway
Suite 550
Houston 77074
Tel: (713) 784-3400
Mycrosystems Marketing Inc.
13777 N. Central Expresswav
Suite 405
Dallas 75243
Tel: (214) 238-7157
TWX: 910-867-4763
Mycrosystems Marketing inc.
6610 Harwin Avenue, Suite 125
Houston 77036
Tel: (713) 783-2900

## UTAH

$\ddagger$ Westek
3788 Brockbank Drive
Salt Lake City 84117
Tel: (801) 278-6920
VIRGINIA
Glen White Associates
P.O. Box 1104

Tel: (804) 24505

- White Asso

Glen White Associates
Rt. \#1, Box 322
Tel (804) 224-4871

## WASHINGTON

Intel Corp.
300 120th Avenue N.E
Bldg. 2, Suite 202
Bellevue 98005
Tel: (206) 453-8086
E.S./Chase Co.
S.O. Box 8090

Tel: (206) 762-4824
TWX•910-444-2298
WISCONSIN
Intel Corp.
4369 S. Howell Ave
Milwaukee 53207
Tel: (414) 747-0789

## CANADA

Intel Corp
Suite 233, Bell Mews
39 Highway 7, Bell Corners
Ottawa, Ontario K2H 8R2
TELEX. $053-4419$
TELEX: 053-44
Multilek, Inc.*
15 Grenfell Crescent
Ottawa, Ontario K2G OG3
Tel: (613) 226-2365
TELEX: 053-4585

[^1]3065 Bowers Avenue
Santa Clara, California 95051
TWX:910-338-0026
TELEX: 34-6372

EUROPEAN MARKETING OFFICES

| BELGIUM | ISRAEL |
| :---: | :---: |
| Intel International* | Intel Semiconductor Ltd. |
| Rue du Moulin à Papier | P.O. Box 1659 |
| 51-Boite 1 | Haifa |
| B-1160 Brussels | Tel: 972/452 4261 |
| Tel. (02) 6603010 | TELEX: 92246511 |
| TELEX: 24814 |  |
| FRANCE | Intel Semiconductor Nederland B.V. |
| Intel Corporation, S.A.R.L.* | Cometongebouw |
| 5 Place de la Balance | Westblaak 106 |
| Silic 223 | 3012 Km Rotterdam |
| 94528 Rungis Cedex | Tel: (10) 149122 |
| Tel: (01) 6872221 | TELEX: 22283 |
| TELEX:270475 | SCANDINAVIA |
|  | Intel Denmark A/S* |
|  | Lyngbyvej 32 2nd Floor |
| ORIENT MARKETING OFFICE | DK-2100 Copenhagen East |
| JAPAN | Tel: (01) 182000 |
| Intel Japan Corporation* | TELEX: 19567 |
| Flower Hitl-Shinmachi East Bldg. | Intel Sweden AB* |
| 1-23-9, Shinmachi, Setagaya-ku | Enighetsvagen, 5 |
| Tokyo 154 | S-16120 Bromma |
| Tel: (03) 426-9261 | Sweden |
| TELEX: 781-28426 | Tel: (08) 985390 |
|  | TELEX: 12261 |

INTERNATIONAL DISTRIBUTORS
ARGENTINA
S I.E S.A.
S I.E S.A.
Av. Pte. Rogue Saenz Pena 1142 9B
1035 Buenos Aires
Tel 35-6784
aUSTRALIA
A.J.F. Systems \& Components

4 Prospect Rd
Prospect 5082
South Australia 17005
TELEX: 82635
A.J.F. Systems \& Components

99 Devin.
Ryde, N.S.W. 2112
Tel. (02) 807-6878
TELEG: 24906
A.J.F. Systems \& Components

TYY. LTD.
310 Queen St. Melbourne
Tel: (03) 679-70
TELEX: 30270
Warburton-Frankı (Sydney) Pty. Ltd.
199 Parramatta Road
auburn, N.S.W. 2114
el. 648-1711, 648-138
ELEX: WARFRAN AA 22265
Warburton-Franki Industries
Melbourne) Pty. Lt
220 Park Street
ne, Victoria 3205
el: 699-4999
Warburton Franki, P
322 Grange Road, Kidman Park
South Australia 5025
Tel: 356 -7333
TELEX: WAR
ELEX: WARFRAN AA 92908
Warburton Franki (Perth) Pty. Ltd
$8-102$ Belgravia St., Belmo
Tel. 356-7000
TELEX: WARFRAN AA 92908
Warburton Frankı (Brisbane) Pty. Ltd.
3 Chester St., Fortitude Valley
Queensland 4006
ELEX. WARFRAN AA 41052
acher Elektronische Geraete GmbH
Rotenmulgasse 26
A 1120 Vienna
el: (0222) 83639
Rekırsch Elektronik Geraete GmbH
ottfried-Keller-Gassa, 29
1030 Vienna
el: (222) 734394
ELEX• 74759
BELGIUM
nelco Belgium S.A.
Avenue Val Duchesse, 3

1. (02) 66000

ELEX: 25441
BRAZIL
jeotron S.A 110 -Av, Mutinga 3650
6 Andar
Prituba-Sao Paul
el. 261-0211
ELEX: (011) 222 ICO BR
CHILE
Intellec
P. Box 13317
Dr Sotero Del Rio 326
Oficina 903
Tel. 723740

SCANDINAVIA (continued)
Intel Scandinavia A/S
P.O. Box 158
N-2040
Klofta, Norway
Tel. $472 / 981068$
TELEX: 18018
Intel Scandinavia A/S
P.O. Box 17
Sentnerikuja, 3
SF-00400
Helsinki, Finland
Tel: 358 0/55 8531
TELEX: 123332
ENGLAND
Intel Corporation (U.K.) Ltd. *
Broadfield House
4 Between Towns Road
Cowley. Oxford OX4 3NB
Tel: (0865) 771431
TELEX- 837203
Intel Corporation (U.K.) Ltd
46-50 Beam Street
N-ntwich, Cheshire CW5 5LJ
Tel. (0270) 626560
TELEX: 36620

| ISRAEL | SINGAPORE |
| :---: | :---: |
| Eastronics Ltd.* | General Engıneers Associates |
| 11 Rozanis Street | Bik 3, 1003-1008 |
| P.O. Box 39330 | P.S.A. Mult-Story Complex |
| Tel-Aviv 61390 | Telok Blangah/Pasir Panjang |
| Tel: 475151 | Singapore 5 |
| TELEX: 33638 | Tel: 271-31є3 |
| Italy |  |
| Eledra 3S S.P.A.* | SOUTH AFRICA |
| Viale Elvezia, 18 | Electronic Building Elements |
| 20154 Milan, | P.O. Box 4609 |
| Tel ( 02 ) 3493041 | Pretoria |
| TELEX: 39332 | Tel: 789221 |
| Eledra 3S S.P.A.* | TELEX: 30181 |
| Via Paolo Gaidano, 141 D | SPAIN |
| 10137 Torino 097 | Interface* |
| TEL: (011) 3097 097-3097114 | Ronda San Pedro 22 |
| TELEX: 210632 | Barcelona 10 |
| Eledra 3S S.P.A.* | Tel 3017851 |
| Via Giuseppe Valmarana, 63 | TELEX: 51508 IFCE E |
| 00139 Rome, ttaly | ITT SESA |
| Tel. (06) 8127 290-8127 324 | Miguel Anget 16 |
| TELEX. 612051 | Madrid 10 |
| JAPAN | Tel: (1) 4102354 |
| Tokyo Electron Labs, Inc. | TELEX: 27707 |
| No 1 Higashikata-Machi | SWEDEN |
| Midori-Ku, Yokohama 226 | Nordisk Electronik AB |
| Tel: (045) 471-8811 | Sandhamnsgatan 71 |
| TELEX: 781-4773 | S-102 54 Stockholm |
| Ryoyo Electric Corp. | Tel: (08) 635040 |
| Konwa Bldg. | TELEX. 10547 |
| 1-12-22, Tsukiji, 1-Chome |  |
| Chuo-Ku, Tokyo 104 |  |
| Tel: (03) 543-7711 |  |
| Nippon Micro Computer Co. Ltd. | $\text { Postcheck } 80-21190$ |
| Mutsumi Bldg. 4-5-21 Kojimachi | $\mathrm{CH}-8021$ Zurich |
| Chiyoda-ku, Tokyo 102 | Tel. (01) 602230 |
| Tel ( 03 ) 230-0041 | TELEX: 56788 |
| KOREA | TAIWAN |
| Koram Digital | Taiwan Automation Co.* |
| Room 411 Ahil Bldg. | 2nd Floor, 224 |
| 49-4 2-GA Hoehyun-Dong | Nanking East Road |
| Chung-Ku Seoul | Section 3 |
| CABLE: CHEJU 26364 | Taipei |
|  | Tel: (02) 7710940-3 |
| Leewood International, Inc. C.P.O. Box 4046 | TELEX: 11942 TAIAUTO |
| 112-25, Sokong-Dong | UNITED KINGDOM |
| Chung-Ku, Seoul 100 | G.E.C. Semiconductors Ltd |
| Tel: 28-5927 | East Lane |
| CABLE: "LEEWOOD" Seoul | North Wembly |
|  | Middlesex HAS 7PP |
| NETHERLANDS | Tel: (01) 904-9303 |
| C.N. Rood BV | TELEX: 923429 |
| Cort Vender | Jermyn Industries |
| Lindenstraat, 13 | Vestry Estate |
| Postbus 428 | Sevenoaks, Kent |
| Tel 070-996360 | Tel: (0732) 51174 |
| TELEX: 31238 | TELEX: 95142 |
| Inelco Nederland | Sintrom Electronics Ltd.* |
| AFD Elektronic | Arkwright Road |
| Joan Muyskenweg 22 | Reading, Berkshire RG2 OLS |
| NL-1006 Amsterdam |  |
| Tel' (020) 934824 | TELEX: 847395 |
| TELEX: 14622 | Rapid Recall, Ltd. 6 Soho Mills Ind. Park |
| NEW ZEALAND | Woburn Green |
| W. K. McLean Ltd. | Bucks, England |
| 103-5 Felton Matthew Avenue | Tel: Bournd End 24961 |
| Glenn Innes, Auckland, 6 | TELEX. 849439 |
| Tel: 587-037 | VENEZUELA |
| TELEX. NZ2763 KOSFY | Componentes y Circuitos |
| NORWAY | Electronicas TTLCA C.A. |
| Nordisk Elektronik (Norge) A/S | Apartado 3223 |
| Mustads Vei 1 | Caracas 101 |
| N -Osio 2 | Tel: 35-5591 |
| Tel (02) 553893 | TELEX: TAMER 24157 |
| TELEX: 16963 |  |
| PORTUGAL |  |
| Ditram ${ }^{\text {a }}$ a |  |
| Componentes E Electronica LDA |  |
| Av. Miguel Bombarda, 133 | *Field Application Location |
| Lisboa 1 |  |

U.S. AND CANADIAN DISTRIBUTORS

3065 Bowers Avenue
Santa Clara, California 95051
Tel: (408) 987-8080
TWX: 910-338-0026
TELEX: 34-6372

## ALABAMA

$\dagger$ Hamilton/Avnet Electronics
805 Oser Drive NW
Huntsville 35805
Tel: (205) 837-7210
Pioneer
1207 Putman Drive NW
Huntsville 35805
Tel: (205) 837-9300

## ARIZONA

$\dagger$ Hamilton/Avnet Electronics
2615 South 21st Street
Phoenix 85034
Tel: (602) 275-7851
†Liberty/Arizona
8155 N. 24th Avenue
Phoenix 85021
Tel: (602) 249-2232
TELEX: 910-951-4282

## CALIFORNIA

$\dagger$ Avnet Electronics
350 McCormick Avenue
Costa Mesa 92626
Tel: (714) 754-6111
$\dagger$ Hamilton/Avnet Electronics
575 E. Middlefield Road
Mountain View 94040
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
Tel: (213) 558-2121
†Liberty Electronics
124 Maryland Street
El Segundo 90245
Tel: (213) 322-5059
TWX: 910-348-7140
$\dagger$ Liberty/San Diego
8284 Mercury Court
San Diego 92111
Tel: (714) 565-9171
TELEX: 910-335-1590
$\dagger$ Elmar Electronics
2288 Charleston Road
Mountain View 94040
Tel: (415) 961-3611
TELEX: 910-379-6437

## COLORADO

$\dagger$ Elmar/Denver
6777 E. 50th Avenue
Commerce City 80022
Tel: (303) 287-9611
TWX: 910-936-0770
$\dagger$ Hamilton/Avnet Electronics
5921 No. Broadway
Denver 80216
Tel: (303) 534-1212
CONNECTICUT
$\dagger$ Cramer/Connecticut
12 Beaumont Road
Wallingford 06492
Tel: (203)265-7741
$\dagger$ Hamilton/Avnet Electronics
643 Danbury Road
Georgetown 06829
Tel: (203) 762-0361
$\dagger$ Harvey Electronics
112 Main Street
Norwalk 06851
Tel: (203) 853-1515

FLORIDA
Arrow Electronics
1001 N.W. 62nd Street
Suite 402
Ft. Lauderdale 33309
Tel: (305) 776-7790
Arrow Electronics
115 Palm Bay Road, NW
Suite 10
Palm Bay 32905
Tel: (305) 725-1480
$\dagger$ Hamilton/Avnet Electronics
6800 Northwest 20th Ave.
Ft. Lauderdale 33309
Tel: (305) 971-2900
$\dagger$ Pioneer
6220 S. Orange Blossom Trail
Suite 412
Orlando 32809
Tel: (305) 859-3600
Hamilton/Avnet
3197 Tech. Drive N.
St. Petersburg 33702
Tel: (813) 576-3930

## GEORGIA

Arrow Electronics
3406 Oak Cliff Road
Doraville 30340
Tel: (404) 455-4054
$\dagger$ Hamilton/Avnet Electronics
6700 I 85, Access Road, \#11
Norcross 30071
Tel: (404) 448-0800

## ILLINOIS

$\dagger$ Cramer/Chicago
1911 So. Busse Rd.
Mt. Prospect 60056
Tel: (312) 593-8230
$\dagger$ Hamilton/Avnet Electronics
3901 No. 25th Ave.
Schiller Park 60176
Tel: (317) 849-7300
Pioneer/Chicago
1551 Carmen Drive
Elk Grove Village 60006
Tel: (312) 437-9680

## INDIANA

$\dagger$ Pioneer/Indiana
6408 Castleplace Drive
Indianapolis 46250
Tel: (317) 849-7300
Sheridan Sales
8790 Purdue Road
Indianapolis 46268
Tel: (317) 297-3146

## KANSAS

$\dagger$ Hamilton/Avnet Electronics 9219 Quivira Road
Overland Park 66215
Tel: (913) 888-8900

## MARYLAND

$\dagger$ Hamilton Avnet
7235 Standard Drive
Hanover 21076
Tel: (301) 796-5684
$\dagger$ Pioneer/Washington
9100 Gaither Road
Gaithersburg 20760
Tel: (301) 948-0710
TWX: 710-828-0545

## MASSACHUSETTS

$\dagger$ Cramer Electronics Inc.
85 Wells Avenue
Newton 02159
Tel: (617) 969-7700

MASSACHUSETTS (continued)
$\dagger$ Hamilton/Avnet Electronics
100 E. Commerce Way
Woburn 01801
Tel: (617) 933-8000

## MICHIGAN

†Sheridan Sales Co.
24543 Indoplex Circle
Farmington Hills 48024
Tel: (313) 477-3800
$\dagger$ Pioneer/Michigan
13485 Stamford
Livonia 48150
Tel: (313) 525-1800
$\dagger$ Hamilton/Avnet Electronics
32487 Schoolcraft Road
Livonia 48150
Tel: (313) 522-4700
TWX: 810-242-8775

## MINNESOTA

†Industrial Components
5280 West 74th Street
Minneapolis 55435
Tel: (612) 831-2666
$\dagger$ Cramer/Bonn
5424 Edina Industrial Blvd.
Edina 55435
Tel: (612) 835-7811
$\dagger$ Hamilton/Avnet Electronics
7683 Washington Avenue So.
Edina 55435
Tel: (612) 941-3801

## MISSOURI

$\dagger$ Hamilton/Avnet Electronics
364 Brookes Drive
Hazelwood 63042
Tel: (314) 731-1144
Sheridan Sales
220 S. Hwy 67, Suite 10
Florissant 63031
Tel: (314) 837-5200

## NEW JERSEY

Arrow Electronics
Pleasant Valley Avenue
Moorestown 08057
Tel: (215) 928-1800
Arrow Electronics
285 Midland Avenue
Saddlebrook 07662
Tel: (201) 797-5800
$\dagger$ Hamilton/Avnet Electronics
218 Little Falls Road
Cedar Grove 07009
Tel: (201) 239-0800
TWX: 710-994-5787
$\dagger$ Harvey Electronics
389 Passaic Avenue
Fairfield 07006
Tel: (201) 227-1262
$\dagger$ Hamilton/Avnet Electronics
113 Gaither Drive
East Gate Industrial Park
Mt. Laurel 08057
Tel: (609) 234-1233
TWX: 710-897-1405

## NEW MEXICO

Alliance Electronics inc.
11728 Linn Ave., N.E.
Albuquerque 87123
Tel: (505) 292-3360
$\dagger$ Hamilton/Avnet Electronics
2524 Baylor Drive, S.E.
Albuquerque 87119
Tel: (505) 765-1500

## U.S. AND CANADIAN DISTRIBUTORS

3065 Bowers Avenue
Santa Clara, California 95051
Tel: (408) 987-8080
TWX: 910-338-0026
TELEX: 34-6372

## NEW YORK

Harvey Electronics
P.O. Box 1208

Binghampton 13902
Tel: (607) 748-8211
Arrow Electronics 900 Broad Hollow Road
Farmingdale 11735
Tel: (516) 694-6800
$\dagger$ Cramer/Rochester
3000 South Winton Road
Rochester 14623
Tel: (716) 275-0300
$\dagger$ Hamilton/Avnet Electronics
167 Clay Road
Rochester 14623
Tel: (716) 442-7820
†Cramer/Syracuse
6716 Joy Road
East Syracuse 13057
Tel: (315) 437-6671
$\dagger$ Hamilton/Avnet Electronics
6500 Joy Road
E. Syracuse 13057

Tel: (315) 437-2641
$\dagger$ Hamilton/Avnet Electronics
70 State Street
Westbury, L.I. 11590
Tel: (516) 333-5800
TWX: 510-222-8237
$\dagger$ Harvey Electronics
60 Crossways Park West
Woodbury 11797
Tel: (516) 921-8700
NORTH CAROLINA
Pioneer/Carolina
2906 Baltic Avenue
Greensboro 27406
Tel: (919) 273-4441
TWX: 510-925-1114
$\dagger$ Hamilton/Avnet Electronics
2803 Industrial Drive
Raleigh 27609
Tel: (919) 829-8030
Arrow Electronics
1377-G S. Park Drive
Kernersville 27284
Tel: (919) 996-2039

## OHIO

†Sheridan Sales Co.
2501 Neff Road
Dayton 45414
Tel: (513) 223-3332
Sheridan Sales Co.
23224 Commerce Park Road
Beachwood 44122
Tel: (216) 831-0130
$\dagger$ Hamilton/Avnet Electronics
954 Senate Drive
Dayton 45459
Tel: (513) 433-0610
TWX: 810-450-2531
Pioneer/Dayton
1900 Troy Stree
Dayton 45404
Tel: (513) 236-9900
+Sheridan Sales Co.
P.O. Box 37856

Cincinnati 45222
Tel: (513) 761-5432
TWX: 810-461-2670
$\dagger$ Pioneer/Cleveland
4800 E. 131st Street
Cleveland 44105
Tel: (216) 587-3600
$\dagger$ Hamilton/Avnet Electronics
761 Beta Drive, Suite E
Cleveland 44143
Tel: (216) 461-1400

OHIO (continued)
$\dagger$ Sheridan Sales Co.
701 Beta Drive
Mayfieldville 44143
Tel: (216) 461-3300

## OKLAHOMA

$\dagger$ Components Specialties, Inc
7920 E. 40th Street
Tulsa 74145
Tel: (918) 664-2820

## OREGON

$\dagger$ Almac/Stroum Electronics
4475 S.W. Scholls Ferry Rd.
Portland 97225
Tel: (503) 292-3534

## PENNSYLVANIA

Sheridan Sales Co.
4297 Greensburgh Pike, Suite 3114
Pittsburgh 15221
Tel: (412) 351-4000
Pioneer/Pittsburgh
560 Alpha Drive
Pittsburgh 15238
Tel: (412) 782-2300
Pioneer/Delaware Valley
141 Gibraltar Road
Horsham 19044
Tel: (215) 674-4000
TWX: 510-665-6778

## TENNESSEE

$\dagger$ Sheridan Sales Co.
6900 Office Park Circle
Knoxville 37919
Tel: (615) 588-5836

## TEXAS

Component Specialties Inc.
8330 Burnett Road, Suite 101
Austin 78758
Tel: (512) 459-3308
tCramer Electronics
13740 Midway Road
Dallas 75240
Tel: (214) 661-9300
$\dagger$ Hamilton/Avnet Electronics
4445 Sigma Road
Dallas 75240
Tel: (214) 661-9300
$\dagger$ Hamilton/Avnet Electronics
3939 Ann Arbor
Houston 77063
Tel: (713) 780-1771
$\dagger$ Component Specialties, Inc.
10907 Shady Trail, Suite 101
Dallas 75220
Tel: (214) 357-6511
$\dagger$ Component Specialties, Inc.
8585 Commerce Park Drive, Suite 590
Houston 77036
Tel: (713) 771-7237

## UTAH

$\dagger$ Hamilton/Avnet Electronics
1585 West 2100 South
Salt Lake City, 84119
Tel: (801) 972-2800
WASHINGTON
Hamilton/Avnet Electronics
14212 N.E. 21s
Bellevue 98005
Tel: (208) 746-8750
$\dagger$ Almac/Stroum Electronics
5811 Sixth Ave. South
Seattle 98108
Tel: (206) 763-2300

WASHINGTON (continued)
+Liberty Electronics
1750 132nd Avenue NE
Bellevue 98005
Tel: (206) 763-8300

## WISCONSIN

Arrow Electronics
434 W. Rawson Avenue
Oak Creek 53154
Tel: (414) 764-6600
$\dagger$ Hamilton/Avnet
2975 Moorland Road
New Berlin 53151
TeI: (414) 784-4510

## CANADA

## ALBERTA

$\dagger$ L. A. Varah Ltd
4742 14th Street N.E
Calgary T2E 6L7
Tel: (403) 276-8818
Telex: 138258977
BRITISH COLUMBIA
†L.A. Varah Ltd.
2077 Alberta Street
Vancouver V5Y 1C4
Tel: (604) 873-3211
TWX: 610-929-1068
Telex: 0453167
Zentronics
8325 Fraser Street
Vancouver V5X 3X8
Tel: (604) 325-3292
Telex: 04-5077-89

## MANITOBA

L. A. Varah

1-1832 King Edward Street
Winnipeg R2R 0N1
Tel: (204) 633-6190

## ONTARIO

L.A. Varah, Ltd

505 Kenora Avenue
Hamilton L8E-3P2
Tel: (416) 561-9311
TELEX: 061-8349
Hamilton/Avnet Electronics
3688 Nashua Drive, Units G \& H
Mississauga L4V IM5
Tel: (416) 677-7432
TWX: 610-492-8867
$\dagger$ Hamilton/Avnet Electronics
1735 Courtwood Cresc.
Ottawa K2C 3J2
Tel: (613) 226-1700
TWX: 610 562-1906
Zentronics
141 Catherine Street
Ottawa, Ontario K2P 1C3
Tel: (613) 238-6411
$\dagger$ Zentronics
99 Norfinch Dr.
Downsview, Ontario M3N 1W8
Tel: (416) 635-2822
Telex: 02-021694

## QUEBEC

$\dagger$ Hamilton/Avnet Electronics
2670 Paulus Street
St. Laurent H4S 1G2
Tel: (514) 331-6443
TWX: 610-421-3731
Zentronics
8146 Montview Road
Town of Mt. Royal
Montreal H4P 2L7

## Random Access Memory



RANDOM ACCESS MEMORIES

|  | Type | No. of Bits | Description | Organization | $\begin{aligned} & \text { No. } \\ & \text { of } \\ & \text { Pins } \end{aligned}$ | Electrical Characteristics Over Temperature |  |  |  | Page No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | Access Time Max. (ns) | Cycle <br> Time Min. (ns) | Power <br> Dissipation Max. ${ }^{\|1\|}$ Operating/ Standby (mW) | Supplies (V) |  |
| DYNAMIC RAMS |  |  |  |  |  |  |  |  |  |  |
|  | $\begin{aligned} & 2104 A \\ & 2104 A-1 \\ & 2104 A-2 \\ & 2104 A-3 \\ & 2104 A-4 \end{aligned}$ | 4096 | 16-Pin Dynamic | 4096x1 | 16 | 350 | 350 | 441/25 | +12, +5, -5 | 3-12 |
|  |  | 4096 | 16-Pin Dynamic | 4096x1 | 16 | 150 | 320 | 462/26 | +12, +5, -5 |  |
|  |  | 4096 | 16-Pin Dynamic | 4096x1 | 16 | 200 | 375 | 422/26 | +12, +5, -5 |  |
|  |  | 4096 | 16-Pin Dynamic | 4096x1 | 16 | 250 | 375 | 396/26 | +12, +5, -5 |  |
|  |  | 4096 | 16-Pin Dynamic | 4096x1 | 16 | 300 | 425 | 396/26 | +12, +5, -5 |  |
|  | $\begin{aligned} & \hline 2107 \mathrm{C} \\ & 2107 \mathrm{C}-1 \\ & 2107 \mathrm{C}-2 \\ & 2107 \mathrm{C}-4 \end{aligned}$ | 4096 | 22-Pin Dynamic | 4096x1 | 22 | 250 | 430 | 396/2.6 | +12, $+5,-5$ | 3-28 |
|  |  | 4096 | 22-Pin Dynamic | 4096x1 | 22 | 150 | 380 | 462/2.6 | +12, +5, -5 |  |
|  |  | 4096 | 22-Pin Dynamic | 4096x1 | 22 | 200 | 400 | 436/2.6 | +12, +5, -5 |  |
|  |  | 4096 | 22-Pin Dynamic | 4096x1 | 22 | 300 | 470 | 396/2.6 | +12, +5, -5 |  |
|  | $\begin{gathered} \hline 2109-3 \\ 2109-4 \end{gathered}$ | 8192 | 16-Pin Dynamic | $8192 \times 1$ | 16 | 200 | 375 | 462/20 | +12, +5, -5 | 3-33 |
|  |  | 8192 | 16-Pin Dynamic | $8192 \times 1$ | 16 | 250 | 410 | 436/20 | +12, +5, -5 |  |
|  | $\begin{gathered} \hline 2117-2 \\ 2117-3 \\ 2117-4 \\ 2117-5 \end{gathered}$ | 16,384 | 16-Pin Dynamic | 16,384×1 | 16 | 150 | 320 | 462/20 | +12, +5, -5 | 3-64 |
|  |  | 16,384 | 16-Pin Dynamic | 16,384x1 | 16 | 200 | 375 | 462/20 | +12, +5, -5 |  |
|  |  | 16,384 | 16-Pin Dynamic | 16,384×1 | 16 | 250 | 410 | 436/20 | +12, +5, -5 |  |
|  |  | 16,384 | 16-Pin Dynamic | 16,384×1 | 16 | 300 | 490 | 462/20 | +12, +5, -5 |  |
|  | $\begin{gathered} \hline 2118-2 \\ 2118-3 \\ 2118-4 \\ 2118-7 \\ \hline \end{gathered}$ | 16,384 | 16-Pin Dynamic | 16,384×1 | 16 | 80 | 200 | 160/16.5 | $+5$ | 3-88 |
|  |  | 16,384 | 16-Pin Dynamic | 16,384×1 | 16 | 100 | 235 | 138/16.5 | $+5$ |  |
|  |  | 16,384 | 16-Pin Dynamic | 16,384×1 | 16 | 120 | 270 | 121/16.5 | +5 |  |
|  |  | 16,384 | 16-Pin Dynamic | 16,384×1 | 16 | 150 | 320 | 121/16.5 | +5 |  |
|  | STATIC RAMS |  |  |  |  |  |  |  |  |  |
|  | $\begin{aligned} & \text { 2101A/8101A } \\ & 2101 A-2 \\ & 2101 A-4 \end{aligned}$ | 1024 | Static, Separate I/O | 256x4 | 22 | 350 | 350 | 300 | +5 | 3-4 |
|  |  | 1024 | Static, Separate I/O | 256x4 | 22 | 250 | 250 | 350 | +5 |  |
|  |  | 1024 | Static, Separate I/O | 256x4 | 22 | 450 | 450 | 300 | +5 |  |
|  |  | 1024 | Static | 1024x1 | 16 | 350 | 350 | 275 | +5 | 3-8 |
|  | $\begin{aligned} & 2102 A-2 \\ & 2102 A-4 \\ & 2102 A L \\ & 2102 A L-2 \\ & 2102 A L-4 \end{aligned}$ | 1024 | Static | 1024x1 | 16 | 250 | 250 | 325 | +5 |  |
|  |  | 1024 | Static | 1024x1 | 16 | 450 | 450 | 275 | +5 |  |
|  |  | 1024 | Low Standby Power Static | 1024×1 | 16 | 350 | 350 | 165/35 | +5 |  |
|  |  | 1024 | Low Standby Power Static | 1024×1 | 16 | 250 | 250 | 325/42 | +5 |  |
|  |  | 1024 | Low Standby Power Static | 1024x1 | 16 | 450 | 450 | 165/35 | +5 |  |
|  | 2111A/8111A | 1024 | Static, Common I/O with Output Deselect | 256x4 | 18 | 350 | 350 | 300 | +5 | 3-45 |
|  | $\begin{aligned} & 2111 A-2 \\ & 2111 A-4 \end{aligned}$ | 1024 | Static, Common 1/O | 256x4 | 18 | 250 | 250 | 350 | +5 |  |
|  |  | 1024 | Static, Common 1/O | 256x4 | 18 | 450 | 450 | 300 | +5 |  |
|  | 2112A | 1024 | Static, Common I/O without Output Deselect | 256x4 | 16 | 350 | 350 | 300 | +5 |  |
|  | $\begin{aligned} & 2112 A-2 \\ & 2112 A-4 \end{aligned}$ | 1024 | Static, Common I/O without Output Deselect | 256x4 | 16 | 250 | 250 | 350 | +5 | 3-49 |
|  |  | 1024 | Static, Common I/O without Output Deselect | 256x4 | 16 | 450 | 450 | 300 | +5 |  |
|  | 2114 | 4096 | Static, Common 1/O | 1024×4 | 18 | 450 | 450 | 525 | +5 | $3-54$ |
|  | $2114-2$ | 4096 | Static, Common 1/O | 1024×4 | 18 | 200 | 200 | 525 | +5 |  |
|  | $2114-3$ | 4096 | Static, Common 1/O | 1024×4 | 18 | 300 | 300 | 525 | +5 |  |
|  | $\begin{aligned} & 2114 \mathrm{~L} \\ & 2114 \mathrm{~L} 2 \\ & 2114 \mathrm{~L} 3 \end{aligned}$ | 4096 | Static, Common I/O | 1024×4 | 18 | 450 | 450 | 370 | +5 |  |
|  |  | 4096 | Static, Common 1/O | $1024 \times 4$ | 18 | 200 | 200 | 370 | +5 |  |
|  |  | 4096 | Static, Common I/O | 1024×4 | 18 | 300 | 300 | 370 | +5 |  |

## RANDOM ACCESS MEMORIES (Cont.)

|  | Type | $\begin{aligned} & \text { No. } \\ & \text { of } \\ & \text { Bits } \end{aligned}$ | Description | Organization | $\begin{gathered} \text { No. } \\ \text { of } \\ \text { Pins } \end{gathered}$ | Electrical Characteristics Over Temperature |  |  |  | Page No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | Access Time Max. (ns) | Cycle <br> Time <br> Min. <br> (ns) | Power <br> Dissipation Max. ${ }^{\|1\|}$ <br> Operating/ <br> Standby (mW) | Supplies (V) |  |
|  | STATIC RAMS (Continued) |  |  |  |  |  |  |  |  |  |
|  | M2114 | 4096 | Static, Common I/O TA $=$ $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | 1024×4 | 18 | 450 | 450 | 550 | +5 | 14-7 |
|  |  | 1024 | High Speed Static, Open Collector | 1024×1 | 16 | 45 | 45 | 655 | +5 | 3-58 |
|  | $2115 \mathrm{~A}-2$ | 1024 | High Speed Static, Open Collector | $1024 \times 1$ | 16 | 70 | 70 | 655 | +5 |  |
|  | 2115AL | 1024 | High Speed Static, Open Collector | 1024x1 | 16 | 45 | 45 | 395 | +5 |  |
|  | 2115AL-2 | 1024 | High Speed Static, Open Collector | $1024 \times 1$ | 16 | 70 | 70 | 395 | +5 |  |
|  | 2125A | 1024 | High Speed Static, Three State | 1024x1 | 16 | 45 | 45 | 655 | +5 | 3-58 |
|  | 2125A-2 | 1024 | High Speed Static, Three State | $1024 \times 1$ | 16 | 70 | 70 | 655 | +5 |  |
|  | $2125 \mathrm{AL}$ | 1024 | High Speed Static, Three State | 1024×1 | 16 | 45 | 45 | 395 | +5 |  |
|  | 2125AL-2 | 1024 | High Speed Static, Three State | 1024×1 | 16 | 70 | 70 | 395 | +5 |  |
|  | M2115A | 1024 | High Speed Static, Open Collector | $1024 \times 1$ | 16 | 55 | 55 | 690 | +5 | 14-11 |
|  | M2115AL | 1024 | High Speed Static, Open Collector | 1024×1 | 16 | 75 | 75 | 415 | +5 |  |
|  | M2125A | 1024 | High Speed Static, Three State | 1024×1 | 16 | 55 | 55 | 690 | +5 | 14-11 |
|  | M2125AL | 1024 | High Speed Static, Three State ( $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ ) | 1024x1 | 16 | 75 | 75 | 415 | +5 |  |
|  | 2115H | 1024 | High Speed Static, Open Collector | $1024 \times 1$ | 16 | 25-35 | 25-35 | 655 | +5 | 3-63 |
|  | 2125H | 1024 | High Speed Static, Three State | 1024x1 | 16 | 25-35 | 25-35 | 655 | +5 | 3-63 |
|  | 2141-2 | 4096 | Static | $4096 \times 1$ | 18 | 120 | 120 | 385/110 | +5 |  |
|  | 2141-3 | 4096 | Static | 4096x1 | 18 | 150 | 150 | 385/110 | +5 | 3-89 |
|  | $2141-4$ | 4096 | Static | 4096x1 | 18 | 200 | 200 | 303/66 | +5 |  |
|  | 2141-5 | 4096 | Static | $4096 \times 1$ | 18 | 250 | 250 | 303/66 | +5 |  |
|  | 2141L-3 | 4096 | Static | $4096 \times 1$ | 18 | 150 | 150 | 220/28 | +5 |  |
|  | 2141L-4 | 4096 | Static | $4096 \times 1$ | 18 | 200 | 200 | 220/28 | +5 |  |
|  |  | 4096 | Static | $4096 \times 1$ | 18 | 250 | 250 | 220/28 | +5 |  |
|  | 2142 | 4096 | Static, with Output Enable | 1024×4 | 20 | 450 | 450 | 525 | +5 |  |
|  | $2142-2$ | 4096 | Static, with Output Enable | 1024x4 | 20 | 200 | 200 | 525 | +5 | 3-95 |
|  | $2142-3$ | 4096 | Static, with Output Enable | $1024 \times 4$ | 20 | 300 | 300 | 525 | +5 |  |
|  | 2142L | 4096 | Static, with Output Enable | 1024x4 | 20 | 450 | 450 | 375 | +5 |  |
|  | 2142L-2 | 4096 | Static, with Output Enable | $1024 \times 4$ | 20 | 200 | 200 | 375 | +5 |  |
|  |  | 4096 | Static, with Output Enable | $1024 \times 4$ | 20 | 300 | 300 | 375 | +5 |  |
|  | 2147 | 4096 | High Speed Static | $4096 \times 1$ | 18 | 70 | 70 | 880/110 | +5 |  |
|  | $2147-3$ | 4096 | High Speed Static | $4096 \times 1$ | 18 | 55 | 55 | 990/165 | +5 | 3-99 |
|  |  | 4096 | High Speed Static | $4096 \times 1$ | 18 | 70 | 70 | 770/55 | +5 |  |
|  | 2147H | 4096 | High Speed Static | $4096 \times 1$ | 18 | 35-45 | 35-45 | 990/165 | +5 | 3-105 |
|  | M2147 | 4096 | High Speed Static ( $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ ) | 4096x1 | 18 | 85 | 85 | 990/165 | +5 | 14-15 |
|  | 2148 | 4096 | High Speed Static | 1024×4 | 18 | 60 | 60 | 825/165 | +5 | 3-106 |
| Nㅡㄹ | 3101 | 64 | Fully Decoded | $16 \times 4$ | 16 | 60 | 60 | 525 | +5 | 3-107 |
|  | 3101A | 64 | High Speed Fully Decoded | 16x4 | 16 | 35 | 35 | 525 | +5 |  |
|  | 51015101L5101L-15101L-3 | 1024 | Static CMOS RAM | $256 \times 4$ | 22 | 800 | 800 | 150/2.5 | +5 | 3-111 |
|  |  | 1024 | Static CMOS RAM | 256x4 | 22 | 650 | 650 | 135/20 $\mu \mathrm{W}$ | +5 |  |
|  |  | 1024 | Static CMOS RAM | $256 \times 4$ | 22 | 450 | 450 | 135/20 $\mu \mathrm{W}$ | +5 |  |
|  |  | 1024 | Static CMOS RAM | $256 \times 4$ | 22. | 650 | 650 | 135/1 | +5 |  |
|  | M5101-4 | 1024 | Static CMOS RAM $\left(-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}$ ) | 256x4 | 22 | 800 | 800 | 168/1 | +5 | 14-41 |
|  | M5101L-4 | 1024 | Static CMOS RAM $\left(-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}$ ) | $256 \times 4$ | 22 | 800 | 800 | 168/400 $\mu \mathrm{W}$ | +5 |  |

## intel'

\author{

2101A/8101A-4* <br> 256 X 4 BIT STATIC RAM <br> | 2101A-2 | 250 ns Max. |
| :--- | :--- |
| 2101A | 350 ns Max. |
| 2101A-4 | 450 ns Max. |

}

■ Inputs Protected: All Inputs Have Protection Against Static Charge
■ Low Cost Packaging: 22 Pin Plastic Dual In-Line Configuration

- Low Power: Typically 150 mW
- Three-State Output: OR-Tie Capability
- Output Disable Provided for Ease of Use in Common Data Bus Systems


## $256 \times 4$ Organization to Meet Needs for Small System Memories

Single +5V Supply Voltage
Directly TTL Compatible: All Inputs and Output
■ Statis MOS: No Clocks or Refreshing Required

## ■ Simple Memory Expansion: Chip Enable Input

The Intel® 2101A 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 2101A 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® 2101A 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.



[^2]
## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\qquad$ $-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. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{L I}$ | Input Current |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\mathrm{I}_{\mathrm{LOH}}$ | Data Output Leakage Current |  | 1 | 10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{\text {OUT }}=4.0 \mathrm{~V}$ |
| ILOL | Data Output Leakage Current |  | -1 | -10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | $\begin{array}{lr}\begin{array}{l}\text { Power Supply } \\ \text { Current }\end{array} & \frac{2101 \mathrm{~A}, 2101 \mathrm{~A}-4}{2101 \mathrm{~A}-2}\end{array}$ |  | 35 | 55 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}, \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 |  |  | 60 | mA | $\begin{aligned} & \mathrm{V}_{1 \mathrm{~N}}=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}$ |
| VOH | Output "High" 2101A, 2101A-2 | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
|  | Voltage $\quad 2101 \mathrm{~A}-4$ | 2.4 |  |  | V | $\mathrm{IOH}^{\prime}=-150 \mu \mathrm{~A}$ |

## TYPICAL D.C. CHARACTERISTICS




NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.

## A.C. CHARACTERISTICS FOR 2101A-2 (250 ns ACCESS TIME)

READ CYCLE $\quad 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. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {R }}$ | Read Cycle | 250 |  |  | ns | $t_{r}, t_{f}=20 n s$ <br> Input Levels $=0.8 \mathrm{~V}$ or 2.0 V <br> Timing Reference $=1.5 \mathrm{~V}$ <br> Load $=1$ TTL Gate and $C_{L}=100 \mathrm{pF}$. |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time |  |  | 250 | ns |  |
| ${ }^{\text {t }} \mathrm{CO}$ | Chip Enable To Output |  |  | 180 | ns |  |
| tod | Output Disable To Output |  |  | 130 | ns |  |
| $\mathrm{t}_{\mathrm{DF}}{ }^{[3]}$ | Data Output to High Z State | 0 |  | 180 | ns |  |
| ${ }^{\text {toh }}$ | Previous Read Data Valid after change of Address | 40 |  |  | ns |  |

## WRITE CYCLE

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{t}$ WC | Write Cycle | 170 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{L}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {t }}$ W ${ }_{\text {W }}$ | Write Delay | 20 |  |  | ns |  |
| ${ }^{\text {t }}$ CW | Chip Enable To Write | 150 |  |  | ns |  |
| $t_{\text {DW }}$ | Data Setup | 150 |  |  | ns |  |
| ${ }_{\text {t }}^{\text {D }}$ H | Data Hold | 0 |  |  | ns |  |
| ${ }_{\text {t }}$ W $P$ | Write Pulse | 150 |  |  | ns |  |
| twr | Write Recovery | 0 |  |  | ns |  |
| ${ }^{t}$ DS | Output Disable Setup | 20 |  |  | ns |  |

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{~V}$ | 4 | 8 |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 8 | 12 |

## WAVEFORMS

## READ CYCLE



NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. This parameter is periodically sampled and is not $100 \%$ tested.
3. ${ }^{t} D F$ is with respect to the trailing edge of $\overline{C E}_{1}, C E_{2}$, or OD, whichever occurs first.

## WRITE CYCLE


4. $O D$ should be tied low for separate $1 / O$ operation.

## 2101A FAMILY

## 2101A (350 ns ACCESS TIME)

## A.C. CHARACTERISTICS

READ CYCLE $\quad 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 | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 350 |  |  | ns | $t_{r}, t_{f}=20 n s$ <br> Input Levels $=0.8 \mathrm{~V}$ or 2.0 V <br> Timing Reference $=1.5 \mathrm{~V}$ <br> Load $=1$ TTL Gate |
| ${ }^{\text {t }}$ A | Access Time |  |  | 350 | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CO}$ | Chip Enable To Output |  |  | 240 | ns |  |
| ${ }^{\text {tob }}$ | Output Disable To Output |  |  | 180 | ns |  |
| ${ }^{\text {t }}$ [ ${ }^{\text {[2] }}$ | Data Output to High Z State | 0 |  | 150 | ns |  |
| ${ }^{\text {toh }}$ | Previous Read Data Valid after change of Address | 40 |  |  | ns |  |

WRITE CYCLE

| Symbol | Parameter | Min. | Typ. ${ }^{\text {[1] }}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {w }}$ | Write Cycle | 220 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{L}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {t }}$ W | Write Delay | 20 |  |  | ns |  |
| ${ }^{\text {t }}$ CW | Chip Enable To Write | 200 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{DW}}$ | Data Setup | 200 |  |  | ns |  |
| ${ }_{\text {t }}^{\text {D }}$ | Data Hold | 0 |  |  | ns |  |
| $t_{W P}$ | Write Pulse | 200 |  |  | ns |  |
| $t_{\text {WR }}$ | Write Recovery | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ DS | Output Disable Setup | 20 |  |  | ns |  |

## 2101A-4 (450 ns ACCESS TIME)

## A.C. CHARACTERISTICS

READ CYCLE $\quad 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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 450 |  |  | ns | $t_{r}, t_{f}=20 n s$ <br> Input Levels $=0.8 \mathrm{~V}$ or 2.0 V <br> Timing Reference $=1.5 \mathrm{~V}$ <br> Load $=1$ TTL Gate |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time |  |  | 450 | ns |  |
| ${ }_{\text {t }} \mathrm{CO}$ | Chip Enable To Output |  |  | 310 | ns |  |
| ${ }^{\text {tod }}$ | Output Disable To Output |  |  | 250 | ns |  |
| $\mathrm{t}_{\mathrm{DF}}{ }^{[2]}$ | Data Output to High Z State | 0 |  | 200 | ns |  |
| ${ }^{\text {tor }}$ | Previous Read Data Valid after change of Address | 40 |  |  | ns |  |

## WRITE CYCLE

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {w }}$ | Write Cycle | 270 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{L}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {taw }}$ | Write Delay | 20 |  |  | ns |  |
| ${ }^{\text {c }}$ CW | Chip Enable To Write | 250 |  |  | ns |  |
| tow | Data Setup | 250 |  |  | ns |  |
| $t_{\text {DH }}$ | Data Hold | 0 |  |  | ns |  |
| $t_{\text {t }} \mathrm{P}$ | Write Pulse | 250 |  |  | ns |  |
| $t_{\text {Wr }}$ | Write Recovery | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ DS | Output Disable Setup | 20 |  |  | ns |  |

NOTES: 1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. tDF is with respect to the trailing edge of $\mathrm{CE}_{1}, \mathrm{CE}_{2}$, or OD , whichever occurs first.

## 2102A, 2102AL/8102A-4* $1 \mathrm{~K} \times 1$ BIT STATIC RAM

| P/N | Standby Pwr. <br> $(\mathrm{mW})$ | Operating Pwr. <br> $(\mathrm{mW})$ | Access <br> $(\mathrm{ns})$ |
| :--- | :---: | :---: | :---: |
| 2102AL-4 | 35 | 174 | 450 |
| 2102AL | 35 | 174 | 350 |
| 2102AL-2 | 42 | 342 | 250 |
| 2102A-2 | - | 342 | 250 |
| 2102A | - | 289 | 350 |
| 2102A-4 | - | 289 | 450 |

## - Single +5 Volts Supply Voltage <br> - Directly TTL Compatible: All Inputs and Output <br> - Standby Power Mode (2102AL) <br> - Three-State Output: OR-Tie Capability

## - Inputs Protected: All Inputs Have Protection Against Static Charge Low Cost Packaging: 16 Pin Dual-In-Line Configuration

The Intel ${ }^{\circledR} 2102 \mathrm{~A}$ is a high speed 1024 word by one bit static random access memory element using N -channel MOS devices integrated on a monolithic array. It uses fully DC stable (static) circuitry and therefore requires no clocks or refreshing to operate. The data is read out nondestructively and has the same polarity as the input data.

The 2102A is designed for memory applications where high performance, low cost, large bit storage, and simple interfacing are important design objectives. A low standby power version (2102AL) is also available. It has all the same operating characteristics of the 2102 A with the added feature of 35 mW maximum power dissipation in standby and 174 mW in operations.

It is directly TTL compatible in all respects: inputs, output, and a single +5 volt supply. A separate chip enable ( $\overline{\mathrm{CE}}$ ) lead allows easy selection of an individual package when outputs are OR-tied.
The Intel® 2102A is fabricated with N -channel silicon gate technology. This technology allows the design and production of high performance easy to use MOS circuits and provides a higher functional density on a monolithic chip than either conventional MOS technology or P-channel silicon gate technology.

*All 8102A-4 specifications are identical to the 2102A-4 specifications.

## Absolute Maximum Ratings*

Ambient Temperature Under Bias $-10^{\circ} \mathrm{C}$ to $80^{\circ} \mathrm{C}$
Storage Temperature
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 | $\begin{aligned} & \text { 2102A, 2102A-4 } \\ & \text { 2102AL, 2102AL-4 } \\ & \text { Limits } \end{aligned}$ |  |  | 2102A-2, 2102AL-2 <br> Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LJ}}$ | Input Load Current |  | 1 | 10 |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| ILOH | Output Leakage Current |  | 1 | 5 |  | 1 | 5 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CE}}=2.0 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{OH}} \end{aligned}$ |
| ILOL | Output Leakage Current |  | -1 | -10 |  | -1 | -10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CE}}=2.0 \mathrm{~V}, \\ & \mathrm{~V}_{\text {OUT }}=0.4 \mathrm{~V} \end{aligned}$ |
| ICC | Power Supply Current |  | 33 | Note 2 |  | 45 | 65 | mA | All Inputs $=5.25 \mathrm{~V}$, Data Out Open, $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | -0.5 |  | 0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{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 |  |  | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |

Notes: 1. Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. The maximum ICC value is 55 mA for the 2102 A and $2102 \mathrm{~A}-4$, and 33 mA for the 2102AL and 2102AL-4.

Standby Characteristics 2102AL, 2102AL-2, and 2102AL-4 (Available only in the Plastic Package)
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | 2102AL, 2102AL-4 Limits |  |  | Min. | 2102AL-2 <br> Limits <br> Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {PD }}$ | $V_{\text {CC }}$ in Standby | 1.5 |  |  | 1.5 |  |  | V |  |
| $\mathrm{V}_{\text {CES }}{ }^{[2]}$ | $\overline{\mathrm{CE}}$ Bias in Standby | 2.0 |  |  | 2.0 |  |  | V | $2.0 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{PD}} \leqslant \mathrm{V}_{\text {CC }}$ Max. |
|  |  | $\mathrm{V}_{\mathrm{PD}}$ |  |  | $\mathrm{V}_{\mathrm{PD}}$ |  |  | V | $1.5 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{PD}}<2.0 \mathrm{~V}$ |
| IPD1 | Standby Current |  | 15 | 23 |  | 20 | 28 | mA | All Inputs $=\mathrm{V}_{\text {PD } 1}=1.5 \mathrm{~V}$ |
| IPD2 | Standby Current |  | 20 | 30 |  | 25 | 38 | mA | All Inputs $=\mathrm{V}_{\text {PD } 2}=2.0 \mathrm{~V}$ |
| $\mathrm{t}_{\mathrm{CP}}$ | Chip Deselect to Standby Time | 0 |  |  | 0 |  |  | ns |  |
| $\mathrm{tr}^{\text {[3] }}$ | Standby Recovery Time | $\mathrm{t}_{\mathrm{RC}}$ |  |  | $\mathrm{t}_{\mathrm{RC}}$ |  |  | ns |  |

STANDBY WAVEFORMS


OV

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$.
2. Consider the test conditions as shown: If the standby voltage ( $V_{P D}$ ) is between 5.25 V ( $V_{C C}$ Max.) and 2.0 V , then $\overline{\mathrm{CE}}$ must be held at 2.0 V Min. $\left(\mathrm{V}_{I H}\right)$. If the standby voltage is less than 2.0 V but greater than 1.5V (VPD Min.), then $\overline{C E}$ and standby voltage must be at least the same value or, if they are different, $\overline{\mathrm{CE}}$ must be the more positive of the two.
3. $t_{R}=t_{R C}$ (READ CYCLE TIME).
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

| Symbol | Parameter | $\begin{gathered} \text { 2102A-2, } 2102 \mathrm{AL}-2 \\ \text { Limits (ns) } \end{gathered}$ |  | 2102A, 2102AL <br> Limits (ns) |  | $\begin{gathered} \text { 2102A-4, 2102AL-4 } \\ \text { Limits (ns) } \end{gathered}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 250 |  | 350 |  | 450 |  |
| $t_{A}$ | Access Time |  | 250 |  | 350 |  | 450 |
| ${ }_{\text {t }} \mathrm{CO}$ | Chip Enable to Output Time |  | 130 |  | 180 |  | 230 |
| $\mathrm{t}_{\mathrm{OH} 1}$ | Previous Read Data Valid with Respect to Address | 40 |  | 40 |  | 40 |  |
| $\mathrm{t}_{\mathrm{OH} 2}$ | Previous Read Data Valid with Respect to Chip Enable | 0 |  | 0 |  | 0 |  |

WRITE CYCLE

| $t_{\text {WC }}$ | Write Cycle | 250 | 350 | 450 |
| :---: | :--- | :---: | :---: | :---: |
| $t_{\text {AW }}$ | Address to Write Setup Time | 20 | 20 | 20 |
| $t_{\text {WP }}$ | Write Pulse Width | 180 | 250 | 300 |
| $t_{\text {WR }}$ | Write Recovery Time | 0 | 0 | 0 |
| $t_{\text {DW }}$ | Data Setup Time | 180 | 250 | 300 |
| $t_{\text {DH }}$ | Data Hold Time | 0 | 0 | 0 |
| $t_{\text {CW }}$ | Chip Enable to Write Setup <br> Time | 180 | 250 | 300 |

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

## A.C. CONDITIONS OF TEST

| Input Pulse Levels: | 0.8 Volt to 2.0 Volt |  |
| :--- | ---: | ---: |
| Input Rise and Fall Times: | 10 nsec |  |
| Timing Measurement | Inputs: | 1.5 Volts |
| $\quad$ Reference Levels | Output: | 0.8 and 2.0 Volts |
| Output Load: | 1 TTL. Gate and $C_{L}=100 \mathrm{pF}$ |  |


| SYMBOL | TEST | LIMITS (pF) |  |
| :--- | :--- | :---: | :---: |
|  | TYP.[1] |  | MAX. |
| $\mathrm{C}_{\text {IN }}$ | INPUT CAPACITANCE <br> (ALL INPUT PINS) $V_{I N}=0 V$ | 3 | 5 |
| $\mathrm{C}_{\text {OUT }}$ | OUTPUT CAPACITANCE <br> $V_{\text {OUT }}=0 V$ | 7 | 10 |

## Waveforms

## READ CYCLE



WRITE CYCLE


NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. This parameter is periodically sampled and is not $100 \%$ tested.

## Typical D. C. and A. C. Characteristics




ACCESS TIME VS.
AMBIENT TEMPERATURE



ACCESS TIME VS. LOAD CAPACITANCE


## 2104A $4096 \times 1$ BIT DYNAMIC RAM

|  | 2104 A |
| :--- | :---: |
| Max. Access Time (ns) | 350 |
| Read, Write Cycle (ns) | 500 |
| Max. IDD (mA) | 35 |

\author{

- Highest Density 4K RAM Industry Standard 16 Pin Package <br> - Low Power 4K RAM <br> - All Inputs Including Clocks TTL Compatible <br> - Standard Power Supplies: <br> $+12 \mathrm{~V}, \mathbf{+ 5 V}$, -5 V
}


## - Refresh Period: $\mathbf{2} \mathbf{~ m s}$ <br> - On-Chip Latches for Addresses, Chip Select and Data In <br> - Simple Memory Expansion: Chip Select <br> - Output is Three-State, TTL Compatible; Data is Latched and Valid into Next Cycle <br> - Compatible with Intel ${ }^{\circledR} 2116$ 16K RAM

The Intel® 2104 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 easily accomplished by performing any $\overline{R A S} / \overline{\mathrm{CAS}}$ cycle with $\overline{C S}$ at $V_{I H}$ for each of the 64 row addresses every 2 milliseconds.
The 2104A is designed for $\overline{C A S}$-only deselect and is compatible with Intel® ${ }^{\circledR} 2116,16$ K RAM.


## 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 . . . . . . . . .$.
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} \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}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[2]}$ | 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 |  |  | 10 | $\mu \mathrm{A}$ | Chip Deselected: $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{I H}$ $\mathrm{V}_{\text {OUT }}=0$ to 5.5 V |
| $\mathrm{I}_{\mathrm{DD} 1}{ }^{[3]}$ | VDD Standby Current |  | 0.7 | 2 | mA | $\mathrm{V}_{\mathrm{DD}}=12.6 \mathrm{~V}, \overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{1 H}$. |
| $\mathrm{I}_{\mathrm{BB} 1}$ | V $\mathrm{VB}^{\text {Standby Current }}$ |  | 5 | 50 | $\mu \mathrm{A}$ | Chip Deselected Prior to Measurement. See Note 5. |
| $\mathrm{I}_{\text {DD2 }}{ }^{[3]}$ | Operating V ${ }_{\text {DD }}$ Current |  | 25 | 35 | mA | $\mathrm{t}_{\mathrm{CYC}}=500 \mathrm{~ns}$ |
| $\mathrm{I}_{\mathrm{BB} 2}$ | Operating $\mathrm{V}_{\mathrm{BB}}$ Current |  | 130 | 400 | $\mu \mathrm{A}$ | $\mathrm{t}_{\text {RC }}=500 \mathrm{~ns}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| $\mathrm{ICC1}^{[4]}$ | $V_{C C}$ Supply Current When Deselected |  |  | 10 | $\mu \mathrm{A}$ |  |
| $\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}_{\mathrm{OL}}$ | Output Low Voltage | 0.0 |  | 0.4 | V | $\mathrm{IOL}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V | $\mathrm{IOH}=-5 \mathrm{~mA}$ |

CAPACITANCE ${ }^{[6]} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Test | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | input Capacitance ( $\left.\mathrm{A}_{0}-\mathrm{A}_{5}\right), \mathrm{D}_{\text {IN }}, \overline{\mathrm{CS}}$ | 3 | 7 | pF | $V_{\text {IN }}=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 | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ |
| $\mathrm{C}_{13}$ | Input Capacitance $\overline{\mathrm{CAS}}$ | 6 | 7 | pF | $\mathrm{V}_{\text {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 $\mathrm{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 valid memory cycles containing both RAS and CAS) prior to normal operation.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply voltages.
3. The IDD current flows to $V_{S S}$.
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{C A S}$-only cycle or by a read cycle with $\overline{C S}$ at $V_{I H}$.
6. Capacitance measured with Boonton Meter.

## A.C.CHARACTERISTICS ${ }^{[1]}$

$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}}=-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 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $t_{\text {REF }}$ | Time Between Refresh |  | 2 | ms |
| $\mathrm{t}_{\mathrm{RP}}$ | $\overline{\text { RAS Precharge Time }}$ | 150 |  | ns |
| ${ }^{t} \mathrm{CP}$ | $\overline{\text { CAS Precharge Time }}$ | 150 |  | ns |
| ${ }^{\text {tRCL }}$ [2] | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ Leading Edge Lead Time | 100 | 150 | ns |
| ${ }^{t}$ CRP | $\overline{\mathrm{CAS}}$ to $\overline{\text { RAS }}$ Precharge Time | 0 |  | ns |
| trsh | $\overline{\text { RAS }}$ Hold Time | 200 |  | ns |
| ${ }^{\text {t }} \mathrm{CSH}$ | $\overline{\text { CAS Hold Time }}$ | 350 |  | ns |
| ${ }_{t}$ AR | $\overline{\mathrm{RAS}}$ to Address or $\overline{\mathrm{CS}}$ Hold Time | 250 |  | ns |
| ${ }^{\text {t ASR }}$ | Row Address Set-Up Time | 0 |  | ns |
| ${ }^{t}$ ASC | Column Address or $\overline{\text { CS }}$ Set-Up Time | 0 |  | ns |
| $t_{\text {RAH }}$ | Row Address Hold Time | 100 |  | ns |
| ${ }^{t} \mathrm{CAH}$ | Column Address or $\overline{\mathrm{CS}}$ Hold Time | 100 |  | ns |
| ${ }_{\mathrm{t}}$ T | Rise or Fall Time | 3 | 50 | ns |
| tOFF | Output Buffer Turn-Off Delay | 0 | 100 | ns |
| ${ }^{\text {t }}{ }^{\text {che }}{ }^{[3]}$ | Access Time From $\overline{\mathrm{CAS}}$ |  | 200 | ns |
| $\mathrm{tRAC}^{[3]}$ | Access Time from $\overline{\mathrm{RAS}}$ |  | 350 | ns |

READ CYCLE

| Symbol | Parameter | 2104A |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| ${ }^{\text {tr }} \mathrm{C}$ | Random Read or Write Cycle Time | 500 |  | ns |
| trAS | $\overline{\text { RAS Pulse Width }}$ | 350 | 32000 | ns |
| ${ }^{t}$ CAS | $\overline{\text { CAS Pulse Width }}$ | 200 |  | ns |
| ${ }^{\text {tRCS }}$ | Read Command Set-Up Time | 0 |  | ns |
| ${ }^{\text {t }} \mathrm{RCH}$ | Read Command Time | 0 |  | ns |
| ${ }^{\text {t }} \mathrm{DOH}$ | Data Out Hold Time | 32 |  | $\mu \mathrm{s}$ |

## WRITE CYCLE ${ }^{[4]}$

| Symbol | Parameter | 2104A |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{R}} \mathrm{C}$ | Random Read or Write Cycle Time | 500 |  | ns |
| tRAS | $\overline{\text { RAS }}$ Pulse Width | 350 | 32000 | ns |
| teAS | $\overline{\text { CAS }}$ Pulse Width | 200 |  | ns |
| twCs | Write Command Set-Up Time | 0 |  | ns |
| tWCH | Write Command Hold Time | 100 |  | ns |
| tWCR | Write Command Hold Time Referenced to $\overline{\text { RAS }}$ | 250 |  | ns |
| twP | Write Command Pulse Width | 100 |  | ns |
| ${ }^{\text {t RWWL }}$ | Write Command to $\overline{\text { RAS }}$ Lead Time | 200 |  | ns |
| ${ }^{\text {t }}$ CWL | Write Command to $\overline{\mathrm{CAS}}$ Lead Time | 200 |  | ns |
| ${ }^{\text {t }}$ D | Data-In Set-Up Time | 0 |  | ns |
| ${ }^{\text {t }} \mathrm{DH}$ | Data-In Hold Time | 100 |  | ns |
| ${ }^{\text {t }}$ DHR | Data-In Hold Time Referenced to $\overline{\text { RAS }}$ | 250 |  | ns |

Notes: 1. All voltages referenced to $V_{S S}$. Minimum timings do not allow for $\mathrm{t}^{\mathrm{T}}$ or skews.
2. $\overline{C A S}$ must remain at $V_{I H}$ a minimum of $t_{R C L} M I N$ after $\overline{\operatorname{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 section. $t_{R C L}$ MAX is given for reference only as tRAC - ${ }^{t} \mathrm{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 cell. If $\overline{W E}$ goes low after $\overline{\mathrm{CAS}}$ and prior to tCAC, DOUT is indeterminate.

## WAVEFORMS

READ CYCLE


## WRITE CYCLE


(See next page for notes)

## A.C.CHARACTERISTICS ${ }^{[1]}$

$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}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

## READ-MODIFY-WRITE CYCLE

| Symbol | Parameter | 2104A |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $t_{\text {RWC }}$ | Read Modify Write Cycle Time ${ }^{[2]}$ | 700 |  | ns |
| tCRW | RMW Cycle $\overline{\text { CAS }}$ Width | 400 |  | ns |
| $t_{\text {RRW }}$ | RMW Cycle $\overline{\text { RAS }}$ Width | 550 |  | ns |
| $t_{\text {RWL }}$ | RMW Cycle $\overline{\text { RAS }}$ Lead Time | 200 |  | ns |
| $\mathrm{t}_{\mathrm{CWH}}$ | RMW Cycle CAS Hold Time | 550 |  | ns |
| ${ }^{\text {t }}$ CWL | Write Command to $\overline{\mathrm{CAS}}$ Lead Time | 200 |  | ns |
| $t_{\text {WP }}$ | Write Command Pulse Width | 100 |  | ns |
| $t_{\text {RCS }}$ | Read Command Set-Up Time | 0 |  | ns |
| $\mathrm{t}_{\text {MOD }}$ | Modify Time | 0 | 10 | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ D | Data-In Set-Up Time | 0 |  | ns |
| ${ }_{\text {t }}{ }^{\text {d }}$ | Data-In Hold Time | 100 |  | ns |

Notes: 1. All voltages referenced to $\mathrm{V}_{\mathrm{SS}}$.
2. The minimum cycle timing does not allow for $\mathrm{t}_{\mathrm{T}}$ or skews.

## WAVEFORMS

READ-MODIFY-WRITE CYCLE


Notes: 1,2. VIHMIN and VILMAX are reference levels for measuring timing of input signals.
3,4. VOHMIN and VOLMAX are reference levels for measuring timing of DOUT.
5. Referenced to $\overline{\mathrm{CAS}}$ or $\overline{W E}$, whichever occurs last.
6. 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{\mathrm{CAS}}$ and prior to ${ }^{\mathrm{t}} \mathrm{CAC}$, DOUT is indeterminate.

## TYPICAL CHARACTERISTICS



## APPLICATIONS

## ADDRESSING

Two externally applied negative going TTL clocks, Row Address Strobe ( $\overline{\mathrm{RAS}}$ ), and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ), are used to strobe the two sets of 6 addresses into internal address buffer registers. The first clock, $\overline{R A S}$, strobes in the six low order addresses $\left(\mathrm{A}_{0}-\mathrm{A}_{5}\right)$ which selects one of 64 rows and begins the timing which enables the column sense amplifiers. The second clock, $\overline{\mathrm{CAS}}$, strobes in the six high order addresses $\left(\mathrm{A}_{6}-\mathrm{A}_{11}\right)$ 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{R A S}$. 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{\mathrm{CAS}}$. 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{C A S}$ 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_{A C C}=t_{R A C} \text { OR 2. } t_{A C C}=t_{R C L}+t_{T}+t_{C A C}
$$

Access time from $\overline{R A S}, t_{\text {RAC }}$, and access time from $\overline{C A S}$, $t_{\text {CAC }}$, are device parameters. Row to column address strobe lead time, $\mathrm{t}_{\mathrm{RCL}}$, and transition time, $\mathrm{t}_{\mathrm{T}}$, are system dependent timing parameters. For example, substituting the device parameters of the 2104A and assuming a TTL level transition time of 5 ns yields:
3. $t_{A C C}=t_{R A C}=350 \mathrm{~ns}$ for $100 \mathrm{nsec} \leqslant \mathrm{t}_{\mathrm{RCL}} \leqslant 145 \mathrm{nsec}$ OR
4. $t_{A C C}=t_{R C L}+t_{T}+t_{C A C}=t_{R C L}+205$ ns for $\mathrm{t}_{\mathrm{RCL}}>145 \mathrm{~ns}$.

Note that if $100 \mathrm{nsec} \leqslant \mathrm{t}_{\mathrm{RCL}} \leqslant 145 \mathrm{nsec}$, device access time is determined by equation 3 and is equal to trac. If $t_{\mathrm{RCL}}>145 \mathrm{nsec}$, access time is determined by equation 4 . This 45 ns interval (shown in the $t_{\text {RCL }}$ inequality in equation 3) in which the failing edge of $\overline{\mathrm{CAS}}$ can occur without affecting access time is provided to allow for system timing skew in the generation of $\overline{C A S}$. This allowance for a $t_{R C L}$ skew is designed in at the device level to allow minimum access times to be achieved in practical 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{\mathrm{WE}}$ goes low after $\overline{\mathrm{CAS}}$ and prior to $t_{C A C}, D_{\text {OUT }}$ will be indeterminate.

## READ-MODIFY-WRITE CYCLE

A Read-Modify-Write Cycle is performed by bringing Write Enable ( $\overline{\mathrm{WE}}$ ) Iow after access time, $\mathrm{t}_{\text {RAC }}$, with RAS 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.

## $\overline{C A S}$ 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{\mathrm{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 $I_{D D 1}$ for any additional $\overline{\mathrm{CAS}}$-only cycles. The cycle timing and $\overline{\mathrm{CAS}}$ timing should be just as if a normal $\overline{\mathrm{RAS}} / \overline{\mathrm{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{C A S}$ 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{C A S}$ 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.

## 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 $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_{\text {SS }}$ 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 $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 $V_{S S}$ at every eighth device to prevent noise coupling to the $\mathrm{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}}$
$C=0.01 \mu \mathrm{~F} \mathrm{~V}_{\mathrm{CC}}$ TO $\mathrm{V}_{\mathrm{SS}}$

## Inte

# 2104A FAMILY <br> $4096 \times 1$ BIT DYNAMIC RAM 

|  | $2104 A-1$ | $2104 A-2$ | $2104 A-3$ | $2104 A-4$ |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 150 | 200 | 250 | 300 |
| Read, Write Cycle (ns) | 320 | 375 | 375 | 425 |
| Max. IDD (mA) | 35 | 32 | 30 | 30 |

## Highest Density 4K RAM Industry Standard 16 Pin Package

## Low Power 4K RAM: 462mW Operating 27mW Standby

## All Inputs Including Clocks TTL Compatible

$\pm 10 \%$ Tolerance on All Power Supplies $+12 \mathrm{~V},+5 \mathrm{~V},-5 \mathrm{~V}$

- 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
$\overline{R A S}-O n l y ~ R e f r e s h ~ O p e r a t i o n ~$

The Intel® 2104 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 RAS-only refresh cycle or read cycle at each of the 64 row addresses every 2 milliseconds.
The 2104A is designed for page mode operation, $\overline{\text { RAS }}$-only refresh, and $\overline{\mathrm{CAS}}$-only deselect.

PIN CONFIGURATION


LOGIC DIAGRAM


PIN NAMES

| $A_{0}$ A5 | ADDRESS INPUTS | WE | WRITE ENABLE |
| :--- | :--- | :--- | :--- |
| $\overline{C A S}$ | COLUMN ADDRESS STROBE | $V_{B B}$ | POWER $(-5 V)$ |
| $\overline{C S}$ | CHIP SELECT | $V_{C C}$ | POWER $(+5 V)$ |
| $D_{\text {IN }}$ | DATA IN | $V_{\text {OD }}$ | POWER $(+12 \mathrm{~V})$ |
| DOUT | DATA OUT | $V_{S S}$ | GROUND |
| $\overline{\text { 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)$
$-0.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}_{S S}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{(2)}$ | Max. |  |  |
| $I_{\text {LI }}$ | Input Load Current (any input) |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {SS }}$ to $\mathrm{V}_{\text {IH MAX }}$ |
| \| LO | Output Leakage Current for High Impedance State |  |  | 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 |
| $\overline{\operatorname{IDD1}}{ }^{[3]}$ | $V_{\text {DD }}$ Standby Current |  | 0.7 | 2 | mA | $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{1 H}$. Chip deselected prior to measurement. See Note 5. |
|  |  |  | 0.7 | 1.5 | mA |  |
| $\mathrm{I}_{\mathrm{BB} 1}$ | $\mathrm{V}_{\text {BB }}$ Standby Current |  | 5 | 50 | $\mu \mathrm{A}$ |  |
| $\mathrm{IDD2}^{[3]}$ | Operating $V_{\text {DD }}$ Current |  | 24 | 35 | mA | $2104 \mathrm{~A}-1 \quad \mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\mathrm{RC}} \mathrm{MIN}$ |
|  |  |  | 22 | 32 | mA | $2104 \mathrm{~A}-2 \quad \mathrm{t}_{\mathrm{RC}}=t_{\text {RC }}$ MIN |
|  |  |  | 20 | 30 | mA | 2104A-3, 2104A-4 $t_{\text {RC }}=t_{\text {RC MIN }}$ |
| $\mathrm{I}_{\text {BB2 }}$ | Operating $\mathrm{V}_{\mathrm{BB}}$ Current |  | 130 | 325 | $\mu \mathrm{A}$ | Min cycle time. $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| $\mathrm{ICC1}^{[4]}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current when <br> Deselected |  |  | 10 | $\mu \mathrm{A}$ |  |
| IDD3 | Operating $V_{D D}$ Current |  | 12 | 25 | mA | 2104A-1, 2104A-2 $\quad t_{\text {RC }}=t_{\text {RC MIN }}$ |
|  | ( $\overline{\text { RAS }}$-only cycle) |  | 10 | 22 | mA | 2104A-3, 2104A-4 $\quad t_{\text {RC }}=t_{\text {RC M M }}$ |
| $V_{\text {IL }}$ | Input Low Voltage (any input) | -1.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (any input) | 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}$ |
| VOH | Output High Voltage | 2.4 |  | $\mathrm{V}_{\text {cc }}$ | V | $\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}$ |

## CAPACITANCE ${ }^{[6]} \mathrm{T}_{\mathrm{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}_{\mathrm{IN}}=\mathrm{V}_{\text {SS }}$ |
| $\mathrm{C}_{12}$ | Input Capacitance ( $\overline{\text { RAS }}, \overline{\text { 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}_{\text {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 valid memory cycles containing both $\overline{R A S}$ and CAS) prior to normal operation.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply voltages.
3. The IDD 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; ı.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} \mathrm{H}$.
6. Capacitance measured with Boonton Meter.

## A.C.CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ 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.

## 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. |  |
| treF | Time Between Refresh |  | 2 |  | 2 |  | 2 |  | 2 | ms |
| trp | $\overline{\text { RAS Precharge Time }}$ | 100 |  | 120 |  | 120 |  | 125 |  | ns |
| ${ }^{t} \mathrm{CP}$ | $\overline{\text { CAS }}$ Precharge Time | 60 |  | 80 |  | 110 |  | 110 |  | ns |
| ${ }^{\text {tr }} \mathrm{RCD}^{[3]}$ | $\overline{\text { RAS }}$ to $\overline{\text { CAS }}$ Delay Time | 20 | 50 | 25 | 65 | 35 | 85 | 80 | 135 | ns |
| ${ }^{\text {t CRP }}$ | $\overline{\text { CAS }}$ to $\overline{R A S}$ Precharge Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {tRSH }}$ | $\overline{\text { RAS Hold Time }}$ | 100 |  | 135 |  | 165 |  | 165 |  | ns |
| ${ }^{t} \mathrm{AR}$ | $\overline{\text { RAS }}$ to Address or $\overline{\text { CS }}$ Hold Time | 95 |  | 120 |  | 160 |  | 215 |  | ns |
| ${ }^{\text {t }}$ ASR | Row Address Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }}$ ASC | Column Address or C̄IS Set-Up Time | -10 |  | -10 |  | -10 |  | -10 |  | ns |
| traH | Row Address Hold Time | 20 |  | 25 |  | 35 |  | 80 |  | ns |
| ${ }^{\text {t }} \mathrm{CAH}$ | Column Address or C̄S Hold Time | 45 |  | 55 |  | 75 |  | 80 |  | ns |
| ${ }_{\text {t }}$ | Rise or Fall Time | 3 | 50 | 3 | 50 | 3 | 50 | 3 | 50 | ns |
| tofF | Output Buffer Turn-Off Delay | 0 | 50 | 0 | 60 | 0 | 60 | 0 | 80 | ns |
| ${ }^{\mathrm{t}} \mathrm{CAC}^{[4,5]}$ | Access Time From $\overline{\text { CAS }}$ |  | 100 |  | 135 |  | 165 |  | 165 | ns |
| ${ }^{\text {R }}{ }^{\text {AC }}{ }^{[4]}$ | Access Time From $\overline{\mathrm{RAS}}$ |  | 150 |  | 200 |  | 250 |  | 300 | ns |

## READ CYCLE

|  | Parameter | 2104A-1 |  | 2104A-2 |  | 2104A-3 |  | 2104A-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {tr }}$ R | Random Read or Write Cycle Time | 320 |  | 375 |  | 375 |  | 425 |  | ns |
| tras | $\overline{\text { RAS }}$ Fulse Width | 150 | 10000 | 200 | 10000 | 250 | 10000 | 300 | 10000 | ns |
| ${ }^{t}$ CAS | $\overline{\text { CAS Pulse Width }}$ | 100 |  | 135 |  | 165 |  | 165 |  | ns |
| ${ }^{\text {tras }}$ | Read Command Set-Up Tıme | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{t} \mathrm{RCH}$ | Read Command Hold Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }} \mathrm{DOH}$ | Data Out Hold Time | 10 |  | 10 |  | 10 |  | 10 |  | $\mu \mathrm{s}$ |

## WRITE CYCLE

| Symbol | Parameter | 2104A-1 |  | 2104A-2 |  | 2104A-3 |  | 2104A-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ${ }^{t} \mathrm{RC}$ | Random Read or Write Cycle Time | 320 |  | 375 |  | 375 |  | 425 |  | ns |
| tras | $\overline{\text { RAS Pulse Width }}$ | 150 | 10000 | 200 | 10000 | 250 | 10000 | 300 | 10000 | ns |
| ${ }^{t} \mathrm{CAS}$ | $\overline{\mathrm{CAS}}$ Pulse Width | 100 |  | 135 |  | 165 |  | 165 |  | ns |
| ${ }^{\text {twCS }}$ [6] | Write Command Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| tWCH | Write Command Hold Time | 45 |  | 55 |  | 75 |  | 80 |  | ns |
| tWCR | Write Command Hold Time Referenced to $\overline{\text { RAS }}$ | 95 |  | 120 |  | 160 |  | 215 |  | ns |
| tWP | Write Command Pulse Width | 45 |  | 55 |  | 75 |  | 80 |  | ns |
| trWL | Write Command to RAS Lead Time | 50 |  | 70 |  | 85 |  | 130 |  | ns |
| ${ }^{\text {t CWL }}$ | Write Command to $\overline{\text { CAS }}$ Lead Time | 50 |  | 70 |  | 85 |  | 130 |  | ns |
| ${ }^{\text {t }} \mathrm{DS}$ | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }} \mathrm{DH}$ | Data-In Hold Time | 55 |  | 65 |  | 75 |  | 80 |  | ns |
| ${ }^{t}$ DHR | Data-In Hold Time Referenced to $\overline{\text { RAS }}$ | 95 |  | 120 |  | 160 |  | 215 |  | ns |

NOTES:

1. All voltages referenced to $\mathrm{V}_{\mathrm{SS}}$.
2. A.C. Characteristics assume $\mathrm{t}_{\mathrm{T}}=5 \mathrm{~ns}$.
3. $t_{R C D}(M A X)$ is specified as a reference point only; if $t_{R C D} \leqslant t_{R C D}(M A X)$ access time is $t_{R A C}$, if $t_{R C D}>t_{R C D}(M A X)$ access time is $t_{R C D}{ }^{+}{ }^{t} C A C$.
4. Load $=2$ TTL loads and 100 pF .
5. Assumes $t_{R C D} \geqslant t_{R C D}(M A X)$.
6. In a write cycle with tWCS $\geqslant$ tWCS(MIN) the cycle is an early write cycle and DOUT will be data written into the selected cell ( $D_{\text {OUT }}=D_{\text {IN }}$ ). If $t_{C W D} \geqslant t_{C W D}(M I N)$ and $t_{R W D} \geqslant t_{\text {RWD }}$ (MIN) the cycle is a read-modify-write cycle and DOUT will be data from the selected address read. If neither of the above conditions are satisfied, DOUT is indeterminate.

## WAVEFORMS

READ CYCLE


RAS-ONLY REFRESH CYCLE

(See next page for notes)

## A.C.CHARACTERISTICS ${ }^{[7,8]}$

$T_{A}=0^{\circ}$ 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 | 2104A-1 |  | 2104A-2 |  | 2104A-3 |  | 2104A-4 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {RWC }}$ | Read Modify Write Cycle Time ${ }^{\text {[2] }}$ | 330 |  | 420 |  | 480 |  | 575 |  | ns |
| terw | RMW Cycle $\overline{\text { CAS }}$ Width | 115 |  | 155 |  | 180 |  | 250 |  | ns |
| $t_{\text {RRW }}$ | RMW Cycle $\overline{\text { RAS }}$ Width | 165 | 10,000 | 220 | 10,000 | 265 | 10,000 | 385 | 10,000 | ns |
| ${ }_{\text {t }}^{\text {RWL }}$ | RMW Cycle $\overline{\mathrm{RAS}}$ Lead Time | 50 |  | 70 |  | 85 |  | 130 |  | ns |
| ${ }^{\text {t }}$ WWL | Write Command to $\overline{\text { CAS }}$ Lead Time | 50 |  | 70 |  | 85 |  | 130 |  | ns |
| $t_{\text {WP }}$ | Write Command Pulse Width | 45 |  | 55 |  | 75 |  | 80 |  | ns |
| $\mathrm{t}_{\text {RCS }}$ | Read Command Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {RWD }}{ }^{[6]}$ | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{WE}}$ Delay | 110 |  | 145 |  | 175 |  | 250 |  | ns |
| ${ }^{t_{\text {CWD }} \text { [6] }}$ | $\overline{\mathrm{CAS}}$ to $\overline{\mathrm{WE}}$ Delay | 60 |  | 80 |  | 90 |  | 115 |  | ns |
| ${ }^{t_{D S}}$ | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }_{\text {t }}$ | Data. In Hold Time | 55 |  | 65 |  | 75 |  | 80 |  | ns |

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE



Notes: 1,2. VIHMIN or $V_{\text {IHCMIN }}$ 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. Referenced to CAS or WE, whichever occurs last.
6. In a write cycle with tWCS $\geqslant$ tWCS (MIN) the cycle is an early write cycle and DOUT will be data written into the selected cell ( $D_{\text {OUT }}=D_{\text {IN }}$ ). If $t_{C W D} \geqslant{ }^{t}$ CWD (MIN) and $t_{\text {RWD }} \geqslant t_{\text {RWD }}($ MIN $)$ the cycle is a read-modify-write cycle and DOUT will be data from the selected address read. If neither of the above conditions are satisfied, DOUT is indeterminate.
7. All voltages referenced to $V_{\text {SS }}$.
8. A.C. Character istics assume $\mathrm{t}_{\mathrm{T}}=5 \mathrm{~ns}$.

## TYPICAL CHARACTERISTICS



## APPLICATIONS

## ADDRESSING

Two externally applied negative going TTL clocks, Row Address Strobe ( $\overline{\mathrm{RAS}}$ ), and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ), are used to strobe the two sets of 6 addresses into internal address buffer registers. The first clock, $\overline{\text { RAS }}$, strobes in the six low order addresses $\left(\mathrm{A}_{0}-\mathrm{A}_{5}\right)$ which selects one of 64 rows and begins the timing which enables the column sense amplifiers. The second clock, $\overline{\mathrm{CAS}}$, strobes in the six high order addresses $\left(\mathrm{A}_{6}-\mathrm{A}_{11}\right)$ 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 {II }}$. All addresses are sequentially located on the chip.

## 2104A Address Map



## DATA CYCLES/TIMING

A memory cycle begins with addresses stable and a negative transition of $\overline{R A S}$. 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{\text { RAS }}$ 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 for at least tDOH MAX. A subsequent $\overline{\mathrm{CAS}}$ must be given to the device either by a Read, Write, Read-Modify-Write, $\overline{\mathrm{CAS}}-$ only or $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ refresh cycle.

Device access time, $t_{A C C}$, is the longer of two calculated intervals:

$$
\text { 1. } t_{A C C}=t_{R A C} O R 2 . t_{A C C}=t_{R C D}+t_{C A C}
$$

Access time from $\overline{R A S}, t_{R A C}$, and access time from $\overline{C A S}$, tcAC, are device parameters. $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ delay time, $\mathrm{t}_{\mathrm{RCD}}$, is a system dependent timing parameter. For example, substituting the device parameters to the 2104A-4 yields:
3. $t_{A C C}=t_{R A C}=300 \mathrm{~ns}$ for $80 \mathrm{nsec} \leq \mathrm{t}_{\mathrm{RCD}} \leq 135 \mathrm{nsec}$
OR
4. $t_{A C C}=t_{R C D}+t_{C A C}=t_{R C D}+165 \mathrm{~ns}$ for $t_{R C D}>135 \mathrm{~ns}$.

Note that if $80 \mathrm{nsec} \leq \mathrm{t}_{\mathrm{RC}} \mathrm{D} \leq 135 \mathrm{nsec}$, device access time is determined by equation 3 and is equal to trAC. If $t_{R C D}>$ 135 ns , access time is determined by equation 4 . This 55 ns interval (shown in the trCD inequality in equation 3) in which the falling edge of $\overline{C A S}$ can occur without affecting access time is provided to allow for system timing skew in the generation of $\overline{C A S}$. This allowance for a tRCD 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}}$. $\mathrm{D}_{\mathrm{Ot} 1}$ will be the data written into the cell addressed. If $\overline{W E}$ goes low after $\overline{\mathrm{CAS}}$ but tcwD < towd min and trWD < trWD MIN, Dout will be indeterminate.

## READ-MODIFY-WRITE CYCLE

A Read-Modify-Write Cycle is performed by bringing Write Enable ( $\overline{W E}$ ) low during a selected $\overline{R A S} / \overline{\mathrm{CAS}}$ cycle with tRWD $\geq$ trwD $^{\text {MIN }}$ and tCWD $\geq$ tcWD MIN. Data in must be valid at or before the falling edge of $\overline{W E}$. In a read-modifywrite cycle Dout is data read from the selected cell 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{\mathrm{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. IDD will be about twice IDD1 for the first cycle of $\overrightarrow{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 $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ cycle was being performed.

## CHIP SELECTION/DESELECTION

The 2104A is selected by driving $\overline{\mathrm{CS}}$ low during a Read,


TYPICAL SUPPLY CURRENTS VS TIME

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{\text { 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 cycle (Read, Write, Read-Modify-Write, $\overline{R A S}-o n l y ~ r e f r e s h) ~ r e f r e s h e s ~$ 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{C A S}$ TIMING

The device clocks, $\overline{\operatorname{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{C A S}$ have minimum pulse widths as defined by tras and tCAS respectively. These minimum pulse widths must be maintained for proper device operation and data integrity. A cycle, once begun by driving $\overline{R A S}$ and/or $\overline{C A S}$ 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. Product tested to page mode operating specifications are available upon request.

## 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. IDD 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 $V_{D D}$ decoupling). For each 16 devices, a $10 \mu \mathrm{~F}$ tantalum or equivalent capacitor should be connected between $\mathrm{V}_{\text {DD }}$ and $\mathrm{V}_{\text {SS }}$ near the array. An equal or slightly smaller bulk capacitor is a!so 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_{C C}$ 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 $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{BB}}$, and $\mathrm{V}_{\mathrm{SS}}$ 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}_{\mathrm{CC}}$ TO $\mathrm{V}_{\mathrm{SS}}$

## 2107C FAMILY 4096-BIT DYNAMIC RAM

|  | $2107 \mathrm{C}-1$ | $2107 \mathrm{C}-2$ | 2107 C | $2107 \mathrm{C}-4$ |
| ---: | :---: | :---: | :---: | :---: |
| Access Time (ns) | 150 | 200 | 250 | 300 |
| Read, Write Cycle (ns) | 380 | 400 | 430 | 470 |
| RMW Cycle (ns) | 450 | 500 | 550 | 590 |
| Max IDD AV (mA) | 35 | 33 | 30 | 30 |

## Direct Replacement for Industry Standard 22-Pin 4K RAMs

## Low Operating Power

## Low Standby Power

## Only One High Voltage Input SignalChip Enable

150 ns Access Time

- $\pm \mathbf{1 0 \%}$ Tolerance on all Power Supplies
- Output is Three-State and TTL Compatible
- TTL Compatible - All Address, Data, Write Enable, Chip Select Inputs

Refresh Period 2 ms

The Intel ${ }^{\circledR} 2107 \mathrm{C}$ 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. A new unique dynamic storage cell provides high speed and wide operating margins. The 2107C 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 2107C 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 2107C is a replacement for the 2107A, 2107B and other industry standard 22-pin 4K RAMs.


## Absolute Maximum Ratings*


#### Abstract

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\right)$ -0.3 V to +20 V

Power Dissipation 1.00W *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{DD}}=+12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}{ }^{[1]}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[2]}$ | Max. |  |  |
| $I_{\text {LI }}$ | Input Load Current (all inputs except CE) |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=O V \text { to } V_{I H \text { MAX }} \\ & C E=V_{I L C} \text { or } V_{I H C} \end{aligned}$ |
| ILC | Input Load Current, CE |  |  | 2 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\text {IHC }}$ MAX |
| \|lol | Output Leakage Current for high impedance state |  |  | 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.5 \mathrm{~V} \end{aligned}$ |
| $\mathrm{IDD1}^{[3]}$ | $\mathrm{V}_{\text {DD }}$ Supply Current - standby ${ }^{\text {[3] }}$ |  | 20 | 200 | $\mu \mathrm{A}$ | $C E=-1 \mathrm{~V}$ to +0.6 V |
| IDD AV | Average $\mathrm{V}_{\text {DD }}$ Current - operating |  | 24 | 35 | mA | $2107 \mathrm{C}-1, \mathrm{t}_{\mathrm{CYC}}=380$ |
|  |  |  | 22 | 33 | mA | $2107 \mathrm{C}-2, \mathrm{t}_{\mathrm{CYC}}=400$ |
|  |  |  | 20 | 30 | mA | 2107C, $\mathrm{t}_{\mathrm{CYC}}=430$ |
|  |  |  | 20 | 30 | mA | $2107 \mathrm{C}-4, \mathrm{t}_{\mathrm{CYC}}=470$ |
| $\mathrm{ICC1}^{[3,4]}$ | $\mathrm{V}_{\text {CC }}$ Supply Current - standby |  |  | 10 | $\mu \mathrm{A}$ | $C E=V_{\text {ILC }}$ or $\overline{C S}=V_{\text {IH }}$ |
| $\mathrm{I}_{\mathrm{BB} 1}$ | $\mathrm{V}_{\text {BB }}$ Supply Current - standby |  | 5 | 50 | $\mu \mathrm{A}$ | $C E=-1 \mathrm{~V}$ to +0.6V |
| $\mathrm{I}_{\text {BB AV }}$ | Average $\mathrm{V}_{\text {BB }}$ Current - operating |  | 100 | 400 | $\mu \mathrm{A}$ | Min. cycle time, Min. $\mathrm{t}_{\text {CE }}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -1.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $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}^{\text {D }}+1$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage | 0.0 |  | 0.40 | V | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V | $\mathrm{I}_{\mathrm{OH}}=-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 0.3 V or more negative than $V_{B B}$.
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}$.
4. During CE on $V_{C C}$ supply current is dependent on output loading. $V_{C C}$ is connected to output buffer only.

## A.C. Characteristics

$\mathrm{T}_{\mathrm{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, AND READ MODIFY/WRITE CYCLE

| Symbol | Parameter | 2107C-1 |  | 2107C-2 |  | 2107C |  | 2107C-4 |  | Units | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\text {REF }}$ | Time Between Refresh |  | 2 |  | 2 |  | 2 |  | 2 | ms |  |
| $\mathrm{t}_{\text {AC }}$ | Address to CE Set-Up Time | 0 |  | 0 |  | 0 |  | 0 |  | ns | 2 |
| $\mathrm{t}_{\text {AH }}$ | Address Hold Time | 50 |  | 50 |  | 100 |  | 100 |  | ns |  |
| $\mathrm{t}_{\mathrm{CC}}$ | CE Off Time | 130 |  | 130 |  | 130 |  | 130 |  | ns |  |
| ${ }_{\text {t }}$ | CE Transition Time |  | 40 |  | 40 |  | 40 |  | 40 | ns |  |
| $t_{\text {c }}$ | CE Off to Output Disable Time | 30 |  | 30 |  | 30 |  | 30 |  | ns | 3 |

READ CYCLE

| Symbol | Parameter | 2107C-1 |  | 2107C-2 |  | 2107C |  | 2107C-4 |  | Units | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\mathrm{C}} \mathrm{Y}$ | Cycle Time | 380 |  | 400 |  | 430 |  | 470 |  | ns | 3 |
| $\mathrm{t}_{\text {CE }}$ | CE On Time | 210 | 4000 | 230 | 4000 | 260 | 4000 | 300 | 4000 | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | CE Output Delay |  | 130 |  | 180 |  | 230 |  | 280 | ns | 4 |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to Output Access |  | 150 |  | 200 |  | 250 |  | 300 | ns | 5 |
| $t_{\text {WL }}$ | CE to $\overline{W E}$ | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |
| $t_{\text {W }}$ | $\overline{W E}$ to CE On | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |

WRITE CYCLE

| Symbol | Parameter | 2107C-1 |  | 2107C-2 |  | 2107C |  | 2107C-4 |  | Units | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\mathrm{C} Y}$ | Cycle Time | 380 |  | 400 |  | 430 |  | 470 |  | ns | 3 |
| ${ }_{\text {t }}^{\text {CE }}$ | CE On Time | 210 | 4000 | 230 | 4000 | 260 | 4000 | 300 | 4000 | ns |  |
| $\mathrm{t}_{\mathrm{w}}$ | $\overline{W E}$ to CE Off | 125 |  | 125 |  | 125 |  | 175 |  | ns |  |
| ${ }^{\text {c }}$ W | CE to $\overline{\mathrm{WE}}$ | 150 |  | 150 |  | 150 |  | 200 |  | ns |  |
| tow | $\mathrm{D}_{\text {IN }}$ to $\overline{\text { WE }}$ Set-Up | 0 |  | 0 |  | 0 |  | 0 |  | ns | 6 |
| ${ }_{\text {t }}{ }^{\text {H }}$ | DIN Hold Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |
| $t_{\text {WP }}$ | WE Pulse Width | 50 |  | 50 |  | 50 |  | 100 |  | ns |  |
| $t_{W D}$ | $\overline{\text { WE }}$ to Output Disable Time | 15 |  | 15 |  | 15 |  | 15 |  |  |  |

Capacitance ${ }^{[7]}{ }^{T}=25^{\circ} \mathrm{C}$

| Symbol | Test | Plastic and <br> Ceramic Package |  | Unit | Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
|  |  | Typ. | Max. |  |  |
| $C_{A D}$ | Address Capacitance, $\overline{C S}, \mathrm{D}_{I N}$ | 5 | 7 | pF | $\mathrm{V}_{I N}=\mathrm{V}_{\mathrm{SS}}$ |
| $\mathrm{C}_{\mathrm{CE}}$ | CE Capacitance | 10 | 15 | pF | $\mathrm{V}_{I N}=\mathrm{V}_{\mathrm{SS}}$ |
| $\mathrm{C}_{\mathrm{OUT}}$ | Data Output Capacitance | 5 | 7 | pF | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\overline{W E}}$ | WE Capacitance | 6 | 8 | pF | $\mathrm{V}_{I N}=\mathrm{V}_{\mathrm{SS}}$ |

## NOTES:

1. After the application of supply voltages or after extended periods of operation without CE, the device must perform a minimum of one initialization cycle (any valid memory cycle or refresh cycle) prior to normal operation.
2. t AC is measured from end of address transition.
3. $\mathrm{t} T=20 \mathrm{~ns}$.
4. $C_{\text {LOAD }}=50 \mathrm{pF}$, Load $=$ One TTL Gate, Pef $=2.0 \mathrm{~V}$.
5. $t_{A C C}=t_{A C}+t_{C O}^{+1} t_{T}$.
6. If $\overline{W E}$ is low before $C E$ goes high then $D_{I N}$ must be valid when CE goes high.
7. Capacitance measured with Boonton Meter or effective capacitance calculated from the equation:
$C=\frac{l \Delta t}{\Delta V}$ with the current equal to a constant 20 mA.

## Read and Refresh Cycle



## 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 N}$ 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 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{\mathrm{DOUT}}$.

## Read Modify Write Cycle

| Symbol | Parameter | 2107C-1 |  | 2107C-2 |  | 2107C |  | 2107C-4 |  | Units | Note |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\text {RWC }}$ | Read Modify Write (RMW) Cycle | 450 |  | 500 |  | 550 |  | 590 |  | ns | 1 |
| tCRW | CE Width During RMW | 280 | 4000 | 330 | 4000 | 380 | 4000 | 420 | 4000 | ns |  |
| $t_{\text {w }}$ c | $\overline{W E}$ to CE On | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |
| tw | $\overline{\text { WE }}$ to CE Off | 125 |  | 125 |  | 125 |  | 175 |  | ns |  |
| $t_{\text {WP }}$ | $\overline{W E}$ Pulse Width | 50 |  | 50 |  | 50 |  | 100 |  | ns |  |
| ${ }_{\text {t }}$ W | $\mathrm{D}_{\text {IN }}$ to WE Setup | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |
| ${ }^{\text {t }}$ DH | $\mathrm{D}_{\text {IN }}$ Hold Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | CE to Output Delay |  | 130 |  | 180 |  | 230 |  | 280 | ns |  |
| $\mathrm{t}_{\mathrm{ACC}}$. | Access Time |  | 150 |  | 200 |  | 250 |  | 300 | ns |  |
| twD | $\bar{W} E$ to Output Disable Time | 15 |  | 15 |  | 15 |  | 15 |  | ns |  |



NOTES: 1. ${ }^{\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. $\mathrm{V}_{\mathrm{SS}}+2.0 \mathrm{~V}$ is the reference level for measuring the timing of $\overline{\mathrm{DOUT}_{\mathrm{OUT}}} \cdot \mathrm{C}_{\mathrm{LOAD}}=50 \mathrm{pF}$. Load $=$ One TTL Gate.
7. WE must be at $\mathrm{V}_{\mathrm{IH}}$ until end of $\mathrm{t}_{\mathrm{CO}}$.

## 2109 FAMILY 8,192 x 1 BIT DYNAMIC RAM

|  | $2109-3$ | $2109-4$ |
| :--- | :---: | :---: |
|  | S6000,S6001 | S6002,S6003 |
| Maximum Access Time (ns) | 200 | 250 |
| Read, Write Cycle (ns) | 375 | 410 |
| Read-Modify-Write Cycle (ns) | 375 | 475 |

## - 8K RAM, Industry Std. 16-Pin Package

■ $\pm 10 \%$ Tolerance on All Power Supplies: $+12 \mathrm{~V},+5 \mathrm{~V},-5 \mathrm{~V}$

- Low Power: 462mW Max. Operating, 20mW Max. Standby
- Low IDD Current Transients
- All Inputs, Including Clocks, TTL Compatible


## ■ Non-Latched Output is Three-State, TTL Compatible

- $\overline{\text { RAS Only Refresh }}$
- 64 Refresh Cycles Required Every 2ms
- Page Mode Capability
- $\overline{\text { CAS }}$ Controlled Output

The Intel ${ }^{\circledR} 2109$ is a 8,192 word by 1-bit Dynamic MOS RAM which is pin compatible with the industry standard 16K dynamic RAMs. The 2109 is manufactured with the same masks as the Intel® 2117 and is fabricated with Intel's standard two layer polysilicon NMOS technology - a production proven process for high reliability, high performance, and high storage density. As is shown in the block diagram below, the device is organized as two 8 K arrays separated by sense amplifiers and column decoders. The selected 8 K array is tested for all of the A.C. and D.C. characteristics necessary to permit the 2109 to be considered a functionally compatible 8 K version of the 16 K device.
The 2109 uses a single transistor dynamic storage cell and advanced dynamic circuitry to achieve high speed with low power dissipation. The circuit design minimizes the current transients typical of dynamic RAM operation. These low current transients and $\pm 10 \%$ tolerance on all power supplies contribute to the high noise immunity of the 2109 in a system environment.
The 2109 is available as either an "upper" or "lower" half of the 2117 . Row Address 6 ( $\mathrm{A}_{6}$ ) selects the operating half, and is $V_{\text {IH }}$ for S6000, S6002, S6064 and S6066 specifications and $A_{6}$ is $V_{I L}$ for S6001, S6003, S6065 and S6067 specifications.
The 2109 three-state output is controlled by Column Address Strobe ( $\overline{\mathrm{CAS}}$ ) independent of Row Address Strobe ( $\overline{\mathrm{RAS}}$ ). After a valid read or read-modify-write cycle, data is latched on the output by holding CAS low. The data out pin is returned to the high impedance state by returning $\overline{\mathrm{CAS}}$ to a high state. The 2109 hidden refresh feature allows $\overline{\mathrm{CAS}}$ to be held low to maintain latched data while $\overline{\mathrm{RAS}}$ is used to execute $\overline{\mathrm{RAS}}$-Only refresh cycles.
The single transistor storage cell requires refreshing for data retention. Refreshing is accomplished by performing $\overline{\text { RAS }}-$ Only refresh cycles, hidden refresh cycles, or normal read or write cycles on the 64 row address combinations of $A_{0}$ through $A_{5}$. $A_{6}$ must be at its proper state ( $V_{1 H}$ or $V_{I L}$ depending on the device specification) for 64 cycle refresh. A write cycle will refresh stored data on all bits of the selected row except the bit which is addressed.

PIN CONFIGURATION LOGIC SYMBOL


NOTE 1: S6000, S6002: $A_{6}$ AT VIH DURING ROW ADDRESS VALID S6001, S6003: A6 AT VIL DURING ROW ADDRESS VALID
PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{6}$ | ADDRESS INPUTS | WE | WRITE ENABLE |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CAS}}$ | COLUMN ADDRESS STROBE | $V_{B B}$ | POWER (-5V) |
| DIN | DATA IN | $\mathrm{V}_{\mathrm{CC}}$ | POWER ( +5 V ) |
| Dout | data out | $V_{D D}$ | POWER (+12V) |
| $\overline{\text { RAS }}$ | ROW ADDRESS STROBE | $\mathrm{V}_{\text {ss }}$ | GROUND |



## 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}$ ( $\mathrm{V}_{\mathrm{SS}}-\mathrm{V}_{\mathrm{BB}} \geq 4 \mathrm{~V}$ ) -0.3 V to +20 V
Data Out Current .................................... 50 mA
Power Dissipation ................................. 1.0W

## *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 ${ }^{[1,2]}$

$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}_{S S}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[3]}$ | Max. |  |  |  |
| \|ILI| | Input Load Current (any input) |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=\mathrm{V}_{\text {SS }}$ to $7.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=-5.0 \mathrm{~V}$ |  |
| \|lool | Output Leakage Current for High Impedance State |  | 0.1 | 10 | $\mu \mathrm{A}$ | Chip Deselected: $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IH}}$, $V_{\text {OUT }}=0$ to 5.5 V |  |
| IDD1 | VDD Supply Current, Standby |  |  | 1.5 | mA | $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{\mathrm{IH}}$ | 4 |
| IBB1 | VBB Supply Current, Standby |  | 1.0 | 50 | $\mu \mathrm{A}$ |  |  |
| ICC1 | Vcc Supply Current, Output Deselected |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IH}}$ | 5 |
| IDD2 | VDD Supply Current, Operating |  |  | 35 | mA | $2109-3, t_{\text {RC }}=375 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=200 \mathrm{~ns}$ | 4 |
|  |  |  |  | 33 | mA | 2109-4, $\mathrm{t}_{\text {RC }}=410 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=250 \mathrm{~ns}$ | 4 |
| IBB2 | VBB Supply Current, Operating, $\overline{R A S}$-Only Refresh, Page Mode |  | 150 | 300 | $\mu \mathrm{A}$ | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |  |
| IDD3 | VDD Supply Current, $\overline{\text { RAS }}$-Only Refresh |  |  | 27 | mA | $2109-3, \mathrm{t}_{\text {RC }}=375 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=200 \mathrm{~ns}$ | 4 |
|  |  |  |  | 26 | mA | 2109-4, $\mathrm{t}_{\text {RC }}=410 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=250 \mathrm{~ns}$ | 4 |
| IDD5 | VDD Supply Current, Standby, Output Enabled |  | 1.5 | 3 | mA | $\overline{\mathrm{CAS}}$ at VIL, $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{\text {IH }}$ |  |
| $V_{\text {IL }}$ | Input Low Voltage (all inputs) | -1.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (all inputs) | 2.4 |  | 6.0 | V |  |  |
| VOL | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ | 4 |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-5 \mathrm{~mA}$ | 4 |

## NOTES:

1. All voltages referenced to Vss.
2. No power supply sequencing is required. However, $V_{D D}, V_{C C}$ and $V_{S S}$ should never be more negative than $-0.3 V$ with respect to $V_{B B}$ as required by the absolute maxımum ratings.
3. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. See the Typical Characteristics Section for values of this parameter under alternate conditions.
5. Icc is dependent on output loading when the device output is selected. VCC is connected to the output buffer only. Vcc may be reduced to Vss without affecting refresh operation or maintenance of internal device data.

## TYPICAL SUPPLY CURRENT WAVEFORMS



Typical power supply current waveforms vs. time are shown for the $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ timings of Read/Write, Read/ Write (Long $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ ), and $\overline{\mathrm{RAS}}$-only refresh cycles. IDD and IBB current transients at the $\overline{R A S}$ and $\overline{C A S}$ edges require adequate decoupling of these supplies. Decoupling recommendations are provided in the Applications section.

The effects of cycle time, VDD supply voltage and ambient temperature on the IDD current are shown in graphs included in the Typical Characteristics Section. Each family of curves for IDD1, IDD2, and IDD3 is related by a common point at $V_{D D}=12.0 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ for two given $t_{\text {RAS }}$ pulse widths. The typical IDD current for a given condition of cycle time, $V_{D D}$ and $T_{A}$ can be determined by combining the effects of the appropriate family of curves.

CAPACITANCE ${ }^{[1]}$
$T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 10 \%, \mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Parameter | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Address, Data In | 3 | 5 | pF |
| $\mathrm{C}_{12}$ | $\overline{\text { RAS }}$ Capacitance, $\overline{\mathrm{WE}}$ Capacitance | 4 | 7 | pF |
| $\mathrm{C}_{13}$ | $\overline{\text { CAS }}$ Capacitance | 6 | 10 | pF |
| $\mathrm{C}_{0}$ | Data Output Capacitance | 4 | 7 | pF |

## NOTES:

1. Capacitance measured with Boonton Meter or effective capacitance calculated from the equation:
$C=\frac{l \Delta t}{\Delta V}$ with $\Delta V$ equal to 3 volts and power supplies at nominal levels.

## A.C. CHARACTERISTICS ${ }^{[1,2,3]}$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$, unless otherwise noted.

## READ, WRITE, READ-MODIFY-WRITE AND REFRESH CYCLES

| Symbol | Parameter | $\begin{aligned} & 2109-3 \\ & \text { S6000,S6001 } \\ & \text { Min. } \quad \text { Max. } \end{aligned}$ | $\begin{aligned} & \text { 2109-4 } \\ & \text { S6002,S6003 } \\ & \text { Min. Max. } \end{aligned}$ | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| trac | Access Time From $\overline{\text { RAS }}$ | 200 | 250 | ns | 4,5 |
| tcac | Access Time From $\overline{\mathrm{CAS}}$ | 135 | 165 | ns | 4,5,6 |
| tref | Time Between Refresh | 2 | 2 | ms |  |
| $t_{\text {RP }}$ | $\overline{\text { RAS Precharge Time }}$ | 120 | 150 | ns |  |
| tCPN | $\overline{\mathrm{CAS}}$ Precharge Time(non-page cycles) | 25 | 25 | ns |  |
| tCRP | $\overline{\mathrm{CAS}}$ to $\overline{\mathrm{RAS}}$ Precharge Time | -20 | -20 | ns |  |
| $t_{\text {RCD }}$ | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ Delay Time | $25 \quad 65$ | 3585 | ns | 7 |
| trin | $\overline{\text { RAS }}$ Hold Time | 135 | 165 | ns |  |
| tcsi | $\overline{\text { CAS }}$ Hold Time | 200 | 250 | ns |  |
| $t_{\text {ASR }}$ | Row Address Set-Up Time | 0 | 0 | ns |  |
| $t_{\text {RAH }}$ | Row Address Hold Time | 25 | 35 | ns |  |
| tasc | Column Address Set-Up Time | -10 | -10 | ns |  |
| tcan | Column Address Hold Time | 55 | 75 | ns |  |
| $t_{\text {AR }}$ | Column Address Hold Time, to $\overline{\mathrm{RAS}}$ | 120 | 160 | ns |  |
| t | Transition Time (Rise and Fall) | 350 | 350 | ns | 8 |
| toff | Output Buffer Turn Off Delay | 060 | $0 \quad 70$ | ns |  |

## READ AND REFRESH CYCLES

| $\mathrm{t}_{\mathrm{RC}}$ | Random Read Cycle Time | 375 |  | 410 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tras | $\overline{\text { RAS }}$ Pulse Width | 200 | 10000 | 250 | 10000 | ns |  |
| tcas | $\overline{\text { CAS Pulse Width }}$ | 135 | 10000 | 165 | 10000 | ns |  |
| trcs | Read Command Set-Up Time | 0 |  | 0 |  | ns |  |
| $t_{\text {RCH }}$ | Read Command Hold Time | 0 |  | 0 |  | ns |  |

## WRITE CYCLE

| tRC | Random Write Cycle Time | 375 | 410 | ns |  |
| :---: | :--- | :--- | :--- | :--- | :--- |
| tRAS | $\overline{R A S}$ Pulse Width | $200 \quad 10000$ | $250 \quad 10000$ | ns |  |
| tCAS | $\overline{\text { CAS Pulse Width }}$ | $135 \quad 10000$ | $165 \quad 10000$ | ns |  |
| twCS | Write Command Set-Up Time | -20 | -20 |  |  |
| twCH | Write Command Hold Time | 55 | 75 | ns | 9 |
| tWCR | Write Command Hold Time, to $\overline{\text { RAS }}$ | 120 | 160 | ns |  |
| tWP | Write Command Pulse Width | 55 | 75 | ns |  |
| tRWL | Write Command to $\overline{\text { RAS }}$ Lead Time | 80 | 100 | ns |  |
| tCWL | Write Command to $\overline{\text { CAS }}$ Lead Time | 80 | 100 | ns |  |
| tDS | Data-In Set-Up Time | 0 | 0 | ns |  |
| tDH | Data-In Hold Time | 55 | 75 | ns |  |
| tDHR | Data-In Hold Time, to $\overline{R A S}$ | 120 | 160 | ns |  |

## READ-MODIFY-WRITE CYCLE

| trWC | Read-Modify-Write Cycle Time | 375 | 475 | ns |  |
| :---: | :--- | :--- | :--- | :--- | :--- |
| tRRW | RMW Cycle $\overline{\text { RAS Pulse Width }}$ | $245 \quad 10000$ | $305 \quad 10000$ | ns |  |
| tCRW | RMW Cycle $\overline{\text { CAS Pulse Width }}$ | $180 \quad 10000$ | 230 | 10000 | ns |
| tRWD | $\overline{\text { RAS }}$ to $\overline{W E}$ Delay | 160 | 200 |  |  |
| tcWD | $\overline{\text { CAS }}$ to $\overline{\text { WE Delay }}$ | 95 | 125 | ns | 9 |

Notes: See following page for A.C. Characteristics Notes.

## WAVEFORMS




NOTES: $1,2 . \mathrm{V}_{\mathrm{IH}}$ MIN AND $\mathrm{V}_{\mathrm{IL}}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $V_{\text {OH MIN }}$ AND $V_{\text {OL max }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT.
5. TOFF IS MEASURED TO IOUT \& | L Lol.
6. $\mathrm{t}_{\mathrm{DS}}$ AND toH $^{\text {ARE REFERENCED TO } \overline{C A S}}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. $\mathrm{t}_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF CAS OR RAS, WHICHEVER OCCURS FIRST.
8. tcRP REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A CASONLY CYCLE (1.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH $\overline{R A S})$.

## A.C. CHARACTERISTICS NOTES (From Previous Page)

1. All voltages referenced to Vss.
2. Eight cycles are required after power-up or prolonged periods (greater than 2 ms ) of $\overline{R A S}$ inactivity before proper device operation is achieved. Any 8 cycles which perform refresh are adequate for this purpose.
3. A.C. Characteristics assume $\mathrm{tt}_{\mathrm{t}}=5 \mathrm{~ns}$.
4. Assume that $t_{R C D} \leq t_{R C D}$ (max.). If $t_{R C D}$ is greater than $t_{R C D}$ (max.) then trac will increase by the amount that $t_{R C D}$ exceeds $t_{\text {RCD }}$ (max.).
5. Load $=2$ TTL loads and 100 pF .
6. Assumes $t_{R C D} \geq t_{R C D}$ (max.).
7. $t_{R C D}$ (max.) is specified as a reference point only; if $t_{R C D}$ is less than $t_{R C D}$ (max.) access time is tRAC, if tRCD is greater than $t_{R C D}$ (max.) access time is trCD + tCAC.
8. $t_{T}$ is measured between $V_{I H}$ (min.) and $V_{I L}$ (max.).
9. twCS, tCWD and tRWD are specified as reference points only. If twcs $\geq$ twos (min.) the cycle is an early write cycle and the data out pin will remain high impedance throughout the entire cycle. If $t_{C W D} \geq t_{C W D}\left(\min\right.$.) and $t_{R W D} \geq t_{\text {RWD }}$ (min.), the cycle is a read-modify-write cycle and the data out will contain the data read from the selected address. If neither of the above conditions is satisfied, the condition of the data out is indeterminate.

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE



RAS-ONLY REFRESH CYCLE


HIDDEN REFRESH CYCLE


NOTES: 1 1,2. $V_{I H ~ M I N ~}$ AND $V_{I L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $V_{\text {OH MIN }}$ AND $V_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT.
5. toff is MeASURED TO IOUT \& \|lol.
6. $t_{D S}$ AND $t_{D H}$ ARE REFERENCED TO CAS OR WE, WHICHEVER OCCURS LAST.
7. $\mathrm{t}_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF CAS OR $\overline{\text { RAS, WHICHEVER OCCURS FIRST }}$
8. tCRP REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A CASONLY CYCLE (I.e., FOR SYSTEMS WHERE $\overline{\text { CAS }}$ HAS NOT BEEN DECODED WITH RAS).

## TYPICAL CHARACTERISTICS ${ }^{[1]}$

## GRAPH 1

TYPICAL ACCESS TIME
${ }^{\text {traC }}$ (NORMALIZED) VS. VDD


GRAPH 4
TYPICAL ACCESS TIME ${ }^{\text {t RAC }}$ (NORMALIZED) VS. AMBIENT TEMPERATURE


TA - AMBIENT TEMPERATURE (C)

GRAPH 7
TYPICAL OPERATING CURRENT IDD2 VS. tRC


GRAPH 2
TYPICAL ACCESS TIME ${ }^{t_{R A C}}$ (NORMALIZED) VS. $V_{B B}$


GRAPH 5
TYPICAL STANDBY CURRENT IDD1 VS. VDD


GRAPH 8
TYPICAL OPERATING CURRENT ${ }^{\prime}$ DD2 VS. VDD


GRAPH 6
TYPICAL STANDBY CURRENT IDD1 VS. AMBIENT TEMPERATURE


GRAPH 9
TYPICAL OPERATING CURRENT IDD2 VS. AMBIENT TEMPERATURE


NOTES: See following page for Typical Characteristics Notes.

## TYPICAL CHARACTERISTICS ${ }^{[1]}$

GRAPH 10
TYPICAL $\overline{R A S}$ ONLY REFRESH CURRENT

IDD3 VS. tre


GRAPH 13
TYPICAL PAGE MODE CURRENT IDD4 VS. tpC


GRAPH 16
TYPICAL OUTPUT SOURCE CURRENT $I_{O H}$ VS. OUTPUT VOLTAGE VOH

$\mathrm{V}_{\mathrm{OH}}$ - OUTPUT VOLTAGE (VOLTS)

GRAPH 11
TYPICAL $\overline{\text { RAS }}$ ONLY REFRESH CURRENT

IDD3 VS. VDD


GRAPH 14
TYPICAL PAGE MODE CURRENT $I_{D D 4}$ VS. $V_{D D}$


GRAPH 17
TYPICAL OUTPUT SINK CURRENT IOL VS. OUTPUT VOLTAGE VOL

$V_{O L}$ - OUTPUT VOLTAGE (VOLTS)

GRAPH 12
TYPICAL $\overline{R A S}$ ONLY REFRESH CURRENT IDD3 VS. AMBIENT TEMPERATURE


GRAPH 15
TYPICAL PAGE MODE CURRENT IDD4 VS. AMBIENT TEMPERATURE


NOTES:

1. The cycle time, $V_{D O}$ supply voltage, and ambient temperature dependence of IDD1, IDD2, IDD3 and IDD4 is shown in related graphs. Common points of related curves are indicated:

- $I_{D D 1} @ V_{D D}=13.2 \mathrm{~V}, T_{A}=0^{\circ} \mathrm{C}$
- IDD2 or $I_{D D 3}$ @ $t_{R A S}=200 \mathrm{~ns}, \mathrm{t}_{\mathrm{RC}}=$ $375 n s, V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\Delta I_{D D 2}$ or $I_{D D 3} @ t_{R A S}=500 \mathrm{~ns}, t_{R C}=$ $750 \mathrm{~ns}, \mathrm{~V}_{\mathrm{DD}}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\square I_{D D 4} @ t^{C A S}=135 \mathrm{~ns}, \mathrm{t}_{\mathrm{CC}}=225 \mathrm{~ns}$, $V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\triangle I_{D D 4} @{ }^{t} \mathrm{CAS}=350 \mathrm{~ns}, \mathrm{tPC}=500 \mathrm{~ns}$, $V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
The typical IDD current for a given combination of cycle time, $V_{D D}$ supply voltage and ambient temperature may be determined by combining the effects of the appropriate family of curves.


## D.C. AND A.C. CHARACTERISTICS, PAGE MODE ${ }^{[7,8,11]}$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=12 \mathrm{~V} \pm 10 \%, \mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$, unless otherwise noted.
For Page Mode Operation order: $2109-3^{*}$ S6064, S6065 or 2109-4* S6066, S6067.

| Symbol | Parameter | $\begin{gathered} 2109-3 \\ \text { S6064,S6065 } \end{gathered}$ |  | $\begin{gathered} 2109-4 \\ \text { S6066,S6067 } \end{gathered}$ |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| tpC | Page Mode Read or Write Cycle | 225 |  | 275 |  | ns |  |
| tPCM | Page Mode Read Modify Write | 270 |  | 340 |  | ns |  |
| tcp | $\overline{\text { CAS Precharge Time, Page Cycle }}$ | 80 |  | 100 |  | ns |  |
| trPM | $\overline{R A S}$ Pulse Width, Page Mode | 200 | 10,000 | 250 | 10,000 | ns |  |
| tCAS | $\overline{\text { CAS Pulse Width }}$ | 135 | 10,000 | 165 | 10,000 | ns |  |
| IDD4 | VDD Supply Current Page Mode, Minimum tpc, Minimum tcas |  | 30 |  | 26 | mA | 9 |

*S6064, S6066: A6 at VIH during Row Address Valid. S6065, S6067: A6 at VIL during Row Address Valid.

## WAVEFORMS

## PAGE MODE READ CYCLE



NOTES: 1,2. $V_{I H \text { MIN }}$ AND $V_{I L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4 . $V_{\text {OH MIN }}$ AND $V_{\text {OL. MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF D
5. toff IS MEASURED TO IOUT $\leqslant I$ ILOI.
6. $\mathrm{t}_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF $\overline{\mathrm{CAS}}$ OR $\overline{\mathrm{RAS}}$, WHICHEVER OCCURS FIRST.
7. ALL VOLTAGES REFERENCED TO VSS.
8. AC CHARACTERISTIC ASSUME $\mathrm{t}_{\mathrm{T}}=5$ ns.
9. SEE THE TYPICAL CHARACTERISTICS SECTION FOR VALUES OF THIS PARAMETER UNDER ALTERNATE CONDITIONS.
10. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\text { RAS }} / \overline{C A S}$ CYCLES PRECEEDED BY A $\overline{\text { CAS }}-$ ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).
11. ALL PREVIOUSLY SPECIFIED A.C. AND D.C. CHARACTERISTICS ARE APPLICABLE TO THEIR RESPECTIVE PAGE MODE DEVICE (i.e., 2109-3, S6064 OR S6065 WILL OPERATE AS A 2109-3).

PAGE MODE WRITE CYCLE


PAGE MODE READ-MODIFY-WRITE CYCLE


NOTES: 1,2. $V_{1 H}$ MIN AND $V_{1 L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $V_{\text {OH MIN }}$ AND $V_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF D OUT .
5. toff is MEASURED TO IOUT $\leqslant\left|I_{\text {LO }}\right|$.
6. $t_{D S}$ AND $t_{D H}$ ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST,
7. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\text { RAS/ }} \overline{\text { CAS }}$ CYCLES PRECEEDED BY A $\overline{C A S}-$

ONLY CYCLE (i.e., FOR SYSTEMS WHERE $\overline{\text { CAS }}$ HAS NOT BEEN DECODED WITH RAS).

## APPLICATIONS

The 2109 is packaged in a standard 16-pin DIP by multiplexing 14 address bits onto 7 input pins $\left(A_{0}-A_{6}\right)$. The 7 bit address words are latched into the 2109 by two TTL clocks, Row Address Strobe ( $\overline{\mathrm{RAS}}$ ) and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ). Since the 2109 is an 8 K memory device, only 13 of the 14 address bits are required and the 14th address bit must be at $\mathrm{V}_{\mathrm{IH}}$ (for S6000, S6002, S6064 or S6066) or $\mathrm{V}_{\mathrm{IL}}$ (for S6001, S6003, S6065 or S6067) during Row Address Valid. This means it is not possible to simply tie input pin A6 high or low, since it supplies two system addresses to the memory array. Input pin $A_{6}$ must be at the appropriate level (determined by the " S "-specification) during the row address valid period and then changed to the proper high order address during the column address valid period.

## READ CYCLE

A Read cycle is performed by maintaining Write Enable $(\overline{W E})$ high during a $\overline{R A S} / \overline{C A S}$ operation. The output pin of a selected device will remain in a high impedance state until valid data appears at the output at access time.
Device access time, $t_{A C C}$, is the longer of the two calculated intervals:

$$
\text { 1. } t_{A C C}=t_{R A C} O R \text { 2. } t_{A C C}=t_{R C D}+t_{C A C}
$$

Access time from $\overline{R A S}$, trAC, and access time from $\overline{\mathrm{CAS}}$, tcac, are device parameters. Row to column address strobe delay time, trCD, are system dependent timing parameters. For example, substituting the device parameters of the 2109-3 yields:

$$
\begin{aligned}
& \text { 3. } t_{A C C}=t_{R A C}=200 \mathrm{nsec} \text { for } 25 \mathrm{nsec} \leq t_{R C D} \leq 65 \mathrm{nsec} \\
& \\
& \text { OR } t_{A C C}=t_{R C D}+t_{C A C}=t_{R C D}+135 \text { for } t_{R C D}>65 \mathrm{nsec}
\end{aligned}
$$

Note that if $25 \mathrm{nsec} \leq \mathrm{t}_{\text {RCD }} \leq 65 \mathrm{nsec}$ device access time is determined by equation 3 and is equal to trac. If trCL $>65 \mathrm{nsec}$, access time is determined by equation 4. This 40 nsec interval (shown in the trCD 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 $\overline{C A S}$.

## REFRESH CYCLES

Each of the 64 rows of the 2109 must be refreshed every 2 milliseconds to maintain data. Any memory cycle:

1. Read Cycle
2. Write Cycle (Early Write, Delayed Write or Read-Modify-Write)
3. $\overline{\text { RAS-only Cycle }}$
refreshes the selected row as defined by the low order $(\overline{\mathrm{RAS}})$ addresses. $\mathrm{A}_{6}$ must be held at the proper level ( $\mathrm{V}_{1 H}$ or $V_{I L}$ depending on specification) to perform 64 cycle refresh operation, but may be driven high and low for 128 cycle $\overline{R A S}-o n l y$ refresh without affecting device data retention. Any Write cycle, of course, may change the state of the selected cell. Using a Read, Write, or Read-Modify-Write cycle for refresh is not recommended for systems which utilize "wire-OR" outputs since output bus contention will occur.
A $\overline{\text { RAS-only refresh cycle is the recommended technique }}$ for most applications to provide for data retention. A $\overline{R A S}-$ only refresh cycle maintains the DOUT in the high impedance state with a typical power reduction of $20 \%$ over a Read or Write cycle.

## $\overline{\text { RAS }} / \overline{\mathbf{C A S}}$ TIMING

$\overline{R A S}$ and $\overline{\text { CAS }}$ have minimum pulse widths as defined by tras and tcas respectively. These minimum pulse widths must be maintained for proper device operation and data integrity. A cycle, once begun by driving $\overline{\mathrm{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 can not begin until the minimum precharge time, thp, has been met.

## DATA OUTPUT OPERATION

The 2109 Data Output (DOUT), which has three-state capability, is controlled by $\overline{\mathrm{CAS}}$. During $\overline{\mathrm{CAS}}$ high state ( $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IH}}$ ) the output is in the high impedance state. The following table summarizes the Dout state for various types of cycles.

## Intel 2109 Data Output Operation for Various Types of Cycles

| Type of Cycle | Dout State |
| :---: | :---: |
| Read Cycle | Data From Addressed Memory Cell |
| Fast Write Cycle | HI-Z |
| RAS-Only Refresh Cycle | HI-Z |
| $\overline{\text { CAS-Only Cycle }}$ | HI-Z |
| Read/Modify/Write Cycle | Data From Addressed Memory Cell |
| Delayed Write Cycle | Indeterminate |

## HIDDEN REFRESH

A feature of the 2109 is that refresh cycles may be performed while maintaining valid data at the output pin. This feature is referred to as Hidden Refresh. Hidden Refresh is performed by holding $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IL}}$ and taking $\overline{R A S}$ high and after a specified precharge period (tRP), executing a "促S-Only" refresh cycle, but with $\overline{\mathrm{CAS}}$ held low (see Figure below).


This feature allows a refresh cycle to be "hidden" among data cycles without affecting the data availability.

## POWER ON

The 2109 requires no power on sequence providing absolute maximum ratings are not exceeded. After the application of supply voltages or after extended periods of bias (greater than 2 milliseconds) without clocks, the device must perform a minimum of eight initialization cycles (any combination of cycles containing a $\overline{\mathrm{RAS}}$ clock, such as $\overline{\text { RAS }}$-Only refresh) prior to normal operation.

## POWER SUPPLY DECOUPLING/DISTRIBUTION

It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be connected between VDD and VSS at every other device in the memory array. A $0.1 \mu \mathrm{~F}$ ceramic capacitor should also be connected between VBB and VSs at every other device (preferably the alternate devices to the VDD decoupling). For each 16 devices, a $10 \mu \mathrm{~F}$ tantalum or equivalent capacitor should be connected between VDD and VSS near the array. An equal or slightly smaller bulk capacitor is also recommended between VBB and VSs for every 32 devices.

The VCc supply is connected only to the 2109 output buffer and is not used internally. The load current from the Vcc supply is dependent only upon the output loading and is associated with the input high level current to a TTL gate and the output leakage currents of any OR-tied 2109's (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 VCC and VSS for every eight memory devices.
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 VDD, VBB, and Vss 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

$$
\begin{aligned}
& \mathbf{D}=0.1 \mu \mathrm{~F} \text { TO } V_{\text {DD }} \text { TO } V_{\text {SS }} \\
& \mathbf{B}=0.1 \mu \mathrm{~F} \mathrm{~V}_{\mathbf{B B}} \text { TO } \mathrm{V}_{\mathbf{S S}} \\
& \mathbf{C}=0.01 \mu \mathrm{~F} \mathrm{~V}_{\mathbf{C C}} \text { TO } \mathrm{V}_{\mathbf{S S}}
\end{aligned}
$$

SAMPLE P.C. BOARD LAYOUT EMPLOYING VERTICAL AND HORIZONTAL GRIDDING ON ALL POWER SUPPLIES.

## 8K UPGRADE FOR 4K SYSTEMS

The 2109 can be used to upgrade existing 4K (Intel 2104A) memory systems with minimal redesign. The 2109 maintains many of the features of the 4K RAMs. For example, the latched data output of the 4 Ks can be emulated by holding CAS low to maintain data out valid. Hidden refresh capability for the 4 Ks is also maintained with the 2109. The 64 cycle refresh operation of the 2109 makes it compatible with 4 K systems.
To upgrade a 4 K system to accept the 2109 , an extra memory address multiplexer must be implemented to replace the Chip Select ( $\overline{\mathrm{CS}}$ ) input of the 4 Ks . The replacement circuitry is shown in the figure below, and involves some gating to control the output of the multiplexer during row and column address valid periods and also some control to handle the multiplexer during refresh operation.


# 2111A/8111A-4* $256 \times 4$ BIT STATIC RAM 

| $2111 A-2$ | 250 ns Max. |
| :--- | :--- |
| $2111 A$ | 350 ns Max. |
| $2111 A-4$ | 450 ns Max. |

## - Common Data Input and Output

- Single +5 V Supply Voltage


## - Directly TTL Compatible: All Inputs and Output

- Static MOS: No Clocks or Refreshing Required


## - Simple Memory Expansion: Chip Enable Input

- Fully Decoded: On Chip Address Decode
- Inputs Protected: All Inputs Have Protection Against Static Charge
- Low Cost Packaging: 18 Pin Plastic Dual In-Line Configuration
- Low Power: Typically 150 mW
- Three-State Output: OR-Tie Capability

The Intel ${ }^{8} 2111 \mathrm{~A}$ 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 2111A 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® 2111 A 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.

LOGIC SYMBOL

PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{7}$ | ADDRESS INPUTS |
| :--- | :--- |
| OD | OUTPUT DISABLE |
| $\mathrm{R} / \overline{\mathrm{W}}$ | READ/WRITE INPUT |
| $\overline{\mathrm{CE}}{ }_{1}$ | CHIP ENABLE 1 |
| $\overline{\mathrm{CE}}_{2}$ | CHIP ENABLE 2 |
| $\mathrm{I} / \mathrm{O}_{1}-\mathrm{I} / \mathrm{O}_{4}$ | DATA INPUT/OUTPUT |

## 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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {LI }}$ | Input Load Current |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\mathrm{I}_{\text {LOH }}$ | I/O Leakage Current |  | 1 | 10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{1 / \mathrm{O}}=4.0 \mathrm{~V}$ |
| $\mathrm{I}_{\text {LOL }}$ | I/O Leakage Current |  | -1 | -10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{1 / \mathrm{O}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Power Supply 2111A, 2111A-4 |  | 35 | 55 | mA | $\begin{aligned} & \mathrm{V}_{I N}=5.25 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
|  | Current 2111A-2 |  | 45 | 65 |  |  |
| ${ }^{\text {c CC2 }}$ | Power Supply 2111A, 2111A-4 |  |  | 60 | 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}$ |
|  | Current 2111A-2 |  |  | 70 |  |  |
| $\mathrm{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{IOL}=2.0 \mathrm{~mA}$ |
| $\mathrm{VOH}^{\text {O }}$ | Output High 2111A, 2111A-2 | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
|  | Voltage 2111A-4 | 2.4 |  |  | V | $\mathrm{IOH}^{\text {O }}=-150 \mu \mathrm{~A}$ |



NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.

## A.C. CHARACTERISTICS FOR 2111A-2 (250 ns ACCESS TIME)

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. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {RC }}$ | Read Cycle | 250 |  |  | ns | ```tr, tf}=20n Input Levels=0.8V or 2.0V Timing Reference = 1.5V Load = 1 TTL Gate``` |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time |  |  | 250 | ns |  |
| ${ }^{\text {t }}$ CO | Chip Enable To Output |  |  | 180 | ns |  |
| ${ }^{1} \mathrm{OD}$ | Output Disable To Output |  |  | 130 | ns |  |
| $\mathrm{t}_{\mathrm{DF}}{ }^{\text {[3] }}$ | Data Output to High Z State | 0 |  | 180 | ns |  |
| ${ }^{\text {tor }}$ | Previous Read Data Valid after change of Address | 40 |  |  | ns |  |

## WRITE CYCLE

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tw }}$ c | Write Cycle | 170 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{\mathrm{L}}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {a }}$ W | Write Delay | 20 |  |  | ns |  |
| ${ }^{\text {c }}$ CW | Chip Enable To Write | 150 |  |  | ns |  |
| tow | Data Setup | 150 |  |  | ns |  |
| ${ }_{\text {t }}{ }_{\text {d }}$ | Data Hold | 0 |  |  | ns |  |
| $t_{\text {WP }}$ | Write Pulse | 150 |  |  | ns |  |
| $t_{\text {WR }}$ | Write Recovery | 0 |  |  | ns |  |
| ${ }^{t}$ DS | Output Disable Setup | 20 |  |  | ns |  |

CAPACITANCE ${ }^{[2]} \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}}$ | $1 / \mathrm{O}$ Capacitance $\mathrm{V}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~V}$ | 10 | 15 |

## WAVEFORMS

## READ CYCLE



NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. This parameter is periodically sampled and is not $100 \%$ tested.
3. t $D F$ is with respect to the trailing edge of $\overline{\mathrm{CE}}, \overline{\mathrm{CE}} \mathrm{E}_{2}$, or OD , whichever occurs first.

## 2111A (350 ns ACCESS TIME)

## 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. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 350 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \end{aligned}$ |
| $t_{\text {A }}$ | Access Time |  |  | 350 | ns |  |
| ${ }^{t} \mathrm{CO}$ | Chip Enable To Output |  |  | 240 | ns |  |
| $\mathrm{t}_{\mathrm{OL}}$ | Output Disabie To Output |  |  | 180 | ns |  |
| $\mathrm{t}_{\mathrm{DF}}{ }^{\text {[2] }}$ | Data Output to High Z State | 0 |  | 150 | ns |  |
| $\mathrm{tOH}^{\text {O}}$ | Previous Read Data Valid after change of Address | 40 |  |  | ns |  |

## WRITE CYCLE

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {w }}$ WC | Write Cycle | 220 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {A }}$ W | Write Delay | 20 |  |  | ns |  |
| ${ }^{\text {t }}$ CW | Chip Enable To Write | 200 |  |  | ns |  |
| tow | Data Setup | 200 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold | 0 |  |  | ns |  |
| $t_{\text {W }} \mathrm{P}$ | Write Pulse | 200 |  |  | ns |  |
| twr | Write Recovery | 0 |  |  | ns |  |
| ${ }^{\mathrm{t}}$ DS | Output Disable Setup | 20 |  |  | ns |  |

## 2111A-4 (450 ns ACCESS TIME)

## 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 {R }}$ | Read Cycle | 450 |  |  | ns | $t_{r}, t_{f}=20 n s$ <br> Input Levels $=0.8 \mathrm{~V}$ or 2.0 V <br> Timing Reference $=1.5 \mathrm{~V}$ <br> Load $=1$ TTL Gate and $C_{L}=100 \mathrm{pF}$. |
| $t_{A}$ | Access Time |  |  | 450 | ns |  |
| ${ }^{\text {t }} \mathrm{CO}$ | Chip Enable To Output |  |  | 310 | ns |  |
| ${ }_{\text {tod }}$ | Output Disable To Output |  |  | 250 | ns |  |
| $\mathrm{t}_{\mathrm{DF}}{ }^{\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. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tw }}$ c | Write Cycle | 270 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{\mathrm{L}}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }_{\text {taw }}$ | Write Delay | 20 |  |  | ns |  |
| ${ }^{\text {t }}$ CW | Chip Enable To Write | 250 |  |  | ns |  |
| tow | Data Setup | 250 |  |  | ns |  |
| ${ }^{\text {t }}$ D ${ }_{\text {c }}$ | Data Hold | 0 |  |  | ns |  |
| twp | Write Pulse | 250 |  |  | ns |  |
| twr | Write Recovery | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ DS | Output Disable Setup | 20 |  |  | ns |  |

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 E}_{1}, \overline{C E}_{2}$, or $O D$, whichever occurs first.

## 2112A <br> 256 X 4 BIT STATIC RAM

| $2112 A-2$ | 250 ns Max. |
| :--- | :--- |
| $2112 A$ | 350 ns Max. |
| $2112 A-4$ | 450 ns Max. |

- Single +5 V Supply Voltage
- Directly TTL Compatible: All Inputs and Outputs
■ Static MOS: No Clocks or Refreshing Required
- Simple Memory Expansion: Chip Enable
Input


## Fully Decoded: On Chip Address Decode <br> ■ Inputs Protected: All Inputs Have Protection Against Static Charge <br> Low Cost Packaging: 16 Pin Plastic Dual In-Line Configuration <br> Low Power: Typically 150 mW <br> Three-State Output: OR-Tie Capability

The Intel® ${ }^{(2112 A}$ 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 2112A 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. A separate chip enable ( $\overline{\mathrm{CE}})$ lead allows easy selection of an individual package when outputs are OR-tied.

The Intel® ${ }^{\circledR}$ 2112A 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.


## 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. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{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 |  | 1 | 10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{1 / \mathrm{O}}=4.0 \mathrm{~V}$ |
| ILOL | 1/O Leakage Current |  | -1 | -10 | $\mu \mathrm{A}$ | Output Disabled, $\mathrm{V}_{1 / \mathrm{O}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Power Supply2112A, 2112A-4 <br> Current <br> 2112A-2 |  | 35 | 55 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}, \mathrm{I}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~mA} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| ${ }^{\text {cC2 }}$ | Power Supply Current |  |  | 60 | 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}$ |
| $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}$ |
| V OH | Output "High"2112A, 2112A-2 <br> Voltage$\quad 2112 \mathrm{~A}-4$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
|  |  | 2.4 |  |  | V | $\mathrm{IOH}=-150 \mu \mathrm{~A}$ |

## A.C. CHARACTERISTICS FOR 2112A-2

READ CYCLE $\quad 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. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 250 |  |  | ns | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns}$ |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time |  |  | 250 | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Enable To Output Time |  |  | 180 | ns | Timing Reference $=1.5 \mathrm{~V}$ Load $=1$ TTL Gate |
| ${ }^{\text {t }}$ CD | Chip Enable To Output Disable Time | 0 |  | 120 | ns |  |
| ${ }^{\text {toH }}$ | Previous Read Data Valid After Change of Address | 40 |  |  | ns | and $C_{L}=100 p F$. |

## READ CYCLE WAVEFORMS


[2]
CAPACITANCE $\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) $\mathrm{V}_{\mathrm{IN}}=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 |
| NOTES: |  |  |  |
| 1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage. <br> 2. This parameter is periodically sampled and is not $100 \%$ tested. |  |  |  |

## A.C. CHARACTERISTICS FOR 2112A-2 (Continued)

WRITE CYCLE \#1 $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tw }}$ W1 | Write Cycle | 200 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} . \end{aligned}$ |
| $\mathrm{t}_{\text {AW } 1}$ | Address To Write Setup Time | 20 |  |  | ns |  |
| $t_{\text {DW1 }}$ | Write Setup Time | 180 |  |  | ns |  |
| tWP1 | Write Pulse Width | 180 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CS} 1$ | Chip Enable Setup Time | 0 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CH} 1$ | Chip Enable Hold Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ WR1 | Write Recovery Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ DH1 | Data Hold Time | 0 |  |  | ns |  |
| ${ }^{\text {c }} \mathrm{CW} 1$ | Chip Enable To Write Setup Time | 180 |  |  | ns |  |

WRITE CYCLE \#2 $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {t }}$ WC2 | Write Cycle | 320 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} . \end{aligned}$ |
| $\mathrm{t}_{\text {AW } 2}$ | Address To Write Setup Time | 20 |  |  | ns |  |
| $t_{\text {DW2 }}$ | Write Setup Time | 180 |  |  | ns |  |
| tWD2 | Write To Output Disable Time | 120 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CS} 2$ | Chip Enable Setup Time | 0 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CH} 2$ | Chip Enable Hold Time | 0 |  |  | ns |  |
| $t_{\text {WR2 }}$ | Write Recovery Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ DH2 | Data Hold Time | 0 |  |  | ns |  |

## WRITE CYCLE WAVEFORMS

## WRITE CYCLE \#1



WRITE CYCLE \#2


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

## A.C. CHARACTERISTICS FOR 2112A

READ CYCLE $\quad 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{t}_{\mathrm{R}} \mathrm{C}$ | Read Cycle | 350 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{L}=100 \mathrm{pF} . \end{aligned}$ |
| $t_{A}$ | Access Time |  |  | 350 | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Enable To Output Time |  |  | 240 | ns |  |
| $\mathrm{t}_{\mathrm{CD}}$ | Chip Enable To Output Disable Time | 0 |  | 200 | ns |  |
| ${ }^{\text {toH }}$ | Previous Read Data Valid After Change of Address | 40 |  |  | ns |  |

WRITE CYCLE \#1 $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {tw }}$ C1 | Write Cycle | 270 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{L}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {t }}$ AW1 | Address To Write Setup Time | 20 |  |  | ns |  |
| ${ }_{\text {t }}$ WW1 | Write Setup Time | 250 |  |  | ns |  |
| ${ }_{\text {t }}$ P1 1 | Write Pulse Width | 250 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CS} 1$ | Chip Enable Setup Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ CH1 | Chip Enable Hold Time | 0 |  |  | ns |  |
| ${ }^{\text {twR1 }}$ | Write Recovery Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ DH1 | Data Hold Time | 0 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CW} 1$ | Chip Enable to Write Setup Time | 250 |  |  | ns |  |

WRITE CYCLE \#2 $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| twC2 | Write Cycle | 470 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {taw2 }}$ | Address To Write Setup Time | 20 |  |  | ns |  |
| tow2 | Write Setup Time | 250 |  |  | ns |  |
| ${ }^{\text {W WD2 }}$ | Write To Output Disable Time | 200 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CS} 2$ | Chip Enable Setup Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ CH2 | Chip Enable Hold Time | 0 |  |  | ns |  |
| ${ }^{\text {twR2 }}$ | Write Recovery Time | 0 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{H} 2$ | Data Hold Time | 0 |  |  | ns |  |

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

## A.C. CHARACTERISTICS FOR 2112A-4

READ CYCLE $\quad 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. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle | 450 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=2 \mathrm{nss} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{L}=100 \mathrm{pF} . \end{aligned}$ |
| $t_{\text {A }}$ | Access Time |  |  | 450 | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Enable To Output Time |  |  | 310 | ns |  |
| ${ }^{\text {t }}$ CD | Chip Enable To Output Disable Time | 0 |  | 260 | ns |  |
| ${ }^{\text {toh }}$ | Previous Read Data Valid After Change of Address | 40 |  |  | ns |  |

WRITE CYCLE \#1 $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {twC1 }}$ | Write Cycle | 320 |  |  | ns | $\begin{aligned} & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=20 \mathrm{~ns} \\ & \text { Input Levels }=0.8 \mathrm{~V} \text { or } 2.0 \mathrm{~V} \\ & \text { Timing Reference }=1.5 \mathrm{~V} \\ & \text { Load }=1 \mathrm{TTL} \text { Gate } \\ & \quad \text { and } C_{L}=100 \mathrm{pF} . \end{aligned}$ |
| ${ }^{\text {taw }} 1$ | Address To Write Setup Time | 20 |  |  | ns |  |
| tow1 | Write Setup Time | 300 |  |  | ns |  |
| ${ }^{\text {t WP1 }}$ | Write Pulse Width | 300 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CS} 1$ | Chip Enable Setup Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ CH1 | Chip Enable Hold Time | 0 |  |  | ns |  |
| tWR1 | Write Recovery Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}$ D ${ }^{\text {1 }}$ | Data Hold Time | 0 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{CW} 1$ | Chip Enable to Write Setup Time | 300 |  |  | ns |  |

WRITE CYCLE \#2 $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{WC} 2}$ | Write Cycle | 580 |  |  | ns | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=2$ 20ns |
| Input Levels $=0.8 \mathrm{~V}$ or 2.0V |  |  |  |  |  |  |

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

2114
1024 X 4 BIT STATIC RAM

|  | $2114-2$ | $2114-3$ | 2114 | 2114 L 2 | 2114 L 3 | 2114 L |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 200 | 300 | 450 | 200 | 300 | 450 |
| Max. Power Dissipation (mw) | 525 | 525 | 525 | 370 | 370 | 370 |

## High Density 18 Pin Package <br> ■ Identical Cycle and Access Times <br> ■ Single +5 V Supply <br> ■ No Clock or Timing Strobe Required <br> ■ 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


#### Abstract

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{\mathrm{CS}}$ ) 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 (+5V) |
| :--- | :--- | :--- |
| $\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


## 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 | 5 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 | 2114-2, 2114-3, 2114 |  |  | 2114L2, 2114L3, 2114L |  |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. | Min. | Typ.[1] | Max. |  |  |
| $I_{\text {LI }}$ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0$ to 5.25 V |
| \| 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 {cCl }}$ | Power Supply Current |  | 80 | 95 |  |  | 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 |  |  | 100 |  |  | 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.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.0 | -1.4 |  | -1.0 | -1.4 |  | mA | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| los ${ }^{[2]}$ | Output Short Circuit Current |  |  | 40 |  |  | 40 | mA |  |

NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
2. Duration not to exceed 30 seconds.

## CAPACITANCE

| $T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ |  |  |  |  |
| :--- | :--- | :---: | :---: | :--- |
| SYMBOL | TEST | MAX | UNIT | CONDITIONS |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{1 / \mathrm{O}}=\mathrm{OV}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{\mathrm{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 Load . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 TTL Gate and CL $=100$ pF
TEST NOTE: This circuit employs a self starting oscillator and a charge pump which require a certain amount of time after POWER ON to start functioning properly. This 2114 circuit is conservatively specified as requiring $500 \mu$ sec after $V_{C C}$ reaches its specified limits (4.75V).
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 | 2114-2, 2114L2 | 2114-3, 2114L3 | 2114, 2114L | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle Time | 200 | 300 | 450 | ns |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time | 200 | 300 | 450 | ns |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Selection to Output Valid | 70 | 100 | 120 | ns |
| ${ }^{\text {c }}$ CX | Chip Selection to Output Active | 20 | 20 | 20 | ns |
| toto | Output 3-state from Deselection | 60 | 80 | 100 | ns |
| toha | Output Hold from Address Change | 50 | 50 | 50 | ns |

WRITE CYCLE [2]

| SYMBOL | PARAMETER | 2114-2, 2114L2 | 2114-3, 2114L3 | 2114, 2114L | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. Max. |  |
| twc | Write Cycle Time | 200 | 300 | 450 | ns |
| tw | Write Time | 120 | 150 | 200 | ns |
| twr | Write Release Time | 0 | 0 | 0 | ns |
| totw | Output 3-state from Write | 60 | 80 | 100 | ns |
| ${ }_{\text {t }}$ W | Data to Write Time Overlap | 120 | 150 | 200 | ns |
| $t_{\text {DH }}$ | 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{\mathrm{WE}}$.
2. A Write occurs during the overlap of a low $\overline{C S}$ and a low $\overline{W E}$.

## WAVEFORMS

## READ CYCLE ${ }^{(3)}$



NOTES:
(3) $\overline{W E}$ is high for a Read Cycle.
(4) If the $\overline{\mathrm{CS}}$ low transition occurs simultaneousiy with the $\overline{W E}$ low transition, the output buffers remain in a high impedance state.
(5) $\overline{\mathrm{WE}}$ must be high during all address transitions.

## WRITE CYCLE



## TYPICAL D.C. AND A.C. CHARACTERISTICS



NORMALIZED ACCESS TIME VS. OUTPUT LOAD CAPACITANCE



OUTPUT SOURCE CURRENT VS. OUTPUT VOLTAGE


OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE


2115A, 2125A FAMILY
HIGH SPEED 1K X 1 BIT STATIC RAM

|  | 2115 AL <br> $2125 A L$ | $2115 A$ <br> $2125 A$ | $2115 A L-2$ <br> $2125 A L-2$ | $2115 A-2$ <br> $2125 A-2$ |
| :--- | :---: | :---: | :---: | :---: |
| Max. $\mathrm{T}_{\mathrm{AA}}(\mathrm{ns})$ | 45 | 45 | 70 | 70 |
| Max. $\operatorname{ICC}(\mathrm{mA})$ | 75 | 125 | 75 | 125 |

## - HMOS Technology

## - Pin Compatible To 93415A

 (2115A) And 93425A (2125A)
## - Fan-Out Of 10 TTL (2115A Family) -- 16mA Output Sink Current

## - Low Operating Power Dissipation --Max. 0.39mW/Bit (2115AL, 2125AL)

- TTL Inputs And Outputs
- Single +5V Supply
- Uncommitted Collector (2115A) And Three-State (2125A) Output
- Standard 16-Pin Dual In-Line Package

The Intel ${ }^{\circledR} 2115 \mathrm{~A}$ and 2125 A families are high-speed, 1024 words by 1 bit random access memories. Both open collector (2115A) and three-state output (2125A) are available. The 2115A and 2125A use fully DC stable (static) circuitry throughout - in both the array and the decoding and, therefore, require no clocks or refreshing to operate. The data is read out nondestructively and has the same polarity as the input data.
The $2115 \mathrm{AL} / 2125 \mathrm{AL}$ at 45 ns maximum access time and the $2115 \mathrm{AL}-2 / 2125 \mathrm{AL}-2$ at 70 ns maximum access time are fully compatible with the industry-produced 1 K bipolar RAMs, yet offer a $50 \%$ reduction in power of their bipolar equivalents. The power dissipation of the 2115AL/2125AL and 2115AL-2/2125AL-2 is 394 mW maximum as compared to 814 mW maximum of their bipolar equivalents. For systems already designed for 1 K bipolar RAMs, the 2115A/2125A and the $2115 \mathrm{~A}-2 / 2125 \mathrm{~A}-2$ at 45 ns and 70 ns maximum access times, respectively, offer complete compatibility with a $20 \%$ reduction in maximum power dissipation.
The devices are directly TTL compatible in all respects: inputs, outputs, and a single +5 V supply. A separate select ( $\overline{\mathrm{CS})}$ lead allows easy selection of an individual package when outputs are OR-tied.
The 2115A and 2125A families are fabricated with HMOS, Intel's High Speed N-channel MOS Silicon Gate Technology.


| PIN NAMES |
| :---: |
| CS CHIP SELECT <br> A TOA ADDRESS INPUTS <br> WE WRITE ENABLE <br> DIN DATA INPUT <br> $D_{\text {OUT }}$ DATA OUTPUT |

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . $-10^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output or Supply Voltages. . . . . . . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . . . . . . . -0.5 V to +5.5 V
D.C. Output Current . . . . . . . . . . . . . . . . . . . . . 20 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 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. CHARACTERISTICS ${ }^{[1,2]}$

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$

| Symbol | Test | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vol1 | 2115A Family Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | 2125A Family Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=7 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.1 |  |  | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.8 | V |  |
| $I_{\text {IL }}$ | Input Low Current |  | -0.1 | -40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max., $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |
| $I_{1 H}$ | Input High Current |  | 0.1 | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max., $\mathrm{V}_{\text {IN }}=4.5 \mathrm{~V}$ |
| ICEX | 2115A Family Output Leakage Current |  | 0.1 | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max., $\mathrm{V}_{\text {OUT }}=4.5 \mathrm{~V}$ |
| $\left\|I_{\text {OFF }}\right\|$ | 2125A Family Output Current (High Z) |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max., $\mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V} / 2.4 \mathrm{~V}$ |
| Ios ${ }^{[3]}$ | 2125A Family Current Short Circuit to Ground |  |  | -100 | mA | $V_{C C}=$ Max |
| $\mathrm{V}_{\mathrm{OH}}$ | Family Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ |
| ICC | $\begin{aligned} & \text { Power Supply Current: } \\ & \text { ICC1: } 2115 \mathrm{AL}, 2115 \mathrm{AL}-2,2125 \mathrm{AL}, \\ & \hline 2125 \mathrm{AL}-2 \\ & \hline \mathrm{ICC2}: 2115 \mathrm{~A}, 2115 \mathrm{~A}-2,2125 \mathrm{~A}, 2125 \mathrm{~A}-2 \end{aligned}$ |  | 60 100 | 75 <br> 125 | mA | All Inputs Grounded, Output Open |

## NOTES:

1. The operating ambient temperature ranges are guaranteed with transverse air flow exceeding 400 linear feet per minute. Typical thermal resistance values of the package at maximum temperature are:
$\theta \mathrm{JA}\left(@ 400\right.$ fPM air flow) $=45^{\circ} \mathrm{C} / \mathrm{W}$
$\theta \mathrm{JA}($ still air $)=60^{\circ} \mathrm{C} / \mathrm{W}$
$\theta \mathrm{JC}=25^{\circ} \mathrm{C} / \mathrm{W}$
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, and maximum loading.
3. Duration of short circuit current should not exceed 1 second.

2115A FAMILY A.C. CHARACTERISTICS ${ }^{[1,2]} V_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$
READ CYCLE

| Symbol | Test | 2115AL Limits Min. Typ. Max. | 2115A Limits Min. Typ. Max. | 2115AL-2 Limits Min. Typ. Max. | 2115A-2 Limits Min. Typ. Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {Acs }}$ | Chip Select Time | $\begin{array}{llll}5 & 15 & 30\end{array}$ | $\begin{array}{lll}5 & 15 & 30\end{array}$ | $5 \quad 15 \quad 30$ | $\begin{array}{lll}5 & 15 & 40\end{array}$ | ns |
| $\mathrm{t}_{\text {RCS }}$ | Chip Select Recovery Time | $10 \quad 30$ | $10 \quad 30$ | 1030 | $10 \quad 40$ | ns |
| ${ }^{\text {t }}$ A | Address Access Time | $30 \quad 45$ | $30 \quad 45$ | $40 \quad 70$ | $40 \quad 70$ | ns |
| $\mathrm{toH}^{\text {O}}$ | Previous Read Data Valid After Change of Address | 10 | 10 | 10 | 10 | ns |

WRITE CYCLE

| Symbol | Test | Min. Typ. Max. | Min. Typ. Max. | Min. Typ. Max. | Min. Typ. Max. | Units |  |  |  |  |
| :--- | :--- | ---: | ---: | ---: | ---: | ---: | ---: | ---: | :--- | :--- |
| $t_{\text {WS }}$ | Write Enable Time | 10 | 25 | 10 | 30 | 10 | 25 |  | 10 | 40 |

## A.C. TEST CONDITIONS



READ CYCLE


PROPAGATION DELAY FROM CHIP SELECT


## WRITE CYCLE



2125A FAMILY A.C. CHARACTERISTICS ${ }^{[1,2]} \quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$
READ CYCLE

| Symbol | Test | 2125AL Limits Min. Typ. Max. |  | 2125A Limits Min. Typ. Max. |  |  | 2125AL-2 Limits Min. Typ. Max. |  |  | 2125A-2 Limits Min. Typ. Max. |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {t }}^{\text {ACS }}$ | Chip Select Time | 515 | 30 | 5 | 15 | 30 | 5 | 15 | 30 | 5 | 15 | 40 | ns |
| $\mathrm{t}_{\text {zRCS }}$ | Chip Select to HIGH Z | 10 | 30 |  | 10 | 30 |  | 10 | 30 |  | 10 | 40 | ns |
| ${ }^{\text {t }}$ A | Address Access Time | 30 | 45 |  | 30 | 45 |  | 40 | 70 |  | 40 | 70 | ns |
| $\mathrm{toH}^{\text {O}}$ | Previous Read Data Valid After Change of Address | 10 |  | 10 |  |  | 10 |  |  | 10 |  |  | ns |

## WRITE CYCLE

| Symbol | Test | Min. Typ. Max. | Min. Typ. Max. | Min. Typ. Max. | Min. Typ. Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tzws | Write Enable to HIGH Z | 1025 | 1030 | $10 \quad 25$ | $10 \quad 40$ | ns |
| $t_{\text {WR }}$ | Write Recovery Time | $0 \quad 25$ | $0 \quad 30$ | $0 \quad 25$ | $0 \quad 45$ | ns |
| tw | Write Pulse Width | 3020 | $30 \quad 10$ | $30 \quad 10$ | 5015 | ns |
| tWSD | Data Set-Up Time Prior to Write | $0-5$ | $5-5$ | $0-5$ | 5 -5 | ns |
| ${ }^{\text {W WHD }}$ | Data Hold Time After Write | 50 | 50 | 50 | 50 | ns |
| twSA | Address Set-Up Time | 50 | 50 | 50 | 150 | ns |
| $t_{\text {WHA }}$ | Address Hold Time | 50 | 50 | 50 | 50 | ns |
| $t_{\text {wscs }}$ | Chip Select Set-Up Time | 50 | 50 | 50 | 50 | ns |
| twhCS | Chip Select Hold Time | 50 | 50 | 50 | 50 | ns |

## A.C. TEST CONDITIONS



## READ CYCLE



PROPAGATION DELAY FROM CHIP SELECT


## WRITE CYCLE



## 2125A FAMILY WRITE ENABLE TO HIGH Z DELAY



LOAD 1


## 2125A FAMILY PROPAGATION DELAY FROM CHIP SELECT TO HIGH Z


(ALL ${ }^{\prime}{ }_{Z X X X}$ PARAMETERS ARE MEASURED AT A DELTA OF 0.5V FROM THE LOGIC LEVEL AND USING LOAD 1.)

2115A/2125A FAMILY CAPACITANCE* $V_{C C}=5 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| SYMBOL | TEST | $2115 A$ <br> LIMITS |  | $2125 A$ <br> LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. | TYP. | MAX. |  |  |
| $\mathrm{C}_{1}$ | Input Capacitance | 3 | 5 | 3 | 5 | pF | All Inputs $=0 \mathrm{~V}$, Output Open |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | 5 | 8 | 5 | 8 | pF | $\overline{\mathrm{CS}}=5 \mathrm{~V}$, All Other Inputs $=0 \mathrm{~V}$, <br> Output Open |

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

## TYPICAL CHARACTERISTICS



# 2115H, 2125H FAMILY HIGH SPEED 1K x 1 BIT STATIC RAM 

## HMOS II Technology

25-35ns Maximum Access Time
125mA Maximum ICC
Pin Compatible to 93415A (2115H) and 93425A (2125H)

TTL Inputs and Outputs
Single $+5 V$ Supply
Uncommitted Collector (2115H) and Three-State (2125H) Output
Standard 16-Pin Dual In-Line Package

The Intel ${ }^{\circledR} 2115 \mathrm{H}$ and 2125 H families are high-speed, 1024 words by 1 bit random access memories. Both open collector $(2115 \mathrm{H})$, and three-state output ( 2125 H ) are available. The 2115 H and 2125 H use fully DC stable (static) circuitry throughout - in both the array and the decoding and, therefore, require no clocks or refreshing to operate. The data is read out non-destructively and has the same polarity as the input data.
The 2115 H and 2125 H families are fully compatible with 1 K Bipolar Static RAMs yet offer significant reductions in power The devices are directly TTL compatible in all respects: inputs, outputs, and a single +5 V supply. A separate select ( $\overline{\mathrm{CS}}$ ) lead allows easy selection of an individual package when outputs are OR-tied.
The 2115 H and 2125 H families are fabricated with Intel's N-channel HMOS II Silicon Gate Technology.


2117 FAMILY 16,384 x 1 BIT DYNAMIC RAM

|  | $2117-2$ | $2117-3$ | $2117-4$ |
| :--- | :---: | :---: | :---: |
| Maximum Access Time (ns) | 150 | 200 | 250 |
| Read, Write Cycle (ns) | 320 | 375 | 410 |
| Read-Modify-Write Cycle (ns) | 330 | 375 | 475 |

■ Industry Standard 16-Pin Configuration
■ $\pm 10 \%$ Tolerance on All Power Supplies: $+12 \mathrm{~V},+5 \mathrm{~V},-5 \mathrm{~V}$
■ Low Power: 462mW Max. Operating, 20mW Max. Standby

- Low IDD Current Transients
- All Inputs, Including Clocks, TTL Compatible


## ■ Non-Latched Output is Three-State, TTL Compatible <br> - $\overline{R A S}$ Only Retresh <br> - 128 Refresh Cycles Required Every 2ms <br> - Page Mode Capability <br> - $\overline{C A S}$ Controlled Output Allows Hidden Refresh

The Intel® 2117 is a 16,384 word by 1 -bit Dynamic MOS RAM fabricated with Intel's standard two layer polysilicon NMOS technology - a production proven process for high performance, high reliability, and high storage density.
The 2117 uses a single transistor dynamic storage cell and advanced dynamic circuitry to achieve high speed with low power dissipation. The circuit design minimizes the current transients typical of dynamic RAM operation. These low current transients and $\pm 10 \%$ tolerance on all power supplies contribute to the high noise immunity of the 2117 in a system environment.

Multiplexing the 14 address bits into the 7 address input pins allows the 2117 to be packaged in the industry standard 16-pin DIP. The two 7-bit address words are latched into the 2117 by the two TTL clocks, Row Address Strobe (RAS) and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ). Non-critical timing requirements for $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ allow use of the address multiplexing technique while maintaining high performance.
The 2117 three-state output is controlled by $\overline{\mathrm{CAS}}$, independent of $\overline{\mathrm{RAS}}$. After a valid read or read-modify-write cycle, data is latched on the output by holding $\overline{\mathrm{CAS}}$ low. The data out pin is returned to the high impedance state by returning $\overline{\mathrm{CAS}}$ to a high state. The 2117 hidden refresh feature allows $\overline{C A S}$ to be held low to maintain latched data while $\overline{R A S}$ is used to execute $\overline{\mathrm{RAS}}$-only refresh cycles.
The single transistor storage cell requires refreshing for data retention. Refreshing is accomplished by performing $\overline{\text { RAS }}-$ only refresh cycles, hidden refresh cycles, or normal read or write cycles on the 128 address combinations of $A_{0}$ through $A_{6}$ during a 2 ms period. A write cycle will refresh stored data on all bits of the selected row except the bit which is addressed.


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots \quad-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}$
(Vss-VBB $\geq 4 \mathrm{~V}$ ) .......................... -0.3 V to +20 V
Data Out Current ................................... 50mA
Power Dissipation .................................. 1.0W

## *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 ${ }^{[1,2]}$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{C}}=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 | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[3]}$ | Max. |  |  |  |
| \|ILI| | Input Load Current (any input) |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ to 7.0V, $\mathrm{V}_{\text {BB }}=-5.0 \mathrm{~V}$ |  |
| \|lıO| | Output Leakage Current for High Impedance State |  | 0.1 | 10 | $\mu \mathrm{A}$ | Chip Deselected: $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IH}}$, Vout $=0$ to 5.5 V |  |
| IDD1 | VDD Supply Current, Standby |  |  | 1.5 | mA | $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{\mathrm{IH}}$ | 4 |
| IbB1 | VBB Supply Current, Standby |  | 1.0 | 50 | $\mu \mathrm{A}$ |  |  |
| Icc1 | VCC Supply Current, Output Deselected |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\overline{\text { CAS }}$ at $\mathrm{V}_{\text {IH }}$ | 5 |
| IDD2 | VDD Supply Current, Operating |  |  | 35 | mA | $2117-2, \mathrm{t}_{\text {RC }}=375 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=150 \mathrm{~ns}$ | 4,6 |
|  |  |  |  | 35 | mA | $2117-3, \mathrm{t}_{\text {RC }}=375 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=200 \mathrm{~ns}$ | 4 |
|  |  |  |  | 33 | mA | 2117-4, $\mathrm{t}_{\mathrm{RC}}=410 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=250 \mathrm{~ns}$ | 4 |
| IBB2 | $V_{B B}$ Supply Current, Operating, RAS-Only Refresh, Page Mode |  | 150 | 300 | $\mu \mathrm{A}$ | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |  |
| IDD3 | VDD Supply Current, $\overline{R A S}$-Only Refresh |  |  | 27 | mA | $2117-2, t_{\text {RC }}=375 \mathrm{~ns}, \mathrm{t}_{\mathrm{RAS}}=150 \mathrm{~ns}$ | 4,6 |
|  |  |  |  | 27 | mA | $2117-3, \mathrm{t}_{\text {RC }}=375 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=200 \mathrm{~ns}$ | 4 |
|  |  |  |  | 26 | mA | 2117-4, $\mathrm{t}_{\mathrm{RC}}=410 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=250 \mathrm{~ns}$ | 4 |
| IDD5 | VDD Supply Current, Standby, Output Enabled |  | 1.5 | 3 | mA | $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\text {IL }}, \overline{\mathrm{RAS}}$ at $\mathrm{V}_{\text {IH }}$ |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (all inputs) | -1.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (all inputs) | 2.4 |  | 6.0 | V |  |  |
| Vol | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ | 4 |
| VOH | Output High Voltage | 2.4 |  |  | V | $1 \mathrm{OH}=-5 \mathrm{~mA}$ | 4 |

NOTES:

1. All voltages referenced to $V_{S S}$.
2. No power supply sequencing is required. However, $V_{D D}, V_{C C}$ and $V_{S S}$ should never be more negative than -0.3 V with respect to $\mathrm{V}_{B B}$ as required by the absolute maximum ratings.
3. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. See the Typical Characteristics Section for values of this parameter under alternate conditions.
5. Icc is dependent on output loading when the device output is selected. $V_{c c}$ is connected to the output buffer only. Vcc may be reduced to VSS without affecting refresh operation or maintenance of internal device data.
6. For the $2117-2$ at $t_{R C}=320 \mathrm{~ns}$, $t_{\text {RAS }}=150 \mathrm{~ns}$, $\mathrm{IDD}_{\mathrm{D} 2}$ max. is 45 mA and $\mathrm{IDD}_{\mathrm{D}} \mathrm{max}$. is 31 mA .

## TYPICAL SUPPLY CURRENT WAVEFORMS



Typical power supply current waveforms vs. time are shown for the RAS/CAS timings of Read/Write, Read/ Write (Long $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ ), and $\overline{\mathrm{RAS}}$-only refresh cycles. IDD and IBB current transients at the $\overline{R A S}$ and $\overline{C A S}$ edges require adequate decoupling of these supplies. Decoupling recommendations are provided in the Applications section.

The effects of cycle time, VDD supply voltage and ambient temperature on the IDD current are shown in graphs included in the Typical Characteristics Section. Each family of curves for IDD1, IDD2, and IDD3 is related by a common point at $V_{D D}=12.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$ for two given $t_{\text {RAS }}$ pulse widths. The typical IDD current for a given condition of cycle time, VDD and TA can be determined by combining the effects of the appropriate family of curves.

CAPACITANCE ${ }^{[1]}$
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=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 specified.

| Symbol | Parameter | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Address, Data In | 3 | 5 | pF |
| $\mathrm{C}_{12}$ | $\overline{\mathrm{RAS}}$ Capacitance, $\overline{\mathrm{WE}}$ Capacitance | 4 | 7 | pF |
| $\mathrm{C}_{13}$ | $\overline{\mathrm{CAS}}$ Capacitance | 6 | 10 | pF |
| $\mathrm{C}_{0}$ | Data Output Capacitance | 4 | 7 | pF |

NOTES:

1. Capacitance measured with Boonton Meter or effective capacitance calculated from the equation: $C=\frac{I \Delta t}{\Delta V}$ with $\Delta V$ equal to 3 volts and power supplies at nominal levels.

## A.C. CHARACTERISTICS

$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}_{S S}=0 \mathrm{~V}$, unless otherwise noted.
READ, WRITE, READ-MODIFY-WRITE AND REFRESH CYCLES

| Symbol | Parameter | 2117-2 |  | 2117-3 |  | 2117-4 |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| trac | Access Time From $\overline{\mathrm{RAS}}$ |  | 150 |  | 200 |  | 250 | ns | 4,5 |
| tcac | Access Time From $\overline{\mathrm{CAS}}$ |  | 100 |  | 135 |  | 165 | ns | 4,5,6 |
| tref | Time Between Refresh |  | 2 |  | 2 |  | 2 | ms |  |
| trp | $\overline{\text { RAS Precharge Time }}$ | 100 |  | 120 |  | 150 |  | ns |  |
| tcPN | $\overline{\text { CAS Precharge Time(non-page cycles) }}$ | 25 |  | 25 |  | 25 |  | ns |  |
| tCRP | $\overline{\text { CAS }}$ to RAS Precharge Time | -20 |  | -20 |  | -20 |  | ns |  |
| $t_{\text {RCD }}$ | $\overline{\text { RAS }}$ to CAS Delay Time | 20 | 50 | 25 | 65 | 35 | 85 | ns | 7 |
| trsh | $\overline{\text { RAS }}$ Hold Time | 100 |  | 135 |  | 165 |  | ns |  |
| tcsi | $\overline{\text { CAS }}$ Hold Time | 150 |  | 200 |  | 250 |  | ns |  |
| task | Row Address Set-Up Time | 0 |  | 0 |  | 0 |  | ns |  |
| trah | Row Address Hold Time | 20 |  | 25 |  | 35 |  | ns |  |
| tasc | Column Address Set-Up Time | -10 |  | -10 |  | -10 |  | ns |  |
| tCAH | Column Address Hold Time | 45 |  | 55 |  | 75 |  | ns |  |
| $t_{\text {AR }}$ | Column Address Hold Time, to $\overline{\text { RAS }}$ | 95 |  | 120 |  | 160 |  | ns |  |
| $t T$ | Transition Time (Rise and Fall) | 3 | 50 | 3 | 50 | 3 | 50 | ns | 8 |
| toff | Output Buffer Turn Off Delay | 0 | 50 | 0 | 60 | 0 | 70 | ns |  |

READ AND REFRESH CYCLES

| tRC | Random Read Cycle Time | 320 | 375 | 410 | ns |  |  |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| tras | $\overline{\text { RAS Pulse Width }}$ | $150 \quad 10000$ | 200 | 10000 | 250 | 10000 | ns |

## WRITE CYCLE

| $t_{\text {R }}$ | Random Write Cycle Time | 320 |  | 375 |  | 410 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tras | $\overline{\text { RAS Pulse Width }}$ | 150 | 10000 | 200 | 10000 | 250 | 10000 | ns |  |
| tcas | $\overline{\text { CAS Pulse Width }}$ | 100 | 10000 | 135 | 10000 | 165 | 10000 | ns |  |
| twCs | Write Command Set-Up Time | -20 |  | -20 |  | -20 |  | ns | 9 |
| twch | Write Command Hold Time | 45 |  | 55 |  | 75 |  | ns |  |
| twCR | Write Command Hold Time, to $\overline{\text { RAS }}$ | 95 |  | 120 |  | 160 |  | ns |  |
| twp | Write Command Pulse Width | 45 |  | 55 |  | 75 |  | ns |  |
| trwL | Write Command to $\overline{\text { RAS }}$ Lead Time | 60 |  | 80 |  | 100 |  | ns |  |
| tcw | Write Command to $\overline{\text { CAS }}$ Lead Time | 60 |  | 80 |  | 100 |  | ns |  |
| tos | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | ns |  |
| tDH | Data-In Hold Time | 45 |  | 55 |  | 75 |  | ns |  |
| tDHR | Data-In Hold Time, to $\overline{\text { RAS }}$ | 95 |  | 120 |  | 160 |  | ns |  |

## READ-MODIFY-WRITE CYCLE

| trwc | Read-Modify-Write Cycle Time | 330 |  | 375 |  | 475 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| trRw | RMW Cycle $\overline{\mathrm{RAS}}$ Pulse Width | 185 | 10000 | 245 | 10000 | 305 | 10000 | ns |  |
| tCRW | RMW Cycle CAS Pulse Width | 135 | 10000 | 180 | 10000 | 230 | 10000 | ns |  |
| trwo | $\overline{\text { RAS }}$ to WE Delay | 120 |  | 160 |  | 200 |  | ns | 9 |
| tewo | $\overline{\text { CAS }}$ to WE Delay | 70 |  | 95 |  | 125 |  | ns | 9 |

Notes: See following page for A.C. Characteristics Notes.

## WAVEFORMS



NOTES: 1,2. $\mathrm{V}_{\text {IH MIN }}$ AND $\mathrm{V}_{\mathrm{IL}}$ mAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $V_{\text {OH MIN }}$ AND $V_{O L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT .
5. toff IS MEASURED TO IOUT $\leqslant\left|\|_{\text {LO }}\right|$.
6. $t_{D S}$ AND toh ARE REFERENCED TO CAS OR WE, WHICHEVER OCCURS LAST.
7. $\mathrm{t}_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF CAS OR RAS, WHICHEVER OCCURS FIRST.
8. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{R A S} / \overline{C A S}$ CYCLES PRECEEDED BY A CASONLY CYCLE (i.e., FOR SYSTEMS WHERE $\overline{C A S}$ HAS NOT BEEN DECODED WITH $\overline{\mathrm{RAS}}$ ).

## A.C. CHARACTERISTICS NOTES (From Previous Page)

1. All voltages referenced to $V_{\text {ss }}$.
2. Eight cycles are required after power-up or prolonged periods (greater than 2 ms ) of $\overline{\text { RAS }}$ inactivity before proper device operation is achieved. Any 8 cycles which perform refresh are adequate for this purpose.
3. A.C. Characteristics assume $\mathrm{t}_{\mathrm{T}}=5 \mathrm{~ns}$.
4. Assume that $t_{R C D} \leq t_{R C D}$ (max.). If $t_{R C D}$ is greater than $t_{R C D}$ (max.) then trac will increase by the amount that trCD exceeds $t_{\text {RCD }}$ (max.).
5. Load $=2$ TTL loads and 100 pF .
6. Assumes $t_{R C D} \geq t_{R C D}$ (max.).
7. $\mathrm{t}_{R C D}$ (max.) is specified as a reference point only; if trCD is less than tRCD (max.) access time is tRAC, if tRCD is greater than tRCD (max.) access time is trCD + tcAC.
8. $\mathrm{t}_{\mathrm{T}}$ is measured between $\mathrm{V}_{\mathrm{IH}}$ ( min .) and $\mathrm{V}_{\mathrm{IL}}$ (max.).
9. twCs, towd and trwD are specified as reference points only. If twcs $\geq$ twcs (min.) the cycle is an early write cycle and the data out pin will remain high impedance throughout the entire cycle. If $\mathrm{tcwD} \geq \mathrm{tcwD}$ ( min .) and $\mathrm{tRWD} \geq \mathrm{t}_{\mathrm{RWD}}$ ( min .), the cycle is a read-modify-write cycle and the data out will contain the data read from the selected address. If neither of the above conditions is satisfied, the condition of the data out is indeterminate.

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE



## $\overline{\text { RAS }}$-ONLY REFRESH CYCLE



## HIDDEN REFRESH CYCLE



NOTES: $1,2 . V_{I H}$ MIN $A N D V_{I L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $V_{\text {OH MIN }}$ AND $V_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF D $D_{\text {OUT }}$.
5. toff IS MEASURED TO IOUT \& \|lol.
6. $t_{D S}$ AND $t_{D H}$ ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. $\mathrm{t}_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF CAS OR $\overline{\text { RAS }}$, WHICHEVER OCCURS FIRST.
8. tcrp REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A CASONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## TYPICAL CHARACTERISTICS ${ }^{[1]}$

GRAPH 1
TYPICAL ACCESS TIME ${ }^{\text {traC }}$ (NORMALIZED) VS. $V_{\text {DD }}$


GRAPH 4
TYPICAL ACCESS TIME
trac (NORMALIZED) VS. AMBIENT TEMPERATURE


GRAPH 7
TYPICAL OPERATING CURRENT IDD2 VS. trC


GRAPH 2
TYPICAL ACCESS TIME $t_{\text {RAC }}$ (NORMALIZED) VS. VBB

$\mathrm{V}_{\mathrm{BB}}$ - SUPPLY VOLTAGE (VOLTS)

GRAPH 5
TYPICAL STANDBY CURRENT $I^{D D 1}$ VS. VDD


GRAPH 8
TYPICAL OPERATING CURRENT IDD2 VS. VDD


GRAPH 3
TYPICAL ACCESS TIME trAC (NORMALIZED) VS. VCC


GRAPH 6
TYPICAL STANDBY CURRENT IDD1 VS. AMBIENT TEMPERATURE


NOTES: See following page for Typical Characteristics Notes.

TYPICAL CHARACTERISTICS ${ }^{[1]}$

GRAPH 10
TYPICAL $\overline{R A S}$ ONLY REFRESH CURRENT IDD3 VS. tRC


GRAPH 13
TYPICAL PAGE MODE CURRENT IDD4 VS. tPC


GRAPH 16
TYPICAL OUTPUT SOURCE CURRENT IOH VS. OUTPUT VOLTAGE VOH

$\mathrm{V}_{\text {OH }}$ - OUTPUT VOLTAGE (VOLTS)

GRAPH 11
TYPICAL $\overline{R A S}$ ONLY REFRESH CURRENT $I^{\prime} D 3^{V}$ V. VDD


GRAPH 14
TYPICAL PAGE MODE CURRENT IDD4 VS. VDD


VDD - SUPPLY VOLTAGE (VOLTS)

GRAPH 17
TYPICAL OUTPUT SINK CURRENT $I_{O L}$ VS. OUTPUT VOLTAGE VOL


VoL - OUTPUT VOLTAGE (VOLTS)

GRAPH 12
TYPICAL $\overline{R A S}$ ONLY REFRESH CURRENT IDD3 VS. AMBIENT TEMPERATURE


GRAPH 15
TYPICAL PAGE MODE CURRENT IDD4 VS. AMBIENT TEMPERATURE


NOTES:

1. The cycle time, $V_{D D}$ supply voltage, and ambient temperature dependence of IDD1, IDD2, IDD3 and IDD4 is shown in related graphs. Common points of related curves are indicated:

- IDD1 @ $V_{D D}=13.2 \mathrm{~V}, T_{A}=0^{\circ} \mathrm{C}$
- IDD2 or IDD3 @ $t_{R A S}=200 \mathrm{~ns}, \mathrm{t}_{\mathrm{RC}}=$ $375 \mathrm{~ns}, \mathrm{~V}_{\mathrm{DD}}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
A IDD2 or IDD3 @ tRAS $=500 \mathrm{~ns}, \mathrm{t}_{\mathrm{RC}}=$ $750 \mathrm{~ns}, V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\square I_{D D 4}{ }^{\text {@ }}{ }^{\mathrm{t}} \mathrm{CAS}=135 \mathrm{~ns}, \mathrm{t}_{\mathrm{P}}=225 \mathrm{~ns}$, $V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\triangle I_{D D 4}$ @ $\mathrm{t}_{\mathrm{CAS}}=350 \mathrm{~ns}, \mathrm{tPC}=500 \mathrm{~ns}$, $V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
The typical IDD current for a given combination of cycle time, $V_{D D}$ supply voltage and ambient temperature may be determined by combining the effects of the appropriate family of curves.


## D.C. AND A.C. CHARACTERISTICS, PAGE MODE

$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} S=0 \mathrm{~V}$, unless otherwise noted.
For Page Mode Operation order 2117-2 S6053, 2117-3 S6054, or 2117-4 S6055.

| Symbol | Parameter | $\begin{aligned} & 2117-2 \\ & \mathrm{~S} 6053 \end{aligned}$ |  | $\begin{aligned} & \text { 2117-3 } \\ & \text { S6054 } \end{aligned}$ |  | $\begin{aligned} & 2117-4 \\ & \mathrm{~S} 6055 \end{aligned}$ |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| tpC | Page Mode Read or Write Cycle | 170 |  | 225 |  | 275 |  | ns |  |
| tPCM | Page Mode Read Modify Write | 205 |  | 270 |  | 340 |  | ns |  |
| tcp | $\overline{\text { CAS Precharge Time, Page Cycle }}$ | 60 |  | 80 |  | 100 |  | ns |  |
| trpm | $\overline{\text { RAS }}$ Pulse Width, Page Mode | 150 | 10,000 | 200 | 10,000 | 250 | 10,000 | ns |  |
| tcas | $\overline{\text { CAS Pulse Width }}$ | 100 | 10,000 | 135 | 10,000 | 165 | 10,000 | ns |  |
| IDD4 | VDd Supply Current Page Mode, Minimum tpc, Minimum tcas |  | 38 |  | 30 |  | 26 | mA | 9 |

## WAVEFORMS

## PAGE MODE READ CYCLE



3,4. $V_{\text {OH min }}$ AND $V_{\text {OL max }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF Dout.
5. toff IS MEASURED TO Iout \& HLOI.
6. $t_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF $\overline{\text { CAS OR }} \overline{\text { RAS }}$, WHICHEVER OCCURS FIRST.
7. ALL VOLTAGES REFERENCED TO VSS.
8. AC CHARACTERISTIC ASSUME TT $^{2}=5 n s$.
9. SEE THE TYPICAL CHARACTERISTICS SECTION FOR VALUES OF THIS PARAMETER UNDER ALTERNATE CONDITIONS.
10. tcRp REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\text { RAS/CAS CYCLES PRECEEDED BY A CAS- }}$ ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).
11. ALL PREVIOUSLY SPECIFIED A.C. AND D.C. CHARACTERISTICS ARE APPLICABLE TO THEIR RESPECTIVE PAGE MODE DEVICE (i.e., 2117.3, S6054 WILL OPERATE AS A 2117.3).

PAGE MODE WRITE CYCLE


PAGE MODE READ-MODIFY-WRITE CYCLE


NOTES: 1,2. $V_{I H \text { MIN }}$ AND $V_{I L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS
3,4. $V_{\text {OH MIN }}$ AND $V_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF $D_{\text {OUT }}$.
5. TOFF IS MEASURED TO Iout $\leqslant|\mathrm{LLO}|$.
6. $\mathrm{t}_{\mathrm{DS}}$ AND t $_{\mathrm{DH}}$ ARE REFERENCED TO $\overline{\mathrm{CAS}}$ OR $\overline{\text { WE, WHICHEVER OCCURS LAST. }}$
7. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\text { RAS/ } / \overline{C A S}}$ CYCLES PRECEEDED BY A $\overline{C A S}-$ ONLY CYCLE (..e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## APPLICATIONS

## READ CYCLE

A Read cycle is performed by maintaining Write Enable ( $\overline{\mathrm{WE}}$ ) high during a $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ operation. The output pin of a selected device will remain in a high impedance state until valid data appears at the output at access time.
Device access time, $t_{A C C}$, is the longer of the two calculated intervals:

1. $t_{A C C}=t_{R A C} O R 2 . t_{A C C}=t_{R C D}+t_{C A C}$

Access time from $\overline{R A S}, t_{R A C}$, and access time from $\overline{C A S}$, tcac, are device parameters. Row to column address strobe delay time, thcD, are system dependent timing parameters. For example, substituting the device parameters of the 2117-3 yields:

$$
\begin{aligned}
& \text { 3. } t_{A C C}=t_{R A C}=200 \mathrm{nsec} \text { for } 25 \mathrm{nsec} \leq \operatorname{tRCD} \leq 65 \mathrm{nsec} \\
& \text { OR } \\
& \text { 4. } t_{A C C}=t_{R C D}+t_{C A C}=t_{R C D}+135 \text { for } t_{R C D}>65 \mathrm{nsec}
\end{aligned}
$$

Note that if $25 \mathrm{nsec} \leq \mathrm{t}_{\mathrm{RCD}} \leq 65 \mathrm{nsec}$ device access time is determined by equation 3 and is equal to trac. If $t_{\text {RCL }}$ $>65 \mathrm{nsec}$, access time is determined by equation 4. This 40 nsec interval (shown in the $t_{R C D}$ inequality in equation 3) in which the falling edge of $\overline{C A S}$ can occur without affecting access time is provided to allow for system timing skew in the generation of $\overline{\mathrm{CAS}}$.

## REFRESH CYCLES

Each of the 128 rows of the 2117 must be refreshed every 2 milliseconds to maintain data. Any memory cycle:

1. Read Cycle
2. Write Cycle (Early Write, Delayed Write or Read-Modify-Write)
3. $\overline{R A S}-$ only Cycle
refreshes the selected row as defined by the low order ( $\overline{\mathrm{RAS}}$ ) addresses. Any Write cycle, of course, may change the state of the selected cell. Using a Read, Write, or Read-Modify-Write cycle for refresh is not recommended for systems which utilize "wire-OR" outputs since output bus contention will occur.
A $\overline{R A S}$-only refresh cycle is the recommended technique for most applications to provide for data retention. A $\overline{\operatorname{RAS}}-$ only refresh cycle maintains the DOUT in the high impedance state with a typical power reduction of $20 \%$ over a Read or Write cycle.

## $\overline{R A S} / \overline{C A S}$ TIMING

$\overline{R A S}$ and $\overline{C A S}$ have minimum pulse widths as defined by tras and tcas respectively. These minimum pulse widths must be maintained for proper device operation and data integrity. A cycle, once begun by driving $\overline{\mathrm{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 can not begin until the minimum precharge time, trp, has been met.

## DATA OUTPUT OPERATION

The 2117 Data Output (DOUT), which has three-state capability, is controlled by $\overline{C A S}$. During $\overline{\mathrm{CAS}}$ high state ( $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{1 H}$ ) the output is in the high impedance state. The following table summarizes the DOut state for various types of cycles.

Intel 2117 Data Output Operation for Various Types of Cycles

| Type of Cycle | Dout State |
| :--- | :--- |
| Read Cycle | Data From Addressed <br>  <br> Memory Cell |
| Early Write Cycle | $\mathrm{HI}-\mathrm{Z}$ |
| $\overline{\text { RAS-Only Refresh Cycle }}$$\mathrm{HI}-\mathrm{Z}$ <br> $\overline{\text { CAS-Only Cycle }}$ | $\mathrm{HI}-\mathrm{Z}$ |
| Read/Modify/Write Cycle | Data From Addressed |
| Delayed Write Cycle | Memory Cell <br> Indeterminate |

## HIDDEN REFRESH

A feature of the 2117 is that refresh cycles may be performed while maintaining valid data at the output pin. This feature is referred to as Hidden Refresh. Hidden Refresh is performed by holding $\overline{C A S}$ at $V_{I L}$ and taking $\overline{R A S}$ high and after a specified precharge period ( $t_{R P}$ ), executing a " $\overline{\mathrm{RAS}}-$ Only" refresh cycle, but with $\overline{\mathrm{CAS}}$ held low (see Figure below).


This feature allows a refresh cycle to be "hidden" among data cycles without affecting the data availability.

## POWER ON

The 2117 requires no power on sequence providing absolute maximum ratings are not exceeded. After the application of supply voltages or after extended periods of bias (greater than 2 milliseconds) without clocks, the device must perform a minimum of eight initialization cycles (any combination of cycles containing a $\overline{R A S}$ clock, such as $\overline{\text { RAS }}-$ Only refresh) prior to normal operation.

## POWER SUPPLY DECOUPLING/DISTRIBUTION

It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be connected between VDD and VSS at every other device in the memory array. A $0.1 \mu \mathrm{~F}$ ceramic capacitor should also be connected between VBB and VSS at every other device (preferably the alternate devices to the VDD decoupling). For each 16 devices, a $10 \mu \mathrm{~F}$ tantalum or equivalent capacitor should be connected between VDD and VSs near the array. An equal or slightly smaller bulk capacitor is also recommended between $V_{B B}$ and VSS for every 32 devices.
The Vcc supply is connected only to the 2117 output buffer and is not used internally. The load current from the Vcc supply is dependent only upon the output loading and
is associated with the input high level current to a TTL gate and the output leakage currents of any OR-tied 2117's (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 Vcc and Vss for every eight memory devices.
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 $V_{\text {DD }}$ TO $V_{S S}$
$B=0.1 \mu \mathrm{~F} \mathrm{~V}_{\mathrm{BB}}$ TO $\mathrm{V}_{\mathrm{SS}}$
$\mathrm{C}=0.01 \mu \mathrm{~F} \mathrm{~V}_{\mathrm{CC}}$ TO $\mathrm{V}_{\mathrm{SS}}$

SAMPLE P.C. BOARD LAYOUT EMPLOYING VERTICAL AND HORIZONTAL GRIDDING ON ALL POWER SUPPLIES.
BOARD ORGANIZATION: 64 K WORDS BY 8-BITS.

## 2117-5 <br> 16,384 x 1 BIT DYNAMIC RAM

|  | $21.17-5$ |
| :--- | :---: |
| Maximum Access Time (ns) | 300 |
| Read, Write Cycle (ns) | 490 |
| Read-Modify-Write Cycle (ns) | 580 |

\author{

- Industry Standard 16-Pin Configuration <br> ■ Low Power: 462mW Max. Operating, 20mW Max. Standby <br> - Low IDD Current Transients <br> - All Inputs, Including Clocks, TTL Compatible <br> - $\overline{\text { RAS Only Refresh }}$
}


## - Non-Latched Output is Three-State, TTL Compatible <br> - 128 Refresh Cycles Required Every 2ms <br> - Page Mode Capability <br> - CAS Controlled Output Allows Hidden Refresh

The Intel® 2117 is a 16,384 word by 1-bit Dynamic MOS RAM fabricated with Intel's standard two layer polysilicon NMOS technology - a production proven process for high performance, high reliability, and high storage density.
The 2117 uses a single transistor dynamic storage cell and advanced dynamic circuitry to achieve high speed with low power dissipation. The circuit design minimizes the current transients typical of dynamic RAM operation. These low current transients contribute to the high noise immunity of the 2117 in a system environment.
Multiplexing the 14 address bits into the 7 address input pins allows the 2117 to be packaged in the industry standard 16-pin DIP. The two 7-bit address words are latched into the 2117 by the two TTL clocks, Row Address Strobe (RAS) and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ). Non-critical timing requirements for $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ allow use of the address multiplexing technique while maintaining high performance.
The 2117 three-state output is controlled by $\overline{\mathrm{CAS}}$, independent of $\overline{\mathrm{RAS}}$. After a valid read or read-modify-write cycle, data is latched on the output by holding $\overline{\mathrm{CAS}}$ low. The data out pin is returned to the high impedance state by returning $\overline{\mathrm{CAS}}$ to a high state. The 2117 hidden refresh feature allows $\overline{\mathrm{CAS}}$ to be held low to maintain latched data while $\overline{\mathrm{RAS}}$ is used to execute $\overline{\mathrm{RAS}}$-only refresh cycles.
The single transistor storage cell requires refreshing for data retention. Refreshing is accomplished by performing $\overline{\text { RAS }}-$ only refresh cycles, hidden refresh cycles, or normal read or write cycles on the 128 address combinations of $A_{0}$ through $A_{6}$ during a 2 ms period. A write cycle will refresh stored data on all bits of the selected row except the bit which is addressed.


## 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 VBB
(VSS - VBB $\geq 4 \mathrm{~V}$ ) ......................... - 0.3 V to +20 V
Data Out Current ................................... 50 mA
Power Dissipation ................................... 1.0W

## *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 ${ }^{[1,2]}$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=12 \mathrm{~V} \pm 5 \%, \mathrm{VCC}=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 | Limits |  |  | Unit | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[3]}$ | Max. |  |  |  |
| \|lıI| | Input Load Current (any input) |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ to $\mathrm{V}_{\text {IHMAX }}, \mathrm{V}_{\text {BB }}=-5.0 \mathrm{~V}$ |  |
| \|lool | Output Leakage Current for High Impedance State |  | 0.1 | 10 | $\mu \mathrm{A}$ | Chip Deselected: $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IH}}$, Vout $=0$ to 5.5 V |  |
| IDD1 | VDD Supply Current, Standby |  |  | 1.5 | mA | $\overline{\text { CAS }}$ and $\overline{R A S}$ at $\mathrm{V}_{\text {IH }}$ | 4 |
| IBB1 | VBB Supply Current, Standby |  | 1.0 | 50 | $\mu \mathrm{A}$ |  |  |
| ICC1 | Vcc Supply Current, Output Deselected |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IH}}$ | 5 |
| IDD2 | VDD Supply Current, Operating |  |  | 35 | mA | 2117, $\mathrm{t}_{\mathrm{RC}}=490 \mathrm{~ns}, \mathrm{t}_{\mathrm{RAS}}=300 \mathrm{~ns}$ | 4 |
| IBB2 | VBB Supply Current, Operating, RAS-Only Refresh, Page Mode |  | 150 | 400 | $\mu \mathrm{A}$ | $T_{A}=0^{\circ} \mathrm{C}$ |  |
| IDD3 | VDD Supply Current, $\overline{\mathrm{RAS}}$-Only Refresh |  |  | 27 | mA | $2117, \mathrm{t}_{\mathrm{RC}}=490 \mathrm{~ns}, \mathrm{t}_{\text {RAS }}=300 \mathrm{~ns}$ | 4 |
| IDD5 | VDD Supply Current, Standby, Output Enabled |  | 1.5 | 3 | mA | $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\text {IL }}, \overline{\mathrm{RAS}}$ at $\mathrm{V}_{\text {IH }}$ |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (all inputs) | -1.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (all inputs) | 2.4 |  | 6.0 | V |  |  |
| Vol | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ | 4 |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-5 \mathrm{~mA}$ | 4 |

NOTES:

1. All voltages referenced to $V_{s s}$.
2. No power supply sequencing is required. However, $V_{D D}, V_{C C}$ and $V_{S S}$ should never be more negative than $-0.3 V_{\text {with }}$ respect to $V_{B B}$ as required by the absolute maximum ratings.
3. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. See the Typical Characteristics Section for values of this parameter under alternate conditions.
5. Icc is dependent on output loading when the device output is selected. Vcc is connected to the output buffer only. Vcc may be reduced to $V_{S S}$ without affecting refresh operation or maintenance of internal device data.

## TYPICAL SUPPLY CURRENT WAVEFORMS




| हAS ONLY REFRESH |
| :--- |
|      |











Typical power supply current waveforms vs. time are shown for the $\overline{R A S} / \overline{\mathrm{CAS}}$ timings of Read/Write, Read/ Write (Long $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ ), and $\overline{\mathrm{RAS}}$-only refresh cycles. IDD and IBB current transients at the $\overline{R A S}$ and $\overline{C A S}$ edges require adequate decoupling of these supplies. Decoupling recommendations are provided in the Applications section.

The effects of cycle time, VDD supply voltage and ambient temperature on the IDD current are shown in graphs included in the Typical Characteristics Section. Each family of curves for IDD1, IDD2, and IDD3 is related by a common point at $V_{D D}=12.0 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ for two given $t_{\text {RAS }}$ pulse widths. The typical IDD current for a given condition of cycle time, $\mathrm{V}_{D D}$ and $\mathrm{T}_{A}$ can be determined by combining the effects of the appropriate family of curves.

## CAPACITANCE ${ }^{[1]}$

$T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{D D}=12 \mathrm{~V} \pm 5 \%, \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 specified.

| Symbol | Parameter | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Address, Data In | 3 | 5 | pF |
| $\mathrm{C}_{12}$ | $\overline{\mathrm{RAS}}$ Capacitance, $\overline{\mathrm{WE}}$ Capacitance | 4 | 7 | pF |
| $\mathrm{C}_{13}$ | $\overline{\mathrm{CAS}}$ Capacitance | 6 | 10 | pF |
| $\mathrm{C}_{0}$ | Data Output Capacitance | 4 | 7 | pF |

## NOTES:

1. Capacitance measured with Boonton Meter or effective capacitance calculated from the equation:
$C=\frac{l \Delta t}{\Delta V}$ with $\Delta V$ equal to 3 volts and power supplies at nominal levels.

## A.C. CHARACTERISTICS <br> $[1,2,3]$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%, \mathrm{~V} C \mathrm{C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V} S \mathrm{~S}=0 \mathrm{~V}$, unless otherwise noted.

## READ, WRITE, READ-MODIFY-WRITE AND REFRESH CYCLES

| Symbol | Parameter | 2117 |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| trac | Access Time From $\overline{\text { RAS }}$ |  | 300 | ns | 4,5 |
| tcac | Access Time From $\overline{\text { CAS }}$ |  | 180 | ns | 4,5,6 |
| tref | Time Between Refresh |  | 2 | ms |  |
| trp | $\overline{\text { RAS Precharge Time }}$ | 180 |  | ns |  |
| tCPN | $\overline{\text { CAS Precharge Time(non-pagecycles) }}$ | 80 |  | ns |  |
| tCRP | $\overline{\mathrm{CAS}}$ to $\overline{\mathrm{RAS}}$ Precharge Time | -20 |  | ns |  |
| trci | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ Delay Time | 80 | 120 | ns | 7 |
| trsh | $\overline{\mathrm{RAS}}$ Hold Time | 180 |  | ns |  |
| tCSH | $\overline{\text { CAS }}$ Hold Time | 300 |  | ns |  |
| tASR | Row Address Set-Up Time | 0 |  | ns |  |
| trah | Row Address Hold Time | 80 |  | ns |  |
| tasc | Column Address Set-Up Time | 0 |  | ns |  |
| tcan | Column Address Hold Time | 80 |  | ns |  |
| $\mathrm{taR}_{\text {A }}$ | Column Address Hold Time, to $\overline{\mathrm{RAS}}$ | 215 |  | ns |  |
| $t \top$ | Transition Time (Rise and Fall) | 3 | 50 | ns | 8 |
| toff | Output Buffer Turn Off Delay | 0 | 80 | ns |  |

READ AND REFRESH CYCLES

| trc | Random Read Cycle Time | 490 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tras | $\overline{\text { RAS Pulse Width }}$ | 300 | 10000 | ns |  |
| tcas | $\overline{\text { CAS Pulse Width }}$ | 180 | 10000 | ns |  |
| trcs | Read Command Set-Up Time | 0 |  | ns |  |
| trach | Read Command Hold Time | 0 |  | ns |  |

## WRITE CYCLE

| tRC | Random Write Cycle Time | 490 | ns |  |
| :---: | :--- | :--- | :--- | :--- |
| tRAS | $\overline{R A S}$ Pulse Width | $300 \quad 10000$ | ns |  |
| tCAS | $\overline{\text { CAS }}$ Pulse Width | $180 \quad 10000$ | ns |  |
| twCs | Write Command Set-Up Time | 0 | ns | 9 |
| twCH | Write Command Hold Time | 100 | ns |  |
| twCR | Write Command Hold Time, to $\overline{R A S}$ | 215 | ns |  |
| twP | Write Command Pulse Width | 100 | ns |  |
| tRWL | Write Command to $\overline{R A S}$ Lead Time | 130 | ns |  |
| tcWL | Write Command to $\overline{\text { CAS }}$ Lead Time | 130 | ns |  |
| tDS | Data-In Set-Up Time | 0 | ns |  |
| tDH | Data-In Hold Time | 80 | ns |  |
| tDHR | Data-In Hold Time, to $\overline{\text { RAS }}$ | 215 | ns |  |

## READ-MODIFY-WRITE CYCLE

| trWC | Read-Modify-Write Cycle Time | 580 | ns |  |
| :---: | :--- | :--- | :--- | :--- |
| tRRW | RMW Cycle $\overline{\text { RAS Pulse Width }}$ | $390 \quad 10000$ | ns |  |
| tCRW | RMW Cycle $\overline{\mathrm{CAS}}$ Pulse Width | $275 \quad 10000$ | ns |  |
| tRWD | $\overline{R A S}$ to $\overline{\text { WE }}$ Delay | 260 | ns | 9 |
| tcWD | $\overline{\mathrm{CAS}}$ to $\overline{\text { WE Delay }}$ | 140 | ns | 9 |

Notes: See following page for A.C. Characteristics Notes.

## WAVEFORMS



Dout $\mathrm{V}_{\mathrm{OL}} \quad$ HIGH
NOTES: $1,2 . \mathrm{V}_{\text {IH MIN }}$ AND $\mathrm{V}_{\text {IL max }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $\mathrm{V}_{\text {OH MIN }}$ AND $\mathrm{V}_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT
5. toff IS MEASURED TO IOUT $\leqslant$ lilol.
6. D $_{D S}$ AND toH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. $\mathrm{t}_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF CAS OR RAS, WHICHEVER OCCURS FIRST.
8. tCRP REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A CAS-

ONLY CYCLE (1.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## A.C. CHARACTERISTICS NOTES (From Previous Page)

1. All voltages referenced to $V_{S S}$.
2. Eight cycles are required after power-up or prolonged periods (greater than 2 ms ) of $\overline{R A S}$ inactivity before proper device operation is achieved. Any 8 cycles which perform refresh are adequate for this purpose.
3. A.C. Characteristics assume $\mathrm{tT}=5 \mathrm{~ns}$.
4. Assume that $t_{R C D} \leq t_{R C D}$ (max.). If $t_{R C D}$ is greater than $t_{R C D}$ (max.) then trac will increase by the amount that tRCD exceeds $t_{R C D}$ (max.).
5. Load $=2$ TTL loads and 100 pF .
6. Assumes $t_{R C D} \geq t_{R C D}$ (max.).
7. $t_{R C D}$ (max.) is specified as a reference point only; if $t_{R C D}$ is less than $t_{R C D}$ (max.) access time is $t_{R A C}$, if tRCD is greater than $t_{R C D}$ (max.) access time is $t_{R C D}+t_{C A C}$.
8. $t_{T}$ is measured between $V_{I H}$ (min.) and $V_{I L}$ (max.).
9. twCS, tcWD and tRWD are specified as reference points only. If twcs $\geq$ twcs (min.) the cycle is an early write cycle and the data out pin will remain high impedance throughout the entire cycle. If tcWD $\geq t_{C W D}\left(\min\right.$.) and $t_{R W D} \geq t_{\text {RWD }}$ (min.), the cycle is a read-modify-write cycle and the data out will contain the data read from the selected address. If neither of the above conditions is satisfied, the condition of the data out is indeterminate.

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE



## $\overline{\text { RAS }}$-ONLY REFRESH CYCLE



HIDDEN REFRESH CYCLE


NOTES: $1,2 . V_{I H}$ MIN AND $V_{I L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3.4. $\mathrm{V}_{\text {OH M M }}$ AND $V_{\text {OL max }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT.
5. tOFF IS MEASURED TO IOUT $\leqslant\left|\left.\right|_{\text {LO }}\right|$.
6. $t_{D S}$ AND $t_{D H}$ ARE REFERENCED TO $\overline{\text { CAS OR }} \overline{\text { WE, WHICHEVER OCCURS LAST. }}$
7. $\mathrm{t}_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF CAS OR RAS, WHICHEVER OCCURS FIRST.
8. tCRP REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A CAS-

ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## TYPICAL CHARACTERISTICS ${ }^{[1]}$

## 춪

GRAPH 1
TYPICAL ACCESS TIME ${ }^{\text {t RAC }}$ (NORMALIZED) VS. VDD


GRAPH 4
TYPICAL ACCESS TIME trac (NORMALIZED) VS. AMBIENT TEMPERATURE


GRAPH 7
TYPICAL OPERATING CURRENT I DD2 $^{\text {VS. }} \mathrm{t}_{\mathrm{RC}}$


GRAPH 2
TYPICAL ACCESS TIME
${ }^{\text {traC }}$ (NORMALIZED) VS. $V_{B B}$


GRAPH 5
TYPICAL STANDBY CURRENT $I_{D D 1}$ VS. $V_{D D}$


GRAPH 8 TYPICAL OPERATING CURRENT $I_{D D 2}$ VS. $V_{D D}$


GRAPH 6
TYPICAL STANDBY CURRENT IDD1 VS. AMBIENT TEMPERATURE


GRAPH 9
TYPICAL OPERATING CURRENT IDD2 VS. AMBIENT TEMPERATURE


GRAPH 10
tYpical $\overline{\text { RAS }}$ ONLY REFRESH CURRENT

IdD3 VS. trc


GRAPH 13
TYPICAL PAGE MODE CURRENT IDD4 VS. tpC


GRAPH 16
TYPICAL OUTPUT SOURCE CURRENT $\mathbf{I}_{\mathrm{OH}}$ VS. OUTPUT VOLTAGE $\mathrm{V}_{\mathrm{OH}}$

$\mathrm{V}_{\mathrm{OH}}$ - OUTPUT VOLTAGE (VOLTS)

GRAPH 11
TYPICAL $\overline{R A S}$ ONLY REFRESH CURRENT

IDD3 VS. VDD


GRAPH 14
TYPICAL PAGE MODE CURRENT IDD4 VS. VDD


GRAPH 17
TYPICAL OUTPUT SINK CURRENT IOL VS. OUTPUT VOLTAGE VOL


VoL - OUTPUT VOLTAGE (VOLTS)

GRAPH 12
TYPICAL $\overline{R A S}$ ONLY REFRESH CURRENT IDD3 VS. AMBIENT TEMPERATURE


TYPICAL PAGE MODE CURRENT IDD4 VS. AMBIENT TEMPERATURE


NOTES:

1. The cycle time, $V_{D D}$ supply voltage, and ambient temperature dependence of IDD1, IDD2, IDD3 and IDD4 is shown in related graphs. Common points of related curves are indicated:

- IDD1 @ $V_{D D}=12.6 \mathrm{~V}, T_{A}=0^{\circ} \mathrm{C}$
- IDD2 or IDD3 @ $t_{R A S}=300 \mathrm{~ns}, \mathrm{t}_{\mathrm{RC}}=$ $490 \mathrm{~ns}, \mathrm{~V}_{\mathrm{DD}}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\Delta I_{D D 2}$ or $I_{D D 3} @ t_{R A S}=500 \mathrm{~ns}, \mathrm{t}_{\mathrm{RC}}=$ $750 \mathrm{~ns}, \mathrm{~V}_{\mathrm{DD}}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\square I_{D D 4} @ t \mathrm{t} A S=180 \mathrm{~ns}, \mathrm{t}_{\mathrm{PC}}=310 \mathrm{~ns}$, $V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$\triangle$ l DD4 $^{@}{ }^{\mathrm{t}} \mathrm{CAS}=350 \mathrm{~ns}, \mathrm{tpC}=500 \mathrm{~ns}$, $V_{D D}=12.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
The typical IDD current for a given combination of cycle time, $V_{D D}$ supply voltage and ambient temperature may be determined by combining the effects of the appropriate family of curves.


## D.C. AND A.C. CHARACTERISTICS, PAGE MODE ${ }^{[7,8,11]}$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=12 \mathrm{~V} \pm 5 \%, \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.
For Page Mode Operation order 2117 S6117.

| Symbol | Parameter | $\begin{aligned} & 2117-5 \\ & \mathrm{~S} 6117 \end{aligned}$ |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tpC | Page Mode Read or Write Cycle | 310 |  | ns |  |
| tpcm | Page Mode Read Modify Write | 405 |  | ns |  |
| tcp | $\overline{\text { CAS Precharge Time, Page Cycle }}$ | 120 |  | ns |  |
| trpm | RAS Pulse Width, Page Mode | 300 | 10,000 | ns |  |
| tcas | $\overline{C A S}$ Pulse Width | 180 | 10,000 | ns |  |
| IDD4 | VDD Supply Current Page Mode, Minimum tpC, Minimum tcas |  | 26 | mA | 9 |

## WAVEFORMS

## PAGE MODE READ CYCLE



NOTES: 1,2. $V_{1 H}$ min AND $V_{1 L}$ max ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $V_{\text {OH MIN }}$ AND $V_{O L}$ MAX ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT. 5. toff IS MEASURED TO Iout \& Hlol.
6. $t_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF $\overline{C A S}$ OR $\overline{R A S}$, WHICHEVER OCCURS FIRST
7. ALL VOLTAGES REFERENCED TO VSS.
8. AC CHARACTERISTIC ASSUME $\mathrm{t}_{T}=5 \mathrm{~ns}$.
9. SEE THE TYPICAL CHARACTERISTICS SECTION FOR VALUES OF THIS PARAMETER UNDER ALTERNATE CONDITIONS.
10. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\operatorname{RAS}} / \overline{\mathrm{CAS}}$ CYCLES PRECEEDED BY A $\overline{\mathrm{CAS}}-$ ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).
11. ALL PREVIOUSLY SPECIFIED A.C. AND D.C. CHARACTERISTICS ARE APPLICABLE TO THEIR RESPECTIVE PAGE MODE DEVICE (i.e., 2117-5, S6117 WILL OPERATE AS A 2117-5).

PAGE MODE WRITE CYCLE


## PAGE MODE READ-MODIFY-WRITE CYCLE



NOTES: 1,2. $V_{I H \text { min }}$ AND $V_{I L}$ max ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3.4. $V_{\text {OH MIN }}$ AND $V_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT.
5. toff IS MEASURED TO Iout $\leqslant$ hlol.
6. tos And toh Are referenced to $\overline{\mathrm{CAS}}$ OR $\overline{\mathrm{WE}}$, WHICHEVER OCCURS LAST
7. tcrp REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\operatorname{RAS}} / \overline{\text { CAS }}$ CYCLES PRECEEDED BY A $\overline{\text { CAS }}-$ ONLY CYCLE (I.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## APPLICATIONS

## READ CYCLE

A Read cycle is performed by maintaining Write Enable $(\overline{W E})$ high during a $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}}$ operation. The output pin of a selected device will remain in a high impedance state until valid data appears at the output at access time.
Device access time, $t_{A C C}$, is the longer of the two calculated intervals:

$$
\text { 1. } t_{A C C}=t_{R A C} O R \text { 2. } t_{A C C}=t_{R C D}+t_{C A C}
$$

Access time from $\overline{R A S}, t_{R A C}$, and access time from $\overline{C A S}$, tcac, are device parameters. Row to column address strobe delay time, trCD, are system dependent timing parameters. For example, substituting the device parameters of the $\mathbf{2} 117$ yields:
3. $t_{A C C}=t_{\text {RAC }}=300 \mathrm{nsec}$ for $80 \mathrm{nsec} \leq t_{\text {RCD }} \leq 120 \mathrm{nsec}$
OR
4. $t_{A C C}=t_{R C D}+t_{C A C}=t_{R C D}+180$ for $t_{R C D}>120 n s e c$

Note that if 80 nsec $\leq t_{R C D} \leq 120$ nsec device access time is determined by equation 3 and is equal to trac. If tricD $>120 \mathrm{nsec}$, access time is determined by equation 4 . This 40 nsec interval (shown in the $t_{R C D}$ 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 $\overline{\mathrm{CAS}}$.

## REFRESH CYCLES

Each of the 128 rows of the 2117 must be refreshed every 2 milliseconds to maintain data. Any memory cycle:

1. Read Cycle
2. Write Cycle (Early Write, Delayed Write or Read-Modify-Write)
3. $\overline{R A S}-$ only Cycle
refreshes the selected row as defined by the low order ( $\overline{\mathrm{RAS}}$ ) addresses. Any Write cycle, of course, may change the state of the selected cell. Using a Read, Write, or Read-Modify-Write cycle for refresh is not recommended for systems which utilize "wire-OR" outputs since output bus contention will occur.
A $\overline{\mathrm{RAS}}$-only refresh cycle is the recommended technique for most applications to provide for data retention. A $\overline{R A S}-$ only refresh cycle maintains the Dout in the high impedance state with a typical power reduction of $20 \%$ over a Read or Write cycle.

## $\overline{R A S} / \overline{C A S}$ TIMING

$\overline{R A S}$ and $\overline{C A S}$ have minimum pulse widths as defined by $t_{\text {RAS }}$ and tCAS respectively. These minimum pulse widths must be maintained for proper device operation and data integrity. A cycle, once begun by driving $\overline{\mathrm{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 can not begin until the minimum precharge time, trp, has been met.

## DATA OUTPUT OPERATION

The 2117 Data Output (DOUT), which has three-state capability, is controlled by $\overline{C A S}$. During $\overline{\text { CAS }}$ high state ( $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{I H}$ ) the output is in the high impedance state. The following table summarizes the Dout state for various types of cycles.

\section*{Intel 2117 Data Output Operation for Various Types of Cycles <br> | Type of Cycle | Dout State |
| :---: | :---: |
| Read Cycle | Data From Addressed Memory Cell |
| Early Write Cycle | $\mathrm{HI}-\mathrm{Z}$ |
| RAS-Only Refresh Cycle | HI-Z |
| $\overline{\text { CAS-Only Cycle }}$ | HI-Z |
| Read/Modify/Write Cycle | Data From Addressed Memory Cell |
| Delayed Write Cycle | Indeterminate |

## HIDDEN REFRESH

A feature of the 2117 is that refresh cycles may be performed while maintaining valid data at the output pin. This feature is referred to as Hidden Refresh. Hidden Refresh is performed by holding $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IL}}$ and taking $\overline{R A S}$ high and after a specified precharge period (trp), executing a " $\overline{R A S}-O n l y " ~ r e f r e s h ~ c y c l e, ~ b u t ~ w i t h ~ \overline{C A S ~}$ held low (see Figure below).


This feature allows a refresh cycle to be "hidden" among data cycles without affecting the data availability.

## POWER ON

The 2117 requires no power on sequence providing absolute maximum ratings are not exceeded. After the application of supply voltages or after extended periods of bias (greater than 2 milliseconds) without clocks, the device must perform a minimum of eight initialization cycles (any combination of cycles containing a $\overline{R A S}$ clock, such as $\overline{R A S}$-Only refresh) prior to normal operation.

## POWER SUPPLY DECOUPLING/DISTRIBUTION

It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be connected between VDD and VSS 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 VDD decoupling). For each 16 devices, a $10 \mu \mathrm{~F}$ tantalum or equivalent capacitor should be connected between VDD and VSS 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.
The Vcc supply is connected only to the 2117 output buffer and is not used internally. The load current from the VCC supply is dependent only upon the output loading and
is associated with the input high level current to a TTL gate and the output leakage currents of any OR-tied 2117's (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 Vcc and Vss for every eight memory devices.
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}_{\text {DD }}$ TO $\mathrm{V}_{\mathrm{SS}}$
$B=0.1 \mu \mathrm{~F} \mathrm{~V}_{\mathrm{BB}}$ TO V $\mathrm{V}_{\mathrm{SS}}$
$\mathrm{C}=0.01 \mu \mathrm{~F} \mathrm{~V}_{\mathrm{CC}}$ TO $\mathrm{V}_{\mathrm{SS}}$

SAMPLE P.C. BOARD LAYOUT EMPLOYING VERTICAL AND HORIZONTAL GRIDDING ON ALL POWER SUPPLIES.

BOARD ORGANIZATION: 64K WORDS BY 8-BITS.

64K BYTE STORAGE ARRAY LAYOUT

# 2118 FAMILY <br> $16,384 \times 1$ BIT DYNAMIC RAM 

|  | $2118-2$ | $2118-3$ | $2118-4$ | $2118-7$ |
| :--- | :---: | :---: | :---: | :---: |
| Maximum Access Time (ns) | 80 | 100 | 120 | 150 |
| Read, Write Cycle (ns) | 200 | 235 | 270 | 320 |
| Read-Modify-Write Cycle (ns) | 250 | 295 | 345 | 410 |

Single +5 V Supply, $\pm 10 \%$ Tolerance
HMOS Technology
Low Power: 160mW Max. Operating 16mW Max. Standby

■ Low VDD Current Transients

- All Inputs, Including Clocks, TTL Compatible

Non-Latched Output is Three-State, TTL Compatible<br>$\overline{\text { RAS Only Refresh }}$<br>- 128 Refresh Cycles Required Every 2ms<br>- Page Mode Capability<br>- CAS Controlled Output Allows Hidden Refresh

The Intel ${ }^{\circledR} 2118$ is a 16,384 word by 1-bit Dynamic MOS RAM designed to operate from a single +5 V power supply. The 2118 is fabricated using HMOS - a production proven process for high performance, high reliability, and high storage density.
The 2118 uses a single transistor dynamic storage cell and advanced dynamic circuitry to achieve high speed with low power dissipation. The circuit design minimizes the current transients typical of dynamic RAM operation. These low current transients contribute to the high noise immunity of the 2118 in a system environment.

Multiplexing the 14 address bits into the 7 address input pins allows the 2118 to be packaged in the industry standard 16 -pin DIP. The two 7 -bit address words are latched into the 2118 by the two TTL clocks, Row Address Strobe ( $\overline{\mathrm{RAS}}$ ) and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ). Non-critical timing requirements for $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ allow use of the address multiplexing technique while maintaining high performance.
The 2118 three-state output is controlled by $\overline{\mathrm{CAS}}$, independent of $\overline{\text { RAS. After a valid read or read-modify-write cycle, data is }}$ latched on the output by holding $\overline{\text { CAS }}$ low. The data out pin is returned to the high impedance state by returning $\overline{\mathrm{CAS}}$ to a high state. The 2118 hidden refresh feature allows $\overline{\mathrm{CAS}}$ to be held low to maintain latched data while $\overline{\mathrm{RAS}}$ is used to execute $\overline{\text { RAS-only refresh cycles. }}$

The single transistor storage cell requires refreshing for data retention. Refreshing is accomplished by performing $\overline{\text { RAS }}-$ only refresh cycles, hidden refresh cycles, or normal read or write cycles on the 128 address combinations of $A_{0}$ through $A_{6}$ during a 2 ms period. A write cycle will refresh stored data on all bits of the selected row except the bit which is addressed.


2141
4096 X 1 BIT STATIC RAM

|  | $2141-2$ | $2141-3$ | $2141-4$ | $2141-5$ | $2141 \mathrm{~L}-3$ | $2141 \mathrm{~L}-4$ | $2141 \mathrm{~L}-5$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 120 | 150 | 200 | 250 | 150 | 200 | 250 |
| Max. Active Current (mA) | 70 | 70 | 55 | 55 | 40 | 40 | 40 |
| Max. Standby Current (mA) | 20 | 20 | 12 | 12 | 5 | 5 | 5 |

## - HMOS Technology

■ Industry Standard 2147 Pinout

- Completely Static Memory - No Clock or Timing Strobe Required
- Equal Access and Cycle Times
- Single +5 V Supply


## Automatic Power-Down <br> - Directly TTL Compatible - All Inputs and Output <br> - Separate Data Input and Output <br> - Three-State Output <br> - High Density 18-Pin Package

The Intel@ 2141 is a 4096-bit static Random Access Memory organized as 4096 words by 1-bit using HMOS, a highperformance MOS technology. It uses a uniquely innovative design approach which provides the ease-of-use features associated with non-clocked static memories and the reduced standby power dissipation associated with clocked static memories. To the user this means low standby power dissipation without the need for clocks, address setup and hold times, nor reduced data rates due to cycle times that are longer than access times.
$\overline{\mathrm{CS}}$ controls the power-down feature. In less than a cycle time after $\overline{\mathrm{CS}}$ goes high - deselecting the 2141 - the part automatically reduces its power requirements and remains in this low power standby mode as long as $\overline{\mathrm{CS}}$ remains high. This device feature results in system power savings as great as $85 \%$ in larger systems, where the majority of devices are deselected.
The 2141 is placed in an 18-pin package configured with the industry standard pinout, the same as the 2147 . It is directly TTL compatible in all respects: inputs, output, and a single +5 V supply. The data is read out nondestructively and has the same polarity as the input data. A data input and a separate three-state output are used.

PIN CONFIGURATION


PIN NAMES

| $A_{0}-A_{11}$ | ADDRESS INPUTS | $V_{\text {CC }}$ POWER ( +5 V ) |
| :---: | :---: | :---: |
| $\overline{W E}$ | WRITE ENABLE | GND GROUND |
| $\overline{\text { CS }}$ | CHIP SELECT |  |
| $\mathrm{D}_{\text {IN }}$ | DATA INPUT |  |
| Dout | DATA OUTPUT |  |

TRUTH TABLE

| $\overline{\mathrm{CS}}$ | $\overline{\mathrm{WE}}$ | MODE | OUTPUT | POWER |
| :---: | :---: | :---: | :---: | :---: |
| H | $\mathbf{X}$ | NOT SELECTED | HIGH Z | STANDBY |
| L | L | WRITE | HIGH Z | ACTIVE |
| L | H | READ | DOUT | ACTIVE |

BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

| der Bias | $-10^{\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 Ground | -1.5 V to +7 V |
| Power Dissipation | 1.2W |
| D.C. Output Current | 20 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}_{C C}=+5 \mathrm{~V} \pm 10 \%$ unless otherwise noted.

| Symbol | Parameter | 2141-2/-3 |  |  | 2141-4/-5 |  |  | 2141L-3/L-4/L-5 |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. | Min. | Typ. ${ }^{[1]}$ | Max. | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| ILI | Input Load Current (All Input Pins) |  | 0.01 | 10 |  | 0.01 | 10 |  | 0.01 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=M a x ., ~ V_{I N}= \\ & \text { GND to } V_{C C} \end{aligned}$ |
| \|lol | Output Leakage Current |  | 0.1 | 10 |  | 0.1 | 10 |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{\text {HH }}, \text { VCC }=\text { Max., } \\ & \text { VOUT }=\text { GND to } 4.5 \mathrm{~V} \end{aligned}$ |
| ICC | Operating Current |  | 45 | 70 |  | 40 | 55 |  | 30 | 40 | mA | $V_{C C}=$ Max., $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$, Outputs Open |
| ISB | Standby Current |  |  | 20 |  |  | 12 |  |  | 5 | mA | $V_{C C}=$ Min. to Max., $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IH}}$ |
| $1 \mathrm{PO}{ }^{(2)}$ | Peak Power-On Current |  |  | 40 |  |  | 30 |  |  | 18 | mA | $\mathrm{V}_{\mathrm{CC}}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{Cc}}$ Min. $\overline{\mathrm{CS}}=$ Lower of VCC or VIH Min. |
| VIL | Input Low Voltage | -1.0 |  | 0.8 | -1.0 |  | 0.8 | -1.0 |  | 0.8 | V |  |
| VIH | Input High Voltage | 2.0 |  | 6.0 | 2.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |
| VoL | Output Low Voltage |  |  | 0.4 |  |  | 0.4 |  |  | 0.4 | V | $1 \mathrm{OL}=8.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | 2.4 |  |  | 2.4 |  |  | V | $\mathrm{IOH}=-4.0 \mathrm{~mA}$ |
| los $^{[3]}$ | Output Short Circuit Current | -120 |  | 120 | -120 |  | 120 | -120 |  | 120 | mA | Vout=GND to Vcc |

Notes: 1. Typical limits are at $V_{C C}=5 \mathrm{~V}, \mathrm{~T}_{A}=+25^{\circ} \mathrm{C}$, and specified loading.
2. ICC exceeds ISB maximum during power-on, as shown in Graph 7. A pull-up resistor to $V_{C C}$ on the $\overline{\mathrm{CS}}$ input is required to keep the device deselected; otherwise, power-on current approaches Icc active.
3. Duration not to exceed one minute.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.5 Volts |
| :--- | :---: |
| Input Rise and Fall Times <br> Input and Output Timing Reference <br> Levels | 10 nsec |
| Output Load | 1 TTL Load plus 100pF |

## CAPACITANCE ${ }^{[4]}$

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

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

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

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

## READ CYCLE

| Symbol | Parameter | $2141-2$ <br> Min. Max. | $\begin{aligned} & \text { 2141-3/L-3 } \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & 2141-4 / \mathrm{L}-4 \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & 2141-5 / L-5 \\ & \text { Min. Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{R C}$ | Read Cycle Time | 120 | 150 | 200 | 250 | ns |
| taA | Address Access Time | 120 | 150 | 200 | 250 | ns |
| $t_{\text {acs1 }}$ [1] | Chip Select Access Time | 120 | 150 | 200 | 250 | ns |
| $\mathrm{taCS2}^{[2]}$ | Chip Select Access Time | 130 | 160 | 200 | 250 | ns |
| tor | Output Hold from Address Change | 10 | 10 | 10 | 10 | ns |
| $t_{L} z^{[3]}$ | Chip Selection to Output in Low Z | 30 | 30 | 30 | 30 | ns |
| $t \mathrm{~Hz}{ }^{[3]}$ | Chip Deselection to Output in High Z | $0 \quad 60$ | $0 \quad 60$ | 060 | $0 \quad 60$ | ns |
| tpu | Chip Selection to Power Up Time | 0 | 0 | 0 | 0 | ns |
| tPD | Chip Deselection to Power Down Time | 60 | 60 | 60 | 60 | ns |

## WAVEFORMS

READ CYCLE NO. $1^{[4,5]}$


READ CYCLE NO. $2^{[4,6]}$


## Notes:

1. Chip deselected for greater than 55 ns prior to selection.
2. Chip deselected for a finite time that is less than 55 ns prior to selection. (If the deselect time is Ons, the chip is by definition selected and access occurs according to Read Cycle No. 1.)
3. At any given temperature and voltage condition, $t_{H Z}$ max is less than $t_{L} Z$ min both for a given device and from device to device.
4. $\overline{W E}$ is high for Read Cycles.
5. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$.
6. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

WRITE CYCLE

|  | Parameter | 2141-2 |  | 2141-3/L-3 |  | 2141-4/L-4 |  | 2141-5/L-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| twc | Write Cycle Time | 120 |  | 150 |  | 200 |  | 250 |  | ns |
| tcw | Chip Selection to End of Write | 110 |  | 135 |  | 180 |  | 230 |  | ns |
| taw | Address Valid to End of Write | 110 |  | 135 |  | 180 |  | 230 |  | ns |
| tas | Address Setup Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| twp | Write Pulse Width | 60 |  | 60 |  | 60 |  | 75 |  | ns |
| twr | Write Recovery Time | 10 |  | 15 |  | 20 |  | 20 |  | ns |
| tow | Data Valid to End of Write | 50 |  | 60 |  | 60 |  | 75 |  | ns |
| toh | Data Hold Time | 5 |  | 5 |  | 5 |  | 5 |  | ns |
| twz | Write Enabled to Output in High Z | 10 | 70 | 10 | 80 | 10 | 80 | 10 | 80 | ns |
| tow | Output Active from End of Write | 5 |  | 5 |  | 5 |  | 5 |  | ns |

## WAVEFORMS

## WRITE CYCLE \#1 (产E CONTROLLED)



## WRITE CYCLE \#2 (CS CONTROLLED)



Note: 1. If $\overline{\mathrm{CS}}$ goes high simultaneously with $\overline{\mathrm{WE}}$ high, the output remains in a high impedance state.

TYPICAL D.C. AND A.C. CHARACTERISTICS

GRAPH 1 SUPPLY CURRENT VS. SUPPLY VOLTAGE


GRAPH 4
NORMALIZED ACCESS TIME VS. SUPPLY VOLTAGE


GRAPH 7
TYPICAL POWER-ON CURRENT VS. POWER SUPPLY VOLTAGE


GRAPH 2
SUPPLY CURRENT VS.
AMBIENT TEMPERATURE


GRAPH 5
NORMALIZED ACCESS TIME VS. AMBIENT TEMPERATURE


GRAPH 8
access time change vs. input voltage


GRAPH 3
OUTPUT SOURCE CURRENT VS. OUTPUT VOLTAGE


OUTPUT SINK CURRENT VS. output voltage


GRAPH 9 access time change vs. OUTPUT LOADING


## DEVICE DESCRIPTION

The 2141 is produced with HMOS, a new highperformance MOS technology which incorporates onchip substrate bias generation to achieve high-performance. This process, combined with new design ideas, gives the 2141 its unique features. Both low power and ease-of-use have been obtained in a single part. The lowpower feature is controlled with the Chip Select input, which is not a clock and does not have to be cycled. Multiple read or write operations are possible during a single select period. Access times are equal to cycle times, resulting in data rates up to 8.3 MHz for the $2141-2$. This is considerably higher performance than for clocked static designs.
Whenever the 2141 is deselected, it automatically reduces its power requirements to a fraction of the active power, as shown in Figure 1. This is achieved by switching off the power to unnecessary portions of the internal peripheral circuitry. This feature adds up to significant system power savings. The average power per device declines as system size grows because a continually higher portion of the memory is deselected. Device power dissipation asymptotically approaches the standby power level, as shown in Figure 2.


FIGURE 1. icc WAVEFORM.


FIGURE 2. AVERAGE DEVICE DISSIPATION VS. MEMORY SIZE.

There is no functional constraint on the amount of time the 2141 is deselected. However, there is a relationship between deselect time and Chip Select access time. With no compensation, the automatic power switch would cause an increase in Chip Select access time, since some time is lost in repowering the device upon selection. A feature of the 2141 design is its ability to compensate for this loss. The amount of compensation is a function of deselect time, as shown in Figure 3. For short deselect times, Chip Select access time becomes slower than address access time, since full compensation typically requires 60 ns . For longer deselect times, Chip Select access time actually becomes faster than address access time because the compensation more than offsets the time lost in powering up. The spec accounts for this characteristic by specifying two Chip Select access times, $t_{A C S 1}$ and $t_{A C S 2}$.


FIGURE 3. $t_{A C S}$ VS. DESELECT TIME.

The power switching characteristic of the 2141 requires more careful decoupling than would be required of a constant power device. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every other device, with a $22 \mu \mathrm{~F}$ to $47 \mu \mathrm{~F}$ bulk electrolytic decoupler every 32 devices. The actual values to be used will depend on board layout, trace widths and duty cycle. Power supply gridding is recommended for PC board layout. A very satisfactory grid can be developed on a two-layer board with vertical traces on one side and horizontal traces on the other, as shown in Figure 4.


FIGURE 4. PC LAYOUT.

2142
1024 X 4 BIT STATIC RAM

|  | $2142-2$ | $2142-3$ | 2142 | $2142 \mathrm{L2}$ | 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 . 1 mW /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 ( $\overline{C S}_{1}$ and $\mathrm{CS}_{2}$ ) 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.

LOGIC SYMBOL


PIN NAMES

| $A_{0}-A_{9}$ | ADDRESS INPUTS | OD | OUTPUT DISABLE |
| :--- | :--- | :--- | :--- |
| $\overline{W E}$ | WRITE ENABLE | $V_{C C}$ | POWER (+5V) |
| $\overline{C S} 1, \mathrm{CS}_{2}$ | CHIP SELECT | GND | GROUND |
| $1 / \mathrm{O}_{1}-1 / \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.0W |
| 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}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| $\mathrm{H}_{\text {LOI }}$ | I/O Leakage Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=2.4 \mathrm{~V}, \\ & \mathrm{~V}_{1 / \mathrm{O}}=0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| $I_{\text {cci }}$ | Power Supply Current |  | 80 | 95 |  |  | 65 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{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} & 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.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |
| IOL | 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.0 | -1.4 |  | -1.0 | -1.4 |  | mA | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| los ${ }^{[2]}$ | Output Short Circuit Current |  |  | 40 |  |  | 40 | mA | $V_{1 / O}=G N D$ to $V_{C C}$ |

NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $V_{C C}=5.0 \mathrm{~V}$.
2. Duration not to exceed 30 seconds.

## CAPACITANCE

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

| SYMBOL | TEST | MAX | UNIT | CONDITIONS |
| :--- | :--- | :---: | :---: | :--- |
| $C_{I / O}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{1 / \mathrm{O}}=\mathrm{OV}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{\mathrm{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 Load . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 TTL Gate and CL 100 pF

TEST NOTE: This circuit employs a self starting oscillator and a charge pump which require a certain amount of time after POWER ON to start functioning properly. This 2142 circuit is conservatively specified as requiring $500 \mu \mathrm{sec}$ after $V_{c c}$ reaches its specified limit $(4,75 \mathrm{~V})$.
Input Rise and Fall Times . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 nsec
Input and Output Timing Levels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.5 Volts
Output Load 1 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 | 2142-2, 2142L2 | 2142-3, 2142L3 | 2142, 2142L | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle Time | 200 | 300 | 450 | ns |
| $\mathrm{t}_{\mathrm{A}}$ | Access Time | 200 | 300 | 450 | ns |
| tod | Output Enable to Output Valid | 70 | 100 | 120 | ns |
| todx | Output Enable to Output Active | 20 | 20 | 20 | ns |
| ${ }^{\text {t }} \mathrm{CO}$ | Chip Selection to Output Valid | 70 | 100 | 120 | ns |
| ${ }^{\text {t }}$ c ${ }^{\text {r }}$ | Chip Selection to Output Active | 20 | 20 | 20 | ns |
| totD | Output 3-state from Disable | 60 | 80 | 100 | ns |
| $\mathrm{t}_{\mathrm{OHA}}$ | 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 |
| twR | Write Release Time | 0 |  | 0 |  | 0 |  | ns |
| totd | Output 3-state from Disable |  | 60 |  | 80 |  | 100 | ns |
| tow | Data to Write Time Overlap | 120 |  | 150 |  | 200 |  | ns |
| ${ }^{\text {t }}$ 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{\mathrm{WE}}$.
2. A Write occurs during the overlap of a low $\overline{\mathrm{CS}}$ and a low $\overline{\mathrm{WE}}$.

## WAVEFORMS

## READ CYCLE ${ }^{(3)}$



NOTES:
(3) $\overline{W E}$ is high for a Read Cycle.
(4) $\overline{\mathrm{WE}}$ must be high during all address transitions.

## WRITE CYCLE



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



## 2147 <br> 4096 X 1 BIT STATIC RAM

|  | $2147-3$ | 2147 | 2147 L |
| :--- | :---: | :---: | :---: |
| Max. Access Time (ns) | 55 | 70 | 70 |
| Max. Active Current (mA) | 180 | 160 | 140 |
| Max. Standby Current (mA) | 30 | 20 | 10 |

## HMOS Technology

Completely Static Memory - No Clock or Timing Strobe Required

Equal Access and Cycle Times
Single +5 V Supply

- Automatic Power-Down

■ High Density 18-Pin Package
■ Directly TTL Compatible - All Inputs and Output

- Separate Data Input and Output
- Three-State Output

The Intel ${ }^{\circledR} 2147$ is a 4096-bit static Random Access Memory organized as 4096 words by 1-bit using HMOS, a highperformance MOS technology. It uses a uniquely innovative design approach which provides the ease-of-use features associated with non-clocked static memories and the reduced standby power dissipation associated with clocked static memories. To the user this means low standby power dissipation without the need for clocks, address setup and hold times, nor reduced data rates due to cycle times that are longer than access times.
$\overline{\mathrm{CS}}$ controls the power-down feature. In less than a cycle time after $\overline{\mathrm{CS}}$ goes high - deselecting the 2147 - the part automatically reduces its power requirements and remains in this low power standby mode as long as $\overline{\mathrm{CS}}$ remains high. This device feature results in system power savings as great as $85 \%$ in larger systems, where the majority of devices are deselected.

The 2147 is placed in an 18-pin package configured with the industry standard pinout. It is directly TTL compatible in all respects: inputs, output, and a single +5 V supply. The data is read out nondestructively and has the same polarity as the input data. A data input and a separate three-state output are used.

PIN CONFIGURATION


PIN NAMES

| $A_{0}-A_{11}$ | ADDRESS INPUTS | $V_{\text {CC }}$ | POWER (+5V) |
| :--- | :--- | :--- | :--- |
| $\overline{W E}$ | WRITE ENABLE | GND | GROUND |
| $\overline{C S}$ | CHIP SELECT |  |  |
| $D_{\text {IN }}$ | DATA INPUT |  |  |
| $D_{\text {OUT }}$ | DATA OUTPUT |  |  |

TRUTH TABLE

| $\overline{\mathrm{CS}}$ | $\overline{\text { WE }}$ | MODE | OUTPUT | POWER |
| :---: | :---: | :---: | :---: | :---: |
| H | $\mathbf{X}$ | NOT SELECTED | HIGH Z | STANDBY |
| L | L | WRITE | HIGH Z | ACTIVE |
| L | H | READ | DOUT | ACTIVE |

BLOCK DIAGRAM

ABSOLUTE MAXIMUM RATINGS*
Temperature Under Bias

                                \(-10^{\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 Ground ........................ -1.5V to +7 V
Power Dissipation ...................................... 1.2W
D.C. Output Current
20 mA


#### Abstract

*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} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

| Symbol | Parameter | Min. | $\begin{aligned} & 2147-3 \\ & \text { Typ. [2] } \end{aligned}$ | Max. | Min. | $\begin{gathered} 2147 \\ \text { Typ. }{ }^{[2]} \end{gathered}$ | Max. | Min. | $\begin{gathered} \text { 2147L } \\ \text { Typ. [2] } \end{gathered}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ILI | Input Load Current (All Input Pins) |  | 0.01 | 10 |  | 0.01 | 10 |  | 0.01 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{Cc}}=\mathrm{MAX}, \mathrm{V}_{\text {IN }}=\mathrm{GND}$ to $\mathrm{V}_{\text {cc }}$ |
| \|liol | Output Leakage Current |  | 0.1 | 50 |  | 0.1 | 50 |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IH}}, \mathrm{~V}_{\mathrm{CC}}=\text { Max., }$ $V_{\text {OUT }}=\mathrm{GND} \text { to } 4.5 \mathrm{~V}$ |
| Icc | Operating Current |  | 120 | 170 |  | 100 | 150 |  | 100 | 135 | mA | $V_{C C}=\text { Max., } \overline{C S}=V_{\text {IL }},$ <br> Outputs Open |
|  |  |  |  | 180 |  |  | 160 |  |  | 140 | mA |  |
| IsB | Standby Current |  | 18 | 30 |  | 12 | 20 |  | 7 | 10 | mA | $V_{C C}=\text { Min. to Max. }$ $\overline{C S}=V_{I H}$ |
| IPO ${ }^{[3]}$ | Peak Power-On Current |  | 35 | 70 |  | 25 | 50 |  | 15 | 30 | mA | $\mathrm{V}_{\mathrm{cc}}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{cc}}$ Min., $\overline{C S}=$ Lower of $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{IH}}$ Min. |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -1.0 |  | 0.8 | -1.0 |  | 0.8 | -1.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | 6.0 | 2.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |
| VOL | Output Low Voltage |  |  | 0.4 |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{IOL}=8 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | 2.4 |  |  | 2.4 |  |  | V | $1 \mathrm{OH}=-4.0 \mathrm{~mA}$ |
| $1 \mathrm{los}^{[4]}$ | Output Short Circuit Current | -120 |  | 120 | -120 |  | 120 | -120 |  | 120 | mA | Vout=GND to Vcc |

Notes:

1. The operating ambient temperature range is guaranteed with transverse air flow exceeding 400 linear feet per minute.
2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, and specified loading.
3. Icc exceeds IsB maximum during power on, as shown in Graph 7. A pull-up resistor to Vcc on the $\overline{\mathrm{CS}}$ input is required to keep the device deselected; otherwise, power-on current approaches Icc active.
4. Duration not to exceed one minute.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.5 Volts |
| :--- | ---: |
| Input Rise and Fall Times | 10 nsec |
| Input and Output Timing Reference |  |
| $\quad$ Levels | 1.5 Volts |
| Output Load | See Figure 1 |



Figure 1. Output Load

## CAPACITANCE ${ }^{[5]}$

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$

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

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

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

## READ CYCLE

| Symbol | Parameter | 2147-3 |  | 2147, 2147L |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| trc | Read Cycle Time | 55 |  | 70 |  | ns |  |
| $t_{A A}$ | Address Access Time |  | 55 |  | 70 | ns |  |
| $\mathrm{taCS1}$ | Chip Select Access Time |  | 55 |  | 70 | ns | Note 1 |
| $t_{\text {ACS2 }}$ | Chip Select Access Time |  | 65 |  | 80 | ns | Note 2 |
| toh | Output Hold from Address Change | 5 |  | 5 |  | ns |  |
| $\mathrm{tLz}^{[3]}$ | Chip Selection to Output in Low Z | 10 |  | 10 |  | ns |  |
| $\mathrm{tHZ}^{[3]}$ | Chip Deselection to Output in High Z | 0 | 40 | 0 | 40 | ns |  |
| tpu | Chip Selection to Power Up Time | 0 |  | 0 |  | ns |  |
| tPD | Chip Deselection to Power Down Time |  | 30 |  | 30 | ns |  |

## WAVEFORMS

## READ CYCLE NO. 1



## READ CYCLE NO. 2



## A.C. CHARACTERISTICS (Continued)

## WRITE CYCLE

| Symbol | Parameter | 2147-3 |  | 2147,2147L |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| twc | Write Cycle Time | 55 |  | 70 |  | ns |  |
| tcw | Chip Selection to End of Write | 45 |  | 55 |  | ns |  |
| $t_{\text {aw }}$ | Address Valid to End of Write | 45 |  | 55 |  | ns |  |
| $t_{\text {AS }}$ | Address Setup Time | 0 |  | 0 |  | ns |  |
| twp | Write Pulse Width | 35 |  | 40 |  | ns |  |
| twr | Write Recovery Time | 10 |  | 15 |  | ns |  |
| tow | Data Valid to End of Write | 25 |  | 30 |  | ns |  |
| tDH | Data Hold Time | 10 |  | 10 |  | ns |  |
| twz | Write Enabled to Output in High Z | 0 | 30 | 0 | 35 | ns |  |
| tow | Output Active from End of Write | 0 |  | 0 |  | ns |  |

## WAVEFORMS

WRITE CYCLE \#1 ( $\overline{W E}$ CONTROLLED)


WRITE CYCLE \#2 ( $\overline{C S}$ CONTROLLED)


Note: 1. If $\overline{\mathrm{CS}}$ goes high simultaneously with $\overline{\mathrm{WE}}$ high, the output remains in a high impedance state.

TYPICAL D.C. AND A.C. CHARACTERISTICS

GRAPH 1
SUPPLY CURRENT VS.
SUPPLY VOLTAGE


GRAPH 4
NORMALIZED ACCESS TIME VS. SUPPLY VOLTAGE


GRAPH 7
TYPICAL POWER-ON CURRENT VS. POWER SUPPLY VOLTAGE


GRAPH 2
SUPPLY CURRENT VS. AMBIENT TEMPERATURE


GRAPH 5
NORMALIZED ACCESS TIME VS. AMBIENT TEMPERATURE


GRAPH 8
ACCESS TIME CHANGE VS.
input Voltage


GRAPH 3
OUTPUT SOURCE CURRENT VS. OUTPUT VOLTAGE


GRAPH 6
OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE


GRAPH 9
ACCESS TIME CHANGE VS. OUTPUT LOADING


Note 1 . The supply current curves shown in Graphs 1 and 2 are for the 2147.
The supply current curves for the 2147L and 2147-3 can be calculated by scaling proportionately.

## DEVICE DESCRIPTION

The 2147 is produced with HMOS, a new highperformance MOS technology which incorporates onchip substrate bias generation combined with device scaling to achieve high-performance. The speed-power product of this process has been measured at 1 pj , approximately four times better than previous MOS processes.
This process, combined with new design ideas, gives the 2147 its unique features. High speed, low power and ease-of-use have been obtained in a single part. The low-power feature is controlled with the Chip Select input, which is not a clock and does not have to be cycled. Multiple read or write operations are possible during a single select period. Access times are equal to cycle times, resulting in data rates of 14.3 MHz and 18 MHz for the 2147 and $2147-3$, respectively. This is considerably higher performance than for clocked static designs.
Whenever the 2147 is deselected, it automatically reduces its power requirements to a fraction of the active power, as shown in Figure 1. This is achieved by switching off the power to unnecessary portions of the internal peripheral circuitry. This feature adds up to significant system power savings. The average power per device declines as system size grows because a continually higher portion of the memory is deselected. Device power dissipation asymptotically approaches the standby power level, as shown in Figure 2.


FIGURE 1. $i_{\text {cc }}$ WAVEFORM.


FIGURE 2. AVERAGE DEVICE DISSIPATION VS. MEMORY SIZE.

There is no functional constraint on the amount of time the 2147 is deselected. However, there is a relationship between deselect time and Chip Select access time. With no compensation, the automatic power switch would cause an increase in Chip Select access time, since some time is lost in repowering the device upon selection. A feature of the 2147 design is its ability to compensate for this loss. The amount of compensation is a function of deselect time, as shown in Figure 3. For short deselect times, Chip Select access time becomes slower than address access time, since full compensation typically requires 40 ns . For longer deselect times, Chip Select access time actually becomes faster than address access time because the compensation more than offsets the time lost in powering up. The spec accounts for this characteristic by specifying two Chip Select access times, $t_{A C S 1}$ and tACS2.


FIGURE 3. $t_{\text {ACS }}$ VS. DESELECT TIME.
The power switching characteristic of the 2147 requires more careful decoupling than would be required of a constant power device. It is recommended that a $0.1 \mu \mathrm{~F}$ to $0.3 \mu \mathrm{~F}$ ceramic capacitor be used on every other device, with a $22 \mu \mathrm{~F}$ to $47 \mu \mathrm{~F}$ bulk electrolytic decoupler every 16 devices. The actual values to be used will depend on board layout, trace widths and duty cycle. Power supply gridding is recommended for PC board layout. A very satisfactory grid can be developed on a two-layer board with vertical traces on one side and horizontal traces on the other, as shown in Figure 4.


FIGURE 4. PC LAYOUT.
Terminations are recommended on input signal lines to the 2147 devices. In high speed systems, fast drivers can cause significant reflections when driving the high impedance inputs of the 2147. Terminations may be required to match the impedance of the line to the driver. The type of termination used depends on designer preference and may be parallel resistive or resistivecapacitive. The latter reduces terminator power dissipation.

# 2147H <br> HIGH SPEED $4096 \times 1$ BIT STATIC RAM 

■ HMOS II Technology
■ 35-45ns Maximum Access Time

- 180mA Maximum ICC
- 30mA Maximum ISB

Completely Static Memory - No Clock or Timing Strobe Required

## Equal Access and Cycle Times

Single +5 V Supply

Fully Compatible with Industry Standard 2147<br>Automatic Power-Down<br>- High Density 18-Pin Package<br>- Directly TTL Compatible - All Inputs and Output<br>Separate Data Input and Output<br>- Three-State Output

The Inte| ${ }^{\circledR} 2147 \mathrm{H}$ is a 4096-bit static Random Access Memory organized as 4096 words by 1 -bit using HMOS II, Intel's new high-performance MOS technology. It uses a uniquely innovative design approach which provides the ease-of-use features associated with non-clocked static memories and the reduced standby power dissipation associated with clocked static memories. To the user this means low standby power dissipation without the need for clocks, address setup and hold times, nor reduced data rates due to cycle times that are longer than access times.
$\overline{\mathrm{CS}}$ controls the power-down feature. In less than a cycle time after $\overline{\mathrm{CS}}$ goes high - deselecting the 2147 H - the part automatically reduces its power requirements and remains in this low power standby mode as long as $\overline{\mathrm{CS}}$ remains high. This device feature results in system power savings as great as $85 \%$ in larger systems, where the majority of devices are deselected.
The 2147 H is placed in an 18-pin package configured with the industry standard pinout. It is directly TTL compatible in all respects: inputs, output, and a single +5 V supply. The data is read out nondestructively and has the same polarity as the input data. A data input and a separate three-state output are used.

PIN CONFIGURATION


PIN NAMES

| $A_{0}-A_{11}$ | ADDRESS INPUTS | VCC POWER ( +5 V ) |
| :---: | :---: | :---: |
| $\overline{\text { WE }}$ | WRITE ENABLE | GND GROUND |
| $\overline{\text { CS }}$ | CHIP SELECT |  |
| $\mathrm{D}_{1 \mathrm{~N}}$ | DATA INPUT |  |
| Dout | DATA OUTPUT |  |

TRUTH TABLE

| CS | WE | MODE | OUTPUT | POWER |
| :---: | :---: | :---: | :---: | :---: |
| H | X | NOT SELECTED | HIGHZ | STANDBY |
| L | L | WRITE | HIGHZ | ACTIVE |
| L | H | READ | DOUT | ACTIVE |

BLOCK DIAGRAM


| Max. Access Time (ns) | 60 |
| :--- | ---: |
| Max. Active Current (mA) | 150 |
| Max. Standby Current (mA) | 30 |

## - HMOS Technology

- Completely Static Memory - No Clock or Timing Strobe Required


## - Equal Access and Cycle Times

- Single +5V Supply


## Automatic Power-Down

## High Density 18-Pin Package

## Directly TTL Compatible

 - All Inputs and Outputs
## Common Data Input and Output

Three-State Output

The Intel ${ }^{\circledR} 2148$ is a 4096 -bit static Random Access Memory organized as 1024 words by 4 bits using HMOS, a highperformance MOS technology. It uses a uniquely innovative design approach which provides the ease-of-use features associated with non-clocked static memories and the reduced standby power dissipation associated with clocked static memories. To the user this means low standby power dissipation without the need for clocks, address setup and hold times, nor reduced data rates due to cycle times that are longer than access times.
CE controls the power-down feature. In less than a cycle time after CE goes high - deselecting the 2148 - the part automatically reduces its power requirements and remains in this low power standby mode as long as CE remains high. This device feature results in system power savings as great as $85 \%$ in larger systems, where the majority of devices are deselected.
The 2148 is placed in an 18-pin package configured with the industry standard $1 \mathrm{~K} \times 4$ pinout. It is directly TTL compatible in all respects: inputs, outputs, and a single +5 V supply. The data is read out nondestructively and has the same polarity as the input data. Common input and output pins are provided.


3101, 3101A $16 \times 4$ BIT HIGH SPEED RAM

## Fast Access Time - 35 nsec max over $0.75^{\circ} \mathrm{C}$ Temperature Range (3101A)

- Simple Memory Expansion through Chip Select Input - 17 nsec max over $0.75^{\circ} \mathrm{C}$ Temperature Range (3101A)

\author{

- DTL and TTL Compatible - Low Input Load Current: 0.25 mA max
}


## - OR-Tie Capability - Open Collector Outputs

- Fully Decoded - on Chip Address
Decode and Buffer

\author{

- Minimum Line Reflection - Low Voltage Diode Input Clamp <br> - Ceramic and Plastic Package - 16 Pin Dual In-]Line Configuration
}

The Intel 3101 and 3101A are high speed fully decoded 64 bit random access memories, organized 16 words by 4 bits. Their high speed makes them ideal in scratch pad applications. An unselected chip will not generate noise at its output during writing of a selected chip. The output is held high on an unselected chip regardless of the state of the read/write signal.
The use of Schottky barrier diode clamped transistors to obtain fast switching speeds results in higher performance than equivalent devices with gold diffusion processes.
The Intel 3101 and 3101A are packaged in either hermetically sealed 16 pin ceramic packages, or in low cost silicone packages, and their performance is specified over a temperature range from $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$.
The storage cells are addressed through an on chip 1 of 16 binary decoder using four input address leads. A separate Chip Select lead allows easy selection of an individual package when outputs are OR-tied.
In addition to the address leads and the Chip Select lead, there is a write input which allows data presented at the data leads to be entered at the addressed storage cells.


## Absolute Maximum Ratings*

| Temperature Under Bias: | Ceramic <br> Plastic | $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ <br> $-65^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ |
| :--- | ---: | ---: |
| Storage Temperature |  | $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ |
| All Output or Supply Voltages | -0.5 to +7 Volts |  |
| All Input Voltages | -1.0 to +5.5 Volts |  |
| Output Currents | 100 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 | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\text {FA }}$ | ADDRESS INPUT LOAD CURRENT |  | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| ${ }^{\prime} \mathrm{FD}$ | DATA INPUT LOAD CURRENT |  | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{D}}=0.45 \mathrm{~V}$ |
| $I_{\text {FW }}$ | WRITE INPUT LOAD CURRENT |  | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{W}}=0.45 \mathrm{~V}$ |
| $I_{\text {FS }}$ | CHIP SELECT INPUT LOAD CURRENT |  | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RA }}$ | ADDRESS INPUT LEAKAGE CURRENT |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.25 \mathrm{~V}$ |
| $I_{\text {RD }}$ | DATA INPUT LEAKAGE CURRENT |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{D}}=5.25 \mathrm{~V}$ |
| $I_{\text {RW }}$ | WRITE INPUT LEAKAGE CURRENT |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{W}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RS }}$ | CHIP SELECT INPUT LEAKAGE CURRENT |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.25 \mathrm{~V}$ |
| $V_{C A}$ | ADDRESS INPUT CLAMP VOLTAGE |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{A}}=-5.0 \mathrm{~mA}$ |
| $V_{C D}$ | DATA INPUT CLAMP VOLTAGE |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{D}}=-5.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{cW}}$ | WRITE INPUT CLAMP VOLTAGE |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{W}}=-5.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {cs }}$ | CHIP SELECT INPUT CLAMP VOLTAGE |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{S}}=-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}}=15 \mathrm{~mA}$ <br> Memory Stores "Low" |
| $I_{\text {CEX }}$ | OUTPUT LEAKAGE CURRENT |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CEX}}=5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{S}}=2.5 \mathrm{~V} \end{aligned}$ |
| ${ }^{\text {cc }}$ | POWER SUPPLY CURRENT |  | 105 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=\mathrm{V}_{\mathrm{S}}=\mathrm{V}_{\mathrm{D}}=0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | INPUT "LOW" VOLTAGE |  | 0.85 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IH }}$ | INPUT "HIGH" VOLTAGE | 2.0 |  | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |

## Typical Characteristics

OUTPUT CURRENT
VS. OUTPUT "LOW" VOLTAGE


INPUT CURRENT
VS. INPUT VOLTAGE


INPUT THRESHOLD VOLTAGE VS. AMBIENT TEMPERATURE


## Switching Characteristics

## Conditions of Test:

Input Pulse amplitudes: 2.5 V
Input Pulse rise and fall times of 5 nanoseconds between 1 volt and 2 volts
Speed measurements are made at 1.5 volt levels Output loading is 15 mA and 30 pF

15 mA Test Load


READ CYCLE
Address to Output Delay
$A_{0}, A_{1}, A_{2}, A_{3}$

CHIP SELECT INPUT


## Chip Select to Output Delay

$A_{0}, A_{1}, A_{2}, A_{3}$

CHIP SELECT INPUT


*Outputs of unselected chips remain high during write cycle.

NOTE 1: $\quad{ }^{\text {t }} \mathrm{SR}$ is associated with a read cycle following a write cycle and does hot affect the access time.
A.C. Characteristics $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V} \pm 5 \%$

| READ CYCLE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | 3101A |  | 3101 |  |
|  |  | LIMITS (ns) |  | LIMITS (ns) |  |
|  |  | MIN. | MAX. | MIN. | MAX. |
| ${ }^{t} \mathrm{~S}_{+},{ }^{\text {t }}$ S- | Chip Select to Output Delay | 5 | 17 | 5 | 42 |
| ${ }^{t}{ }_{\text {A }},{ }^{\text {t }}$ A+ | Address to Output Delay | 10 | 35 | 10 | 60 |

CAPACITANCE ${ }^{(2)} \quad T_{A}=25^{\circ} \mathrm{C}$

| $C_{I N}$ | INPUT CAPACITANCE <br> (All Pins) | 10 pF <br> maximum |
| :--- | :--- | :---: |
| $\mathrm{C}_{\text {OUT }}$ | OUTPUT CAPACITANCE | 12 pF <br> maximum |


| WRITE CYCLE |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | TEST | 3101A |  | 3101 |  |
|  |  | LIMITS (ns) |  | LIMITS (ns) |  |
|  |  | MIN. | MAX. | MIN. | MAX. |
| ${ }^{\text {t }} \mathrm{SR}$ | Sense Amplifier Recovery Time |  | 35 |  | 50 |
| $t_{\text {WP }}$ | Write Pulse Width | 25 |  | 40 |  |
| tow | Data-Write Overlap Time | 25 |  | 40 |  |
| twr | Write Recovery Time | 0 |  | 5 |  |

NOTE 2: This parameter is periodically sampled and is not $100 \%$ tested. Condition of measurement is $f=1 \mathrm{MHz}, V_{\text {bias }}$ $=2 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V}$, and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## Typical A.C. Characteristics

ADDRESS TO OUTPUT DELAY
VS.
AMBIENT TEMPERATURE


ADDRESS \& CHIP SELECT TO OUTPUT DELAY
VS.
LOAD CAPACITANCE


CHIP SELECT TO OUTPUT DELAY
VS.
AMBIENT TEMPERATURE


WRITE PULSE WIDTH \& SENSE AMPLIFIER RECOVERY TIME VS. AMBIENT TEMPERATURE


## intel ${ }^{\circ}$

# 5101 FAMILY <br> $256 \times 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 |

## Single +5V Power Supply 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 5101L 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.

*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 | $\left\lvert\, \begin{gathered} 5101 \mathrm{~L} \text { and } 5101 \mathrm{~L}-1 \\ \text { Limits } \\ \text { Min. Typ. }[1] \text { Max. } \end{gathered}\right.$ |  |  |  | 5101L-3 <br> Limits <br> Typ.[1] | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{L} 2}{ }^{[2]}$ | Input Current |  | 5 |  |  | 5 |  | nA |  |
| $\\|_{\text {LO }}{ }^{\text {\| }}$ [2] | Output Leakage Current |  |  | 1 |  |  | 1 | $\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 | mA | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$, Except $\overline{\mathrm{CE}} \leqslant 0.65 \mathrm{~V}$, <br> Outputs Open |
| ${ }^{\text {CCC2 }}$ | Operating Current |  | 13 | 27 |  | 13 | 27 | mA | $\mathrm{V}_{\mathrm{IN}}=2.2 \mathrm{~V}$, Except $\overline{\mathrm{CE}} \leqslant 0.65 \mathrm{~V}$, <br> Outputs Open |
| $\mathrm{ICCL}^{[2]}$ | Standby Current |  |  | 10 |  |  | 200 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{CE} 2 \leqslant 0.2 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}= \\ & 70^{\circ} \mathrm{C} \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -0.3 |  | 0.65 | -0.3 |  | 0.65 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage | 2.2 |  | $\mathrm{V}_{\mathrm{Cc}}$ | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}$ |

Low Vcc 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 | $\mathrm{CE} 2 \leqslant 0.2 \mathrm{~V}$ |  |
| ICCDR1 | 5101L or 5101L-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 I CCL measurement.
3. $\mathrm{t}_{\mathrm{RC}}=$ 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

| Symbol | Parameter | 5101L-1 <br> Limits (ns) |  | 5101 L and 5101L-3 <br> Limits (ns) |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |
| $\mathrm{t}_{\mathrm{R}} \mathrm{C}$ | Read Cycle | 450 |  | 650 |  |
| $t_{A}$ | Access Time |  | 450 |  | 650 |
| ${ }^{\text {c }} \mathrm{CO} 1$ | Chip Enable ( $\overline{\mathrm{CE}} 1$ ) to Output |  | 400 |  | 600 |
| ${ }^{\text {t }} \mathrm{CO} 2$ | Chip Enable (CE 2) to Output |  | 500 |  | 700 |
| tod | Output Disable to Output |  | 250 |  | 350 |
| $t_{\text {DF }}$ | Data Output to High Z State | 0 | 130 | 0 | 150 |
| tor1 | Previous Read Data Valid with Respect to Address Change | 0 |  | 0 |  |
| ${ }^{\text {toH2 }}$ | Previous Read Data Valid with Respect to Chip Enable | 0 |  | 0 |  |

WRITE CYCLE

| $t_{\text {w }}$ | Write Cycle | 450 | 650 |
| :---: | :---: | :---: | :---: |
| ${ }^{t}$ AW | Write Delay | 130 | 150 |
| ${ }^{\text {t }} \mathrm{CW} 1$ | Chip Enable ( $\overline{\mathrm{CE}} 1$ ) to Write | 350 | 550 |
| ${ }^{\text {t }}$ W ${ }^{\text {W }}$ | Chip Enable (CE 2) to Write | 350 | 550 |
| tow | Data Setup | 250 | 400 |
| ${ }^{\text {t }}$ D ${ }^{\text {r }}$ | Data Hold | 50 | 100 |
| twp | Write Pulse | 250 | 400 |
| ${ }^{\text {t }}$ WR | Write Recovery | 50 | 50 |
| $t_{\text {D }}$ | Output Disable Setup | 130 | 150 |

## 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$ TTL Gate and $C_{L}=100 \mathrm{pF}$ |  |

Capacitance ${ }^{[2]} 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_{I N}=0 V$ | 4 | 8 |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ | 8 | 12 |

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.

## Waveforms

READ CYCLE


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.

## Read Only Memory <br> 4



## MOS EPROM AND ROM FAMILY

|  | Type | No. of Bits | Organization | $\begin{gathered} \text { No. } \\ \text { of } \\ \text { Pins } \end{gathered}$ | Output ${ }^{[1]}$ | Maximum Access (ns) | Maximum Power Dissipation (mW) | Operating Temperature Range ( ${ }^{\circ} \mathrm{C}$ ) | Power Supply (V) | Page No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 2316E | 16384 | $2048 \times 8$ | 24 | T.S. | 450 | 630 | 0 to 70 | $5 \mathrm{~V} \pm 10 \%$ | 4-12 |
|  | 2332A | 32768 | $4096 \times 8$ | 24 | T.S. | TBD | TBD | 0 to 70 | $5 \mathrm{~V} \pm 10 \%$ | 4-15 |
|  | 2364A | 65536 | $8192 \times 8$ | 28 | T.S. | TBD | TBD | 0 to 70 | $5 \mathrm{~V} \pm 10 \%$ | 4-16 |
|  | 2608 | 8192 | $1024 \times 8$ | 24 | T.S. | 450 | 800 | 0 to 70 | $\begin{gathered} 5 \mathrm{~V} \pm 5 \% \\ 12 \mathrm{~V} \pm 5 \% \\ -5 \mathrm{~V} \pm 5 \% \end{gathered}$ | $4-17$ |
|  | $\begin{aligned} & 1702 A \\ & \text { 1702A-2 } \\ & \text { 1702A-6 } \end{aligned}$ | $\begin{array}{r} 2048 \\ 2048 \\ 2048 \end{array}$ | $\begin{aligned} & 256 \times 8 \\ & 256 \times 8 \\ & 256 \times 8 \end{aligned}$ | 24 <br> 24 <br> 24 | T.S. <br> T.S. <br> T.S. | $1 \mu \mathrm{~s}$ 650 $1.5 \mu \mathrm{~s}$ | $\begin{aligned} & 885 \\ & 959 \\ & 885 \end{aligned}$ | 0 to 70 <br> 0 to 70 <br> 0 to 70 | $\begin{gathered} 5 V \pm 5 \% \\ -9 V \pm 5 \% \\ 5 V \pm 5 \% \\ -9 V \pm 5 \% \\ 5 V \pm 5 \% \\ -9 V \pm 5 \% \end{gathered}$ | 4.5 |
|  | M1702A | 2048 | $256 \times 8$ | 24 | T.S. | 850 | 960 | -55 to 100 | $\left\lvert\, \begin{gathered} 5 \mathrm{~V} \pm 10 \% \\ -9 \mathrm{~V} \pm 10 \% \end{gathered}\right.$ | 14-5 |
|  | $\begin{aligned} & \text { 1702AL } \\ & \text { 1702AL-2 } \end{aligned}$ | 2048 <br> 2048 | $\begin{aligned} & 256 \times 8 \\ & 256 \times 8 \end{aligned}$ | 24 24 | $\begin{aligned} & \text { T.S. } \\ & \text { T.S. } \end{aligned}$ | $1 \mu \mathrm{~s}$ $650$ | $\begin{aligned} & 221 \\ & 221 \end{aligned}$ | 0 to 70 <br> 0 to 70 | $\begin{gathered} 5 V \pm 5 \% \\ -9 V \pm 5 \% \\ 5 V \pm 5 \% \\ -9 V \pm 5 \% \end{gathered}$ | 4-9 |
|  | 2704 | 4096 | $512 \times 8$ | 24 | T.S. | 450 | 800 | 0 to 70 | $\begin{gathered} 5 V \pm 5 \% \\ 12 V \pm 5 \% \\ -5 V \pm 5 \% \end{gathered}$ | 4-20 |
|  | $2708$ $2708 \mathrm{~L}$ $2708-1$ | $\begin{aligned} & 8192 \\ & 8192 \\ & 8192 \end{aligned}$ | $\begin{aligned} & 1024 \times 8 \\ & 1024 \times 8 \\ & 1024 \times 8 \end{aligned}$ | 24 <br> 24 <br> 24 | T.S. <br> T.S. <br> T.S. | 450 <br> 450 $350$ | 800 <br> 425 <br> 800 | $\begin{aligned} & 0 \text { to } 70 \\ & 0 \text { to } 70 \\ & 0 \text { to } 70 \end{aligned}$ | $\begin{gathered} 5 \mathrm{~V} \pm 5 \% \\ 12 \mathrm{~V} \pm 5 \% \\ -5 \mathrm{~V} \pm 5 \% \\ 5 \mathrm{~V} \pm 5 \% \\ 12 \mathrm{~V} \pm 5 \% \\ -5 \mathrm{~V} \pm 5 \% \\ 5 \mathrm{~V} \pm 5 \% \\ 12 \mathrm{~V} \pm 5 \% \\ -5 \mathrm{~V} \pm 5 \% \end{gathered}$ | 4-21 |
|  | 12708 | 8192 | $1024 \times 8$ | 24 | T.S. | 450 | 800 | -40 to 85 | $\begin{aligned} & 12 V \pm 5 \% \\ & -5 V \pm 5 \% \end{aligned}$ | $13-4$ |
|  | M2708 | 8192 | $1024 \times 8$ | 24 | T.S. | 450 | 750 | -55 to 100 | $\begin{aligned} & 12 \mathrm{~V} \pm 10 \% \\ & -5 \mathrm{~V} \pm 10 \% \end{aligned}$ | 14-22 |
|  | $\begin{aligned} & 2716 \\ & 2716-1 \\ & 2716-2 \end{aligned}$ | $\begin{aligned} & 16384 \\ & 16384 \\ & 16384 \end{aligned}$ | $\begin{aligned} & 2048 \times 8 \\ & 2048 \times 8 \\ & 2048 \times 8 \end{aligned}$ | $\begin{aligned} & 24 \\ & 24 \\ & 24 \end{aligned}$ | T.S. <br> T.S. <br> T.S. | $\begin{aligned} & 450 \\ & 350 \\ & 390 \end{aligned}$ | $\begin{aligned} & 525 / 132^{[2]} \\ & 550 / 138^{[2]} \\ & 525 / 132^{[2]} \end{aligned}$ | 0 to 70 <br> 0 to 70 <br> 0 to 70 | $\begin{gathered} 5 V \pm 5 \% \\ 5 V \pm 10 \% \\ 5 V \pm 5 \% \end{gathered}$ | 4-23 |
|  | 12716 | 16384 | $2048 \times 8$ | 24 | T.S. | 450 | $603 / 165^{[2]}$ | -40 to 85 | $5 \mathrm{~V} \pm 5 \%$ | 13-5 |
|  | M2716 | 16384 | $2048 \times 8$ | 24 | T.S. | 450 | 603/165 ${ }^{[2]}$ | -55 to 100 | $5 \mathrm{~V} \pm 10 \%$ | 14-28 |
|  | 2732 | 32768 | $4096 \times 8$ | 24 | T.S. | 450 | 788/158 ${ }^{[2]}$ | 0 to 70 | $5 \mathrm{~V} \pm 5 \%$ | 4-28 |
|  | 2758 | 8192 | $1024 \times 8$ | 24 | T.S. | 450 | $525 / 132^{[2]}$ | 0 to 70 | $5 \mathrm{~V} \pm 5 \%$ | 4-31 |

Notes: 1. T.S. is a three state output.
2. Static standby mode feature.

| Type | No. <br> of <br> Bits | Organization | No. <br> of <br> Pins | Output ${ }^{[1]}$ | Maximum <br> Access <br> (ns) | Maximum <br> Power <br> Dissipation <br> (mW) | Operating <br> Temperature <br> Range <br> ( ${ }^{\circ}$ C) | Power <br> Supply | Page <br> No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 3604A | 4096 | $512 \times 8$ | 24 | O.C. | 70 | 895 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ |  |
| 3604A-2 | 4096 | $512 \times 8$ | 24 | O.C. | 60 | 895 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ |  |
| 3604AL | 4096 | $512 \times 8$ | 24 | O.C. | 90 | $685 / 135^{[2]}$ | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ | $4-36$ |
| 3624A | 4096 | $512 \times 8$ | 24 | T.S. | 70 | 895 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ |  |
| 3624A-2 | 4096 | $512 \times 8$ | 24 | T.S. | 60 | 895 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ |  |
| M3604A | 4096 | $512 \times 8$ | 24 | O.C. | 90 | 1045 | -55 to 125 | $5 \mathrm{~V} \pm 10 \%$ | $14-33$ |
| M3624A | 4096 | $512 \times 8$ | 24 | T.S. | 90 | 1045 | -55 to 125 | $5 \mathrm{~V} \pm 10 \%$ |  |
| 3605A | 4096 | $1024 \times 4$ | 18 | O.C. | 60 | 735 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ |  |
| 3605A-1 | 4096 | $1024 \times 4$ | 18 | O.C. | 50 | 735 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ | $4-39$ |
| 3625A | 4096 | $1024 \times 4$ | 18 | T.S. | 60 | 735 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ |  |
| 3625A-1 | 4096 | $1024 \times 4$ | 18 | T.S. | 50 | 735 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ |  |
| M3625A | 4096 | $1024 \times 4$ | 18 | T.S. | 60 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ | $14-35$ |
| 3628 | 8192 | $1024 \times 8$ | 24 | T.S. | 80 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ | $4-42$ |
| 3628-4 | 8192 | $1024 \times 8$ | 24 | T.S. | 100 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 5 \%$ | 4 |
| 3636 | 16384 | $2048 \times 8$ | 24 | T.S. | 80 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ | $4-45$ |
| 3636-1 | 16384 | $2048 \times 8$ | 24 | T.S. | 65 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ | 4 |
| M3636 | 16384 | $2048 \times 8$ | 24 | T.S. | 80 | 998 | -50 to 125 | $5 \mathrm{~V} \pm 5 \%$ | $14-38$ |

Notes: 1. O.C. and T.S. are open collector and three-state output respectively.

ROM and PROM Programming Instructions $\quad 4-48$
2. The 3604 AL has a low power dissipation feature.

## BIPOLAR PROM CROSS REFERENCE

|  |  |  | Intel Part Number |  |
| :---: | :---: | :---: | :---: | :---: |
| Part <br> Number | Prefix and Manufacturer | Organization | Direct <br> Replacement | For New Designs |
| 5340-1 | MMI | $512 \times 8$ | M3624A |  |
| 5341-1 | MMI | $512 \times 8$ | M3624A |  |
| 5604C | IM-Intersil | $512 \times 4$ | 3602A |  |
| 5605C | IM-Intersil | $512 \times 8$ | 3604A |  |
| 5624C | IM-Intersil | $512 \times 4$ | 3622A |  |
| 5625C | IM-Intersil | $512 \times 8$ | 3624A |  |
| 6305-1 | MMI | $512 \times 4$ |  | 3604A |
| 6306-1 | MMI | $512 \times 4$ |  | 3625A |
| 6340-1 | MMI | $512 \times 8$ | 3604A |  |
| 6341-1 | MMI | $512 \times 8$ | 3624A |  |
| 6352-1 | MMI | $1024 \times 4$ |  | 3625A |
| 6353-1 | MMI | $1024 \times 4$ | 3625A |  |
| 6380-1 | MMI | $1024 \times 8$ |  | 3628 |
| 6381-1 | MMI | $1024 \times 8$ | 3628 |  |
| 74S472 | TI | $512 \times 8$ |  | 3624A |
| 745473 | TI | $512 \times 8$ |  | 3604A |
| 745474 | TI | $512 \times 8$ | 3624A |  |
| 74S475 | TI | $512 \times 8$ | 3604A |  |
| 74S570 | National | $512 \times 4$ |  | 3604A |
| 745571 | National | $512 \times 4$ |  | 3625A |
| 7620-5 | HM-Harris | $512 \times 4$ |  | 3604A |
| 7621-5 | HM-Harris | $512 \times 4$ |  |  |
| 7640-2 | HM-Harris | $512 \times 8$ |  | M3604A |
| 7640-5 | HM-Harris | $512 \times 8$ | 3604A |  |
| 7641-2 | HM-Harris | $512 \times 8$ |  | M3624A |
| 7641-5 | HM-Harris | $512 \times 8$ | 3624A |  |
| 7642-5 | HM-Harris | $1024 \times 4$ | 3605A |  |
| 7643-5 | HM-Harris | $1024 \times 4$ | 3625A |  |
| 7644-5 | HM-Harris | $1024 \times 4$ |  | 3625A |
| 7680-5 | HM-Harris | $1024 \times 8$ |  | 3628 |
| 7681-5 | HM-Harris | $1024 \times 8$ | 3628 |  |
| $82 \mathrm{S115}$ | N -Signetics | $512 \times 8$ |  | 3624A |
| 82S115 | S-Signetics | $512 \times 8$ |  | M3624A |
| 82S130 | N -Signetics | $512 \times 4$ |  | 3604A |
| 82S131 | N -Signetics | $512 \times 4$ |  | 3625A |
| $82 \mathrm{S140}$ | N -Signetics | $512 \times 8$ | 3604A-2 |  |
| 82S141 | N -Signetics | $512 \times 8$ | 3624A-2 |  |
| 82S136 | N -Signetics | $1024 \times 4$ |  | 3625A-1 |
| 82S137 | N -Signetics | $1024 \times 4$ | 3625A-1 |  |
| 82S137 | S-Signetics | $1024 \times 4$ | M3625A |  |
| 82S180 | N -Signetics | $1024 \times 8$ |  | 3628 |
| 82S181 | N -Signetics | $1024 \times 8$ |  | 3628 |
| 82S182 | N -Signetics | $1024 \times 8$ |  | 3628-1 |
| 82S183 | N -Signetics | $1024 \times 8$ |  |  |
| 82S19: | N -Signetics | $2048 \times 8$ | 3636 |  |
| 82S191 | S-Signetics | $2048 \times 8$ | M3636 |  |
| 87S295 | National | $512 \times 8$ | 3604A |  |
| 875296 | National | $512 \times 8$ | 3624A |  |
| 93436C | Fairchild | $512 \times 4$ |  | 3604A |
| 93438C | Fairchild | $512 \times 8$ |  | 3604A-2 |
| 93438M | Fairchild | $512 \times 8$ |  | M3604A |
| 93446C | Fairchild | $512 \times 4$ |  | 3625A-1 |
| 93448C | Fairchild | $512 \times 8$ |  | 3624A-2 |
| 93448M | Fairchild | $512 \times 8$ |  | M3624A |
| 93452C | Fairchild | $1024 \times 4$ | 3625A-1 |  |
| 93453C | Fairchild | $1024 \times 4$ | 3625A-1 |  |
| 93453M | Fairchild | $1024 \times 4$ | M3625A |  |

# 2K (256 x 8) UV ERASABLE PROM 

| $1702 A-2$ | 0.65 us Max. |
| :--- | :---: |
| $1702 A$ | 1.0 us Max. |
| $1702 A-6$ | 1.5 us Max. |

## - Fast Access Time: Max. 650 ns (1702A-2)

- Fast Programming: 2 Minutes for all 2048 Bits
- All 2048 Bits Guaranteed* Programmable: 100\% Factory Tested
- Static MOS: No Clocks Required
- Inputs and Outputs DTL and TTL Compatible
- Three-State Output: OR-tie Capability

The 1702A is a 256 word by 8 -bit electrically programmable ROM ideally suited for uses where fast turnaround and pattern experimentation are important. The 1702A undergoes complete programming and functional testing prior to shipment, thus insuring $100 \%$ programmability.
Initially all 2048 bits of the 1702A are in the " 0 " state (output low). Information is introduced by selectively programming " 1 "s (output high) in the proper bit location. The 1702A is packaged in a 24 pin dual in-line package with a transparent lid. The transparent lid allows the user to expose the 1702A to ultraviolet light to erase the bit pattern. A new pattern can then be written into the device.
The circuitry of the 1702A is completely static. No clocks are required. Access times from 650 ns to $1.5 \mu \mathrm{~s}$ are available. A 1702AL family is available (see 1702AL data sheets for specifications) for those systems requiring lower power dissipation than the 1702A.

The 1702A is fabricated with silicon gate technology. This low threshold technology allows the design and production of higher performance MOS circuits and provides a higher functional density on a monolithic chip than conventional MOS technologies.
*Intel's liability shall be limited to replacing any unit which fails to program as desired.


## PIN CONNECTIONS

The external lead connections to the 1702A differ, depending on whether the device is being programmed or used in read mode (see following table). In the programming mode, the data inputs 1-8 are pins 4-11 respectively. The programming voltages and timing are shown in the Data Catalog ROM and PROM Programming Instructions section.

| PIN | 12 <br> $\left(\mathrm{~V}_{\mathrm{CC}}\right)$ | 13 <br> $($ Program $)$ | 14 <br> $(\mathbf{C S})$ | 15 <br> $\left(\mathrm{~V}_{\mathrm{BB}}\right)$ | 16 <br> $\left(\mathrm{~V}_{\mathrm{GG}}\right)$ | $\mathbf{2 2}$ <br> $\left(\mathrm{V}_{\mathrm{CC}}\right)$ | $\mathbf{2 3}$ <br> $\left(\mathrm{V}_{\mathrm{CC}}\right)$ | $\mathbf{2 4}$ <br> $\left(\mathrm{V}_{\mathrm{DD}}\right)$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Read | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | GND | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{GG}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{DD}}$ |
| Programming | GND | Program Pulse | GND | $\mathrm{V}_{\mathrm{BB}}$ | Pulsed $\mathrm{V}_{\mathrm{GG}}$ | GND | GND | Pulsed $\mathrm{V}_{\mathrm{DD}}$ |

## Absolute Maximum Ratings*

Ambient Temperature Under Bias $-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering Temperature of Leads ( 10 sec ) . . . . . . . . $+300^{\circ} \mathrm{C}$
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 2 Watts
Read Operation: Input Voltages and Supply
Voltages with respect to $\mathrm{V}_{\mathrm{CC}}$. . . . . . . . . +0.5 V to -20 V
Program Operation: Input Voltages and Supply
Voltages with respect to $\mathrm{V}_{\mathrm{CC}}$
$-48 \mathrm{~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 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 \%, \mathrm{~V}_{\mathrm{DD}}=-9 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{GG}}=-\mathrm{gV} \pm 5 \%$, READ OPERATION unless otherwise noted.

| Symbol | Test | 1702A, 1702A-6 Limits |  |  | 1702A-2 Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. | Min. | Typ. ${ }^{\text {11] }}$ | Max. |  |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Address and Chip Select Input Load Current |  |  | 1 |  |  | 1 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.0 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | 1 |  |  | 1 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}, \overline{\mathrm{CS}}=\mathrm{V}_{1 \mathrm{H} 2}$ |
| $\mathrm{IDD1}^{[1]}$ | Power Supply Current |  | 35 | 50 |  | 40 | 60 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IH} 2}, \mathrm{IOL}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| IDD2 | Power Supply Current |  | 32 | 46 |  | 37 | 55 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=0.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| IDD3 | Power Supply Current |  | 38 | 60 |  | 43 | 65 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{1 \mathrm{H} 2}, \mathrm{I}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| ICF1 | Output Clamp Current |  | 8 | 14 |  | 7 | 13 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=-1.0 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| ICF2 | Output Clamp Current |  | 7 | 13 |  | 6 | 12 | mA | $\begin{aligned} & \mathrm{V}_{\text {OUT }}=-1.0 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \text {, Continuous } \end{aligned}$ |
| $\mathrm{I}_{\mathrm{GG}}$ | Gate Supply Current |  |  | 1 |  |  | 1 | $\mu \mathrm{A}$ |  |
| $V_{\text {IL1 }}$ | Input Low Voltage for TTL Interface | -1 |  | 0.65 | -1 |  | 0.65 | V |  |
| $\mathrm{V}_{\text {IL2 }}$ | Input Low Voltage for MOS Interface | $V_{\text {DD }}$ |  | $\mathrm{V}_{\mathrm{cc}}{ }^{-6}$ | $\mathrm{V}_{\mathrm{DD}}$ |  | $\mathrm{V}_{\mathrm{cc}}{ }^{-6}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Addr. Input High Voltage | $\mathrm{V}_{\mathrm{Cc}}-2$ |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | Chip Sel. Input High Volt. | $\mathrm{V}_{\mathrm{CC}}-2$ |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | $\mathrm{V}_{\text {cC }}{ }^{-1.5}$ |  | $\mathrm{V}_{\mathrm{CC}}{ }^{+0.3}$ | V |  |
| IOL | Output Sink Current | 1.6 | 4 |  | 1.6 | 4 |  | mA | $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}$ |
| IOH | Output Source Current | -2.0 |  |  | -2.0 |  |  | mA | $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | -3 | 0.45 |  | -3 | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 3.5 | 4.5 |  | 3.5 | 4.5 |  | V | $\mathrm{IOH}=-200 \mu \mathrm{~A}$ |

Note 1: Typical values are at nominal voltages and $T_{A}=25^{\circ} \mathrm{C}$.

## 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}}=-9 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{GG}}=-9 \mathrm{~V} \pm 5 \%$ unless otherwise noted

| Symbol | Test | 1702A <br> Limits | $\begin{aligned} & \text { 1702A-2 } \\ & \text { Limits } \end{aligned}$ | $\begin{aligned} & \text { 1702A-6 } \\ & \text { Limits } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. Max. |  |
| Freq. | Repetition Rate | 1 | 1.6 | 0.66 | MHz |
| $\mathrm{toH}^{\text {r }}$ | Previous Read Data Valid | 0.1 | 0.1 | 0.1 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {ACC }}$ | Address to Output Delay | 1 | 0.65 | 1.5 | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ cs | Chip Select Delay | 0.1 | 0.3 | 0.6 | $\mu \mathrm{s}$ |
| ${ }^{\text {t }} \mathrm{CO}$ | Output Delay From $\overline{\mathrm{CS}}$ | 0.9 | 0.35 | 0.9 | $\mu \mathrm{s}$ |
| tod | Output Deselect | 0.3 | 0.3 | 0.3 | $\mu \mathrm{s}$ |

Capacitance " $T_{A}=25^{\circ} \mathrm{C}$

| SYMBOL | TEST | TYPICAL | MAXIMUM | UNIT | CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 8 | 15 | pF | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ <br> CS <br> $\mathrm{C}_{\mathrm{CO}}$ |
| $\mathrm{V}_{\mathrm{CC}}$ | Output Capacitance | 10 | 15 | pF | AII <br> unused pins <br> $\mathrm{V}_{\mathrm{OUT}}$ |

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

## Switching Characteristics

## Conditions of Test:

Input pulse amplitudes: 0 to $4 \mathrm{~V} ; \mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}} \leq 50 \mathrm{~ns}$ Output load is 1 TTL gate; measurements made at output of TTL gate ( $t_{P D} \leqslant 15 \mathrm{~ns}$ ), $\mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$

## A) READ OPERATION


B) DESELECTION OF DATA OUTPUT IN OR-TIE OPERATION


## Typical Characteristics



OUTPUT SINK CURRENT VS. OUTPUT VOltage

access time vs. LOAD CAPACITANCE


OUTPUT CURRENT VS. TEMPERATURE


IdD CURRENT VS. TEMPERATURE


ACCESS TIME VS. TEMPERATURE


# 2K (256 x 8) UV ERASABLE LOW POWER PROM 

| Part No. | MAXIMUM <br> ACCESS $(\mu s)$ | tDVGG ( $\mu s)$ |
| :---: | :---: | :---: |
| 1702AL | 1.0 | 0.4 |
| 1702AL-2 | 0.65 | 0.3 |

## - Clocked Vgg Mode for Low Power Dissipation

- Fast Programming: 2 Minutes for all 2048 Bits


## - All 2048 Bits Guaranteed* Programmable: 100\% Factory Tested

The 1702AL is a 256 word by 8 bit electrically programmable ROM and is the same chip as the industry standard 1702A. The programming and erasing specifications are identical to the 1702 A . The 1702 AL operates with the $\mathrm{V}_{\mathrm{GG}}$ clocked to reduce the power dissipation.

Initially all 2048 bits of the 1702AL are in the " 0 " state (output low). Information is introduced by selectively programming " 1 "s (output high) in the proper bit location. The 1702AL is packaged in a 24 pin dual in-line package with a transparent lid. The transparent lid allows the user to expose the 1702AL to ultraviolet light to erase the bit pattern. A new pattern can then be written into the device.

The 1702AL is fabricated with silicon gate technology. This low threshold technology allows the design and production of high performance MOS circuits and provides a higher functional density on a monolithic chip than conventional MOS technologies.
*Intel's liability shall be limited to replacing any unit which fails to program as desired.

## - Inputs and Outputs DTL and TTL 휼 Compatible

- Three-State Output: OR-tie Capability

> PIN CONFIGURATION
> -THIS PIN IS THE DATA INPUT LEAD DURING PROGRAMMING
> PIN NAMES

BLOCK DIAGRAM


NOTE: In the read mode a logic 1 at the address inputs and data outputs is a high and logic 0 is a low.

## PIN CONNECTIONS

The external lead connections to the 1702AL differ, depending on whether the device is being programmed or used in read mode (see following table). In the programming mode, the data inputs 1-8 are pins 4-11 respectively. The programming voltages and timing are shown in the Data Catalog ROM and PROM Programming Instructions section.

| PIN | 12 <br> $\left(\mathrm{~V}_{\mathrm{CC}}\right)$ | 13 <br> $($ Program $)$ | 14 <br> $(\mathrm{CS})$ | 15 <br> $\left(\mathrm{~V}_{\mathrm{BB}}\right)$ | 16 <br> $\left(\mathrm{~V}_{\mathrm{GG}}\right)$ | 22 <br> $\left(\mathrm{~V}_{\mathrm{CC}}\right)$ | $\mathbf{2 3}$ <br> $\left(\mathrm{V}_{\mathrm{CC}}\right)$ | $\mathbf{2 4}$ <br> $\left(\mathrm{V}_{\mathrm{DD}}\right)$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Read | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | GND | $\mathrm{V}_{\mathrm{CC}}$ | Clocked $\mathrm{V}_{\mathrm{GG}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{DD}}$ |
| Programming | GND | Program Pulse | GND | $\mathrm{V}_{\mathrm{BB}}$ | Pulsed $\mathrm{V}_{\mathrm{GG}}$ | GND | GND | Pulsed $\mathrm{V}_{\mathrm{DD}}$ |

## Absolute Maximum Ratings*

Ambient Temperature Under Bias . . . . . . $-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Soldering Temperature of Leads ( 10 sec ) . . . . . . . $+300^{\circ} \mathrm{C}$
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 2 Watts
Read Operation: Input Voltages and Supply
Voltages with respect to $\mathrm{V}_{\mathrm{CC}}$. . . . . . . . . +0.5 V to -20 V
Program Operation: Input Voltages and Supply
Voltages with respect to $\mathrm{V}_{\mathrm{CC}}$. . . . . . . . . . . . . . . . -48V

## *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 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 \%, \mathrm{~V}_{\mathrm{DD}}=-9 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{GG}}[1]=-9 \mathrm{~V} \pm 5 \%$, unless otherwise noted.

 READ OPERATION| Symbol | Test | 1702AL Limits |  |  | 1702AL-2 Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ.[2] | Max. | Min. | Typ. [2] | Max. |  |  |
| ILI | Address and Chip Select Input Load Current |  |  | 1 |  |  | 1 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.0 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | 1 |  |  | 1 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}, \overline{\mathrm{CS}}=\mathrm{V}_{\text {CC }}-2$ |
| $\mathrm{IDDO1}^{\text {[1] }}$ | Power Supply Current |  | 7 | 10 |  | 7 | 10 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \overline{C S}=\mathrm{V}_{1 H}, \mathrm{~V}_{G G}=\mathrm{V}_{C C}$, |
| IDDO2 | Power Supply Current |  |  | 15 |  |  | 15 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \quad \mathrm{lOL}=0.0 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{DD1}}{ }^{[1]}$ | Power Supply Current |  | 35 | 50 |  | 35 | 50 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{CC}}-2, \mathrm{I}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| IDD2 | Power Supply Current |  | 32 | 46 |  | 32 | 46 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=0.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| $I_{\text {DD3 }}$ | Power Supply Current |  | 38 | 60 |  | 38 | 60 | mA | $\begin{aligned} & \overline{\overline{C S}}=\mathrm{V}_{\mathrm{CC}}-2, \mathrm{I}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| ICF1 | Output Clamp Current |  | 8 | 14 |  | 5.5 | 8 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=-1.0 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| ICF2 | Output Clamp Current |  | 7 | 13 |  | 5 | 7 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{OUT}}=-1.0 \mathrm{~V}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| $\mathrm{I}_{\mathrm{GG}}$ | Gate Supply Current |  |  | 1 | - |  | 1 | $\mu \mathrm{A}$ |  |
| $V_{\text {IL1 }}$ | Input Low Voltage for TTL Interface | -1 |  | 0.65 | -1 |  | 0.65 | V |  |
| $\mathrm{V}_{\text {IL2 }}$ | Input Low Voltage for MOS Interface | $V_{\text {DD }}$ |  | $\mathrm{V}_{\mathrm{Cc}}{ }^{-6}$ | $\mathrm{V}_{\mathrm{DD}}$ |  | $\mathrm{V}_{\mathrm{cc}}{ }^{-6}$ | V |  |
| $\mathrm{V}_{\mathbf{I H}}$ | Address and Chip Select Input High Voltage | $\mathrm{V}_{\mathrm{cc}}-2$ |  | $\mathrm{V}_{\mathrm{cc}}+0.3$ | $\mathrm{V}_{\mathrm{CC}}-2$ |  | $\mathrm{V}_{\mathrm{cc}}{ }^{+0.3}$ | V |  |
| lOL | Output Sink Current | 1.6 | 4 |  | 1.6 | 4 |  | mA | $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}$ |
| IOH | Output Source Current | -2.0 |  |  | -2.0 |  |  | mA | $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | -3 | 0.45 |  | -3 | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 3.5 | 4.5 |  | 3.5 | 4.5 |  | V | $\mathrm{IOH}^{\prime}=-200 \mu \mathrm{~A}$ |

NOTES: 1. The 1702AL is operated with the $V_{G G}$ clocked to obtain low power dissipation. The average IDD will vary between IDD0 and IDD1 (at $25^{\circ} \mathrm{C}$ ) depending on the $\mathrm{V}_{G G}$ duty cycle (see curve opposite). 2. Typical values are at nominal voltage and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

TYPICAL 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}}=-9 \mathrm{~V} \pm 5 \%$ unless otherwise noted

| Symbol | Test | 1702AL <br> Limits <br> Max. |  | 1702AL-2 <br> Limits <br> Min. |
| :--- | :--- | :---: | :---: | :---: |
| Max. | Unit |  |  |  |
| Freq. | Repetition Rate | 1 | 1.6 | MHz |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to output delay | 1 | 0.65 | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{DV}} \mathrm{MG}_{\mathrm{GG}}$ | Clocked $\mathrm{V}_{\mathrm{GG}}$ set up | 0.4 | 0.3 | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{CS}}$ | Chip select delay | 0.1 | 0.3 | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{CO}}$ | Output delay from $\overline{\mathrm{CS}}$ |  | 0.9 | 0.35 |
| $\mathrm{t}_{\mathrm{OD}}$ | Output deselect | $\mu \mathrm{s}$ |  |  |
| $\mathrm{t}_{\mathrm{OHC}}$ | Data out hold in clocked $\mathrm{V}_{\mathrm{GG}}$ mode | 0.3 | 0.3 | $\mu \mathrm{~s}$ |

CAPACITANCE $T_{A}=25^{\circ} \mathrm{C}$

| SYMBOL | TEST | TYPICAL | MAXIMUM | UNIT | CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 8 | 15 | pF | _{\mathrm{IN}}}$=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 10 | 15 | pF |  |
| $\mathrm{C}_{\mathrm{V}_{\mathrm{GG}}}$ | $\mathrm{V}_{\mathrm{GG}}$ Capacitance <br> (Note 1) |  | 30 | pF | AlI <br> unused pins <br> $\mathrm{V}_{\mathrm{GG}}$ |

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

## SWITCHING CHARACTERISTICS

## Conditions of Test:

Input pulse amplitudes: 0 to $4 \mathrm{~V} ; \mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}} \leqslant 50 \mathrm{~ns}$
Output load is 1 TTL gate; measurements made at output of $T T L$ gate ( $t_{P D} \leqslant 15 \mathrm{~ns}$ ), $C_{L}=15 p F$

## A. READ OPERATION


B. DESELECTION OF DATA OUTPUT IN OR-TIE OPERATION


## 2316E

## - Fast Access Time-450 ns Max. <br> - Single +5V $\pm 10 \%$ Power Supply

- Intel MCS 80 and 85 Compatible


## - Three Programmable Chip Selects for Simple Memory Expansion and System Interface

- EPROM/ROM Pin Compatible for Cost-Effective System Development
- Completly Static Operation
- Inputs and Outputs TTL Compatible

\author{

- Three-State Output for Direct <br> Bus Interface
}

The Intel ${ }^{\circledR} 2316$ E 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 2316 E 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 MCS ${ }^{\top}{ }^{\top}$ - 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 2616 PROM and 2316E ROM for production. The three 2316E 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


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

$\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 | 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 |
| ILOH | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | Chip Deselected, $\mathrm{V}_{\text {Out }}=4.0 \mathrm{~V}$ |
| ILOL | Output Leakage Current |  |  | -20 | $\mu \mathrm{A}$ | Chip Deselected, $\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}$ |
| Icc | 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}_{\text {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 | PARAMETER | 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. CHARACTERISTICSOutput Load . . . . . . . . . . 1 TTL Gate and $C_{L}=100 \mathrm{pF}$
Input Pulse Levels . . . . . . . . . . . . 0.8 to 2.4 V
Input Pulse Rise and Fall Times $(10 \%$ to $90 \%) \ldots .{ }^{20 \mathrm{~ns}}$
Timing Measurement Reference Level
Input . . . . . . . . . . . . . . . . . . . . . . . 1 V and 2.2 V
Output . . . . . . . . . . . . . . 0.8 V and 2.0 V
Output . . . . . . . . . . . . . . . . . . . . . . . 0.8 V and 2.0V

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 |
| C OUT | 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

 CHIP SELECTS

## Typical System Application (8K $\times 8$ ROM Memory)



## 2332A <br> 32K (4K $\times 8$ ) ROM

- Single $+5 \mathrm{~V} \pm 10 \%$ Power Supply
- Pin for Pin Compatible with the Intel ${ }^{\text {® }}$ 2716 and 2732 EPROMs
- Low Power Dissipation:


## 150 mA Max Active Current

 30 mA Max Standby Current- Completely Static Operation
- Inputs and Outputs TTL Compatible
- Three-State Output for Direct Bus Interface
- MCS-85 ${ }^{\text {TM }}$ and MCS. $86^{\text {TM }}$ Compatible
- Independent Output Enable Function

The Intel ${ }^{\left({ }^{(0)}\right)} 2332 \mathrm{~A}$ is a single +5 V supply, 32,768 -bit N -channel MOS read only memory organized as 4096 words by 8 -bits. The 2332 A has a static standby mode which reduces the active power dissipation by more than $75 \%$.

The 2332A is ideal for microprocessor systems, especially those with common input and output bus structures. The separate output control, $\overline{O E}$, eliminates bus contention. Three-state outputs and TTL input/output levels further simplify system design.
A cost effective system development program may be implemented by using the pin compatible Intele $2732,32 \mathrm{~K}$ UV EPROM for prototyping and the 2332A ROM for volume production. The 2732 is pin for pin compatible to the 2332A in all respects.

## PIN CONFIGURATION



## BLOCK DIAGRAM



PIN NAMES

| $A_{0}-A_{11}$ | ADDRESSES |
| :--- | :--- |
| $C E$ | CHIP ENABLE |
| $\overline{O E}$ | OUTPUT ENABLE |
| $O_{0}-07$ | OUTPUTS |

2364A
$64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ BIT ROM

Single $+5 \mathrm{~V} \pm 10 \%$ Power Supply
Pin Compatible to Intel ${ }^{\circledR} 2732$ EPROM
Completely Static Operation

## Static Standby Mode

- Inputs and Outputs TTL Compatible
- Independent Output Enable Function
- Three-State Output for Direct Bus Interface
- MCS-85 and MCS-86 Compatible

The Intel ${ }^{\circledR} 2364 \mathrm{~A}$ is a single $+5 \mathrm{~V}, 65,536$-bit N -channel MOS read only memory organized as 8192 words by 8 bits and is pin and function compatible with the 2732 UV EPROM. Its high bit density is ideal for large, non-volatile data storage, such as program storage. The three-state outputs and TTL input/output levels allow for direct interface with common bus structures. The 2364A has a static standby mode which reduces the active power dissipation by over 75\%.

A cost-effective system development program may be implemented by using the Intel ${ }^{\circledR} 2732$ 32K UV EPROM for prototyping and the 2364A ROM for production. The lower 24 pins of the 2364A are the same as the 2732 to facilitate board designs in making the transition from EPROM to ROM.

PIN CONFIGURATION


BLOCK DIAGRAM


PIN NAMES

| $A_{0}-A_{12}$ | ADDRESSES |
| :--- | :--- |
| $O E$ | OUTPUT ENABLE |
| $C E$ | CHIP ENABLE |
| $C S$ | CHIP SELECT |
| N.C. | NO CONNECTION |

2608

## 8K (1K $\times 8$ ) FACTORY PROGRAMMABLE PROM

Fast Access Time - 450 ns Max.<br>Pin Compatible to 2708 EPROM<br>Static - No Clocks Required

- Data Inputs and Outputs TTL Compatible
- Three-State Outputs - OR-Tie
Capability

The Intel ${ }^{\circledR} 2608$ is a 8192 -bit, one-time factory-programmable MOS PROM organized as 1 K words by 8 bits. The electrical characteristics are specified over the $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ operating temperature range with $5 \%$ power supply variation. The 2608 features are ideally suited for microprocessor systems: 450 ns maximum access time, three-state outputs for common bussing, and TTL inputs/outputs for easy interfacing. The 2608 is fully compatible to the 2708 in all respects.

PIN CONFIGURATION


BLOCK DIAGRAM


PIN NAMES

| $A_{0} \cdot A_{9}$ | ADDRESS INPUTS |
| :--- | :--- |
| $O_{1} \cdot O_{8}$ | DATA OUTPUTS/INPUTS |
| $\overline{C S}$ | CHIP SELECT/WRITE ENABLE INPUT |

MODE SELECTION

|  | PIN NUMBER |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | DATA I/O 9.11 13.17 | ADDRESS INPUTS 1.8, 22,23 | $\begin{aligned} & \mathrm{v}_{\mathrm{ss}} \\ & 12 \end{aligned}$ | $\begin{gathered} V_{D D} \\ 19 \end{gathered}$ | $\begin{aligned} & \overline{C S} \\ & 20 \end{aligned}$ | $\begin{aligned} & V_{B B} \\ & 21 \end{aligned}$ | $\begin{gathered} \mathrm{v}_{\mathrm{cc}} \\ 24 \end{gathered}$ |
| READ | Dout | AIN | GND | +12 | $\mathrm{V}_{\mathrm{IL}}$ | -5 | +5 |
| DESELECT | HIGH IMPEDANCE | DON'T CARE | GND | +12 | $\mathrm{V}_{\mathrm{IH}}$ | -5 | +5 |


| 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}$ |
| $V_{D D}$ With Respect to $V_{B B}$ | +20 V to -0.3 V |
| $V_{C C}$ and $V_{S S}$ With Respect to $V_{B B}$ | +15 V to -0.3 V |
| All Input or Output Voltages With Respect |  |
| to $V_{B B}$ | +15 V to -0.3 V |

## Absolute Maximum Ratings*

Storage Temperature
$V_{D D}$ With Respect to $V_{B B}$. . . . . . . . . . . . . . . . . . . . . . +20 V to -0.3 V

All Input or Output Voltages With Respect
to $V_{B B}$
+15 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.

## 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 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}{ }^{[1]}=-5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Min. | Typ. ${ }^{[2]}$ | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{L I}$ | 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.5 \mathrm{~V}, \overline{\mathrm{CS}} / \mathrm{WE}=5 \mathrm{~V}$ |
| $\mathrm{IDD}^{[3]}$ | $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}$ |
| $\mathrm{ICC}^{[3]}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 6 | 10 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}{ }^{[3]}$ | $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{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | 3.7 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-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. $V_{B B}$ must be applied prior to $V_{C C}$ and $V_{D D} . V_{B B}$ must also be the last power supply switched off.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. The total power dissipation is specified at 800 mW . It is not calculated by summing the various currents (IDD, ${ }^{\prime} C C$, and $\mathrm{I}_{\mathrm{BB}}$ ) multiplied by their respective voltages since current paths exist between the various power supplies and $\mathrm{V}_{\mathrm{SS}}$. The $I_{D D}, I_{C C}$, and I ${ }_{B B}$ currents should be used to determine power supply capacity only.

## Typical Characteristics

MAXIMUM JUNCTION TEMPERATURE VS. AMBIENT TEMPERATURE


## RANGE OF SUPPLY CURRENTS

VS. TEMPERATURE


ACCESS TIME 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 \%, \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 |  | Limits |  | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 280 | 450 | ns |
| $t_{C O}$ | Chip Select to Output Delay |  | 60 | 120 | $n$ |
| $t_{D F}$ | Chip Deselect to Output Float | 0 |  | 120 | ns |
| $t_{\mathrm{OH}}$ | Address to Output Hold | 0 |  |  | ns |

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

| Symbol | Parameter | Typ. | Max. | Unit. | Conditions |
| :--- | :--- | :---: | :---: | :--- | :--- |
| $\mathrm{C}_{\mathrm{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: 1. This parameter is periodically sampled and is not $100 \%$ tested.

## A.C. TEST CONDITIONS:

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$ Input Rise and Fall Times: $\leqslant 20$ ns
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



2708/8708* 8K AND 4K UV ERASABLE PROM

|  | Max. Power | Max. Access | Organization |
| :--- | :---: | :---: | :---: |
| 2708 | 800 mW | 450 ns | $1 \mathrm{~K} \times 8$ |
| 2708 L | 425 mW | 450 ns | $1 \mathrm{~K} \times 8$ |
| $2708-1$ | 800 mW | 350 ns | $1 \mathrm{~K} \times 8$ |
| 2704 | 800 mW | 450 ns | $512 \times 8$ |

- Low Power Dissipation - 425 mW Max. (2708L)


## ■ Fast Access Time - $\mathbf{3 5 0}$ ns Max. (2708-1)

## - Static - No Clocks Required

- Data Inputs and Outputs TTL Compatible during both Read and Program Modes


## - Three-State Outputs - OR-Tie Capability

The Inte| ${ }^{\circledR} 2708$ is a 8192 -bit ultraviolet light erasable and electrically reprogrammable EPROM, ideally suited where fast turnaround and pattern experimentation are important requirements. All data inputs and outputs are TTL compatible during both the read and program modes. The outputs are three-state, allowing direct interface with common system bus structures.

The 2708 L at 425 mW is available for systems requiring lower power dissipation than from the 2708. A power dissipation savings of over $50 \%$, without any sacrifice in speed, is obtained with the 2708L. The 2708L has high input noise immunity and is specified at $10 \%$ power supply tolerance. A high-speed $2708-1$ is also available at 350 ns for microprocessors requiring fast access times. For smaller size systems there is the 4096 -bit 2704 which is organized as 512 words by 8 bits. All these devices have the same programming and erasing specifications of the 2708. The 2704 electrical specifications are the same as the 2708.
The 2708 family is fabricated with the N-channel silicon gate FAMOS technology and is available in a 24-pin dual in-line package.

PIN CONFIGURATION


NOTE 1: PIN 22 MUST BE CONNECTED TO VSS FOR THE 2704.

## PIN NAMES

| $A_{0} \cdot A_{9}$ | ADDRESS INPUTS |
| :--- | :--- |
| $O_{1} \cdot O_{8}$ | DATA OUTPUTS/INPUTS |
| CS/WE | CHIP SELECT/WRITE ENABLE INPUT |



PIN CONNECTION DURING READ OR PROGRAM

|  | PIN NUMBER |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | $\begin{gathered} \text { DATA I/O } \\ 9-11, \\ 13-17 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { ADDRESS } \\ & \text { INPUTS } \\ & 1-8, \\ & 22,23 \\ & \hline \end{aligned}$ | $\begin{gathered} V_{\mathrm{Ss}} \\ 12 \end{gathered}$ | PROGRAM $18$ | $\begin{gathered} V_{D D} \\ 19 \end{gathered}$ | $\overline{\mathrm{CS}} / \mathrm{WE}$ <br> 20 | $\begin{gathered} V_{B B} \\ 21 \end{gathered}$ | $\begin{array}{r} V_{c c} \\ 24 \end{array}$ |
| READ | DOUT | AIN | GND | GND | +12 | $\mathrm{V}_{\mathrm{IL}}$ | -5 | +5 |
| DESELECT | HIGH IMPEDANCE | DON'T CARE | GND | GND | +12 | $\mathrm{V}_{\mathrm{IH}}$ | -5 | +5 |
| PROGRAM | DIN | AIN | GND | PUI_SED 26 V | +12 | VIHW | -5 | +5 |

## PROGRAMMING

The programming specifications are described in the Data Catalog PROM/ROM Programming Instructions Section.
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}$
$V_{D D}$ With Respect to $V_{B B}$. . . . . . . . . . . . . . . . . . . . . . +20 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 . . . . . . . . . . . . . . . . . . . . . . . +20V to -0.3V

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.

## DC and AC Operating Conditions During Read

|  | $\mathbf{2 7 0 8}$ | $\mathbf{2 7 0 8 - 1}$ | $\mathbf{2 7 0 8 \mathrm { L }}$ |
| :---: | :---: | :---: | :---: |
| Temperature Range | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ Power Supply | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{~V}_{\text {DD }}$ Power Supply | $12 \mathrm{~V} \pm 5 \%$ | $12 \mathrm{~V} \pm 5 \%$ | $12 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{~V}_{\text {BB }}$ Power Supply | $-5 \mathrm{~V} \pm 5 \%$ | $-5 \mathrm{~V} \pm 5 \%$ | $-5 \mathrm{~V} \pm 10 \%$ |

## READ OPERATION

D.C. and Operating Characteristics

| Symbol | Parameter | 2708, 2708-1 Limits |  |  | 2708L Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[2]}$ | Max. | Min. | Typ. ${ }^{[2]}$ | Max. |  |  |
| ILI | Address and Chip Select Input Sink Current |  | 1 | 10 |  | 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 |  | 1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}, \mathrm{CS} / \mathrm{WE}=5 \mathrm{~V}$ |
| IDD [3] | VDD Supply Current |  | 50 | 65 |  | 21 | 28 | mA | Worst Case Supply Currents ${ }^{[4]}$ |
| Icc[3] | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 6 | 10 |  | 2 | 4 | mA | All inputs High; |
| ${ }^{\text {IBB [3] }}$ | $\mathrm{V}_{\text {BB }}$ Supply Current |  | 30 | 45 |  | 10 | 14 | mA | $\overline{C S} / W E=5 V ; T_{A}=0^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $\mathrm{v}_{\text {SS }}$ |  | 0.65 | $\mathrm{V}_{\text {SS }}$ |  | 0.65 | v |  |
| $\underline{V_{\text {IH }}}$ | Input High Voltage | 3.0 |  | $\mathrm{v}_{\mathrm{cc}}{ }^{+1}$ | 2.2 |  | $v_{\text {cc }}+1$ | v |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage | 0.45 |  |  | 0.4 |  |  | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}(2708,2708-1)$ |
|  |  |  |  |  | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ (2708L) |  |  |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage | 3.7 |  |  |  |  |  | 3.7 |  |  | v | $\mathrm{IOH}^{\prime}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage | 2.4 |  |  | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| PD | Power Dissipation |  |  | 800 |  |  | 325 | mW | $\mathrm{T}_{\mathrm{A}}=70^{\circ} \mathrm{C}$ |
|  |  |  |  |  |  |  | 425 | mW | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |

NOTES: 1. $V_{B B}$ must be applied prior to $V_{C C}$ and $V_{D D} . V_{B B}$ must also be the last power supply switched off
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. The total power disiipation is not calculated by summing the various currents ( ${ }^{\mathrm{DD}}{ }^{\prime} \mathrm{I}^{\mathrm{CC}}$, and $\mathrm{I}_{\mathrm{BB}}$ ) multiplied by their respective voltages since current paths exist between the various power supplies and $V_{S S}$. The $I_{D D}$, $I_{C C}$, and $I_{B B}$ currents should be used to determine power supply capacity only
4. $I_{B B}$ for the 2708 L is specified in the programmed state and is 18 mA maximum in the unprogrammed state.

2708L
RANGE OF SUPPLY CURRENTS
VS. TEMPERATURE


2708 AND 2708-1
RANGE OF SUPPLY CURRENTS

## VS. TEMPERATURE



ACCESS TIME VS. TEMPERATURE


## A. C. Characteristics

| Symbol | Parameter |  | 2708-1 Limits <br> Typ. |  |  | 2708, 2708L, Limits <br> Typ. |  | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Mddress to Output Delay |  | 280 | 350 |  | 280 | 450 | ns |  |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Select to Output Delay |  | 60 | 120 |  | 60 | 120 | ns |  |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip Deselect to Output Float | 0 |  | 120 | 0 |  | 120 | ns |  |
| $\mathrm{t}_{\mathrm{OH}}$ | Address to Output Hold | 0 |  |  | 0 |  |  | ns |  |

CAPACITANCE ${ }^{[1]} \quad \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}$ |

## A.C. TEST CONDITIONS:

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$ Input Rise and Fall Times: $\leqslant 20$ ns
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

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

## Waveforms



## ERASURE CHARACTERISTICS

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

The recommended erasure procedure (see Data Catalog PROM/ROM Programming Instructions Section) for the 2708 family is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity $X$ exposure time) for erasure should be a minimum of 15 W -sec $/ \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 device should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.

## 2716 $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ UV ERASABLE PROM

\author{

- Fast Access Time <br> - 350 ns Max. 2716-1 <br> - 390 ns Max. 2716-2 <br> - 450 ns Max. 2716
}


## - Single + 5V Power Supply

\author{

- Low Power Dissipation - 525 mW Max. Active Power <br> - 132 mW Max. Standby Power
}


## - Pin Compatible to Intel ${ }^{\left({ }^{\circ} 5 \mathrm{~V}\right.}$ ROMs (2316E, 2332A, and 2364A) and 2732 EPROM

- Simple Programming Requirements
Single Location Programming
Programs with One 50 ms Pulse
- Inputs and Outputs TTL Compatible during Read and Program
- Completely Static

The Intel ${ }^{(®)} 2716$ is a 16,384 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 2716 operates from a single 5 -volt power supply, has a static standby mode, and features fast single address location programming. It makes designing with EPROMs faster, easier and more economical. For production quantities, the 2716 user can convert rapidly to Intel's pin-for-pin compatible 16 K ROM (the 2316 E ) or the new 32 K and 64 K ROMs (the 2332 A and 2364A respectively).
The 2716 , with its single 5 -volt supply and with an access time up to 350 ns , is ideal for use with the newer high performance +5 V microprocessors such as Intel's 8085 and 8086 . The 2716 is also the first EPROM with a static standby mode which reduces the power dissipation without increasing access time. The maximum active power dissipation is 525 mW while the maximum standby power dissipation is only 132 mW , a $75 \%$ savings.

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

PIN CONFIGURATION


PIN NAMES

| $A_{0}-A_{10}$ | ADDRESSES |
| :--- | :--- |
| $\overline{C E} / P G M$ | CHIP ENABLE/PROGRAM |
| $\overline{O E}$ | OUTPUT ENABL.E |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | OUTPUTS |

MODE SELECTION

|  | $\overline{\text { CE/PGM }}$ <br> (18) | $\begin{gathered} \overline{\mathrm{CE}} \\ (20) \end{gathered}$ | $V_{\text {Pp }}$ <br> (21) | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}} \\ & \text { (24) } \end{aligned}$ | OUTPUTS $(9.11,13.17)$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | VIL | +5 | +5 | Dout |
| Standby | $\mathrm{V}_{\text {IH }}$ | Don't Care | +5 | +5 | High Z |
| Program | Pulsed $V_{\text {IL }}$ to $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{1} \mathrm{H}$ | +25 | +5 | DIN |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +25 | +5 | Dout |
| Program Inhibit | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | High Z |

BLOCK DIAGRAM


## PROGRAMMING

The programming specifications are described in the Data Catalog PROM/ROM Programming Instructions Section.

## 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
$V_{\text {pp }}$ Supply Voltage with Respect to Ground During Program . . . . . . . +26.5 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.

DC and AC Operating Conditions During Read

|  | $\mathbf{2 7 1 6}$ | $\mathbf{2 7 1 6 - 1}$ | $2716-\mathbf{2}$ |
| :---: | :---: | :---: | :---: |
| Temperature Range | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ Power Supply ${ }^{[1,2]}$ | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 10 \%$ | $5 \mathrm{~V} \pm 5 \%$ |
| $\mathrm{~V}_{\text {PP }}$ Power Supply ${ }^{[2]}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |

## READ OPERATION

## D.C. and Operating Characteristics

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[3]}$ | Max. |  |  |
| $I_{\text {LI }}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ |
| Ito | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.25 \mathrm{~V}$ |
| $\mathrm{IPP} 1[2]$ | Vpp Current |  |  | 5 | mA | $\mathrm{V}_{\mathrm{PP}}=5.25 \mathrm{~V}$ |
| $\mathrm{ICC1}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Standby) |  | 10 | 25 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{I H}, \overline{\mathrm{OE}}=\mathrm{V}_{I L}$ |
| $\mathrm{ICC2}^{[2]}$ | $\mathrm{V}_{\mathrm{CC}}$ Current (Active) |  | 57 | 100 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\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. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. This parameter is only sampled and is not $100 \%$ tested.

## Typical Characteristics



## A.C. Characteristics

| Symbol | Parameter | 2716 Limits |  |  | 2716-1 Limits |  |  | 2716-2 Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{[3]}$ | Max | Min | Typ ${ }^{[3]}$ | Max | Min | Typ ${ }^{[3]}$ | Max |  |  |
| ${ }^{\text {t }} \mathrm{ACC}$ | Address to Output Delay |  |  | 450 |  |  | 350 |  |  | 390 | ns | $\overline{\mathrm{CE}}=\overrightarrow{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\text {t }}$ CE | $\overline{\mathrm{CE}}$ to Output Delay |  |  | 450 |  |  | 350 |  |  | 390 | ns | $\overline{O E}=V_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{OE}$ | Output Enable to Output Delay |  |  | 120 |  |  | 120 |  |  | 120 | ns | $\overline{C E}=V_{\text {IL }}$ |
| ${ }^{\text {t }}$ DF | Output Enable High to Output Float | 0 |  | 100 | 0 |  | 100 | 0 |  | 100 | ns | $\overline{C E}=V_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{OH}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{O E}$ Whichever Occurred First | 0 |  |  | 0 |  |  | 0 |  |  | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |

Capacitance ${ }^{[4]} \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 }}=\mathrm{OV}$ |

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

## A. C. Waveforms [1]



NOTE: 1. VCC 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 $I_{C C}$ and $I_{P P 1}$.
3. Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. This parameter is only sampled and is not $100 \%$ tested.
5. $\overline{\bar{O} E}$ may be delayed up to $t_{A C C}^{--}{ }^{\text {t }}$ OE after the falling edge of $\overline{C E}$ without impact on $t_{A C C}$.
6. ${ }^{t} D F$ is specified from $\overline{O E}$ or $\overline{C E}$, whichever occurs first.


- This scheme accomplished by using $\overline{C E}(P D)$ as the primary decode. $\overline{O E}(C S)$ is now controlled by previously unused signal. RD now controls data on and off the bus by way of $\overline{\mathrm{OE}}$.
- A selected 2716 is available for systems which require $\overline{C E}$ access of less than 450 ns for decode network operation.
- The use of a PROM as a decoder allows for:
a) Compatibility with upward (and downward) memory expansion.
b) Easy assignment of ROM memory modules, compatible with PLM modular software concepts.



## 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 Data Catalog PROM/ROM Programming Instruction Section) 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 five modes of operation of the 2716 are listed in Table I. It should be noted that all inputs for the five modes are at TTL levels. The power supplies required are $a+5 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$ and a $V_{\text {Pp }}$. The $V_{\text {Pp }}$ power supply must be at 25 V during the three programming modes, and must be at 5 V in the other two modes.

> TABLEI. MODE SELECTION

|  | $\overline{C E} / P G M$ <br> (18) | $\begin{gathered} \overline{O E} \\ (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 |
| Standby | $V_{1 H}$ | Don't Care | +5 | +5 | High Z |
| Program | Pulsed $\mathrm{V}_{\text {IL }}$ to $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | DIN |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +25 | +5 | Dout |
| Program Inhibit | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | High Z |

## READ MODE

The 2716 has two control functions, both of which must be logically satisfied in order to obtain data at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{EE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{C E}$ to output ( $t_{C E}$ ). Data is available at the outputs 120 ns ( $\mathrm{t}_{\mathrm{OE}}$ ) after the falling edge of $\overline{\mathrm{OE}}$, assuming that $\overline{\mathrm{CE}}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.

## STANDBY MODE

The 2716 has a standby mode which reduces the active power dissipation by $75 \%$, from 525 mW to 132 mW . The 2716 is placed in the standby mode by applying a TTL high signal to the $\overline{\mathrm{CE}}$ input. When in standby mode, the outputs are in a high impedence state, independent of the $\overline{\mathrm{OE}}$ input.

## OUTPUT OR-TIEING

Because 2716's are usually used in larger memory arrays, Intel has provided a 2 line control function that accomodates this use of multiple memory connections. The two line control function allows for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that $\overline{\mathrm{CE}}$ (pin 18) be decoded and used as the primary device selecting function, while $\overline{O E}$ (pin 20) be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their active when data is desired from a particular memory device.

## PROGRAMMING

Initially, and after each erasure, all bits of the 2716 are in the " 1 " state. Data is introduced by selectively programming " 0 's" into the desired bit locations. Although only " 0 's" will be programmed, both " 1 ' $s$ " and " 0 ' $s$ " can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.
The 2716 is in the programming mode when the $V_{\text {pp }}$ power supply is at 25 V and $\overline{\mathrm{OE}}$ 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 address and data are stable, a 50 msec , active high, TTL program pulse is applied to the $\overline{\mathrm{CE}} / \mathrm{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 $\overline{\mathrm{CE}} / \mathrm{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 $\overline{\mathrm{CE}} / \mathrm{PGM}$ input programs the paralleled 2716s.

## PROGRAM INHIBIT

Programming of multiple 2716s in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}} / \mathrm{PGM}$, all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel 2716s may be common. A TTL level program pulse applied to a 2716's $\overline{\mathrm{CE}} / \mathrm{PGM}$ input with $\mathrm{V}_{\mathrm{PP}}$ at 25 V will program that 2716. A low level $\overline{C E} / P G M$ input inhibits the other 2716 from being programmed.

## PROGRAM VERIFY

A verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed wth $\mathrm{V}_{\mathrm{PP}}$ at 25 V . Except during programming and program verify, $V_{\text {Pp }}$ must be at 5 V .

Single $+5 \mathrm{~V} \pm 5 \%$ Power Supply<br>■ Output Enable for MCS-85 ${ }^{\text {™ }}$ and MCS-86 ${ }^{\text {TM }}$ Compatibility<br>- Fast Access Time: 450ns Max.<br>Low Power Dissipation:<br>150mA Max. Active Current 30mA Max. Standby Current

## - Pin Compatible to Intel® 2716 EPROM and 2332/2364 ROMs

- Completely Static
- Simple Programming Requirements - Single Location Programming - Programs with One 50ms Pulse
- Three-State Output for Direct Bus Interface

The Intel ${ }^{\circledR} 2732$ is a 32,768 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 2732 operates from a single 5-volt power supply, has a standby mode, and features an output enable control. For production, the pin compatible 2332 and 2364 ROMs are available. The total programming time for all bits is three and a half minutes. All these features make designing with the 2732 in microcomputer systems faster, easier, and more economical.
An important 2732 feature is the separate output control, Output Enable ( $\overline{\mathrm{OE}}$ ), from the Chip Enable control ( $\overline{\mathrm{CE}}$ ). The $\overline{\mathrm{OE}}$ control eliminates bus contention in multiple bus microprocessor systems. Intel's Application Note AP-30 describes the microprocessor system implementation of the $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}}$ controls on Intel's 2716 and 2732 EPROMs. AP-30 is available from Intel's Literature Department.
The 2732 has a standby mode which reduces the power dissipation without increasing access time. The maximum active current is 150 mA , while the maximum standby current is only 30 mA , an $80 \%$ savings. The standby mode is achieved by applying a TTL-high signal to the $\overline{\mathrm{CE}}$ input.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{11}$ | ADDRESSES |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | CHIP ENABLE |
| $\overline{\mathrm{OE}}$ | OUTPUT ENABLE |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | OUTPUTS |

MODE SELECTION

| PINS <br> MODE | $\begin{aligned} & \overline{C E} \\ & (18) \end{aligned}$ | $\begin{gathered} \overline{O E} / V_{P P} \\ (20) \end{gathered}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{Cc}} \\ & (24) \end{aligned}$ | $\begin{aligned} & \text { OUTPUTS } \\ & (9-11,13-17) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | Dout |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | Don't Care | +5 | High Z |
| Program | $V_{\text {IL }}$ | VPP | +5 | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | DOUT |
| Program Inhibit | $V_{\text {IH }}$ | VPP | +5 | High Z |

## BLOCK DIAGRAM



## PROGRAMMING

The programming specifications are described in the Data Catalog PROMIROM Programming Instructigns Seotion:

## 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
*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 \%$

## READ OPERATION

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{\text {[1] }}$ | Max. |  |  |
| ILII | Input Load Current (except $\overline{\mathrm{OE}} / \mathrm{VPPP}^{\text {) }}$ |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ |
| ILI2 | $\overline{\text { OE/VPP Input Load Current }}$ |  |  | 300 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | VOUT $=5.25 \mathrm{~V}$ |
| Icc1 | Vcc Current (Standby) |  | 15 | 30 | mA | $\overline{C E}=V_{I H}, \overline{O E}=V_{I L}$ |
| Icc2 | Vcc Current (Active) |  | 85 | 150 | mA | $\overline{O E}=\overline{C E}=V_{I L}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| VIH | Input High Voltage | 2.0 |  | $\mathrm{Vcc}+1$ | V |  |
| VOL | Output Low Voltage |  |  | 0.45 | V | $\mathrm{IOL}=2.1 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | V | $1 \mathrm{OH}=-400 \mu \mathrm{~A}$ |

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

## TYPICAL CHARACTERISTICS

Icc CURRENT
vs. TEMPERATURE

$\overline{\text { Ce }}$ TO OUTPUT DELAY ( $\mathbf{t}_{\text {CE }}$ ) vs. CAPACITANCE

$\overline{C E}$ TO OUTPUT DELAY ( $\mathrm{t}_{\mathrm{CE}}$ ) VS. TEMPERATURE


## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. |  |  |
| $t_{\text {Acc }}$ | Address to Output Delay |  |  | 450 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |
| tce | $\overline{\mathrm{CE}}$ to Output Delay |  |  | 450 | ns | $\mathrm{OE}=\mathrm{V}_{\mathrm{IL}}$ |
| toe | Output Enable to Output Delay |  |  | 120 | ns | $\overline{C E}=V_{I L}$ |
| tDF | Output Enable High to Output Float | 0 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |
| tor | Address to Output Hold | 0 |  |  | ns | $\overline{C E}=\overline{O E}=V_{I L}$ |

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

| Symbol | Parameter | Typ. | Max. | Unit | Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\text {IN } 1}$ | Input Capacitance <br> Except $\overline{\mathrm{OE} / V_{P P}}$ | 4 | 6 | pF | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ |
| CIN2 | $\overline{\mathrm{OE}} / \mathrm{V}_{\text {PP }}$ Input <br> Capacitance |  | 20 | pF | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ |
| COUT | Output Capacitance |  | 12 | pF | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ |

## A.C. TEST CONDITIONS

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$ Input Rise and Fall Times: $\leq 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
A.C. WAVEFORMS ${ }^{[3]}$


NOTES:

1. TYPICAL VALUES ARE FOR $T_{A}=25^{\circ} \mathrm{C}$ AND NOMINAL SUPPLY VOLTAGES
2. THIS PARAMETER IS ONLY SAMPLED AND IS NOT $100 \%$ TESTED.
3. ALL TIMES SHOWN IN PARENTHESES ARE MINIMUM TIMES AND ARE NSEC UNLESS OTHERWISE SPECIFIED.
4. $\overline{O E}$ MAY BE DELAYED UP TO 330ns AFTER THE FALLING EDGE OF $\overline{C E}$ WITHOUT IMPACT ON $t_{A C C}$ -
5. $\mathrm{I}_{\mathrm{DF}}$ IS SPECIFIED FROM $\overline{O E}$ OR $\overline{C E}$, WHICHEVER OCCURS FIRST.

# 2758 <br> 8K ( $1 \mathrm{~K} \times 8$ ) UV ERASABLE LOW POWER PROM 

- Single +5 V Power Supply
- Simple Programming Requirements Single Location Programming Programs with One 50 ms Pulse

Low Power Dissipation<br>525 mW Max. Active Power 132 mW Max. Standby Power

Fast Access Time: 450 ns Max. in Active and Standby Power Modes

- Inputs and Outputs TTL Compatible during Read and Program
- Completely Static
- Three-State Outputs for OR-Ties

The Intel ${ }^{\circledR} 2758$ is a 8192 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 2758 operates from a single 5 -volt power supply, has a static standby mode, and features fast single address location programming. It makes designing with EPROMs faster, easier and more economical. The total programming time for all 8192 bits is 50 seconds.
The 2758 has a static standby mode which reduces the power dissipation without increasing access time. The maximum active power dissipation is 525 mW , while the maximum standby power dissipation is only 132 mW , a $75 \%$ savings. Powerdown is achieved by applying a TTL-high signal to the $\overline{\mathrm{CE}}$ input.
A 2758 system may be designed for total upwards compatibility with Intel's 16K 2716 EPROM (see Applications Note 30). The 2758 maintains the simplest and fastest method yet devised for programming EPROMs - single pulse TTLlevel programming. There is no need for high voltage pulsing because all programming controls are handled by TTL signals. Program any location at any time - either individually, sequentially, or at random, with the single address location programming.

PIN CONFIGURATION

| A7 ${ }^{1}$ | 24 |
| :---: | :---: |
| $\mathrm{A}_{6} \mathrm{C}_{2}$ | 23 |
| ${ }^{4} 5$ | 22 |
| $\mathrm{A}_{4} \mathrm{C}_{4}$ | 21 |
| $\mathrm{A}_{3} \mathrm{C}_{5}$ | 20 |
| $\mathrm{A}_{2} \mathrm{C}^{6}$ | 19 |
| $\mathrm{A}_{1} 7$ | 18 |
| $\mathrm{A}_{0} \mathrm{O}^{8}$ | 17 |
| $0_{0}{ }^{\text {a }}$ | 16 |
| 01010 | 15 |
| $\mathrm{O}_{2}{ }^{11}$ | 14 |
| GND 12 | 13 |

PIN NAMES

| $A_{0}-A_{9}$ | ADDRESSES |
| :--- | :--- |
| $\overline{C E / P G M}$ | CHIP ENABLE/PROGRAM |
| $\overline{\overline{O E}}$ | OUTPUT ENABLE |
| $O_{0}-O_{7}$ | OUTPUTS |
| $A_{7}$ | SELECT REFERENCE <br> INPUT LEVEL |

MODE SELECTION

| PINS <br> MODE | $\overline{\mathrm{CE}} / \mathrm{PGM}$ <br> (18) | $\begin{aligned} & A_{R} \\ & (19) \end{aligned}$ | $\begin{aligned} & \overline{O E} \\ & (20) \end{aligned}$ | $\begin{aligned} & V_{P P} \\ & (21) \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}} \\ & (24) \end{aligned}$ | $\begin{aligned} & \text { OUTPUTS } \\ & (9-11,13-17) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$. | $\mathrm{V}_{\text {IL }}$ | +5 | +5 | Dout |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | $V_{\text {IL }}$ | $\begin{aligned} & \text { Don't } \\ & \text { Care } \end{aligned}$ | +5 | +5 | High Z |
| Program | Pulsed $\mathrm{V}_{\mathrm{IL}}$ to $\mathrm{V}_{\mathrm{IH}}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | $\mathrm{D}_{\mathrm{IN}}$ |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | +25 | +5 | Dout |
| Program Inhibit | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | High Z |

## BLOCK DIAGRAM



## PROGRAMMING

The programming specifications are described in the Data Catalog PROMIROM Programming Instructions section.

## 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 . . . . . . . . . . . . . . . +6V to -0.3 V
VPp Supply Voltage with Respect
to Ground During Programming
+26.5 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}}$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[3]}$ | Max. |  |  |
| $I_{L I}$ | 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.25 \mathrm{~V}$ |
| $\mathrm{CCC1}^{12]}$ | $\mathrm{V}_{\text {cc }}$ Current (Standby) |  | 10 | 25 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{ICC2}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Active) |  | 57. | 100 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $A_{R}{ }^{[4]}$ | Select Reference Input Level | -0.1 |  | 0.8 | V | $\mathrm{I}_{\text {IN }}=10 \mu \mathrm{~A}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\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. VCC must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$.
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. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. $A_{R}$ is a reference voltage level which requires an input current of only $10 \mu \mathrm{~A}$. The 2758 S 1865 is also available which has a reference voltage level of $\mathrm{V}_{I H}$ instead of $\mathrm{V}_{\mathrm{IL}}$.

## Typical Characteristics

Icc CURRENT
TEMPERATURE


ACCESS TIME
vs.
CAPACITANCE


ACCESS TIME
vs.
TEMPERATURE


## A.C. Characteristics

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

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[3]}$ | Max. |  |  |
| ${ }^{\text {t }}$ ACC | Address to Output Delay |  | 250 | 450 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\text {t }}$ CE | CE to Output Delay |  | 280 | 450 | ns | $\overline{O E}=V_{\text {IL }}$ |
| toe | Output Enable to Output Delay |  |  | 120 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |
| $t_{\text {DF }}$ | Output Enable High to Output Float | 0 |  | 100 | ns | $\overline{C E}=V_{1 L}$ |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold From Addresses, $\overline{\mathrm{CE}}$ or OE Whichever Occurred First | 0 |  |  | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |

Capacitance ${ }^{[4]} \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.

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

$$
\begin{array}{ll}
\text { Inputs } & 1 \mathrm{~V} \text { and } 2 \mathrm{~V} \\
\text { Outputs } & 0.8 \mathrm{~V} \text { and } 2 \mathrm{~V}
\end{array}
$$

## A.C. Waveforms ${ }^{[5]}$



NOTES: 1. $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$
2. $\mathrm{V}_{\mathrm{PP}}$ may be connected directly to $\mathrm{V}_{\mathrm{CC}}$ except during programming. The supply current would then be the sum of ICC and IPP1
3. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. This parameter is only sampled and is not $100 \%$ tested.

5 All times shown in parentheses are minımum times and are nsec unless otherwise specified.
$6 \overline{\mathrm{OE}}$ may be delayed up to 330 ns after the falling edge of $\overline{\mathrm{CE}}$ without impact on taCC
7. ${ }^{t} D F$ is specified from $\overline{O E}$ or $\overline{C E}$, whichever occurs first

## ERASURE CHARACTERISTICS

The erasure characteristics of the $\mathbf{2 7 5 8}$ 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 2758 in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 2758 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 2758 window to prevent unintentional erasure.

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

## DEVICE OPERATION

The five modes of operation of the 2758 are listed in Table 1. It should be noted that all inputs for the five modes are at TTL levels. The power supplied required are a $+5 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$ and a $\mathrm{V}_{\text {PP }}$. The $\mathrm{V}_{\text {PP }}$ power supply must be at 25 V during the two programming modes, and must be at 5 V in the other three modes. In all operational modes, $A_{R}$ must be at $V_{\text {IL }}$ (except for the 2758 S 1865 which has $A_{R}$ at $V_{I H}$ ).

TABLE I. MODE SELECTION

| PINS <br> MODE | $\overline{\text { CE/PGM }}$ <br> (18) | $A_{R}$ <br> (19) | $\overline{\mathrm{OE}}$ $(20)$ | $\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 }}$ | $\mathrm{V}_{\mathrm{HL}}$ | $V_{\text {IL }}$ | +5 | +5 | Dout |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | $V_{\text {IL }}$ | Don't Care | +5 | +5 | High $\mathbf{Z}$ |
| Program | Pulsed $\mathrm{V}_{\text {IL }}$ to $\mathrm{V}_{\text {IH }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | +25 | +5 | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +25 | +5 | Dout |
| Program Inhibit | $V_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | +25 | +5 | High Z |

## READ MODE

The 2758 has two control functions, both of which must be logically satisfied in order to obtain data at the outputs. Chip Enable $(\overline{\mathrm{CE}})$ is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE})}$ is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $\mathrm{t}_{\mathrm{ACC}}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at
the outputs 120 ns ( $\mathrm{t}_{\mathrm{OE}}$ ) after the falling edge of $\overline{\mathrm{OE}}$, assuming that $\overline{\mathrm{CE}}$ has been low and addresses have been stable for at least $t_{A C C}-t_{O E}$.

## STANDBY MODE

The 2758 has a standby mode which reduces the active power dissipation by $75 \%$, from 525 mW to 132 mW . The 2758 is placed in the standby mode by applying a TTL high signal to $\overline{\mathrm{CE}}$ input. When in standby mode, the outputs are in a high impedence state, independent of the OE input.

## OUTPUT OR-TIEING

Because EPROMs are usually used in larger memory arrays, Intel has provided a 2 line control function that accommodates this use of multiple memory connections. The two line control function allows for:
a) the lowest possible memory Power dissipation, and
b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that $\overline{C E}$ (pin 18) be decoded and used as the primary device selecting function, while $\overline{\mathrm{OE}}$ (pin 20) be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby mode and that the output pins are only active when data is desired from a particular memory device.

## PROGRAMMING

Initially, and after each erasure, all bits of the 2758 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 2758 is in the programming mode when the $\mathrm{V}_{\mathrm{PP}}$ power supply is at 25 V and $\overline{\mathrm{OE}}$ 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 address and data are stable, a 50 msec , active high, TTL program pulse is applied to the $\overline{\mathrm{CE}} / \mathrm{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 2758 must be programmed with a DC signal applied to the $\overline{\mathrm{CE}} / \mathrm{PGM}$ input.
Programming of multiple 2758s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the parallelled 2758s may be connected together when they are programmed with the same data. A high level TTL pulse applied to the $\overline{\mathrm{CE}} / \mathrm{PGM}$ input programs the paralleled 2758s.

## PROGRAM INHIBIT

Programming of multiple 2758s in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}} / \mathrm{PGM}$, all like inputs(including $\overline{\mathrm{OE}}$ ) of the parallel 2758s may be common. A TTL level program pulse applied to a 2758 's $\overline{\mathrm{CE}} / \mathrm{PGM}$ input with $\mathrm{V}_{\mathrm{Pp}}$ at 25 V will program that 2758. A low level $\overline{C E} / P G M$ input inhibits the other 2758 from being programmed.

## PROGRAM VERIFY

A verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed with $V_{\text {PP }}$ at 25 V . Except during programming and program verify, $\mathrm{V}_{\mathrm{PP}}$ must be at 5 V .

# 3604A, 3624A FAMILY 4K (512 $\times 8$ ) HIGH-SPEED PROM 

|  | $3604 \mathrm{~A}-2$ <br> $3624 \mathrm{~A}-2$ | 3604 A <br> 3624 A | 3604AL |
| :--- | :---: | :---: | :---: |
| Max. $\mathrm{T}_{\mathrm{A}}(\mathrm{ns})$ | 60 | 70 | 90 |
| Max. $\mathrm{ICC}(\mathrm{mA})$ | 170 | 170 | $130 / 25^{*}$ |

## *Standby Current When The Chip is Deselected.

## - Fast Access Time --6Ons Max (3604A-2, 3624A-2)

- Low Standby Power Dissipation (3604AL) -- $32 \mu$ W/Bit Max


## - Open Collector (3604A)

 or Three State (3624A) Outputs- Four Chip Select Inputs For Easy Memory Expansion
- Polycrystalline Silicon Fuse For Higher Reliability
- Hermetic 24 Pin DIP

The Intel ${ }^{\circledR}$ 3604A/3624A are 4096-bit bipolar PROMs organized as 512 words by 8 bits. The fast second generation 3604A/3624A replaces its Intel predecessor, the 3604/3624. Higher speed PROMs, the 3604A-2/3624A-2, are now available at 60 ns . All 3604A/3624A specifications, except programming, are the same as or better than the 3604/3624. Once programmed, the 3604A/3624A are interchangeable with the 3604/3624

The PROMs are manufactured with all outputs initially logically high. Logic low levels can be electrically programmed in selected bit locations. Both open collector and three-state outputs are available. Low standby power dissipation can be achieved with the 3604 AL . The standby power dissipation is approximately $20 \%$ of the active power dissipation.

The 3604A/3624A are available in a hermetic 24 -pin dual in-line package. These PROMs are manufactured with the time-proven polycrystalline silicon fuse technology.

| Mode/Pin Connection |  | Pin 22 | Pin 24 |
| :---: | :---: | :---: | :---: |
| READ: | $\begin{aligned} & 3604 A, 3604 A-2 \\ & 3624 \mathrm{~A}, 3624 \mathrm{~A}-2 \end{aligned}$ | No Connect or 5 V | 5 V |
|  | 3604AL | +5V | Must be Left Open |
| PROGRAM: | $\begin{aligned} & 3604 \mathrm{~A}, 3604 \mathrm{~A}-2 \\ & 3624 \mathrm{~A}, 3624 \mathrm{~A}-2 \end{aligned}$ | Pulsed 12.5V | Pulsed 12.5V |
|  | 3604 AL | Pulsed 12.5V | Pulsed 12.5V |
| STANDBY | 3604 AL | Power dissipation is automatically reduced whenever the 3604AL is deselected. |  |

(LSB)


LOGIC SYMBOL


## PROGRAMMING

The programming specifications are described in the Data Catalog PROM/ROM Programming Instructions

## Absolute Maximum Ratings*

| Temperature Under Bias | $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ |
| Output or Supply Voltages | -0.5V to 7 Volts |
| All Input Voltages | -1.6 to 5.5V |
| Output Currents | 100 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.
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. ${ }^{17}$ | Max. |  |  |
| $\mathrm{I}_{\text {FA }}$ | Address Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| $I_{\text {FS }}$ | Chip Select Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $I_{\text {RA }}$ | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RS }}$ | Chip Select Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {CA }}$ | Address Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{A}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {CS }}$ | Chip Select Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{S}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA}$ |
| ICEX | Output Leakage Current |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=5.25 \mathrm{~V}, \mathrm{~V}_{\text {CE }}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | Power Supply Current (3604A, 3604A-2, 3624A, and 3624A-2) |  | 130 | 170 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC} 1}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{AO} \rightarrow \mathrm{~V}_{\mathrm{A} 8}=0 \mathrm{~V},} \\ & \mathrm{CS}_{1}=\mathrm{CS}_{2}=0 \mathrm{~V}, \mathrm{CS}_{3}=\mathrm{CS}_{4}=5.25 \mathrm{~V} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Power Supply Current (3604AL) Active |  | 100 | 130 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC} 2}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC} 1}=\text { Open } \\ & \mathrm{CS}_{1}=\overline{\mathrm{CS}}_{2}=0.45 \mathrm{~V}, \mathrm{CS}_{3}=\mathrm{CS}_{4}=2.4 \mathrm{~V} \end{aligned}$ |
|  | Standby |  | 15 | 25 | mA | $\overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=2.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |

3624A FAMILY ONLY

| Symbol | Parameter | Min. | Typ.[1] | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{II}_{\mathrm{O}} \mathrm{I}$ | Output Leakage for High <br> Impedance Stage |  |  | 100 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{O}}=5.25 \mathrm{~V}$ or 0.45 V, <br> $\mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=2.4 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{SC}}{ }^{[2]}$ | Output Short Circuit Current | -20 | -25 | -70 | mA | $\mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |

NOTES: 1. Typical values are at $25^{\circ} \mathrm{C}$ and at nominal voltage.
2. Unmeasured outputs are open during this test.
A. Characteristics $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAXIMUM LIMITS (ns) |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { 3604A-2 } \\ & 3624 A-2 \end{aligned}$ | $\begin{aligned} & \text { 3604A } \\ & 3624 A \end{aligned}$ | 3604AL |  |  |
| $\begin{aligned} & t_{\mathrm{A}++}, \mathrm{t}_{\mathrm{A}--} \\ & \mathrm{t}_{\mathrm{A}+-}, \mathrm{t}_{\mathrm{A}-+} \end{aligned}$ | Address to Output Delay | 60 | 70 | 90 | ns | $\begin{aligned} & \overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=\mathrm{V}_{1 \mathrm{~L}} \\ & \text { and } \mathrm{CS}_{3}=\mathrm{CS}_{4}=V_{1 H} \end{aligned}$ to Select the PROM |
| $\mathrm{t}_{\mathrm{S}++}$ | Chip Select to Output Delay | 30 | 30 | 30 | ns |  |
| $\mathrm{t}_{\text {S-- }}$ | Chip Select to Output Delay | 30 | 30 | 120 | ns |  |

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

| SYMBOL | PARAMETER | LIMITS |  | UNIT | TEST CONDITIONS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. |  |  |  |
| $C_{\text {INA }}$ | Address Input Capacitance | 4 | 10 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| Cins | Chip-Select Input Capacitance | 6 | 10 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| Cout | Output Capacitance | 7 | 15 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

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

## Switching Characteristics

## Conditions of Test:

Input pulse amplitudes
2.5 V

Input pulse rise and fall times of
5 nanoseconds between 1 volt and 2 volts Speed measurements are made at 1.5 volt levels Output loading is 15 mA and 30 pF
Frequency of test -2.5 MHz

15 mA TEST LOAD


## Waveforms

ADDRESS TO OUTPUT DELAY


CHIP SELECT TO OUTPUT DELAY


# 3605A, 3625A <br> 4K (1K $\times 4$ ) PROM 

| $3605 A-1,3625 A-1$ | 50 ns Max. |
| :--- | :--- |
| $3605 A, 3625 A$ | 60 ns Max. |

- $\pm 10 \%$ Power Supply Tolerance
- Fast Access Time: 40 ns Typically
- Lower Power Dissipation: 0.14 mW/Bit Typically


## - Simple Memory Expansion Two Chip Select Inputs

- Open Collector (3605A) and Three-State (3625A) Outputs
- Polycrystalline Silicon Fuse for Higher
Reliability

\author{

- Hermetic 18-Pin DIP
}

The Intel ${ }^{\circledR}$ 3605A and 3625A families are high density, 4096-bit bipolar PROMs organized as 1024 words by 4 bits. The 1024 by 4 organization gives ideal word or bit modularity for memory array expansion. The 3605A has open collector outputs and the 3625A has three-state outputs. The 3605A and 3625A are fully specified over the $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ temperature range with $\pm 10 \%$ power supply variation. Maximum access times of 50 ns (3605A-1/3625A-1) and 60 ns (3605A/3625A) are available at a typical power dissipation of $0.14 \mathrm{~mW} / \mathrm{bit}$.

The 3605A/3625A are packaged in an 18 -pin dual in-line hermetic package with 300 milli-inch centers. Thus, twice the bit density can be achieved with the 3605A/3625A in the same memory board areas as 512 by 8 -bit PROMs in 24 -pin packages.
The highly reliable polycrystalline silicon fuse technology is used in the manufacturing of the 3605A and 3625A families. All outputs are initially a logical high and logic low levels can be electrically programmed in selected bit locations.

BLOCK DIAGRAM


The programming specifications are described in the Data Catalog PROM/ROM Programming Instructions.

## Absolute Maximum Ratings*

Temperature Under Bias $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ Output or Supply Voltages . . . . . . . . . $\quad-0.5 \mathrm{~V}$ to 7 Volts All Input Voltages . . . . . . . . . . . . . . . . . - 1 IV to 5.5 V Output Currents . . . . . . . . . . . . . . . . . . . . . . . 100mA

## *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 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. | Unit |  |
| $I_{\text {FA }}$ | Address Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| $I_{\text {FS }}$ | Chip Select Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RA }}$ | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.5 \mathrm{~V}$ |
| ins | Chip Select Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.5 \mathrm{~V}$ |
| $V_{C A}$ | Address Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{C C}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{A}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {cs }}$ | Chip Select Input Clamp Voltage |  | -0.9 | -1.5 | V | $V_{C C}=4.5 \mathrm{~V}, I_{S}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA}$ |
| ICEX | 3605A Output Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=5.5 \mathrm{~V}, \mathrm{~V}_{\text {CE }}=5.5 \mathrm{~V}$ |
| ICC | Power Supply Current |  | 110 | 140 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{AO}} \rightarrow \mathrm{~V}_{\mathrm{A} 9}=0 \mathrm{~V}, \\ & \mathrm{CS}_{1}=\overline{C S}_{2}=\mathrm{V}_{1 \mathrm{H}} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V |  |

3625, 3625-1 ONLY

| Symbol | Parameter | Min. | Typ. ${ }^{11]}$ | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{II}_{\mathrm{O}} \mathrm{I}$ | Output Leakage for High <br> Impedance Stage |  |  | 40 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V}$ or 0.45 V, <br> $\mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=2.4 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{SC}}{ }^{[1]}$ | Output Short Circuit Current | -20 | -35 | -80 | mA | $\mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |

NOTES: 1. Unmeasured outputs are open during this test.
A. C. Characteristics $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$

| Symbol | Parameter | Max. Limits |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { 3605A-1 } \\ & 3625 A-1 \end{aligned}$ | $\begin{aligned} & \text { 3605A } \\ & \text { 3625A } \end{aligned}$ |  |  |
| $\begin{aligned} & t_{\mathrm{A}++}, \mathrm{t}_{\mathrm{A}--} \\ & \mathrm{t}_{\mathrm{A}+-}, \mathrm{t}_{\mathrm{A}-+} \end{aligned}$ | Address to Output Delay | 50 | 60 | ns | $\begin{aligned} & \overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=\mathrm{V}_{1 \mathrm{~L}} \\ & \text { to select the } \\ & \text { PROM. } \end{aligned}$ |
| ${ }_{\text {t }}^{\text {S + }}$ + | Chip Select to Output Delay | 30 | 30 | ns |  |
| ts-- | Chip Select to Output Delay | 30 | 30 | ns |  |

Capacitance ${ }^{(1)} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | LIMITS |  | UNIT | TEST CONDITIONS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. |  |  |  |
| $C_{\text {INA }}$ | Address Input Capacitance | 3 | 8 | pF | $V_{C C}=5 \mathrm{~V}$ | $V_{\text {IN }}=2.5 \mathrm{~V}$ |
| CINS | Chip-Select Input Capacitance | 4 | 8 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| Cout | Output Capacitance | 5 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

NOTE 1: This parameter is only periodicaliy sampled and is not $100 \%$ tested.

## Switching Characteristics

## Conditions of Test:

Input pulse amplitudes - 2.5 V
Input pulse rise and fall times of
5 nanoseconds between 1 volt and 2 volts
Speed measurements are made at 1.5 volt levels Output loading is 15 mA and 30 pF Frequency of test -2.5 MHz

## Waveforms

ADDRESS TO OUTPUT DELAY


CHIP SELECT TO OUTPUT DELAY


3628
8K (1K X 8) BIPOLAR PROM

| 3628 | 80 ns Max. |
| :--- | ---: |
| $3628-4$ | 100 ns Max. |

Fast Access Time: 65 ns Typically
Low Power Dissipation: 0.09mW/Bit Typically

- Four Chip Select Inputs for Easy Memory
Expansion
- Three-State Outputs
- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability

The Intel ${ }^{\otimes} 3628$ is a fully decoded 8192 -bit PROM organized as 1024 words by 8 bits. The worst case access time of 80 ns is specified over the $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ temperatue range and $5 \% \mathrm{~V}_{\mathrm{CC}}$ power supply tolerances. There are four chip selects provided to facilitate expansion into larger PROM arrays. It uses Schottky clamped TTL technology with polycrystalline silicon fuses. All outputs are initially high and logic low levels can be electrically programmed in selected bit locations.
Prior to the 8192 bit 3628 , the highest density bipolar PROM available was 4096 bits. The high density of the 3628 now easily doubles the capacity without an increase in area on existing designs currently using 512 words by 8 bit PROMs. There is also little, if any, penalty in power since the 3628 power/bit is approximately one-half that of 4 K PROMs. The 3628 is packaged in a hermetic 24 -pin dual in-line package.


PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{9}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{\mathrm{CS}}_{1}-\overline{\mathrm{CS}}_{2}$ |  |
| $\mathrm{CS}_{3}-\mathrm{CS}_{4}$ |  |
| $\mathrm{O}_{1}-\mathrm{O}_{8}$ | DATA OUTP SELECT INPUTS ${ }^{[1]}$ |

[1] To select the PROM $\overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=\mathrm{V}_{\mathrm{IL}}$ and $\mathrm{CS}_{3}=\mathrm{CS}_{4}=\mathrm{V}_{\mathrm{IH}}$

## PROGRAMMING

The programming specifications are described in the PROM programming section of the Data Catalog.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ Output or Supply Voltages . . . . . . . . . -0.5 V to 7 Volts All Input Voltages . . . . . . . . . . . . . . . . . . - -1 V to 5.5 V
Output Currents 100 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.
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 |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. | Unit |  |
| $I_{F A}$ | Address Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {FS }}$ | Chip Select Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RA }}$ | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.25 \mathrm{~V}$ |
| $I_{\text {RS }}$ | Chip Select Input Leakge Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.0 \mathrm{~V}$ |
| $\|10\|$ | Output Leakge for High Impedance State |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=5.25 \mathrm{~V} \text { or } 0.45 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{CS}_{1}=\mathrm{CS}_{2}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{[2]}$ | Output Short Circuit Current | -20 | -25 | -80 | mA | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {CA }}$ | Address Input Clamp Voltage |  | -0.9 | $-1.5$ | V | $\mathrm{V}_{C C}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{A}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {CS }}$ | Chip Select Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{S}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | 3.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 150 | 190 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A} 0} \rightarrow \mathrm{~V}_{\mathrm{A} 9}=0 \mathrm{~V}$ <br> PROM deselected |
| $\mathrm{V}_{\mathrm{IL}}$ | Input "Low" Voltage |  |  | 0.85 | V | $\mathrm{V}_{\text {CC }}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |

NOTES: 1. Typical values are at $25^{\circ} \mathrm{C}$ and at nominal voltage. 2 Unmeasured outputs are open during this test.
A.C. CHARACTERISTICS $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX. LIMITS |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3628 | 3628-4 |  |  |
| $\mathrm{t}_{\text {A }}$ | Address to Output Delay | 80 | 100 | ns | $\overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=\mathrm{V}_{1 \mathrm{~L}}$ |
| $\mathrm{t}_{\mathrm{EN}}$ | Output Enable Time | 40 | 45 | ns | and $\mathrm{CS}_{3}=\mathrm{CS}_{4}=\mathrm{V}_{1 H}$ |
| ${ }_{\text {tis }}$ | Output Disable Time | 40 | 45 | ns | to select the PROM. |

CAPACITANCE ${ }^{(1)} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | TYP. LIMITS |  | UNIT | TEST CONDITIONS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. |  |  |  |
| $\mathrm{C}_{\text {INA }}$ | Address Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| Cins | Chip-Select Input Capacitance | 6 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{1 \mathrm{~N}}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 7 | 15 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

NOTE 1: This parameter is only periodically sampled and is not $100 \%$ tested.

## SWITCHING CHARACTERISTICS

## Conditions of Test:

Input pulse amplitudes - 2.5 V
Input pulse rise and fall times of
5 nanoseconds between 1 volt and 2 volts Speed measurements are made at 1.5 volt levels Output loading is 15 mA and 30 pF
Frequency of test -2.5 MHz

15mA TEST LOAD


## WAVEFORMS

ADDRESS TO OUTPUT DELAY


CHIP SELECT TO OUTPUT DELAY


3636
$16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ BIPOLAR PROM

| $3636-1$ | 65 ns Max. |
| :--- | :--- |
| 3636 | 80 ns Max. |

## Fast Access Time: $\mathbf{5 0}$ ns Typically

- Low Power Dissipation: 0.05 mW/Bit Typically


## - Three Chips Select Input for Easy Memory Expansion

## - Three-State Outputs

## - Hermetic 24-Pin DIP

## Polycrystalline Silicon Fuses for Higher Fuse Reliability

The Intel ${ }^{\circledR} 3636$ is a fully decoded 16,384 bit PROM organized as 2048 words by 8 bits. The worst case access time of 65 ns is specified over the $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ temperature range and $10 \% \mathrm{~V}_{\mathrm{Cc}}$ power supply tolerances. There are three chip selects provided to facilitate expansion into larger PROM arrays. The PROMs use the Schottky clamped TTL technology with polycrystalline silicon fuses. All outputs are initially high and logic low levels can be electrically programmed in selected bit locations.

Prior to the 16,384 bit 3636 , the highest density bipolar PROM available was 8192 bits. The high density of the 3636 now easily doubles the capacity without an increase in area on existing designs currently using 1024 by 8 bit PROMs. There is also little, if any, penalty in power since the power/bit is approximately one-half that of 8 K PROMs. The 3636 is packaged in a hermetic 24-pin dual in-line package.

## PIN CONFIGURATION



BLOCK DIAGRAM


LOGIC SYMBOL


PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{10}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{\mathrm{CS}}_{1}, \mathrm{CS}_{2}, \mathrm{CS}_{3}$ | CHIP SELECT INPUTS ${ }^{(1)}$ |
| $\mathrm{O}_{1}-\mathrm{O}_{8}$ | DATA OUTPUTS |

(1) | To select the PROM $\overline{\mathrm{CS}}_{1}=\mathrm{V}_{\mathrm{IL}}$ and |
| :--- |
| $\mathrm{CS}_{2}=\mathrm{CS}_{3}=\mathrm{V}_{1 \mathrm{H}}$ |

PROGRAMMING
The programming specifications are described in the PROM Programming Section of the Data Catalogue.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias
$-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$
Output or Supply Voltages . . . . . . . . . -0.5 V to 7 Voits
All Input Voltages . . . . . . . . . . . . . . . . . . - 1 V to 5.5 V
Output Currents . . . . . . . . . . . . . . . . . . . . . . . 100 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.
D.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}$

| Symbol | Parameter | Limits |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. | Unit |  |
| $I_{\text {FA }}$ | Address Input Load Current |  | $-0.05$ | $-0.25$ | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| $I_{\text {FS }}$ | Chip Select Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $I_{\text {RA }}$ | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{RS}}$ | Chip Select Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.5 \mathrm{~V}$ |
| $\left\|\mathrm{I}_{0}\right\|$ | Output Leakage for High Impedance State |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V} \text { or } 0.45 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{CS}_{1}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{[2]}$ | Output Short Circuit Current | -20 | -35 | -80 | mA | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| $V_{C A}$ | Address Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{A}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {CS }}$ | Chip Select Input Clamp Voltage |  | -0.9 | $-1.5$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{S}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | 3.0 |  | V | $\mathrm{I}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 150 | 185 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ |

NOTES: 1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.

## A.C. CHARACTERISTICS <br> $V_{C C}= \pm 5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX. LIMITS |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3636-1 | 3636 |  |  |
| $\mathrm{t}_{\mathrm{A}}$ | Address to Output Delay | 65 | 80 | ns | $\overline{\mathrm{CS}}_{1}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{t}_{\mathrm{EN}}$ | Output Enable Time | 40 | 50 | ns | and $\mathrm{CS}_{2}=\mathrm{CS}_{3}=\mathrm{V}_{1 \mathrm{H}}$ |
| ${ }^{\text {t IIS }}$ | Output Disable Time | 40 | 50 | ns | to select the PROM. |

CAPACITANCE ${ }^{(1)} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | TYP. LIMITS |  | UNIT | TEST CONDITIONS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. |  |  |  |
| $\mathrm{C}_{\text {INA }}$ | Address Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| CINS | Chip-Select Input Capacitance | 6 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $V_{1 N}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 7 | 12 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

NOTE 1: This parameter is only periodically sampled and is not $100 \%$ tested.

## SWITCHING CHARACTERISTICS

## Conditions of Test:

Input pulse amplitudes: 2.5 V Input pulse rise and fall times of 5 nanoseconds between 1 volt and 2 volts
Speed measurements are made at 1.5 volt levels Output loading is 10 mA and 30 pF Frequency of test: 2.5 MHz


## WAVEFORMS

## ADDRESS TO OUTPUT DELAY



CHIP SELECT TO OUTPUT DELAY


## PROM AND ROM PROGRAMMING INSTRUCTIONS

## TABLE OF CONTENTS

Page No.
I. PROM AND ROM INPUT FORMATS ..... 4-49
A. Acceptable Formats ..... 4-49
B. Paper Tape Format ..... 4-50

1. Intellec Hex ..... 4-50
2. BPNF ..... 4-51
3. Non-Intellec Hex ..... 4-52
C. Computer Punched Card Format ..... 4-52
4. Intellec Hex ..... 4-52
5. PN ..... 4-54
D. Custom PROM/ROM Order Forms ..... 4-55
6. MOS EPROMs ..... 4-56
7. $8741,8748,8755$. ..... 4-56
8. 2316E, 2616, 8316A ..... 4-57
9. $8041,8048,8049$ ..... 4-58
10. 2608 ..... $4-59$
11. 8355 ..... 4-60
12. Bipolar PROMs ..... 4-61
13. 4001 ..... 4-62
14. 4308 ..... 4-64
15. 8021 ..... 4-65
16. 8022 ..... 4-66
II. MOS EPROMs ..... 4-67
A. Erasure Procedure. ..... 4-67
17. UV Sources ..... 4-67
B. 1702A/1702AL Family Programming ..... 4-68
C. 2708/2704 Programming. ..... 4-70
D. 2716 and 2758 Programming ..... 4-72
E. 2732 Programming ..... 4-73
III. BIPOLAR PROM PROGRAMMING ..... 4-75

## I. PROM AND ROM INPUT FORMATS

## A. Acceptible Formats

Intel can accept programming and masking information for PROMs, EPROMs, or ROMs in the form of floppy disk, punched paper tape, a master device from which to copy, or computer punched cards. The allowable formats are given in Table 1. The preferred formats for the paper tape and computer card input media 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 Formats

| Floppy Disk | Paper Tape | Computer Card | Master Device |
| :--- | :--- | :--- | :--- |
| - Intel Microcomputer <br> Development System <br> Single or Double <br> Density Disk <br> - Intellec Hex | $\bullet$ Intellec Hex | -Same Density and <br> Pin Compatible <br> to Device which <br> is to be Pro- <br> grammed. |  |

## A1. Logic Levels

All data field for Intel's EPROMs/PROMs/ROMs are positive logic. The only exceptions are the 4001 and 4308 ROMs which use negative logic. For the $4001 / 4308$, an " 0 " is a high output and a " 1 " is a low output. Consequently, because the BPNP format specifies the voltage level at the output of the device, it is necessary to input an " 0 " and " 1 " in the $4001 / 4308$ instruction code as a " $P$ " and " $N$ " respectively. However, for the Hex format, the 4001/4308 input should be specified according to the instruction code logic state, i.e., a " 1 " or " 0 ." The below example shows the corresponding input for 4001 instruction codes. For comparison, the input for an 8080A is also given as an example.

1. 4001 Instruction Code

| 4001 <br> Instruction <br> Mnemonic | Instruction <br> Code | Intellec Hex <br> Or Non-Intellec <br> Hex Input | BPNF <br> Input |
| :---: | :---: | :---: | :---: |
| NOP | $0000 \quad 0000$ | 00 | BPPPPPPPPF |
| WRM | $1110 \quad 0000$ | EO | BNNNPPPPPF |

2. 8080 A Instruction Code

| Instruction <br> Mnemonic | Instruction <br> Code | Intellec Hex <br> Or Non-Intellec <br> Hex Input | BPNF <br> Input |
| :---: | :---: | :---: | :---: |
| JMP | 11000011 | C3 | BPPNNNNPPF |
| Push D | 11010101 | D5 | BPPNPNPNPF |

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

## Inteilec Hex Example:

$$
\begin{aligned}
& : 10310000311 \text { A320E03117E31CD40003A9231B7C2EE } \\
& : 1031100060310 E 00117031 C D 40003 A 9231 B 7 C 2607 B \\
& : 10312000312 A 7 E 31227 A 310 E 03111 \mathrm{E} 31 \mathrm{CD} 40003 A B 0 \\
& : 103130009231 \mathrm{~B} 7 \mathrm{C} 260312 A 8 C 317 C B 5 C A 50310 E 044 \mathrm{D} \\
& : 10314000118831 \mathrm{CD} 40003 A 9231 \mathrm{~B} 7 \mathrm{C} 26031 \mathrm{C} 3273186 \\
& : 103150000 \mathrm{E} 01117 \mathrm{~A} 31 \mathrm{CD} 40000 \mathrm{E} 09119031 \mathrm{CD} 4000 \mathrm{~A} 1 \\
& : 103160000 \mathrm{C} 119231 \mathrm{CD} 40000 \mathrm{E} 09119031 \mathrm{CD} 40006 \mathrm{E} \\
& : 0 \mathrm{~A} 3170007 \mathrm{E} 3196310100000092311 \mathrm{~B} \\
& : 10317 \mathrm{C} 0092310100963180008 \mathrm{C} 31923100009631 \mathrm{~F} 1 \\
& : 04318 \mathrm{E} 0092319231 \mathrm{~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}=\mathbf{2 0 4 8}$ ):


Example of $512 \times 4$ format $(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_{H}$ to $05_{H}$, followed with "don't care" from addresses $06_{\mathrm{H}}$ to $25_{\mathrm{H}}$, data being entered again starting at address location $26_{\mathrm{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 N/8 or N/14 data cards for N words $x 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 $\times 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 |  |  |
| :---: | :---: | :---: |
| NO. OF OUTPUTS $4 \text { 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 |
| COMPANYNAME LOCATION P/N | 29-30 | Blank |
|  | 31-50 | Customer's Company Division or location |
| Stermilcs CCRF \% | 51-52 | Blank |
|  | 53-61 | Customer Part Number |
| 1 In int ill il | 62-63 | Blank |
| (1009180000 ${ }^{\text {a }}$ | 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 blank. |
| 6666666666666s616666668666666666666666666666666666156665666566666666666666666666 | 77-78 | Blank |
|  | 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. |

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_{\mathrm{HEX}}$ bytes (16 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 16 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}}$ " ( 16 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 $\times 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
THE TRUTH TA


 222222222222222222212222222222222122222222222222222222222 122222222222222222229


 66666666666666661666666166666666666666666666666666664666666666666666666666666666666 11711171111111111111117111111111111111111111111111111111111111111111111 8888888188888888888888888888888888888888888888888888888888888888888888888881月18888888


| Column | Data |
| :---: | :---: |
| 1 | Punch a T |
| 2-3 | Blank |
| 4-28 | Customer Company Name |
| 29-30 | Blank |
| 31-50 | Customer's Company Division or location |
| 51-52 | Blank |
| 53-61 | Customer Part Number |
| 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 blank. |
| 77-78 | Blank |
| 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. |

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

| $\text { MSB } \longrightarrow$ |  |  |  | binary coded location which begins each card. The address is right justified, i.e., ØøØøø, Øøøø8, Øøø 16, etc. |
| :---: | :---: | :---: | :---: | :---: |
| DECIMAL WORD |  | DECIMAL NUMBER | 6 | Blank |
| ADDRESS BEGINNING |  | INDICATING THE | 7-14 | Data Field |
| EACH CARD | 8 DATA FIELDS | TRUTH TABLE NUMBER | 15 | Blank |
| $\xrightarrow{\sim}$ |  | TRUTH TABLENUMBER | 16-23 | Data Field |
|  |  |  | 24 | Blank |
|  |  |  | 25-32 | Data Field |
|  |  |  | 33 | Blank |
| 11118000000000000000000000000000000000000000000000000000000000000000000000000011 |  |  | 34-41 | Data Field |
| 111111111111111111111111111111111111111111111111111111111111111111111 |  |  | 42 | Blank |
| 22222223222222222222222222222222222222222222222222222222222222222222222222222222 |  |  | 51 | Blank |
| 33333333333333333333333333333333333333333333333333333333333333333333333333333333 |  |  | 52-59 | Data Field |
| 4444444444444444444444444444404.144444444444444444444444444444444444444444444 |  |  | 60 | Blank |
|  |  |  | 61-68 | Data Field |
| i66666566666666666666666c6tb6b6t666666066666660666666666066606666666066666666666 |  |  | 69 | Blank |
|  |  |  | 70-77 | Data Field |
| 888888888886888888888888888888888887888888888888888888888888888888888888888888888888 |  |  | 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 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 |
| $8741,8748,8755$ |  |
| $2316 \mathrm{E}, 2616$ |  |
| $8041,8048,8049$ | A |
| 2608 | B |
| 8355 | C |
| Bipolar PROMs | D |
| 4001 | E |
| 4308 | F |
| 8021 | G |
| 8022 | H |
|  | I |

CUSTOMER EPROM ORDER FORM A

| Company  <br> Company Contact Phone \# <br> P.O. \# _  |
| :--- | :--- |

For Intel Use Only
S\#\#__
APP_
Date___ Data Catalog. Additional 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 . \mathrm{Z}$ ). The customer part number is limited to a maximum of 9 digits or spaces.

> 1702A MARKING EXAMPLE


## FLOPPY DISK

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk sent should also be indicated by checking one of the appropriate boxes:
$\square$ Single Density
$\square$ Double Density

## CUSTOMER PART NUMBER

Customer P/N
(Please Fill-In)

2. $\mid$
3. $L \perp|\perp| \perp|\perp| \perp \mid$
4. $L \perp|\perp| \perp|\perp| \perp \perp$
5. $\qquad$
L $\mid$
7. $\qquad$

9. $\qquad$
10. $|\perp| \perp|\perp| \perp|\perp|$
11. $\mid$
12. | $\mid$
13. $L \perp$
14. $|\perp| \perp|\perp| \perp|\perp| \perp$
15. $|\perp| \perp|\perp| \perp|\perp|$
16. $|\perp| \perp|\perp| \perp|\perp|$
17. $|\perp| \perp|\perp| \perp|\perp|$
18. $L \perp$
19.

Floppy Disk File Name
(Please Fill-In)
L $\mid$
2. $\qquad$
3. $\llcorner\perp \perp \perp \perp|\perp| \perp \perp \perp \perp$
4. $|\perp| \perp|\perp|$
5. $\qquad$
6. $\qquad$
7.
8. L
9.
10. $|\perp|$
11. $|\perp|$
12.
13. L ل 1
14. $\mid$
15. $|\perp|$
16. $L \perp \perp \perp \perp \mid$
17. $\qquad$
18. C
19. $\perp \perp \perp \perp|\perp \perp \perp|$

Intel Pattern Number (Please Do Not Use)

2. $\qquad$
3. $|\perp| \perp|\perp| \perp|\perp|$
4. L $\perp$
5. $\qquad$
6. $\perp \perp \perp|\perp| \perp \perp \perp \mid$ 1
8. $\mid$
9. $\mid \perp \perp \perp \perp \perp \perp \perp \perp \perp \perp \perp$
10. $\mid$
11. $\mid$
12. $\qquad$
13. $\mid$
14.
L $\mid$
15. $|\perp|$
16. $\mid$
17. $\qquad$
18. $\mid$
19. $L \perp|\quad| \quad|\quad| \quad|\quad| \quad \mid$

## ORDER FORM

## B

|  | S\# For Intel Use Only |
| :---: | :---: |
| Company $\qquad$ Phone \# $\qquad$ |  |
| Company Contact ___ Date___ | STD |
| P.O. \#__ Intel P/N \& Pkg_ | APP |
| A custom 16K ROM order must be submitted on this form. Programming information should be sent per the formats described in the Programming Instruction section of the Intel Data Catalog. Additional forms are available from Intel. | Date |

## 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 \ldots Z)$. The customer part number is limited to a maximum of 9 digits or spaces.

When authorized by the customer to ship 2616 PROMs against a 2316 E order, the PROMs are marked with the dual part number 2616/2316E.


1
P2316E MARKING EXAMPLE

## IMPORTANT MASK OPTION SPECIFICATION

The $2316 \mathrm{E}, 8316 \mathrm{~A}$, and 8316 AL 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 and 2616 PROM.

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

## FLOPPY DISK

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk sent should also be indicated by checking one of the appropriate boxes:
$\square$ Single Density
$\square$ Double Density

## CUSTOMER PART NUMBER

Customer P/N
(Please Fill-In)
1.


2. |  | $\perp$ | $\perp$ | $\perp$ | $\perp$ | $\perp$ |
| :--- | :--- | :--- | :--- | :--- | :--- |
3. 


4.

5. 1
6. L $\mid$
7.
8.

16K ROM Chip Number (Please Fill-In)

> 1. لـــا
2. $L$
3. $L$
4. $L$
5. $L$
6. $L$
7. $L$
8.
$\square$

Floppy Disk File Name (Please Fill-In)

1. $|\perp| \perp|\perp| \perp \mid \perp$
2. $\perp \perp$
3. Lـلـ|
4. $\perp \perp|\perp|$
5. $\quad \perp$
6. $L \perp \perp \perp \perp \perp \mid \perp \perp$
7. $L \perp \perp \perp \perp \perp$
8. $\mid$

Intel Pattern Number
(Please Do Not Use)

| Company __ Phone \# | $\qquad$ |
| :---: | :---: |
| Company Contact__Date |  |
| P.O. \#__ Package Type: $\square$ Plastic $\square$ Cerdip |  |
| All custom 8041, 8048 and 8049 orders be submitted on this form. Programming information should be sent per the formats described in the Programming Instruction section 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 (P8048), the 4-digit Intel pattern number (WWWW), a date code ( XXYY ), and the customer part number ( $\mathrm{Z} \ldots \mathrm{Z}$ ). The customer part number is limited to a maximum of 9 digits or spaces.


1
P8048 MARKING EXAMPLE

## FLOPPY DISK

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk sent should also be indicated by checking one of the appropriate boxes:
$\square$ Single Density
$\square$ Double Density

CUSTOMER PART NUMBER

## Customer P/N <br> (Please Fill-In)

| $\mid$
2. $L$
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
$|\perp|$
L

لـ
L
1
L
1
لـ1

1
1
L
1
L
L
1
لـ

## Floppy Disk File Name

(Please Fill-In)
L $\perp$
1

4
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
$\perp|\perp| \perp \mid$
|
L $\perp$
1
C
L
$\perp \perp \perp \mid$
لـ
$1 \begin{array}{lllllllll}L & \perp & \perp & \perp & \perp & \perp\end{array}$
L
L
لـ L

1
L


Intel Pattern Number
(Please Do Not Use)

## 

L $\mid$
3. $\mid$
$\begin{array}{lllllllll} \\ L & \perp & \perp & \perp & \perp & \perp & \perp & \perp\end{array}$
5. $\perp \perp \perp \perp \perp \perp \perp \perp \perp \perp$
6.
7.

لــــL
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20. $\mid$

D


## FLOPPY DISK

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk sent should also be indicated by checking one of the appropriate boxes:
$\square$ Single Density
$\square$ Double Density

## CUSTOMER PART NUMBER

Customer P/N (Please Fill-In)
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.

14
15.
16. $L \perp \mid$
17.
18.
19.
$\qquad$
L $L \perp \perp|\perp| \perp \mid \perp$

$\perp \perp \perp \perp \perp \perp \perp \perp$
. $L \perp \perp \perp \perp \perp \perp \perp \perp$
. $L \perp \perp \perp \perp \perp \perp \perp \perp \perp$
. $L \perp|\perp| \perp|\perp| \perp \mid \perp$
8. $L \perp|\perp| \perp|\perp \perp| \perp \mid$
9. $|\perp| \perp|\perp| \perp|\perp| \perp$

1. $|\perp|$
2. $L \perp \perp \perp \perp|\perp| \perp \mid \perp$

3. $L \perp|\perp| \perp|\perp| \perp \mid \perp$
4. $L \perp \perp|\perp| \perp \mid \perp \perp$
. $L \perp \perp \perp|\perp| \perp \mid$
. $L \perp \perp \perp \perp \perp \perp \perp \perp \perp$

Floppy Disk File Name

## (Please Fill-In)

1. $\qquad$
2. $L \perp \perp|\perp \perp \perp| \perp \mid \perp \perp$
3. $L \perp \perp \perp \perp|\perp| \perp \mid \perp \perp$
4. $|\perp \perp \perp \perp \perp \perp \perp| \perp \perp$
5. $L \perp \perp|\perp \perp| \perp \mid \perp \perp$
6. $\perp \perp \perp \perp \perp \mid \perp \perp \perp \perp \perp$
7. $\perp \perp \perp \perp \perp \perp \perp \mid \perp \perp \perp$
8. 
9. 
10. $L \perp|\perp| \perp|\perp| \perp \mid \perp$
11. $L \perp \perp|\perp| \perp \mid \perp \perp$
12. $L \perp \mid$
13. $L|\perp| \perp|\perp| \perp \mid \perp$
14. $L \perp|+|\perp| \perp| \perp \mid \perp$
15. $L \perp|\perp| \perp|\perp| \perp|\perp| ل 1$
16. $L \perp \perp \mid$
17. $\perp \perp \perp \perp \perp \perp|\perp| \perp \perp$
18. $L \perp \perp \perp|\perp| \perp|\perp| \perp$


Intel Pattern Number
(Please Do Not Use)
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.


## ORDER FORM

| Company ___ Phone \# | For Intel Use Only |
| :---: | :---: |
| Company Contact ___ Date | STD |
| P.O. \#_ Package Type: $\square$ Plastic $\square$ Cerdip | APP |
| All custom 8355 orders must be submitted on this form. Programming information should be sent per the formats described in the Programming Instruction section of the Intel Data Catalog. Additional forms are available from Intel. |  |

## 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 ( $X X Y Y$ ), and the customer part number ( $Z \ldots . . \mathrm{Z}$ ). The customer part number is limited to a maximum of 9 digits or spaces.

## FLOPPY DISK

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk sent should also be indicated by checking one of the appropriate boxes:
$\square$ Single Density
$\square$ Double Density

## CUSTOMER PART NUMBER

## Customer P/N (Please Fill-In)


$1 \perp \mid$
3. $\qquad$
Lـ 1
$\qquad$
7. $\qquad$
8. $\qquad$
L
10. $\qquad$
11. $|\perp| \perp \mid$
12. 1
13. $|\perp|$
14.

15. $\perp \perp \perp \mid$
16. $\mid$
17. $\mid$
18. $L \perp \mid$
19. $|\perp \perp| \perp|\perp| \perp \mid \perp$
20. $L$

Floppy Disk File Name (Please Fill-In)
$\qquad$ $\xrightarrow[L]{L} \perp \perp \perp \perp \perp \perp \perp \perp$
3. $L$
4. $\perp|\perp|$ L $\perp$
6. 1
7. $L \perp \perp \perp \perp \perp$
8. $L \perp \perp \perp|\perp| \perp \mid \perp \perp \perp$
9. $\xrightarrow{\perp} \mid$
10.
11.


12. $L \perp$
13. $L \perp$
14. $L \perp$
15. $L \perp \perp|\perp| \perp \mid \perp$
16. $\mid$
17. $\perp \perp \perp \perp \mid$
18. $L \perp \mid$
19.
20. $\mid$

## Intel Pattern Number (Please Do Not Use)

1. $\qquad$
2. $L \perp \mid$
3. $\qquad$
4. $\qquad$
5. $\qquad$ Lـ_
6. $\mid$
7. $\qquad$
8. L
9. $\qquad$
10. $\mid$
11. Lـ $\mid$
12. L
13. L $\mid$
14. $\qquad$
15. $L \mid$
16. $\mid$
17. $\mid$
18. $L$
19. $L \perp$

| Company __ Phone \# | For Intel Use Only |
| :---: | :---: |
| Company Contact ___ Date_ | $\qquad$ |
| P.O. \#___ Intel Device P/N |  |
| All custom bipolar PROM orders must be submitted on this form. Programming informaion should be sent per the formats described in the Programming Instruction section of the Intel Data Catalog. Additional forms are available from Intel. |  |

## IMPORTANT HEX AND INTELLEC HEX FORMAT INFORMATION

A word field must be 8 bits in the hex format. Consequently for N words by 4 -bit devices such as the 3625 A , it is important that jou indicate by checking the box below whether the submitted tape or card deck for programming is right or left justified.

Right Justified
$\square$ Left Justified

## 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 (D36AA), 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.


1
D36AA MARKING EXAMPLE

## FLOPPY DISK

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk sent should also be indicated by checking one of the appropriate boxes:
$\square$ Single Density
$\square$ Double Density

## CUSTOMER PART NUMBER

Customer P/N
(Please Fill-In)

2. $L$
3. L $|\perp| \perp \mid$ $\perp \perp \perp$ 1
7. $\mid$
8. 1 1
10. $\mid$
11. $\mid$
12. 1
13. L $\perp$
14. $L \perp \perp$

15. 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Floppy Disk File Name
(Please Fill-In)

2. $L \perp \perp$
3.

4. L
5.
6. $\mid$
7. $L \perp \perp \perp \mid$
8. $\qquad$
9. $|\perp|$
10. L
11. L
12. $L \perp$
13.

14. L
15. $\qquad$

Intel Pattern Number
(Please Do Not Use)

1. $\mid$
2. $\mid$
3. $\mid$
4. $\left\lvert\, \begin{array}{llllllllll}L & \perp & \mid & \mid & \mid & \mid & \mid & \perp\end{array}\right.$
5. $\mid$
6. $\mid$
7. $\mid$
8. $|$| $\perp$ |
| :--- |
9. $|\perp|$
10. $\mid$
11. $L \perp \perp \mid$
12. $\mid$
13. 
14. $|\perp| \perp|\perp| \perp \mid \perp \perp$
15. $\mid$

## CUSTOMER 4001 ROM <br> ORDER FORM

All custom ROM orders must be submitted on forms provided by Intel. Programming information should be sent in the form of computer punched cards or punched paper tape. In either case, a printout of the truth table must accompany the order. Refer to MCS-40 ${ }^{\text {tm }}$ User's Manual for complete pattern specifications. Alternatively, the accompanying truth table may be used. Additional forms are available from Intel.


The marking as shown at right must contain the Intel logo, the product type (P4001), the four-digit Intel pattern number (PPPP), a date code ( $X X X X$ ), and the two-digit chip number (DD). A customer identification number (maximum 6 characters or spaces) may be substituted for the chip number (ZZ).


Customer Identification Number $\qquad$

## MASK OPTION SPECIFICATIONS

A. Chip Number (DD) $\qquad$ (must be specified - any number from 1 through 15)
B. I/O Option - Specify the connection numbers for each I/O pin (see next page). Examples of some of the possible I/O options are shown below:

## DESIRED OPTION - CONNECTIONS REQUIRED

1. Non-inverting output -1 and 3 are connected.
2. Inverting output - 1 and 4 are connected.
3. Non-inverting input (no input resistor) - only 5 is connected.
4. Inverting input (input resistor to $V_{S S}$ ) $-2,6,7$, and 9 are connected.
5. Non-inverting input (input resistor to $V_{D D}$ ) $-2,7,8$, and 10 are connected.
6. If inputs and outputs are mixed on the same port, the pins used as the outputs must have the internal resistor connected to either $V_{D D}$ or $V_{S S}$ ( 8 and 9 or 8 and 10 must be connected). This is necessary for testing purposes. For example, if there are two inverting inputs (with no input resistor) and 2 non-inverting outputs, the connection would be made as follows:

Inputs - 2 and 6 are connected.
Outputs $-1,3,8$, and 9 are connected or 1,3,8, and 10 are connected.
If the pins on a port are all inputs or all outputs the internal resistors do not have to be connected.
C. 4001 Custom ROM Pattern - Programming information should be sent in the form of computer punched cards or punched paper tape. In either case, a printout of the truth table must accompany the order. Refer to Intel's Data Catalog for complete pattern specifications. Alternatively, the accompanying truth table may be used. Based on the particular customer pattern, the characters should be written as a " P " for a high level output = n -logic " 0 " (negative logic " 0 ") or an " $N$ " for a low level output = $n$-logic " 1 " (negative logic " 1 ").
Note that NOP $=$ BPPPP PPPPF $=00000000$.


## I/O. (PIN 16)

## CONNECTIONS DESIRED:

(List numbers and circle connections on schematic.)
a. For $T^{2} L$ compatibility on the I/O lines, the supply voltages should be $V_{D D}=-10 \mathrm{~V} \pm 5 \%, V_{S S}=+5 \mathrm{~V} \pm 5 \%$.
b. If non-inverting input option is used, $\mathrm{V}_{\mathrm{IL}}=-6.5 \mathrm{~V}$ maximum (not TTL).


## I/ $\mathrm{O}_{2}$ (PIN 14)

CONNECTIONS DESIRED:
(List numbers and circie connections on schematic.)
a. For $\mathrm{T}^{2} \mathrm{~L}$ compatibility on the $1 / O$ lines, the supply voltages should be $V_{D D}=-10 \mathrm{~V} \pm 5 \%, V_{S S}=+5 \mathrm{~V} \pm 5 \%$.
b. If non-inverting input option is used, $\mathrm{V}_{\mathrm{IL}}=-6.5 \mathrm{~V}$ maximum (not TTL).


## I/O (PIN 15)

CONNECTIONS DESIRED:
(List numbers and circle connections on schematic.)
a. For $T^{2} L$ compatibility on the $1 / O$ lines, the supply voltages should be $V_{D D}=-10 \mathrm{~V} \pm 5 \%, V_{S S}=+5 \mathrm{~V} \pm 5 \%$.
b. If non-inverting input option is used, $V_{I L}=-6.5 \mathrm{~V}$ maximum (not TTL).


## I/O $\mathrm{O}_{3}$ (PIN 13)

## CONNECTIONS DESIRED:

(List numbers and circle connections on schematic.)
a. For $T^{2} \mathrm{~L}$ compatibility on the $1 / O$ lines, the supply voltages should be $\mathrm{V}_{\mathrm{DD}}=-10 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=+5 \mathrm{~V} \pm 5 \%$.
b. If non-inverting input option is used, $\mathrm{V}_{I \mathrm{~L}}=-6.5 \mathrm{~V}$ maximum (not TTL).

## CUSTOMER 4308 ROM ORDER FORM <br> H

## 4308 METAL MASKED ROM

All custom ROM orders must be submitted on forms provided by Intel. Programming information should be sent in the form of computer punched cards or punched paper tape. In either case, a printout of the truth table must accompany the order. Refer to the 4308 Data Catalog for complete pattern specifications. Additional forms are available from Intel.

|  | (Intel use only) |  |
| :---: | :---: | :---: |
| Customer | S \# | PPPP |
| Address | STD | ZZ |
|  | APP | DD |
| P.O. Number _ Date | Date |  |

## INTEL STANDARD MARKING

The marking as shown at right must contain the Intel logo, the product type ( P 4308 ), the four-digit Intel pattern number (PPPP), a date code ( $X X X X$ ), and the two-digit chip number (DD). A customer identification number (maximum 6 characters or spaces) may be substituted for the chip number ( ZZ ).

Customer Identification Number $\qquad$

## ROM DESCRIPTION

Chip Select Value (0-3) $\qquad$ (must be specified)

In the table below, select the connections which should

| PIN |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---: |
| $1 / O 0_{0}$ | 27 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 0_{1}$ | 26 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 0_{2}$ | 25 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 0_{3}$ | 24 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 1_{0}$ | 5 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 1_{1}$ | 4 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 1_{2}$ | 3 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 1_{3}$ | 2 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 2_{0}$ | 17 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 2_{1}$ | 16 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 2_{2}$ | 15 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 2_{3}$ | 14 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 3_{0}$ | 21 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 3_{1}$ | 20 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 3_{2}$ | 19 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |
| $1 / O 3_{3}$ | 18 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |  |

© Intel 1977/Printed in U.S.A.
be made for each of the 16 I/O port input lines. Avoid the use of illegal options - refer to the MCS $-40^{\text {tm }}$ User's Manual.

Mark the appropriate box for an option connection. Leave a blank for a no connection.


## CUSTOMER 8021 ROM <br> ORDER FORM

| Company ___ Phone No. | For Intel Use Only |
| :---: | :---: |
| Company Contact $\qquad$ Date | S No. |
| P.O. No. Package Type: $\square$ Plastic $\square$ Cerdip | STD |
| All custom 8021 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. 8748's may also be used to input programming information for the 8021. Additional forms are available from Intel. | APP 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 (P8021), the 4 -digit Intel pattern number (WWWW), a date code ( $X X Y Y$ ), and the customer part number ( $Z \ldots . . \mathrm{Z}$ ). The customer part number is limited to a maximum of 9 digits or spaces.


P8021 MARKING EXAMPLE

## CUSTOMER PART NUMBER

Customer P/N
Intel Pattern Number
(Please Fill-In)
(Please Do Not Use)

## I/O Mask Options

Specify the desired connection for each I/O line on Port 0 and for the T1 input by marking only one box for each pin.

| PIN |  | OPTION |  |
| :---: | :---: | :---: | :---: |
|  |  | 1 | 2 |
| P00 | 4 |  |  |
| P01 | 5 |  |  |
| P02 | 6 |  |  |
| P03 | 7 |  |  |
| P04 | 8 |  |  |
| P05 | 9 |  |  |
| P06 | 10 |  |  |
| P07 | 11 |  |  |
| T1 | 13 |  |  |

Port 0:
Option 1 deletes the pullup resistor on the I/O line providing true open drain outputs.

Option 2 includes the pullup resistor on the I/O line providing a quasi-bidirectional line.

OPTIONAL PULLUP RESISTOR


T1:
Option 1 deletes the pullup resistor for use as a zero cross detection input.

Option 2 includes the pullup resistor for use with an external switch or standard TTL.

OPTIONAL PULLUP RESISTOR


## CUSTOMER 8022 ROM ORDER FORM <br> J

| Company ___ Phone No. | For Intel Use Only <br> S No. $\qquad$ <br> STD $\qquad$ |
| :---: | :---: |
| Company Contact |  |
| P.O. No. Package Type: $\square$ Plastic $\square$ Cerdip |  |
| All custom 8022 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. 8755's may also used to input programming ir.formation for the 8022. 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 arid package type (P8022), 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.


P8022 MARKING EXAMPLE

## CUSTOMER PART NUMBER

## Customer P/N <br> (Please Fill-In)

## Intel Pattern Number

(Please Do Not Use)
$\qquad$ $\perp \perp \perp \perp \perp 1$

## I/O Mask Options

Specify the desired connection for each I/O line on Port 0 and for the T1 input by marking only one box for each pin.

OPTIONAL PULLUP RESISTOR

| PIN |  | OPTION |  |
| :---: | :---: | :---: | :---: |
|  | 1 | 1 | 2 |
| P00 | 10 |  |  |
| P01 | 11 |  |  |
| P02 | 12 |  |  |
| P03 | 13 |  |  |
| P04 | 14 |  |  |
| P05 | 15 |  |  |
| P06 | 16 |  |  |
| P07 | 17 |  |  |
| T1 | 19 |  |  |

Port 0
Option 1 deletes the pullup resistor on the I/O line providing true open drain outputs.
Option 2 includes the pullup resistor or the I/O line providing a quasi-bidirectional line.

T1:
Option 1 deletes the pullup resistor for use as a zero cross detection input.

Option 2 includes the pullup resistor for use with an external switch or standard TTL.


OPTIONAL PULLUP RESISTOR


## 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 dosage (UV intensity $X$ exposure time) for the EPROMs currently in production by Intel.

Table III. Required Erase Energy for Device Types

| Device Type | 2537 Å Erase Energy |
| :--- | :---: |
| 1702A/4702A | $6 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$ |
| All other | $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$ | | Intel EPROMs |
| :--- |
| or EPROMs |
| with I/O ports |$\quad$.

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 |  |
| :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & 6 \text { W-sec } \\ & \text { 1702A, } \\ & 4702 A \end{aligned}$ | 15 W-sec <br> All Intel EPROMs or EPROMs with I/O Ports Except the 1702A/4702A |
| 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. 1702A/1702AL Family Programming

The 1702A/1702AL is erased by exposure to high intensity short wave ultraviolet light at a wavelength of $2537 \AA$. The recommended integrated dose (i.e., UV intensity $X$ exposure time) is $6 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$. An example of an ultraviolet source which can erase the 1702A/1702AL in 10 to 20 minutes is the Model S52 short wave ultraviolet lamp. The lamp should be used without short wave filters and the PROM should be placed within 1 inch away from the lamp tubes.

Initially, all 2048 bits of the PROM are in the " 0 " state (output low). Information is introduced by selectively programming "1"s (output high) in the proper bit locations.
Word address selection is done by the same decoding circuitry used in the READ mode. All 8 address bits must be in the binary complement state when pulsed $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{GG}}$ move to their negative levels. The addresses must be held in their binary complement state for a minimum of $25 \mu \mathrm{sec}$ after $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{GG}}$ have moved to their negative levels. The addresses must then make the transition to their true state a minimum of $10 \mu \mathrm{sec}$ before the program pulse is applied. The addresses should be programmed in the sequence 0 through 255 for a minimum of 32 times. The eight output terminals are used as data inputs to determine the information pattern in the 8 bits of each word. A low data input level ( -48 V ) will program a " 1 " and a high data input level (ground) will leave a " 0 ". All 8 bits of one word are programmed simultaneously by setting the desired bit information patterns on the data input terminals.
During the programming, $\mathrm{V}_{\mathrm{GG}}, \mathrm{V}_{\mathrm{DD}}$ and the Program Pulse are pulsed signals. See page 4-12 for required pin connections during programming.

1702A, 1702AL

## D.C. and Operating Characteristics for Programming Operation

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=+12 \mathrm{~V} \pm 10 \%, \overline{\mathrm{CS}}=0 \mathrm{~V}$ unless otherwise noted

| Symbol | Test | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ILIIP | Address and Data Input Load Current |  |  | 10 | mA | $V_{\text {IN }}=-48 \mathrm{~V}$ |
| $\mathrm{I}_{\text {LI2P }}$ | Program and $\mathrm{V}_{\mathrm{GG}}$ Load Current |  |  | 10 | mA | $\mathrm{V}_{\text {IN }}=-48 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{BB}}{ }^{[1]}$ | $\mathrm{V}_{\text {BB }}$ Supply Load Current |  | 10 |  | mA |  |
| IDDP ${ }^{[2]}$ | Peak IDD Supply Load Current |  | 200 |  | mA | $\begin{aligned} & V_{D D}=V_{P R O G}=-48 V, \\ & V_{G G}=-35 V \end{aligned}$ |
| $\mathrm{V}_{\text {IHP }}$ | Input High Voltage |  |  | 0.3 | V |  |
| $\mathrm{V}_{\text {ILIP }}$ | Pulsed Data Input Low Voltage | -46 |  | -48 | V |  |
| $V_{\text {IL2P }}$ | Address Input Low Voltage | -40 |  | -48 | V |  |
| VIL3P | Pulsed Input Low VDD and Program Voltage | -46 |  | -48 | V |  |
| $V_{\text {IL4P }}$ | Pulsed Input Low $\mathrm{V}_{\mathrm{GG}}$ Voltage | -35 |  | -40 | V |  |

Notes: 1. The $V_{B B}$ supply must be limited to 100 mA max. current to prevent damage to the device.
2. IDDP flows only during $V_{D D}, V_{G G}$ on time. IDDP should not be allowed to exceed 300 mA for greater than $100 \mu \mathrm{sec}$. Average power supply current IDDP is typically 40 mA at $20 \%$ duty cycle.

## 1702A, 1702AL

## A.C. Characteristics for Programming Operation

$\mathrm{T}_{\mathrm{AMBIENT}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=+12 \mathrm{~V} \pm 10 \%, \overline{\mathrm{CS}}=0 \mathrm{~V}$ unless otherwise noted

| Symbol | Test | Min. | Typ. | Max. | Unit | Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  | Duty Cycle (VD, $\left.V_{G G}\right)$ |  |  | 20 | $\%$ |  |
| $t_{\phi P W}$ | Program Pulse Width |  | 2 | 3 | ms | $V_{G G}=-35 \mathrm{~V}$, <br> $V_{D D}=V_{P R O G}=-48 \mathrm{~V}$ |
| $\mathrm{t}_{\mathrm{DW}}$ | Data Set-Up Time | 25 |  |  | $\mu \mathrm{~s}$ |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time | 10 |  |  | $\mu \mathrm{~s}$ |  |
| $\mathrm{t}_{\mathrm{VW}}$ | $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{GG}}$ Set-Up | 100 |  |  | $\mu \mathrm{~s}$ |  |
| $\mathrm{t}_{\mathrm{VD}}$ | $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{GG}}$ Hold | 10 |  | 100 | $\mu \mathrm{~s}$ |  |
| $\mathrm{t}_{\text {ACW }}$ | Address Complement Set-Up | 25 |  |  | $\mu \mathrm{~s}$ |  |
| $\mathrm{t}_{\text {ACH }}$ | Address Complement Hold | 25 |  |  | $\mu \mathrm{~s}$ |  |
| $\mathrm{t}_{\text {ATW }}$ | Address True Set-Up | 10 |  |  | $\mu \mathrm{~s}$ |  |
| $\mathrm{t}_{\text {ATH }}$ | Address True Hold | 10 |  |  | $\mu \mathrm{~s}$ |  |

## PROGRAM WAVEFORMS

Conditions of Test:
Input pulse rise and fall times $\leq 1 \mu \mathrm{sec}$
$\overline{\mathrm{CS}}=\mathrm{OV}$


## C. 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 (tpW) according to $N \times t_{\text {pW }}$ $\geqslant 100 \mathrm{~ms}$.
The width of the program pulse is from 0.1 to 1 ms . The number of loops ( N ) is from a minimum of 100 ( $t_{\text {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 $\mathrm{V}_{\text {ILP }}$ with an active instead of a passive device. This pin will source a small amount of current ( $I_{\text {ILL }}$ ) when $C S / W E$ is at $V_{\text {IHW }}(12 \mathrm{~V})$ and the program pulse is at $V_{\text {ILP }}$.

## Programming Examples (Using $\mathbf{N} \times \mathbf{t}_{\text {PW }} \geqslant 100 \mathrm{~ms}$ )

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 Family

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



Note 1. $I_{B B}$ for the 2708 L is specified in the programmed state and is 18 mA maximum in the unprogrammed state.

## 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}} / \mathrm{WE}$ Setup Time | 10 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Setup Time | 10 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\text {AH }}$ | Address Hold Time | 1 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{CH}}$ | $\overline{\text { 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 Family

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

## D. 2716 And 2758 Programming

Initally, and after each erasure, all bits of the 2716/2758 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 / 2758$ is programmed by applying a 50 ms , TTL programming puise to the $\overline{\mathrm{CE}} / \mathrm{PGM}$ pin with the $\overline{\mathrm{OE}}$ input high and the $V_{P P}$ supply at $25 \mathrm{~V} \pm 1 \mathrm{~V}$. Any location may be programmed at any time - either individually, sequentially, or randomly. The programming time for a single bit is only 50 ms and for all bits is approximately 100 and 50 seconds for the 2716 and 2758 respectively. The detailed programming specifications and timing waveforms are given in the following tables and figures.

CAUTION: The $V_{C C}$ and $V_{P P}$ supplied must be sequenced on and off such that $V_{C C}$ is applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$ to prevent damage to the 2716/2758. The maximum allowable voltage during programming which may be applied to the $\mathrm{V}_{\mathrm{Pp}}$ with respect to ground is +26 V . Care must be taken when switching the $V_{\text {Pp }}$ supply to prevent overshoot exceeding the 26 -volt maximum specification. For convenience in programming, the $2716 / 2758$ 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}_{\mathrm{PP}}$ must be at $\mathrm{V}_{\mathrm{CC}}$.

## 2716 AND 2758 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}_{\mathrm{IN}}=5.25 \mathrm{~V} / 0.45$ |
| $\mathrm{I}_{\mathrm{PP} 1}$ | $V_{\text {PP }}$ Supply Current |  |  | 5 | mA | $\overline{\mathrm{CE}} / \mathrm{PGM}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{I}_{\mathrm{PP} 2}$ | $V_{\text {PP }}$ Supply Current During <br> Programming Pulse |  |  | 30 | mA | $\overline{\mathrm{CE}} / \mathrm{PGM}=\mathrm{V}_{\mathrm{IH}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $V_{\mathrm{CC}}$ Supply Current |  |  | 100 | mA |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Level | -0.1 |  | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Level | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+1$ | V |  |

## A.C. Programming Characteristics

| Symbol | Parameter | Min. | Typ. | Max. | Units |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ AS | Address Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| toes | $\overline{\mathrm{OE}}$ 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}$ |  |
| $\mathrm{t}_{\text {OEH }}$ | $\overline{\mathrm{OE}}$ Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ ( ${ }_{\text {ch }}$ | Data Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ DF | Output Enable to Output Float Delay | 0 |  | 120 | ns | $\overline{\mathrm{CE}} / \mathrm{PGM}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{OE}$ | Output Enable to Output Delay |  |  | 120 | ns | $\overline{\mathrm{CE}} / \mathrm{PGM}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{t}_{\text {PW }}$ | Program Pulse Width | 45 | 50 | 55 | ms |  |
| $t_{\text {PR } T}$ | 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. $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P P}$. The 2716/2758 must not be inserted into or removed from a board with $V_{P P}$ 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:

| $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ | Input Pulse Levels . . . . . . . . . . . . . . . . . . . . 0.8 V V to 2.2V |
| :---: | :---: | :---: |
| $V_{\text {PP }}$ | . $25 \mathrm{~V} \pm 1 \mathrm{~V}$ | Input Timing Reference Level. . . . . . . . . . . . . 1V and 2V |
| Inpu | 20 ns | Output Timing Reference Level. . . . . . . . . . 0.8 V and 2V |

## PROGRAMMING WAVEFORMS



NOTE ALL TIMES SHOWN IN PARENTHESES ARE MINIMUM TIMES AND ARE $\mu$ SEC UNLESS OTHERWISE NOTED

## E. 2732 Programming

Initially, and after each erasure, all bits of the 2732 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 2732 is in the programming mode when the $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ input is at 25 V . It is required that a $0.1 \mu \mathrm{~F}$ capacitor be placed across $\overline{O E} / V_{P P}$ and ground to suppress spurious voltage transients which may damage the device. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.
When the address and data are stable, a 50 msec , active low, TTL program pulse is applied to the $\overline{\mathrm{CE}}$ 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 2732 must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.
Programming of multiple 2732s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled 2732s may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{\mathrm{CE}}$ input programs the paralleled 2732s.

## Program Inhibit

Programming of multiple 2732s in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$, all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel 2732 s may be common. A TTL level program pulse applied to a 2732 's $\overline{\mathrm{CE}}$ input with $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ at 25 V will program that 2732 . A high level $\overline{\mathrm{CE}}$ input inhibits the other 2732 s from being programmed.

## Program Verify

A verify should be performed on the programmed bits to determine that they were correctly programmed. The verify is accomplished with $\overline{O E} / V_{P P}$ and $\overline{C E}$ at $V_{I L}$. Data should be verified $t_{D V}$ after the falling edge of $\overline{C E}$.

## A.C. CONDITIONS OF TEST

Input Rise and Fall Times (10\% to 90\%). . . . . . . . . 20 ns
Input Pulse Levels . . . . . . . . . . . . . . . . . . . . . . 0.8 V to 2.2V
Input Timing Reference Level. . . . . . . . . . . . . . . 1 V and 2 V
Output Timing Reference Level. . . . . . . . . . 0.8 V and 2 V

## PROGRAMMING ${ }^{[1]}$

D.C. PROGRAMMING CHARACTERISTICS: $T_{A}=25 \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Current (All Inputs) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IL }}$ or $\mathrm{V}_{\text {IH }}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage During Verify |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage During Verify | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 85 | 150 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level (All Inputs) | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Level (All Inputs Except OE/V ${ }_{\text {PP }}$ ) | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V |  |
| $\mathrm{I}_{\mathrm{PP}}$ | $\mathrm{V}_{\text {PP }}$ Supply Current |  |  | 30 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{1 L}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{PP}}$ |

A.C. PROGRAMMING CHARACTERISTICS: $T_{A}=25 \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $t_{\text {AS }}$ | Address Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\text {OES }}$ | $\overline{\text { OE Setup Time }}$ | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $t_{\text {AH }}$ | Address Hold Time | 0 |  |  | $\mu \mathrm{s}$ |  |
| $t_{\text {OEH }}$ | OE Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $t_{\text {DH }}$ | Data Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $t_{\text {DF }}$ | Chip Enable to Output Float Delay | 0 |  | 120 | ns |  |
| $t_{\text {DV }}$ | Data Valid from $\overline{C E}$ |  |  | 1 | $\mu \mathrm{s}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| tpw | CE Pulse Width During Programming | 45 | 50 | 55 | ms |  |
| $t_{\text {PRT }}$ | $\overline{\text { OE Pulse Rise Time During Programming }}$ | 50 |  |  | ns |  |
| $t_{V R}$ | $\mathrm{V}_{\mathrm{PP}}$ Recovery Time | 2 |  |  | $\mu \mathrm{s}$ |  |

Note: 1. When programming the 2732 , a $0.1 \mu \mathrm{~F}$ capacitor is required across OE/VPP and ground to suppress spurious voltage transients which may damage the device.

## PROGRAMMING WAVEFORMS



1. ALL TIMES SHOWN IN () ARE MINIMUM AND IN $\mu$ SEC UNLESS OTHERWISE SPECIFIED.
2. THE INPUT TIMING REFERENCE LEVEL IS 1V FOR A $V_{I L}$ AND $2 V$ FOR $A V_{I H}$.

## III. BIPOLAR PROM PROGRAMMING

All Intel bipolar PROMs are programmed with the algorithm described below. This algorithm was developed specifically to program Intel PROMs and must be used to insure properly and reliably programmed fuses.

Initially, all bits are in a logic 1 (high) state. To program a bit to a logic 0 (low) state, it is necessary to force 5 mA into the output to be programmed. A series of program pulses must also be applied to the $\mathrm{V}_{\mathrm{CC}}$ power supply and to any one of the logically low true chip select ( $\overline{\mathrm{CS}}$ ) inputs. The logic level of the other chip selects, in the case of PROMs with multiple chip selects, should be such that the PROM is selected during verification.
Program pulses are applied to all outputs of a word in a cycle time. The program pulses are multiplexed during a cycle time to each output of the word to be programmed. If desired, a $N$ word by 8 -bit PROM may have its words programmed in two separate groups - the four lower order bits $\left(\mathrm{O}_{1}\right.$ to $\left.\mathrm{O}_{4}\right)$ and the four higher order bits $\left(\mathrm{O}_{5}\right.$ to $\left.\mathrm{O}_{8}\right)$. The operation in this manner is the same as for a N word by 4 -bit PROM. For fastest programming time, it is preferred that all eight outputs be programmed at the same time.

The programming specifications are given in Table V and the programming waveforms are shown in Figure 1. The programming procedure (described with nominal specifications) is as follows:

1. A 5 mA current must be forced into the output to be programmed by a current source. The current source must be clamped to $\mathrm{V}_{\mathrm{CC}}$ by a silicon diode. All the other outputs must be floating until it is their turn for programming. The $\mathrm{V}_{\mathrm{CC}}$ power supply and the chip select ( $\overline{\mathrm{CS}}$ ) input is pulsed as shown in Figures 1 and 2. The width of $\mathrm{V}_{\mathrm{CC}}$ is linearly increased from $0.2 \mu \mathrm{~s}$ to $8 \mu \mathrm{~s}$ according to the ramp time shown in Figure 3. The total ramp time for a group of four outputs is 180 ms and 360 ms for a group of eight outputs.
The $V_{\text {CC }}$ program pulses are multiplexed during a cycle time to the outputs of the word to be programmed. The cycle time ( $\mathrm{t}_{\mathrm{CYC}}$ ) between the $\mathrm{V}_{\mathrm{CC}}$ program pulses to the same output will increase as the $\mathrm{V}_{\mathrm{CC}}$ program pulse width increases from $0.2 \mu \mathrm{~s}$ to $8 \mu \mathrm{~s}$. The time ( $\mathrm{t}_{\mathrm{D}}$ ) between $\mathrm{V}_{\mathrm{CC}}$ pulses of two different outputs is constant at $1.8 \mu \mathrm{~s}$.
2. All outputs must be continuously monitored for programming verification. This verification must occur after $\mathrm{V}_{\mathrm{CC}}$ has been at 4.5 V for $90 \%$ of $t_{D}$ and prior to $\mathrm{V}_{\mathrm{CC}}$ rising to 12.5 V . The program/verification cycles must still be applied (with the pulse width still linearly increasing to a maximum of $8 \mu \mathrm{~s}$ ) even though the output has been sensed as being programmed. An additional 128 verifications (i.e., 128 program/verify cycles) on each output must be obtained to insure a correctly programmed output. This additional 128 verification is a minimum number and must occur after all the bits of the word are sensed as being programmed. Please refer to Figure 1 for the timing waveforms.
More than 128 program/verify cycles may be required to achieve the 128 verifications on each bit. The cycles should still continue even if one bit fails, since the verifications are not required to be in consecutive sequence. After the 128 verifications have occurred for all bits, a final $\mathrm{V}_{\mathrm{CC}}$ and CS pulse at a width of 2.5 ms is simultaneously applied to all outputs. Programming should cease if the 128 verifications are not achieved in 800 ms .
3. A $4 \mathrm{~mA} \pm 50 \% \mathrm{I}_{\mathrm{CS}}$ current must also be forced into an appropriate chip select. I CS is forced into $\mathrm{CS}_{4}$ (pin 18) of $3604 A / 3624 A, C_{2}$ (pin 10) of $3605 A / 3625 A$, CS $_{3}$ (pin 19) of $3608 / 3628$, and $\mathrm{CS}_{2}$ (pin 19) of 3636 . The 4 mA current into the chip select input may be easily accomplished by using a 1.2 K resistor connected to a +15 V power supply. The voltage on the chip select input will be approximately 10 V with the 1.2 K resistor.
4. The 4 mA current into the chip select input may be easily accomplished by using a 1.2 K resistor connected to a +15 V power supply. The voltage on the chip select input will be approximately 10 V with the 1.2 K resistor.
Table V. Programming Characteristics
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  |  | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Nom. | Max. | Units |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | $V_{\text {CC }}$ Program Pulse Amplitude | 12 | 12.5 | 13 | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | $\overline{\mathrm{CS}}$ Program Pulse Amplitude | 3 | 5 | 5.5 | V |  |
| $\mathrm{V}_{\text {IL1 }}$ | $\mathrm{V}_{\text {CC }}$ During Verify | $4.25{ }^{[1]}$ | 4.5 | 4.75 | V |  |
| $\mathrm{V}_{\text {IH2 }}$ | $\overline{\mathrm{CS}}$ During Verify | 0 | 0.2 | 0.4 | V |  |
| $t_{\text {PW } 1}$ | $V_{c c}$ Pulse Width at Beginning of Pulse Train | 160 | 200 | 240 | ns | Measured at 12 V |
| $\mathrm{t}_{\text {PW2 }}$ | $V_{\text {CC }}$ Pulse Width at End of Pulse Train | 7.2 | 8 | 8.8 | $\mu \mathrm{s}$ | Measured at 12V |
| Tcss | Chip Select Setup Time | 0 |  |  | ns | Measured from 1.5 V on rising edge of $\overline{C S}$ to 5.0 V on rising edge of $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{T}_{\text {CSH }}$ | Chip Select Hold Time | 100 |  |  | ns | Measured from 5.0 V on falling edge of $\mathrm{V}_{\mathrm{CC}}$ to 1.5 V on falling edge of $\overline{\mathrm{CS}}$ |
| $\mathrm{T}_{\mathrm{R}}$ | $V_{\text {cc }}$ Rise Time | 300 | 400 | 500 | ns | Measured from 5 V to 12 V on $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{T}_{\mathrm{F}}$ | $V_{\text {cc }}$ Fall Time | 50 | 100 | 200 | ns | Measured from 12 V to 5 V on $\mathrm{V}_{\mathrm{Cc}}$ |
| $\mathrm{T}_{\mathrm{CYC}}$ | Time Between Pulses to Same Output | 9 | 10 |  | $\mu \mathrm{s}$ | Measured at 5 V on $\mathrm{V}_{\mathrm{Cc}}$ |
| TOP | DC Program Time After Verification Has Been Obtained | 2.2 | 2.5 | 2.8 | ms | Measured at 12 V |
| $\mathrm{T}_{\mathrm{D}}$ | Time Between $\mathrm{V}_{\mathrm{CC}}$ Pulses to Successive Outputs | 1.5 | 1.8 |  | $\mu \mathrm{s}$ | Measured at 5 V on $\mathrm{V}_{\mathrm{Cc}}$ |
| TRAMP | Time During Which $\mathrm{V}_{\mathrm{CC}}$ <br> Pulse Width is Increased $\qquad$ <br> Linearly from $t_{\text {PW }} 1$ to tpW2 | 160 | 180 360 | 200 400 | ms |  |
| Ics | Chip Select Input Current (See Programming Instruction 3 for Details) | 2 | 4 | 6 | mA | ICS should be generated using a 1.2 K resistor from a 15 V power supply |



Figure 1. Programming Cycles.
NOTES: 1. PROGRAM VERIFICATION MUST OCCUR AFTER VCC HAS BEEN AT 4.5V FOR $90 \%$ OF tD AND PRIOR TO VCC RISING TO 12.5 V . THE PROGRAMMED OUTPUT IS $\leqslant 0.45 \mathrm{~V}$ WHEN $\overline{\mathrm{CS}} \leqslant 0.8 \mathrm{~V}$ AND FLOATING WHEN $\overline{\mathrm{CS}} \geqslant 3 \mathrm{~V}$
2. AFTER THE LAST BIT HAS BEEN PROGRAMMED, 128 ADDITIONAL VERIFICATIONS ARE REQUIRED FOR EACH OUTPUT TO BE CORRECTLY PROGRAMMED.
3. AFTER THE 128 PROGRAM VERIFICATIONS, A FINAL. 2.5 ms VCC AND CS PULSE SHOULD BE APPLIED WHILE SIMULTANEOUSLY ENABLING THE CURRENT SOURCES TO ALL OUTPUTS WHICH ARE TO BE PROGRAMMED.


Figure 2. Programming Cycle Details .
4.77
(b) RAMP TIME IN PROGRAMMING 4 OUTPUTS


Figure 3. VCC Pulse Width vs. Programming Time.


## MEMORY SUPPORT CIRCUITS

| Type | Description | No. of Pins | Electrical Characteristics Over Temperature |  | Supplies, V | Page No. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Input to Output Delay Max. | $\begin{aligned} & \text { Power } \\ & \text { Dissipation[1] } \\ & \text { Maximum } \end{aligned}$ |  |  |
| 3205 | 1 of 8 Binary Decoder | 16 | 18 ns | 350 mW | + 5 | 5-3 |
| 3207A | Quad Bipolar to MOS Level Shifter and Driver | 16 | 25 ns | 900 mW | $+5,+16,+19$ | 5-7 |
| 3207A-1 | Quad Bipolar to MOS Level Shifter and Driver | 16 | 25 ns | 1040 mW | $+5,+19,+22$ | 5-11 |
| 3222 | 4K Dynamic RAM Refresh Controller | 22 | - | 600 mW | + 5 | 5-13 |
| 3232 | 4K Dynamic RAM Address Multiplexer and Refresh Counter | 24 | 20 ns | 750 mW | +5 | 5-19 |
| 3242 | 16K Dynamic RAM Address Multiplexer and Refresh Counter | 28 | 20 ns | 825 mW | +5 | 5-23 |
| 3245 | Quad TTL to MOS Driver for 4K RAMs | 16 | 32 ns | 388 mW | +12, + 5 | 5-27 |
| 3404 | High Speed 6-Bit Latch | 16 | 12 ns | 375 mW | +5 | 5-3 |

Note 1. Power Dissipation calculated with maximum power supply current and nominal supply voltages.

# 3205, 3404 3205 HIGH SPEED 1 OUT OF 8 BINARY DECODER 3404 HIGH SPEED 6-BIT LATCH 

18ns Max. Delay Over $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ Temperature: 3205<br>- 12ns Max. Data to Output Delay Over $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ Temperature: 3404

■ Directly Compatible With DTL and TTL Logic Circuits<br>■ Totem-Pole Output

Low Input Load Current: .25mA Max., 1/6 Standard TTL input Load<br>■ Minimum Line Reflection: Low Voltage Diode Input Clamp<br>\section*{Outputs Sink 10 mA Min.}<br>16-Pin Dual In-Line Package<br>Simple Expansion: Enable Inputs


#### Abstract

3205 The 3205 decoder can be used for expansion of systems which utilize memory components with active low chip select input. When the 3205 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 3205 allow easy memory expansion. For very large memory systems, 3205 decoders can be cascaded such that each decoder can drive 8 other decoders for arbitrary memory expansions. 3404 The Intel 3404 contains six high speed latches organized as independent 4 -bit and 2 -bit latches. They are designed for use as memory data registers, address registers, or other storage elements. The latches act as high speed inverters when the "Write" input is "low". The Intel 3404 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


## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias: | Ceramic <br> Plastic | $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ <br> $-65^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ |
| :--- | ---: | ---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ |  |
| All Output or Supply Voltages | -0.5 to +7 Volts |  |
| All Input Voltages | -1.0 to +5.5 Volts |  |
| Output Currents | 125 mA |  |

*COMMENT
Stresses above those listed under "Absolute Maximum Ràting" 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 $\quad T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$

3205, 3404

| SYMBOL | PARAMETER | LIMIT |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. |  |  |
| $I_{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{l}_{\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}$ |
| $V_{\text {IL }}$ | INPUT "LOW" VOLTAGE |  | 0.85 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | INPUT "HIGH" VOLTAGE | 2.0 |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{sc}}$ | OUTPUT HIGH SHORT CIRCUIT CURRENT | -40 | -120 | mA | $\mathrm{V}_{\text {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}$ |

3205 ONLY

| $\mathrm{I}_{\mathrm{CC}}$ | POWER SUPPLY CURRENT |  | 70 | mA | $\mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}$, Outputs Open |
| :---: | :---: | :---: | :---: | :---: | :---: |

3404 ONLY

| ${ }_{\mathrm{ICC}}$ | POWER SUPPLY CURRENT | 75 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$, Outputs Open |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\text {FW1 }}$ | WRITE ENABLE LOAD CURRENT PIN 7 | -1.00 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{W}}=0.45 \mathrm{~V}$ |
| $I_{\text {FW2 }}$ | WRITE ENABLE LOAD CURRENT PIN 15 | $-0.50$ | mA | $V_{C C}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{W}}=0.45 \mathrm{~V}$ |
| $I_{\text {RW }}$ | WRITE ENABLE LEAKAGE CURRENT | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |

## TYPICAL CHARACTERISTICS

OUTPUT CURRENT VS. OUTPUT "LOW" VOLTAGE


OUTPUT CURRENT VS. OUTPUT "HIGH" VOLTAGE


DATA TRANSFER FUNCTION


## 3205 HIGH SPEED 1 OUT OF 8 BINARY DECODER <br> SWITCHING CHARACTERISTICS



TEST WAVEFORMS

ADDRESS OR ENABLE INPUT PULSE
output

A.C. CHARACTERISTICS $\quad T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| SYMBOL | PARAMETER | MAX. LIMIT | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $t_{++}$ | ADDRESS OR ENABLE TO OUTPUT DELAY | 18 | ns |  |
| $\mathrm{t}_{-+}$ |  | 18 | ns |  |
| $t_{+}$ |  | 18 | ns |  |
| $\mathrm{t}_{\text {- }}$ |  | 18 | ns |  |
| $\mathrm{C}_{\text {IN }}{ }^{(1)}$ | INPUT CAPACITANCE P3205 | $\frac{\text { 4(typ.) }}{\text { 5(typ.) }}$ | $\frac{\mathrm{pF}}{\mathrm{pF}}$ | $\begin{aligned} & f=1 \mathrm{MHz}, V_{C C}=0 \mathrm{~V} \\ & V_{B \mid A S}=2.0 \mathrm{~V}, T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |

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

## TYPICAL CHARACTERISTICS

ADDRESS OR ENABLE TO OUTPUT DELAY VS. LOAD CAPACITANCE


ADDRESS OR ENABLE TO OUTPUT DELAY VS. AMBIENT TEMPERATURE


## 3404 6-BIT LATCH

## 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
NOTE 1: Output Data is valid after $\mathrm{t}_{+-}, \mathrm{t}_{-+}$TATA
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$; unless otherwise specified.

| SYMBOL | PARAMETER |  | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | MIN. | TYP. | MAX |  |  |
| $t_{+-,} \mathrm{t}_{\text {- }}+$ | DATA TO OUTPUT DELAY |  |  |  | 12 | ns |  |
| $\mathrm{t}_{\text {_ }-, \mathrm{t}_{\text {- }}+}$ | WRITE ENABLE TO OUTPUT DELAY |  |  |  | 17 | ns |  |
| ${ }^{\text {t }}$ SET UP | TIME DATA MUST BE PRESENT BEFORE RISING EDGE OF WRITE ENABLE |  | 12 |  |  | ns |  |
| ${ }^{\text {tHOLD }}$ | TIME DATA MUST REMAIN AFTER RISING EDGE OF WRITE ENABLE |  | 8 |  |  | ns |  |
| ${ }^{\text {t }} \mathrm{W}$ P | WRITE ENABLE PULSE WIDTH |  | 15 |  |  | ns |  |
| $\mathrm{C}_{\text {IND }}{ }^{(3)}$ | DATA INPUT CAPACITANCE | P3404 |  | 4 |  | pF | $\mathrm{f}=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ |
|  |  | C3404 |  | 5 |  | pF | $\mathrm{V}_{\text {BIAS }}=2.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{C}_{\text {INW }}{ }^{(3)}$ | WRITE ENABLE CAPACITANCE | P3404 |  | 7 |  | pF | $f=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ |
|  |  | C3404 |  | 8 |  | pF | $\mathrm{V}_{\mathrm{BIAS}}=2.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

NOTE 3: This parameter is periodically sampled and is not $100 \%$ tested.
TYPICAL CHARACTERISTICS

DATA INPUT, WRITE ENABLE TO OUTPUT DELAY VS. LOAD CAPACITANCE


DATA INPUT, WRITE ENABLE TO OUTPUT DELAY VS. AMBIENT TEMPERATURE


WRITE ENABLE PULSE WIDTH VS. LOAD CAPACITANCE


3207A
QUAD BIPOLAR-TO-MOS LEVEL SHIFTER AND DRIVER

■ High Speed, 45 nsec Max. - Delay + Transition Time Over Temperature with 200 pF Load

- TTL and DTL Compatible Inputs
- 1103 and 1103A Memory Compatible at Output
■ Simplifies Design - Replaces Discrete Components
> - Easy to Use - Operates from Standard Bipolar and MOS Supplies
> - Minimum Line Reflection - Input and Output Clamp Diodes
> - High Input Breakdown Voltage 19 Volts
> - CerDIP Package - 16 Pin DIP

The 3207A is a Quad Bipolar-to-MOS level shifter and driver which accepts TTL and DTL input signals, and provides high output current and voltage suitable for driving MOS circuits. It is particularly suitable for driving the 1103 and 1103A memory chips. The circuit operates from a 5 volt TTL power supply, and $V_{S S}$ and $V_{B B}$ power supplies from the 1103 and 1103A.

The device features two common enable inputs per pair of devices which permits some logic to be done at their inputs, such as cenable and precharge decoding for the 1103 and 1103A.

For the TTL inputs a logic " 1 " is $V_{I H}$ and a logic " 0 " is $V_{I L}$. The 3207A outputs correspond to a logic " 1 " as $V_{\mathrm{OL}}$ and a logic " 0 " as $\mathrm{V}_{\mathrm{OH}}$ for driving MOS inputs.

The 3207A is packaged in a hermetically sealed 16 pin ceramic dual-in-line package. The device performance is specified over the same temperature range as the 1103 and 1103 A , i.e. from $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$.
PIN CONFIGURATION

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature. . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$
All Input Voltages and $\mathrm{V}_{\text {SS }} \ldots \ldots . .$.
Supply Voltage $\mathrm{V}_{\mathrm{CC}} \ldots \ldots$.
All Outputs and Supply Voltage
$V_{B B}$ with respect to GND $\qquad$ -1.0 to +25 V
Power Dissipation at $25^{\circ} \mathrm{C}$. 2 Watts ${ }^{(1)}$

## * 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 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.
(1) Refer to the graph of Junction Temperature versus Total Power Dissipation on page 5-10 for other temperatures.

## D.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{SS}}=16 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}-\mathrm{V}_{\mathrm{SS}}=3.0 \mathrm{~V}$ to 4.0 V

| SYMBOL | TEST | $\text { MIN. }{ }^{\text {LIMIT }} \text { MAX. }$ | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| ${ }^{\prime}$ FD | DATA INPUT LOAD CURRENT | -0.25 | mA | $\begin{aligned} & V_{D}=.45 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \text { All Other Inputs } \\ & \text { at } 5.25 \mathrm{~V}, \mathrm{~V}_{S S}=16 \mathrm{~V}, \mathrm{~V}_{B B}=19 \mathrm{~V} \end{aligned}$ |
| ${ }^{\prime}$ FE | ENABLE INPUT LOAD CURRENT | -0.50 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{E}}=45 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \text { All Other Inputs } \\ & \text { at } 5.25 \mathrm{~V}, \mathrm{~V}_{S S}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V} \end{aligned}$ |
| ${ }^{\text {RD }}$ | dATA INPUT LEAKAGE CURRENT | 20 | $\mu \mathrm{A}$ | $V_{D}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, All Other Inputs Grounded, $\mathrm{V}_{\mathrm{SS}}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V}$ |
| ${ }_{\text {RE }}$ | ENABLE INPUT LEAKAGE CURRENT | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{E}}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, All Other Inputs Grounded, $\mathrm{V}_{\mathrm{SS}}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | OUTPUT "LOW" VOLTAGE | $\begin{aligned} & .8 \\ & .7 \\ & .6 \end{aligned}$ | $\begin{aligned} & \mathrm{V}\left(0^{\circ} \mathrm{C}\right) \\ & \mathrm{V}\left(25^{\circ} \mathrm{C}\right) \\ & \mathrm{V}\left(70^{\circ} \mathrm{C}\right) \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=500 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V} \\ & \text { All Inputs at } 2.0 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ (MIN.) | OUTPUT "HIGH" VOLTAGE | $\begin{array}{r} v_{S S}-.7 \\ v_{S S}-.6 \\ v_{S S}-.5 \\ \hline \end{array}$ | $\vee\left(0^{\circ} \mathrm{C}\right)$ <br> $V\left(25^{\circ} \mathrm{C}\right)$ <br> $V\left(70^{\circ} \mathrm{C}\right)$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-500 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V} \\ & \text { All Inputs at } 0.85 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ (MAX.) |  | $\mathrm{V}_{\text {SS }}+1.0$ | v | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V} \end{aligned}$ |
| 'OL | OUTPUT SINK CURRENT | 100 | mA | $\begin{aligned} & V_{O}=4 \mathrm{~V}, \mathrm{~V}_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=16 \mathrm{~V}, \\ & V_{B B}=19 \mathrm{~V}, V_{E}=V_{D}=2.0 \mathrm{~V} \end{aligned}$ |
| ${ }^{1} \mathrm{OH}$ | OUTPUT SOURCE CURRENT | -100 | mA | $\begin{aligned} & V_{O}=V_{S S}-4 V, V_{C C}=5.0 \mathrm{~V}, V_{S S}=16 \mathrm{~V} \\ & V_{B B}=19 \mathrm{~V}, V_{E}=V_{D}=0.85 \mathrm{~V} \end{aligned}$ |
| $V_{1 L}$ | INPUT "LOW" VOLTAGE | 1.0 | v | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\text {SS }}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V}$ |
| $V_{1 H}$ | INPUT "HIGH" VOLTAGE | 2.0 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=16 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=19 \mathrm{~V}$ |
| $\mathrm{Cin}_{\text {I }}$ | InPUT CAPACITANCE | 8(Typical) | pF | $\mathrm{v}_{\mathrm{BIAS}}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V}$ |

POWER SUPPLY CURRENT DRAIN:
All Outputs "Low"

| Symbol | Parameter | Min. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |

All Outputs "High"

| ${ }^{\prime} \mathrm{CC}$ | Current from $\mathrm{V}_{\mathrm{CC}}$ | 33 | mA |
| :--- | :--- | ---: | :---: |
| ${ }^{\prime} \mathrm{SS}$ | Current from $\mathrm{V}_{\mathrm{SS}}$ | 250 | $\mu \mathrm{~A}$ |
| ${ }^{\prime} \mathrm{BB}$ | Current from $\mathrm{V}_{\mathrm{BB}}$ | 3 | mA |
| $\mathrm{P}_{\text {TOTAL }}$ | Total Power Dissipation | 250 | mW |

$V_{C C}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=16.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=20.8 \mathrm{~V}$ All Inputs Grounded

Standby Condition with $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=\mathrm{V}_{\mathrm{BB}}$

| ${ }^{\prime} \mathrm{CC}$ | Current from $\mathrm{V}_{\mathrm{CC}}$ | 0 | mA |
| :--- | :--- | ---: | :---: |
| ${ }^{\prime} \mathrm{SS}$ | $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=16.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=16.8 \mathrm{~V}$ |  |  |
| ${ }^{\prime} \mathrm{BB}$ |  | 250 | $\mu \mathrm{~A}$ |
| $\mathrm{P}_{\mathrm{TOTAL}}$ | Current from $\mathrm{V}_{\mathrm{BB}}$ | 250 | $\mu \mathrm{~A}$ |

## SWITCHING 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{SS}}=16 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=\mathrm{V}_{\mathrm{SS}}+3$ to $4 \mathrm{~V}, \mathrm{f}=2 \mathrm{MHz}, 50 \%$ Duty Cycle

| SYMBOL | TEST | LIMITS (ns) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | pF MAX. | $\begin{aligned} & \mathrm{C}_{\mathrm{L}} \\ & \text { MIN. } \end{aligned}$ | pF MAX. | DELAY DIFFERENTIAL ${ }^{(1)}$ $\begin{gathered} \mathrm{C}_{\mathrm{L}}=200 \mathrm{pF} \\ \text { MAX. } \end{gathered}$ |
| $\mathrm{t}_{+}$ | INPUT TO OUTPUT DELAY | 5 | 15 | 5 | 15 | 5 |
| $\mathrm{t}_{\text {-+ }}$ | INPUT TO OUTPUT DELAY | 5 | 25 | 5 | 25 | 10 |
| $\mathrm{t}_{\mathrm{r}}$ | OUTPUT RISE TIME | 5 | 20 | 5 | 30 | 10 |
| $t_{f}$ | OUTPUT FALL TIME | 5 | 20 | 10 | 30 | 10 |
| ${ }^{\text {t }}$ | DELAY + RISE OR FALL TIME | 10 | 35 | 20 | 45 | 10 |

(1) This is defined as the maximum skew between any output in the same package, eg., all the input to output delays for the $\mathrm{t}_{-+}$parameter are within a maximum of 10 nsec of each other in the same package.

## WAVEFORMS



## TYPICAL CHARACTERISTICS

SWITCHING TIME VS. AMBIENT TEMPERATURE


SWITCHING TIME VS. LOAD CAPACITANCE


## POWER AND SWITCHING CHARACTERISTICS

POWER CONSUMED IN CHARGING AND DISCHARGING LOAD CAPACITANCE OVER OV TO 16V INTERVAL


JUNCTION TEMPERATURE VS. TOTAL POWER DISSIPATION OF THE CIRCUIT


TOTAL POWER DISSIPATION OF THE CIRCUIT (W) TOTAL POWER = D.C. POWER + POWER CONSUMED IN CHARGING AND DISCHARGING LOAD CAPACITANCE.

NO LOAD D.C. POWER DISSIPATION VS. OPERATING DUTY CYCLE


WORST CASELOAD CAPACITANCE ON EACH OUTPUT VS. FREQUENCY OF SWITCHING


FREQUENCY OF SWITCHING (MHz)

## intel

# 3207A-1 <br> QUAD BIPOLAR-TO-MOS LEVEL SHIFTER AND DRIVER 

## - Power Supply Voltage Compatible with the High Voltage 1103-1

## 1103-1 Memory Compatible at Output

The Intel 3207A-1 is the high voltage version of the standard 3207A, and is compatible with the 1103-1. The 3207A- 1 has all the same features as the standard 3207A. The absolute maximum ratings and pin configuration are repeated below for convenience, while the DC and AC characteristics appear below and on the next page.


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias
$0^{\circ} \mathrm{C}$ to $+55^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$
All Input Voltages . . . . . . . . . . . . -1.0 to +21 Volts
Supply Voltage $\mathrm{V}_{\mathrm{CC}}$. . . . . . . . . . -1.0 to +7.0 Volts
All Outputs and Supply Voltages $V_{B B}$ and $V_{S S}$
with respect to GND. . . . . . . . . . . -1.0 to +25 Volts
Power Dissipation at $25^{\circ} \mathrm{C}$. . . . . . . . . . . . . . . 2 Watts
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 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 $55^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, V_{S S}=19 \mathrm{~V} \pm 5 \%, V_{B B}-V_{S S}=3.0 \mathrm{~V}$ to 4.0 V

| SYMBOL | TEST | $\text { MIN. }{ }^{\text {LIMIT }} \text { MAX. }$ | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $I_{\text {Fo }}$ | DATA INPUT LOAD CURRENT | -0.25 | mA | $\begin{aligned} & V_{D}=.45 \mathrm{~V}, V_{C C}=5.25 \mathrm{~V}, \text { All Other Inputs } \\ & \text { at } 5.25 \mathrm{~V}, \mathrm{~V}_{S S}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V} \end{aligned}$ |
| ${ }^{\prime}$ FE | ENABLE INPUT LOAD CURRENT | -0.50 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{E}}=.45 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{All} \text { Other Inputs } \\ & \text { at } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V} \end{aligned}$ |
| $I_{\text {RD }}$ | DATA INPUT LEAKAGE CURRENT | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{D}=19 \mathrm{~V}, V_{C C}=5.0 \mathrm{~V}, \text { All Other Inputs } \\ & \text { Grounded, } V_{S S}=19 \mathrm{~V}, V_{B B}=23 \mathrm{~V} \end{aligned}$ |
| ${ }_{\text {I }}$ E | ENABLE INPUT LEAKAGE CURRENT | 20 | $\mu \mathrm{A}$ | $V_{E}=19 \mathrm{~V}, V_{C C}=5.0 \mathrm{~V}$, All Other Inputs Grounded, $\mathrm{V}_{\mathrm{SS}}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | OUTPUT "LOW" VOLTAGE | $\begin{aligned} & 0.8 \\ & 0.7 \\ & 0.6 \end{aligned}$ | $\begin{aligned} & V\left(0^{\circ} \mathrm{C}\right) \\ & V\left(25^{\circ} \mathrm{C}\right) \\ & V\left(55^{\circ} \mathrm{C}\right) \end{aligned}$ | $\begin{aligned} & I_{O L}=500 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V} \end{aligned}$ <br> All Inputs at 2.0 V |
| $\mathrm{V}_{\mathrm{OH}}(\mathrm{MIN}$. | OUTPUT "HIGH" VOLTAGE | $\begin{aligned} & V_{S S}-0.7 \\ & v_{S S}-0.6 \\ & V_{S S}-0.5 \end{aligned}$ | $\begin{aligned} & V\left(0^{\circ} \mathrm{C}\right) \\ & V\left(25^{\circ} \mathrm{C}\right) \\ & V\left(55^{\circ} \mathrm{C}\right) \end{aligned}$ | $\begin{aligned} & { }^{{ }^{O H}}=-500 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V} \\ & \text { All Inputs at } 0.85 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}(\mathrm{MAX}$. |  | $\mathrm{V}_{S S}+1.0$ | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V} \end{aligned}$ |
| ${ }^{\prime} \mathrm{OL}$ | OUTPUT SINK CURRENT | 100 | mA | $\begin{aligned} & V_{O}=4 \mathrm{~V}, V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V}, \\ & V_{B B}=23 \mathrm{~V}, V_{E}=V_{D}=2.0 \mathrm{~V} \end{aligned}$ |
| ${ }^{\prime} \mathrm{OH}$ | OUTPUT SOURCE CURRENT | -100 | mA | $\begin{aligned} & V_{O}=V_{S S}-4 V, V_{C C}=5.0 \mathrm{~V}, V_{S S}=19 \mathrm{~V} \\ & V_{B B}=23 V, V_{E}=V_{D}=0.85 \mathrm{~V} \end{aligned}$ |
| $V_{\text {IL }}$ | INPUT 'LOW' VOLTAGE | 1.0 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V}$ |
| $V_{1 H}$ | INPUT "HIGH" VOLTAGE | 2.0 | V | $V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{S S}=19 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=23 \mathrm{~V}$ |
| $\mathrm{Cl}_{1 \mathrm{~N}}$ | INPUT CAPACITANCE | 8(Typical) | pF | $\mathrm{V}_{\text {BIAS }}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V}$ |

D.C. CHARACTERISTICS (Cont'd) $T_{A}=0^{\circ} \mathrm{C}$ to $+55^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}-\mathrm{V}_{\mathrm{SS}}=3.0 \mathrm{~V}$ to 4.0 V

POWER SUPPLY CURRENT DRAIN:
All Outputs "Low"

| Symbol | Parameter | Min. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |

All Outputs "High"

| ${ }^{\prime} \mathrm{CC}$ | Current from $\mathrm{V}_{\mathrm{CC}}$ | 33 | mA |
| :--- | :--- | :---: | :---: |
| ${ }^{\prime} \mathrm{SS}$ | Current from $\mathrm{V}_{\mathrm{SS}}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=20 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=24 \mathrm{~V}$ |  |
| All Inputs Grounded |  |  |  |

Standby Condition with $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=\mathrm{V}_{\mathrm{BB}}$

| ${ }^{1} \mathrm{CC}$ | Current from $\mathrm{V}_{\mathrm{CC}}$ | 0 | mA | $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \mathrm{~V}_{S S}=20 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=20 \mathrm{~V}$ |
| :---: | :---: | :---: | :---: | :---: |
| 'SS | Current from $\mathrm{V}_{\mathrm{SS}}$ | 500 | $\mu \mathrm{A}$ |  |
| ${ }^{\prime} \mathrm{BB}$ | Current from $\mathrm{V}_{\mathrm{BB}}$ | 500 | $\mu \mathrm{A}$ |  |
| $\mathrm{P}_{\text {TOTAL }}$ | Total Power Dissipation | 15 | mW |  |

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=19 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=\mathrm{V}_{\mathrm{SS}}+3$ to $4 \mathrm{~V}, \mathrm{f}=2 \mathrm{MHz}, 50 \%$ Duty Cycle

| SYMBOL | TEST | LIMITS (ns) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | pF MAX. | $C_{L}$ <br> MIN. | pF MAX | DELAY DIFFERENTIAL ${ }^{(1)}$ $C_{L}=200 \mathrm{pF}$ <br> MAX. |
| $\mathrm{t}_{+}$ | INPUT TO OUTPUT DELAY | 5 | 15 | 5 | 15 | 5 |
| ${ }^{\text {- }}$ + | INPUT TO OUTPUT DELAY | 5 | 25 | 5 | 25 | 10 |
| $\mathrm{t}_{\mathrm{r}}$ | OUTPUT RISE TIME | 5 | 20 | 5 | 30 | 10 |
| $\mathrm{t}_{\mathrm{f}}$ | OUTPUT FALL TIME | 5 | 25 | 10 | 35 | 10 |
| ${ }^{t}$ D | DELAY + RISE OR FALL TIME | 10 | 35 | 20 | 45 | 10 |

(1) This is defined as the maximum skew between any output in the same package, eg., all the input to output delays for the $t_{-+}$parameter are within a maximum of 10 nsec of each other in the same package.

## WAVEFORMS



3222
REFRESH CONTROLLER FOR 4K DYNAMIC RANDOM ACCESS MEMORIES

■ Ideal for use in 2107A, 2107C Systems

- Simplifies System Design
- Reduces Package Count

■ Standard 22-Pin DIP

## Adjustable Refresh Timing Oscillator <br> - 6-Bit Address Multiplexer <br> ■ 6-Bit Refresh Address Counter <br> ■ 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® ${ }^{\circledR} 2107 \mathrm{C}$. 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}$ - $\mathrm{A}_{5}$ | ADDRESS INPUTS | $\bar{o}_{0} \cdot \bar{o}_{5}$ | ADDRESS OUTPUTS |
| :---: | :---: | :---: | :---: |
| $\overline{\text { ACK }}$ | ACKNOWLEDGE OUTPUT | $\overline{\mathrm{o}}$ | INTERNAL REFRESH REQUEST LATCH OUTPUT |
| BUSY | BUSY INPUT | REFON | REFRESH ON OUTPUT |
| CYREO | CYCLE REQUEST INPUT | REFREO | REFRESH REQUEST 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 $\overline{\text { 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}$ |
| IRB | Input Leakage Current $\overline{\mathrm{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}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.8 | V |  |
| $\mathrm{V}_{\text {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}$ |
| Isc | Output High Short Circuit Current |  | -48 | -70 | mA | $\begin{aligned} & V_{\mathrm{OUT}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.32 | 0.45 | V | $\mathrm{IOL}^{\mathrm{OL}}=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{I}_{\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{l}_{\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}}=25^{\circ} \mathrm{C}$ and nominal power supply voltages.

Capacitance ${ }^{[2]}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol |  | Limits (pF) | Conditions |  |
| :--- | :--- | :---: | :---: | :--- |
|  |  |  |  |  |
| $\mathrm{C}_{\mathrm{IN}}$ (Address) | Input Capacitance | 5 | 10 | $\mathrm{~V}_{\text {bias }}=2.0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{IN}}$ ( $\left.\overline{\mathrm{CYREQ}}\right)$ | Input Capacitance | 6 | 10 |  |
| $\mathrm{C}_{\mathrm{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 $V_{C C}=+5.0 \mathrm{~V} \pm 5 \%, T_{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{B U S Y}=V_{I 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{\text { BUSY }}$ In to $\overline{\text { ACK Out }}$ |  | 14 | 20 | ns | $\overline{\text { REFREQ }}=\mathrm{V}_{\mathrm{IH}}, \overline{\mathrm{CYREQ}}=\mathrm{V}_{\mathrm{IL}}$ |
| $t_{\text {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{\mathrm{CYREO}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{t}_{\text {HOLD }}$ | BUSY Hold Time | 50 |  |  | ns | External Delay between STARTCY and $\overline{B U S Y}$ |
| $\mathrm{t}_{\mathrm{RH}}$ | $\overline{\text { CYREQ or } \overline{\text { REFREQ }} \text { Hold Time }}$ | 0 |  |  | ns | External Delay after $\overline{\text { BUSY }}$ |
| $t_{\text {RR }}$ | $\overline{\text { REFREQ }}$ to $\overline{\text { REFON }}$ |  | 18 | 26 | ns | $\overline{\mathrm{CYREQ}}$ and $\overline{\mathrm{BUSY}}=\mathrm{V}_{I H}$, No priority contention between $\overline{\operatorname{REFREO}}$ and CYREO |
| $t_{\text {RRC }}$ | REFREO to REFON |  | 33 | 45 | ns | $\overline{\overline{B U S Y}}=V_{1 H}$ |
| $\mathrm{t}_{\text {RS }}$ | CYREQ or REFREQ In to STARTCY Out | 9 | 14 | 21 | ns | $\overline{\overline{B U S Y}}=\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

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

E. TYPICAL APPLICATION OF 3222 REFRESH
CONTROLLER IN A 2107C SYSTEM



## F. USE OF 3222 FOR REFRESH TIMING AND CONTROL IN A 2104A SYSTEM



## PIN NAMES AND FUNCTIONS

| Pin No. | Pin <br> Name | Function |
| :---: | :---: | :---: |
| 1 | $\bar{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 $\overline{B U S Y}$ is high the memory is not busy and a system or refresh cycle may begin. If $\overline{\mathrm{BUSY}}$ 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 | RX/CX | 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 ${ }^{\circledR} 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 $\left(\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}\right)$.
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{\operatorname{REFREQ}}$ ), 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 (BUSY $=$ Low)
3. Refresh cycle request - memory not busy (BUSY $=$ 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 $\overline{C Y R E Q}$ input going low. The Start Cycle output STARTCY goes low at $\mathrm{t}_{\mathrm{RS}}$ after CYREQ. STARTCY is used for two purposes:

1. To set the external $\overline{B U S Y}$ 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{\mathrm{ACK}}$ to go low (after $\mathrm{t}_{\mathrm{BK}}$ 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 $\overline{B U S Y}$ returning high. (If $\overline{B U S Y}$ goes high before $\overline{C Y R E Q}$ 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} n s e c$. 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 ( $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ ) 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 $\mathrm{t}_{\mathrm{AA}}$ time if the previous cycle was a system cycle request and change at or before $t_{B A M}$ 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{\mathrm{ACK}}$ can not go low until after $\mathrm{t}_{\text {HOLD }}$ there is no ambiguity between $\overline{R E F O N}$ and $\overline{A C K}$. 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 ( $\overline{R E F R E Q}$ ) going low. This low going input causes both the Start Cycle output,

and tRRC (or tRR) time respectively. The low going edge of STARTCY is used to set the external BUSY 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 $\overline{B U S Y}$ drives the $\overline{S T A R T C Y}$ 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 $\overline{\text { STARTCY }}$ input goes low $\mathrm{t}_{\mathrm{BS}}$ 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 ( $\overline{\mathrm{O}}_{0}-\overline{\mathrm{O}}_{5}$ ) 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 ${ }^{(3} 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{\mathrm{CYREQ}}$ 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{A C K}$ 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 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 2107C $r=64$ ).
$R_{\mathrm{X}}=$ external timing resistance in $\mathrm{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.

## intel

## 3232 <br> ADDRESS MULTIPLEXER AND REFRESH COUNTER FOR 4K DYNAMIC RAMs

Ideal for 2104A
■ Simplifies System Design

- Reduces Package Count

Standard 24-Pin DIP

■ 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 \%$

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.

PIN CONFIGURATION


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 |
| L | L | COLUMN ADDRESS <br> $\left(A_{6}\right.$ THROUGH A $\left._{11}\right)$ |

COUNT - ADVANCES INTERNAL REFRESH COUNTER.
ZERO DETECT - INDICATES A ZERO IN THE REFRESH ADDRESS (USED IN BURST REFRESH MODE).

LOGIC 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.5V to +7 Volts |
| Output Currents | 100mA |
| 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. 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}}^{\prime}=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. (1) | MAX. |  |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current |  | -0.04 | -0.25 | mA | $\mathrm{~V}_{\mathrm{IN}}=0.45 \mathrm{~V}$ |
| $\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 $V_{c c}=+5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$, Load $=1 \mathrm{TTL}, \mathrm{C}_{\mathrm{L}}=250 \mathrm{p} \overrightarrow{\mathrm{F}}$, Unless Otherwise Specified.

| SYMBOL | PARAMETER | MIN. | TYP( ${ }^{(1)}$ | MAX. | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AO }}$ | Address Input to Output Delay |  | 6 | 9 | ns | Refresh Enable $=$ Low $^{(1)(2)}$ |
| $\mathrm{t}_{\mathrm{AO} 1}$ | Address Input to Output Delay |  | 16 | 25 | ns | Refresh Enable = Low |
| $\mathrm{t}_{\mathrm{ob}}$ | Row Enable to Output Delay | 7 | 12 | 27 | ns | Refresh Enable $=$ Low ${ }^{(1)(2)}$ |
| $\mathrm{tool}^{\text {l }}$ | 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 | 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 $=\operatorname{High}^{(1)(2)}$ |
| $t_{\text {col }}$ | $\overline{\text { Count }}$ to Output | 20 | 55 | 80 | ns | Refresh Enable $=$ High |
| $f_{c}$ | Counting Frequency | 5 |  |  | MHz |  |
| $\mathrm{t}_{\text {cpw }}$ | Count Pulse Width | 35 |  |  | ns |  |
| $t_{\text {cz }}$ | $\overline{\text { Count to }} \overline{\text { Zero }} \overline{\text { Detect }}$ | 15 |  | 70 | ns | Note 2 |

Note 1: $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
2: $C_{L}=15 p F$
A.C. TIMING WAVEFORMS (Ty.pically used with 2104A)

## NORMAL CYCLE



## REFRESH CYCLE



| PIN NAMES AND FUNCTIONS |  |  |
| :---: | :---: | :---: |
| 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}$ | $A_{6}-A_{11}$ Inputs | Column address inputs. |
| $\begin{aligned} & 9,11,10 \\ & 16,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 ( $\mathrm{A}_{0}$ through $\mathrm{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{\text { Zero }} \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 trefresh is the specified refresh rate for the device. For the 2104A $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 $\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 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 $A_{6}-A_{11}$ are gated to the outputs and applied to the driven memories.
Figure 1 shows a typical connection between the 3232 and the 2104A 4K 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 \%$
- 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(A_{0}\right.$ THROUGH $A_{6}$ ) |
| $L$ | L | COLUMN ADDRESS <br> $\left(\mathrm{A}_{7}\right.$ THROUGH $\mathrm{A}_{13}$ ) |

COUNT - ADVANCES INTERNAL REFRESH COUNTER. ZERO DETECT - INDICATES ZERO IN THE FIRST 6 SIGNIFICANT REFRESH COUNTER BITS (USED IN BURST REFRESH MODE)

LOGIC DIAGRAM
COUNT 0 $\qquad$

## 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{AOL}}$ | 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{EO}}$ | Refresh Enable to Output Delay | 7 | 14 | 27 | ns | Notes 2, 3 |
| $\mathrm{t}_{\mathrm{EOI}}$ | 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{tcOl}^{\text {c }}$ | $\overline{\text { Count }}$ to Output | 20 | 55 | 80 | ns | Refresh Enable $=$ High |
| $\mathrm{f}_{\mathrm{C}}$ | Counting Frequency |  |  | 5 | MHz |  |
| $\mathrm{t}_{\text {CPW }}$ | $\overline{\text { Count }}$ Pulse Width | 35 |  |  | ns |  |
| $t_{\text {cz }}$ | $\overline{\text { Count to } \overline{\text { Zero }} \overline{\text { Detect }} \text { ]}}$ | 15 |  | 70 | ns | Note 3 |

Notes: 1. Typical values are for $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.5V 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 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. (1) | MAX. |  |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current |  | -0.04 | -0.25 | 10 | $\mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current |  | 0.01 | $\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 $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
2. Inputs are high impedance, TTL compatible, and suitable for bus operation.

## Packaging Information

## 28 LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D



| PIN NAMES AND FUNCTIONS |  |  |
| :--- | :--- | :--- |
| Pin <br> No. | Pin <br> Name | Function |
| 1 | Count <br> Input | Active low input increments internal 7- <br> bit counter by one for each count pulse <br> in. |

*The inputs are high impedance, TTL compatible, and suitable for bus operation.

## DEVICE OPERATION

The Intel ${ }^{\circledR} 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 ( $A_{7}$ 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 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 $\overline{\text { Zero }} \overline{\text { Detect. }}$

## Distributed Refresh Mode

In the distributed refresh mode, one row is selected for refresh each ( $t_{\text {REFRESH }} / n$ ) time where $n=$ number of refresh cycles required for the device and $t_{\text {REFRESH }}$ 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 $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 $\mathrm{n}_{\mathrm{x}+1}$. The $\overline{\text { 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.

## 3245 <br> QUAD TTL-TO-MOS DRIVER <br> FOR 4K N-CHANNEL MOS RAMs

Fully Compatible with 4K RAMs Without Requiring Extra Supply or External Devices<br>- High Speed, 32 nsec Max. Delay + Transition Time<br>- Low Power - 75mW Typical Per Channel

The Intel ${ }^{\circledR} 3245$ is a Quad Bipolar-to-MOS driver which accepts TTL and DTL input signals. It provides high output current and voltage suitable for driving the clock inputs of N-channel MOS memories such as the 2107 B . The circuit operates from two power supplies which are 5 and 12 volts. Input and output clamp diodes minimize line reflections.
The device features two common enable inputs, a refresh select input, and a clock control input for simplified system designs. The internal gating structure of the 3245 eliminates gating delays and minimizes package count.
The 3245 is fabricated by means of Intel's highly reliable Schottky bipolar process and is specified for operation over a 0 to $+75^{\circ} \mathrm{C}$ ambient temperature range.


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$
Storage Temperature. . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Supply Voltage, $V_{\text {Cc }}$. . . . . . . . . . . . . . -0.5 to +7 V
Supply Voltage, VDD . . . . . . . . . . . . . . -0.5 to +14V
All Input Voltages . . . . . . . . . . . . . . . . -1.0 to VDD
Outputs for Clock Driver . . . . . . . . . -1.0 to VDD +1 V
Power Dissipation at $25^{\circ} \mathrm{C}$
*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 $75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {FD }}$ | Input Load Current, $\bar{T}_{1}, \bar{T}_{2}, \bar{T}_{3}, \bar{I}_{4}$ |  | -0.25 | mA | $V_{F}=0.45 \mathrm{~V}$ |
| $I_{\text {FE }}$ | Input Load Current, $\overline{\mathrm{R}}, \overline{\mathrm{C}}^{\prime}, \bar{E}_{1}, \overline{\mathrm{E}}_{2}$ |  | -1.0 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{RD}}$ | Data Input Leakage Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.0 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RE }}$ | Enable Input Leakage Current |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}, \mathrm{~V}_{\mathrm{IH}}=2 \mathrm{~V}$ |
|  |  | -1.0 |  | V | $\mathrm{IOL}^{\text {O }}=-5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | $\mathrm{V}_{\mathrm{DD}}-0.50$ |  | V | $\mathrm{l}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{~V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
|  |  |  | $\mathrm{V}_{\mathrm{DD}}+1.0$ | V | $\mathrm{IOH}=5 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input Low Voltage, All Inputs |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage, All Inputs | 2 |  | V |  |

## POWER SUPPLY CURRENT DRAIN AND POWER DISSIPATION

| Symbol | Parameter | Typ. | Max. | Unit | Test Conditions - Input states to ensure the following output states: | Additional Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{\text {CC }}$ | Current from $\mathrm{V}_{\mathrm{CC}}$ | 23 | 30 | mA | High | $\begin{aligned} & V_{C C}=5.25 \mathrm{~V} \\ & V_{D D}=12.6 \mathrm{~V} \end{aligned}$ |
| IDD | Current from V ${ }_{\text {DD }}$ | 19 | 26 | mA |  |  |
| $\mathrm{P}_{\mathrm{D} 1}$ | Power Dissipation | 365 | 485 | mW |  |  |
|  | Power Per Channel | 91 | 121 | mW |  |  |
| ICC | Current from V CC | 29 | 39 | mA | Low |  |
| IDD | Current from VDD | 12 | 15 | mA |  |  |
| $\mathrm{P}_{\mathrm{D} 2}$ | Power Dissipation | 300 | 388 | mW |  |  |
|  | Power Per Channel | 75 | 97 | mW |  |  |

A.C. CHARACTERISTICS $T_{A}=0^{\circ}$ to $75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min.1] | Typ.[2,4] | Max.[3] | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{t}_{-+}$ | Input to Output Delay | 5 | 11 |  | ns | $R_{\text {SERIES }}=0$ |
| $\mathrm{t}_{\text {DR }}$ | Delay Plus Rise Time |  | 20 | 32 | ns | $R_{\text {SERIES }}=0$ |
| $\mathrm{t}_{+-}$ | Input to Output Delay | 3 | 7 |  | ns | $R_{\text {SERIES }}=0$ |
| $\mathrm{t}_{\text {DF }}$ | Delay Plus Fall Time |  | 18 | 32 | ns | $R_{\text {SERIES }}=0$ |
| $\mathrm{t}_{\mathrm{T}}$ | Output Transition Time | 10 | 17 | 25 | ns | $R_{\text {SERIES }}=20 \Omega$ |
| $\mathrm{t}_{\text {DR }}$ | Delay Plus Rise Time |  | 27 | 38 | ns | $R_{\text {SERIES }}=20 \Omega$ |
| $\mathrm{t}_{\text {DF }}$ | Delay Plus Fall Time |  | 25 | 38 | ns | $R_{\text {SERIES }}=20 \Omega$ |

NOTES: 1. $C_{L}=150 \mathrm{pF}$
2. $C_{L}=200 \mathrm{pF}$
3. $C_{L}=250 p F$values represent a range of
4. Typical values are measured at $25^{\circ} \mathrm{C}$.

CAPACITANCE ${ }^{*} \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Test | Typ. | Max. | Unit |
| :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance, $\overline{\bar{I}_{1}}, \overline{\bar{I}_{2}}, \overline{\bar{I}}_{3}, \overline{\bar{I}}_{4}$ | 5 | 8 | pF |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance, $\overline{\mathrm{R}}, \overline{\mathrm{C}}, \overline{\mathrm{E}}_{1}, \overline{\mathrm{E}}_{2}$ | 8 | 12 | pF |

*This parameter is periodically sampled and is not $100 \%$ tested. Condition of measurement is $f=1 \mathrm{MHz}, V_{\text {bias }}=2 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V}$, and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## A.C. CONDITIONS OF TEST

Input Pulse Amplitudes: 3.0V
Input Pulse Rise and Fall Times: 5 ns between 1 volt and 2 volts
Measurement Points: See Waveforms


## WAVEFORMS



## TYPICAL CHARACTERISTICS

INPUT TO OUTPUT DELAY VS. LOAD CAPACITANCE


DELAY PLUS TRANSITION TIME VS. LOAD CAPACITANCE


## Typical System

Below is an example of a $64 \mathrm{~K} \times 18$ bit memory system (each card is $16 \mathrm{~K} \times 18$ ) employing the 3245 quad high voltage driver for the chip enable inputs. A single 3245 package drives $16 \mathrm{~K} \times 9$ bits. $A_{0}$ through $A_{11}$ are $2107 B$ addresses.



## TELECOMMUNICATIONS

## INTRODUCTION

The 2910 and 2911 Codecs (Coder-Decoder) are the first members of a family of advanced Telecommunication components. High density LSI fabrication techniques are used allowing sample and hold, digital to analog converter, and comparitors to be integrated on a single chip along with digital logic necessary to interface a full duplex PCM (Pulse Code Modulation) link.
The 2912 Line Filters are designed to interface directly to the Codecs to perform the filtering function required in PCM Systems. The 2912 is a fully integrated monolithic device that contains the transmit and receive filters, a 50/60 Hertz notch, power amplifiers, and features necessary to interface directly to the Codec.
The primary applications of the Codecs and Filters are in telephone systems for the transmission, switching and concentration of voice communications in PCM Systems.

## TABLE OF CONTENTS

2910 PCM CODEC - $\mu$ LAW ..... 6-3
2911 PCM CODEC - A LAW . ..... 6-14
2912 PCM LINE FILTERS. ..... 6-26

# 2910 <br> PCM CODEC- $\mu$ LAW <br> 8-BIT COMPANDED A/D AND D/A CONVERTER 

- Per Channel, Single Chip Codec
- CCITT G711 and G733 Compatible. ATT T1 Compatible with 8th Bit Signaling
- Microcomputer Interface with On-Chip Time-Slot Computation


## 78dB Dynamic Range, with Resolution Equivalent to 12-Bit Linear Conversion Around Zero

■ $\pm 5 \%$ Power Supplies: $+12 \mathrm{~V},+5 \mathrm{~V},-5 \mathrm{~V}$

- Precision On-Chip Voltage Reference
- Low Power Consumption 230mW Typ. Standby Power 110 mW Typ.
- All Digital Inputs and Outputs TTL Compatible
- Fabricated with Reliable $\mathbf{N}$-Channel MOS Process

The Intel® 2910 is a fully integrated PCM (Pulse Code Modulation) Codec (Coder-Decoder), fabricated with N-channel silicon gate technology. The high density of integration allows the sample and hold circuits, the digital-to-analog converter, the comparator and the successive approximation register to be iritegrated on the same chip, along with the logic necessary to interface a full duplex PCM link and provide in-band signaling.
The primary applications are in telephone systems:

- Transmission
- Switching - Digital PBX's and Central Office Switching Systems
- Concentration - Subscriber Carrier/Concentrators

The wide dynamic range of the 2910 ( 78 dB ) and the minimal conversion time ( $80 \mu \mathrm{sec}$ minimum) make it an ideal product for other applications, like:

- Data Acquisition
- Secure Communications Systems
- Telemetry
- Signal Processing Systems

BLOCK DIAGRAM



## PIN DESCRIPTION

| Pin No. | Symbol | Function | Description |
| :--- | :--- | :--- | :--- |
| 1 | CAP1x | Hold | Connections for the transmit <br> holding capacitor. Refer to Appli- <br> cations Section. |
| 2 | CAP2x | VFx | Input |
| 3 | Analog input to be encoded into <br> a PCM word. The signal on this <br> lead is sampled at the same rate <br> as the transmit frame synchroni- <br> zation pulse FSx, and the sample <br> value is held in the external <br> capacitor connected to the <br> CAP1x and CAP2x leads until <br> the encoding process is com- <br> pleted. |  |  |
| 4 | AUTO | Output | Most significant bit of the en- |
| coded PCM word (+5V for nega- |  |  |  |
| tive, -5V for positive inputs). |  |  |  |
| Refer to the Codec Applications |  |  |  |
| section. |  |  |  |


| Pin No. | Symbol | Function | Description |
| :--- | :--- | :--- | :--- |
| 15 | $\overline{\text { TSX }}$ | Output | Normally high, this signal goes <br> low while the Codec is transmit- <br> tingan 8-bit PCM word on the Dx <br> lead. (Time-slot information <br> used for diagnostic purposes <br> and also to gate the data on the <br> Dx lead.) TTL interface, open <br> drain output. |
| 16 | VCC | Power | +5V, +5\%, referenced to GRDD. |
| 17 | CLKR | Input | Master receive clock defining <br> the bit rate on the receive PCM <br> highway. Typically 1.544 Mbps <br> for a T1 carrier system. Maxi- <br> mum rate 2.1 Mbps. 50\% duty <br> cycle. TTL interface. |
| 18 | FSR | Input | Frame synchronization pulse for <br> the receive PCM highway. Re- |
| sets the on-chip time slot count- |  |  |  |
| er for the receive side. Maximum |  |  |  |
| repetition rate 12 KHz. Also used |  |  |  |
| to differentiate between non- |  |  |  |
| signaling frames and signaling |  |  |  |
| frames for the receive side. TTL |  |  |  |
| interface. |  |  |  |

## FUNCTIONAL DESCRIPTION

The 2910 PCM Codec provides the analog-to-digital and the digital-to-analog conversions necessary to interface a full duplex ( 4 wires) voice telephone circuit with the PCM highways of a time division multiplexed (TDM) system.

In a typical telephone system the Codec is used between the PCM highways and the line filters.

The Codec provides two major functions:

- Encoding and decoding of analog signals (voice and call progress tones)
- Encoding and decoding of the signaling and supervision information

On a non-signaling frame, the Codec encodes the incoming analog signal at the frame rate (FSX) into an 8bit PCM word which is sent out on the Dx lead at the proper time. Similarly, on a non-signaling frame of the receive link, the Codec fetches an 8-bit PCM word from the receive highway ( $D_{R}$ lead) and decodes an analog value which will remain constant on lead VFR until the next receive frame. Transmit and receive frames are independent. They can be asynchronous (transmission) or synchronous (switching) with each other.

On a signaling frame, the Codec transmit side will encode the incoming analog signal as previously described and substitute the signal present on lead SIGx for the least significant bit of the encoded PCM word. Similarly, on a receive signaling frame, the Codec will decode the 7 most significant bits according to the CCITT G733 recommendation and will output the least significant bit value on the SIGR lead until the next signaling frame. Signaling frames on the send and receive sides are independent of each other.


The 2910 Codec is intended to be used on line and trunk terminations. The call progress tones (dial tone, busy tone, ring-back tone, re-order tone), and the pre-recorded announcements, can be sent through the voice-path, while signaling (off hook and disconnect supervision, rotary dial pulses, ring control) is sent through the signaling path.
Circuitry is provided within the Codec to internally define the transmit and receive time-slots in order to minimize the common equipment. This feature can be bypassed and discrete time-slots sent to each Codec within a system.

In the power-down mode, most functions of the Codec are disabled to reduce power dissipation to a minimum.

## CODEC OPERATION

## Codec Control

The operation of the 2910 is defined by serially loading an 8 -bit word through the Dc lead (data) and the CLKc lead (clock). The loading is asynchronous with the other operations of the Codec, and takes place whenever transitions occur on the CLKc lead. The Dc input is loaded in during the trailing edge of the CLK $\mathrm{K}_{\mathrm{C}}$ input.


The control word contains two fields:
Bit 1 and Bit 2 define whether the subsequent 6 bits apply to both the transmit and receive side ( 00 ), the transmit side only (01), the receive side only (10) or whether the Codec should go into the standby, power-down mode (11). In the latter case (11), the following 6 bits are irrelevant.

The last 6 bits of the control word define the time-slot assignment, from 000000 (time-slot 1 ) to 111111 (time-slot $64)$. Bit 3 is the most significant bit and bit 8 the least significant bit and last into the Codec.

| Bit 1 | Bit 2 | Mode |
| :---: | :---: | :---: |
| 0 | 0 | $\times \& R$ |
| 0 | 1 | $\times$ |
| 1 | 0 | $R$ |
| 1 | 1 | Standby |


| Bit 3 | $\ldots$ | $\ldots$ | $\ldots$ | Time Slot |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 | 1 | 2 |
|  |  |  | $\cdot$ |  |  | $\cdot$ |
|  |  |  | $\cdot$ |  |  | $\cdot$ |
|  |  |  | $\cdot$ |  |  | $\cdot$ |
| 1 | 1 | 1 | 1 | 1 | 1 | $\cdot$ |

The Codec will retain the control word (or words) until a new word is loaded in or until power is lost. This feature permits dynamic allocation of time-slots for switching applications.

## Microcomputer Control Mode

In the microcomputer mode, each Codec performs its own time-slot computation independently for the transmit and receive channels by counting clock pulses (CLKx and CLKR). All Codec's tied to the same data bus receive identical framing pulses ( $F S_{x}$ and $F_{R}$ ). The framing pulses reset the on-chip time-slot counters every frame; hence the time-slot counters of all devices are synchronized. Each Codec is programmed via CLKc and Dc for the desired transmit and receive time-slots according to the description in the Codec Control Section. All Codec's tied to the same $D_{R}$ bus will, in general, have different receive time-slots, although that is not a device requirement. There may be separate busses for transmit and receive or all Codec's may transmit and receive over the same bus, in which case the transmit and receive channels must be synchronous (CLKX $=$ CLK $K_{R}$ ). There are no other restrictions on time-slot assignments; a device may have the same transmit and receive timeslot even if a single bus is used.
There are several requirements for using the CLKc-Dc interface in the microcomputer mode.

1. A complete time-slot assignment, consisting of eight negative transitions of CLK $\mathrm{K}_{\mathrm{C}}$, must be made in less than one frame period. The assignment can overlap a framing pulse so long as all 8 control bits are clocked in within a total span of $125 \mu \mathrm{sec}$ (for an 8 KHz frame rate). CLKc must be left at a TTL low level when not assigning a time-slot.
2. A dead period of two frames must always be observed between successive time-slot assignments. The two frame delay is measured from the rising edge of the first

CLKC transition of the previous time-slot assigned.
3. When the device is in the power-down state, an initialization time-slot assignment is required prior to the assignment of the desired time-slots. That is, the first assignment brings the device out of power-down but does not register the time-slot information in the lower six bits of the control word. Once the initialization time-slot assignment has been completed, the desired time-slots may be assigned according to the descriptions above. The two frame delay between the initialization and the time-slot assignment must be observed.

Example of Microcomputer Control Mode:
The two words 01000001 and 10000010 have been loaded into the Codec. The transmit side is now programmed for time-slot 2 and the receive side for time-slot 3. The Codec will output a PCM word on the transmit PCM highway (bus) during the time-slot 2 of the transmit frame, and will fetch a PCM word from the receive PCM highway during time-slot 3.


In this example the Codec interface to the PCM highway then functions as shown below (FSX and FSR may be asynchronous).


## Direct Control Mode

In the Direct Mode, unlike the microcomputer mode, the Codec time-slots bear a fixed phase relationship to the framing pulses (FSX, FSR). Frame pulses become timeslot strobes. Devices tied to the same Dx bus must get different FSx pulses; all devices tied to the same $D_{R}$ bus will, in general, receive different $F_{R}$ pulses, although that is not a device requirement. Again the $D_{x}$ and $D_{R}$ busses may be the same bus in synchronous systems, and there are no restrictions on the relationship between the transmit and receive time-slots of a given Codec. The direct mode is a special case of the microcomputer mode in that the device always operates in the first time-slot and
hence transmits and receives its data in the eight clock periods which begin with the first clock (CLKx or CLKR) rising edge following the rising edge of the framing pulse (FSX or FSR). That is, bit 1 of each time-slot is delayed one clock cycle from the leading edge of the respective framing pulse.

The essential difference between the direct mode and microcomputer mode is that in the direct mode, the control words always consist either of all 1's (for assigning power-down) or all 0's (for powering up the device and assigning the first time-slot). Hence there are fewer timing constraints on Dc and CLK C . In particular, it is possible to define a continuous clock which can be tied to CLKc and
which makes the device behave as if the Dc lead is an active low chip select. Whenever selected, the device assumes the first time-slot in both the transmit and receive directions. The characteristics of the continuous clock used for CLKc are:
a) The clock must contain at least 8 pulses per frame.
b) The transitions must occur only during the 8th bit of any transmit time-slot. CLKc transitions may not occur during the first through seventh bits of any transmit time-slot. This requirement is unique to the case when
the direct mode is implemented with a continuous clock on CLKc. Commonly, the external timing circuitry which is used to generate the time-slot strobes for the direct mode control, will contain a clock which marks the 8th bit of each transmit time-slot (for example, a signaling bit marker).
c) The microcomputer mode requirement that successive time-slot assignments be separated by two frames does not apply when a continuous clock with these characteristics is used for CLKc.

## General Control Requirements

All bit and frame clocks should be applied whenever the device is active. In particular, an unused channel cannot be de-activated by removal of its associated frame or bit clock while the other channel of the same device remains active. A single channel can be removed from service in the microcomputer mode by assigning an excess timeslot to that channel.
Since the time-slot counters contain 6-bits they can count to 64 time-slots. Therefore, a channel assigned an excess
time-slot (e.g. time-slot 48 in a 32 channel system) will remain idle.

A single channel cannot be deactivated in the direct control mode except by physical disconnection of the data lead ( $\mathrm{Dx}_{\mathrm{x}}$ or $\mathrm{DR}_{\mathrm{R}}$ ) from the system data bus. A device (both transmit and receive channels) may be de-activated in either control mode by powering down the device. Both channels are always powered down together.

## Encoding

The VF signal to be encoded is input on the VFx lead. An internal switch samples the signal and the hold function is performed by the external capacitor connected to the CAP1x and CAP $2 x$ leads. The sampling and conversion is synchronized with the transmit time-slot (worst case
conversion time is 20 time-slots). The PCM word is then output on the Dx lead at the proper time-slot occurrance of the following frame. The A/D converter saturates at approximately $\pm 2.2$ volts rms ( $\pm 3.1$ volts peak).


## Decoding

The PCM word is fetched by the DR lead from the PCM highway at the proper time-slot occurrence. The decoded value is held on the external capacitor connected to the CAP1R and CAP2R leads.

The buffered non-return to zero output signal on the VFR lead is equal to the stored voltage on CAPR. The output signal on lead $V F_{R}$ has a dynamic range of approximately $\pm 2.2$ volts rms ( $\pm 3.1$ volts peak).

## Signaling

The duration of the FSX and FSR pulses defines whether a frame is an information frame or a signaling frame:

- A frame synchronization pulse which is a full clock period in duration (CLKx period for FSx, CLK ${ }_{R}$ period for $\mathrm{FS}_{\mathrm{R}}$ ) designates a non-signaling frame.
- A frame synchronization pulse which is two full clock periods in duration (two CLKx periods for FSx, two CLK ${ }_{R}$ periods for FSR) designates a signaling frame.
On the encoding side, when the FSx pulse is widened, the 8th bit of the PCM word will be replaced by the value on the SIGx input at the time when the 8th bit is output on the $\mathrm{Dx}_{\mathrm{x}}$ lead.


On the decoding side, when the FSR pulse is widened, the 8th bit of the PCM word is detected and transmitted on the SIGR lead. That output is latched until the next receiving signaling frame.

The remaining 7-bits are decoded according to the value given in the CCITT G733 recommendation. The SIGR lead is reset to a TTL low level whenever the Codec is in the power-down state.


## D3 Framing

The number of clock pulses (CLKx, CLKR) delivered to the Codec per frame must be a multiple of 8 . In the case of the D3 framing format (193 bits/frame), one clock pulse per frame must be suppressed (blanked) from the $1.544 \mathrm{Mb} / \mathrm{s}$ bit clocks CLKx and CLKR. It is generally easiest to blank the framing (193rd) bit in both cases. This pulse suppression may be performed once at the system level,
with the same bit clock distributed to all Codec's, whether the microcomputer control mode or the direct control mode is employed.

The framing pulse widths are always defined relative to Codec bit clock transitions; whenever a pulse is blanked in a Codec bit clock, any framing pulse which spans that blanked bit clock interval must be extended beyond the next bit clock transition.

## Standby Mode - Power Down

To minimize power consumption and dissipation in large systems, a standby mode is provided by loading a control word (DC) with a "1" in bits 1 and 2 locations. Most of the Codec functions thereby become disabled, with the
exception of the interface to the Dc and CLKc leads, to allow the Codec to be reactivated.

The power consumption in the standby mode is typically 110 mW .

## Power-On Clear

Whether the device is used in the direct or microcomputer mode, an internal reset (power-on clear) is generated whenever either of the two positive device power supplies
(VDD or VCC) are removed or applied. The Codec thus assumes the power-down state upon application of the positive power supplies and must be initialized in the normal way for operation.

## Precision Voltage Reference for the D/A Converter

The voltage reference is generated on the chip and is calibrated during the manufacturing process. The technique uses the difference in sub-surface charge density between two suitably implanted MOS devices to derive a temperature stable and bias stable reference voltage.

A gain setting op amp, programmed during manufacturing, "trims" the reference voltage source to the final precision voltage reference value provided to the D/A converter. The precision voltage reference determines the initial gain and dynamic range characteristics described in the A.C. Transmission Specification Section.

## APPLICATIONS

## Circuit Interface



## Holding Capacitors

For an 8 KHz sampling system the transmit holding capacitor CAPX should be $2000 \mathrm{pF}, 20 \%$. The receive holding capacitor CAPR should be $470 \mathrm{pF}, 20 \%$ for 32 timeslots and 8 KHz sample rate or $560 \mathrm{pF}, 20 \%$ for 24 time-slots and 8 KHz sample rate. An additional capacitor $\mathrm{C}_{2}$ of 100 pF , is required from the CAP2R lead to GRDA.

## Auto Zero

The auto zero output (most significant bit or sign bit of the A/D conversion) integrated over a long time constant will compensate for the DC offset inside the Codec ivoltage difference between the bottom of the DAC and GRDA). The above drawing shows a possible connection between the VFx and Auto leads. The recommended values of the auto zero components are:
$C_{1}$ of $1 \mu \mathrm{~F}, \mathrm{R}_{1}$ of $47 \mathrm{k} \Omega, R_{2}$ of $330 \Omega$, and $R_{3}$ of $470 \mathrm{k} \Omega$.

## Filters Interface

The filters may be interfaced as shown in the circuit interface diagram. Note that the output pulse stream is of the non-return to zero type.

## $D_{X}$ Buffering

For optimum idle channel noise performance it is recommended that the Dx output of each Codec be buffered from the system PCM bus with an external threestate or open collector buffer. Each buffer can be enabled with the appropriate Codec generated $\overline{T S x}$ signal. The $\overline{T S x}$ signal may be used to activate zero code suppression logic on the PCM bus.

## Grounding and Decoupling Recommendations



## Grounding

Analog grounding is connected to the GRDA lead. The GRDA and GRDD leads are not connected inside the 2910. An external connection is thus necessary outside the Codec to tie all the analog ground lines to the common return of the system GRDD.

To minimize the injection of digital logic noise into the analog signal path the GRDA and GRDD external connection should be made as close as practical to the system supply ground.

## Decoupling

A $0.1 \mu \mathrm{~F}$ bypassing capacitor from each power supply to digital ground is generally recommended at each device. This decoupling may be reduced based on actual board design and performance.
Sufficient board level decoupling must be provided to guarantee that power supply transients (including turn on and off) do not exceed the absolute maximum ratings of the device. A minimum of $1 \mu \mathrm{~F}$ is recommended once per board for each power supply. A pair of small switching diodes (in opposite directions) between analog and digital ground on a once-per-board basis is recommended to maintain the two ground levels near the same value during board insertion and removal.

## 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}$ |
| All Input or Output Voltages with Respect to $V_{B B}$ | -0.3 to +20V |
| $V_{C C}, V_{D D}$ and $V_{S S}$ with |  |
| Respect to $V_{\text {BB }}$ | -0.3 to +20 V |
| Power Dissipation | 1.35 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 $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{C C}=5 \mathrm{~V} \pm 5 \%$,
$V_{B B}=-5 V \pm 5 \%, G R D A=0 V, G R D D=0 V$, unless otherwise specified.
DIGITAL INTERFACE

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| IIL | Low Level Input Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {IL }}$ |
| IIH | High Level Input Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}>\mathrm{V}_{\text {IH }}$ |
| VIL | Input Low Voltage |  |  | +0.6 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | +2.2 |  |  | V |  |
| Vol | Output Low Voltage |  |  | 0.4 | V | $\mathrm{Dx}, \mathrm{lol}=3.2 \mathrm{~mA}$ |
|  |  |  |  |  |  | SIGR, ${ }_{\text {IOL }}=0.5 \mathrm{~mA}$ |
|  |  |  |  |  |  | $\overline{\mathrm{TSx}}, \mathrm{lOL}=1.6 \mathrm{~mA}$, open drain |
|  |  |  |  |  |  | PDN, IOL $=0.5 \mathrm{~mA}$, open drain |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{DX}_{\mathrm{x}, \mathrm{IOH}}=30 \mathrm{~mA}$ |
|  |  |  |  |  |  | SIGR, $\mathrm{IOH}^{\prime}=0.6 \mathrm{~mA}$ |

## ANALOG INTERFACE

| AIZ | Input Impedance when Sampling, VFx | 125 | 300 | 500 | $\Omega$ | In Series with CAPx to GRDA, $-3.1 \mathrm{~V}<\mathrm{V}_{\text {IN }}<3.1 \mathrm{~V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Aoz | Output Impedance, VFR | 100 | 180 | 300 | $\Omega$ | -3.1 V < V OUT < 3.1V |
| VoL | Output Low Voltage, Auto |  | VBB | $V_{B B}$ | V | $400 \mathrm{k} \Omega$ to GRDA |
| VOH | Output High Voltage, Auto | Vcc | Vcc |  | V |  |
| R1 | Auto Zero Component | 42 | 47 | 52 | $\mathrm{k} \Omega$ | $47 \mathrm{k} \Omega$ Recommended ${ }^{\text {2] }}$ |
| $\mathrm{R}_{2}$ | Auto Zero Component | 290 | 330 | 360 | $\Omega$ | $330 \Omega$ Recommended ${ }^{[2]}$ |
| R3 | Auto Zero Component | 420 | 470 | 520 | k $\Omega$ | $470 \mathrm{k} \Omega$ Recommended ${ }^{\text {[2] }}$ |
| $\mathrm{C}_{1}$ | Auto Zero Component | 1.0 |  |  | $\mu \mathrm{F}$ |  |
| CAPX | Holding Capacitor, Transmit | 1600 | 2000 | 2400 | pF | 8kHz Sampling, 2000pF Recommended ${ }^{[2]}$ |
| CAPR | Holding Capacitor, Receive | 390 | 470 | 560 | pF | 8 kHz Sampling, 32 TimeSlots, 470pF Recommended ${ }^{12}$ |
|  |  | 450 | 560 | 670 | pF | 8 kHz Sampling, 24 TimeSlots, 560 pF Recommended ${ }^{12}$ |
| $\mathrm{C}_{2}$ | Bypass Capacitor | 80 |  | 120 | pF | 100pF Recommended [2] |

## POWER DISSIPATION

| IDDO | Standby Current | 6 | 9 | mA | $\begin{aligned} & V_{D D}=12.6 \mathrm{~V} \\ & V_{C C}=5.25 \mathrm{~V} \\ & V_{B B}=-4.75 \mathrm{~V} \end{aligned}$ <br> Clock Frequency 2.048 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Icco | Standby Current | 5 | 8 | mA |  |
| IbBO | Standby Current | 2 | 4 | mA |  |
| IDDI | Operating Current | 11 | 16 | mA |  |
| IcCl | Operating Current | 13 | 21 | mA |  |
| IBBI | Operating Current | 4 | 6 | mA |  |

NOTES: 1. Typical Values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. See Applications Circuit Interface for component connections.

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=+12 \mathrm{~V} \pm 5 \%, \mathrm{VCC}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 5 \%, G R D A=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.
TRANSMISSION (Any two 2910 Codec's, end-to-end)

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| S/D | Signal/Total Distortion Ratio, C-message Weighted (See Figure 1) | Fig. 1 | Fig. 1 |  | dB | $V_{F X}=1.02 \mathrm{KHz}$, Sinusoid |
| $\Delta \mathrm{G}$ | Gain Tracking Error (See Figure 2) | -0.3 |  | 0.3 | dB | $V_{F X}=1.02 \mathrm{KHz}$ Sinusoid $-37 \mathrm{dBmO} \leq \mathrm{VF} \times 0 \mathrm{dBm0}$ |
|  |  | -0.7 |  | 0.7 | dB | $-50 \mathrm{dBm0} 5 \mathrm{VFx}<-37 \mathrm{dBm0}$ |
|  |  | -2.1 |  | 2.1 | dB | $-55 \mathrm{dBm0} 5 \mathrm{VF} \times-50 \mathrm{dBm0}$ |
| NiC1 | Idle Channel Noise, C-message Weighted |  | 8 | 14 | dBrnc0 | With Auto-Zero, No Signaling ${ }^{[2]}$ |
| NiC2 | Idle Channel Noise, C-message Weighted |  | 10 | 16 | dBrnc0 | With Auto-Zero; with 6th and 12th Frame Signaling |
| HD | Harmonic Distortion (2nd or 3rd) |  | -48 | -44 | dB | $V_{\mathrm{FX}}=1.02 \mathrm{KHz}, 0 \mathrm{dBmO}$; Measured at Decoder Output, VFR |

Notes:

1. Typical Values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply values.


Figure 1. Signal/Total Distortion Ratio.


Figure 2. Gain Tracking Error ( $\Delta \mathbf{G}$ ) vs. Signal Level Reference Level OdBm0.

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=+12 \mathrm{~V} \pm 5 \%, \mathrm{VCC}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, G R D A=0 \mathrm{~V}, G R D D=0 \mathrm{~V}$, unless otherwise specified.

GAIN AND DYNAMIC RANGE

| Symbol | Parameter | Limits |  |  | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| DmW | Digital Milliwatt Response | 5.55 | 5.63 | 5.71 | dBm | $23^{\circ} \mathrm{C}$, Nominal Supplies ${ }^{[2]}$ |
| DmWT | DmW0 Variation with Temperature |  | -. 0005 | -. 0009 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}^{[2]}$ |
| DmWs | DmW0 Variation with Supplies |  |  | $\pm .07$ | dB | Supplies $\pm 5 \%{ }^{[2]}$ |
| Aor | Output Dynamic Range, VFR | 2.14 | 2.16 | 2.18 | $V_{\text {RMS }}$ | $23^{\circ} \mathrm{C}$, Nominal Supplies |
| Aort | AOR Variation with Temperature |  |  | -. 22 | mVRMS $/{ }^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}$ |
| Aors | AOR Variation with Supplies |  |  | $\pm 18$ | mV RMS | Supplies $\pm 5 \%$ |
| GSL | Self Loop Gain | -. 24 | -. 20 | -. 16 | dB | $V_{F X}=-\mathrm{dBm0} 0,1.02 \mathrm{KHz}^{[3]}$ |
| Gee | End-to-End Codec Gain | -. 4 | -. 3 | -. 2 | dB | $23^{\circ} \mathrm{C}$, Nominal Supplies ${ }^{(4)}$ |
| GEET | Gee Variation with Temperature |  | . 0010 | . 0018 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}^{[4]}$ |
| Gees | Gee Variation with Supplies |  | $\pm .07$ | $\pm .13$ | dB | Supplies $\pm 5 \%{ }^{[4]}$ |
| GfR | Decoder Frequency Response Departure from Ideal (Sinx)/x, VFR |  |  | $\pm .05$ | dB | $\begin{aligned} & 300 \mathrm{~Hz}<f<3800 \mathrm{~Hz} \\ & \mathrm{~V}_{\mathrm{FX}}=0 \mathrm{dBmO}{ }^{[5]} \end{aligned}$ |

SUPPLY REJECTION AND CROSSTALK

| $\mathrm{PSRR}_{1}$ | VDD Power Supply Rejection Ratio | 50 | 60 | dB | Encoder Alone ${ }^{[6]}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{PSRR}_{2}$ | VBB Power Supply Rejection Ratio | 50 | 60 | dB | Encoder Alone ${ }^{[6]}$ |
| $\mathrm{PSRR}_{3}$ | Vcc Power Supply Rejection Ratio | 50 | 80 | dB | Encoder Alone ${ }^{[6]}$ |
| $\mathrm{PSRR}_{4}$ | VDD Power Supply Rejection Ratio | 40 | 50 | dB | Digital Loop Back ${ }^{[7]}$ |
| PSRR5 | VBB Power Supply Rejection Ratio | 40 | 45 | dB | Digital Loop Back ${ }^{[7]}$ |
| PSRR6 | Vcc Power Supply Rejection Ratio | 50 | 80 | dB | Digital Loop Back ${ }^{[7]}$ |
| CT | Cross Talk Isolation | 75 | >80 | dB | Note 8 |

## NOTES:

1. Typical Values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. $\mathrm{D}_{\mathrm{R}}$ of Device Under Test (D.U.T.) driven with repetitive digital word sequence specified in CCITT recommendation G.711. Measurement made at VFR output.
3. D.U.T. acts as both encoder and decoder ( $\mathrm{Dx}_{\mathrm{x}}=\mathrm{D}_{\mathrm{R}}$ ) in a digital loop-back configuration. Specified gain is in addition to normal ( $\left.\operatorname{Sin} \mathrm{x}\right) / \mathrm{x}$ insertion loss.
4. Any 2910 as encoder; any other 2910 as decoder; both D.U.T.'s with separate supplies and at independent temperatures. Specified gain is in addition to normal ( $\operatorname{Sin} x) / x$ insertion loss.
5. $(\operatorname{Sin} \mathrm{x}) / \mathrm{x}$ with $\mathrm{x}=$ Measurement Frequency $(f) \mathrm{x} \pi$

Sampling Frequency
6. D.U.T. Encoder; impose 200 mV p-p, 1.02 KHz on appropriate supply; measurement made at remote decoder output; encoder in idle channel conditions.
7. D.U.T. acts as encoder and decoder; impose 200 mV p-p, 1.02 KHz on appropriate supply; measurement made at co-located decoder output; encoder in idle channel conditions.
8. $V_{\text {FX }}$ of D.U.T. encoder $=1.02 \mathrm{KHz}, 0 \mathrm{dBm0}$. Co-located D.U.T. decoder under quiet channel conditions; measurement made at colocated decoder output.

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{VCC}=+5 \mathrm{~V} \pm 5 \%, \mathrm{VBB}=-5 \mathrm{~V} \pm 5 \%, G R D A=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.

## TIMING SPECIFICATION

## CLOCK SECTION

| Symbol | Parameter | Limits |  | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tcy | Clock Period | 485 |  | ns | CLKx, CLKR (2.048MHz systems), CLK C |
| $\mathrm{tr}_{\mathrm{r}}, \mathrm{tf}^{\text {f }}$ | Clock Rise and Fall Time | 5 | 30 | ns | CLKx, CLK ${ }_{\text {R }}$, CLK ${ }_{\text {c }}$ |
| tcle | Clock Pulse Width | 215 |  | ns | CLK ${ }_{\text {x }}$, CLK ${ }_{\text {R }}$, CLK ${ }_{\text {c }}$ |
| tcDC | Clock Duty Cycle (tclk $\div$ tcy ) | 45 | 55 | \% | CLKX, CLK ${ }_{\text {R }}$ |

## TRANSMIT SECTION

| tVFX | Analog Input Conversion | 20 |  | Time Slot | From Leading Edge of Transmit Time Slot ${ }^{[1]}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tozx | Data Enabled on TS Entry | 50 | 180 | ns | $0<C_{L O A D}<100 \mathrm{pF}$ |
| tDHX | Data Hold Time | 80 | 230 | ns | $0<C_{\text {LOAD }}>100 \mathrm{pF}$ |
| $\mathrm{thzX}^{\text {l }}$ | Data Float on TS Exit | 75 | 205 | ns | CLOAD $=0$ |
| tson | Time Slot $X$ to Enable | 30 | 220 | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| tsoff | Time Slot X to Disable | 70 | 185 | ns | CLOAD $=0$ |
| tss | Signal Setup Time | 0 |  | ns | Relative to Bit-7 Falling Edge |
| ts ${ }^{\text {d }}$ | Signal Hold Time | 100 |  | ns | Relative to Bit-8 Falling Edge |
| tFSD | Frame Sync Delay | 15 | 100 | ns | FSx |

## RECEIVE AND CONTROL SECTIONS

| tVFR | Analog Output Update | 6 | 6 | Time Slot | From the Leading Edge of the <br> Channel Time Slot |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {DSR }}$ | Receive Data Setup | 20 |  | ns |  |
| $t_{\text {DHR }}$ | Receive Data Hold | 50 |  | ns |  |
| $t_{\text {SIGR }}$ | SIGR Update |  | 300 | ns | From the Trailing Edge of the <br> Channel Time Slot |
| $\mathrm{t}_{\text {FSD }}$ | Frame Sync Delay | 15 | 100 | ns |  |
| $\mathrm{t}_{\text {DSC }}$ | Control Data Setup | 100 |  | ns |  |
| $\mathrm{t}_{\text {DHC }}$ | Control Data Hold | 100 |  | ns |  |

NOTE:

1. The 20 time slot minimum insures that the complete $A / D$ conversion will take place under any combination of receive interrupt or asynchronous operation of the Codec. If the transmit channel only is operated the A/D conversion can be completed in a minimum of 11 time slots. Refer to the Codec Control General Requirement section for instructions on setting a channel in an idle condition.

## TIMING WAVEFORMS ${ }^{[1]}$

TRANSMIT TIMING


RECEIVE TIMING


CONTROL TIMING


Notes: 1. All timing parameters referenced to 2.0 V , except $\mathrm{t} H 2 \mathrm{X}$ and tsoff which reference a high impedance state.

## 2911 <br> PCM CODEC - A LAW <br> 8-BIT COMPANDED A/D AND D/A CONVERTER

## - Per Channel, Single Chip Codec <br> - CCITT G711 and G732 Compatible. Even Order Bits Inversion Included <br> - Microcomputer Interface with On-Chip Time-Slot Computation <br> - 66dB Dynamic Range, with Resolution Equivalent to 11-Bit Linear Conversion Around Zero

■ $\pm 5 \%$ Power Supplies: $+12 \mathrm{~V},+5 \mathrm{~V},-5 \mathrm{~V}$

- Precision On-Chip Voltage Reference

■ Low Power Consumption: 230mW Typ. Standby Power: 110 mW Typ.

- All Digital Inputs and Outputs TTL Compatible
Fabricated with Reliable N-Channel MOS Process

The Intel® 2911 is a fully integrated PCM (Pulse Code Modulation) Codec (Coder-Decoder), fabricated with N-channel silicon gate technology. The high density of integration allows the sample and hold circuits, the digital-to-analog converter, the comparator and the successive approximation register to be integrated on the same chip, along with the logic necessary to interface a full duplex PCM link.
The primary applications are in telephone systems:

- Transmission - 30/32 Channel Systerts at 2.048 Mbps
- Switching - Digital PBX's and Central Office Switching Systems
- Concentration - Subscriber Carrier/Concentrators

The wide dynamic range of the $2911(66 \mathrm{~dB})$ and the minimal conversion time ( $80 \mu \mathrm{sec}$ minimum) make it an ideal product for other applications, like:

- Data Acquisition
- Secure Communications Systems
- Telemetry
- Signal Processing Systems

PIN CONFIGURATION
BLOCK DIAGRAM



| Pin No. | Symbol | Function | Description |
| :---: | :---: | :---: | :---: |
| 1 | CAP1x | Hold | Connections for the transmit holding capacitor. Refer to Applications Section. |
| 2 | CAP2x |  |  |
| 3 | VFx | Input | Analog input to be encoded into a PCM word. The signal on this lead is sampled at the same rate as the transmit frame synchronization pulse FSx, and the sample value is held in the external capacitor connected to the CAP1x and CAP2x leads until the encoding process is completed |
| 4 | AUTO | Output | Most significant bit of the encoded PCM word ( +5 V for negative, -5 V for positive value). Refer to the Codec Applications Section. |
| 5 | GRDA | Ground | Analog return common to the transmit and receive analog circuits. Not connected to GRDD internally. |
| 6 | VDD | Power | $+12 \mathrm{~V}, \pm 5 \%$, referenced to GRDD or GRDA, depending upon system grounding considerations. |
| 7 | $\mathrm{D}_{\mathrm{R}}$ | Input | Receive PCM highway (serial bus) interface. The Codec serially receives a PCM word (8-bits) through this lead at the proper time defined by $\mathrm{FS}_{\mathrm{R}}, \mathrm{CLK}$, $\mathrm{D}_{\mathrm{C}}$, and CLKC. |
| 8 | PDN | Output | Active high when the Codec is in the power down mode. TTL interface. Open drain output. |
| 9 | VFR | Output | Analog output. The voltage present on VFR is the decoded value of the PCM word received on lead $\mathrm{D}_{\mathrm{R}}$. This value is held constant between two conversions. |

## PIN DESCRIPTION

| Pin No. Symbol | Function | Description |  |
| :---: | :--- | :--- | :--- |
| 10 | CAP1R | Hold | $\begin{array}{l}\text { Connections for the re } \\ \text { ceive holding capacitor. } \\ \text { Refer to the Applications } \\ \text { Section. }\end{array}$ |
| 11 | CAP2R | GRDD | Ground |
| 12 | $\begin{array}{l}\text { Ground return common to } \\ \text { the DC power supplies; } \\ \text { VBB, VCc, and VDD. }\end{array}$ |  |  |
| 13 | DX | Output | $\begin{array}{l}\text { Output of the transmit side } \\ \text { onto the send PCM high- } \\ \text { way (serial bus). The 8-bit } \\ \text { PCM word is serially sent }\end{array}$ |
| out on this pin at the proper |  |  |  |
| time defined by FSx, CLKx, |  |  |  |
| DC, and CLKc. TTL three- |  |  |  |
| state output. |  |  |  |$\}$


| Pin No. Symbol | Function | Description |  |
| :---: | :--- | :--- | :--- |
| 19 | FSX | Input | Frame synchronization pulse <br> for the transmit PCM high- <br> way. Resets the on-chip <br> time-slot counter for the <br> transmit side. Maximum <br> repetition rate 12 kHz. TTL <br> interface. |
| 20 | VBB | Power | $-5 \mathrm{~V}, \pm 5 \%$, referenced to <br> GRDD or GRDA, depend- <br> upon system grounding <br> considerations. |

## FUNCTIONAL DESCRIPTION

The 2911 PCM Codec provides the analog-to-digital and the digital-to-analog conversions necessary to interface a full duplex ( 4 wires) voice telephone circuit with the PCM highways of a time division multiplexed (TDM) system. The Codec is intended to be used on line and trunk terminations.

In a typical telephone system the Codec is located between the PCM highways and the channel filters.
The Codec encodes the incoming analog signal at the frame rate ( FS ) into an 8-bit PCM word which is sent out on the Dx lead at the proper time. Similarly, on the receive link, the Codec fetches an 8-bit PCM word from the receive highway ( $D_{R}$ lead) and decodes an analog value which will remain constant on lead VFR until the next receive frame. Transmit and receive frames are independent. They can be asynchronous (transmission) or synchronous (switching) with each other.
Circuitry is provided within the Codec to internally define the transmit and receive time-slots in order to minimize the common equipment. This feature can be bypassed

| Pin No. | Symbol | Function | Deseription |
| :---: | :--- | :--- | :--- |
| 21 | DC | Input | Data input to progtamgthe <br> Codec for the chosen mode <br> of operation. TTLinterface. |
| 22 | CLKC | Input | Clock input to clock in the <br> data on the Dc lead in order <br> to define the mode of opera- <br> tion of the Codec. TTL <br> interface. |



## CODEC OPERATION

## Codec Control

The operation of the 2911 is defined by serially loading an 8 -bit word through the Dc lead (data) and the CLK $C_{C}$ lead (clock). The loading is asynchronous with the other operations of the Codec, and takes place whenever transitions occur on the CLKc lead. The Dc input is loaded in during the trailing edge of the CLK $\mathrm{C}_{\mathrm{C}}$ input.


The control word contains two fields:
Bit 1 and Bit 2 define whether the subsequent 6 bits apply to both the transmit and receive side ( 00 ), the transmit side only (01), the receive side only (10) or whether the Codec should go into the standby, power-down mode (11). In the latter case (11), the following 6 bits are irrelevant.

The last 6 bits of the control word define the time-slot assignment, from 000000 (time-slot 1 ) to 111111 (time-slot 64 ). Bit 3 is the most significant bit and bit 8 the least significant bit and last into the Codec.

| Bit 1 | Bit 2 | Mode |
| :---: | :---: | :---: |
| 0 | 0 | $\times \& R$ |
| 0 | 1 | $\times$ |
| 1 | 0 | $R$ |
| 1 | 1 | Standby |


| Bit 3 | $\ldots$ | $\ldots$ | $\ldots$ | 8 | Time Slot |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| 0 | 0 | 0 | 0 | 0 | 1 | 2 |  |
|  |  |  | $\cdot$ |  |  | $\cdot$ |  |
|  |  |  | $\cdot$ |  |  | $\cdot$ |  |
|  |  |  | $\cdot$ |  |  | $\cdot$ |  |
| 1 | 1 | 1 | 1 | 1 | 1 |  |  |

The Codec will retain the control word (or words) until a new word is loaded in or until power is lost. This feature permits dynamic allocation of time-slots for switching applications.

## Microcomputer Control Mode

In the microcomputer mode, each Codec performs its own time-slot computation independently for the transmit and receive channels by counting clock pulses (CLKX and CLKR). All Codec's tied to the same data bus receive identical framing pulses (FSX and $\mathrm{FS}_{\mathrm{R}}$ ). The framing pulses reset the on-chip time-slot counters every frame; hence the time-slot counters of all devices are synchronized. Each Codec is programmed via CLKC and Dc for the desired transmit and receive time-slots according to the description in the Codec Control Section. All Codec's tied to the same $D_{R}$ bus will, in general, have different receive time-slots, although that is not a device requirement. There may be separate busses for transmit and receive or all Codec's may transmit and receive over the same bus, in which case the transmit and receive channels must be synchronous (CLKx $\left.=C L K_{R}\right)$. There are no other restrictions on time-slot assignments; a device may have the same transmit and receive timeslot even if a single bus is used.
There are several requirements for using the $\mathrm{CLK}_{\mathrm{C}}-\mathrm{D}_{\mathrm{C}}$ interface in the microcomputer mode.

1. A complete time-slot assignment, consisting of eight negative transitions of CLKC, must be made in less than one frame period. The assignment can overlap a framing pulse so long as all 8 control bits are clocked in within a total span of $125 \mu \mathrm{sec}$ (for an 8 KHz frame rate). CLKc must be left at a TTL low level when not assigning a time-slot.
2. A dead period of two frames must always be observed between successive time-slot assignments. The two frame delay is measured from the rising edge of the first

CLKc transition of the previous time-stot assigned.
3. When the device is in the power-down state an initialization time-slot assignment is required prior to the assignment of the desired time-slots. That is, the: first assignment brings the device out of power-down but does not register the time-slot information in the lower six bits of the control word. Once the initialization time-slot assignment has been completed, the desired time-slots may be assigned according to the descriptions above. The two frame delay between the initialization and the time-slot assignment must be observed.

## Example of Microcomputer Control Mode:

The two words 01000001 and 10000010 have been loaded into the Codec. The transmit side is now programmed for time-slot 2 and the receive side for time-slot 3 . The Codec will output a PCM word on the transmit PCM highway (bus) during the time-slot 2 of the transmit frame, and will fetch a PCM word from the receive PCM highway during time-slot 3.


In this example the Codec interface to the PCM highway then functions as shown below (FSx and FSR may be asynchronous).


## Direct Control Mode

In the Direct Mode, unlike the microcomputer mode, the Codec time-slots bear a fixed phase relationship to the framing pulses (FSX, FSR). Frame pulses become timeslot strobes. Devices tied to the same Dx bus must get different FSX pulses; all devices tied to the same $D_{R}$ bus will, in general, receive different FSR pulses, although that is not a device requirement. Again the $\mathrm{Dx}_{\mathrm{x}}$ and $\mathrm{D}_{\mathrm{R}}$ busses may be the same bus in synchronous systems, and there are no restrictions on the relationship between the transmit and receive time-slots of a given Codec. The direct mode is a special case of the microcomputer mode in that the device always operates in the first time-slot and
hence transmits and receives its data in the eight clock periods which begin with the first clock (CLKx or CLK ${ }_{R}$ ) rising edge following the rising edge of the framing pulse ( $F S_{x}$ or FSR $_{\text {R }}$ ). That is, bit 1 of each time-slot is delayed one clock cycle from the leading edge of the respective framing pulse.

The essential difference between the direct mode and microcomputer mode is that in the direct mode, the control words always consist either of all 1's (for assigning power-down) or all 0's (for powering up the device and assigning the first time-slot). Hence there are fewer timing constraints on Dc and CLKc. In particular, it is possible to define a continuous clock which can be tied to CLKc and
which makes the device behave as if the Dc lead is an active low chip select. Whenever selected, the device assumes the first time-slot in both the transmit and receive directions. The characteristics of the continuous clock used for CLKC are:
a) The clock must contain at least 8 pulses per frame.
b) The transitions must occur only during the 8th bit of any transmit time-slot. CLK $C_{C}$ transitions may not occur during the first through seventh bits of any transmit time-slot. This requirement is unique to the case when
the direct mode is implemented with a gontinuous clock on CLKc. Commonly, the external timing circuitry which is used to generate the timestot strobes for the direct mode control, will contain acioch five.. which marks the 8th bit of each transmit time-slot for example, a signaling bit marker .
c) The microcomputer mode requirement that successive time-slot assignments be separated by two frames does not apply when a continuous clock with these characteristics is used for CLKc.

## General Control Requirements

All bit and frame clocks should be applied whenever the device is active. In particular, an unused channel cannot be de-activated by removal of its associated frame or bit clock while the other channel of the same device remains active. A single channel can be removed from service in the microcomputer mode by assigning an excess timeslot to that channel.
Since the time-slot counters contain 6-bits they can count to 64 time-slots. Therefore, a channel assigned an excess
time-slot (e.g. time-slot 48 in a 32 channel system) will remain idle.

A single channel cannot be deactivated in the direct control mode except by physical disconnection of the data lead ( Dx or $\mathrm{DR}_{\mathrm{R}}$ ) from the system data bus. A device (both transmit and receive channels) may be de-activated in either control mode by powering down the device. Both channels are always powered down together.

## Encoding

The VF signal to be encoded is input on the VFX lead. An internal switch samples the signal and the hold function is performed by the external capacitor connected to the CAP1 $x$ and CAP2x leads. The sampling and conversion is synchronized with the transmit time-slot (worst case
conversion time is 20 time-slots). The PCM word is then output on the Dx lead at the proper time-slot occurrance of the following frame. The A/D converter saturates at approximately $\pm 2.2$ volts rms ( $\pm 3.1$ volts peak).


## Decoding

The PCM word is fetched by the DR lead from the PCM highway at the proper time-slot occurrence. The decoded value is held on the external capacitor connected to the CAP1R and CAP2R leads.

The buffered non-return to zero output signal on the VFR lead is equal to the stored voltage on CAPR $_{R}$. The output signal on lead $V F_{R}$ has a dynamic range of $\pm 2.2$ volts rms ( $\pm 3.1$ volts peak).

## Standby Mode - Power Down

To minimize power consumption and dissipation in large systems, a standby mode is provided by loading a control word ( $\mathrm{D}_{\mathrm{c}}$ ) with a " 1 " in bits 1 and 2 locations. Most of the Codec functions thereby become disabled, with the
exception of the interface to the Dc and CLKc leads, to allow the Codec to be reactivated.
The power consumption in the standby mode is typically 110 mW .

## Power-On Clear

Whether the device is used in the direct or microcomputer mode, an internal reset (power-on clear) is generated whenever either of the two positive device power supplies
(VDD or $\mathrm{V}_{C C}$ ) are removed or applied. The codec thus assumes the power-down state upon application of the positive power supplies and must be initialized in the normal way for operation.

## Precision Voltage Reference for the D/A Converter

The voltage reference is generated on the chip and is calibrated during the manufacturing process. The technique uses the difference in sub-surface charge density between two suitably implanted MOS devices to derive a temperature stable and bias stable reference voltage.

A gain setting op amp, programmed during manufacturing, "trims" the reference voltage source to the final precision voltage reference value provided to the D/A converter. The precision voltage reference determines the initial gain and dynamic range characteristics described in the A.C. Transmission Specification Section.

## CONVERSION LAW

The conversion law is commoniy referred to as the A Law.
The Codec provides a piecewise linear approximation of the logrithmic law through 13 segments. Each segment is made of 16 steps with the exception of the first segment which has 32 steps. In adjacent segments the step sizes are in a ratio of two to one. Within each segment, the step size is constant.

The output levels are midway between the corresponding decision levels. The output levels $Y_{n}$ are related to the input levels $X_{n}$ by the expression:

$$
Y_{n}=\frac{X_{n-1}+X_{n}}{2} \quad 0<n \leq 128
$$

CODER TRANSFER CHARACTERISTIC
(A/D CONVERSION)


CODEC TRANSFER CHARACTERISTIC


DECODER TRANSFER CHARACTERISTIC
(D/A CONVERSION)


## THEORETICAL A LAW - POSITIVE INPUT VALUES

(For Negative Input Values, Invert Bit 1)


NOTES:
(1) 4096 normalized value units correspond to the value of the on-chip voltage reference.
(2) The PCM word corresponding to positive input values between two successive decision values numbered $n$ and $n+1$ (see column 4) is $(128+n)$ expressed as a binary number.
(3) $X_{128}$ is a virtual decision value.
(4) The PCM word on the highways is the same as the one shown in column 6, with the even order bits inverted. The 2911 provides for the inversion of the even order bits on both the send and receive sections. The sign bit is inverted on the encoder side only.
(5) The voltage output on the $V F_{R}$ lead is equal to the normalized value given in the table, augmented by an offset. The offset value is approximately 15 mV .

## APPLICATIONS

## Circuit Interface



## Holding Capacitors

For an 8 KHz sampling system the transmit holding capacitor CAPx should be $2000 \mathrm{pF}, 20 \%$. The receive holding capacitor CAPR should be $470 \mathrm{pF}, 20 \%$ for 32 timeslots and 8 KHz sample rate or $560 \mathrm{pF}, 20 \%$ for 24 time-slots and 8 KHz sample rate. An additional capacitor $\mathrm{C}_{2}$ of 100 pF , is required from the CAP2R lead to GRDA.

## Auto Zero

The auto zero output (most significant bit or sign bitofthe A/D conversion) integrated over a long time constant will compensate for the DC offset inside the Codec ivoltage difference between the bottom of the DAC and GRDA : The above drawing shows a possible connection between the VFX and Auto leads. The recommended values of the auto zero components are:
$\mathrm{C}_{1}$ of $1 \mu \mathrm{~F}, \mathrm{R}_{1}$ of $47 \mathrm{k} \Omega, \mathrm{R}_{2}$ of $330 \Omega$, and $\mathrm{R}_{3}$ of $470 \mathrm{k} \Omega$.

## Filters Interface

The filters may be interfaced as shown in the circuit interface diagram. Note that the output pulse stream is of the non-return to zero type.

## $D_{x}$ Buffering

For optimum idle channel noise performance it is recommended that the Dx output of each Codec be buffered from the system PCM bus with an external threestate or open collector buffer. Each buffer can be enabled with the appropriate Codec generated $\overline{\mathrm{TSx}}$ signal.

## Grounding and Decoupling Recommendations



## Grounding

Analog grounding is connected to the GRDA lead. The GRDA and GRDD leads are not connected inside the 2911. An external connection is thus necessary outside the Codec to tie all the analog ground lines to the common return of the system GRDD.

To minimize the injection of digital logic noise into the analog signal path the GRDA and GRDD external connection should be made as close as practical to the system supply ground.

## Decoupling

A $0.1 \mu \mathrm{~F}$ bypassing capacitor from each power supply to digital ground is generally recommended at each device. This decoupling may be reduced based on actual board design and performance.
Sufficient board level decoupling must be provided to guarantee that power supply transients (including turn on and off) do not exceed the absolute maximum ratings of the device. A minimum of $1 \mu \mathrm{~F}$ is recommended once per board for each power supply. A pair of small switching diodes (in opposite directions) between analog and digital ground on a once-per-board basis is recommended to maintain the two ground levels near the same value during board insertion and removal.

## ABSOLUTE MAXIMUM RATINGS*

| Under Bias | $-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages with Respect to VBB | -0.3 to +20V |
| $V_{C C}$, VDD and VSs with |  |
| Respect to VBB | -0.3 to +20 V |
| Power Dissipation | 1.35 W |

*COMMENT: Stresses above those listed under "Absolute Maxir mum 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}_{D D}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{C C}=5 \mathrm{~V} \pm 5 \%$,
$V_{B B}=-5 \mathrm{~V} \pm 5 \%, G R D A=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.
DIGITAL INTERFACE

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{11]}$ | Max. |  |  |
| IIL | Low Level Input Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {IL }}$ |
| $\mathrm{IIH}^{\text {I }}$ | High Level Input Current |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}>V_{\text {IH }}$ |
| VIL | Input Low Voltage |  |  | +0.6 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | +2.2 |  |  | V |  |
| VOL | Output Low Voltage |  |  | 0.4 | V | Dx, IOL $=3.2 \mathrm{~mA}$ |
|  |  |  |  |  |  |  |
|  |  |  |  |  |  | $\overline{\text { TSx }}$, IOL $=1.6 \mathrm{~mA}$, open drain |
|  |  |  |  |  |  | PDN, IOL $=0.5 \mathrm{~mA}$, open drain |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{Dx}, 1 \mathrm{OH}=30 \mathrm{~mA}$ |

## ANALOG INTERFACE

| AIZ | Input Impedance when Sampling, VFx | 125 | 300 | 500 | $\Omega$ | In Series with CAPx to GRDA, $-3.1 \mathrm{~V}<\mathrm{V}_{\text {IN }}<3.1 \mathrm{~V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Aoz | Output Impedance, VFR | 100 | 180 | 300 | $\Omega$ | -3.1 V < V OUT < 3.1V |
| VOL | Output Low Voltage, Auto |  | $\mathrm{V}_{\mathrm{BB}}$ |  | V | $400 \mathrm{k} \Omega$ to GRDA |
| VOH | Output High Voltage, Auto |  | VCC |  | V |  |
| $\mathrm{R}_{1}$ | Auto Zero Component | 42 | 47 | 52 | $\mathrm{k} \Omega$ | $47 \mathrm{k} \Omega$ Recommended ${ }^{2}$ \| |
| $\mathrm{R}_{2}$ | Auto Zero Component | 290 | 330 | 616 | $\Omega$ | $330 \Omega$ Recommended ${ }^{2 \mid}$ |
| $\mathrm{R}_{3}$ | Auto Zero Component | 420 | 470 | 520 | $\mathrm{k} \Omega$ | $470 \mathrm{k} \Omega$ Recommended ${ }^{(2)}$ |
| $\mathrm{C}_{1}$ | Auto Zero Component | 1.0 |  |  | $\mu \mathrm{F}$ |  |
| CAPX | Holding Capacitor, Transmit | 1600 | 2000 | 2400 | pF | 8kHz Sampling, 2000pF Recommended ${ }^{\|2\|}$ |
| CAPR | Holding Capacitor, Receive | 390 | 470 | 560 | pF | 8 kHz Sampling, 32 TimeSlots, 470pF Recommended ${ }^{12}$ |
|  |  | 450 | 560 | 670 | pF | 8 kHz Sampling, 24 TimeSlots, 560pF Recommended ${ }^{12}$ |
| $\mathrm{C}_{2}$ | Bypass Capacitor | 80 | 100 | 120 | pF | 100pF Recommended ${ }^{\text {\|2\| }}$ |

## POWER DISSIPATION

| IDDO | Standby Current | 6 | 9 | mA | $\begin{aligned} & V_{D D}=12.6 \mathrm{~V} \\ & V_{C C}=5.25 \mathrm{~V} \\ & V_{B B}=-4.75 \mathrm{~V} \end{aligned}$ <br> Clock Frequency 2.048 MHz |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Icco | Standby Current | 5 | 8 | mA |  |
| Ibbo | Standby Current | 2 | 4 | mA |  |
| IDDI | Operating Current | 11 | 16 | mA |  |
| ICCI | Operating Current | 13 | 21 | mA |  |
| IbBI | Operating Current | 4 | 6 | mA |  |

NOTES: 1. Typical Values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. See Applications Circuit Interface for component connections.

## A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{VDD}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=+5 \mathrm{~V} \pm 5 \% \%$ GRDA $=0 V, G R D D=0 V$, unless otherwise specified.

TRANSMISSION, GAIN AND DYNAMIC RANGE

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ.[1] | Max. |  |  |
| S/D | Signal to Total Distortion Ratio. See Figure 2. CCITT G. 712 Method 2 (Sinusoidal method). | 35 |  |  | dB | Signal Level OdBm0 to $-30 \mathrm{dBm0}$ |
|  |  | 29 |  |  | dB | Signal Level -40dBm0 |
|  |  | 24 |  |  | dB | Signal Level -45dBm0 |
| $\Delta \mathrm{G}$ | Gain Tracking Deviation from Gain at OdBm0. See Figure 1. CCITT G. 712 Method 2 (Sinusoidal method). |  |  | $\pm 0.3$ | dB | Signal Level $+3 \mathrm{dBm0}$ to -40dBm0 |
|  |  |  |  | $\pm 0.7$ | dB | $\begin{aligned} & \text { Signal Level -40dBm0 to } \\ & -50 \mathrm{dBm0} \\ & \hline \end{aligned}$ |
|  |  |  |  | $\pm 2.1$ | dB | Signal Level -50dBm0 to -55dBm0 |
| NiC | Idle Channel Noise |  |  | -73 | dBmOp | With Auto Zero ${ }^{[2]}$ |
| AOR | Output Dynamic Range, VFR | 2.14 | 2.16 | 2.18 | $V_{\text {RMS }}$ | $23^{\circ} \mathrm{C}$, Nominal Supplies |
| Aort | AOR Variation with Temperature |  |  | -. 22 | $\mathrm{mV} \mathrm{RMS} /{ }^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}$ |
| Aors | AOR Variation with Supplies |  |  | $\pm 18$ | $\mathrm{mV} \mathrm{V}_{\text {MS }}$ | Supplies $\pm 5 \%$ |
| GSL | Self Loop Gain | -. 24 | -. 20 | -. 16 | dB | $\mathrm{V}_{\mathrm{FX}}=-\mathrm{dBm0} 0,1.02 \mathrm{KHz}{ }^{[3]}$ |
| Gee | End-to-End Codec Gain | -. 4 | -. 3 | -. 2 | dB | $23^{\circ} \mathrm{C}$, Nominal Supplies ${ }^{[4]}$ |
| Geet | Gee Variation with Temperature |  | . 0010 | . 0018 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}[4]$ |
| Gees | Gee Variation with Supplies |  | $\pm .07$ | $\pm .13$ | dB | Supplies $\pm 5 \%[4]$ |
| GFR | Decoder Frequency Response Departure from Ideal (Sinx)/x, VFR |  |  | $\pm .05$ | dB | $\begin{aligned} & 300 \mathrm{~Hz}<f<3800 \mathrm{~Hz} \\ & \mathrm{~V}_{\mathrm{FX}}=0 \mathrm{dBmo} \end{aligned}$ |
| CT | Cross Talk Isolation | 75 | >80 |  | dB | [6] |

## NOTES:

1. Typical Values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. If all Auto-Zero components are removed and VFX is direct coupled, the encoder tends to bias itself away from a decision level (hysteresis). The idle channel noise is then typically -85 dBmOp , but will be dependent on the D.C. offset of the PCM transmit filter output provided to VFx .
3. D.U.T. acts as both encoder and decoder ( $\mathrm{D} X=\mathrm{D}_{\mathrm{R}}$ ) in a digital loop-back configuration. Specified gain is in addition to normal ( $\operatorname{Sin} \mathrm{x} / / \mathrm{x}$ insertion loss.
4. Any 2911 as encoder; any other 2911 as decoder; both D.U.T.'s with separate supplies and at independent temperatures. Specified gain is in addition to normal $(\operatorname{Sin} x) / x$ insertion loss.
5. $(\operatorname{Sin} \mathrm{x}) / \mathrm{x}$ with $\mathrm{x}=$ Measurement Frequency $(f) \mathrm{x} \pi$

Sampling Frequency
6. $V_{F X}$ of D.U.T. encoder $=1.02 \mathrm{KHz}, 0 \mathrm{dBmO}$. Co-located D.U.T. decoder under quiet channel conditions; measurement made at colocated decoder output.


Figure 1. Gain Variation ( $\Delta \mathbf{G}$ ) vs. Signal Level Reference Level 0dBm0


Figure 2. -Signal/Total Distortion Ratio
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{C C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 5 \%$, GRDA $=0 V, G R D D=O V$, unless otherwise specified.
TIMING SPECIFICATIONS AND WAVEFORMS ${ }^{[1]}$
CLOCK AND TRANSMIT SECTION

| Symbol | Parameter | Limits |  | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tcy | Clock Period | 485 |  | ns | CLKX, CLKR ( 2.048 MHz systems) CLKc |
| $\mathrm{tr}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | Clock Rise and Fall Time | 5 | 30 | ns | CLK ${ }_{\text {, }}$ CLKKR, CLK ${ }_{\text {c }}$ |
| tCLK | Clock Pulse Width | 215 |  | ns | CLK ${ }_{\text {x }}$, CLK ${ }_{\text {R }}$, CLK ${ }_{\text {c }}$ |
| tcDC | Clock Duty Cycle (tclk $\div$ tcy) | 45 | 55 | \% | CLK ${ }_{\text {x, CLK }}$ |
| tvFx | Analog Input Conversion | 20 |  | Time Slot | From Leading Edge of Transmit Time Slot ${ }^{[2]}$ |
| tozx | Data Enabled on TS Entry | 50 | 180 | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| tDHX | Data Hold Time | 80 | 230 | ns | $0<C_{\text {LOAD }}>100 \mathrm{pF}$ |
| thzx | Data Float on TS Exit | 75 | 205 | ns | $C_{\text {LOAD }}=0$ |
| tson | Time Slot $X$ to Enable | 30 | 220 | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| tsoff | Time Slot X to Disable | 70 | 185 | ns | CLOAD $=0$ |
| tss | Signal Setup Time | 0 |  | ns | Relative to Bit-7 Falling Edge |
| tSH | Signal Hold Time | 100 |  | ns | Relative to Bit-8 Falling Edge |
| tFSD | Frame Sync Delay | 15 | 100 | ns | FSx |




## Notes:

1. All timing parameters referenced to 2.0 V , except $t_{H Z X}$ and tsoff which reference a high impedance state
2. The 20 time slot minimum insures that the complete $A / D$ conversion will take place under any combination of receive interrupt or asynchronous operation of the Codec. If the transmit channel only is operated the A/D conversion can be completed in a minimum of 11 time slots. Refer to the Codec Control General Requirement section for instructions on setting a channel in an idle condition.
A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{C C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V}, 5 \%$ GRDA $=0 V$, GRDD $=0 V$, unless otherwise specified.

## TIMING SPECIFICATIONS AND WAVEFORMS ${ }^{[1]}$

## RECEIVE AND CONTROL SECTIONS

| tVFR | Analog Output Update |  | 8 | Time Slot | From the Leading Edge of the <br> Channel Time Slot |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {DSR }}$ | Receive Data Setup | 40 |  | ns |  |
| $t_{\text {DHR }}$ | Receive Data Hold | 30 |  | ns |  |
| $\mathrm{t}_{\text {SIGR }}$ | SIGR Update |  | 300 | ns | From the Trailing Edge of the <br> Channel Time Slot |
| $\mathrm{t}_{\text {FSD }}$ | Frame Sync Delay | 15 | 100 | ns |  |
| $t_{\text {DSC }}$ | Control Data Setup | 100 |  | ns |  |
| $t_{\text {DHC }}$ | Control Data Hold | 100 |  | ns |  |



Notes:

1. All timing parameters referenced to 2.0 V , except $t_{H Z X}$ and $\operatorname{tSOFF}$ which reference a high impedance state.

## 2912 <br> PCM LINE FILTERS

■ Monolithic Device Includes Both Transmit and Receive Filters

- CCITT G712 Compatible AT\&T® D3/D4 Compatible
- $50 \mathrm{~Hz} / 60 \mathrm{~Hz}$ Rejection Included in the Transmit Filter
- Gain Adjustment in Both Directions
- Direct Interface with Transformer or Electronic Telephone Hybrids
- Direct Interface to the Intel ${ }^{\circledR}$ 2910/2911 PCM Codecs Including Stand-By, Power Down Mode
$\pm 5 \%$ Power Supplies: +5V, -5V
- Low Power Consumption: 210mW Typical without Power Amplifiers 280mW Typical with Power Amplifiers 55 mW Typical on Stand-By Fabricated with Reliable N-Channel MOS Process

The Intel® 2912 is a fully integrated monolithic device containing the two filters of a PCM line or trunk termination. The device is designed to meet the following objectives:

- To meet the digital Class 5 central office switching systems stringent specification
- To minimize power dissipation
- To maximize reliability
- To provide a low cost alternative to hybrid filters

The 2912 is directly compatible with the Intel® 2910 ( $\mu$ Law) and the Intel@ 2911 (A Law) PCM Codecs. The primary application for the 2912 is in telephone systems, for transmission, switching or remote concentration.

PIN CONFIGURATION


PIN NAMES

| VFXI', $\mathrm{VFXI}^{-}$ | ANALOG INPUTS | CLK | CLOCK INPUT |
| :---: | :---: | :---: | :---: |
| GS ${ }_{\mathbf{X}}$ | GAIN CONTROL | CLKO | CLOCK SELECTION |
| VFxO | ANALOG OUTPUT | PWDN | POWER DOWN |
| $V F_{R}$ I | ANALOG INPUT | $V_{C C}$ | POWER ( +5 V ) |
| $V F_{R} O$ | ANALOG OUTPUT | $\mathrm{V}_{\mathrm{BB}}$ | POWER (-5V) |
| PWRI | DRIVER INPUT | GRDD | DIGITAL GROUND |
| $\mathrm{PWRO}^{+}, \mathrm{PWRO}^{-}$ | DRIVER OUTPUT | GRDA | ANALOG GROUND |

BLOCK DIAGRAM


## PIN DESCRIPTION

| Pin <br> No. | Symbol | Function | Description |
| :---: | :---: | :---: | :---: |
| 1 | VFXI ${ }^{+}$ | Input | Analog input of the transmit filter. The VFXI ${ }^{+}$signal comes from the 2 to 4 wire hybrid in the case of a 2 wire line and goes through the $50 / 60 \mathrm{~Hz}$ notch and the antialiasing filter before being sent to the Codec for encoding. |
| 2 | VFxI ${ }^{-}$ | Input | Inverting input of the gain adjustment operational amplifier on the transmit filter. |
| 3 | GSx | Output | Output of the gain adjustment operational amplifier on the transmit filter. Used for gain setting of the transmit filter. |
| 4 | VFro | Output | Analog output of the receive filter. This output provides a direct interface to electronic hybrids. For a transformer hybrid application, $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ is tied to PRWI and a dual balanced output is provided on pins $\mathrm{PWRO}^{+}$and PWRO ${ }^{-}$. |
| 5 | PWRI | Input | Input to the power driver amplifiers on the receive side for interface to transformer hybrids. High impedance input. When tied to $V_{B B}$, the power amplifiers are powered down. |
| 6 | $\mathrm{PWRO}^{+}$ | Output | Non-inverting side of the power amplifiers. Power driver output capable of directly driving transformer hybrids. |
| 7 | PWRO- | Output | Inverting side of the power amplifiers. Power driver output capable of directly driving transformer hybrids. |
| 8 | VBb | Power | $-5 \mathrm{~V} \pm 5 \%$ referenced to GRDA |
| 9 | Vcc | Power | $+5 \mathrm{~V} \pm 5 \%$ referenced to GRDA |

Pin
No. Symbol Function Description
$10 \mathrm{VFRI}_{\mathrm{R}}$ Input Analog input of the receive filter, interface to the Codec analog output for PCM applications. The receive filter provides the $\frac{\operatorname{Sin} x}{x}$ correction needed for sample and hold type Codec outputs to give unity gain. The input voltage range is directly compatible with the Intel ${ }^{\circledR} 2910$ and 2911 Codecs.

11 GRDD Ground Digital ground return for internal clock generator.
12 CLK ${ }^{[1]}$ Input Clock input. Three clock frequencies can be used: $1.536 \mathrm{MHz}, 1.544 \mathrm{MHz}$ or 2.048 MHz ; pin 14, CLK0, has to be strapped accordingly. High impedance input, TTL voltage levels.
13 PDWN Input Control input for the stand-by power down mode. An internal pull up to +5 V is provided for interface to the Intel ${ }^{\circledR} 2910$ and 2911 PDWN outputs. TTL voltage levels.
14 CLKO ${ }^{[1]}$ Input Clock (pin 12, CLK) frequency selection. If tied to $\mathrm{V}_{\mathrm{BB}}$, CLK should be 1.536 MHz . If tied to Ground, CLK should be 1.544 MHz . If tied to $\mathrm{VCC}, \mathrm{CLK}$ should be 2.048 MHz .
15 GRDA Ground Analog return common to the transmit and receive analog circuits. Not connected to GRDD internally.
Analog output of the transmit filter. The output voltage range is directly compatible with the Intel ${ }^{(8)} 2910$ and 2911 Codecs.

NOTE:

1. The three clock frequencies are directly compatible with the Intel® 2910 and 2911 Codecs. The following table should be observed in selecting the clock frequency.

| Codec Clock | Clock Bits/Frame | 2912 CLK, Pin 12 | 2912 CLK0, Pin $\mathbf{1 4}$ |
| :---: | :---: | :---: | :---: |
| 1.536 MHz | 192 | 1.536 MHz | $\mathrm{V}_{\mathrm{BB}}(-5 \mathrm{~V})$ |
| 1.544 MHz | 193 | 1.544 MHz | GRDD |
| 2.048 MHz | 256 | 2.048 MHz | $\mathrm{V}_{\mathrm{CC}}(+5 \mathrm{~V})$ |

## FUNCTIONAL DESCRIPTION

The 2912 provides the transmit and receive filters found on the termination of a PCM line or trunk. The transmit filter performs the anti-aliasing function needed for an 8 KHz sampling system, and the $50 / 60 \mathrm{~Hz}$ rejection. The receive filter has a low pass transfer characteristic and also provides the $\operatorname{Sin} x / x$ correction necessary to interface the Intel 2910 ( $\mu$ Law) and 2911 (A Law) Codecs which have a non-return-to-zero output of the digital to analog conversion. Gain adjustment is provided in the receive and transmit directions.

A stand-by, power down mode is included in the 2912 and. can be directly controlled by the 2910/291t Codecs:
The 2912 can interface directly with a transformer hybrid (2 to 4 wire conversion) or with electronic hybrids; in the latter case the power dissipation is significantly reduced by powering down the output amplifier provided on the 2912.


## FILTER OPERATION

## Transmit Filter Input Stage

The input stage provides gain adjustment in the passband. The input operational amplifier has a common mode range of $\pm 2.2$ volts, a DC offset of less than 25 mV , a voltage gain greater than 2000 and a unity gain bandwidth of 2 MHz . It can be connected to provide a gain of 20 dB without degrading the noise performance of the filter. The
load impedance connected to the amplifier output must be greater than $10 \mathrm{~K} \Omega$ in parallel with 20 pF . The input signal on lead $\mathrm{VFxI}^{+}$can be either AC or DC coupled. The input Op Amp can also be used in the inverting mode or differential amplifier mode. The remaining portion of the transmit filter provides a gain of +3 dB in the pass band.


TRANSMIT FILTER GAIN ADJUSTMENT

## Transmit Filter Transfer Characteristics

The transmit section of the filter provides a passband flatness and stopband attenuation which exceeds the ATT® D3 and D4 specification and is compatible with the CCITT G712 recommendation. The 2912 specification meets the digital class 5 central office switching systems requirements. The transmit filter transfer characteristics and specifications are shown in the diagram below.

## 50Hz/60Hz Notch - Transmit Filter

The transmit filter has a notch section to reject $50 H z$ and 60 Hz components of the input signal: $A$ minimum attenuation of 26 dB is provided at 60 Hz . At 50 Hz , the minimum attenuation is 20 dB . The gain at 200 Hz is between -.125 dB and -1.8 dB . (All gain figures are relative to the gain at 1 kHz ).


TRANSMIT FILTER TRANSFER CHARACTERISTICS

## Transmit Filter Output Stage

The voltage range of the output signal on the $\mathrm{VF} \times \mathrm{O}$ lead is $\pm 3.2$ volts. The DC offset is less than 200 mV . It is recommended that the VFxO output be capacitively coupled to the VFx input of the Intel ${ }^{\circledR} 2910$ and 2911 Codecs.

## Receive Filter Transfer Characteristics

The receive section of the filter provides a passband flatness and stopband rejection which exceeds the ATT® D3/D4 specification and is compatible with the CCITT G712 recommendation when used with a decoder which contains a sample/hold amplifier at its output. The filter contains the required compensation for the $\frac{\operatorname{Sin} x}{x}$ response
of such decoders. The receive filter transfer characteristics and specifications, including the $\frac{\operatorname{Sin} x}{x}$ responsewf the decoder, as shown in the diagram below.


[^3] RESPONSE MEETS THE STATED SPECIFICATIONS.

## Receive Filter Output

The $\mathrm{VFRO}_{\mathrm{R}}$ lead is capable of driving high impedance electronic hybrids. The gain of the receive section from $V F_{R} I$ to $V F_{R O}$ is:

$$
\frac{\pi\left(\frac{f}{8000}\right)}{\sin \pi\left(\frac{f}{8000}\right)}
$$

which when multiplied by the output response of the Intel 2910 and 2911 Codecs results in a OdB gain in the pass band. The filter gain can be adjusted downward by a resistor voltage divider connected as shown. The total resistive load $\mathrm{RT}_{\mathrm{T}}$ on $V \mathrm{FRO}_{\mathrm{R}}$ should not be less than $10 \mathrm{k} \Omega$.


RECEIVE FILTER OUTPUT GAIN ADJUSTMENT

## Receive Filter Output Driver Amplifier Stage

A balanced power amplifier is provided in order to drive low-impedance loads in a bridged configuration. The receive filter output $V F_{R} O$ is connected through gain setting resistors $R_{1}$ and $R_{2}$ to the amplifier input PWRI. The input voltage range on PWRI is $\pm 3.2$ volts and the gain is 6 dB for a bridged output. With a $20 \mathrm{k} \Omega$ load connected between $\mathrm{PWRO}^{+}$and $\mathrm{PWRO}^{-}$, the maximum voltage swing across the load is $\pm 6.4$ volts. With a $600 \Omega$ load connected between $\mathrm{PWRO}^{+}$and $\mathrm{PWRO}^{-}$, the maximum voltage swing across the load is $\pm 5.0$ volts. The series combination of $R_{s}$ and the hybrid transformer must present a minimum A.C. load resistance of $600 \Omega$ to the amplifier in the bridged configuration. A typical connection of the output driver amplifiers is shown below. These amplifiers can also be used with loads connected to ground.
The power amplifier should be deactivated when not utilized to save power. This is accomplished by tying the PWRI pin to $V_{B B}$.


## TYPICAL CONNECTION OF OUTPUT DRIVER AMPLIFIER

## Power Down Mode

Pin 13, PDWN, provides the power down control. When the signal on this lead is brought high, the 2912 goes into a standby, power down mode. Power dissipation is reduced to 55 mW . In the stand-by mode, all outputs go into a high impedance state. This features allows multiple 2912's to drive the same analog bus on a time-shared basis.

When power is restored, the settling time of the 2912 is typically 15 ms .
The PDWN interface is directly compatible with the Intel 2910 and 2911 PDWN outputs. Only one command from the common control is then necessary to power down both the Codec and the Filters of the line or trunk interface.

APPLICATIONS
Circuit Interface
(Example 1)
2910


TYPICAL LINE INTERFACE USING A 2910 CODEC AND 2912 FILTER AND TRANSFORMER-RESISTOR HYBRID.

## Codec Interface

The 2912 PCM Filter is designed to directly interface to the 2910 and 2911 Codecs as shown above. The transmit path is completed by connecting the VFxO output of the 2912 to the coupling capacitor of the auto zero circuit associated with the 2910 and 2911 codecs. The receive path is completed by directly connecting the codec output VFR to the receive input of the $2912 \mathrm{VF}_{\mathrm{R}} \mathrm{I}$. The PWDN input of the 2912 should be connected to the PWDN output of the codec to allow the filter to be put in the power-down standby mode under control of the codec.

## Clock Interface

To assure proper operation, the CLK input of the 2912 should be connected to the same clock provided to the receive bit clock, CLK R of 2910 or 2911 Codec as shown above. The CLKO input of the 2912 should be set to the proper voltage depending on the standard clock frequency chosen for the codec and filter. See the clock selection table in the Pin Description section.

## Transformer Interface (Example 1)

The diagram above shows a typical interface of the 2912 Filter to a transformer. This connection can provide +8 dBm into a $600 \Omega$ line. The functions of the resistors in example 1 are as follows:
$R_{1}, R_{2}$ are gain setting resistors for the transmit filter input stage. Transmit gain equals $-R_{2} / R_{1}$. The transmit filter provides an additional 3.0 dB of gain.
$R_{3}, R_{4}$ are attenuation setting resistors for the receive filter. Receive gain equals $R_{3} /\left(R_{3}+R_{4}\right)$.
$R_{5}$ is a resistor which injects the balance network signal into the transmit path to perform the $2 / 4$ wire conversion.
$R_{L}$ is a $600 \Omega$ load resistor through which the balanced driver amplifier stage drives the transformer winding.

## Grounding and Decoupling <br> Recommendations

Analog grounding is connected to the GRDA leads. The GRDA and GRDD leads are not connected inside the 2912. An external connection is thus necessary outside the Filter to tie all the analog ground lines to the common return of the system GRDD. To minimize the injection of digital logic noise into the analog signal path the GRDA and GRDD external connection should be made as close as practical to the system supply ground.
The GRDA of the 2912 Filter should be tied to the GRDA of the 2910 or 2911 Codec as shown above. Likewise, the GRDD pins of the Codec and Filter should be connected. Analog gain setting or 2/4 wire circuits associated with the filter should have a ground path to GRDA.
A $0.05 \mu \mathrm{~F}$ bypassing capacitor from each power supply to analog ground GRDA is generally recommended at each 2912 device. This decoupling may be reduced based on actual board design and performance. Sufficient board level decoupling must be provided to guarantee that power supply transients (including turn on and turn off) do not exceed absolute maximum ratings of the device. A minimum of $1 \mu \mathrm{~F}$ is recommended once per board for each power supply.

## Transformer Interface (Example 2)

The diagram shows an alternative interface of the 2912 Filter to a transformer. This connection can provide +5.75 dBm into a $600 \Omega$ line. The functions of the resistors in example 2 are as follows:
$R_{1}=R_{2}$. The matching maintains hybrid balance.
$R_{3}=R_{4}$. The gain setting for the transmit filter input stage is performed by $R_{2}$ and $R_{4}$. Transmit gain equals $-R_{4} / R_{2}$. The transmit filter provides an additional 3.0dB of gain.
$R_{5}=R_{7}=2 R_{6}$. Each power amplifier drives a load equal to R5.
$\mathrm{R}_{8}, \mathrm{R}_{9}$ are attenuation setting resistors for the receive filter. Receive gain equals $R_{9} /\left(R_{8}+R_{9}\right)$.


## ABSOLUTE MAXIMUM RATINGS*

| , | $-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Supply Voltage with Res | -0.3 V to +14.0 V |
| All Input and Output Vol |  |
| Respect to $\mathrm{V}_{\text {BB }}$ | -0.3V to +14.0 V |
| All Output Currents | $\pm 50 \mathrm{~mA}$ |
| 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} C \mathrm{C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, G R D A=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.

## DIGITAL INTERFACE

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{1 \mid}$ | Max. |  |  |
| ILIC | Input Load Current (except PDWN) |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {IL }}$ MIN to $V_{\text {IH }}$ max |
| ILIO | Input Load Current, CLK0 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {BB }}$ to $\mathrm{V}_{\text {IH }} \mathrm{mAX}$ |
| ILIP | Input Load Current, PDWN |  |  | -100 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {IL }}$ MIN to $\mathrm{V}_{\text {IH }}$ MAX |
| $V_{\text {IL }}$ | Input Low Voltage (except CLKO) |  |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (except CLK0) | 2.2 |  |  | V |  |
| VILO | Input Low Voltage, CLKO | VBB |  | $\mathrm{V}_{\mathrm{BB}}+0.5$ | V |  |
| $\mathrm{V}_{110}$ | Input Intermediate Voltage, CLK0 | GRDD-0.5 |  | 0.8 | V |  |
| VIHO | Input High Voltage, CLK0 | $\mathrm{V}_{\text {cc }}{ }^{-0.5}$ |  | Vcc | V |  |

## POWER DISSIPATION

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| Icco | Vcc Standby Current |  | 6 | 9 | mA | PDWN $=\mathrm{V}_{\text {IH MIN }}$ |
| IBBO | VBB Standby Current |  | 5 | 8 | mA | PDWN $=\mathrm{V}_{\text {IH MIN }}$ |
| ICC1 | VCC Operating Current, Power Amplifiers Inactive |  | 21 | 33 | mA | PWRI $=\mathrm{V}_{\mathrm{BB}}$ |
| IBB1 | VBB Operating Current, Power Amplifiers Inactive |  | 21 | 33 | mA | PWRI $=\mathrm{V}_{\mathrm{BB}}$ |
| ICC2 | Vcc Operating Current |  | 28 | 44 | mA |  |
| IBB2 | VBB operating Current |  | 28 | 44 | mA |  |

NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply values.

## 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{BB}}=-5 \mathrm{~V} \pm 5 \%$, GRDA $=0 \mathrm{~V}$, GRDD $=0 \mathrm{~V}$, unless otherwise specified.

## ANALOG INTERFACE, TRANSMIT FILTER INPUT STAGE

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IBXI | Input Leakage Current, $\mathrm{VFxI}^{+}, \mathrm{VFxI}^{-}$ |  |  | 100 | nA | $-2.2 \mathrm{~V}<\mathrm{V}_{\text {IN }}<2.2 \mathrm{~V}$ |
| RIXI | Input Resistance, $\mathrm{VFXI}^{+}$, $\mathrm{VFxI}^{-}$ | 10 |  |  | $\mathrm{M} \Omega$ |  |
| Vosxı | Input Offset Voltage, $\mathrm{VFxI}^{+}, \mathrm{VFxI}^{-}$ |  |  | 25 | mV | $-2.2 \mathrm{~V}<\mathrm{V}_{\text {IN }}<2.2 \mathrm{~V}$ |
| PSRR1 | Power Supply Rejection, GSx | 45 |  |  | dB |  |
| CMRR | Common Mode Rejection, $\mathrm{VFxI}^{+}, \mathrm{VFxI}{ }^{-}$ | 45 |  |  | dB | $-2.2 \mathrm{~V}<\mathrm{V}_{\text {IN }}<2.2 \mathrm{~V}$ |
| Avol | DC Open Loop Voltage Gain, GSx | 2000 |  |  |  |  |
| fc | Open Loop Unity Gain Bandwidth, GSx |  | 2 |  | MHz |  |
| Voxi | Output Voltage Swing, GSx |  |  | $\pm 2.5$ | V | $R_{L} \geq 10 \mathrm{k} \Omega$ |
| CLXI | Load Capacitance, GSx |  |  | 20 | pF |  |
| RLXI | Minimum Load Resistance, GSx | 10 |  |  | $\mathrm{k} \Omega$ | Minimum $\mathrm{R}_{\mathrm{L}}$ |

## ANALOG INTERFACE, TRANSMIT FILTER

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Rox | Output Resistance, VFxO |  |  | 400 | $\Omega$ |  |
| Vosx | Output DC Offset, VFxO |  |  | 200 | mV | VFxl ${ }^{+}$Connected to GRDA, Input Op Amp at Unity Gain |
| PSRR2 | Power Supply Rejection of Vcc at 1 kHz , VFxO | 30 | 35 |  | dB |  |
| PSRR3 | Power Supply Rejection of $V_{B B}$ at 1 kHz , VFxO | 25 | 30 |  | dB |  |
| CLX | Load Capacitance, VFxO |  |  | 20 | pF |  |
| RLX | Minimum Load Resistance, VFxO | 10 |  |  | $\mathrm{k} \Omega$ | Minimum $\mathrm{R}_{\mathrm{L}}$ |
| Vox | Output Voltage Swing, 1kHz, VFxO |  |  | $\pm 3.2$ | V | $\mathrm{R}_{\mathrm{L}} \geq 10 \mathrm{k} \Omega$ or with 2910 or 2911 |

ANALOG INTERFACE, RECEIVE FILTER

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IBR | Input Leakage Current, VFRI |  |  | 1 | $\mu \mathrm{A}$ | $-3.2 \mathrm{~V}<\mathrm{V}_{\text {IN }}<3.2 \mathrm{~V}$ |
| RIR | Input Resistance, VFRI | 1 |  |  | $\mathrm{M} \Omega$ |  |
| Ror | Output Resistance, VFrO |  |  | 100 | $\Omega$ |  |
| VosR | Output DC Offset, VFRO |  |  | 200 | mV | VFril Connected to GRDA |
| PSRR4 | Power Supply Rejection of Vcc at $1 \mathrm{kHz}, \mathrm{VFRO}$ | 30 | 35 |  | dB |  |
| PSRR5 | Power Supply Rejection of $\mathrm{V}_{\mathrm{BB}}$ at 1 kHz , VFrO | 25 | 30 |  | dB |  |
| $C_{\text {LR }}$ | Load Capacitance, $\mathrm{VFRO}^{\text {O }}$ |  |  | 20 | pF |  |
| RLR | Minimum Load Resistance, VFrO | 10 |  |  | $\mathrm{k} \Omega$ | Minimum $\mathrm{R}_{\mathrm{L}}$ |
| Vor | Output Voltage Swing, $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ |  |  | $\pm 3.2$ | V | $\mathrm{R}_{\mathrm{L}}=10 \mathrm{k} \Omega$ |

NOTE:

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

## 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 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{GRDA}=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.

## ANALOG INTERFACE, RECEIVE FILTER DRIVER AMPLIFIER STAGE



## 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{BB}}=-5 \mathrm{~V} \pm 5 \%, G R D A=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.
Clock Input Frequency: $C L K=1.536 \mathrm{MHz} \pm 0.1 \%, C L K 0=V_{\text {ILO }}$ (Tied to $V_{B B}$ )

$$
\begin{aligned}
& \text { CLK }=1.544 \mathrm{MHz} \pm 0.1 \%, \text { CLKO }=V_{110}(\text { Tied to } G R D D) \\
& \text { CLK }=2.048 \mathrm{MHz} \pm 0.1 \%, \text { CLKO }=V_{\text {IHO }}\left(\text { Tied to } V_{C C}\right)
\end{aligned}
$$

TRANSMIT FILTER TRANSFER CHARACTERISTICS ${ }_{\text {for Transmit Filter Transfer Characteristics description section }}^{\text {(See }}$

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| GRX | Gain Relative to Gain at 1 kHz |  |  |  |  | OdBmO Input Signal Gain Setting Op Amp at Unity Gain <br> OdBmO Signal $\equiv 1.1 \mathrm{~V}_{\mathrm{RMS}}$ Input at VFxI- <br> OdBmO Signal $\equiv 1.6 \mathrm{~V}_{\mathrm{RMS}}$ Output at VFxO |
|  | Below 50Hz |  |  | -10 | dB |  |
|  | 50Hz |  |  | -20 | dB |  |
|  | 60 Hz |  |  | -26 | dB |  |
|  | 200 Hz | -1.8 |  | -0.125 | dB |  |
|  | 300 Hz to 3000 Hz | -0.125 |  | 0.125 | dB |  |
|  | 3300 Hz | -0.65 |  | 0.03 | dB |  |
|  | 3400 Hz | -1.4 |  | -0.1 | dB |  |
|  | 4000 Hz |  |  | -14 | dB |  |
|  | 4600 Hz and Above |  |  | -32 | dB |  |
| $\mathrm{G}_{\text {AX }}$ | Absolute Passband Gain at 1kHz, VFxO | 2.9 | 3.0 | 3.1 | dB |  |
| $\mathrm{G}_{\text {AXT }}$ | Gain Variation with Temperature at 1 kHz |  | . 0005 |  | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | OdBmO Signal Level |
| $\mathrm{G}_{\text {AXS }}$ | Gain Variation with Supplies at 1 kHz |  | . 05 |  | dB/V | 0dBmO Signal Level, Supplies $\pm 5 \%$ |
| CTRT | Cross Talk, Receive to Transmit, Measured at VFxO |  |  | -60 | dB | $V F_{\text {RI }}=1.6 \mathrm{~V}_{\mathrm{RMS}}, 1 \mathrm{kHz}$ Input VFxI ${ }^{+}$, VFxI - Connected to GSx, GSx Connected through 10k $\Omega$ to GRDA |
| NCX1 | Total C Message Noise at Output, VFxO |  | 9 | 12 | dBrnc0 [2] | Gain Setting Op Amp at Unity Gain |
| NCx2 | Total C Message Noise at Output, VFxO |  | 10 | 13 | dBrnco [2] | Gain Setting Op Amp at 20dB Gain |
| DDX | Differential Envelope Delay, $\mathrm{VF}_{\mathrm{XO}}$ 1 kHz to 2.6 kHz |  |  | 80 | $\mu \mathrm{S}$ |  |
| DAX | Absolute Delay at $1 \mathrm{kHz}, \mathrm{VFxO}$ |  |  | 130 | $\mu \mathrm{S}$ |  |
| DP $\mathrm{x}_{1}$ | Single Frequency Distortion Products |  |  | -48 | dB | OdBm Input Signal at 1 kHz |
| DPx2 | Single Frequency Distortion Products at Maximum Signal Level of $+3 \mathrm{dBm0}$ at VFxO |  |  | -45 | dB | $0.16 \mathrm{~V}_{\mathrm{RMS}} 1 \mathrm{kHz}$ Input Signal at VFxI- , Gain Setting Op Amp at 20 dB Gain. The +3 dBmO signal at VFxO is 2.24 VRMs. |

See next page for NOTES.

## 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{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{GRDA}=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.
Clock Input Frequency: $C L K=1.536 \mathrm{MHz} \pm 0.1 \%, C L K 0=V_{1 L 0}$ (Tied to $V_{B B}$ )
CLK $=1.544 \mathrm{MHz} \pm 0.1 \%, C L K 0=V_{10}$ (Tied to GRDD)
CLK $=2.048 \mathrm{MHz} \pm 0.1 \%, C L K O=\mathrm{V}_{\mathrm{IHO}}$ (Tied to $\mathrm{V}_{\mathrm{CC}}$ )

RECEIVE FILTER TRANSFER CHARACTERISTICS
(See Receive Filter Transfer Characteristics description section for graph)

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| GRR | Gain Relative to Gain at 1 kHz with Sinx/x Correction of 2910 or 2911 |  |  |  |  | OdBmO Input Signal |
|  | Below 200Hz |  |  | 0.125 | dB | 0 dBmO Signal $\equiv 1.6$ |
|  | 200 Hz | -0.5 |  | 0.125 | dB |  |
|  | 300 Hz to 3000 Hz | -0.125 |  | 0.125 | dB | $(\sin \overline{2 \pi(8000)} / \overline{2 \pi(8000)})$ |
|  | 3300 Hz | -0.65 |  | 0.03 | dB | Input at $V F_{R}$ I |
|  | 3400 Hz | -1.4 |  | -0.1 | dB |  |
|  | 4000 Hz |  |  | -14 | dB |  |
|  | 4600 Hz and Above |  |  | -30 | dB | OdBmO Signal $=1.6 \mathrm{~V}$ RMS |
| $\mathrm{G}_{\text {AR }}$ | Absolute Passband Gain at $1 \mathrm{kHz}, \mathrm{VF}_{\mathrm{R}} \mathrm{O}$ | -0.1 | 0 | +0.1 | dB | Output at $\mathrm{VFRO}^{\text {O }}$ |
| Gart | Gain Variation with Temperature at 1 kHz |  | . 0005 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | dB/ ${ }^{\circ} \mathrm{C}$ | OdBmO Signal Level |
| Gars | Gain Variation with Supplies at 1 kHz |  | . 05 |  | dB/V | OdBmO Signal Level, Supplies $\pm 5 \%$ |
| CTTR | Cross Talk, Transmit to Receive, Measured at $\mathrm{VFRO}_{\mathrm{R}}$ |  |  | -60 | dB | VFxO = 2.2 $\mathrm{V}_{\mathrm{RmS}}, 1 \mathrm{kHz}$ Output. VFRI Connected to GRDA. |
| NCR | Total C Message Noise at Output, $\mathrm{VFrO}^{\text {O }}$ |  | 9 | 12 | dBrnc0 [2] | $\mathrm{VFRO}_{\mathrm{R}}$ Output or $\mathrm{PWRO}^{+}$and PWRO- Connected with Unity Gain |
| DDR | Differential Envelope Delay, VFrO, 1 kHz to 2.6 kHz |  |  | 100 | $\mu \mathrm{S}$ |  |
| DAR | Absolute Delay at $1 \mathrm{kHz}, \mathrm{VFR}_{\mathrm{R}} \mathrm{O}$ |  |  | 130 | $\mu \mathrm{s}$ |  |
| DPP1 | Single Frequency Distortion Products |  |  | -48 | dB | OdBm Input Signal at 1 kHz |
| DPR2 | Single Frequency Distortion Products at Maximum Signal Level of +3 dBmO at VFRO |  |  | -45 | dB | +3 dBmO Signal Level of 2.24 VRMs, 1 kHz Input at $\mathrm{VFRO}_{\mathrm{R}}$ |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. A noise measurement of 18 dBrnc into a $600 \Omega$ load at the 2912 device is equivalent to 12 dBrnc 0 .

# MCS-4/40 ${ }^{\text {TM }}$ Microprocessor 



## TABLE OF CONTENTS*

Central Processing Unit
4040 Single Chip 4-Bit P-Channel Microprocessor ..... 7-3
4004 Single Chip 4-Bit P-Channel Microprocessor ..... 7-4
Input/Output
4003 10-Bit Shift Register/Output Expander ..... 7-5
4265 Programmable General Purpose I/O Device ..... 7-6
4269 Programmable Keyboard Display Device ..... 7-7
Peripherals
4201A Clock Generator. ..... 7-8
4289 Standard Memory Interface ..... 7-9
RAMs
4002 320-Bit RAM and 4-Bit Output Port ..... 7-10
ROMs
$4001256 \times 8$ Mask Programmable ROM and 4-Bit I/O Port ..... 7-11
$43081024 \times 8$ Mask Programmable ROM and Four 4-Bit I/O Ports ..... 7-13
4316A/2316A $2048 \times 8$ ROM ..... 4-12
PROMs
1702A/4702A 2K (256 x 8) UV Erasable PROM ..... 4-5 Avenue, Santa Clara, California 95051.

## SINGLE CHIP 4-BIT P-CHANNEL MICROPROCESSOR

## - Functionally and Electrically Upward Compatible to 4004 CPU <br> - 14 Additional Instructions (60 total) Including Logical Operations and Read Program Memory <br> - Interrupt Capability <br> - Single Step Operation

- 8K Byte Memory Addressing Capability
- 24 Index Registers
- Subroutine Nesting to 7 Levels
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available With $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The Intel® 4040 is a complete 4-bit parallel central processing unit (CPU). The CPU can directly address 4 K eight bit instruction words or 8 K with a bank switch. Seven levels of subroutine nesting, including interrupt, and 24 randomly accessable index registers $(24 \times 4)$ are provided as convenient facilities for the designer. The index registers may be used for addressing or for scratch pad memory for storing computation results. The interrupt feature permits a normal program sequence to be interrupted, with normal program execution continuing after the interrupt service routine is completed. Provisions have also been made to permit single-stepping the CPU using the STOP and ACKNOWLEDGE signals.
The 4040 is an enhanced version of the 4004 and as such retains all the functional capability of that device. It will execute all the 4004 instructions, and is also electrically compatible with all components used with a 4004 CPU.


## intel

## 4004 <br> SINGLE CHIP 4-BIT P-CHANNEL MICROPROCESSOR

- 4-Bit Parallel CPU With 46 Instructions
- Instruction Set Includes Conditional Branching, Jump to Subroutine and Indirect Fetching
- Binary and Decimal Arithmetic Modes
- 10.8 Microsecond Instruction Cycle
- CPU Directly Compatible With MCS-40 ROMs and RAMs
- Easy Expansion-One CPU can Directly Drive up to 32,768 Bits of ROM and up to 5120 Bits of RAM
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available With $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The Intel® 4004 is a complete 4-bit parallel central processing unit (CPU). The 4004 easily interfaces with keyboards, switches, displays, A-D converters, printers and other peripheral equipment.

The CPU can directly address 4 K 8 -bit instruction words of program memory and 5120 bits of data storage RAM. Sixteen index registers are provided for temporary data storage. Up to 164 -bit input ports and 164 -bit output ports may also be directly addressed.
The 4004 is fabricated with P-channel silicon gate MOS technology.


## 4003

## 10-BIT SHIFT REGISTER/OUTPUT EXPANDER

- 10 Bit Serial-In/Parallel Out
- Serial-Out Capability for Additional I/O Expansion
- 16 Pin Dual-In-Line Package
- Easy Expansion of I/O Output Capability
- Enable Output Control
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$

The 4003 is a 10 bit serial-in, parallel-out, serial-out shift register with enable logic. The 4003 is used to expand the number of ROM and RAM I/O ports to communicate with peripheral devices such as keyboards, printers, displays, readers, teletypewriters, etc.
The 4003 is a single phase static shift register; however, the clock pulse (CP) maximum width is limited to 10 msec . Data-in and CP can be simultaneous. To avoid race conditions, CP is internally delayed.


## 4265

## PROGRAMMABLE GENERAL PURPOSE I/O DEVICE

- Multi-Mode 14 Operating Modes
- 16 Lines of I/O Capability
- Bit Set/Reset

■ Multiplexable Outputs

- Eight Bit Transfer Mode
- Interfaces to 8080 Peripherals
- Synchronous and Asynchronous Interface
- Strobed Buffer Inputs and Outputs

TTL Interface

- Up to Eight 4265s Per System
- Interface to Standard RAMs
- 28 Pin Dual-In-Line Package
- Interface to Standard RAMs
- 28 Pin Dual-in-Line Package
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available with $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The 4265 is a general purpose I/O device designed to interface with the MCS-40 ${ }^{\text {TM }}$ microcomputer family. This device provides four software programmable 4-bit I/O ports which can be configured to allow any one of fourteen unique operating modes for interfacing to data memory or a variety of user peripheral devices.

A single MCS-40 system can accomodate up to four 4265s (one per CM-RAM) without external logic or up to eight 4265 s with one external decoder.

The 4265 resides on the MCS-40 data bus and uses the same selection procedure as 4002 RAM device. A valid compare selects the 4265 for MCS-40 I/O commands. As in the case of the 4002 or any MCS-40 peripheral circuit, selection occurs only when the proper SRC code and the CM signal are present simultaneously.

The 4265 provides an extremely flexible, general purpose I/O system capable of handling 4-or 8-bit input or output data. One of fourteen basic operating modes can be selected (software programmable) as described below.
Port $Z$ is TTL compatible with any TTL device. Ports $W, X$, and $Y$ are low-power TTL compatible.

PIN CONFIGURATION


## 4269

## PROGRAMMABLE KEYBOARD DISPLAY DEVICE

## Keyboard Features:

- Programmable to Interface to Encoded Keyboard (8-bit code), 64-Key Scanned Keyboard (expandable to 128 keys) or Sensor Matrix (64 sensors)
- 8 Character FIFO Character Buffer (or RAM in Sensor Mode)
- 2 Key Rollover and Key Debounce
- External Interrupt Line to Indicate When a Character Has Been Entered in Character Buffer


## Display Features:

- Programmable to Interface to Individually Scanned Displays or Burrough's Self-Scan* Drive (16, 18, or 20 Characters)
- Two $16 \times 4$ Display Registers Recirculated Synchronously with Keyboard Scan Lines to Give Automatic Display Refresh
- Display Registers Loadable and Readable Selectively or Sequentially
- 40 Pin Dual In-Line Package
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available with $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The 4269 has two separate and distinct sections: the keyboard section and the display section. The keyboard section can interface to a range of devices from a matrix of toggle or thumb switches such as found on an instrument panel up to a full typewriter style keyboard. The display section can interface to a range of devices from an array of individual LED indicators up to a gas discharge alphanumeric display.
The 4269 Programmable Keyboard Display (PKD) relieves the 4004 or 4040 CPU from continuously scanning a switch array or refreshing a display under software control. This greatly expands the CPU throughput. The 4269 can scan up to an $8 \times 8$ keyboard or sensor matrix (or a $2 \times 8 \times 8$ keyboard with the use of the shift or control key input). The display portion can continuously refresh either a single $16 \times 8$ alphanumeric display; a single $8 \times 8$ alphanumeric display; a dual $16 \times 4$ digit display; a single $32 \times 4$ digit display; a $16 \times 6,18 \times 6$ or $20 \times 6$ alphanumeric gas discharge display such as the Burroughs Self-Scan*; or an array of 128 indicators.
*Self-Scan is a registered trademark of the Burroughs Corporation


4201A

## CLOCK GENERATOR

- Complete Clock Requirements for MCS-40 ${ }^{\text {™ }}$ Systems
- Crystal Controlled Oscillator (XTAL External)
MOS and TTL Level Clock Outputs
- Provides MCS-40 Reset Function Signal
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available with $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The 4201A is a CMOS integrated circuit designed to fill the clock requirements of the MCS-40 microcomputer family. The 4201A contains a crystal controlled oscillator (XTAL external), clock generation circuitry, and both MOS and TTL level clock driver circuits.

The 4201A also performs the power on reset function required by MCS-40 components and provides the logic necessary to implement the single-step function of the 4040 central processor unit.

## PIN CONFIGURATION




## STANDARD MEMORY INTERFACE

- Direct Interface to all Standard
Memories
- Allows Read and Write Program Memory
- Single Package Equivalent of 4008/4009
- TTL Compatible Address, Chip Select, Program Memory Data Lines


## - 40 Pin Dual In-Line Package <br> - Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$

- Also Available With $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The 4289 standard memory interface and I/O interface enables the CPU devices to utilize standard memory components as program data memory. Notably, PROMs (4702A), RAMs (2102) and ROMs can be arranged in a memory array to facilitate system development. Programs generated using the 4289 interface can be committed to MCS $40^{\text {™ }}$ ROMs ( 4308 and 4001) with no change to software.
The 4289 also contains a 4 bit bi-directional I/O port and necessary steering logic to multiplex a host of I/O sources to the CPU. The Read and Write Program Memory instruction allows the user to store data and modify program memory. The device directly addresses 4 K of program memory. The address is obtained sequentially during $\mathrm{A}_{1}-\mathrm{A}_{3}$ states of an instruction cycle. The eight bit instruction is presented to the CPU during $M_{1}$ and $M_{2}$ states of the instruction cycle via the four bit data bus.
The 4289 stores the SRC instruction operand as an I/O address and responds to the ROM I/O instructions (WRR and RDR) by reading or writing data to and from the processor and 4289 I/O bus.

## BLOCK DIAGRAM



4002

## 320-BIT RAM AND 4-BIT OUTPUT PORT

Four Registers of 204 Bit Characters
Direct Interface to MCS-40 ${ }^{\text {M }}$ 4 Bit Bus

- Output Port Low-Power TTL Compatible
- 16 Pin Dual In-Line Package
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available With $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The 4002 performs two distinct functions. As a RAM it stores 320 bits arranged in 4 registers of twenty 4 bit characters each (16 main memory characters and 4 status characters). As a vehicle of communication with peripheral devices, it is provided with 4 output lines and associated control logic to perform output operations. The 4002 is a PMOS device and is compatible with all MCS-40 ${ }^{\text {TM }}$ components.
The 4002 is available in two options, the 4002-1 and 4002-2. Along with an external pin connected to either $V_{D D}$ or $V_{S S}$, a two bit chip selection address is provided allowing a maximum of 1280 bits of 4002 RAM on a single MCS- 40 CM-RAM line. Thus, the four CM-RAM lines give a maximum of 5120 bits of 4002 RAM in an MCS-40 system.

PIN CONFIGURATION


BLOCK DIAGRAM


4001

## 256 x 8 MASK PROGRAMMABLE ROM AND 4-BIT I/O PORT

\author{

- Direct Interface to MCS-40™ 4 Bit Data Bus <br> - I/O Port Low-Power TTL Compatible <br> - 16 Pin Dual In-Line Package
}
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available With $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The 4001 performs two basic and distinct functions. As a ROM it stores $256 \times 8$ words of program or data tables; as a vehicle of communication with peripheral devices it is provided with 4 I/O pins and associated control logic to perform input and output operations. The 4001 is a PMOS device, compatible with all other MCS-40 ${ }^{\text {TM }}$ devices.



All custom 4001 ROM orders must be submitted on this form. Progranming 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 as shown at the right must contain the Intel logo, the product type (P4001), the 4 -digit Intel pattern number (PPPP), a date code (XXXX), and the 2-digit chip number (DD). An optional customer identification number may be substituted for the chip number ( $Z Z)$. Optional Customer Number (maximum 6 characters or spaces).
CUSTOMER NUMBER


## MASK OPTION SPECIFICATIONS

## A. CHIP NUMBER

(Must be specified-any number from 0 through 15-DD).
B. I/O OPTION - Specify the connection numbers for each I/O pin (next page). Examples of some of the possible 1/O options are shown below:

## EXAMPLES - DESIRED OPTION/CON-

 NECTIONS REQUIRED1. Non-inverting output -1 and 3 are connected.
2. Inverting output - 1 and 4 are connected.
3. Non-inverting input (no input resistor) - only 5 is connected.
4. Inverting input (input resistor to $V_{S S}$ ) - 2, 6, 7, and 9 are connected.
5. Non-inverting input (input resistor to $\left.V_{D D}\right)$ - 2, 7, 8, and 10 are connected.
6. If inputs and outputs are mixed on the same port, the pins used as the outputs must have the internal resistor connected to either $V_{D D}$ or $\mathrm{V}_{\mathrm{SS}}$ ( 8 and 9 or 8 and 10 must be connected). This is necessary for testing purposes. For example, if there are two inverting inputs (with no input resistor) and two non-inverting outputs, the connection would be made as follows:

Inputs - 2 and 6 are connected Outputs - 1, 3, 8, and 9 are connected or
1, 3, 8, and 10 are connected
If the pins on a port are all inputs or all outputs, the internal resistors do not have to be connected.
C. 4001 CUSTOM ROM PATTERN -
Programming information should be
sent in the form of computer punched
cards or punched paper tape. In either case, a printout of the truth table must accompany the order. In the BPNF format, the characters should be written as a " $P$ " for a high level output $=\mathrm{V}_{\text {SS }}$ (negative logic " 0 ") or an " N " for a low level output $=\mathrm{V}_{\mathrm{DD}}$ (negative logic " 1 ").
Hex input tapes for the 4001 and 4308 may also be generated by Intellec ${ }^{\circledR}$ Development Systems. These tapes are assumed to be negative logic. This means that a NOP instruction operation code (00000000), for example, would be coded as 00 in the HEX format. This would automatically result in the $\mathrm{V}_{\mathrm{IH}}$ levels on the MCS $4 / 40$ data bus. When the BPNF format is used, all logic representations must be inverted. Thus, a NOP would be represented as BPPPPPPPPF.

## intel

## 4308 <br> $1024 \times 8$ MASK PROGRAMMABLE ROM AND FOUR 4-BIT I/O PORTS

## Direct Interface to MCS-40 ${ }^{\text {™ }}$

 4-Bit Data Bus- Equivalent to Four 4001 ROMs
- Four Independent 4-Bit I/O Ports
- Input I/O Buffer Storage with an Optional Strobe
- I/O Ports Low-Power TTL Compatible
- 28 Pin Dual In-Line Package
- Standard Operating Temperature Range of $0^{\circ}$ to $70^{\circ} \mathrm{C}$
- Also Available With $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ Operating Range

The 4308 is a $1024 \times 8$ bit word ROM memory with four I/O ports. It is designed for the MCS- $40^{\text {TM }}$ system and is operationally compatible with all existing MCS-40 elements. The 4308 is functionally identical to four 4001 chips. The 4308 has 16 I/O lines arranged in four groups of four lines.


PIN CONFIGURATION
(135

MCS ${ }^{\oplus}$
4308
CUSTOM ROM ORDER FORM


All custom 4308 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 as shown at the right must contain the Intel logo, the product type ( P 4308 ), the 4 -digit Intel pattern number (PPPP), a date code ( $X X X X$ ), and the 2-digit chip number (DD). An optional customer identification number may be substituted for the chip number ( $Z Z$ ). Optional Customer Number (maximum 6 characters or spaces).

## CUSTOMER NUMBER



## MASK OPTION SPECIFICATION

## A. CHIP NUMBER

$\qquad$ (Must be specified).
B. I/O OPTION - Specify the connection numbers for each I/O pin. See table below.
C. 4308 CUSTOM ROM PATTERN - Programming information should be sent in the form of computer punched cards or punched paper tape. In either case, a printout of the truth table must accompany the order. In the BPNF format, the characters should be written as a " $P$ " for a high level output $=V_{\text {SS }}$ (negative logic " 0 ") or an " $N$ " for a low level output $=V_{D D}$ (negative logic " 1 ").

Hex input tapes for the 4001 and 4308 may also be generated by Intellec ${ }^{\circledR}$ Development Systems. These tapes are assumed to be negative logic. This means that a NOP instruction operation code ( 00000000 ), for example, would be coded as 00 in the HEX format. This would automatically result in the $\mathrm{V}_{1 H}$ levels on the MCS $4 / 40$ data bus. When the BPNF format is used, all logic representations must be inverted. Thus, a NOP would be represented as BPPPPPPPPF.

| PIN |  | OPTION |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $1 / 00_{0}$ | 27 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / \mathrm{O}_{1}$ | 26 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / \mathrm{OH}_{2}$ | 25 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / \mathrm{OH}_{3}$ | 24 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 010$ | 5 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 01_{1}$ | 4 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 01_{2}$ | 3 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 013$ | 2 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 020$ | 17 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 021$ | 16 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 022$ | 15 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 023$ | 14 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / \mathrm{O} 30$ | 21 | 1 | 2 | 3 | 4 | $\overline{5}$ | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 03_{1}$ | 20 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 03_{2}$ | 19 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| $1 / 033$ | 18 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 |



NOTE: Options 10 and 11 cannot both be specified.


## MCS-48™ MICROCOMPUTERS

## TABLE OF CONTENTS

Single Component 8-Bit Microcomputers
8021 Single Component 8-Bit Microcomputer ..... 8-4
8022 Single Component 8-Bit Microcomputer with A/D ..... 8-10
8048/8648/8748/8035 Single Component 8-Bit Microcomputer ..... 8-22
8049/8039/8039-6 Single Component 8-Bit Microcomputer . ..... 8-31
Input/Output
8243 MCS-48 ${ }^{\text {TM }}$ Input/Output Expander. ..... $8-36$

## INTRODUCTION

Recent advances in NMOS technology have allowed Intel for the first time to place enough capability on a single silicon die to create a true single chip microcomputer containing all the functions required in a digital processing system. This microcomputer, its variations, and its optional peripherals are collectively called the MCS-48 microcomputer family and are fully described in this manual.

The head of the family is the 8048 microcomputer which contains the following functions in a single 40-pin package:
8 -Bit CPU
$1 \mathrm{~K} \times 8$ ROM program memory
$64 \times 8$ RAM data memory
27 I/O lines
8 -bit timer/event counter

A 2.5 or 5.0 microsecond cycle time and a repertoire of over 90 instructions each consisting of either one or two cycles makes the single chip 8048 the equal in performance of most presently available multi-chip NMOS microprocessors, yet the 8048 is a true "low-cost" microcomputer. A single 5 V supply requirement for all MCS-48 components assures that "low cost" also applies to the power supply in your system.
Even with low component costs, however, a project may be jeopardized by high development and rework costs resulting from an inflexible production design. Intel has solved this problem by creating two pin-compatible versions of the 8048 microcomputer: the 8048 with mask programmable ROM program memory for low cost production and the 8748 with user programmable and erasable EPROM program memory for prototype development. The 8478 is essentially a single chip microcomputer "breadboard" which can be modified over and over again during development and pre-production, then simply replaced by the low cost 8048 ROM for volume production. The 8748 provides a very easy transition from development to production and also provides an easy vehicle for temporary field updates while new ROMs are being made.

To allow the MCS-48 to solve a wide range of problems and to provide for future expansion, all 8048 functions have been made externally expandable using either special expanders or standard memories and peripherals. An efficient low cost means of I/O expansion is provided by the 8243 Input/Output Expander which provides 16 I/O lines in a 24 -pin package. For systems with large I/O requirements, multiple 8243s can be used.
For such applications as keyboards, displays, serial communication lines, etc., standard MCS-80 ${ }^{\mathrm{TM}}$ (8080) and MCS $85^{\text {TM }}$ (8085) peripheral circuits may be added. Program and data memory may be expanded using standard memories or the 8355 and 8155 memories that also include programmable I/O lines and timing functions.
The 8035 is an 8048 without internal program memory that allows the user to match his program memory requirements exactly by using a wide variety of external memories. The 8035 allows the user to select a minimum cost system no matter what his program memory requirements.
The 8048 was designed to be an efficient control processor as well as an arithmetic processor with an instruction set which allows the user to directly set and reset individual lines within its I/O ports as well as test individual bits within the accumulator. A large variety of branch and table look-up instructions make the 8048 very efficient in implementing standard logic functions. Special attention was also given to code efficiency with over $70 \%$ of the instructions being single byte and all others being only two bytes. This means many functions requiring 1.5 K to 2.0 K bytes in other processors may very well be compressed into the 1 K words resident in the 8048.


## SPECIAL FEATURES

## Single 5V Supply <br> 40-Pin DIP

## Pin Compatible ROM and EPROM

## - 2.5 and $5.0 \mu \mathrm{sec}$ Cycle Versions

## - All Instructions 1 or 2 Cycles - Single Step

- 8-Level Stack
- 2 Working Register Banks
- RC, XTAL, or External Frequency Source
- Clock per Cycle and Optional Clock per State Output

8021

## SINGLE COMPONENT 8-BIT MICROCOMPUTER

\author{

- 8-Bit CPU, ROM, RAM, I/O in Single 28-Pin Package <br> - Single 5V Supply ( +4.5 V to 6.5 V ) <br> - $8.38 \mu \mathrm{sec}$ Cycle With 3.58 MHz XTAL; All Instructions 1 or 2 Cycles <br> - Instructions -8748 Subset <br> - High Current Drive Capability-2 Pins
}
- $1 \mathrm{~K} \times 8 \mathrm{ROM}$
$64 \times 8$ RAM 21 I/O Lines
- Interval Timer/Event Counter
- Clock Generated With Single Resistor or Inductor
- Zero-Cross Detection Capability
- Easily Expandable I/O


#### Abstract

The Intel ${ }^{\circledR} 8021$ is a totally self-sufficient 8 -bit parallel computer fabricated on a single silicon chip using Intel's N -channel silicon gate MOS process. The features of the 8021 include a subset of the 8048 optimized for low cost, high volume applications, plus additional I/O flexibility and power.

The 8021 contains a $1 \mathrm{~K} \times 8$ program memory, a $64 \times 8$ data memory, $21 \mathrm{I} / \mathrm{O}$ lines, and an 8 -bit timer/event counter, in addition to on-board oscillator and clock circuits. For systems that require extra I/O capability, the 8021 can be expanded using the 8243 or discrete logic.

This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The 8021 has bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from an instruction set consisting mostly of single byte instructions and no instructions over two bytes in length.

To minimize development problems and maximize flexibility, an 8021 system can be easily designed using the 8021 emulation board, EMB-21. The EMB-21 contains a 40-pin socket which can accommodate either the 8748 shipped with the board or an ICE-48 plug. Also, the necessary discrete logic to reproduce the 8021 's additional I/O features is included.




## 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 +7V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . 1 W
*COMMENT: Stresses above those listed under "Absolute Maxinn mum 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 sec. tions 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.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (All except XTAL1, XTAL2) | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (All except XTAL1, XTAL2) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{V}_{\mathrm{H}_{1}}$ | Input High Voltage (All except XTAL1, XTAL2) | 3.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage (P10, P11) |  |  | 2.5 | V | $\mathrm{I}_{\mathrm{OL}}=7 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (All unless Open Drain) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=50 \mu \mathrm{~A}$ |
| IOL | Output Leakage Current (Open Drain Option Port 0) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  | 100 | mA |  |

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CY}}$ | Cycle Time | 8.38 | 50.0 | $\mu \mathrm{sec}$ | 3 MHz XTAL $=10 \mu \mathrm{sec} \mathrm{t}_{\mathrm{CY}}$ |
| $\Delta_{\mathrm{F}}$ | Oscillator Frequency Variation -Resistor Mode | -20 | +20 | $\%$ | $\mathrm{~F}=2.5 \mathrm{MHz}$ |

## A.C. TEST CONDITIONS

Control Outputs: $C_{L}=80 \mathrm{pF}$

PIN DESCRIPTION

| Designation | Pin \# | Function |
| :--- | :---: | :--- |
| $V_{\text {SS }}$ | 14 | Circuit GND potential <br> +5V power supply |
| V $_{\text {CC }}$ | 28 | Output strobe for 8243 I/O Ex- <br> pander |
| PROG-P07 <br> Port 0 | $4-11$ | 8-bit quasi-bidirectional port |
| P10-P17 <br> Port 1 | $18-25$ | 8-bit quasi-bidirectional port |
| P20-P23 <br> Port 2 | $26-27$ | 4-bit quasi-bidirectional port <br> P20-P23 also serve as a 4-bit I/O <br> expander bus for 8243 |
| T1 | 13 | Input pin testable using the JT1 <br> and JNT1 instructions. Can be <br> designated the timer/event count- <br> er input using the STRT CNT <br> instruction. Also allows zero- |

Designation Pin \# Function
crossover sensing of slowly moving $A C$ inputs.

RESET
17 Input used to initialize the processor by clearing status flip-flops and setting program counters to zero.

Address Latch Enable. Signal occuring once every 30 input clocks, used as an output clock.
XTAL1 15
One side of crystal, inductor, or resistor input for internal oscillator. Also input for external source. (Not TTL compatible.)
XTAL2 16 Other side of timing control element.

## INSTRUCTION SET*

| Mnemonic |  | Description <br> Add register to $A$ | Bytes <br> 1 | Cycle <br> 1 |
| :---: | :---: | :---: | :---: | :---: |
|  | A, R |  |  |  |
|  | A, @R | Add data memory to $A$ | 1 | 1 |
|  | A,\#data | Add immediate to $A$ | 2 | 2 |
|  | A,R | Add with carry | 1 | 1 |
|  | A, @R | Add with carry | 1 | 1 |
|  | A, \#data | Add with carry | 2 | 2 |
|  | A,R | And register to $A$ | 1 | 1 |
|  | A, @R | And data memory to $A$ | 1 | 1 |
|  | A, \#data | And immediate to $A$ | 2 | 2 |
|  | A, R | Or register to A | 1 | 1 |
|  | A, @R | Or data memory to $A$ | 1 | 1 |
|  | A,\#data | Or immediate to $A$ | 2 | 2 |
|  | A, R | Exclusive Or register to $A$ | 1 | 1 |
|  | A, @R | Exclusive or data memory to $A$ | 1 | 1 |
|  | A, \#data | Exclusive or ımmediate to $A$ | 2 | 2 |
|  | A | Increment A | 1 | 1 |
|  | A | Decrement A | 1 | 1 |
|  | A | Clear A | 1 | 1 |
|  | A | Complement A | 1 | 1 |
|  | A | Decimal Adjust A | 1 | 1 |
|  | A | Swap nibbles of $A$ | 1 | 1 |
|  | A | Rotate A left | 1 | 1 |
|  | A | Rotate A left through carry | 1 | 1 |
|  | A | Rotate A right | 1 | 1 |
|  | A | Rotate A right through carry | 1 | 1 |
|  | A, P | Input port to A | 1 | 2 |
|  | P, A | Output A to port | 1 | 2 |
|  | A, P | Input Expander port to A | 1 | 2 |
|  | P, A | Output A to Expander port | 1 | 2 |
|  | P, A | And A to Expander port | 1 | 2 |
|  | P, A | Or A to Expander port | 1 | 2 |
|  | R | Increment register | 1 | 1 |
|  | @R | Increment data memory | 1 | 1 |
|  | addr | Jump unconditional | 2 | 2 |
|  | @A | Jump indirect | 1 | 2 |
|  | R,addr | Decrement register and Jump on $\mathbf{R}$ not zero | 2 | 2 |



[^4]
## FUNCTIONAL SPECIFICATIONS

The following is a functional description of the major elements of the 8021 .

## Program Memory

The 8021 contains $1 \mathrm{~K} \times 8$ of mask programmable ROM. No external ROM expansion capability is provided.

## Data Memory

A $64 \times 8$ dynamic RAM is located on chip for data storage. All locations are indirectly addressable and eight designated locations are directly addressable. Also, included in the memory is the address stack, addressed by a 3 -bit stack pointer.
Memory is organized as shown in Figure 1. The least significant 8 addresses, $0-7$, are directly addressable by any of the 11 direct register instructions. The locations are readily accessible for a variety of operations with the least number of instruction bytes required for their manipulation.

Registers 0 and 1 have yet another function, in that they can be used to indirectly address all locations in memory, using the indirect register instructions. These indirect RAM address registers, IRAR's, are especially useful for repeti-tive-type operations on adjacent memory locations. The indirect register instruction specifies which IRAR to use, and the contents of the IRAR is used to address a location in RAM. The contents of the addressed location is used during the execution of the instruction, and may be modified. A value larger than 63 should not be preset in the IRAR when selected by an indirect register instruction. IRAR's may point to addresses $0-7$, if desired.

Locations 8-23 may be used as the address stack. The address stack enables the processor to keep track of the return addresses generated from CALL instructions. A 3-bit stack pointer (SP) supplies the address of the locations to be loaded with the next return address generated. The SP to this pushdown stack is incremented by one after a return address is stored, and decremented by one before an address is fetched during a RET. A total of 8 levels of nesting is possible. The SP is initialized to location 8 upon RESET. Since each address is 10 bits long, two bytes must be used to store a single address. The SP is incremented and decremented by one, but each increment or decrement moves the address pointed to by two. Therefore, only even numbered addresses are pointed to.
If a particular application does not require 8 levels of nesting, the unused portion of the stack may be used as any other indirectly addressable scratchpad location. For example, if only 3 levels of subroutine nesting are used, then only locations $8-15$ need be reserved for the address stack, and locations 16-63 can be used for data storage. The actual program counter address is not stored in the address stack. A separate register retains its value.


Figure 1. Internal RAM Organization

## Oscillator and Clock

The 8021 contains its own onboard oscillator and clock circuit, requiring only an external timing control element. This control element can be a crystal, inductor, resistor, or clock in. The capacitor normally required in resistor or inductor timing control operation is integrated onto the 8021. All internal time slots are derived from the external element, and all outputs are a function of the oscillator frequency. Pins X1 and X2 are used to input the particular control element. An instruction cycle consists of 10 states, and each state is a time slot of 3 oscillator periods. Therefore, to obtain a $10 \mu \mathrm{sec}$ instruction cycle, a 3 MHz crystal should be used.

## Timer/Event Counter

An interval timer is available to enable the user to keep track of time elapsed or number of events occurred, during normal program execution and flow.
By a MOV T,A instruction, the contents of the accumulator are loaded to the timer. At the STRT T command an internal prescaler is zeroed and thereafter increments once each 30 input clocks (once each single cycle instruction, twice each double cycle instruction). The prescaler is a divide by 32. At the (11111) to (00000) transition the timer is incremented. The timer is 8 bits and an overflow (FFH) to $(00 \mathrm{H})$ timer flag is set. A conditional branch is available for testing this flag, the flag being reset each test. Total count capacity for the timer is $2^{8} \times 2^{5}=8192$ or 81.9 msec at a $10 \mu \mathrm{sec}$ cycle time. Contents of the timer are moved to the accumulator by the MOV A, T instruction without disturbing the counting process.
The timer may also be used as an event counter. After a STRT CNT command, the chip will respond to a high to low transition on the Test 1 pin by incrementing the timer. Transitions can occur no faster than one each three instruction cycles.
The timer and event functions are exclusive. Counting or timing may be started or stopped (STOP TCNT) at will.

## Input/Output Capabilities

The 8021 I/O configurations are highly flexible. A number of different configurations are possible, tailoring an 8021 to a given task. Other than the power supply and dedicated pins, all other pins (20) can be used for input, output, or both, depending on the configuration.

P20-P23 and P10-P17 are quasi-bidirectional, and Test 1 is directly testable through program control. A simplified schematic of the quasi-bidirectional interface is shown in Figure 2. This configuration allows buffered outputs, and also allows external input. When writing a " 0 " or low value to these ports, the large pulldown device sinks an external TTL load. When writing a " 1 ", a large current is supplied through the large pullup device to allow a fast data transfer. After a short time (less than one instruction cycle), the large device is shut off and the small pullup maintains the " 1 " level indefinitely. However, in this situtation, an input device capable of overriding the small amount of sustaining current supplied by the pullup device can be read. (Alternatively, the data written can be read). So, by writing a "1" to any particular pin, that pin can serve either as a true high-level latched output pin, or as just a pullup resistor on an input. This allows maximum user flexibility in selecting his input or latched output pins, with a minimum of external components.

Port 00-07 is also quasi-bidirectional, except there is no large pullup device. As outputs, this port is essentially open drain.

By mask option the small pullup devices on P00-P07 may be deleted on any pin providing a true open drain output. This is useful in driving analog circuits and certain loads, such as keyboards.

Also available is the $8243 \mathrm{I} / \mathrm{O}$ expander chip, which provides additional I/O capability with a limited number of overhead pins. This chip has 4 directly addressable 4 -bit ports. It connects to the PROG pin, which provides a clock, and pins P20-P23, which provide address and data. These ports can be written with a MOVD P,A; ANLD P,A; and ORLD P,A for Ports 4-7. A high to low transition on PROG signifies that address and control are available on P20-P23. The previous data on P20-P23 before an output expander instruction is lost. Therefore, when using an output expander P20-P23 are not useful for general input/output. Reading is via the MOVD A,P. This circuit configuration is shown in Figure 3.

The Test 1 pin has a special bias input that allows zerocrossover sensing of slowly moving inputs. This is especially useful in SCR control of 60 Hz power and in developing time of day routines. As a ROM mask option there is a pullup resistor that is useful for switch contact input or standard TTL. See Figure 4.


Figure 2. Quasi-Bidirectional Port Structure


Figure 3. I/O Expander Interface


Figure 4. Test 1 Pin

## CPU

The 8021 CPU has arithmetic and logical capability. A wide variety of arithmetic and logic instructions may be exercised, which affect the contents of the accumulator, and/or direct or indirect scratchpad locations. Provisions have been made for simplified BCD arithmetic capability through the use of the DAA, SWAP A, and XCHD instructions. In addition, MOVP A,@A allows table lookup for display formating and constants. Jump conditions such as zero, not zero refer to the accumulator contents at the time of the condition.

## Reset

The 8021 may see poorly regulated and noisy power supplies. A useful feature is to sense when the power supply dips and do a reset to prevent continued operation with incorrect data. This feature may be implemented on the 8021 by connecting a diode between the RESET node and ground. See Figure 5.

A reset will then be forced if the supply drops approximately 1.5 volts and rapidly recovers. One instruction cycle will reset the 8021 to the initialized state.

By removing the diode and using only the capacitor, voltage drops in $\mathrm{V}_{\mathrm{CC}}$ will not cause a RESET.


FIGURE 5. POWER ON RESET

## Differences Between the $\mathbf{8 0 2 1}$ and the $\mathbf{8 7 4 8}$

Although the 8021 is basically an electrical and functional subset of the 8748 , there are some differences:

1. Pin Out - As the 8021 is a 28 -pin DiP, some form of adapter must be used to interface the 8021 socket to ICE-48. An emulation board, EM-1, has been designed to perform this function. The EM-1 also accounts for the increased flexibility of some 8021 I/O lines.
2. Instruction Time - The 8021 instruction cycle is 30 clock cycles long, the 8748 instruction cycle is 15 clocks long. Where exact timing is important the 8748 breadboard part should be operated at half the 8021 clock rate.
3. Test 1 - To facilitate developing time of day routines from 60 Hz , and for SCR control, the Test 1 pin without the pullup resistor option will detect zero crossing of a capacitively coupled AC input.
4. Quasi-Bidirectional Ports - All 8021 ports are quasibidirectional to facilitate stand-alone use. Port 0 has open drain outputs and by mask option it may or may not have pullup resistors.
5. Oscillator - The 8021 has on-chip oscillator that is optimized for the single resistor mode. External connection will differ from the 8748.
6. Dynamic RAM and Logic - The 8021 utilizes dynamic RAM and some dynamic logic. Input clocking must be maintained above the minimum rate or improper operation may result.
7. High Current Outputs - Very high current drive is desirable for minimizing external parts required to do high power control. P10 and P11 have been designated high drive outputs capable of sinking 7 mA at $\mathrm{V}_{\mathrm{SS}}+2.5$ volts. (For clarity, this is 7 mA to $V_{S S}$ with a 2.5 volt drop across the buffer.) These pins may, of course, be paralleled for 14 mA drive if the output logic states are always the same.
8. Reset - Reset has been modified on the 8021, as previously noted. A reset will be forced if the power supply drops approximately 1.5 volts and rapidly recovers, if a diode is used in the reset circuit. This prevents continued operation with incorrect data caused by a poorly regulated and/or noisy power supply.
9. Instruction Set - The following instructions, which are found in the 8748, have been deleted from the 8021 instruction set.

| Data Moves |  | Registers | Branch |  | Timer | Contro |  | Input/Output |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOV <br> MOV <br> MOVX <br> MOVX <br> MOVP3 | A, PSW PSW,A A,@R @R,A A,@A | DEC R | JTO <br> JNTO <br> JFO <br> JF1 <br> JNI <br> JBb | addr addr addr addr addr addr | EN TCNTI | EN | 1 | ANL | P, \#data |
|  |  |  |  |  | DIS TCNTI | DIS | 1 | ORL | P.\#data |
|  |  | Flags |  |  |  | SEL | RBO | INS | A,BUS * |
|  |  | CLR FO |  |  | Subroutine | SEL | RB1 | OUTL | BUS,A * |
|  |  | CPL FO |  |  | RETR | SEL | MBO | ANL | BUS,\#data |
|  |  | CLR F1 |  |  | RETR | SEL | MB1 | ORL | BUS,\#data |
|  |  | CPL F1 |  |  |  | ENTO | CLK |  |  |

*These Instructions have been replaced in the 8021 by IN A,PO and OUTL PO,A respectively.

# SINGLE COMPONENT 8-BIT MICROCOMPUTER WITH ON-CHIP AID CONVERTER 

8-Bit CPU, ROM, RAM, I/O in Single 40-Pin Package

- On-Chip 8-Bit A/D Converter; Two Input
Channels
- 8 Comparator Inputs (Port 0)
. Zero-Cross Detection Capability
- Single 5V Supply (4.5V to 6.5V)
- High Current Drive Capability - 2 Pins
- Two Interrupts - External and Timer
- $2 \mathrm{~K} \times 8$ ROM, $64 \times 8$ RAM, 28 I/O Lines
- $8.38 \mu \mathrm{sec}$ Cycle; All Instructions 1 or 2 Cycles
- Instructions - 8048 Subset
- Interval Timer/Event Counter
- Clock Generated with Single Resistor, Inductor, or Crystal

\author{

- Easily Expandable I/O
}

The Inte ${ }^{\circledR} 8022$ is the newest member of the MCS-48 ${ }^{\text {TM }}$ family of single chip 8-bit microcomputers. It is designed to satisfy the requirements of low cost, high volume applications which involve analog signals, capacitive touchpanel keyboards, and/or large ROM space. The 8022 addresses these applications by integrating many new functions onchip, such as A/D conversion, comparator inputs and zero-cross detection.
The features of the 8022 include 2 K bytes of program memory (ROM), 64 bytes of data memory (RAM), 28 I/O lines, an on-chip 8-bit A/D converter with two input channels, an 8 -bit port with comparator inputs for interfacing to low voltage capacitive touchpanels or other non-TTL interfaces, external and timer interrupts, and zero-cross detection capability. In addition, it contains the 8 -bit interval timer/event counter, on-board oscillator and clock circuitry, single 5 V power supply requirement, and easily expandable I/O structure common to all members of the MCS-48 family.

The 8022 is designed to be an efficient controller as well as an arithmetic processor. It has bit handling capability plus facilities for both binary and BCD arithmetic. Efficient use of program memory results from using the MCS-48 instruction set which consists mostly of single byte instructions and has extensive conditional jump and direct table lookup capability. Program memory usage is further reduced via the 8022's hardware implementation of the A/D converter which simplifies interfacing to analog signals.


## PIN DESCRIPTION

| Designation | Pin \# | Function |
| :---: | :---: | :---: |
| $V_{\text {SS }}$ | 20 | Circuit GND potential. |
| $V_{\text {CC }}$ | 40 | +5 V circuit power supply. |
| PROG | 37 | Output strobe for Intel ${ }^{\text {© }} 8243$ //O expander. |
| $\begin{aligned} & \text { P00-P07 } \\ & \text { Port } 0 \end{aligned}$ | 10-17 | 8-bit open-drain port with comparator inputs. The switching threshold is set externally by $\mathrm{V}_{\mathrm{TH}}$. Optional pull-up resistors may be added via ROM mask selection. |
| $V_{\text {TH }}$ | 9 | Port 0 threshold reference pin. |
| P10-P17 <br> Port 1 | 25-32 | 8 -bit quasi-bidirectional port. |
| P20-P27 | 33-36 | 8-bit quasi-bidirectional port. |
| Port 2 | $\begin{gathered} 38-39 \\ 1-2 \end{gathered}$ | P20-23 also serve as a 4 -bit I/O expander for Intel ${ }^{\circledR} 8243$. |
| T0 | 8 | Interrupt input and input pin testable using the conditional transfer instructions JTO and JNTO. Initiates an interrupt following a low level input if interrupt is enabled. Interrupt is disabled after a reset. |
| T1 | 19 | Input pin testable using the JT1 and JNT1 conditional transfer instructions. Can be designated the timer/event counter input using the STRT CNT instruction. Also serves as the zero-cross detection input to allow zerocrossover sensing of slowly moving AC inputs. Optional pull-up resistor may be added via ROM mask selection. |


| Designation | Pin \# | Function |
| :---: | :---: | :---: |
| RESET | 24 | Input used to initialize the processor by clearing status flipifioms. and setting the program counter to zero. |
| $\mathrm{AV}_{\text {SS }}$ | 7 | A/D converter GND Potential. Also establishes the lower limit of the conversion range. |
| $\mathrm{AV}_{\text {cc }}$ | 3 | $A / D+5 V$ power supply. |
| SUBST | 21 | Substrate pin used with a bypass capacitor to stabilize the substrate voltage and improve A/D accuracy. |
| $V_{\text {AREF }}$ | 4 | A/D converter reference voltage. Establishes the upper limit of the conversion range. |
| AN0, AN1 | 6,5 | Analog inputs to A/D converter. Software selectable on-chip via SEL ANO and SEL AN1 instructions. |
| ALE | 18 | Address Latch Enable. Signal occurring once every 30 input clocks (once every cycle), used as an output clock. |
| XTAL 1 | 22 | One side of crystal, inductor, or resistor input for internal oscillator. Also input for external frequency source. (Not TTL compatible.) |
| XTAL 2 | 23 | Other side of timing control element. This pin is not connected when an external frequency source is used. |

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias
. . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature. $-65^{\circ} \mathrm{C}$ to $+180^{\circ} \mathrm{C}$
Voltage on Any Pin with
Respect to Ground. . . . . . . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation. $\qquad$
*COMMENT: Stresses above those listed under "Absolute Maximim Ratings" may cause permenent 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.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter |  | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $V_{\text {IL }}$ | Input Low Voltage (All except XTAL 1, XTAL 2, Port 0) | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {ILI }}$ | Input Low Voltage (Port 0) | -0.5 |  | $\mathrm{V}_{T H}-0.1$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (All except XTAL 1, XTAL 2, RESET, Port 0) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | $V_{C C}=5.0 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{V}_{\mathbf{I H 1}}$ | Input High Voltage (All except XTAL 1, XTAL 2, RESET, Port 0) | 2.4 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{C C}=6.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$ |
| $\overline{\mathrm{V}_{1 \mathrm{H} 2}}$ | Input High Voltage (Port 0) | $\mathrm{V}_{\mathrm{TH}}+0.1$ |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {H3 }}$ | Input High Voltage (RESET, XTAL 1) | 3.0 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\text {TH }}$ | Port 0 Threshold Reference Voltage | 0 |  | $\mathrm{V}_{\mathrm{CC}} / 2$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{IL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage (P10, P11) |  |  | 2.5 | V | $\mathrm{I}_{\mathrm{OL}}=7 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (All unless Open Drain Option-Port 0) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=50 \mu \mathrm{~A}$ |
| ILI | Input Leakage Current (T1) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current (Open Drain Option-Port 0) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{C C} \geqslant \mathrm{~V}_{1 N} \geqslant \mathrm{~V}_{S S}+0.45 \mathrm{~V}$ |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  | 100 | mA |  |
| $\mathrm{V}_{\mathrm{T} 1}$ | Zero-Cross Detection Input (T1) | 1 |  | 3 | VACpp | Input through a capacitor |

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{C Y}$ | Cycle Time | 8.38 | 50.0 | $\mu \mathrm{~s}$ | $3 \mathrm{MHz} \mathrm{XTAL}=10 \mu \mathrm{~s} \mathrm{t}_{\mathrm{CY}}$ |
| $\mathrm{t}_{\mathrm{LL}}$ | ALE Pulse Width | 4.6 | 23.0 | $\mu \mathrm{~s}$ | $\mathrm{t}_{\mathrm{CY}}=10 \mu \mathrm{~s}$ |
| $\Delta_{\mathrm{F}}$ | Oscillator Frequency Variation—Resistor Mode | -20 | +20 | $\%$ | $\mathrm{~F}=2.5 \mathrm{MHz}, \mathrm{R}=15 \mathrm{k} \Omega$ |
| $\mathrm{F}_{\mathrm{T} 1}$ | Zero-Cross Detection Input Frequency (T1) | 0.03 | 1 | kHz |  |

## A.C. TEST CONDITIONS

Control Outputs: $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$


PORT 2 TIMING


## AID CONVERTER CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{C C}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V}, A V_{C C}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, A V_{S S}=0 \mathrm{~V}$

| Parameter | Min. | Typ. | Max. | Unit | Comments. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Resolution | 8 |  |  | Bits |  |
| Non-Linearity |  | $\pm 1 / 2$ |  | LSB | (Note 1) |
| Zero Error |  | 0 |  | LSB | (Note 2) $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Full Scale Error |  | 0 |  | LSB | (Note 3) $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Absolute Accuracy |  | $\pm 1$ |  | \% | (Note 4) |
| Conversion Range | $\mathrm{AV}_{\text {SS }}$ |  | $\mathrm{V}_{\text {AREF }}$ | V |  |
| $V_{\text {AREF }}$ | $\mathrm{AV}_{\mathrm{Cd}}{ }^{12}$ |  | $\mathrm{AV}_{\mathrm{CC}}$ | V |  |
| Input Capacitance (AN0, AN1) |  | 1 |  | pF |  |
| Conversion Time | 4 |  | 4 | $\mathrm{t}_{\mathrm{Cr}}$ |  |
| Sample Hold Time ( $\mathrm{t}_{\text {AS }}$ ) |  | 0.07 |  | ${ }^{t_{C r}}$ | (Note 5) |
| Sample Hold Time ( $\mathrm{t}_{\mathrm{AH}}$ ) |  | 0.23 |  | $t_{C Y}$ | (Note 5) |
| Sample Setup Before Falling Edge of ALE ( $\mathrm{t}_{\text {SS }}$ ) |  | 0.20 |  | ${ }^{\text {c }} \mathrm{Cr}$ |  |
| Sample Hold After Falling Edge of ALE ( $\mathrm{tSH}^{\text {) }}$ |  | 0.10 |  | ${ }^{t}{ }_{C Y}$ |  |



NOTES:

1. Non-linearity error is the maximum deviation from a straight line through the end points of the $A / D$ transfer characteristics.
2. Zero error is the difference between the output of an ideal and the actual $A / D$ for zero input voltage.
3. Full-scale error is the difference between the output of an ideal and the actual A/D for full-scale input voltage.
4. Absolute accuracy describes the difference between the actual input voltage and the full-scale weighted equivalent of the binary output. Included are quantizing and all other errors.
5. The analog input must be maintained at a constant voltage during the sampling time ( $\left.{ }^{( } A S\right)$ and the sample hold time ( $t_{A H}$ ).

INSTRUCTION SET


|  | Mnemonic | Description $\therefore$ | Byte |  | Hexadecimal Opcode |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | JTO | Jump on T0 = 1 | 2 | 2 | , 36 \% |
|  | JNTO | Jump on $\mathrm{TO}=0$ | 2 | 2 | 26 \% why |
|  | JT1 addr | Jump on $\mathrm{T} 1=1$ | 2 | 2 | 56 |
|  | JNT1 addr | Jump on $\mathrm{T} 1=0$ | 2 | 2 | 46 |
|  | JTF addr | Jump on timer flag | 2 | 2 | 16 |
|  | CALLRET | Jump to subroutine | 1 | 2 | $\begin{aligned} & 14,34,54,74 \\ & 94, B 4, D 4, F 4 \\ & 83 \end{aligned}$ |
|  |  | Return | 1 | 2 |  |
| $\begin{aligned} & \text { a } \\ & \text { 囟 } \end{aligned}$ | CLR C | Clear carry Complement carry | 1 | 1k | 97 |
|  | CPL C |  | 1 | 1 | A7 |
| $\begin{aligned} & \mathscr{0} \\ & \stackrel{0}{0} \\ & \sum_{0}^{0} \\ & \underset{\sim}{\omega} \end{aligned}$ | MOV A, $\mathrm{R}_{\mathrm{r}}$ | Move register to A | 1 | 1 | F8.FF |
|  | MOV A, © R | Move data memory to $A$ | 1 | 1 | FO.F1 |
|  | MOV A, \#data | Move immediate to $A$ | 2 | 2 | 23 |
|  | MOV $R_{r}, A$ | Move A to register | 1 | 1 | A8.AF |
|  | MOV @ R,A | Move $A$ to data memory | 1 | 1 | A0.A1 |
|  | MOV $\mathrm{R}_{\mathrm{r}}$, \#data | Move immediate to register | 2 | 2 | B8-BF |
|  | MOV @ R,\#data | Move immediate to data memory | 2 | 2 | B0-B1 |
|  | $\mathrm{XCH} \mathrm{A}, \mathrm{R}_{\mathrm{r}}$ | Exchange $A$ and register | 1 | 1 | 28-2F |
|  | XCH A,@R | Exchange $A$ and data memory | 1 | 1 | 20-21 |
|  | XCHD A,@R | Exchange nibble of $A$ and register | 1 | 1 | 30-31 |
|  | MOVP A,@A | Move to A from current page | 1 | 2 | A3 |


|  | MOV A,T | Read timer/counter | 1 | 1 | 42 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MOV T,A | Load timer/counter | 1 | 1 | 62 |
|  | STRT T | Start timer | 1 | 1 | 55 |
|  | STRT CNT | Start counter | 1 | 1 | 45 |
|  | STOP TCNT | Stop timer/counter | 1 | 1 | 65 |


| $\pm$ RAD | Move conversion result <br> register to $A$ | 1 | 2 | 80 |
| :--- | :--- | :--- | :--- | :--- |
| Select analog input |  |  |  |  |
| zero |  |  |  |  |
| Select analog input one |  |  |  |  |

$\begin{array}{lllll}\text { EN I } & \begin{array}{c}\text { Enable external } \\ \text { interrupt }\end{array} & 1 & 1 & 05 \\ \text { Disable external } & 1 & 1 & 15 \\ \text { interrupt }\end{array} \quad$ DIS I $\left.\quad \begin{array}{c}\text { Enable timer/counter } \\ \text { interrupt }\end{array}\right)$

## SYMBOLS AND ABBREVIATIONS USED

|  |  | $P^{2}$ | Mnemonic for "in-page" Operation |
| :--- | :--- | :--- | :--- |
| A | Accumulator | $P_{p}$ | Port Designator $(P=1,2$ or 4-7) |
| addr | 11-Bit Program Memory Address | $R_{r}$ | Register Designator $(r=0-7)$ |
| AN0, AN1 | Analog Input 0, Analog Input 1 | $T$ | Timer |
| CNT | Event Counter | T0, T1 | Test 0, Test 1 |
| data | 8-Bit Number or Expression | $\#$ | Immediate Data Prefix |
| I | Interrupt | @ | Indirect Address Prefix |

## FUNCTIONAL DESCRIPTION

## PROGRAM MEMORY

The 8022 program memory consists of 2048 words 8 bits wide which are addressed by the program counter. The memory is ROM which is mask programmable at the factory. No external ROM expansion capability is provided. There are three locations in program memory of special importance.

Location 0: Activating the RESET line of the processor causes the first instruction to be fetched from location 0.
Location 3: Activating the interrupt input line of the processor (if interrupt is enabled) causes a jump to subroutine.
Location 7: A timer/event counter interrupt resulting from a timer/counter overflow causes a jump to subroutine (if timer/counter interrupt is enabled).

Therefore, the first instruction to be executed after initialization is stored in location 0 , the first word of an external interrupt service routine is stored in location 3, and the first word of a timer/event counter interrupt service routine is stored in location 7.

## PROGRAM MEMORY MAP

Program memory can be used to store constants as well as program instructions. The MOVP instruction allows easy table lookup for constants and display formatting.

## DATA MEMORY

On-chip data memory is organized as 64 words eight bits wide. All locations are indirectly addressable and eight designated locations are directly addressable. Also included in the data memory is the program counter stack, addressed by a 3-bit stack pointer.

The first eight locations (0-7) of the array are designated as working registers and are directly addressable by any of the 11 direct register instructions. These locations are readily accessible for a variety of operations with a minimum number of instruction bytes required for their manipulation. Thus, they are usually used to store frequently accessed intermediate results. The DJNZ in-
struction makes very efficient use of the working registers as program loop counters by allowing the programmer to decrement and test the register in a single instruction.

Registers 0 and 1 have yet another furiction in that they can be used to indirectly address all locations in the data memory using the indirect register instructions. These two RAM pointer registers are especially useful for repetitive type operations on adjacent memory locations. The indirect register instruction specifies which pointer register to use and the content of the pointer register is used to address a location in RAM. The contents of the addressed location are used during the execution of the instruction and may be modified. The pointer registers may also point to registers 0-7, if desired.

Locations 8-23 serve a dual role in that they contain the 8 -level program counter stack, two RAM locations per level. The program counter stack enables the processor to keep track of the return addresses generated by interrupts or CALL instructions by storing the contents of the program counter prior to servicing the subroutine. A 3-bit stack pointer determines which of the program counter stack's eight register pairs will be loaded with the next return address generated. The stack pointer, when initialized to 000 by RESET, points to RAM locations 8 and 9. The first subroutine jump or interrupt results in the program counter contents being transferred to locations 8 and 9 . The stack pointer is then incremented by one and points to locations 10 and 11 in anticipation of another CALL. The end of a subroutine, which is signaled by a return instruction (RET or RETI), causes the stack pointer to be decremented and the contents of the resulting register pair to be transferred to the program counter.
Since the program counter's addresses are 11 bits long, two bytes or registers must be used to store a single address. Thus, the 16 -byte program counter stack permits up to a total of 8 levels of subroutine nesting without overflowing the stack. If overflow does occur, the deepest address stored (locations 8 and 9) will be overwritten and lost since the stack pointer overflows from 111 to 000 . It also underflows from 000 to 111. If a particular application does not require 8 levels of nesting, tthe unused portion of the program counter stack may be used as any other indirectly addressable RAM location. For example, if only 3 levels of subroutine nesting are used, then only locations 8-13 need be reserved for the program counter stack, and locations 14-23 can be used for data storage.


DATA MEMORY MAP

## INPUT/OUTPUT

The 8022 has 26 lines which can be used for digital input or output functions. These lines are organized as 3 ports of 8 lines, each of which serve as either inputs, outputs, or bidirectional ports, and 2 test inputs which can alter program sequences when tested by conditional jump instructions.

Ports 1 and 2 have identical operating characteristics and are both quasi-bidirectional. That is, each line may serve as an input, an output, or both. Data written to these ports is statically latched and remains unchanged until rewritten. As inputs, these lines are non-latching;
i.e., inputs must be present until read by an input instruction. Inputs are fully TTL compatible and all outputs will drive at least one standard TTL load. Two fines of port 1 (P10 and P11) are designated as high current drive lines and have the ability to sink 7 mA . In addition, these pins may be paralleled for 14 mA output if the output logic states are always the same. The high current output lines eliminate the need for discrete transistors in many applications.

The lines of ports 1 and 2 are quasi-bidirectional because of their output structure which allows them to be used as inputs, outputs, or both, even though as outputs they are statically latched.


## QUASI-BIDIRECTIONAL PORT STRUCTURE

Each line is continuously pulled up to +5 V through a relatively high impedance device ( $\sim 50 \mathrm{k} \Omega$ ). This pullup is sufficient to provide the source current for a TTL high level, yet can be pulled low by a standard TTL gate, thus allowing the same pin to be used both as an input and output. When writing a " 0 " or low value to these ports, a low impedance device ( $\sim 300 \Omega$ ) overcomes the high pullup and provides TTL current sinking capability. When writing a " 1 ", a large current is momentarily supplied through a relatively low impedance device ( $\sim 5 k \Omega$ ) to allow a fast data transfer. After a short time (less than one instruction cycle) the low impedance device is shut off and the small pullup maintains the "1" level indefinitely. In this situation, an input device capable of overriding the small amount of sustaining current supplied by the pullup device can be read. (Alternatively, the data written en be read.) So, by writing a " 1 " to any particular pin that pin can serve either as a true high-level latched output pin, or as just a pullup resistor on an input. This allows maximum user flexibility in selecting his input or latched output lines, with a minimum of external components.

## PORT 0 COMPARATOR INPUTS

Port 0 has been modified from the standard quasibidirectional structure to allow an optional open drain configuration with comparator inputs. The low impedance pullup device has been eliminated and the high impedance pullup is optional. Thus, the user can choose via a mask programmable selection each line of port 0 to be either quasi-bidirectional with a high impedance or true open-drain. The open drain configuration allows the line to sink current through the low impedance pulldown device or to float in the high output state. More importantly, the open drain configuration makes port 0 very easy to drive when it is used as inputs. The input circuitry for each line of port 0 includes a voltage comparator which amplifies the voltage difference between the input port line and the port 0 threshold reference pin $\left(\mathrm{V}_{\mathrm{TH}}\right)$. The voltage gain of the comparator is sufficient to sense a 100 mV input differential within the range $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\mathrm{CC}} / 2$.


## PORT 0 I/O STRUCTURE

If $V_{T H}$ is allowed to float, it will bias itself to the digital switch point of the other ports, and port 0 behaves as a set of normal digital inputs. However, by biasing $\mathrm{V}_{\mathrm{TH}}$, the switch point can be both tightly controlled and adjusted. Common uses for this would include high noise margin inputs ( $\mathrm{V}_{\mathrm{CC}} / 2$ ), unusual logic level inputs as from a diode isolated keyboard, analog channel expansion, and direct capacitive touchpanel interface. The comparator action is automatic and the port is read just as any other port.

In addition to the 26 digital I/O lines contained on-board the 8022, a user can obtain additional I/O lines by utilizing the Intel ${ }^{\circledR} 8243$ I/O expander chip or standard TTL. The 8243 interfaces to 4 port lines of the 8022 (lower half of port 2) and is strobed by the PROG line of the 8022.


## I/O EXPANDER INTERFACE

The 8243 contains four 4-bit I/O ports which serve as extensions of the on-chip I/O and are addressed as ports $4-7$. The following operations may be performed on these ports:

1. Transfer Accumulator to Port
2. Transfer Port to Accumulator
3. And Accumulator to Port
4. Or Accumulator to Port

A 4-bit transfer from a port to the lower half of the accumulator sets the most significant four bits to zero. Each transfer consists of two 4-bit nibbles. The first contains the "opcodes" and port address, and the second contains the actual 4 bits of data. A high-to-low transition of the PROG line indicates that address is present while a low-to-high transition indicates the presence of data.

## TEST AND INTERRUPT INPUTS

In addition to the 24 general purpose I/O lines which comprise ports 0,1 , and 2 , the 8022 has two inputs which are testable via conditional jump instructions, T0 and T1. These pins allow inputs to cause program branches without the necessity to load an input port into the accumulator. T0 and T1 have other functions as well.

The Test 0 pin serves as an external interrupt input as well as a testable input. An interrupt sequence is initiated by applying a low " 0 " level input to the T0 pin when external interrupt is enabled. Interrupt is level triggered and active low to allow "WIRE ORING" of several interrupt sources at the input pin. When an interrupt is detected, it causes a "jump to subroutine" at location 3 in program memory as soon as all other cycles of the current instruction are complete. At this time, the program counter contents are saved in the program counter stack, but the remaining status of the processor is not. Unlike the 8048, the 8022 does not contain a program status word. Thus, when appropriate, the carry and auxiliary carry flags are saved in software, as the accumulator is. The routine shown below saves the accumulator and the carry flags in only four bytes.

| Instructions | Bytes | Comments |
| :--- | :---: | :--- |
| MOV R6,A | 1 | ;save accumulator |
| CLR A | 1 | ;clear accumulator |
| DA A | 1 | ;convert carry flags into sixes |
| MOV R7,A | 1 | ;save status of carry flags |

The end of an interrupt service subroutine is marked by the execution of a Return from Interrupt instruction (RETI). Prior to returning from the interrupt subroutine
however, the status of the accumulator and the carry flags are restored in software. The following routine restores the status of the accumulator and the carry flags, which was previously saved, in five bytes.

| Instructions | Bytes | Comments |
| :--- | :---: | :--- |
| MOV A,R7 | 1 | ;restore carry flags status to |
| Add A,\#OAAH | 2 | ;accumulator and set/clear carry flags |
| MOV A,R6 | 1 | ;restore accumulator |
| RETI | 1 | ;return |

The interrupt system is single level in that once an interrupt is detected, all further interrupt requests are ignored until execution of a RETI re-enables the interrupt input logic. This sequence holds true also for an internal interrupt generated by timer overflow. If an external interrupt and an internal timer/counter generated interrupt are detected at the same time, the external source will be recognized. If needed, a second external interrupt can be created by enabling the timer/counter interrupt, loading FFH in the counter (one less than terminal count) and enabling the event counter mode. A low-tohigh transition on the T1 input will then cause an interrupt vector to location 7.
The Test 1 pin, in addition to being a testable input, serves two other important functions. It can be used as an input pin to the external event counter, as previously mentioned, and it can be used to detect the zero crossing point of slow moving AC signals. Execution of the STRT CNT instruction puts the T1 pin in the counter input mode by connecting T 1 to the counter and enabling the counter. Subsequent low-to-high transitions on T1 will cause the counter to increment. Note that this operation differs from the rest of the MCS-48 devices, which increment the counter on high-to-low transitions. This change was made on the 8022 to take advantage of the accuracy of the rising edge detection on the zero cross circuitry. The maximum rate at which the counter may be incremented is once per three instruction cycles (every $30 \mu \mathrm{~s}$ when using a 3 MHz crystal) - there is no minimum frequency.

In addition to serving as a testable input and as the counter input, the T1 pin has special circuitry to detect when an AC signal crosses its average DC level. When driven directly, this pin responds as a normal digital input. To utilize the zero cross detection mode, an AC signal of approximately 1-3 VAC p-p magnitude and a maximum frequency of 1 kHz is coupled through an external capacitor $(1 \mu \mathrm{~F})$ to the T1 pin.


The internal digital state is sensed as a zero until the rising edge crosses the DC average level, when it becomes a one. This is accomplished by the self-biasing high gain amplifier which is included in the T1 input. This cir** cuit biases the T1 input exactly at its switching point, such that a small change will cause a digital transition to occur. This digital transition takes place within 5 degrees of the zero point. The digital value of T 1 remains a one until the falling edge of the AC input drops approximately 100 mV below the switching point of the rising edge ( 100 mV below the zero point, if the digital transition occurred exactly at the zero point). The 100 mV offset is created by hysteresis and eliminates chattering of the internal signal caused by the external noise.

The zero cross detection capability allows the user to make the 60 Hz power signal the basis for this system timing. All timing routines, including time-of-day, can be implemented using the zero cross detection capability of T1 and its conditional jump instructions. In addition, the zero cross detection feature can be used in conjunction with the timer interrupt to interrupt processing at the zero voltage point. This enables the user to control voltage phase sensitive devices such as triacs and SCRs, and to use the 8022 in applications such as shaft speed and angle measurement.

## ANALOG TO DIGITAL CONVERTER

The 8022 contains on-chip a complete hardware implementation of an 8 -bit analog to digital (A/D) converter with two multiplexed analog inputs. The A/D converter utilizes a successive approximation technique to provide an updated conversion once every four instruction cycles (i.e., once every $40 \mu \mathrm{~s}$ ) with a minimum of required software.
The A/D converter consists of four main parts, the input circuitry, a series string of resistors, a voltage comparator, and the successive approximation logic. The two analog inputs are multiplexed on-chip and selected via software by the SEL AN0 and SEL AN1 instructions. Besides selecting one of the analog inputs, these instructions restart the conversion sequence which operates continuously. Restarting a conversion sequence deletes the conversion in progress but does not effect the result of the previous conversion which is stored in the conversion result register. The continuous operation of the A/D converter saves program space and time by allowing the user obtain multiple readings from a given input with only one select instruction. To obtain a valid conversion reading, the user must provide the analog input signal no later than the beginning of the select instruction cycle. The analog input is then sampled by the A/D converter and maintained internally. This voltage becomes one input to the voltage comparator which amplifies the difference between the analog input and the voltage tap on the series resistor string.
The series resistor string is connected between the A/D reference pin ( $\mathrm{V}_{\text {AREF }}$ ) and ground ( $\mathrm{AV} \mathrm{VS}_{\mathrm{SS}}$ ). It is comprised of 256 identical resistors which divide the voltage between these two pins into 256 identical voltage steps. This configuration gives the converter its inherent monotonicity. The range of $\mathrm{V}_{\text {AREF }}$ in which full 8-bit resolution can be provided is between $\mathrm{V}_{\mathrm{CC}} / 2$ and $\mathrm{V}_{\mathrm{Cc}}$.

Thus, the user is given a minimum voltage range from ground to $\mathrm{V}_{\mathrm{CC}} / 2$ and a maximum range from ground to $\mathrm{V}_{\mathrm{CC}}$ over which 8-bit resolution is insured.
The voltage tap on the series resistor string is selected by the resistor ladder decoder. This decoder is driven by the 8 -bit successive approximation register (SAR). Each bit of the SAR is set in succession MSB to LSB and a voltage comparison between the selected resistor ladder voltage and the analog input voltage is performed after the setting of each bit. The result of each comparison determines whether the particular bit will remain set or be reset. All comparisons are performed automatically by the on-chip A/D hardware. At the end of 8 comparisons the SAR contains a valid digital result which is then latched into the conversion result register (CRR). The RAD instruction (read A/D) loads the conversion result from the CRR to the accumulator of the 8022.

As mentioned previously, the software and time required to perform an A/D conversion is optimized by the 8022's on-chip A/D converter configuration. Typical software for reading two sequential A/D conversions and storing them in data memory is shown below:

| First | SEL ANO | ;Starts conversion of AN0 input |
| :--- | :--- | :--- |
| Conversion | MOV R0,\#24 | ;Set up memory pointer |
| $50 \mu \mathrm{~s}$ | RAD | ;First conversion value to accumulator |
| 4 bytes |  |  |
| Second <br> Conversion | MOV @RO,A | ;Store first conversion value |
| $40 \mu \mathrm{~S}$ | RAD | ;Increment memory location |
| 3 bytes |  | ;Second conversion value to accumulator |

Note that the second conversion occurs without a second select instruction being used. Rather, the continuous operation of the A/D converter provides an updated digital value 4 instruction cycles after the first.

To insure maximum accuracy from the A/D converter, separate power supply pins ( $A V_{C C}$ and $A V_{S S}^{\prime}$ ) and a substrate pin (SUBST) have been provided. Supplying the power supply pins with a well filtered and regulated voltage supply minimizes the effect of power supply variance and system noise. The substrate pin should be bypassed to ground through a 500 pF to $0.001 \mu \mathrm{~F}$ capacitor.


AID CONVERTER BLOCK DIAGRAM



INDUCTOR


EXtERNAL

## OSCILLATOR AND CLOCK

The 8022 contains its own on-board oscillator and clock circuit, requiring only an external timing control element. This control element can be a crystal, inductor, resistor, or clock in. The capacitor normally required in resistor or inductor timing control operation is integrated onto the 8022. All internal time slots are derived from the external element, and all outputs are a function of the oscillator frequency. Pins X1 and X2 are used to input the particular control element. An instruction cycle consists of 10 states, and each state is a time slot of 3 oscillator periods. Therefore, to obtain a $10 \mu \mathrm{~s}$ instruction cycle, a 3 MHz crystal should be used.

## TIMER/COUNTER

An interval timer/counter is available to enable the user to keep track of time elapsed or number of events occurred during normal program execution and flow.
By a MOV T,A instruction, the contents of the accumulator are loaded to the timer. At the STRT T command an internal prescaler is zeroed and thereafter increments once each 30 input clocks (once each single cycle instruction, twice each double cycle instruction). The prescaler is a divide by 32. At the (11111) to (00000) transition the timer is incremented. The timer is 8 bits and an overflow (FFH) to $(00 \mathrm{H})$ timer flag is set along with the timer interrupt, if enabled. A conditional branch instruction (JTF) is available for testing this flag, the flag being reset each test. This instruction must also be used to initialize the timer overflow flag after a RESET instruction, as RESET does not perform this function. Total count capacity for the timer is $2^{8} \times 2^{5}=8192$ or 81.9 ms at a 10 $\mu \mathrm{s}$ cycle time. Contents of the timer are moved to the accumulator by the MOV A,T instruction without disturbing the counting process.
The timer may also be used as an event counter. After a STRT CNT command, the 8022 will respond to a low-tohigh transition on the Test 1 pin by incrementing the timer. Transitions can occur no faster than once each three instruction cycles.
The timer and event functions are exclusive. Counting or timing may be started or stopped (STOP TCNT) at will.

## CPU

The 8022 CPU has arithmetic and logical capabillty. A wide variety of arithmetic and logic instructions may be exercised, which affect the contents of the accumins lator, and/or direct or indirect scratchpad locations. Provisions have been made for simplified BCD arithmetic capability through the use of the DAA, SWAP A, and XCHD instructions. In addition, MOVP A,@A allows table lookup for display formatting and constants. Jump conditions such as zero, not zero refer to the accumulator contents at the time of the condition.

## RESET

The 8022 may be used in systems with poorly regulated and noisy power supplies. A useful feature is to sense when the power supply dips and quickly recovers, and do a reset to prevent continued operation with incorrect data. This feature may be implemented on the 8022 by connecting a diode between the RESET node and ground.
Including the diode in the reset circuitry forces a reset to occur if the power supply experiences a very sudden voltage glitch. Specifically, if the power supply drops approximately 1.5 V and recovers after at least a few nanoseconds, a reset will occur. Without the diode, a power supply interruption of less than 1 ms will not cause a power-on reset.


## POWER ON RESET

8048/8648/8748/8035

## SINGLE COMPONENT 8-BIT MICROCOMPUTER

- 8048 Mask Programmable ROM
- 8648 One-Time Factory Programmable EPROM
- 8748 User Programmable/Erasable EPROM
- 8035/8035L External ROM or EPROM

\author{

- 8-Bit CPU, ROM, RAM, I/O in Single Package
}


## - Interchangeable ROM and EPROM Versions

- Single 5V Supply
- $2.5 \mu \mathrm{sec}$ and $5.0 \mu \mathrm{sec}$ Cycle Versions All Instructions 1 or 2 Cycles.
- Over 90 Instructions: 70\% Single Byte

\author{

- $1 \mathrm{~K} \times 8 \mathrm{ROM} / E P R O M$ <br> $64 \times 8$ RAM <br> 27 I/O Lines <br> - Interval Timer/Event Counter <br> - Easily Expandable Memory and I/O <br> - Compatible with 8080/8085 Series Peripherals <br> - Single Level Interrupt
}


#### Abstract

The Intel® ${ }^{(8048 / 8648 / 8748 / 8035}$ is a totally self-sufficient, 8 -bit parallel computer fabricated on a single silicon chip using Intel's N -channel silicon gate MOS process. The 8048 contains a $1 \mathrm{~K} \times 8$ program memory, a $64 \times 8$ RAM data memory, 27 I/O lines, and an 8 -bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability, the 8048 can be expanded using standard memories and MCS- $80^{T M} / \mathrm{MCS}-85^{\mathrm{TM}}$ peripherals. The 8035 is the equivalent of an 8048 without program memory. The 8035L has the RAM power-down mode of the 8048 while the 8035 does not. The 8648 is a one-time programmable (at the factory) 8748 which can be ordered as the first 25 pieces of a new 8048 RAM order. The substitution of 8648 's for 8048 's allows for very fast turnaround for initial code verification and evaluation units. To reduce development problems to a minimum and provide maximum flexibility, three interchangeable pin-compatible versions of this single component microcomputer exist: the 8748 with user-programmable and erasable EPROM program memory for prototype and preproduction systems, the 8048 with factory-programmed mask ROM program memory for low cost, high volume production, and the 8035 without program memory for use with external program memories. This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The 8048 has extensive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from an instruction set consisting mostly of single byte instructions and no instructions over 2 bytes in length.


PIN CONFIGURATION

| то- | 1 |  | 40 | $\mathrm{v}_{\mathrm{cc}}$ |
| :---: | :---: | :---: | :---: | :---: |
| xtal 18 | 2 |  | 39 | $\square^{11}$ |
| xtal 2 | 3 |  | 38 | $\mathrm{D}^{\mathbf{P} 27}$ |
| RESET $\square$ | 4 |  | 37 | -P26 |
| $\overline{\text { ss }}$ | 5 |  | 36 | -P25 |
| INT | 6 |  | 35 | PP24 |
| EAC | 7 |  | 34 | $\mathrm{P}^{19}$ |
| $\overline{\text { RO }}$ | 8 |  | 33 | Pp16 |
| $\overline{\text { PSEN }}$ | 9 | $8648$ | 32 | P15 |
| WED | 10 | $8748$ | 31 | $\mathrm{P}^{\text {P14 }}$ |
| ale | 11 | $8035$ | 30 | $\mathrm{P}^{\text {P13 }}$ |
| $\mathrm{DB}_{0}$ | 12 |  | 29 | $\mathrm{P}^{\mathrm{P} 12}$ |
| D8, | 13 |  | 28 | $\mathrm{D}^{\text {P1 }} 1$ |
| $\mathrm{DB}_{2} \mathrm{C}$ | 14 |  | 27 | Pp10 |
| $\mathrm{DB}_{3}$ | 15 |  | 26 | $\mathrm{v}_{\text {D }}$ |
| $\mathrm{OB}_{4}$ | 16 |  | 25 | $\square \mathrm{Prog}$ |
| $\mathrm{DB}_{5}$ - | 17 |  | 24 | $\mathrm{P}^{\text {P23 }}$ |
| $\mathrm{DB}_{6} \mathrm{C}$ | 18 |  | 23 | $\mathrm{P}^{\mathrm{P} 22}$ |
| $\mathrm{DB}_{7}$ | 19 |  | 22 | $\mathrm{P}^{121}$ |
| $\mathrm{v}_{5 s}$ - | 20 |  | 21 | $\mathrm{D}^{\mathrm{P} 20}$ |

LOGIC SYMBOL


BLOCK DIAGRAM


64 WORDS DATA MEMORY


## PIN DESCRIPTION

| Designation | Pin \# | Function | Designation | Pin \# | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {SS }}$ | 20 | Circuit GND potential | $\overline{\mathrm{RD}}$ | 8 | Output strobe activated during a |
| $V_{\text {DD }}$ | 26 | Programming power supply; +25V during program, +5 V during operation for both ROM and PROM. Low power standby pin in 8048 and 8035L. |  |  | BUS read. Can be used to enable data onto the bus from an external device. <br> Used as a read strobe to external data memory. (Active low) |
| $\mathrm{V}_{\mathrm{cc}}$ | 40 | Main power supply; +5 V during operation and programming. | $\overline{\text { RESET }}$ | 4 | Input which is used to initialize the processor. Also used during PROM programming verification, and power down. (Active low) (Non TTL $V_{1 H}$ ) |
| PROG | 25 | Program pulse ( +23 V ) input pin during 8748 programming. <br> Output strobe for 8243 I/O |  |  |  |
| P10-P17 | 27-34 | expander. 8 -bit quasi-bidirectional port. | $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) |
| Port 1 P20-P27 Per | 21-24 | 8-bit quasi-bidirectional port. |  |  | Used as write strobe to external data memory. |
| Port 2 | 35-38 | P20-P23 contain the four high order program counter bits during an external program memory fetch and serve as a 4 -bit I/O expander bus for 8243. | ALE | 11 | Address latch enable. This signal occurs once during each cycle and is useful as a clock output. <br> The negative edge of ALE strobes address into external data and program memory. |
| $\begin{aligned} & \mathrm{DB}_{0}-\mathrm{DB}_{7} \\ & \text { BUS } \end{aligned}$ | 12-19 | True bidirectional port which can be written or read synchronously using the $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ strobes. The port can also be statically latched. | PSEN | 9 | Program store enable. This output occurs only during a fetch to external program memory. (Active low) |
|  |  | Contains the 8 low order program counter bits during an external program memory fetch, and receives the addressed instruction under the control of $\overline{\text { SSEN }}$. Also contains the | SS | 5 | Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active low) |
|  |  | address and data during an external RAM data store instruction, under control of ALE, $\overline{R D}$, and $\overline{W R}$. | EA | 7 | External access input which forces all program memory fetches to reference external memory. Useful |
| T0 | 1 | Input pin testable using the conditional transfer instructions JTO and JNTO. TO can be designated as |  |  | for emulation and debug, and essential for testing and program verification. (Active high) |
|  |  | a clock output using ENTO CLK instruction. TO is also used during programming. | XTAL1 | 2 | One side of crystal input for internal oscillator. Also input for external source. (Non TTL $\mathrm{V}_{1 \mathrm{H}}$ ) |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. | XTAL2 | 3 | Other side of crystal input. |
| $\overline{\mathrm{INT}}$ | 6 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. Also testable with conditional jump instruction. (Active low) |  |  |  |

INSTRUCTION SET

|  | Mnemonic | Description | Bytes | Cycle |
| :---: | :---: | :---: | :---: | :---: |
|  | ADD A, R | Add register to A | 1 | 1 |
|  | ADD A, @R | Add data memory to $A$ | 1 | 1 |
|  | ADD A, =data | Add immediate to A | 2 | 2 |
|  | ADDC A, R | Add register with carry | 1 | 1 |
|  | ADDC A, @R | Add data memory with carry | 1 | 1 |
|  | ADDC A, \#data | Add immediate with carry | 2 | 2 |
|  | ANL A, R | And register to $A$ | 1 | 1 |
|  | ANL A, @R | And data memory to $A$ | 1 | 1 |
|  | ANL A, \#data | And immediate to $A$ | 2 | 2 |
|  | ORL A, R | Or register to A | 1 | 1 |
|  | ORL A, @R | Or data memory to $A$ | 1 | 1 |
|  | ORL A, \#data | Or immediate to $A$ | 2 | 2 |
|  | XRL A, R | Exclusive or register to $A$ | 1 | 1 |
|  | XRL A, @R | Exclusive or data memory to $A$ | 1 | 1 |
|  | XRL A, \#data | Exclusive or immediate to $A$ | 2 | 2 |
|  | INC A | Increment A | 1 |  |
|  | DEC A | Decrement $A$ | 1 | , |
|  | CLR A | Clear A | 1 | 1 |
|  | CPLA | Complement $A$ | 1 | 1 |
|  | DA A | Decimal adjust $A$ | 1 | 1 |
|  | SWAP A | Swap nibbles of $A$ | 1 | 1 |
|  | RLA | Rotate A left | 1 | 1 |
|  | RLC A | Rotate A left through carry | 1 | 1 |
|  | RR A | Rotate A right | 1 | 1 |
|  | RRC A | Rotate A right through carry | 1 | 1 |
|  | IN A, P | Input port to $A$ | 1 | 2 |
|  | OUTLP, A | Output A to port | 1 | 2 |
|  | ANL P, \#data | And immediate to port | 2 | 2 |
|  | ORL P, \#data | Or immediate to port | 2 | 2 |
|  | INS A, BUS | Input BUS to A | 1 | 2 |
|  | OUTL BUS, $A$ | Output A to BUS | 1 | 2 |
|  | ANL BUS, \#data | And immediate to BUS | 2 | 2 |
|  | ORL BUS, \#data | Or immediate to BUS | 2 | 2 |
|  | MOVD A, P | Input expander port to $A$ | 1 | 2 |
|  | MOVD P, A | Output A to expander port | 1 | 2 |
|  | ANLD P, A | And A to expander port | 1 | 2 |
|  | ORLD P, A | Or A to expander port | 1 | 2 |
|  | INC R | Increment register | 1 | 1 |
|  | INC @R | Increment data memory | 1 | 1 |
|  | DECR | Decrement register | 1 | 1 |
|  | JMP addr | Jump unconditional | 2 | 2 |
|  | JMPP @A | Jump indirect | 1 | 2 |
|  | DJNZ R, addr | Decrement register and skip | 2 | 2 |
|  | JC addr | Jump on carry $=1$ | 2 | 2 |
|  | JNC addr | Jump on carry $=0$ | 2 | 2 |
|  | $J \mathbf{Z}$ addr | Jump on A zero | 2 | 2 |
|  | JNZ addr | Jump on A not zero | 2 | 2 |
|  | JTO addr | Jump on T0 = 1 | 2 | 2 |
|  | JNTO addr | Jump on T0 $=0$ | 2 | 2 |
|  | JT1 addr | Jump on T1 = 1 | 2 | 2 |
|  | JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
|  | JFO addr | Jump on F0 $=1$ | 2 | 2 |
|  | JF 1 addr | Jump on F1 = 1 | 2 | 2 |
|  | JTF addr | Jump on timer flag | 2 | 2 |
|  | JNI addr | Jump on $\overline{\mathrm{INT}}=0$ | 2 | 2 |
|  | JBb addr | Jump on accumulator bit | 2 | 2 |


|  | Mnemonic | Description | Bytes | Cycles |
| :---: | :---: | :---: | :---: | :---: |
|  | CALL addr | Jump to subroutine | 2 | 2 |
|  | RET | Return | 1 | 2 |
|  | RETR | Return and restore status | 1 | 2 |
| $\begin{aligned} & \text { 号 } \\ & \text { 萑 } \end{aligned}$ | CLR C | Clear carry | 1 | 1 |
|  | CPL C | Complement carry | 1 | 1 |
|  | CLR F0 | Clear flag 0 | 1 | 1 |
|  | CPL FO | Complement flag 0 | 1 | 1 |
|  | CLR F1 | Clear flag 1 | 1 | 1 |
|  | CPL F1 | Complement flag 1 | 1 | 1 |
| $\begin{aligned} & \text { W } \\ & \sum_{0}^{0} \\ & \sum_{0}^{0} \\ & \mathbb{N} \end{aligned}$ | MOV A, R | Move register to A | 1 | 1 |
|  | MOV A, @R | Move data memory to $A$ | 1 | 1 |
|  | MOV A, \#data | Move immediate to $A$ | 2 | 2 |
|  | MOV R, A | Move A to register | 1 | 1 |
|  | MOV @R, A | Move A to data memory | 1 | 1 |
|  | MOV R, \#data | Move immediate to register | 2 | 2 |
|  | MOV @R, \#data | Move immediate to data memory | 2 | 2 |
|  | MOV A, PSW | Move PSW to A | 1 | 1 |
|  | MOV PSW, A | Move A to PSW | 1 | 1 |
|  | XCH A, R | Exchange $A$ and register | 1 | 1 |
|  | XCHA, @R | Exchange $A$ and data memory | 1 | 1 |
|  | XCHD A, @R | Exchange nibble of $A$ and register | r 1 | 1 |
|  | MOVX A, @R | Move external data memory to $A$ | 1 | 2 |
|  | MOVX @R, A | Move A to external data memory | 1 | 2 |
|  | MOVP A, @A | Move to A from current page | 1 | 2 |
|  | MOVP3 A, @A | Move to A from page 3 | 1 | 2 |
|  | MOV A, T | Read timer/counter | 1 | 1. |
|  | MOV T, A | Load timer/counter | 1 | 1 |
|  | STRT T | Start timer | 1 | 1 |
|  | STRT CNT | Start counter | 1 | 1 |
|  | STOP TCNT | Stop timer/counter | 1 | 1 |
|  | EN TCNTI | Enable timer/counter interrupt | 1 | 1 |
|  | DIS TCNTI | Disable timer/counter interrupt | 1 | 1 |
| $\overline{0}$000 | EN I | Enable external interrupt | 1 | 1 |
|  | DIS I | Disable external interrupt | 1 | 1 |
|  | SEL RBO | Select register bank 0 | 1 | 1 |
|  | SEL RB1 | Select register bank 1 | 1 | 1 |
|  | SEL MBO | Select memory bank 0 | 1 | 1 |
|  | SEL MB1 | Select memory bank 1 | 1 | 1 |
|  | ENTO CLK | Enable clock output on TO | 1 | 1 |
|  | NOP | No operation | 1 | 1 |

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots .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.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 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.AND OPERATING CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $V_{\text {IL }}$ | Input Low Voltage <br> (All Except $\overline{\mathrm{RESET}}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 8 | V |  |
| $V_{\text {IL1 }}$ | Input Low Voltage (RESET, X1, X2) | $-.5$ |  | . 6 | V |  |
| $V_{\text {IH }}$ | Input High Voltage <br> (All Except XTAL1, XTAL 2, $\overline{\text { RESET }}$ ) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage (X1, X2, $\overline{\text { RESET }}$ ) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage (BUS) |  |  | . 45 | V | $\mathrm{V}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage <br> ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=1.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage (PROG) |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL3 }}$ | Output Low Voltage <br> (All Other Outputs) |  |  | . 45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-40 \mu \mathrm{~A}$ |
| $I_{L I}$ | Input Leakage Current (T1, $\overline{\mathrm{NT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\text {LI1 }}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{\text { SS }}$ ) |  |  | - 500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current (BUS, TO) <br> (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leqslant \mathrm{~V}_{1 N} \leqslant \mathrm{~V}_{\mathrm{CC}}$ |
| $I_{\text {DD }}$ | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 5 | 15 | mA |  |
| $I_{D D}+I_{C C}$ | Total Supply Current |  | 60 | 135 | mA |  |

## BUS

P1, P2



BUS, P1, P2


## WAVEFORMS

## Instruction Fetch From External Program Memory



Write to External Data Memory


Read From External Data Memory


Input and Output Waveforms for A.C. Tests

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | 804886488748/8035/8035L |  | $\begin{aligned} & 8748-8^{*} \\ & 8035-8 \end{aligned}$ |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $t_{\text {LL }}$ | ALE Pulse Width | 400 |  | 600 |  | ns |  |
| $\mathrm{t}_{\text {AL }}$ | Address Setup to ALE | 120 |  | 150 |  | ns |  |
| ${ }_{t}$ LA | Address Hold from ALE | 80 |  | 80 |  | ns |  |
| ${ }^{\text {c }}$ c | Control Pulse Width ( $\overline{\text { PSEN }}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 700 |  | 1500 |  | ns |  |
| ${ }^{\text {t }}$ W | Data Setup before $\overline{W R}$ | 500 |  | 640 |  | ns |  |
| ${ }^{\text {tw }}$ | Data Hold After $\bar{W} \mathrm{R}$ | 120 |  | 120 |  | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ |
| ${ }^{t} \mathrm{CY}$ | Cycle Time | 2.5 | 15.0 | 4.17 | 15.0 | $\mu \mathrm{s}$ | $\begin{aligned} & 6 \mathrm{MHz} \mathrm{XTAL}=2.5 \\ & \text { (3.6 MHz XTAL for }-8 \text { ) } \end{aligned}$ |
| $\mathrm{t}_{\text {DR }}$ | Data Hold | 0 | 200 | 0 | 200 | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | $\overline{\text { PSEN }}, \overline{\mathrm{RD}}$ to Data In |  | 500 |  | 750 | ns |  |
| $\mathrm{t}_{\text {AW }}$ | Address Setup to $\overline{W R}$ | 230 |  | 260 |  | ns |  |
| ${ }_{\text {t }}^{\text {AD }}$ | Address Setup to Data In |  | 950 |  | 1450 | ns |  |
| ${ }^{\text {t }}$ AFC | Address Float to $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ | 0 |  | 0 |  | ns |  |
| ${ }^{\text {c }}$ CA | Control Pulse to ALE | 10 |  | 20 |  | ns |  |

[^5]
## A.C. CHARACTERISTICS (PORT 2 TIMING)

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{VCC}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| tcP | Port Control Setup Before Falling <br> Edge of PROG | 110 |  | ns |  |
| tPC | Port Control Hold After Falling <br> Edge of PROG | 100 |  | ns |  |
| tpR | PROG to Time P2 Input Must Be Valid |  | 810 | ns |  |
| tPF | Input Data Hold Time | 0 | 150 | ns |  |
| tDP | Output Data Setup Time | 250 |  | ns |  |
| tpD | Output Data Hold Time | 65 |  | ns |  |
| tpP | PROG Pulse Width | 1200 |  | ns |  |
| tPL | Port 2 I/O Data Setup | 350 |  | ns |  |
| tLP | Port 2 I/O Data Hold | 150 |  | ns |  |

PORT 2 TIMING


## CRYSTAL OSCILLATOR MODE



CRYSTAL SERIES RESISTANCE SHOULD BE $<75 \Omega$ AT $6 \mathrm{MHz} ;<180 \Omega$ AT $3.6 \mathbf{M H z}$.


BOTH X1 AND X2 SHOULD BE DRIVEN.
RESISTORS TO $\mathrm{V}_{\mathrm{CC}}$ ARE NEEDED TO ENSURE $\mathrm{V}_{I H}=3.8 \mathrm{~V}$ IF TTL CIRCUITRY IS USED. THE MINIMUM HIGH AND THE MINIMUM LOW TIMES ARE $45 \%$.

## LC OSCILLATOR MODE



$$
\begin{aligned}
& f=\frac{1}{2 \pi \sqrt{L C^{\prime}}} \\
& C^{\prime}=\frac{C+3 C_{P P}}{2}
\end{aligned}
$$

EACH C SHOULD BE APPROXIMATELY 20 pF, INCLUDING STRAY CAPACITANCE.

## PROGRAMMING, VERIFYING, AND ERASING THE 8748 EPROM

## Programming Verification

In brief, the programming process consists of: activating the program mode, applying an address, latching the address, applying data, and applying a programming pulse. Each word is programmed completely before moving on to the next and is followed by a verification step. The following is a list of the pins used for programming and a description of their functions:

| Pin | Function |
| :--- | :--- |
| XTAL 1 | Clock Input (1 to 6MHz) |
| $\overline{\text { Reset }}$ | Initialization and Address Latching |
| Test 0 | Selection of Program or Verify Mode |
| EA | Activation of Program/Verify Modes |
| BUS | Address and Data Input |
|  | Data Output During Verify |
| P20-1 | Address Input |
| VDD | Programming Power Supply |
| PROG | Program Pulse Input |

WARNING:
An attempt to program a missocketed 8748 will result in severe damage to the part. An indication of a properly socketed part is the appearance of the ALE clock output. The lack of this clock may be used to disable the programmer.

The Program/Verify sequence is:

1. $\quad V_{D D}=5 v$, Clock applied or internal oscillator operating, $\overline{\mathrm{RESET}}=0 \mathrm{v}$, TEST $0=5 \mathrm{v}, \mathrm{EA}=5 \mathrm{v}$, BUS and PROG floating.
2. Insert 8748 in programming socket
3. TEST $0=0 \mathrm{v}$ (select program mode)
4. $E A=23 V$ (activate program mode)
5. Address applied to BUS and P20-1
6. $\overline{\text { RESET }}=5 v$ (latch address)
7. Data applied to BUS
8. $V_{D D}=25 v$ (programming power)
9. $\mathrm{PROG}=0 \mathrm{v}$ followed by one 50 ms pulse to 23 V
10. $\quad V_{D D}=5 v$
11. TEST $0=5 v$ (verify mode)
12. Read and verify data on BUS
13. TEST $0=0 v$
14. $\overline{\operatorname{RESET}}=\mathrm{Ov}$ and repeat from step 5
15. Programmer should be at conditions of step 1 when 8748 is removed from socket.

## AC TIMING SPECIFICATION FOR PROGRAMMING

$T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{D D}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| taw | Address Setup Time to $\overline{\text { RESET }} 1$ | 4tcy |  |  |  |
| twa | Address Hold Time After $\overline{\text { RESET }}$ † | 4tcy |  |  |  |
| tow | Data in Setup Time to PROG 1 | 4tcy |  |  |  |
| two | Data in Hold Time After PROG ! | 4tcy |  |  |  |
| tPh | RESET Hold Time to Verify | 4tcy |  |  |  |
| tvodw | VDD | 4tcy |  |  |  |
| tVDD'H | Vod Hold Time After PROG ! | 0 |  |  |  |
| tpw | Program Pulse Width | 50 | 60 | mS |  |
| trw | Test 0 Setup Time for Program Mode | 4tcy |  |  |  |
| twT | Test 0 Hold Time After Program Mode | 4tcy |  |  |  |
| too | Test 0 to Data Out Delay |  | 4tcy |  |  |
| tww | $\overline{\text { RESET }}$ Pulse Width to Latch Address | 4tcy |  |  |  |
| $\mathrm{tr}_{\mathrm{r}} \mathrm{tf}_{\mathrm{f}}$ | VDD and PROG Rise and Fall Times | 0.5 | 2.0 | $\mu \mathrm{S}$ |  |
| tcr | CPU Operation Cycle Time | 5.0 |  | $\mu \mathrm{S}$ |  |
| tre | $\overline{\text { RESET }}$ Setup Time Before EA $\dagger$. | 4tcy |  |  |  |

Note: If Test 0 is high too can be triggered by $\overline{\operatorname{RESET}}$ t.

## DC SPECIFICATION FOR PROGRAMMING

$T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VDOH | VDD Program Voltage High Level | 24.0 | 26.0 | V |  |
| VDDL | VDD Voltage Low Level | 4.75 | 5.25 | V |  |
| VPH | PROG Program Voltage High Level | 21.5 | 24.5 | V |  |
| $V_{P L}$ | PROG Voltage Low Level |  | 0.2 | V |  |
| Veah | EA Program or Verify Voltage High Level | 21.5 | 24.5 | V | 8748 |
| $\mathrm{V}_{\text {EAH1 }}$ | EA1 Verify Voltage High Level | 11.4 | 12.6 | V | 8048 |
| VEAL | EA Voltage Low Level |  | 5.25 | V |  |
| IDD | VDD High Voltage Supply Current |  | 30.0 | mA |  |
| Iprog | PROG High Voltage Supply Current |  | 16.0 | mA |  |
| IEA | EA High Voltage Supply Current |  | 1.0 | mA |  |

## WAVEFORMS FOR PROGRAMMING

## COMBINATION PROGRAM/VERIFY MODE (EPROM'S ONLY)



VERIFY MODE (ROM/EPROM)

TO, $\overline{\mathrm{RESET}}$

$\mathrm{DB}_{0}-\mathrm{DB}_{7}$


NOTES:

1. PROG MUST FLOAT IF EA IS LOW (i.e., $\neq 23 \mathrm{~V}$ ), OR IF TO $=5 \mathrm{~V}$ FOR THE 8748. FOR THE 8048 PROG MUST ALWAYS FLOAT
2. $X_{1}$ AND $X_{2}$ DRIVEN BY 3 MHz CLOCK WILL GIVE $5 \mu \mathrm{sec}$ tCY. THIS IS ACCEPTABLE FOR -8 PARTS AS WELL AS STANDARD PARTS.

The 8748 EPROM can be programmed by either of two Intel products:

1. PROMPT-48 Microcomputer Design Aid, or
2. Universal PROM Programmer (UPP series) peripheral of the Intellec ${ }^{\text {® }}$ Development System with a UPP-848 Personality Card.

Note: See the ROM/PROM section for 8048 ROM ordering procedures. To minimize turnaround time on the first 25 pieces 8648 may be specified on the ROM order.

# NEW HIGH PERFORMANCE 8049/8039/8039-6 SINGLE COMPONENT 8-BIT MICROCOMPUTER 

# *8049 Mask Programmable ROM <br> *8039 External ROM or EPROM <br> *New 11 MHz Operation 

- 8-Bit CPU, ROM, RAM, I/O in Single Package
- Single 5V $\pm 10 \%$ Supply
- $1.36 \mu \mathrm{sec}$ Cycle; All Instructions 1 or 2 Cycles


## ■ Over 90 Instructions: 70\% Single Byte

■ Pin Compatible with 8048/8748

\author{

- 2K $\times 8$ ROM $128 \times 8$ RAM 27 I/O Lines <br> ■ Interval Timer/Event Counter <br> - Easily Expandable Memory and I/O <br> - Compatible with MCS Memory and I/O <br> ■ Single Level Interrupt
}

The Intel ${ }^{\circledR}$ 8049/8039/8039-6 is a totally self-sufficient 8 -bit parallel computer fabricated on a single silicon chip using Intel's N -channel silicon gate MOS process.
The 8049 contains a $2 \mathrm{~K} \times 8$ program memory, a $128 \times 8$ RAM data memory, 27 I/O lines, and an 8 -bit timer/counter in addition to on board oscillator and clock circuits. For systems that require extra capability, the 8049 can be expanded using standard memories and MCS- $80^{T M} / \mathrm{MCS}-85^{\mathrm{TM}}$ peripherals. The 8039 is the equivalent to an 8049 without program memory. The $8039-6$ is a lower speed $(6 \mathrm{MHz})$ version of the 8039.
To reduce development problems to a minimum and provide maximum flexibility, two interchangeable pin-compatible versions of this single component microcomputer exist: the 8049 with factory-programmed mask ROM program memory for low-cost high volume production, and the 8039 without program memory for use with external program memories in prototype and preproduction systems.
This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The 8049 has extensive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from an instruction set consisting mostly of single byte instructions and no instructions over two bytes in length.

PIN CONFIGURATION
LOGIC SYMBOL
BLOCK DIAGRAM


## PIN DESCRIPTION

| Designation | Pin \# | Function | Designation | Pin \# | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {SS }}$ | 20 | Circuit GND potential | $\overline{\overline{R D}}$ | 8 | Output strobe activated during a BUS read. Can be used to enable data onto the BUS from an external device. <br> Used as a Read Strobe to External Data Memory. (Active low) |
| $V_{\text {DD }}$ | 26 | +5 V during operation. Low power standby pin. |  |  |  |
| $\mathrm{V}_{\mathrm{Cc}}$ | 40 | Main power supply; +5 V during operation. |  |  |  |
| PROG | 25 | Output strobe for 8243 I/O expander. | RESET | 4 | Input which is used to initialize the processor. Also used during verification, and power down. (Active low) (Non TTL $V_{I H}$ ) |
| P10-P17 <br> Port 1 <br> P20-P27 <br> Port 2 | 27-34 | 8 -bit quasi-bidirectional port. |  |  |  |
|  | $\begin{aligned} & 21-24 \\ & 35-38 \end{aligned}$ | P20-P23 contain the four high order program counter bits during an external program memory fetch and serve as a 4-bit I/O expander bus for 8243 | $\overline{W R}$ | 10 | Output strobe during a BUS write. (Active low) |
|  |  |  |  |  | Used as write strobe to External Data Memory. <br> Address Latch Enable. This signal |
| $\begin{aligned} & \text { DO-D7 } \\ & \text { BUS } \end{aligned}$ | 12-19 | True bidirectional port which can be written or read synchronously using the $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ strobes. The port can also be statically latched. | ALE | 11 | Address Latch Enable. This signal occurs once during each cycle and is useful as a clock output. |
|  |  | Contains the 8 low order program counter bits during an external program memory fetch, and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM data store instruction, under control of ALE, $\overline{R D}$, and $\overline{W R}$. | $\overline{\text { PSEN }}$ | 9 | Program Store Enable. This output occurs only during a fetch to external program memory. (Active low) |
|  |  |  | SS | 5 | Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active low) |
| T0 | 1 | Input pin testable using the conditional transfer instructions JTO and JNTO. TO can be designated as a clock output using ENTO CLK instruction. | EA | 7 | External Access input which forces all program memory fetches to reference external memory. Useful for emulation and debug, and |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be des- |  |  | essential for testing and program verification. (Active high) |
|  |  | ignated the timer/counter input using the STRT CNT instruction. | XTAL1 | 2 | One side of crystal input for internal oscillator. Also input for external source. (Not TTL Compatible) |
| $\overline{\text { INT }}$ | 6 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. Also testable with conditional jump instruction. (Active low) | XTAL2 | 3 | Other side of crystal input. |

## INSTRUCTION SET

|  | Mnemonic | Description | Bytes | Cycle |
| :---: | :---: | :---: | :---: | :---: |
|  | ADD A, R | Add register to A | 1 | 1 |
|  | ADD A, @R | Add data memory to $A$ | 1 | 1 |
|  | ADD A, \#data | Add immediate to $A$ | 2 | 2 |
|  | ADDC A, R | Add register with carry | 1 | 1 |
|  | ADDC A, @R | Add data memory with carry | 1 | 1 |
|  | ADDC A, \#data | Add immediate with carry | 2 | 2 |
|  | ANL A, R | And register to $A$ | 1 | 1 |
|  | ANL A, @R | And data memory to $A$ | 1 | 1 |
|  | ANL A, \#data | And immediate to $A$ | 2 | 2 |
|  | ORL A, R | Or register to $A$ | 1 | 1 |
|  | ORL A, @R | Or data memory to $A$ | 1 | 1 |
|  | ORL A, \#data | Or immediate to $A$ | 2 | 2 |
|  | XRL A, R | Exclusive Or register to $A$ | 1 | 1 |
|  | XRLA, @R | Exclusive or data memory to $A$ | 1 | 1 |
|  | XRL $A, \#$ data | Exclusive or immediate to $A$ | 2 | 2 |
|  | INC A | Increment A | 1 | 1 |
|  | DEC A | Decrement $A$ | 1 | 1 |
|  | CLR A | Clear A | 1 | 1 |
|  | CPLA | Complement $A$ | 1 | 1 |
|  | DA A | Decimal Adjust A | 1 | 1 |
|  | SWAP A | Swap ribbles of $A$ | 1 | 1 |
|  | RLA | Rotate A left | 1 | 1 |
|  | RLC A | Rotate A left through carry | 1 | 1 |
|  | RR A | Rotate A right | 1 | 1 |
|  | RRC A | Rotate A right through carry | 1 | 1 |
|  | IN A, P | Input port to $A$ | 1 | 2 |
|  | OUTLP, A | Output A to port | 1 | 2 |
|  | ANL P, \#data | And immediate to port | 2 | 2 |
|  | ORL P, \#data | Or immediate to port | 2 | 2 |
|  | INS A, BUS | Input BUS to A | 1 | 2 |
|  | OUTL BUS, A | Output A to BUS | 1 | 2 |
|  | ANL BUS, \#data | And immediate to BUS | 2 | 2 |
|  | ORL BUS, \#data | Or immediate to BUS | 2 | 2 |
|  | MOVD A, P | Input Expander port to A | 1 | 2 |
|  | MOVD P, A | Output A to Expander port | 1 | 2 |
|  | ANLD P, A | And $A$ to Expander port | 1 | 2 |
|  | ORLD P, A | Or A to Expander port | 1 | 2 |
|  | INC R | Increment register | 1 | 1 |
|  | INC @R | Increment data memory | 1 | 1 |
|  | DEC R | Decrement register | 1 | 1 |
| 毕 | JMP addr | Jump unconditional | 2 | 2 |
|  | JMPP @A | Jump indirect | 1 | 2 |
|  | DJNZ R, addr | Decrement register and skip | 2 | 2 |
|  | JC addr | Jump on Carry = 1 | 2 | 2 |
|  | JNC addr | Jump on Carry $=0$ | 2 | 2 |
|  | $J \mathrm{Z}$ addr | Jump on A Zero | 2 | 2 |
|  | JNZ addr | Jump on A not Zero | 2 | 2 |
|  | JTO addr | Jump on T0 $=1$ | 2 | 2 |
|  | JNTO addr | Jump on T0 $=0$ | 2 | 2 |
|  | JT1 addr | Jump on T1 = 1 | 2 | 2 |
|  | JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
|  | JFO addr | Jump on $\mathrm{FO}=1$ | 2 | 2 |
|  | JF1 addr | Jump on F1 = 1 | 2 | 2 |
|  | JTF addr | Jump on timer flag | 2 | 2 |
|  | JNI addr | Jump on $\overline{\text { INT }}=0$ | 2 | 2 |
|  | JBb addr | Jump on Accumulator Bit | 2 | 2 |


|  | Mnemonic | Description A | Bytes | Cycles |
| :---: | :---: | :---: | :---: | :---: |
|  | CALL | Jump to subroutine | 2 | 2 |
|  | RET | Return | 1 | 2 |
|  | RETR | Return and restore status | 1 | 2 |
|  | CLR C | Clear Carry | 1 | 1 |
|  | CPL C | Complement Carry | 1 | 1 |
|  | CLR FO | Clear Flag 0 | 1 | 1 |
|  | CPL FO | Complement Flag 0 | 1 | 1 |
|  | CLR F1 | Clear Flag 1 | 1 | 1 |
|  | CPL F1 | Complement Flag 1 | 1 | 1 |
| $\begin{aligned} & \mathscr{O} \\ & \sum_{0}^{0} \\ & \sum_{0}^{0} \\ & 0 \\ & 0 \end{aligned}$ | MOV A, R | Move register to A | 1 | 1 |
|  | MOV A, @R | Move data memory to $A$ | 1 | 1 |
|  | MOV A, \#data | Move immediate to $A$ | 2 | 2 |
|  | MOV R, A | Move A to register | 1 | 1 |
|  | MOV @R, A | Move A to data memory | 1 | 1 |
|  | MOV R, \#data | Move immediate to register | 2 | 2 |
|  | MOV @R, \#data | Move immediate to data memory | 2 | 2 |
|  | Move A, PSW | Move PSW to A | 1 | 1 |
|  | MOV PSW, A | Move A to PSW | 1 | 1 |
|  | XCH A, R | Exchange $A$ and register | 1 | 1 |
|  | XCHA, @R | Exchange $A$ and data memory | 1 | 1 |
|  | XCHD A, @R | Exchange nibble of $A$ and register | r 1 | 1 |
|  | MOVX A, @R | Move external data memory to $A$ | 1 | 2 |
|  | MOVX @R, A | Move A to external data memory | 1 | 2 |
|  | MOVP A, @A | Move to $A$ from current page | 1 | 2 |
|  | MOVP3 A, @A | Move to $A$ from Page 3 | 1 | 2 |
|  | MOV A, T | Read Timer/Counter | 1 | 1 |
|  | MOV T, A | Load Timer/Counter | 1 | 1 |
|  | STRT T | Start Timer | 1 | 1 |
|  | STRT CNT | Start Counter | 1 | 1 |
|  | STOP TCNT | Stop Timer/Counter | 1 | 1 |
|  | EN TCNTI | Enable Timer/Counter Interrupt | 1 | 1 |
|  | DIS TCNTI | Disable Timer/Counter Interrupt | 1 | 1 |
| $\begin{aligned} & \bar{O} \\ & \stackrel{\rightharpoonup}{0} \\ & 0 \end{aligned}$ | ENI | Enable external interrupt | 1 | 1 |
|  | DIS I | Disable external interrupt | 1 | 1 |
|  | SEL RB0 | Select register bank 0 | 1 | 1 |
|  | SEL RB1 | Select register bank 1 | 1 | 1 |
|  | SEL MBO | Select memory bank 0 | 1 | 1 |
|  | SEL MB1 | Select memory bank 1 | 1 | 1 |
|  | ENTO CLK | Enable Clock output on TO | 1 | 1 |
|  | NOP | No Operatior | 1 | 1 |


| ¢ |
| :--- |
|  |
|  |

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\qquad$ $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
*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}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{\mathrm{RESET}}$ ) | 2.0 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\text {IH1 }}$ | Input High Voltage ( $\overline{\mathrm{RESET}}$, $\mathrm{X} 1, \mathrm{X} 2$ ) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage (BUS, $\overline{R D}, \overline{W R}, \overline{P S E N}, A L E)$ |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage <br> (All Other Outputs Except PROG) |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage (PROG) |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS, $\overline{R D}, \overline{W R}, \overline{P S E N}, ~ A L E)$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | $\mathrm{IOH}^{\text {O }}=-50 \mu \mathrm{~A}$ |
| $I_{\text {IL }}$ | Input Leakage Current (T1, INT) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| IOL | Output Leakage Current (Bus, T0) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| IDD | Power Down Supply Current |  | 25 | 50 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{I}_{\mathrm{DD}} \mathrm{I}_{\mathrm{CC}}$ | Total Supply Current |  | 100 | 170 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | $\begin{gathered} 8049 / 8039 \\ \text { (Note 1) } \\ \hline \end{gathered}$ |  | 8039-6 |  | Unit | Conditions (Note 2) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $t_{L L}$ | ALE Pulse Width | 150 |  | 400 |  | ns |  |
| $t_{\text {AL }}$ | Address Setup to ALE | 70 |  | 150 |  | ns |  |
| $t_{\text {LA }}$ | Address Hold from ALE | 50 |  | 80 |  | ns |  |
| $t_{C C}$ | Control Pulse Width (PSEN, RD, WR) | 300 |  | 700 |  | ns |  |
| $t_{\text {DW }}$ | Data Set-Up Before WR | 250 |  | 500 |  | ns |  |
| $t_{\text {WD }}$ | Data Hold After WR | 40 |  | 120 |  | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ |
| ${ }^{t_{C Y}}$ | Cycle Time | 1.36 | 15.0 | 2.5 | 15.0 | $\mu \mathrm{s}$ | $\begin{aligned} & 11 \mathrm{MHz} \mathrm{XTAL} \\ & (6 \mathrm{MHz} \mathrm{XTAL} \text { for }-6) \end{aligned}$ |
| $t_{\text {DR }}$ | Data Hold | 0 | 100 | 0 | 200 | ns |  |
| $\mathrm{t}_{\text {RD }}$ | PSEN, RD to Data In |  | 200 |  | 500 | ns |  |
| $t_{\text {AW }}$ | Address Setup to WR | 200 |  | 230 |  | ns |  |
| $t_{A D}$ | Address Setup to Data In |  | 400 |  | 950 | ns |  |
| $t_{\text {AFC }}$ | Address Float to RD, PSEN | $-10$ |  | 0 |  | ns |  |

Notes: 1. $8039-6$ specifications are also valid for $8049 / 8039$ operating at 6 MHz .
2. Control Outputs: $C_{L}=80 \mathrm{pF}$ BUS Outputs: $\quad C_{L}=150 \mathrm{pF}$

INSTRUCTION FETCH FROM EXTERNAL PROGRAM MEMORY


READ FROM EXTERNAL DATA MEMORY


WRITE TO EXTERNAL DATA MEMORY


## 8243 <br> MCS-48™ ${ }^{\text {T }}$ INPUT/OUTPUT EXPANDER

Low Cost<br>- Simple Interface to MCS-48™ Microcomputers<br>- Four 4-Bit I/O Ports<br>AND and OR Directly to Ports

24-Pin DIP

- Single 5V Supply
- High Output Drive
■ Direct Extension of Resident 8048 I/O Ports

The Intelब 8243 is an input/output expander designed specifically to provide a low cost means of I/O expansion for the MES-48 ${ }^{\text {™ }}$ family of single chip microcomputers. Fabricated in 5 volts NMOS, the 8243 combines low cost, single supply voltage and high drive current capability.
The 8243 consists of four 4-bit bidirectional static I/O ports and one 4-bit port which serves as an interface to the MCS-48 microcomputers. The 4-bit interface requires that only 4 I/O lines of the 8048 be used for I/O expansion, and also allows multiple 8243's to be added to the same bus.

The I/O ports of the 8243 serve as a direct extension of the resident I/O facilities of the MCS-48 microcomputers and are accessed by their own MOV, ANL, and ORL instructions.

PIN CONFIGURATION


BLOCK DIAGRAM


## PIN DESCRIPTION

| Symbol | Pin No. | Function |
| :--- | :---: | :--- |
| PROG | 7 | Clock Input. A high to low <br> transistion on PROG signifies <br> that address and control are <br> available on P20-P23, and a low <br> to high transition signifies that <br> data is available on P20-23. |
| CS | 6 | Chip Select Input. A high on CS <br> inhibits any change of output or <br> internal status. |
| P20-P23 | $11-8$ | Four (4) bit bi-directional port <br> contains the address and con- <br> trol bits on a high to low |
| transition of PROG. During a |  |  |
| low to high transition contains |  |  |
| the data for a selected output |  |  |
| port if a write operation, or the |  |  |
| data from a selected port before |  |  |
| the low to high transition if a |  |  |
| read operation. |  |  |

## FUNCTIONAL DESCRIPTION <br> General Operation

The 8243 contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports 47. The following operations may be performed on these ports:

- Transfer Accumulator to Port.
- Transfer Port to Accumulator.
- AND Accumulator to Port.
- OR Accumulator to Port.

All communication between the 8048 and the 8243 occurs over Port 2 (P20-P23) with timing provided by an output pulse on the PROG pin of the processor. Each transfer consists of two 4-bit nibbles:

The first containing the "op code" and port address and the second containing the actual 4 -bits of data.

A high to low transition of the PROG line indicates that address is present while a low to high transition indicates the presence of data. Additional 8243's may be added to the 4 -bit bus and chip selected using additional output lines from the 8048/8748/8035.

## Power On Initialization

Initial application of power to the device forces input/output ports $4,5,6$, and 7 to the tri-state and port 2 to the input mode. The PROG pin may be either high or low when power is applied. The first high to low transition of PROG causes device to exit power on mode. The power on sequence is initiated if $\mathrm{V}_{\mathrm{CC}}$ drops below 1 V .

| P21 | P20 | Address Code | P23 | P22 Instruction Code |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Port 4 | 0 | 0 | Read |
| 0 | 1 | Port 5 | 0 | 1 | Write |
| 1 | 0 | Port 6 | 1 | 0 | ORLD |
| 1 | 1 | Port 7 | 1 | 1 | ANLD |

## Write Modes

The device has three write modes. MOVD Pi, A directly writes new data into the selected port and old data is lost. ORLD Pi,A takes new data, OR's it with the old data and then writes it to the port. ANLD Pi,A takes new data AND's it with the old data and then writes it to the port. Operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. On the low to high transition of PROG data on port 2 is transferred to the logic block of the specified output port.
After the logic manipulation is performed, the data is latched and outputed. The old data remains latched until new valid outputs are entered.

## Read Mode

The device has one read mode. The operation code and port address are latched from the input port 2 on the high to low transition of the PROG pin. As soon as the read operation and port address are decoded, the appropriate outputs are tri-stated, and the input buffers switched on. The read operation is terminated by a low to high transition of the PROG pin. The port ( $4,5,6$ or 7 ) that was selected is switched to the tri-stated mode while port 2 is returned to the input mode.

Normally, a port will be in an output (write mode) or input (read mode). If modes are changed during operation, the first read following a write should be ignored; all following reads are valid. This is to allow the external driver on the port to settle after the first read instruction removes the low impedance drive from the 8243 output. A read of any port will leave that port in a high impedance state.

## 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 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 10 \%$

| SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{~V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL} 1}$ | Output Low Voltage Ports 4-7 |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA} *$ |
| $\mathrm{~V}_{\mathrm{OL} 2}$ | Output Low Voltage Port 7 |  |  | 1 | V | $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH} 1}$ | Output High Voltage Ports 4-7 | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=240 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL} 1}$ | Input Leakage Ports 4-7 | -10 |  | 20 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {in }}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{IL} 2}$ | Input Leakage Port 2, CS, PROG | -10 |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {in }}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{~V}_{\mathrm{OL} 3}$ | Output Low Voltage Port 2 |  |  | .45 | V | $\mathrm{I}_{\mathrm{OL}}=0.6 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 10 | 20 | mA |  |
| $\mathrm{~V}_{\mathrm{OH} 2}$ | Output Voltage Port 2 | 2.4 |  |  |  | $\mathrm{I}_{\mathrm{OH}}=100 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{OL}}$ | Sum of all IOL from 16 Outputs |  |  | 80 | mA | 5 mA Each Pin |

*See following graph for additional sink current capability

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{\mathrm{A}}$ | Code Valid Before PROG | 100 |  | ns | 80 pF Load |
| $\mathrm{t}_{\mathrm{B}}$ | Code Valid After PROG | 60 |  | ns | 20 pF Load |
| $\mathrm{t}_{\mathrm{C}}$ | Data Valid Before PROG | 200 |  | ns | 80 pF Load |
| $\mathrm{t}_{\mathrm{D}}$ | Data Valid After PROG | 20 |  | ns | 20 pF Load |
| $\mathrm{t}_{\mathrm{H}}$ | Floating After PROG | 0 | 150 | ns | 20 pF Load |
| $\mathrm{t}_{\mathrm{K}}$ | PROG Negative Pulse Width | 700 |  | ns |  |
| $\mathrm{t}_{\mathrm{CS}}$ | CS Valid Before/After PROG | 50 |  | ns |  |
| $\mathrm{t}_{\text {PO }}$ | Ports 4-7 Valid After PROG |  | 700 | ns | 100 pF Load |
| $\mathrm{t}_{\text {LP1 }}$ | Ports 4-7 Valid Before/After PROG | 100 |  | ns |  |
| $\mathrm{t}_{\text {ACC }}$ | Port 2 Valid After PROG |  | 650 | ns | 80 pF Load |

## WAVEFORMS

PROG

PORT 2


PORT 2

PORTS 4-7



## Sink Capability

The 8243 can sink $5 \mathrm{mA@}$. 45 V on each of its 16 I/O lines simultaneously. If, however, all lines are not sinking simultaneously or all lines are not fully loaded, the drive capability of any individual line increases as is shown by the accompanying curve.

For example, if only 5 of the 16 lines are to sink current at one time, the curve shows that each of those 5 lines is capable of sinking $9 \mathrm{~mA} @ .45 \mathrm{~V}$ (if any lines are to sink 9 mA the total $\mathrm{I}_{\mathrm{OL}}$ must not exceed 45 mA or five 9 mA loads).

Example: How many pins can drive 5 TTL loads ( 1.6 mA ) assuming remaining pins are unloaded?
$\mathrm{I}_{\mathrm{OL}}=5 \times 1.6 \mathrm{~mA}=8 \mathrm{~mA}$
$\varepsilon l_{\mathrm{OL}}=60 \mathrm{~mA}$ from curve
\# pins $=60 \mathrm{~mA} \div 8 \mathrm{~mA} /$ pin $=7.5=7$
In this case, 7 lines can sink 8 mA for a total of 56 mA . This leaves 4 mA sink current capability which can be divided in any way among the remaining 8 I/O lines of the 8243.

Example: This example shows how the use of the 20 mA sink capability of Port 7 affects the sinking capability of the other I/O lines.

An 8243 will drive the following loads simultaneously.

2 loads - $20 \mathrm{~mA} @ 1 \mathrm{~V}$ (port 7 only)
8 loads - $4 \mathrm{~mA} @ .45 \mathrm{~V}$
6 loads - $3.2 \mathrm{~mA} @ .45 \mathrm{~V}$
Is this within the specified limits?
$\varepsilon \mathrm{l}_{\mathrm{OL}}=(2 \times 20)+(8 \times 4)+(6 \times 3.2)=91.2 \mathrm{~mA}$. From the curve: for $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}, \varepsilon \mathrm{l}_{\mathrm{OL}} \approx 93 \mathrm{~mA}$ since $91.2 \mathrm{~mA}<93 \mathrm{~mA}$ the loads are within specified limits.

Although the $20 \mathrm{~mA} @ 1 \mathrm{~V}$ loads are used in calculating $\varepsilon l_{\mathrm{OL}}$, it is the largest current required@. 45 V which determines the maximum allowable $\varepsilon \mathrm{l}_{\mathrm{OL}}$.

Note: A 10 to $50 \mathrm{~K} \Omega$ pullup resistor to +5 V should be added to 8243 outputs when driving to 5 V CMOS directly.

## EXPANDER INTERFACE



OUTPUT EXPANDER TIMING


USING MULTIPLE 8243's


MCS-80/85 ${ }^{\text {TM }}$ Microprocessors

## MCS-80/85 ${ }^{\text {TM }}$ MICROPROCESSORS

## INTRODUCTION

The MCS-80 and MCS-85 have become the industry standard 8-bit microcomputer systems. Their wide usage is due to many factors, among them total system support in terms of the largest family of state-of-the-art processors, memories, and peripheral components. Many of these are described in the pages that follow. In addition, system designers using the 8080A and 8085A have the benefit of the world's largest and most usable set of microcomputer development tools (see section 12).
The MCS-85 components are of particular interest for new microcomputer designs. Systems designed around the 8085A and the new 8085A-2 offer the highest performance-to-cost ratios in the industry. Higher speed, single power supply requirement, and low component count while maintaining total MCS-80 software compatibility are key features of the MCS-85 system.


Figure 1. MCS-80 ${ }^{\text {TM }}$ - Foundation for MCS-85 ${ }^{\text {TM }}$
Figure 2. MCS-85 ${ }^{T M}$ - The New Industry Standard

Note: For more detailed information on the 8080A and 8085A microcomputer families, please consult the following:

MCS-80 ${ }^{\text {TM }}$ User's Manual (order number 98-153D) - Price $\$ 7.50$
MCS-85 ${ }^{\mathrm{TM}}$ User's Manual (order number 98-366E) - Price $\$ 5.00$
Available from Intel, Literature Dept., 3065 Bowers Ave., Santa Clara, CA 95051

## TABLE OF CONTENTS

Recommended Products for New 8085A Applications ..... 9-4
8008/8008-1 8-Bit Microprocessor ..... 9-5
8080A/8080A-1/8080A-2 8-Bit N-Channel Microprocessor ..... 9-11
8224 Clock Generator and Driver for 8080A CPU ..... 9-19
8801 Clock Generator Crystal for 8224/8080A ..... 9-23
8228/8238 System Controller and Bus Driver for 8080A CPU ..... 9-25
8205 High Speed 1 out of 8 Binary Decoder. ..... 9-29
8212 8 -Bit Input/Output Port ..... 9-35
8214 Priority Interrupt Control Unit ..... 9-45
8216/8226 4-Bit Parallel Bidirectional Bus Driver ..... 9-49
8085A/8085A-2 Single Chip 8-Bit N-Channel Microprocessors. ..... 9-54
8155/8156/8155-2/8156-2 2048 Bit Static MOS RAM with I/O Ports and Timer ..... 9-70
8185/8185-2 $1024 \times 8$-Bit Static RAM for MCS-85 ..... 9-77
8218/8219 Bipolar Microcomputer Bus Controllers for MCS-80 and MCS-85 ..... 9-81
8257/8257-5 Programmable DMA Controller ..... 9-92
8259A Programmable Interrupt Controller ..... 9-109
8355/8355-2 16,384-Bit ROM with I/O ..... 9-127
8755A 16,384-Bit EPROM with I/O ..... 9-132

## Recommended Products For

 New 8085A Microcomputer Applications| Function | Part No. | Page No. | Description |
| :---: | :---: | :---: | :---: |
| Memory and I/O Expanders for MCS-85 | $\begin{aligned} & \text { 8155/8156* } \\ & \text { 8185* } \\ & \text { 8355* } \\ & \text { 8755A } \end{aligned}$ | $\begin{aligned} & 9-70 \\ & 9-77 \\ & 9-127 \\ & 9-132 \end{aligned}$ | RAM-I/O-Timer $1 \mathrm{~K} \times 8$ Static Ram ROM-I/O EPROM-I/O |
| RAMs (Static) | $\begin{aligned} & 2114 \\ & 2142 \end{aligned}$ | $\begin{aligned} & 3-54 \\ & 3-95 \end{aligned}$ | $\begin{aligned} & 1 \mathrm{~K} \times 4 \\ & 1 \mathrm{~K} \times 4 \end{aligned}$ |
| RAMs (Dynamic) | $\begin{aligned} & 2117 \\ & 2118 \end{aligned}$ | $\begin{aligned} & 3-64 \\ & 3-88 \end{aligned}$ | $\begin{aligned} & 16 K \times 1 \\ & 16 K \times 1 \end{aligned}$ |
| RAM Support Circuits | 8202 | 11-14 | Dynamic RAM Controller |
| ROMs | 2316E | 4-12 | $2 \mathrm{~K} \times 8$ |
| EPROMs | $\begin{aligned} & 2716 \\ & 2732 \\ & 2758 \end{aligned}$ | $\begin{aligned} & 4-23 \\ & 4-28 \\ & 4-31 \\ & \hline \end{aligned}$ | $\begin{aligned} & 2 K \times 8 \\ & 4 K \times 8 \\ & 1 K \times 8 \end{aligned}$ |
| Microprocessor Support Circuits | 8205 <br> 8257-5 <br> 8259A <br> 8282 <br> 8283 <br> 8286 <br> 8287 | $\begin{gathered} 9-29 \\ 9-92 \\ 9-109 \\ 10-23 \\ 10-23 \\ 10-33 \\ 10-33 \end{gathered}$ | 1-of-8 Decoder DMA Controller Interrupt Controller 8-Bit Non-Inverting Latch 8-Bit Inverting Latch 8-Bit Non-Inverting Transceiver 8-Bit Inverting Transceiver |
| Peripherals | 8251A <br> 8253-5 <br> 8255A-5 <br> 8271 <br> 8273 <br> 8275 <br> 8278 <br> 8279-5 <br> 8291 <br> 8292 <br> 8294 <br> 8295 <br> 8041/8741 | 11-24 11-32 11-43 11-64 $11-93$ $11-118$ 11-142 11-152 11-164 11-188 11-190 11-201 $11-3$ | USART <br> Interval Timer <br> PPI <br> Floppy Disk Controller <br> SDLC Controller <br> CRT Controller <br> Keyboard/Display Controller <br> Keyboard/Display Controller <br> GPIB Talker/Listener <br> GPIB Controller <br> Data Encrypter <br> Dot Matrix Printer Controller <br> Universal Peripheral Interface |

[^6]
## 8008/8008-1 <br> 8-BIT MICROPROCESSOR

- Instruction Cycle Time - $1.25 \mu \mathrm{~s}$ with 8008-1 or $20 \mu$ with 8008


## - Directly Addresses $16 \mathrm{~K} \times 8$ Bits of Memory (RAM, ROM, or S.R.) <br> - Interrupt Capability

- 48 Instructions, Data Oriented

Address Stack Contains 8 14-Bit Registers (Including Program Counter) Which Permit Nesting of Subroutines Up to 7 Levels

The Intel ${ }^{\circledR} 8008$ is a single chip MOS 8-bit parallel central processor unit (CPU) for the MCS-8 microcomputer system. This CPU contains 68 -bit data registers, an 8 -bit accumulator, 28 -bit temporary registers, 4 flag bits (carry, zero, sign, parity), and an 8 -bit parallel binary arithmetic unit which implements addition, subtraction, and logical operations. A memory stack containing a 14 -bit program counter and 714 -bit words is used internally to store program and subroutine addresses. The 14 -bit address permits the direct addressing of 16 K words of memory (any mix of RAM, ROM, or S.R.).
The instruction set of the 8008 consists of 48 instructions including data manipulation, binary arithmetic, and jump to subroutine.
The normal program flow of the 8008 may be interrupted through the use of the interrupt control line. This allows the servicing of slow I/O peripheral devices while also executing the main program.
The ready command line synchronizes the 8008 to the memory cycle allowing any type or speed of semiconductor memory to be used.


## PIN DESCRIPTION



Figure 1. Pin Configuration

## $D_{0}-D_{7}$

BI-DIRECTIONAL DATA BUS. All address and data communication between the processor and the program memory, data memory, and I/O devices occurs on these 8 lines. Cycle control information is also available.

## INT

INTERRUPT input. A logic " 1 " level at this input causes the processor to enter the INTERRUPT mode.

## READY

READY input. This command line is used to synchronize the 8008 to the memory cycle allowing any speed memory to be used.

SYNC
SYNC output. Synchronization signal generated by the processor. It indicates the beginning of a machine cycle.
$\phi_{1}, \phi_{2}$
Two phase clock inputs.
$\mathbf{S}_{\mathbf{0}}, \mathbf{S}_{\mathbf{1}}, \mathbf{S}_{\mathbf{2}}$
MACHINE STATE OUTPUTS. The processor controls the use of the data bus and determines whether it will be sending or receiving data. State signals $\mathrm{S}_{0}, \mathrm{~S}_{1}$, and $\mathrm{S}_{2}$, along with SYNC inform the peripheral circuitry of the state of the processor.
$V_{c c}+5 \mathrm{~V} \pm 5 \%$
$V_{D D}-9 V \pm 5 \%$

## INSTRUCTION SET

## Data and Instruction Formats

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

$$
\frac{D_{7} D_{6} D_{5} D_{4} D_{3} D_{2} D_{1} D_{0}}{\text { DATA WORD }}
$$

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 Brie Instiuctions |  | TYPICAL INSTRUCTIONS |
| :---: | :---: | :---: |
|  | OP CODE | Register to register, memory referpace. I/O atithmetic or logical, rotate or |
| Two Byie instructions |  | return instructions |
|  | OP CODE |  |
|  | OPERAND | Immediate mode instructions |
| Three Byte instructions |  |  |
| $\mathrm{D}_{7} \mathrm{D}_{6} \mathrm{D}_{5} \mathrm{D}_{4} \mathrm{D}_{3} \mathrm{D}_{2} \mathrm{D}_{1} \mathrm{D}_{0}$ | OP CODE |  |
|  | LOW ADDRESS | JUMP or CALL instructions |
|  | HIGH ADDRESS* | - For the third byte of this instruction. $D_{6}$ and $D_{7}$ are "don 1 care" bits |

For the MCS $-8^{\text {TM }}$ a logic " 1 " is defined as a high level and a logıc " 0 " is defined as a low level.
Index Register Instructions
The load instructions do not affect the flag flip-flops. The increment and decrement instructions affect all flip-
flops except the carry.

| MNEMONIC | MINIMUM STATES REQUIRED | INSTRUCTION CODE |  |  |  |  |  |  | DESCRIPTION OF OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $D_{7} D_{6}$ | $\mathrm{D}_{5} \mathrm{D}_{4} \mathrm{D}_{3}$ |  |  |  | $\mathrm{D}_{1}$ |  |  |
| (1) MOV $\mathrm{r}_{1}, \mathrm{r}_{2}$ | (5) | 11 | D | D | D | S | S | S | Load index register $r_{1}$ with the content of index register $r_{2}$. |
| (2) MOV r. M | (8) | 11 | D | D | D | 1 | 1 | 1 | Load index register, with the content of memory register $M$. |
| MOV M, ${ }^{\text {r }}$ | (7) | 11 | 1 | 1 | 1 | S | S | S | Load memory register $M$ with the content of index register r. |
| (3) MVI r | (8) | $\begin{array}{ll} \hline 0 & 0 \\ B & B \\ \hline \end{array}$ | D |  | $\begin{aligned} & \mathrm{D} \\ & \mathrm{~B} \\ & \hline \end{aligned}$ | 1 |  | $\begin{aligned} & 0 \\ & \mathrm{~B} \\ & \hline \end{aligned}$ | Load index register $r$ with data B . . B. |
| MVI M | (9) | $\begin{array}{ll} \hline 0 & 0 \\ B & B \\ \hline \end{array}$ | 1 $B$ |  |  | 1 |  | O | Load memory register $M$ with data B . . B. |
| INR r | (5) | 00 | D | D | D | 0 | 0 | 0 | Increment the content of index register $r$ ( $r \not \ddagger A$ ). |
| DCR r | (5) | 00 | D | D | D | 0 | 0 | 1 | Decrement the content of index register $r(r \notin A)$. |

Accumulator Group Instructions
The result of the ALU instructions affect all of the flag flip-flops. The rotate instructions affect only the carry flip-flop.

| ADD r | (5) | 1 | 0 | 0 | 0 | 0 | S | S | S | Add the content of index register $r$, memory register $M$. or data B ... B to the accumulator. An overflow (carry) sets the carry flip.flop. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADD M | (8) | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |  |
| ADI | (8) |  |  | 0 | O | 0 | 1 | 0 |  |  |
| ADC r | (5) | 1 | 0 | 0 | 0 | 1 | S | S | S | Add the content of indéx register $r$, memory register $M$, or data B ... B from the accumulator with carry. An overflow (carry) sets the carry flip-flop. |
| ADC M | (8) | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |  |
| ACl | (8) |  | O |  | 0 | 1 | 1 | 0 | O |  |
| SUB r | (5) | 1 | 0 | 0 | 1 | 0 | S | S | S | Subtract the content of index register $r$, memory register $M$, or data B . . B from the accumulator. An underflow (borrow) sets the carry flip-flop. |
| SUB M | (8) | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 |  |
| SUI | (8) | O | 0 8 |  | 1 <br> 8 | O | $\begin{aligned} & 1 \\ & B \\ & \hline \end{aligned}$ | 0 | O |  |
| SBB ${ }^{\text {r }}$ | (5) | 1 | 0 | 0 | 1 | 1 | S | S | S | Subtract the content of index register $r$, memory register $M$, or data data B ... B from the accumulator with borrow. An underflow (borrow) sets the carry thip-flop. |
| SBB M | (8) | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 |  |
| SBI | (8) |  |  |  |  |  | 1 8 |  |  |  |


|  | minimum | INSTRUCTION CODE |  |  |  |  |  |  | DESCRIPTION OF OPERATION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MNEMONIC | STATES REQUIRED | $\mathrm{D}_{7} \mathrm{D}_{6}$ |  |  |  |  |  |  |  |
| ANA 1 | (5) | 10 | 1 | 0 | 0 |  | S | S | Compute the logical AND of the content of index register $r$. me:mory register $M$, or data $\mathbf{B} \ldots$. with the accumulator. |
| ANA M | (8) | 10 | 1 | 0 | 0 | 1 | 1 | 1 |  |
| ANI | (8) | $\begin{array}{ll} 0 & 0 \\ B & B \\ \hline \end{array}$ | 1 |  |  | 1 |  | 0 8 |  |
| XRA ${ }^{\text {r }}$ | (5) | 10 | 1 | 0 | 1 | S | S | S | Compute the EXCLUSIVE OR of the content of index register |
| XRA M | (8) | 10 | 1 | 0 | 1 | 1 | 1 | 1 | $r$, memory register $M$, or data B . . B with the accumulator. |
| XRI | (8) | $\begin{array}{ll} 0 & 0 \\ B & B \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 8 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 1 \\ & \mathrm{~B} \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & \mathrm{~B} \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 0 \\ & \mathrm{~B} \\ & \hline \end{aligned}$ |  |
| ORA 1 | (5) | 10 | 1 | 1 | 0 | S | S | S | Compute the INCLUSIVE OR of the content of index register |
| ORA M | (8) | 10 | 1 | 1 | 0 | 1 | 1 | 1 | $r$. memory register $m$, or data B . . B with the accumulator. |
| ORI | (8) | $\begin{array}{ll} \hline 0 & 0 \\ B & B \end{array}$ |  | 1 |  | 1 |  | 0 |  |
| CMP ${ }_{\text {r }}$ | (5) | 10 | 1 | 1 | 1 |  | S | S | Compare the content of index register r , memory register M , |
| CMP M | (8) | 10 | 1 | 1 | 1 |  | 1 | 1 | or data B . . B with the accumulator. The content of the |
| CPI | (8) | $\begin{array}{ll}0 & 0 \\ B & \text { B }\end{array}$ | 1 | 1 | 1 | 1 | 0 | O | accumulator is unchanged. |
| RLC | (5) | 00 | 0 | 0 | 0 | 0 | 1 | 0 | Rotate the content of the accumulator left. |
| RRC | (5) | 00 | 0 | 0 | 1 | 0 | 1 | 0 | Rotate the content of the accumulator right. |
| RAL | (5) | 00 | 0 | 1 | 0 | 0 | 1 | 0 | Rotate the content of the accumulator left through the carry. |
| RAR | (5) | 00 | 0 | 1 | 1 | 0 | 1 | 0 | Rotate the content of the accumulator right through the carry. |

Program Counter and Stack Control Instructions

| (4) JMP | (11) | $\begin{array}{ll} 0 & 1 \\ B_{2} & B_{2} \\ \times & X \end{array}$ | $\begin{array}{llll} \hline x & x & x \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \\ \hline \end{array}$ | $\left.\begin{array}{ccc} 1 & 0 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array} \right\rvert\,$ | Unconditionaily jump to memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (5) JNC, JNZ, JP, JPO | (9 or 11) | $\begin{array}{ll} \hline 0 \quad 1 \\ \mathrm{~B}_{2} \mathrm{~B}_{2} \\ \times \quad \times \\ \hline \end{array}$ | $\begin{array}{lll} 0 & C_{4} & C_{3} \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \\ \hline \end{array}$ | $\begin{array}{lll} \hline 0 & 0 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | Jump to memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ if the condition flip-flop is false. Otherwise, execute the next in : : uction in sequence. |
| $\begin{aligned} & J C, J Z \\ & J M, ~ J P E \end{aligned}$ | (9 or 11) | $\begin{array}{ll} \hline 0 & 1 \\ B_{2} & B_{2} \\ \mathrm{x} & \mathrm{X} \end{array}$ | $\begin{array}{llll} 1 & C_{4} & C_{3} \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \\ \hline \end{array}$ | $\begin{array}{lll} 0 & 0 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | Jump to memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ it the condition flip-flop is true. Otherwise, execute the next instructicn in sequence. |
| CALL | (11) | $\begin{aligned} & \hline 01 \\ & B_{2} B_{2} \\ & \times \quad \times \end{aligned}$ | $\begin{array}{lll} x & x & x \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \\ \hline \end{array}$ | $\begin{array}{lll} \hline 1 & 1 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | Unconditionally call the subroutine at memory address $\mathrm{B}_{3} \ldots$ $\mathrm{B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$. Save the current address (up one level in the stack). |
| CNC, CNZ, CP, CPO | (9 or 11) | $\begin{array}{ll} \hline 0 & 1 \\ B_{2} & B_{2} \\ \mathrm{x} & \mathrm{X} \end{array}$ | $\begin{array}{llll} 0 & C_{4} & C_{3} \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \\ \hline \end{array}$ | $\begin{array}{lll} \hline 0 & 1 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | Call the subroutine at memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ if the condition flip-flop is false, and save the current address (up one level in the stack.) Otherwise, execute the next instruction in sequence. |
| $\begin{aligned} & \mathrm{CC}, \mathrm{CZ}, \\ & \mathrm{CM}, \mathrm{CP}, \end{aligned}$ | (9 or 11) | $\begin{array}{ll} \hline 0 & 1 \\ \mathrm{~B}_{2} & \mathrm{~B}_{2} \\ \mathrm{x} & \mathrm{x} \end{array}$ | $\begin{array}{lll} 1 & C_{4} & C_{3} \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | $\begin{array}{lll} \hline 0 & 1 & 0 \\ B_{2} & B_{2} & B_{2} \\ B_{3} & B_{3} & B_{3} \end{array}$ | Call the subroutine at memory address $\mathrm{B}_{3} \ldots \mathrm{~B}_{3} \mathrm{~B}_{2} \ldots \mathrm{~B}_{2}$ if the condition flip-flop is true, and save the current address (up one level in the stack). Otherwise, execute the next instruction in sequence. |
| RET | (5) | 0 0 | $\times \times \times$ | $\begin{array}{lll}1 & 1\end{array}$ | Unconditionally return (down one level in the stack). |
| RNC, RNZ. RP, RPO | (3 or 5) | 00 | $0 \mathrm{C}_{4} \mathrm{C}_{3}$ | 011 | Return (down one level in the stack) if the condition flip-flop is false. Otherwise, execute the next instruction in sequence. |
| RC, RZ RM, RPE | (3 or 5 ) | 00 | $1 \mathrm{C}_{4} \mathrm{C}_{3}$ | 011 | Return (down one level in the stack) if the condition flip-flop is true. Otherwise, execute the next instruction in sequence. |
| RST | (5) | 00 | A A A | 101 | Call the subroutine at memory address AAA000 (up one level in the stack) |

Input/Output Instructions

| IN | (8) | 0 | 1 | 0 | 0 | $M$ | $M M 1$ | Read the content of the selected input port (MMM) into the <br> accumulator. |
| :---: | :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| OUT | (6) | 0 | 1 | R R M M M 1 | Write the content of the accumulator into the selected output <br> port (RRMMM, RR $f 00$ ) |  |  |  |

## Machine Instruction

| HLT | $(4)$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | $x$ | Enter the STOPPED state and remain there until interrupted. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $(4)$ | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |

NOTES
(1) SSS = Source Index Register These registers, $r_{1}$, are designated A(accumulator -000 ),

DDD = Destination Index Register $5 \mathrm{~B}(001), \mathrm{C}(010), \mathrm{D}(011), \mathrm{E}(100), \mathrm{H}(101), \mathrm{L}(110)$.
(2) Memory registers are addressed by the contents of registers $H \& L$.
(3) Additional bytes of instruction are designated by BBBBBBBB.
(4) $X=$ "Don't Care".
(5) Flag flip-flops are defined by $\mathrm{C}_{4} \mathrm{C}_{3}$ carry (00-overflow or underflow), zero ( 01 -result is zero), sign (10-MSB of result is " 1 "). parity (11-parity is even).

## ABSOLUTE MAXIMUM RATINGS*

| Ambient lemperature | $00^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| :--- | ---: |
| $\quad$ Under Bias | $-55^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Storage Temperature |  |
| Input Voltages and Supply |  |
| Voltage With Respect | +0.5 to -20 V |
| to VCC | $1.0 \mathrm{~W} @ 25^{\circ} \mathrm{C}$ |

*COMMENT
Stresses above those listed under "Absolute Max imum 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 condition above those indicated in the operational sections of this specification is not implied.

## D.C. AND OPERATING CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{C C}=+5 \mathrm{~V} \pm 5 \%, V_{D D}=-9 \mathrm{~V} \pm 5 \%$ unless otherwise specified. Logic " 1 " is defined as the more positive level $\left(\mathrm{V}_{\mathrm{IH}}, \mathrm{V}_{\mathrm{OH}}\right)$. " 0 " is defined as the more negative level ( $\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{OL}}$ ).

| SYMBOL | PARAMETER | LIMITS |  |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | TYP. | MAX. |  |  |
| Ioo | AVERAGE SUPPLY CURRENTOUTPUTS LOADED* |  | 30 | 60 | mA | $T_{A}=25^{\circ} \mathrm{C}$ |
| $I_{L I}$ | INPUT LEAKAGE CURRENT |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=O \mathrm{~V}$ |
| $V_{\text {IL }}$ | INPUT LOW VOLTAGE (INCLUDING CLOCKS) | $V_{D D}$ |  | $\mathrm{V}_{\mathrm{cc}}-4.2$ | V |  |
| $V_{\text {IH }}$ | INPUT HIGH VOLTAGE (INCLUDING CLOCKS) | $V_{c c^{-1}}{ }^{\text {c }}$ |  | $\mathrm{V}_{\mathrm{cc}}+0.3$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | OUTPUT LOW VOLTAGE |  |  | 0.4 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=0.44 \mathrm{~mA} \\ & \mathrm{C}_{\mathrm{L}}=200 \mathrm{pF} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | OUTPUT HIGH VOLTAGE | $V_{c c}-1.5$ |  |  | V | $\mathrm{I}_{\mathrm{OH}}=0.2 \mathrm{~mA}$ |

*Measurements are made while the 8008 is executing a typical sequence of instructions. The test load is selected such that at $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0.44 \mathrm{~mA}$ on each output.

## 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}}=-9 \mathrm{~V} \pm 5 \%$. All measurements are referenced to 1.5 V levels.

| SYMBOL | PARAMETER | 8008 |  | 8008-1 |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LIMITS |  | LIMITS |  |  |  |
|  |  | MIN. | MAX. | MIN. | MAX. |  |  |
| ${ }^{t}{ }_{C Y}$ | CLOCK PERIOD | 2 | 3 | 1.25 | 3 | $\mu \mathrm{s}$ | $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=50 \mathrm{~ns}$ |
| $\mathrm{t}_{\mathrm{R},} \mathrm{t}_{\mathrm{F}}$ | CLOCK RISE AND FALL TIMES |  | 50 |  | 50 | ns |  |
| ${ }^{t}{ }_{\phi 1}$ | PULSE WIDTH OF $\phi_{1}$ | . 70 |  | . 35 |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}{ }_{\phi 2}$ | PULSE WIIDTH OF $\phi_{2}$ | . 55 |  | . 35 |  | $\mu \mathrm{s}$ |  |
| ${ }^{t}{ }_{\text {D1 }}$ | CLOCK DELAY FROM FALLING EDGE OF $\phi_{1}$ TO FALLING EDGE OF $\phi_{2}$ | . 90 | 1.1 |  | 1.1 | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ 2 | CLOCK DELAY FROM $\phi_{2}$ TO $\phi_{1}$ | . 40 |  | . 35 |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ 3 | CLOCK DELAY FROM $\phi_{1}$ TO $\phi_{2}$ | . 20 |  | . 20 |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ D | DATA OUT DELAY |  | 1.0 |  | 1.0 | $\mu \mathrm{s}$ | $C_{L}=100 \mathrm{pF}$ |
| ${ }^{\text {t }}{ }_{\text {OH }}$ | HOLD TIME FOR DATA BUS OUT | . 10 |  | . 10 |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ IH | HOLD TIME FOR DATA IN | [1] |  | [1] |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ SD | SYNC OUT DELAY |  | . 70 |  | . 70 | $\mu \mathrm{s}$ | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| ${ }^{t}$ S1 | STATE OUT DELAY (ALL STATES EXCEPT T1 AND T11) ${ }^{[2]}$ |  | 1.1 |  | 1.1 | $\mu \mathrm{s}$ | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| ${ }^{t}$ s2 | STATE OUT DELAY (STATES T1 AND T11) |  | 1.0 |  | 1.0 | $\mu \mathrm{s}$ | $C_{L}=100 \mathrm{pF}$ |
| ${ }^{\text {t }}$ RW | PULSE WIDTH OF READY DURING $\phi_{22}$ TO ENTER T3 STATE | . 35 |  | . 35 |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ R | READY DELAY TO ENTER WAIT STATE | . 20 |  | . 20 |  | $\mu \mathrm{s}$ |  |

[^7]
## TIMING DIAGRAM



Notes: 1. READY line must be at " 0 ' prior to $\phi_{22}$ of $T_{2}$ to guarantee entry into the WAIT state.
2. INTERRUPT line must not change levels within 200 ns (max.) of falling edge of $\phi_{1}$.

TYPICAL D.C. CHARACTERISTICS


OUTPUT SINKING CURRENT
VS. TEMPERATURE


OUTPUT SOURCE CURRENT VS. OUTPUT VOLTAGE

output voltage ivi. $\mathrm{V}_{\mathrm{on}}$

## TYPICAL A.C. CHARACTERISTICS



CAPACITANCE $f=1 \mathrm{MHz} ; T_{A}=25^{\circ} \mathrm{C}$; Unmeasured Pins Grounded

| SYMBOL | TEST |  | LIMIT (pF) |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. |  |
| $\mathrm{C}_{\text {IN }}$ | INPUT CAPACITANCE | 5 | 10 |  |
| $\mathrm{C}_{\text {DB }}$ | DATA BUS I/O CAPACITANCE | 5 | 10 |  |
| $\mathrm{C}_{\text {OUT }}$ | OUTPUT CAPACITANCE | 5 | 10 |  |

## ■ TTL Drive Capability

■ $2 \mu \mathrm{~s}(-1: 1.3 \mu \mathrm{~s},-2: 1.5 \mu \mathrm{~s})$ Instruction Cycle

- Powerful Problem Solving Instruction Set
- 6 General Purpose Registers and an Accumulator


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

- 16-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 ${ }^{(®)}$ 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 68 -bit general purpose working registers and an accumulator. The 6 general purpose registers may be addressed individually or in pairs providing both single and double precision operators. Arithmetic and logical instructions set or reset 4 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 6 general purpose registers. The 16 -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 bidirectional 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 OR-tying these busses with other controlling devices for (DMA) direct memory access or multiprocessor operation.


## PIN DESCRIPTION

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 8080A 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 $\overline{W R}$ 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 ( $A_{15}-A_{0}$ ) 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


Figure 1. 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)[1]

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.

[^8]
## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias |  |
| :---: | :---: |
| Storage Temperature | $5^{\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}_{S S}$ With Respect to $\mathrm{V}_{\mathrm{BB}}$ | -0.3 V to +20 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. 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 ILC | Clock Input Low Voltage | $\mathrm{V}_{\mathrm{SS}}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V | $\begin{aligned} \mathrm{l}_{\mathrm{OL}} & =1.9 \mathrm{~mA} \text { on all outputs, } \\ \mathrm{I}_{\mathrm{OH}} & =-150 \mu \mathrm{~A} . \end{aligned}$ |
| $V_{\text {IHC }}$ | Clock Input High Voltage | 9.0 |  | $V_{D D}+1$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $\mathrm{V}_{\text {SS }}-1$ |  | $V_{\text {SS }}+0.8$ | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | 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 |  |
| 1 DD (AV) | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{DD}}$ ) |  | 40 | 70 | mA | $\begin{aligned} & \text { Operation } \\ & T_{\mathrm{CY}}=.48 \mu \mathrm{sec} \end{aligned}$ |
| $\operatorname{lcC}(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}} \\ & \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 {c }}$ CL | Clock Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ |  |
| $\mathrm{I}_{\mathrm{DL}}{ }^{\text {[2] }}$ | Data Bus Leakage in Input Mode |  |  | $\begin{aligned} & -100 \\ & -2.0 \end{aligned}$ | $\begin{array}{r} \mu \mathrm{A} \\ \mathrm{~mA} \end{array}$ |  |
| $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 \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V}$

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}$.


AMBIENT TEMPERATURE ( ${ }^{\circ} \mathrm{C}$ )
Figure 2. Typical Supply Current vs. Temperature, Normalized ${ }^{[3]}$


Figure 3. Data Bus Characteristic During DBIN

| 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}_{\text {OUT }}$ | Output Capacitance | 10 | 20 | pf | Returned to $\mathrm{V}_{\mathrm{SS}}$ l |

## A.C. CHARACTERISTICS (8080A)

$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. | $\begin{gathered} -1 \\ \text { Min. } \end{gathered}$ | $\begin{gathered} -1 \\ \text { Max. } \end{gathered}$ | $\begin{gathered} -2 \\ \text { Min. } \end{gathered}$ | $\begin{gathered} -2 \\ \text { Max. } \end{gathered}$ | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{t} \mathrm{Cr}^{[3]}$ | Clock Period | 0.48 | 2.0 | 0.32 | 2.0 | 0.38 | 2.0 | $\mu \mathrm{sec}$ | $\begin{aligned} & \left\{\begin{array}{l} C_{L}=100 \mathrm{pF} \\ -C_{L}=50 \mathrm{pF} \end{array}\right. \end{aligned}$ |
| $t_{r}, t_{f}$ | Clock Rise and Fall Time | 0 | 50 | 0 | 25 | 0 | 50 | nsec |  |
| $t_{01}$ | $\varnothing_{1}$ Pulse Width | 60 |  | 50 |  | 60 |  | nsec |  |
| $t_{\varnothing 2}$ | $\varnothing_{2}$ Pulse Width | 220 |  | 145 |  | 175 |  | nsec |  |
| ${ }^{t} 11$ | Delay $\varnothing_{1}$ to $\varnothing_{2}$ | 0 |  | 0 |  | 0 |  | nsec |  |
| ${ }^{\text {t }}$ 2 | Delay $\varnothing_{2}$ to $\varnothing_{1}$ | 70 |  | 60 |  | 70 |  | nsec |  |
| ${ }^{\text {t }}$ 3 | Delay $\varnothing_{1}$ to $\varnothing_{2}$ Leading Edges | 80 |  | 60 |  | 70 |  | nsec |  |
| ${ }^{t} \mathrm{DA}^{[2]}$ | Address Output Deray From $\varnothing_{2}$ |  | 200 |  | 150 |  | 175 | nsec |  |
| $t_{D D^{[2]}}$ | Data Output Delay From $\varnothing_{2}$ |  | 220 |  | 180 |  | 200 | nsec |  |
| $t_{D C}{ }^{[2]}$ | Signal Output Delay From $\varnothing_{2}$ or $\varnothing_{2}$ (SYNC, WR, WAIT, HLDA) |  | 120 |  | 110 |  | 120 | nsec |  |
| ${ }^{t_{D F}}{ }^{[2]}$ | DBIN Delay From $\varnothing_{2}$ | 25 | 140 | 25 | 130 | 25 | 140 | nsec |  |
| ${ }_{t} \mathrm{DI}^{[1]}$ | Delay for Input Bus to Enter Input Mode |  | t ${ }^{\text {DF }}$ |  | ${ }^{\text {t }}$ DF |  | ${ }^{\text {t }}$ DF | nsec |  |
| ${ }^{\text {t DS1 }}$ | Data Setup Time During $\varnothing_{1}$ and DBIN | 30 |  | 10 |  | 20 |  | nsec |  |

## WAVEFORMS

(Note: Timing measurements are made at the following reference voltages: CLOCK " 1 " $=8.0 \mathrm{~V}$ $" 0^{\prime \prime}=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 (8080A)

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

| Symbol | Parameter | Min. | Max. | $\begin{gathered} -1 \\ \text { Min. } \end{gathered}$ | $\begin{gathered} -1 \\ \operatorname{Max} . \end{gathered}$ | $\begin{gathered} -2 \\ \text { Min. } \end{gathered}$ | $\stackrel{-2}{\text { Max. }}$ | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t DS2 }}$ | Data Setup Time to $\varnothing_{2}$ During DBIN | 150 |  | 120 |  | 130 |  | nsec | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| ${ }_{\text {t } H{ }^{[1]}}$ | Data Holt time From $\varnothing_{2}$ During DBIN | [1] |  | [1] |  | [1] |  | nsec |  |
| $\mathrm{t}_{1 E^{[2]}}$ | INTE Output Delay From $\varnothing_{2}$ |  | 200 |  | 200 |  | 200 | nsec |  |
| ${ }^{\text {t } R S}$. | READY Setup Time During $\varnothing_{2}$ | 120 |  | 90 |  | 90 |  | nsec |  |
| ${ }^{\text {thS }}$ | HOLD Setup Time to $\varnothing_{2}$ | 140 |  | 120 |  | 120 |  | nsec |  |
| tis | INT Setup Time During $\varnothing_{2}$ | 120 |  | 100 |  | 100 |  | nsec |  |
| ${ }^{t} \mathrm{H}$ | Hold Time From $\varnothing_{2}$ (READY, INT, HOLD) | 0 |  | 0 |  | 0 |  | nsec |  |
| ${ }^{t_{\text {F }}}$ | Delay to Float During Hold (Address and Data Bus) |  | 120 |  | 120 |  | 120 | nsec |  |
| ${ }^{t} A W^{[2]}$ | Address Stable Prior to WR | [5] |  | [5] |  | [5] |  | nsec | $C_{L}=100 \mathrm{pF}$ : Address, Data <br> $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}: \overline{\mathrm{WR}}, \mathrm{HLDA}, \mathrm{DBIN}$ |
| ${ }^{t_{D W} W^{[2]}}$ | Output Data Stable Prior to WR | [6] |  | [6] |  | [6] |  | nsec |  |
| ${ }_{\text {twD }}{ }^{[2]}$ | Output Data Stable From WR | [7] |  | [7] |  | [7] |  | nsec |  |
| ${ }^{\text {twa }}{ }^{[2]}$ | Address Stable From WR | [7] |  | [7] |  | [7] |  | nsec |  |
| ${ }^{\mathrm{t}_{\mathrm{HF}}{ }^{[2]}}$ | HLDA to Float Delay | [8] |  | [8] |  | [8] |  | nsec |  |
| ${ }^{\text {t }} \mathrm{WF}^{[2]}$ | WR to Float Delay | [9] |  | [9] |  | [9] |  | nsec |  |
| ${ }^{t_{A H}{ }^{[2]}}$ | Address Hold Time After DBIN During HLDA | -20 |  | -20 |  | -20 |  | nsec |  |



NOTES: (Parenthesis gives $-1,-2$ specifications, respectively)

1. Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured ${ }^{\mathrm{t}} \mathrm{DH}=50 \mathrm{~ns}$ or ${ }^{\mathrm{t}} \mathrm{DF}$, 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 2}+t_{r \phi 1} \geqslant 480 \mathrm{~ns}(-1: 320 \mathrm{~ns},-2: 380 \mathrm{~ns})$.

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

4. The following are relevant when interfacing the 8080A 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}=\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}_{S P E C}$.
5. $t_{A W}=2 t_{C Y}-t_{D 3}-t_{\text {r } 2}-140 \mathrm{~ns}(-1: 110 \mathrm{~ns},-2: 130 \mathrm{~ns})$.
6. $t_{D W}=t_{C Y}-t_{D 3}-t_{\text {r申2 }}-170 \mathrm{~ns}(-1: 150 \mathrm{~ns},-2: 170 \mathrm{~ns})$.
7. If not HLDA, $t W D=t W A=t D 3+t_{r} \phi 2+10$ ns. If $H L D A, t W D=t W A=t W F$.
$\mathrm{t}_{\mathrm{HF}}=\mathrm{t}_{\mathrm{D}} 3+\mathrm{t}_{\mathrm{r} \phi} 2-50 \mathrm{~ns}$.
$\mathrm{t}_{\mathrm{W}}=\mathrm{t}_{\mathrm{D}} 3+\mathrm{t}_{\mathrm{r} \phi 2}-10 \mathrm{~ns}$
10. 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.)
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.

$$
\left.\frac{D_{7}}{D_{7}} \mathrm{D}_{6} \quad \mathrm{D}_{5} \quad \mathrm{D}_{4} \quad \mathrm{D}_{3} \quad \mathrm{D}_{2} \quad \mathrm{D}_{1} \quad \mathrm{D}_{0} \right\rvert\,
$$

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

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Two Byte Instructions

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

Three Byte Instructions


## TYPICAL INSTRUCTIONS

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

Immediate mode or I/O instructions

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

## Summary of Processor Instructions



## Summary of Processor Instructions (Cont.)

| Mnemonic | Description | 07 | Instruction Code[I] |  |  |  |  |  |  | Clock\|2] Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathrm{O}_{6}$ | D5 | $\mathrm{O}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| SUBTRACT |  |  |  |  |  |  |  |  |  |  |
| SUB r | Subtract regıster 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 immedıate from A | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| SBI | Subtract immedıate 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 1 | Or registei 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 inmediate 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 | Decımal 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 |

## - Single Chip Clock Generator/Driver for 8080A CPU

- Power-Up Reset for CPU
- Ready Synchronizing Flip-Flop
- Advanced Status Strobe
- Oscillator Output for External System Timing
- Crystal Controlled for Stable System Operation
- Reduces System Package Count

The Intel ${ }^{\circledR} 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 |
| $\overline{\text { STSTB }}$ | STATUS STB <br> (ACTIVE LOW) |
| $\phi_{1}$ | 8 <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_{\mathrm{CC}}$ | +12 V |
| $V_{\text {DD }}$ | $O \mathrm{~V}$ |
| GND |  |

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ Supply Voltage, VCC . . . . . . . . . . . . . . . . -0.5 V to +7 V Supply Voltage, VDD . . . . . . . . . . . . . -0.5 V to +13.5 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.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}$ |
| $I_{\text {R }}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Clañ 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 |
| $V_{1 H} \cdot V_{\text {IL }}$ | RESIN Input Hysteresis | . 25 |  |  | V | $\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, STSTB $\mathrm{I}_{\mathrm{OL}}=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 \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 <br> (All Low Voltage Outputs Only) | -10 |  | -60 | mA | $\begin{aligned} & V_{O}=0 \mathrm{~V} \\ & V_{C C}=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: $0.005 \%$ at $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$
Resonance: Series (Fundamental)*
Load Capacitance: 20-35 pF
Equivalent Resistance: 75-20 ohms
Power Dissipation (Min): 4 mW
*With tank circuit use 3rd overtone mode.

## A.C. CHARACTERISTICS

$V_{C C}=+5.0 \mathrm{~V} \pm 5 \% ; V_{D D}=+12.0 \mathrm{~V} \pm 5 \% ; T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{t}_{\text {¢ }}{ }_{1}$ | $\phi_{1}$ Pulse Width | $\frac{2 t c y}{9}-20 n s$ |  |  | ns | $C_{L}=20 \mathrm{pF}$ to 50 pF |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | $\frac{5 t c y}{9}-35 n s$ |  |  |  |  |
| $t_{\text {D1 }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | 0 |  |  |  |  |
| $t_{\text {D2 }}$ | $\phi_{2}$ to $\phi_{1}$ Delay | $\frac{2 \mathrm{tcy}}{9}-14 \mathrm{~ns}$ |  |  |  |  |
| $t_{\text {D }}$ | $\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 |  |  |
| ${ }^{\text {b }}{ }_{\text {¢ } 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}$ |
| ${ }^{\text {t }}$ DSS | $\phi_{2}$ to STSTB Delay | $\frac{6 t c y}{9}-30 \mathrm{~ns}$ |  | $\frac{6 \text { tcy }}{9}$ |  | $\begin{aligned} & \overline{\text { STSTB }}, C L=15 p F \\ & R_{1}=2 K \\ & R_{2}=4 K \end{aligned}$ |
| ${ }^{\text {P }}$ W | $\overline{\text { STSTB Pulse Width }}$ | $\frac{\text { tcy }}{9}-15 n s$ |  |  |  |  |
| ${ }^{\text {t }}$ DRS | RDYIN Setup Time to Status Strobe | $50 \mathrm{~ns}-\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| tDRH | RDYIN Hold Time After STSTB | $\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| ${ }^{\text {t }}$ DR | 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 {t CLK }}$ | CLK Period |  | $\frac{\text { tcy }}{9}$ |  |  |  |
| $f_{\text {max }}$ | Maximum Oscillating Frequency |  |  | 27 | 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} \\ & 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{DD}}=+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 ns ns ns ns | ${ }^{\mathrm{t}} \mathrm{CY}=488.28 \mathrm{~ns}$ |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 236 |  |  |  |  |
| $\mathrm{t}_{\mathrm{D} 1}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  |  |  |  |
| $t_{\text {D2 }}$ | Delay $\phi_{2}$ to $\phi_{1}$ | 95 |  |  |  | $\phi_{1} \& \phi_{2}$ Loaded to$C_{L}=20 \text { to } 50 \mathrm{pF}$ |
| ${ }^{\text {t }}$, ${ }^{\text {r }}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 109 |  | 129 |  |  |
| $\mathrm{t}_{\mathrm{r}}$ | Output Rise Time |  |  | 20 | ns |  |
| $\mathrm{t}_{\mathrm{f}}$ | Output Fall Time |  |  | 20 |  |  |
| toss | $\phi_{2}$ to STSTB Delay | 296 |  | 326 | ns | Ready \& Reset Loaded to $2 \mathrm{~mA} / 10 \mathrm{pF}$ |
| ${ }^{t}{ }_{D}{ }^{2} 2$ | $\phi_{2}$ to $\phi_{2}$ (TTL) Delay | -5 |  | +15 | ns |  |
| $t_{\text {PW }}$ | Status Strobe Pulse Width | 40 |  |  | ns |  |
| ${ }^{\text {t DRS }}$ | RDYIN Setup Time to STSTB | -167 |  |  | ns |  |
| tDRH | RDYIN Hold Time after STSTB | 217 |  |  | ns | All measurements |
| ${ }^{t} \mathrm{DR}$ | READY or RESET to $\phi_{2}$ Delay | 192 |  |  | ns | referenced to 1.5 V unless specified otherwise. |
| $\mathrm{f}_{\text {MAX }}$ | Oscillator Frequency |  |  | 18.432 | MHz |  |

8801
CLOCK GENERATOR CRYSTAL FOR 8224/8080A

Specifically Selected for Intel ${ }^{\circledR} 8224$<br>■ 18.432 MHz for $1.95 \mu \mathrm{~s}$ 8080A Cycle<br>- Simple Generation of all Standard Communication Baud Rates<br>- Frequency Deviation $\pm \mathbf{0 . 0 0 5 \%}$<br>- Fundamental Frequency Mode<br>$-0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Operating Temperature

The Intel® 8801 is a quartz crystal specifically selected to operate with the 8224 clock generator and the 8080A CPU. It resonates in the fundamental frequency mode at 18.432 MHz . This frequency allows the 8080A at full speed ( $\mathrm{T}_{\mathrm{CY}}=488$ 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.


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


Figure 1. 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 32$ |
| 300 | 1200 | 9.2 KH | $\div 30$ | $\div 64$ |
|  | 600 | 4.8 KH | $\div 30$ | $\div 128$ |

[^9]Figure 2. Baud Rate Chart

## ELECTRICAL CHARACTERISTICS

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

$$
\begin{array}{ccc}
0^{\circ}-70^{\circ} \mathrm{C} & \ldots \\
-55^{\circ}-125^{\circ} \mathrm{C} & .
\end{array} .
$$

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

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

## - Built-In Bidirectional 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 Intel ${ }^{\oplus} 8228$ 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 bidirectional 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 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


BLOCK DIAGRAM


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) |
| 1/OW | I/O WRITE | BUSEN | BUS ENABLE INPUT |
| MEMR | MEMORY READ | STSTB | STATUS STROBE (FROM 8224) |
| MEMW | MEMORY WRITE | $\mathrm{V}_{\text {cc }}$ | +5V |
| DBIN | DBIN (FROM 8080) | GND | 0 VOLTS |

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias. $\qquad$
Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$
Supply Voltage, VCC . . . . . . . . . . . . . . . . -0.5 V to +7 V
Input Voltage . . . . . . . . . . . . . . . . . . . . . -1.5 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}=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}$ |  |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current 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}$ |
| ICC | Power Supply Current |  | 140 | 190 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage, $\mathrm{D}_{0}-\mathrm{D}_{7}$ |  |  | . 45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} ; \mathrm{l}_{\mathrm{OL}}=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 | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} ; \mathrm{l}_{\mathrm{OH}}=-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}$ |
| IO(off) | Off State Output Current, All Control Outputs |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{C C}=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) |

[^10]
## 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}_{\mathrm{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 |  |
| $\mathrm{t}_{\mathrm{DC}}$ | Delay from STSTB to any Control Signal | 20 | 60 | ns | $C_{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 | $\mathrm{C}_{\mathrm{L}}=25 \mathrm{pF}$ |
| $t_{\text {RD }}$ | Delay from System Bus to 8080 Bus during Read |  | 30 | ns | $\mathrm{C}_{\mathrm{L}}=25 \mathrm{pF}$ |
| twr | Delay from $\overline{W R}$ to Control Outputs | 5 | 45 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| twe | 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 | $C_{L}=100 \mathrm{pF}$ |
| $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 |  |
| $t_{\text {DS }}$ | Setup Time, System Bus Inputs to HLDA | 10 |  | ns |  |
| ${ }^{\text {t }}$ ( ${ }^{\text {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.

|  |  | Limits |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Symbol | Parameter | 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: NS: $\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}$.


Figure 1. INTA Test Circuit (for RST 7)


Figure 2. CPU Standard Interface

## 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 - $\mathbf{2 5} \mathrm{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 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 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $A_{0}$ | $A_{1}$ | $\mathrm{A}_{2}$ | $\mathrm{E}_{1}$ | $\mathrm{E}_{2}$ | $\mathrm{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 | 1 | L | H | H | H | H | H | H | H | H | L |
| X | X | X | 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 | $\times$ | L | H | 1 | 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 | $\times$ | H | H | H | H | H | H | H | H | H | H | H |

## FUNCTIONAL DESCRIPTION

## Decoder

The $\mathbf{8 2 0 5}$ 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 AO, A1 and A2 address input lines, and the device was enabled, an active low signal would appear on the $\overline{\mathbf{0 5}}$ 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 (E1, E2, E3) 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.

## 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, AO 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 $1 / 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 24K memory system.
The memory devices used can be either ROM or RAM and are 1 K in storage capacity. 8308s and 8102s 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 AO-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).


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

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{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{\text { T1 }}$ output, the boolean equation for it would be:

$$
\overline{\mathrm{T} 1}=(\overline{\mathrm{SO}} \cdot \mathrm{~S} 1 \cdot \overline{\mathrm{~S} 2}) \cdot(\overline{\mathrm{SYNC}} \cdot \text { Phase } 2 \cdot \overline{\text { Reset }})
$$

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.

State Control Coding

| $\mathrm{S}_{0}$ | $\mathrm{~S}_{1}$ | $\mathrm{~S}_{2}$ | STATE |
| :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | T1 |
| 0 | 1 | 1 | T1I |
| 0 | 0 | 1 | T2 |
| 0 | 0 | 0 | WAIT |
| 1 | 0 | 0 | T3 |
| 1 | 1 | 0 | STOP |
| 1 | 1 | 1 | T4 |
| 1 | 0 | 1 | T5 |

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias: | Ceramic <br> Plastic | $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ <br> $-65^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ |
| :--- | ---: | ---: |
| Storage Temperature |  | $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ |
| All Output or Supply Voltages | -0.5 to +7 Volts |  |
| All Input Voltages | -1.0 to +5.5 Volts |  |
| Output Currents | 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 \%$

## 8205

| SYMBOL | PARAMETER | LIMIT |  | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. |  |  |
| $I_{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}_{\mathrm{CC}}=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}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{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

OUTPUT CURRENT VS. OUTPUT "LOW" VOLTAGE


OUTPUT CURRENT VS. OUTPUT "HIGH" VOLTAGE



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


## TEST WAVEFORMS

ADDRESS OR ENABLE INPUT PULSE

OUTPUT

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \%$ unless otherwise specified.

| SYMBOL | PARAMETER | MAX. LIMIT | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{++}$ | ADDRESS OR ENABLE TO OUTPUT DELAY | 18 | ns |  |
| $t_{\text {- }}+$ |  | 18 | ns |  |
| ${ }_{+}^{+}$ |  | 18 | ns |  |
| $\mathrm{t}_{\text {- }}$ |  | 18 | ns |  |
| $\mathrm{C}_{\text {IN }}{ }^{(1)}$ | INPUT CAPACITANCE $\frac{\text { P8205 }}{\text { C8205 }}$ | $\frac{4(\text { typ. ) }}{5 \text { (typ.) }}$ | $\frac{\mathrm{pF}}{\mathrm{pF}}$ | $\begin{aligned} & f=1 \mathrm{MHZ}, V_{C C}=0 \mathrm{~V} \\ & V_{B I A S}=2.0 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |

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

## TYPICAL CHARACTERISTICS

## ADDRESS OR ENABLE TO OUTPUT

 DELAY VS. LOAD CAPACITANCE

ADDRESS OR ENABLE TO OUTPUT DELAY VS. AMBIENT TEMPERATURE


8212

## 8-BIT INPUT/OUTPUT PORT

Fully Parallel 8-Bit Data Register and Buffer

- Service Request FIIp-Flop for Interrupt Generation
- Low Input Load Current - . 25mA Max.
- Three State Outputs

■ Outputs Sink 15 mA

- 3.65V Output High Voltage for Direct Interface to 8008, 8080A, or 8085A CPU
- Asynchronous Register Clear
- Replaces Buffers, Latches and Multiplexers in Microcomputer Systems
Reduces System Package Count

The 8212 input/output port consists of an 8-bit latch with 3-state output buffers along with control and device selection logic. Also included is a service request flip-flop for the generation and control of interrupts to the microprocessor.
The device is multimode in nature. It can be used to implement latches, gated buffers or multiplexers. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with this device.


## FUNCTIONAL DESCRIPTION

## Data Latch

The 8 flip-flops that make up the data latch are of a "D" type design. The output (Q) of the flip-flop will follow the data input ( $D$ ) while the clock input ( $C$ ) is high. Latching will occur when the clock (C) returns low.
The latched data is cleared by an asynchronous reset input ( $\overline{\mathrm{CLR}}$ ). (Note: Clock (C) Overrides Reset ( $\overline{\mathrm{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 ( $\mathbf{Q}$ ) or disables the buffer, forcing the output into a high impedance state. (3-state)
The high-impedance state allows the designer to connect the 8212 directly onto the microprocessor bi-directional data bus.

## Control Logic

The 8212 has control inputs $\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} 1} \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{DS1}} \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} \cdot \mathrm{DS} 2$ ) and the source of clock (C) to the data latch is the STB (Strobe) input.

## STB (Strobe)

This input is used as the clock ( C ) to the data latch for the input mode MD $=0$ ) and to synchronously reset the service request flip-flop (SR).
Note that the SR flip-flop is negative edge triggered.

## Service Request Flip-Flop

The (SR) flip-flop is used to generate and control interrupts in microcomputer systems. It is asynchronously set by the $\overline{C L R}$ input (active low). When the (SR) flipflop is set it is in the non-interrupting state.
The output of the (SR) flip-flop ( $Q$ ) is connected to an inverting input of a "NOR" gate. The other input to the "NOR" gate is non-inverting and is connected to the device selection logic (DS1 • DS2). The output of the "NOR" gate (INT) is active low (interrupting state) for connection to active low input priority generating circuits.


## Applications of the 8212 - For <br> 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
VII 8080A Status Latch
VIII 8085A Address Latch

## 1. 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 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 3state.

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



## III. Bi-Directional Bus Driver

A pair of 8212's wired (back-to-back) can be used as a symmetrical drive, bi-directional bus driver. The devices are controlled by the data bus input control which is connected to DS1 on the first 8212 and to DS2 on the second. One device is active, and acting as a straight through buffer the other is in 3-state mode. This is a very useful circuit in small system design.

## IV. Interrupting Input Port

This use of an 8212 is that of a system input port that accepts a strobe from the system input source, which in turn clears the service request flip-flop and interrupts the processor. The processor then goes through a service routine, identifies the port, and causes the device selection logic to go true - enabling the system input data onto the data bus.

## BI-DIRECTIONAL BUS DRIVER



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 handshaking signal such as "reception of data" from the device that the system is outputting to. It in turn, can interrupt the system signifying the reception of data. The selection of the port comes from the device selection logic. $(\overline{\mathrm{DS} 1} \cdot \mathrm{DS} 2)$

OUTPUT PORT (WITH HAND-SHAKING)


## VII. 8080A Status Latch

Here the 8212 is used as the status latch for an 8080A microcomputer system. The input to the 8212 latch is directly from the 8080A data bus. Timing shows that when the SYNC signal is true, which is connected to the DS2 input and the phase 1 signal is true, which is a TTL level coming from the clock generator; then, the status data will be latched into the 8212.

Note: The mode signal is tied high so that the output on the latch is active and enabled all the time.
It is shown that the two areas of concern are the bidirectional data bus of the microprocessor and the control bus.


## VIII. 8085A Low-Order Address Latch

The 8085A microprocessor uses a multiplexed address/ data bus that contains the low order 8-bits of address information during the first part of a machine cycle. The same bus contains data at a later time in the cycle. An address latch enable (ALE) signal is provided by the 8085A to be used by the 8212 to latch the address so that it may be available through the whole machine cycle. Note: In this configuration, the MODE input is tied high, keeping the 8212's output buffers turned on at all times.


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias Plastic ....... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature ................ $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$
All Output or Supply Voltages ........ -0.5 to +7 Volts
All Input Voltages ..................... -1.0 to 5.5 Volts
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.
D.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V} C \mathrm{C}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| IF | Input Load Current, ACK, DS2, CR, $\mathrm{Dl}_{1}$-Dl8 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 1 Input |  |  | -1.0 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| IR | Input Leakage Current, ACK, DS, CR, Dl1-DI8 Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current MO Input |  |  | 30 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IR | Input Leakage Current DS1 Input |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Voltage Clamp |  |  | -1 | V | $I C=-5 m A$ |
| VIL | Input "Low" Voltage |  |  | . 85 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| Vol | Output "Low" Voltage |  |  | . 45 | V | $\mathrm{IOL}=15 \mathrm{~mA}$ |
| VOH | Output "High" Voltage | 3.65 | 4.0 |  | V | $1 \mathrm{OH}=-1 \mathrm{~mA}$ |
| Isc | Short Circuit Output Current | -15 |  | -75 | mA | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{cc}}=5 \mathrm{~V}$ |
| \|lo| | Output Leakage Current High Impedance State |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V} / 5.25 \mathrm{~V}$ |
| Icc | 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


## 8212

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| tpw | Pulse Width | 30 |  |  | ns |  |
| tPD | Data to Output Delay |  |  | 30 | ns | Note 1 |
| twe | Write Enable to Output Delay |  |  | 40 | ns | Note 1 |
| tSET | Data Set Up Time | 15 |  |  | ns |  |
| $\mathrm{tH}_{\mathrm{H}}$ | Data Hold Time | 20 |  |  | ns |  |
| $t_{\text {R }}$ | Reset to Output Delay |  |  | 40 | ns | Note 1 |
| ts | Set to Output Delay |  |  | 30 | ns | Note 1 |
| te | Output Enable/Disable Time |  |  | 45 | ns | Note 1 |
| tc | Clear to Output Delay |  |  | 55 | ns | Note 1 |

CAPACITANCE* $F=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{VCC}=+5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Test | Limits |
| :---: | :---: | :---: |
|  |  | Typ. Max. |
| CIN | DS1 MD Input Capacitance | 9pF 12pF |
| CIN | DS2, CK, ACK, DI 1 -DI 8 Input Capacitance | 5pF 9pF |
| Cout | $\mathrm{DO}_{1-\mathrm{DO}}^{8}$ Output Capacitance | 8pF 12pF |

*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 5ns
Between 1V and 2 V Measurements made at 1.5 V with 15 mA and 30 pF Test Load

Note 1:

| Test | $C_{L}{ }^{*}$ | $\mathrm{R}_{1}$ | $\mathbf{R}_{2}$ |
| :---: | :---: | :---: | :---: |
| tpd, twe, $\mathrm{tr}_{\mathrm{R}}, \mathrm{ts}^{\text {, }} \mathrm{tc}$ | 30pF | $300 \Omega$ | $600 \Omega$ |
| $\mathrm{t}_{\mathrm{E},}$ ENABLE! | 30pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| te, ENABLE ! | 30pF | $300 \Omega$ | $600 \Omega$ |
| te, DISABLE $\dagger$ | 5 pF | $300 \Omega$ | $600 \Omega$ |
| te, DISABLE | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

*Includes probe and jig capacitance.

TIMING DIAGRAM


DATA


STB or $\overline{\mathrm{DS}}_{1} \cdot \mathrm{DS}_{2}$


STB

an
PRIORITY INTERRUPT CONTROL UNIT

\author{

- 8 Priority Levels <br> - Current Status Register <br> - Priority Comparator
}


# - Fully Expandable <br> - High Performance ( $\mathbf{5 0} \mathbf{n s}$ ) 

- 24-Pin Dual In-Line Package

The Intel ${ }^{\circ} 8214$ is an 8 -level priority interrupt control unit (PICU) designed to simplify interrupt-driven microcomputer systems.
The PICU can accept 8 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 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 interruptdriven microcomputer systems.
"Note: The specifications for the 3214 are identical with those for the 8214.

PIN CONFIGURATION


PIN NAMES

| INPUTS |  |
| :---: | :---: |
| Re-k7 | REQUEST LEVELS (R, HIGHEST PRIORITY) |
| $\mathrm{B}_{0} \cdot \mathrm{CL}_{2}$ | CURRENT STATUS |
| 868 | STATUS GROUP SELECT |
| ECS | ENABLE CUARENT STATUS |
| INTE | InTERRUPT ENABLE |
| $\overline{C L K}$ | CLOCK (INT F.F) |
| ELA | Emable level read |
| ETLG | ENABLE THIS LEVEL GROUP |
| OUTPUTS: |  |
| $\overline{A_{0} \cdot A_{2}}$ | REOUEST LEVELS $]$ OPEN |
| INT | INTERRUPT (ACT. LOW) $]$ COLLECTOR |
| ENLG | ENABLE NEXT LEVEL GROUP |

LOGIC DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$
Storage Temperature $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$
All Output and Supply Voltages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -0.5V to +7V
All Input Voltages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . -1.0V to +5.5V
Output Currents 100 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 specifications is not implied. Exposure to absolute maximum ratings 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 \%$.

| Symbol | Parameter |  | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Typ. ${ }^{11]}$ | Max. |  |  |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage (all inputs) |  |  |  | -1.0 | V | $\mathrm{I}_{C}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Forward Current: | ETLG input all other inputs |  | $\begin{aligned} & \hline-.15 \\ & -.08 \end{aligned}$ | $\begin{gathered} -0.5 \\ -0.25 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Input Reverse Current: | ETLG input all other inputs |  |  | $\begin{aligned} & 80 \\ & 40 \end{aligned}$ | $\begin{aligned} & \mu A \\ & \mu A \end{aligned}$ | $V_{R}=5.25 \mathrm{~V}$ |
| $V_{\text {IL }}$ | Input LOW Voltage: | all inputs |  |  | 0.8 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage: | all inputs | 2.0 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| ICC | Power Supply Current |  |  | 90 | 130 | mA | See Note 2. |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage: | all outputs |  | . 3 | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage: | ENLG output | 2.4 | 3.0 |  | V | $\mathrm{IOH}=-1 \mathrm{~mA}$ |
| los | Short Circuit Output Current: ENLG output |  | -20 | -35 | -55 | mA | $\mathrm{V}_{\mathrm{OS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $I_{\text {CEX }}$ | Output Leakage Current: $\overline{\mathrm{NT}}$ and $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ |  |  |  | 100 | $\mu \mathrm{A}$ | $V_{\text {CEX }}=5.25 \mathrm{~V}$ |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
2. $\mathrm{B}_{0}-B_{2}, \overline{\mathrm{SGS}}, \mathrm{CLK}, \overline{R_{0}} \cdot \cdot \cdot \mathrm{R}_{4}$ grounded, all other inputs and all outputs open.

## A.C. CHARACTERISTICS <br> $\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 |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{11]}$ | Max. |  |
| ${ }_{\text {ter }}$ | $\overline{\text { CLK }}$ Cycle Time | 80 | 50 |  | ns |
| $t_{\text {PW }}$ | $\overline{\text { CLK }}$, ECS, $\overline{\text { INT P 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 $\overline{C L K}$ | 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}_{\text {ECCS }}{ }^{[2]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{C L K}$ | 80 | 25 |  | ns |
| $\mathrm{t}_{\mathrm{ECCH}}{ }^{[3]}$ | $\overline{\text { ECS }}$ Hold Time After CLK | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{ECRS}}{ }^{[3]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{C L K}$ | 110 | 70 |  | ns |
| $\mathrm{t}_{\mathrm{ECRH}}{ }^{[3]}$ | $\overline{\text { ECS }}$ Hold Time After CLK | 0 |  |  |  |
| $\mathrm{t}_{\mathrm{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{\text { CLK }}$ | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{DCS}}{ }^{[2]}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Setup Time to $\overline{\mathrm{CLK}}$ | 70 | 50 |  | ns |
| $\mathrm{t}_{\mathrm{DCH}}{ }^{[2]}$ | $\overline{\mathrm{SGS}}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{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{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Hold Time After $\overline{\mathrm{CLK}}$ | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{ICS}}$ |  | 55 | 35 |  | ns |
| ${ }^{\text {t }}$ CI | $\overline{\mathrm{CLK}}$ to INT Propagation Delay |  | 15 | 25 | ns |
| $\mathrm{t}_{\text {RIS }}{ }^{\text {[4] }}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to $\overline{\mathrm{INT}}$ | 10 | 0 |  | ns |
| $\mathrm{t}_{\text {RIH }}{ }^{[4]}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Hold Time After $\overline{\mathrm{INT}}$ | 35 | 20 |  | ns |
| $\mathrm{t}_{\text {RA }}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 80 | 100 | ns |
| $t_{\text {ELA }}$ | $\overline{\text { 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 |
| $\mathrm{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}}$ | 15 | 10 |  | ns |
| ${ }_{\text {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 |
| $\mathrm{t}_{\text {ETEN }}$ | ETLG to ENLG Propagation Delay |  | 20 | 25 | ns |
| teCRN | $\overline{\text { ECS }}$ to ENLG Propagation Delay |  | 85 | 90 | ns |
| $\mathrm{t}_{\text {ECSN }}$ | $\overline{\text { ECS }}$ to ENLG Propagation Delay |  | 35 | 55 | ns |

## CAPACITANCE ${ }^{[5]}$

|  |  | Limits |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Typ. ${ }^{11]}$ | Max |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 5 | 10 | pF |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance |  | 7 | 12 | pF |

Test Conditions: $\quad \mathrm{V}_{\mathrm{BIAS}}=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) $\mathrm{T}_{\text {ypical values are for }} \mathrm{T}_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=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.


## 8216/8226 <br> 4-BIT PARALLEL BIDIRECTIONAL BUS DRIVER

## Data Bus Buffer Driver for 8080 CPU <br> - Low Input Load Current - 0.25 mA Maximum

High Output Drive Capability for Driving System Bus

# - 3.65V Output High Voltage for Direct Interface to $\mathbf{8 0 8 0}$ CPU 

- 3-State Outputs
- Reduces System Package Count

The $8216 / 8226$ is a 4-bit bidirectional 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.
*Note: The specifications for the $3216 / 3226$ are identical with those for the $8216 / 8226$.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{DB}_{0} \cdot \mathrm{DB}_{3}$ | DATA BUS <br> BI-DIRECTIONAL |
| :--- | :--- |
| $\mathrm{DI}_{0} \cdot \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


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.

## Bidirectional 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 \mathrm{~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 $\overline{\text { DIEN, }} \overline{\mathbf{C S}}$

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 $\overline{\text { 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

| $\overline{\text { DIEN }}$ | $\overline{C S}$ |  |
| :---: | :---: | :--- |
| 0 | 0 | $D I \cdot D B$ |
| 1 | 0 | $D B: D O$ |
| 0 | 1 | -HIGH IMPEDANCE |
| 1 | 1 | J |

Figure 1. 8216/8226 Logic Diagrams

## WAVEFORMS



## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+\right\lrcorner \mathrm{V} \pm 5 \%$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. |  |  |
| TPD1 | Input to Output Delay DO Outputs |  | 15 | 25 | ns | $\begin{aligned} & C_{L}=30 \mathrm{pF}, R_{1}=300 \Omega \\ & R_{2}=600 \Omega \end{aligned}$ |
| $T_{\text {PD2 }}$ | Input to Output Delay DB Outputs 8216 |  | 19 | 30 | ns | $\begin{aligned} & C_{L}=300 \mathrm{pF}, \mathrm{R}_{1}=90 \Omega \\ & \mathrm{R}_{2}=180 \Omega \end{aligned}$ |
|  | 8226 |  | 16 | 25 | ns |  |
| $\mathrm{T}_{\mathrm{E}}$ |  |  | 42 | 65 | ns | (Note 2) |
|  |  |  | 36 | 54 | ns | (Note 3) |
| $T_{\text {D }}$ | Output Disable Time |  | 16 | 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]}$
Test Load Circuit


| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{\text {[1] }}$ | Max. |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 4 | 8 | pF |
| Couti | Output Capacitance |  | 6 | 10 | pF |
| Cout2 | Output Capacitance |  | 13 | 18 | pF |

Test Conditions $\quad 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}, f=1 \mathrm{MHz}$.
NOTES: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, 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 p F, 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 p F, 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.

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

## 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 \%$

| 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 | $\mathrm{V}_{\mathrm{F}}=0.45$ |
| $\mathrm{I}_{\mathrm{R} 1}$ | Input Leakage Current $\overline{\text { DIEN, }} \overline{\text { CS }}$ |  |  | 80 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R} 2}$ | Input Leakage Current DI Inputs |  |  | 40 | $\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}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| $\|10\|$ | 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 {cc }}$ | Power Supply Current |  | 95 | 130 | mA |  |
|  |  |  | 85 | 120 | 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}_{\text {OL2 }}$ | Output "Low" Voltage |  | 0.5 | . 6 | V | DB Outputs $\mathrm{lOL}=55 \mathrm{~mA}$ |
|  |  |  | 0.5 | . 6 | V | DB Outputs $\mathrm{IOL}=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{IOH}=-10 \mathrm{~mA}$ |
| !os | 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}$, <br> 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}$.

## APPLICATIONS OF THE 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 small, 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 \mathrm{~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 Bidirectional 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 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 ${ }^{\circledR} 8255 \mathrm{~s}$, and can be used for both input and output ports. The $\overline{1 / O R}$ signal is connected directly to the $\overline{\text { DIEN }}$ 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 Bidirectional Bus

## 8085A/8085A-2 SINGLE CHIP 8-BIT N-CHANNEL MICROPROCESSORS

- Single +5V Power Supply
- 100\% Software Compatible with 8080A
- $1.3 \mu$ s Instruction Cycle (8085A); $0.8 \mu \mathrm{~s}$ (8085A-2)
- On-Chip Clock Generator (with External Crystal, LC or RC Network)
- On-Chip System Controller; Advanced Cycle Status Information Available for Large System Control

Four Vectored Interrupt Inputs (One is non-Maskable) Plus an 8080Acompatible interrupt

Serial In/Serial Out Port
Decimal, Binary and Double Precision Arithmetic

Direct Addressing Capability to 64k Bytes of Memory

The Intel® 8085A is a 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 8080A's performance by higher system speed. Its high level of system integration allows a minimum system of three IC's [8085A (CPU), 8156 (RAM/IO) and 8355/8755A (ROM/PROM/IO)] while maintaining total system expandability. The 8085A-2 is a faster version of the 8085A.

The 8085A incorporates all of the features that the 8224 (clock generator) and 8228 (system controller) provided for the 8080A, thereby offering a high level of system integration.
The 8085A uses a multiplexed data bus. The address is split between the 8 bit address bus and the 8 bit data bus. The on-chip address latches of 8155/8156/8355/8755A memory products allow a direct interface with the 8085A.


Figure 1. 8085A CPU Functional Block Diagram


Figure 2. 8085A Pinout Diagram

## 8085A FUNCTIONAL PIN DEFINITION

The following describes the function of each pin:

## Symbol

$\mathbf{A}_{8}-\mathbf{A}_{15}$
(Output, 3-state)

AD0-7
(Input/Output, 3-state)

ALE
(Output)

## $S_{0}, S_{1}$, and $10 / \bar{M}$

 (Output)
## Function

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 and during RESET.
Multiplexed Address/Data Bus: Lower 8 bits of the memory address (or I/O address) appear on the bus during the first clock cycle (T state) of a machine cycle. It then becomes the data bus during the second and third clock cycles.
Address Latch Enable: It occurs during the first clock state of a machine cycle 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. The falling edge of ALE can also be used to strobe the status information. ALE is never 3-stated.

Machine cycle status:

| $\frac{10 / \bar{M}}{}$ | $\frac{\mathbf{S}_{1}}{0}$ | $\frac{\mathbf{S}_{0}}{}$ | Status |
| :--- | :--- | :--- | :--- |
| 0 | 1 | Memory write |  |
| 0 | 1 | 0 | Memory read |
| 1 | 0 | 1 | I/O write |
| 1 | 1 | 0 | I/O read |
| 0 | 1 | 1 | Opcode fetch |
| 1 | 1 | 1 | Interrupt Acknowledge |
| $*$ | 0 | 0 | Halt |
| * | X | X | Hold |
| * | X | X Reset |  |
| * $=3$-state (high impedance) |  |  |  |
| X $=$ unspecified |  |  |  |

## Symbol

## $\overline{R D}$

(Output, 3-state)
(Output, 3-state)

READY
(Input)

HOLD
(Input)

HLDA (Output)

INTR
(Input)

## 8085A FUNCTIONAL PIN DESCRIPTION (Continued)

| Symbol |
| :--- |
| INTA <br> (Output) |
|  |
|  |
| RST 5.5 |
| RST 6.5 |
| RST 7.5 |
| (Inputs) |

TRAP (Input)

RESET IN (Input)

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

RESTART INTERRUPTS: These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted.
The priority of these interrupts is ordered as shown in Table 1. These interrupts have a higher priority than INTR. In addition, they may be individually masked out using the SIM instruction.

Trap interrupt is a nonmaskable RESTART interrupt. It is recognized at the same time as INTR or RST 5.5-7.5. It is unaffected by any mask or Interrupt Enable. It has the highest priority of any interrupt. (See Table 1.)
Sets the Program Counter to zero and resets the Interrupt Enable and HLDA flip-flops. The data and address buses and the control lines are 3 -stated during RESET and because of the asynchronous nature of RESET, the processor's internal registers and flags may be altered by RESET with unpredictable results. $\overline{\text { RESET IN }}$ is a
Symbol
RESET OUT
(Output)
(Input)
(In
CLK
(Output)
SID
(Input)
SOD
(Output)
VCC
VSS

TABLE 1. INTERRUPT PRIORITY, RESTART ADDRESS, AND SENSITIVITY

| Name | Priority | Address Branched To (1) <br> When Interrupt Occurs | Type Trigger |
| :--- | :---: | :--- | :--- |
| TRAP | 1 | 24 H | Rising edge AND high level until sampled. |
| RST 7.5 | 2 | 3 H | Rising edge (latched). |
| RST 6.5 | 3 | 34 H | High level until sampled. |
| RST 5.5 | 4 | 2 CH | High level until sampled. |
| INTR | 5 | See Note (2). | High level until sampled. |

NOTES:
(1) The processor pushes the PC on the stack before branching to the indicated address.
(2) The address branched to depends on the instruction provided to the cpu when the interrupt is acknowledged.

## FUNCTIONAL DESCRIPTION

The 8085A 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 (8085A) or 5 MHz (8085A-2), thus improving on the present 8080A's performance with higher system speed. Also it is designed to fit into a minimum system of three IC's: The cpu (8085A), a RAM/IO (8156), and a ROM or EPROM/IO chip (8355 or 8755A).
The 8085A has twelve addressable 8-bit registers. Four of them can function only as two 16 -bit register pairs. Six others can be used interchangeably as 8-bit registers or as 16-bit register pairs. The 8085A register set is as follows:

| Mnemonic |  | Register | Contents |
| :--- | :--- | :--- | :--- |
| ACC or A |  | Accumulator | bits |
| PC | PCogram Counter | 16 -bit address |  |
|  | General-Purpose <br> Registers; data <br> pointer (HL) | 8 bits $\times 6$ or <br> 16 bits $\times 3$ |  |
| SP | Stack Pointer | 16-bit address |  |
| Flags or F | Flag Register | 5 flags (8-bit space) |  |

The 8085A 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 T state (clock cycle) of a machine cycle the low order address is sent out on the Address/Data bus. These lower 8 bits may be latched externally by the Address Latch Enable signal (ALE). During the rest of the machine cycle the data bus is used for memory or I/O data.
The 8085A provides $\overline{R D}, \overline{W R}, S_{0}, S_{1}$, and $I O / \bar{M}$ signals for bus control. An Interrupt Acknowledge signal (INTA) is also provided. HOLD, READY, and all Interrupts are synchronized with the processor's internal clock. The 8085A also provides Serial Input Data (SID) and Serial Output Data (SOD) lines for simple serial interface.
In addition to these features, the 8085A has three maskable, vector interrupt pins and one nonmaskable TRAP interrupt.

## INTERRUPT AND SERIAL I/O

The 8085A has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP. INTR is identical in function to the 8080A INT. Each of the three RESTART inputs, 5.5, 6.5, and 7.5, has a programmable mask. TRAP is also a RESTART interrupt but it is nonmaskable.
The three maskable interrupts cause the internal execution of RESTART (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 RESTART vector independent of the state of the interrupt enable or masks. (See Table 1.)
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. (See Section 2.2.7.) 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 8085A. 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. (See SIM, Chapter 4.)
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 an RST 7.5 routine if the interrupts are re-enabled before the end of the RST 7.5 routine.
The TRAP interrupt is useful for catastrophic events 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 remain high until it is acknowledged. It will not be recognized again until it goes low, then high again. This avoids any false triggering due to noise or logic glitches. Figure 3 illustrates the TRAP interrupt request circuitry within the 8085A. 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 EI instruction is executed.


## Figure 3. TRAP and RESET IN Circuit

The TRAP interrupt is special in that it disables interrupts, but preserves the previous interrupt enable status. Performing the first RIM instruction following a TRAP interrupt allows you to determine whether interrupts were enabled or disabled prior to the TRAP. All subsequent RIM instructions provide current interrupt enable status. Performing a RIM instruction following INTR, or RST 5.5-7.5 will provide current Interrupt Enable status, revealing that Interrupts are disabled. See the description of the RIM instruction in Chapter 4.
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.

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

You may drive the clock inputs of the 8085A or 8085A-2 with a crystal, an LC tuned circuit, an RC network, or an external clock source. The driving frequency must be at least 1 MHz , and must be twice the desired internal clock frequency; hence, the 8085A is operated with a 6 MHz crystal (for 3 MHz clock), and the 8085A-2 can be operated with a 10 MHz crystal (for 5 MHz clock). If a crystal is used, it must have the following characteristics:
Parallel resonance at twice the clock frequency desired $C_{L}($ load capacitance $) \leq 30 \mathrm{pf}$
$\mathrm{C}_{\text {s }}$ (shunt capacitance) $\leq 7 \mathrm{pf}$
$R_{\text {s }}$ (equivalent shunt resistance) $\leq 75$ Ohms
Drive level: 10 mW
Frequency tolerance: $\pm .005 \%$ (suggested)
Note the use of the 20 pf capacitors between $X_{1}, X_{2}$ and ground. These capacitors are required with crystal frequencies below 4 MHz to assure oscillator startup at the correct frequency. A parallel-resonant LC circuit may be used as the frequency-determining network for the 8085A, providing that its frequency tolerance of approximately $\pm 10 \%$ is acceptable. The components are chosen from the formula:

$$
f=\frac{1}{2 \pi \sqrt{L\left(C_{e x t}+C_{i n t}\right)}}
$$

To minimize variations in frequency, it is recommended that you choose a value for $\mathrm{C}_{\text {ext }}$ that is at least twice that of $\mathrm{C}_{\mathrm{int}}$, or 30 pF . The use of an LC circuit is not recommended for frequencies higher than approximately 5 MHz .
An RC circuit may be used as the frequency-determining network for the 8085A if maintaining a precise clock frequency is of no importance. Variations in the on-chip timing generation can cause a wide variation in frequency when using the RC mode. Its advantage is its low component cost. The driving frequency generated by the circuit shown is approximately 3 MHz . It is not recommended that frequencies greatly higher or lower than this be attempted.
Figure 4 shows the recommended clock driver circuits. Note in D and E that pullup resistors are required to assure that the high level voltage of the input is at least 4 V .

For driving frequencies up to and including 6 MHz you may supply the driving signal to $X_{1}$ and leave $X_{2}$ opencircuited (Figue 4D). If the driving frequency is from 6 MHz to 10 MHz , stability of the clock generator will be improved by driving both $\mathrm{X}_{1}$ and $\mathrm{X}_{2}$ with a push-pull source (Figure $4 \mathrm{E})$. To prevent self-oscillation of the 8085A, be sure that $X_{2}$ is not coupled back to $X_{1}$ through the driving circuit.

C. RC Circuit Clock Driver

D. 1-6 MHz Input Frequency External Clock Driver Circult

E. 1-10 MHz Input Frequency External Clock Driver Circuit

Figure 4. Clock Driver Circuits

## GENERATING AN 8085A WAIT STATE

If your system requirements are such that slow memories or peripheral devices are being used, the circuit shown in Figure 5 may be used to insert one WAIT state in each 8085A machine cycle

The D flip-flops should be chosen so that

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


Figure 5. Generation of a Wait State for 8085A CPU
As in the 8080, the READY line is used to extend the read and write pulse lengths so that the 8085A can be used with slow memory. HOLD causes the cpu to relinquish the bus when it is through with it by floating the Address and Data Buses.

## SYSTEM INTERFACE

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

- 2K Bytes ROM
- 256 Bytes RAM
- 1 Timer/Counter
- 4 8-bit I/O Ports
- 1 6-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 6.

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 I/O address, thereby, using the memory address for I/O manipulation. Figure 7 shows the system configuration of Memory Mapped I/O using 8085A.

The 8085A 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 8.

"NOTE: OPTIONAL CONNECTION

Figure 6. 8085A Minimum System (Standard I/O Technique)


Figure 7. MCS-85™ Minimum System (Memory Mapped I/O)


Figure 8. MCS-85™ System (Using Standard Memories)

## BASIC SYSTEM TIMING

The 8085A has a multiplexed Data Bus. ALE is used as a strobe to sample the lower 8-bits of address on the Data Bus. Figure 9 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction). 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.
There are seven possible types of machine cycles. Which of these seven takes place is defined by the status of the three status lines ( $\mathrm{IO} / \overline{\mathrm{M}}, \mathrm{S}_{1}, \mathrm{~S}_{0}$ ) and the three control signals ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{NTA}}$ ). (See Table 2.) The status lines can be used as advanced controls (for device selection, for example), since they become active at the $\mathrm{T}_{1}$ state, at the outset of each machine cycle. Control lines $\overline{R D}$ and $\overline{W R}$ become active later, at the time when the transfer of data is to take place, so are used as command lines.
A machine cycle normally consists of three $T$ states, with the exception of OPCODE FETCH, which normally has either four or six T states (unless WAIT or HOLD states are forced by the receipt of READY or HOLD inputs). Any T state must be one of ten possible states, shown in Table 3.

TABLE 2. 8085A MACHINE CYCLE CHART

| MACHINE CYCLE |  |  | STATUS |  |  | CONTROL |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $10 / \bar{M}$ | S1 | so | $\overline{\text { RD }}$ | $\overline{W R}$ | INTA |
| OPCODE FETCH | (OF) |  | 0 | 1 | 1 | 0 | 1 | 1 |
| MEMORY READ | (MR) |  | 0 | 1 | 0 | 0 | 1 | 1 |
| MEMORY WRITE | (MW) |  | 0 | 0 | 1 | 1 | 0 | 1 |
| I/O READ | (IOR) |  | 1 | 1 | 0 | 0 | 1 | 1 |
| I/O WRITE | (IOW) |  | 1 | 0 | 1 | 1 | 0 | 1 |
| ACKNOWLEDGE |  |  |  |  |  |  |  |  |
| OF INTR | (INA) |  | 1 | 1 | 1 | 1 | 1 | 0 |
| BUS IDLE | (BI). | DAD | 0 | 1 | 0 | 1 | 1 | 1 |
|  |  | ACK OF |  |  |  |  |  |  |
|  |  | RST,TRAP | 1 | 1 | 1 | 1 | 1 | 1 |
|  |  | HALT | TS | 0 | 0 | TS | TS | 1 |

TABLE 3. 8085A MACHINE STATE CHART

| Machine State | Status \& Buses |  |  |  | Control |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | S1,s0 | 10/M | $A_{8}-A_{15}$ | $\mathrm{AD}_{0}-\mathrm{AD}_{7}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $\overline{\text { INTA }}$ | ALE |
| $\mathrm{T}_{1}$ | X | $x$ | $X$ | X | 1 | 1 | $1^{*}$ |
| $\mathrm{T}_{2}$ | $x$ | x | $x$ | $x$ | $x$ | $x$ | 0 |
| TWAIT | $x$ | $x$ | $x$ | $x$ | $x$ | $x$ | 0 |
| $\mathrm{T}_{3}$ | X | X | $x$ | X | X | X | 0 |
| $\mathrm{T}_{4}$ | 1 | 0 + | $x$ | TS | 1 | 1 | 0 |
| $\mathrm{T}_{5}$ | 1 | $0{ }^{\prime}$ | $x$ | TS | 1 | 1 | 0 |
| $\mathrm{T}_{6}$ | 1 | 0 ' | X | TS | 1 | 1 | 0 |
| Treset | X | TS | TS | TS | TS | 1 | 0 |
| Thalt | 0 | TS | TS | TS | TS | 1 | 0 |
| THOLD | X | TS | TS | TS | TS | 1 | 0 |

$0=$ Logic " 0 " $\quad$ TS $=$ High Impedance
$1=$ Logic " 1 " $X=$ Unspecified

* ALE not generated during 2 nd and 3rd machine cycles of DAD instruction $+10 / \mathrm{M}=1$ during $\mathrm{T}_{4}-\mathrm{T}_{6}$ of INA machine cycle.


Figure 9. 8085A Basic System Timing

## TABLE 4. ABSOLUTE MAXIMUM RATINGS*

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

TABLE 5. 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 \% ; \mathrm{V}_{S S}=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}_{\mathrm{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}_{\text {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 |  |

TABLE 6. 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{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | 8085A ${ }^{[2]}$ |  | $\begin{gathered} 8085 \mathrm{~A}-2^{[2]} \\ \text { (Preliminary) } \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {cre }}$ | CLK Cycle Period | 320 | 2000 | 200 | 2000 | ns |
| $\mathrm{f}_{1}$ | $\text { CLK Low Time - Standard } 150 \mathrm{pFF} \text { Loading }$ | $\begin{array}{r} 80 \\ 100 \end{array}$ |  | 40 |  | ns ns |
| $t_{2}$ | $\text { CLK High Time }-\underset{\text { Lightly Loaded }{ }^{[8]}}{\text { Staading }}$ | $\begin{aligned} & 120 \\ & 150 \end{aligned}$ |  | 70 |  | ns ns |
| $t_{r}, t_{f}$ | CLK Rise and Fall Time |  | 30 |  | 30 | ns |
| ${ }^{\text {tXKR }}$ | $X_{1}$ Rising to CLK Rising | 30 | 120 | 30 | 100 | ns |
| ${ }^{\text {t }}$ XKF | $X_{1}$ Rising to CLK Falling | 30 | 150 | 30 | 110 | ns |
| $t_{A C}$ | $\mathrm{A}_{8-15}$ Valid to Leading Edge of Control ${ }^{[1]}$ | 270 |  | 115 |  | ns |
| $t_{\text {ACL }}$ | $\mathrm{A}_{0-7}$ Valid to Leading of Control | 240 |  | 115 |  | ns |
| $t_{A D}$ | $A_{0-15}$ Valid to Valid Data In |  | 575 |  | 350 | ns |
| $t_{\text {AFR }}$ | Address Float after Leading Edge of $\overline{\text { READ }}$ ( $\overline{\text { INTA }}$ ) |  | 0 |  | 0 | ns |
| $t_{\text {AL }}$ | $\mathrm{A}_{8-15}$ Valid before Trailing Edge of ALE ${ }^{[1]}$ | 115 |  | 50 |  | ns |
| $t_{\text {ALL }}$ | $A_{0-7}$ Valid before Trailing Edge of ALE | 90 |  | 50 |  | ns |
| $t_{\text {ARY }}$ | READY Valid from Address Valid |  | 220 |  | 100 | ns |
| $t_{\text {ca }}$ | Address ( $\mathrm{A}_{8}-\mathrm{A}_{15}$ ) Valid after Control | 120 |  | 60 |  | ns |
| $t_{\text {cc }}$ | Width of Control Low ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, $\overline{\text { INTA }}$ ) Edge of ALE | 400 |  | 230 |  | ns |
| $t_{\text {cL }}$ | Trailing Edge of Control to Leading Edge of ALE | 50 |  | 25 |  | ns |
| $t_{\text {DW }}$ | Data Valid to Trailing Edge of WRITE | 420 |  | 230 |  | ns |
| $t_{\text {HABE }}$ | HLDA to Bus Enable |  | 210 |  | 150 | ns |
| $t_{\text {HABF }}$ | Bus Float after HLDA |  | 210 |  | 150 | ns |
| $t_{\text {HACK }}$ | HLDA Valid to Trailing Edge of CLK | 110 |  | 40 |  | ns |
| $t_{\text {HDH }}$ | HOLD Hold Time | 0 |  | 0 |  | ns |
| $t_{\text {HDS }}$ | HOLD Setup Time to Trailing Edge of CLK | 170 |  | 120 |  | ns |
| $\mathrm{t}_{\text {INH }}$ | INTR Hold Time | 0 |  | 0 |  | ns |
| tins | INTR, RST, and TRAP Setup Time to Falling Edge of CLK | 160 |  | 150 |  | ns |
| $t_{\text {LA }}$ | Address Hold Time after ALE | 100 |  | 50 |  | ns |
| $t_{\text {LC }}$ | Trailing Edge of ALE to Leading Edge of Control | 130 |  | 60 |  | ns |
| tLCK | ALE Low during CLK High | 100 |  | 50 |  | ns |
| tLDR | ALE to Valid Data during Read |  | 460 |  | 270 | ns |
| tLDW | ALE to Valid Data during Write |  | 200 |  | 120 | ns |
| $t_{\text {LL }}$ | ALE Width | 140 |  | 80 |  | ns |
| $t_{\text {LRY }}$ | ALE to READY Stable |  | 110 |  | 30 | ns |

TABLE 6. A.C. CHARACTERISTICS (Cont.)

| Symbol | Parameter | 8085A ${ }^{[2]}$ : |  | $\begin{gathered} \text { 8085A-2 }{ }^{[2]} \\ \text { (Preliminary) } \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| trat | Trailing Edge of $\overline{\text { READ }}$ to Re-Enabling of Address | 150 |  | 90 |  | ns |
| trd | $\overline{\text { READ ( }}$ ( $\overline{\text { INTA }}$ ) to Valid Data |  | 300 |  | 150 | ns |
| trv | Control Trailing Edge to Leading Edge of Next Control | 400 |  | 220 |  | ns |
| trin | Data Hold Time After $\overline{\mathrm{READ}} \overline{\mathrm{NTA}}{ }^{[7]}$ | 0 |  | 0 |  | ns |
| $t_{\text {RYM }}$ | READY Hold Time | 0 |  | 0 |  | ns |
| trys | READY Setup Time to Leading Edge of CLK | 110 |  | 100 |  | ns |
| two | Data Valid After Trailing Edge of $\overline{\text { WRITE }}$ | 100 |  | 60 |  | ns |
| tWDL | LEADING Edge of WRITE to Data Valid |  | 40 |  | 20 | ns |

Notes:

1. $A_{8}-A_{15}$ address Specs apply to $I O / \bar{M}, S_{0}$, and $S_{1}$ except $A_{8}-A_{15}$ are undefined during $T_{4}-T_{6}$ of OF cycle whereas $I O / \bar{M}, S_{0}$, and $\mathrm{S}_{1}$ are stable.
2. Test conditions: $\mathrm{t}_{\mathrm{CYC}}=320 \mathrm{~ns}(8085 \mathrm{~A}) / 200 \mathrm{~ns}(8085 \mathrm{~A}-2) ; \mathrm{CL}_{\mathrm{L}}=150 \mathrm{pF}$.
3. For all output timing where $C_{L}=150 \mathrm{pF}$ use the following correction factors: $25 \mathrm{pF} \leq \mathrm{C}_{\mathrm{L}}<150 \mathrm{pF}:-0.10 \mathrm{~ns} / \mathrm{pF}$ $150 \mathrm{pF}<\mathrm{CL}_{\mathrm{L}} \leq 300 \mathrm{pF}:+0.30 \mathrm{~ns} / \mathrm{pF}$
4. Output timings are measured with purely capacitive load
5. All timings are measured at output voltage $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}=2.0 \mathrm{~V}$, and 1.5 V with 20 ns rise and fall time on inputs.
6. To calculate timing specifications at other values of tcyc use Table 7.
7. Data hold time is guaranteed under all loading conditions.
8. Loading equivalent to $50 \mathrm{pF}+1 \mathrm{TTL}$ input.

TABLE 7. BUS TIMING SPECIFICATION AS A Tcyc DEPENDENT

8085A

| ${ }_{\text {t }}$ L | - | (1/2) T-45 | MIN |
| :---: | :---: | :---: | :---: |
| ${ }_{\text {t }}^{\text {LA }}$ | - | (1/2) T-60 | MIN |
| ${ }^{\text {L LL }}$ | - | (1/2) T-20 | MIN |
| ${ }_{\text {L }}^{\text {LCK }}$ | - | (1/2) T-60 | MIN |
| ${ }_{\text {t }}^{\text {L }}$ C | - | (1/2) T-30 | MIN |
| ${ }^{t}{ }_{\text {AD }}$ | - | (5/2+N) T-225 | MAX |
| ${ }^{\text {t }}$ RD | - | $(3 / 2+N) T-180$ | MAX |
| $\mathrm{t}_{\text {RAE }}$ | - | (1/2) T-10 | MIN |
| ${ }^{\text {t }}$ CA | - | (1/2) T-40 | MIN |
| ${ }^{\text {t }}$ W | - | $(3 / 2+N) T-60$ | MIN |
| ${ }^{\text {tw }}$ | - | (1/2) T-60 | MIN |
| ${ }^{\text {t }}$ c | - | $(3 / 2+N) T-80$ | MIN |
| ${ }^{\text {t }} \mathrm{CL}$ | - | (1/2) T-110 | MIN |
| $\mathrm{t}_{\text {ARY }}$ | - | (3/2) T-260 | MAX |
| $\mathrm{t}_{\text {HACK }}$ | - | (1/2) T-50 | MIN |
| $\mathrm{t}_{\text {HABF }}$ | - | (1/2) T+50 | MAX |
| $\mathrm{t}_{\text {HABE }}$ | - | (1/2) T + 50 | 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 |
| $\mathrm{t}_{\text {LDR }}$ | - | (4/2) T-180 | MAX |

NOTE: $\quad N$ is equal to the total WAIT states.
$T=\mathrm{t}_{\mathrm{Cr}} \mathrm{C}$.

8085A-2 (Preliminary)

| ${ }^{\text {t }}$ AL | - | (1/2) T-50 | MIN |
| :---: | :---: | :---: | :---: |
| ${ }_{\text {L }}^{\text {LA }}$ | - | (1/2) T-50 | MIN |
| $\mathrm{t}_{\text {LL }}$ | - | (1/2) T-20 | MIN |
| ${ }_{\text {t LCK }}$ | - | (1/2) T-50 | MIN |
| ${ }_{t}{ }_{\text {LC }}$ | - | (1/2) T-40 | MIN |
| ${ }^{\text {t }}$ AD | - | $(5 / 2+N) T-150$ | MAX |
| $\mathrm{t}_{\mathrm{RD}}$ | - | $(3 / 2+N) T-150$ | MAX |
| $\mathrm{t}_{\text {RAE }}$ | - | (1/2) T-10 | MIN |
| ${ }^{\text {t }}$ CA | - | (1/2) T-40 | MIN |
| ${ }^{\text {t }}$ W | - | $(3 / 2+N) T-70$ | MIN |
| ${ }^{\text {w }}$ D | - | (1/2) T-40 | MIN |
| ${ }^{\text {t }} \mathrm{C}$ | - | $(3 / 2+N) T-70$ | MIN |
| ${ }^{\text {t }}$ cL | - | (1/2) T-75 | MIN |
| ${ }^{\text {t }}$ ARY | - | (3/2) T-200 | MAX |
| $\mathrm{t}_{\text {HACK }}$ | - | (1/2) T-60 | MIN |
| $\mathrm{t}_{\text {HABF }}$ | - | (1/2) T+50 | MAX |
| ${ }^{\text {t }}$ HABE | - | (1/2) T + 50 | MAX |
| ${ }^{t}{ }_{\text {AC }}$ | - | (2/2) T-85 | MIN |
| $\mathrm{t}_{1}$ | - | (1/2) T-60 | MIN |
| $\mathrm{t}_{2}$ | - | (1/2) T-30 | MIN |
| $\mathrm{t}_{\mathrm{R} V}$ | - | (3/2) T-80 | MIN |
| $\mathrm{t}_{\text {LDR }}$ | - | (4/2) T-130 | MAX |

NOTE: $\quad N$ is equal to the total WAIT states.
$T=\mathrm{tc} \mathrm{Yc}$.

Figure 10. Clock Timing Waveform

Read Operation


Write Operation


Read operation with Wait Cycle (Typical) - same READY timing applies to WRITE operation.


Figure 11. 8085A Bus Timing, With and Without Wait

## Hold Operation



Figure 12. 8085A Hold Timing.


Figure 13. 8085A Interrupt and Hold Timing

## TABLE 8. INSTRUCTION SET SUMMARY

|  |  |  | Instruction Codel(1) Clock[2] |  |  |  |  |  |  |  |  | Mnemonic | Description | Instruction Coderll |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Mnemonic | Description |  |  |  |  |  |  |  |  |  | $\mathrm{D}_{7}$ |  | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{O}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{O}_{2}$ | $\mathrm{D}_{1}$ | $D_{0}$ | Cycles |
|  | MOVE, LOAD. AND STORE |  |  |  |  |  |  |  |  |  |  |  | CPE | Call on parity even | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 9/18 |
|  | MOV 11 r 2 | Move register to register | 0 | 1 | D | 0 | D | S | S | S | 4 | CPO | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 9/18 |
|  | MOV M.r | Move register to memory | 0 | 1 | 1 | 1 | 0 | S | S | S | 7 | RETURN |  |  |  |  |  |  |  |  |  |  |
|  | MOV r.M | Move memory to register | 0 | 1 | 0 | D | D | 1 | 1 | 0 | 7 | RET | Return | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
|  | MVI r | Move immediate register | 0 | 0 | 0 | D | D | 1 | 1 | 0 | 7 | RC | Return on carry | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 6/12 |
|  | MVI M | Move immediate memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 | RNC | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 6/12 |
|  | LXIB | Load immediate register | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 | RZ | Return on zero | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 6/12 |
|  |  | Pair B \& C |  |  |  |  |  |  |  |  |  | RNZ | Return on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 6/12 |
|  | LXI D | Load immediate register Pair D \& E | 0 | 0 | 0 | 1 | 0 |  | 0 | 1 | 10 | $\begin{aligned} & \text { RP } \\ & \text { RM } \end{aligned}$ | Return on positive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 6/12 |
|  |  |  | 0 |  |  |  |  | 0 |  |  |  |  | Return on minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 6/12 |
|  | LXI H | Load immediate register Pair H \& L | 0 | 0 | 1 | 0 |  | 0 | 0 | 1 | 10 | RPE | Return on parity even <br> Return on parity odd | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 6/12 |
|  | LXI SP | Load immediate stack pointer | 0 | 0 | 1 | 10 |  | 00 | 00 | 1 | 10 | RESTART |  | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 6/12 |
|  | STAX B | Store A indirect | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 7 | RST | Restart | 1 | 1 | A | A | A | 1 | 1 | 1 | 12 |
|  | STAX D | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 7 | INPUT/OUTPUT |  |  |  |  |  |  |  |  |  |  |
|  | LDAX B | Load A indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 7 | IN | Input | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
|  | LDAX D | Load A indirect | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 7 | OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
|  | STA | Store A direct | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 | INCREMENT AND DECREMENT |  |  |  |  |  |  |  |  |  |  |
|  | LDA | Load A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 | iNR r | Increment register | 0 | 0 | D | D | D | 1 | 0 | 0 | 4 |
|  | SHLD | Store H \& L direct | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 | DCR r | Decrement register | 0 | 0 | D | D | D | 1 | 0 | 1 | 4 |
|  | LHLD | Load H \& L direct | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 | INR M | Increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 |
|  | XCHG | Exchange $D \& E H \& L$ | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 | DCR M | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 |
|  |  | Registers |  |  |  |  |  |  |  |  |  | INX B | Increment B \& C | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 6 |
|  | STACK OPS |  |  |  |  |  |  |  |  |  |  |  | registers |  |  |  |  |  |  |  |  |  |
|  | PUSH B | Push register Paır B \& C on stack | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | 12 | INX D | Increment D \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 6 |
|  | PUSH D | Push register Parr D \& E on stack | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 12 | INXH | Increment H\&L registers | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 6 |
|  | PIJSH H | Push register Pair H \& L on stack | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 12 | INX SP DCX B | Increment stack pointer Decrement B \& C | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 6 |
|  | PUSH PSW | Push A and Flags | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 12 | DCX D | Decrement D \& E | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 6 |
|  |  | on stack |  |  |  |  |  |  |  |  |  | DCX H | Decrement H\&L | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 6 |
|  | POP B | Pop regıster Paır B \& C off stack | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 10 | DCX SP | Decrement stack pointer | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 6 |
| $\begin{aligned} & 18 \\ & 0 \\ & 8 \\ & 0 \\ & 0 \\ & \end{aligned}$ | POP D | Pop register Paır D \& E off stack | 1 | 10 | 0 | 1-0 |  | 00 | 00 | 1 | 10 | ADD |  |  |  |  |  |  |  |  |  |  |
|  | POP H | Pop register Paır H \& | 1 | 1 | 1 | 0 | 0 | O | 0 | 1 | 10 | ADD r | Add register to A | 1 | 0 | 0 | 0 | 0 | S | S | S | 4 |
|  |  | L off stack |  |  |  |  |  |  |  |  |  | ADC r | Add register to A | 1 | 0 | 0 | 0 | 1 | S | S | S | 4 |
|  | POP PSW | Pop A and Flags off stack | 1 | 1 | 1 | 10 |  | 00 | 00 | 1 | 10 | ADD M | with carry Add memory to $A$ | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
|  | XTHL | Exchange top of stack. H \& L | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 16 | ADC M | Add memory to A with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
|  |  | H\&L to stack pointer | 1 | 1 | 1 | 11 |  |  | 0 | 1 | 6 | $\begin{aligned} & \mathrm{ADI} \\ & \mathrm{ACl} \end{aligned}$ | Add immediate to A | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
|  | JUMP |  |  |  |  |  |  |  |  |  |  |  | Add immediate to $A$ with carry | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
|  | JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 10 | DAD B | Add $B$ \& C to H \& L | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
|  | JC | Jump on carry | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 7/10 | DAD D | Add $D \& E$ to $H \& L$ | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 10 |
|  | JNC | Jump on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 7/10 | DAD H | Add H\&L to H \& L | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 |
|  | JZ | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 7/10 | DAD SP | Add stack pointer to | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 |
|  | JNZ | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 7/10 |  | $H \& L$ |  |  |  |  |  |  |  |  |  |
|  | JP | Jump on positıve | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 7/10 | SUBTRAC |  |  |  |  |  |  |  |  |  |  |
|  | JM | Jump on minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 7/10 | SUB r | Subtract register | 1 | 0 | 0 | 1 | 0 | S | S | S | 4 |
|  | JPE | Jump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 7/10 |  | from A- |  |  |  |  |  |  |  |  |  |
|  | JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 7/10 | SBB r | Subtract register from A with borrow | 1 | 0 | 0 | 1 | 1 | S | S | S | 4 |
|  | PCHL | H\&L to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 6 | SUB M | Subtract memory from A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
|  | CALL |  |  |  |  |  |  |  |  |  |  | SBB M |  | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
|  | CALL | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 18 |  | A with borrow |  |  |  |  |  |  |  | 0 |  |
|  | CC | Call on carry | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 9/18 | SUI | Subtract immedıate | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
|  | CNC | Call on no carry | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 9/18 |  | from A |  |  |  |  |  |  |  |  |  |
|  | CZ | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 9/18 | SBI | Subtract immediate | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
|  | CNZ | Call on no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 9/18 |  | from A with borrow |  |  |  |  |  |  |  |  |  |
|  | CP | Call on positive | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 9/18 | LOGICAL |  |  |  |  |  |  |  |  |  |  |
|  | CM | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 9/18 | ANA I | And register with A | 1 | 0 | 1 | 0 | 0 | S | S | S | 4 |

## TABLE 8. INSTRUCTION SET SUMMARY (Continued)

| Mnemonic |  | Instruction Code[1] Clock[2] |  |  |  |  |  |  |  |  | Mnemonic | Description | Instruction Codelı |  |  |  |  |  |  |  | Clock[2] Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Description | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | Cycles |  |  | 07 | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{O}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| XRA r | Exclusive Or register with A | 1 | 0 | 1 | 0 | 1 | S | S | S | 4 | RAL | Rotate A left through carry | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4 |
| ORA r | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S | S | 4 | RAR | Rotate A right through | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 |
| CMP r | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | S | S | 4 |  | carry |  |  |  |  |  |  |  |  |  |
| ANA M | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 7 | SPECIALS |  |  |  |  |  |  |  |  |  |  |
| XRA M | Exclusive Or memory | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 7 | CMA | Complement A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 4 |
|  | with A |  |  |  |  |  |  |  |  |  | STC | Set carry | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| ORA M | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 7 | CMC | Complement carry | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| CMP M | Compare memory with A | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 7 | DAA | Decımal adjust A | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| ANI | And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 7 | CONTROL |  |  |  |  |  |  |  |  |  |  |
| XRI | Exclusive Or immediate with A | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 7 | EI | Enable Interrupts | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| ORI | Or immediate with A | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 7 | DI | Disable Interrupt | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 |
| CPI | Compare immediate | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 7 | NOP | No-operation | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
|  | with A |  |  |  |  |  |  |  |  |  | HLT | Halt | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 5 |
| ROTATE |  |  |  |  |  |  |  |  |  |  | NEW 8085 | NSTRUCTIONS |  |  |  |  |  |  |  |  |  |
| RLC | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 4 | RIM | Read Interrupt Mask | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 4 |
| RRC | Rotate A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 4 | SIM | Set interrupt Mask | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 4 |

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
*All mnemonics copyright ©Intel Corporation 1977

## 8155/8156/8155-2/8156-2 2048 BIT STATIC MOS RAM WITH I/O PORTS AND TIMER

| 8085A | 8085A-2 | Compatible <br> CPUChip <br> Enable |
| :---: | :---: | :---: |
| 8155 | $8155-2$ | ACTIVE LOW |
| 8156 | $8156-2$ | ACTIVE HIGH |

- 256 Word x 8 Bits
- Single +5V 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 {T" }}$ microcomputer system. The RAM portion is designed with 2048 static cells organized as $256 \times 8$. They have a maximum access time of 400 ns to permit use with no wait states in 8085A CPU. The 8155-2 and 8156-2 have maximum access times of 330 ns for use with the 8085A-2.

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 depending on timer mode.

PIN CONFIGURATION


BLOCK DIAGRAM


[^11]
## 8155/8156 PIN FUNCTIONS

Symbol

| RESET |
| :--- |
| (input) |

AD0-7

## $\overline{R D}$

(input)

## $\overline{W R}$

(input)

Function
Pulse provided by the 8085A to initialize the system (connect to 8085A RESET OUT). Input high on this line resets the chip and initializes the three I/O ports to input mode. The width of RESET pulseshould typically be two 8085A clock cycle times.
3-state Address/Data lines that interface with the CPU lower 8-bit Address/Data Bus. The 8-bit address is latched into the address latch inside the $8155 / 56$ on the falling edge of ALE. The address can be either for the memory section or the I/O section depending on the $10 / \bar{M}$ input. The 8 -bit data is either written into the chip or read from the chip, depending on the $\overline{W R}$ or $\overline{R D}$ input signal.
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.
Read control: Input low on this line with the Chip Enable active enables and $\mathrm{AD}_{0-7}$ buffers. If $1 \mathrm{O} / \overline{\mathrm{M}}$ pin is low, the RAM content will be read out to the AD bus. Otherwise the content of the selected I/O port or command/ status registers will be read to the AD bus.
Write control: Input low on this line with the Chip Enable active causes the data on the Address/Data bus to be written to the RAM or I/O ports and command/status register depending on $10 / \bar{M}$.
$\left.\begin{array}{ll}\text { Symbol } & \text { Function } \\ \text { ALE } \\ \text { (input) }\end{array} \quad \begin{array}{l}\text { Address Latch Enable: This control } \\ \text { signallatches both the address on the } \\ \text { ADo-7 lines and the state of the Chip }\end{array}\right\}$

## 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.5 V to +7 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 $\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 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\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}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{BL}=2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {cc }}$ to 0 V |
| LLo | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| Icc | $\mathrm{V}_{\text {cc }}$ Supply Current |  | 180 | mA |  |
| $\mathrm{I}_{1}$ (CE) | Chip Enable Leakage 8155 <br> 8156 |  | $\begin{aligned} & +100 \\ & -100 \end{aligned}$ | ${ }_{\mu \mathrm{A}}^{\mu \mathrm{A}}$ | $V_{\text {IN }}=V_{\text {CC }}$ to 0 V |

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 \%$ )

|  |  | 8155/8156 |  | $\begin{gathered} \text { 8155-2/8156-2 } \\ \text { (Preliminary) } \\ \hline \end{gathered}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN. | MAX. | MIN. | MAX. | UNITS |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | 30 |  | ns |
| $t_{\text {LA }}$ | Address Hold Time after Latch | 80 |  | 30 |  | ns |
| $\mathrm{t}_{\mathrm{LC}}$ | Latch to READ/WRITE Control | 100 |  | 40 |  | ns |
| $t_{\text {RD }}$ | Valid Data Out Delay from READ Control |  | 170 |  | 140 | ns |
| $t_{A D}$ | Address Stable to Data Out Valid |  | 400 |  | 330 | ns |
| $t_{L L}$ | Latch Enable Width | 100 |  | 70 |  | ns |
| $\mathrm{t}_{\text {RDF }}$ | Data Bus Float After READ | 0 | 100 | 0 | 80 | ns |
| ${ }^{\text {t }}$ CL | READNRITE Control to Latch Enable | 20 |  | 10 |  | ns |
| ${ }^{\text {t C }}$ | READ/WRITE Control Width | 250 |  | 200 |  | ns |
| ${ }^{\text {t }}$ WW | Data In to WRITE Set Up Time | 150 |  | 100 |  | ns |
| two | Data In Hold Time After WRITE | 0 |  | 0 |  | ns |
| $t_{\text {R }} \mathrm{V}$ | Recovery Time Between Controls | 300 |  | 200 |  | ns |
| $t_{\text {WP }}$ | WRITE to Port Output |  | 400 |  | 300 | ns |
| $t_{\text {PR }}$ | Port Input Setup Time | 70 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{R} P}$ | Port Input Hold Time | 50 |  | 10 |  | ns |
| ${ }^{\text {t SBF }}$ | Strobe to Buffer Full |  | 400 |  | 300 | ns |
| ${ }_{\text {tSS }}$ | Strobe Width | 200 |  | 150 |  | ns |
| $t_{\text {Rbe }}$ | READ to Buffer Empty |  | 400 |  | 300 | ns |
| ${ }^{\text {t }}$ S | Strobe to INTR On |  | 400 |  | 300 | ns |
| $t_{\text {RDI }}$ | READ to INTR Off |  | 400 |  | 300 | ns |
| tpss | Port Setup Time to Strobe Strobe | 50 |  | 0 |  | ns |
| ${ }^{\text {tPHS }}$ | Port Hold Time After Strobe | 120 |  | 100 |  | ns |
| ${ }^{\text {t SBE }}$ | Strobe to Buffer Empty |  | 400 |  | 300 | ns |
| ${ }^{\text {twBF }}$ | WRITE to Buffer Full |  | 400 |  | 300 | ns |
| $t_{W I}$ | WRITE to INTR Off |  | 400 |  | 300 | ns |
| ${ }^{\text {t }}$ L | TIMER-IN to TIMER-OUT Low |  | 400 |  | 300 | ns |
| ${ }_{\text {t }}^{\text {H }}$ | TIMER-IN to $\overline{\text { TIMER - }}$ OUT High |  | 400 |  | 300 | ns |
| $t_{\text {RDE }}$ | Data Bus Enable from READ Control | 10 |  | 10 |  | ns |
| $\mathrm{t}_{1}$ | TIMER-IN Low Time | 80 |  | 40 |  | ns |
| $\mathrm{t}_{2}$ | TIMER-IN High Time | 120 |  | 70 |  | ns |

## WAVEFORMS

## a. Read Cycle


b. Write Cycle


Figure 1. 8155/8156 Read/Write Timing Diagrams
a. Strobed input Mode

b. Strobed Output Mode


Figure 2. Strobed I/O Timing

## a. Basic Input Mode


b. Basic Output Mode

*DATA BUS TIMING IS SHOWN IN FIGURE 7.

Figure 3. Basic I/O Timing Waveform
 RELOAD MODE ( $\mathrm{M}_{1}$ MODE BIT = 1)

Figure 4. Timer Output Waveform Countdown from 5 to 1

# 8185*/8185-2** <br> $1024 \times 8$-BIT STATIC RAM FOR MCS-85"' 

## *Compatible with 8085A <br> **Compatible with 8085A-2

- Multiplexed Address and Data Bus

Directly Compatible with 8085A Microprocessor

Low Operating Power Dissipation

- Low Standby Power Dissipation

Single +5 V Supply

■ High Density 18-Pin Package

The Intel® 8185 is an 8192-bit static random access memory (RAM) organized as 1024 words by 8 -bits using N -channel Silicon-Gate MOS technology. The multiplexed address and data bus allows the 8185 to interface directly to the 8085A microprocessor to provide a maximum level of system integration
The low standby power dissipation minimizes system power requirements when the 8185 is disabled.
The 8185-2 is a high-speed selected version of the 8185 .

PIN CONFIGURATION


PIN NAMES

| $A D_{0} \cdot A D_{7}$ | ADDRESS/DATA LINES |
| :--- | :--- |
| $A_{8}, A_{9}$ | ADDRESS LINES |
| $\overline{C S}$ | CHIP SELECT |
| $\overline{C E}_{1}$ | CHIP ENABLE $(I O / \bar{M})$ |
| $C E E_{2}$ | CHIP ENABLE |
| $\overline{A L E}$ | ADDRESS LATCH ENABLE |
| $\overline{R D}$ | READ ENABLE |
| $\overline{W R}$ | WRITE ENABLE |

## OPERATIONAL DESCRIPTION

The 8185 has been designed to provide for direct interface to the multiplexed bus structure and bus timing of the 8085A microprocessor.

At the beginning of an 8185 memory access cycle, the 8bit address on $\mathrm{AD}_{0-7}, \mathrm{~A}_{8}$ and $\mathrm{A}_{9}$, and the status of $\overline{C E}_{1}$ and $\mathrm{CE}_{2}$ are all latched internally in the 8185 by the falling edge of ALE . If the latched status of both $\overline{\mathrm{CE}}_{1}$ and $\mathrm{CE}_{2}$ are active, the 8185 powers itself up, but no action occurs until the $\overline{\mathrm{CS}}$ line goes low and the appropriate $\overline{\mathrm{RD}}$ or $\overline{W R}$ control signal input is activated.
The $\overline{\mathrm{CS}}$ input is not latched by the 8185 in order to allow the maximum amount of time for address decoding in selecting the 8185 chip. Maximum power consumption savings will occur, however, only when $\overline{C E_{1}}$ and $C E_{2}$ are activated selectively to power down the 8185 when it is not in use. A possible connection would be to wire the 8085A's $10 / \bar{M}$ line to the 8185 's $\overline{C E} E_{1}$ input, thereby keeping the 8185 powered down during I/O and interrupt cycles.

TABLE 1.
TRUTH TABLE FOR POWER DOWN AND FUNCTION ENABLE

| $\overline{C E}_{1}$ | $C E_{2}$ | $\overline{\mathbf{C S}}$ | $\left(C S^{*}\right)^{[2]}$ | 8185 Status |
| :---: | :---: | :---: | :---: | :---: |
| 1 | X | X | 0 | Power Down and Function Disable[1] |
| $x$ | 0 | x | 0 | Power Down and Function Disable[1] |
| 0 | 1 | 1 | 0 | Powered Up and Function Disable[1] |
| 0 | 1 | 0 | 1 | Powered Up and Enabled |

Notes:
X: Don't Care.
1: Function Disable implies Data Bus in high impedance state and not writing.
2: $\mathrm{CS}^{*}=\left(\overline{C E}_{1}=0\right) \cdot\left(C E_{2}=1\right) \cdot(\overline{C S}=0)$
$C S^{*}=1$ signifies all chip enables and chip select active

TABLE 2.
TRUTH TABLE FOR
CONTROL AND DATA BUS PIN STATUS

| (CS*) | $\overline{\mathbf{R D}}$ | $\overline{\mathrm{WR}}$ | $\mathbf{A D}_{0-7}$ During Data <br> Portion of Cycle | 8185 Function |
| :---: | :---: | :---: | :--- | :--- |
| 0 | X | X | Hi-Impedance | No Function |
| 1 | 0 | 1 | Data from Memory | Read |
| 1 | 1 | 0 | Data to Memory | Write |
| 1 | 1 | 1 | Hi-Impedance | Reading, but not <br> Driving Data Bus |

Note:
X: Don't Care.


Figure 1. 8185 in an MCS-85 System.

## 4 Chips:

2K Bytes ROM
1.25K Bytes RAM

38 I/O Lines
1 Counter/Timer
2 Serial I/O Lines
5 Interrupt Inputs

## 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.5V to +7V |
| Power Dissipation | 1.5W |

*COMMEIv,
Stresses above those listed under "Absolute Maximum "Ratings" "7ry atuse permanent damage to the device. This is a stress rating onfy and furctiorial operation of the device at these or any other conditions,aboye those indicated in the operational sections of this specification is not ingpitad. 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 | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\text {H }}$ | Input High Voltage | 2.0 | Vcc+0.5 | V |  |
| VOL | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=2 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | $\mathrm{IOH}=400 \mu \mathrm{~A}$ |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {cc }}$ to 0 V |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {cc }}$ |
| Icc | Vcc Supply Current Powered Up Powered Down |  | 100 | mA |  |
|  |  |  | 25 | 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 \%$ )

|  | Parameter ${ }^{[1]}$ | 8185Preliminary |  | 8185-2 <br> Preliminary |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Units |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | 30 |  | ns |
| tLA | Address Hold Time After Latch | 80 |  | 30 |  | ns |
| $t \mathrm{tc}$ | Latch to READ/WRITE Control | 100 |  | 40 |  | ns |
| trD | Valid Data Out Delay from READ Control | 170 |  | 140 |  | ns |
| tLD | ALE to Data Out Valid | 300 |  | 200 |  | ns |
| tLL | Latch Enable Width | 100 |  | 70 |  | ns |
| trif | Data Bus Float After READ | 0 | 100 | 0 | 80 | ns |
| tcl | READ/WRITE Control to Latch Enable | 20 |  | 10 |  | ns |
| tcc | READ/WRITE Control Width | 250 |  | 200 |  | ns |
| tow | Data In to WRITE Set Up Time | 150 |  | 150 |  | ns |
| twD | Data In Hold Time After WRITE | 20 |  | 20 |  | ns |
| tsc | Chip Select Set Up to Control Line | 10 |  | 10 |  | ns |
| tcs | Chip Select Hold Time After Control | 10 |  | 10 |  | ns |
| $\mathrm{taLCE}^{\text {a }}$ | Chip Enable Set Up to ALE Falling | 30 |  | 10 |  | ns |
| tlace | Chip Enable Hold Time After ALE | 50 |  | 30 |  | ns |

Notes:

1. All AC parameters are referenced at
a) 2.4 V and .45 V for inputs
b) 2.0 V and .8 V for outputs.


Figure 2. 8185 Timing.

## 8218/8219 <br> BIPOLAR MICROCOMPUTER BUS CONTROLLERS FOR MCS-80"" AND MCS-85"' FAMILIES

## - 8218 for Use in MCS-80 Systems <br> - 8219 for Use in MCS-85 Systems <br> - Coordinates the Sharing of a Common Bus Between Several CPU's

## Reduces Component Count in Multimaster Bus Arbitration Logic <br> Single +5 Volt Power Supply <br> 28 Pin Package

The 8218 and 8219 Microcomputer Bus Controllers consist of control logic which allows a bus master device such as a CPU or DMA channel to interface with other masters on a common bus, sharing memory and I/O devices. The 8218 and 8219 consist of:

1. Bus Arbitration Logic which operates from the Bus Clock ( $\overline{\mathrm{BCLK}}$ ) and resolves bus contention between devices sharing a common bus.
2. Timing Logic which when initiated by the bus arbitration logic generates timing signals for the memory and $1 / O$ command lines to guarantee set-up and hold times of the address/data lines onto the bus. The timing logic also signals to the bus arbitration logic when the current data transfer is completed and the bus is no longer needed.
3. Output Drive Logic which contains the logic and output drivers for the memory and I/O command lines.

An external RC time constant is used with the timing logic to generate the guaranteed address set-up and hold times on the bus. The 8219 can interface directly to the 8085A CPU and the 8218 interfaces to the 8080A CPU chip and the 8257 DMA controller.

PIN CONFIGURATION


|  | 8218 | 8219 |
| :---: | :---: | :---: |
| (A) | IOWR | 10/M |
| (B) | MWTR | WR |
| (c) | $\overline{\text { IORR }}$ | $\overline{\mathrm{RD}}$ |
| (D) | $\overline{\text { MRDR }}$ | $\overline{\text { ASRO }}$ |
| (E) | $\overline{\text { BCR2 }}$ | BCR |

BLOCK DIAGRAM


## 8218/8219 PIN DEFINITIONS

## Signals Interfaced Directly to the System Bus

## $\overline{B R E Q}$ (TTL Output)

The Bus-Request is used with a central parallel priority resolution circuit. It indicates that the device needs to access the bus for one or more data transfers. It is synchronized with the Bus Clock.

## $\overline{\text { BUSY (Input, O.C. Output) }}$

Bus-Busy indicates to all master devices on the bus that the bus is in use. It inhibits any other device from getting the bus. It is synchronized with Bus Clock.

## $\overline{\text { BCLK }}$ (Input)

The negative edge of Bus-Clock is used to synchronize the bus contention resolution circuit asynchronously to the CPU clock. It has $100 \mathrm{~ns} \min$. period, $35 \%-65 \%$ duty cycle. It may be slowed, single stepped or stopped.

## $\overline{\text { BPRN (Input) }}$

The Bus-Priority-In indicates to a device that no device of a higher priority is requesting the bus. It is synchronous with the Bus Clock.

## $\overline{\text { BPRO }}$ (TTL Output)

The Bus-Priority-Out is used with serial priority resolution circuits. Priority may be transferred to the next lower in priority as BPRN.

## $\overline{\text { INIT }}$ (Input)

The Initialize resets the $8218 / 8219$ to a known internal state.

## $\overline{\text { MRDC }}$ (3-State Output)

The Memory-Read-Control indicates that the Master is requesting a read operation from the addressed location. It is asynchronous to the Bus Clock.

## MWTC (3-State Output)

The Memory-Write-Control indicates that data and an address have been placed on the bus by the Master and the data is to be deposited at that location. It is asynchronous to the Bus Clock.

## $\overline{\text { IORC (3-State Output) }}$

The I/O-Read-Control indicates that the Master is requesting a read operation from the I/O device addressed. It is asynchronous to the Bus Clock.

## IOWC (3-State Output)

The 1/O-Write-Control indicates that Data and an I/O device address has been placed on the bus by the Master and the data is to be deposited to the I/O device.

## Signals Generated or Received by the Bus Master <br> BCR1/BCR2 (Inputs)

Bus-Control-Request 1 or Bus-Control-Request 2 indicate to the $8218 / 8219$ that the Master device is making a request to control the bus. BCR2 is active low in the 8218 ( $\overline{\mathrm{BCR2}}$ ). BCR2 is active high in the 8219.

## RSTB (Input)

Request-Strobe latches the status of BCR1 andBCR2 inte the $8218 / 8219$. The strobe is active low in the 8218 and negative edge triggered in the 8219.

## $\overline{\text { ADEN }}$ (TTL Output)

Address-and-Data-Enable indicates the Master has control of the bus. It is often used to enable Address and Data Buffers on the bus. It is synchronous with Bus Clock.

## RDD (TTL Output)

Read-Data controls the direction of the bi-directional data bus drivers. It is asynchronous to the Bus Clock. A high on RDD indicates a read mode by the master.

## OVRD (Input)

Override inhibits automatic deselect between transfers caused by a higher priority bus request. May be used for consecutive data transfers such as read-modify-write operations. It is asynchronous to the Bus Clock.

## XSTR (Input, Rising-Edge-Triggered)

Transfer-Start-Request indicates to the 8218/8219 that a new data transfer cycle is requested to start. It is raised for each new word transfer in a multiple data word transfer. It is asynchronous to the Bus Clock.

## $\overline{X C P}$ (Input, Falling-Edge-Triggered)

Transfer-Complete indicates to the 8218/8219 that the data has been received by the slave device in a write cycle or transmitted by the slave and received by master in a read cycle. It is asynchronous to the Bus Clock.

## $\overline{\mathrm{XCY}}$ (TTL Output)

Indicates that a data transfer is in progress. It is asynchronous to the Bus Clock.
$\overline{W R}, \overline{R D}, I O / \bar{M}(8219$ Only) (Inputs from 8085 to the 8219) WRITE, READ, $10 / \overline{\text { Memory }}$ are the control request inputs used by the 8085 and are internally decoded by the 8219 to produce the request signals $\overline{M R D R}, \overline{M W T R}, \overline{I O R R}, \overline{\text { IOWR }}$. They are asynchronous to the Bus Clock.

## ASRQ (8219 Only) (Input from 8085 System)

Can be used for interrupt status from the 8085. Acts like a level sensitive asynchronous bus request - no RSTB needed. It is asynchronous to the Bus Clock.

## MRDR, $\overline{M W T R}, \overline{\text { IORR, }} \overline{\text { IOWR ( } 8218 \text { Only) (Inputs from }}$ 8080 or 8257 to the 8218)

Memory-Read-Request, Memory-Write-Request, I/O-Read-Request, or 1/O-Write-Request indicate that address and data have been placed on the bus and the appropriate request is being made to the addressed device. Only one of these inputs should be active at any one time. They are asynchronous to the Bus Clock.

## ANYR (TTL Output)

Any-Request is the logical OR of the active state of $\overline{M R D R}$, $\overline{M W T R}, \overline{\text { IORR }}, \overline{\text { IOWR. It may be tied to XSTR when the }}$ rising edge of ANYR is used to initiate a transfer.

## DLYADJ (Input)

Delay-Adjust is used for connection of an external capacitor and resistor to ground to adjust the required set-up and hold time of address to control signal.

## 8218/8219 FUNCTIONAL DESCRIPTION

The $8218 / 8219$ is a bipolar Bus Control Chip which reduces component count in the interface between a master device and the system Bus. (Master device: 8080, 8085, 8257 (DMA).)

The 8218 and 8219 serve three major functions:

1. Resolve bus contention.
2. Guarantee set-up and hold time of address/data lines to I/O and Memory read/write control signals (adjustable by external capacitor).
3. Provide sufficient drive on all bus command lines.

## Bus Arbitration Logic

Bus Arbitration Logic activity begins when the Master makes a request for use of the bus on BCR1 or BCR2. The request is strobed in by $\overline{\operatorname{RSTB}}$. Following the next two falling edges of the bus clock (BCLK) the $8218 / 8219$
outputs a bus request ( $\overline{\mathrm{BREQ}})$ and forces Bus Priority Out inactive (BPRO). See Figures 1a and 1b:
$\overline{B R E Q}$ is used for requesting the bus when priority is decided by a parallel priority resolver circuit.
$\overline{\mathrm{BPRO}}$ is used to allow lower priority devices to gain the bus when a serial priority resolving structure is used. $\overline{\text { BPRO }}$ would go to BPRN of the next lower priority Master.
When priority is granted to the Master (a low on $\overline{B P R N}$ and a high on BUSY) the Master outputs a BUSY signal on the next falling edge of $\overline{B C L K}$. The $\overline{B U S Y}$ signal locks the master onto the bus and prohibits the enable of any other masters onto the bus.
At the same time $\overline{B U S Y}$ goes active, Address and Data Enable (ADEN) goes active signifying that the Master has control of the bus. $\overline{A D E N}$ is often used to enable the bus drivers.

The Bus will be released only if the master loses priority; is not in the middle of a transfer, and Override is not active or, if the Master stops requesting the bus, is not in the middle of a data transfer, and Override is not active. $\overline{\text { ADEN }}$ then goes inactive.
Provision has been made in the 8218 to allow bussynchronous requests. This mode is activated when BCR1, $\overline{B C R 2}$ and $\overline{R S T B}$ are all low. This action asynchronously sets the synchronization flip flop (FF2) in Figure 1 a .


FIGURE 1a. 8218 bUS ARBITRATION LOGIC


FIGURE 1b. 8219 BUS ARBITRATION LOGIC

## Timing Logic

Timing Logic activity begins with the rising edge of XSTR (Transfer Start Request) or with $\overline{\text { ADEN }}$ going active, whichever occurs second. This action causes $\overline{X C Y}$ (Transfer Cycle) to go active. 50-200ns later (depending on resistance and capacitance at DLYADJ) the appropriate Control Outputs will go active if the control input is active.
XSTR can be raised after the command goes active in the current transfer cycle so that a new transfer can be initiated immediately after the current transfer is complete.
A negative going edge on $\overline{\mathrm{XCP}}$ (Transfer Complete) will cause the Control Outputs ( $\overline{\mathrm{MRDC}}$, etc.) to go inactive. $50-200 \mathrm{~ns}$ later (depending on capacitance at DLYADJ) $\overline{X C Y}$ will go inactive indicating the transfer cycle is completed.

Additional logic within the 8218/8219 guarantees that if a transfer cycle is started ( $\overline{\mathrm{XCY}}$ is active), but the bus is not requested ( $\overline{\mathrm{BREQ}}$ is inactive) and there is no command request input (ANYR is output low), then the transfer cycle will be cleared. This allows the bus to be released in applications where advanced bus requests are generated but the processor enters a HALT mode.

## Control Logic

The control outputs are generated in the 8219 by decoding the 8085 system control outputs (i.e., RD, WR, IO/M) or in the 8218 by directly buffering the control inputs to the control outputs for use in an 8080 or DMA system (see Figures 2 a and 2 b ). The control outputs may be held high (inactive) by the Timing Logic. Also the control outputs are enabled when the Master gains control of the bus and disabled when control is relinquished.

The Control Logic also has two other outputs, ANYR (Any Request) and RDD (Read Data). ANYR goes high (active) if any control requests (IOWR, etc.) are active. RDD controls the direction of the Masters Bi-directional Data Bus Drivers. The Bus Driver will always be in the Write mode (RDD $=$ Low) except from the start of a Read Control Request to 25 to 70 ns after $\overline{\mathrm{XCP}}$ is activated.


FIGURE 2a. 8218 CONTROL LOGIC


FIGURE 2b. 8219 CONTROL LOGIC

## 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}$ Supply Voltage (VCC) ...................... -0.5 V to +7 V Input Voltage ..................... -1.0 V to $\mathrm{Vcc}+0.25 \mathrm{~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. AND OPERATING 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. | Max. |  |  |
| $V_{c}$ | Input Clamp Voltage |  |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{IC}=-5 \mathrm{~mA}$ |
| IF | Input Load Current $\overline{M R D R} / \overline{N T A} / \overline{M W T R} / \overline{W R}$ $\overline{\text { IORR } / \overline{R D}, ~ I O W R / I O / ~} \bar{M}$ |  |  | -0.5 | mA | $\begin{aligned} & V_{C C}=5.25 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
|  | Other |  |  | -0.5 | mA |  |
| IR | Input Leakage Current |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=5.25 \\ & V_{R}=5.25 \end{aligned}$ |
| $V_{\text {TH }}$ | Input Threshold Voltage | 0.8 |  | 2.0 | V | $\mathrm{V}_{\text {cc }}=5 \mathrm{~V}$ |
| Icc | Power Supply Current |  | 200 | 240 | mA | $\mathrm{Vcic}=5.25 \mathrm{~V}$ |
| Vol | Output Low Voltage <br> $\overline{M R D C}, \overline{M W T C}, \overline{\text { IORC }}, \overline{\text { IOWC }}$ $\overline{B R E Q}, \overline{B U S Y}$ <br> $\overline{X C Y}, \overline{R D D}, \overline{A D E N}$ BPRO, ANYR |  |  |  |  | $\mathrm{Vcc}=4.75$ |
|  |  |  |  | 0.45 | V | $\mathrm{IOL}=32 \mathrm{~mA}$ |
|  |  |  |  | 0.45 | V | $1 \mathrm{OL}=20 \mathrm{~mA}$ |
|  |  |  |  | 0.45 | V | $\mathrm{IOL}=16 \mathrm{~mA}$ |
|  |  |  |  | 0.45 | V | $\mathrm{lOL}=3.2 \mathrm{~mA}$ |
| VOH | Output High Voltage <br> $\overline{\text { MRDC }}, \overline{\text { MWTC }}, \overline{\text { IORC }}, \overline{\text { IOWC }}$ $\overline{B U S Y}$ O.C. <br> All Other Outputs |  |  |  |  | $\mathrm{Vcc}=4.75 \mathrm{~V}$ |
|  |  | 2.4 |  |  |  | $\mathrm{IOH}=-2 \mathrm{~mA}$ |
|  |  | 2.4 |  |  |  | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| los | Short Circuit Output Current | -10 |  | -90 | mA | $\mathrm{V}_{C C}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| IO (OFF) | Tri-State Output Current |  |  | -100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {cc }}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.45 \mathrm{~V}$ |
|  |  |  |  | +100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=5.25 \mathrm{~V}$ |

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 \%$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| tBCY | Bus Clock Cycle Time | 100 |  |  | ns | 35\% to 65\% Duty Cycle |
| tPW | Bus Clock Pulse Width | 35 |  | 0.65 tBCY | ns |  |
| tRQS | $\overline{\text { RSTB }}$ to $\overline{\text { BCLK }}$ Set-Up Time | 25 |  |  | ns |  |
| tcss | $\mathrm{BCR}_{1}$ and $\overline{\mathrm{BCR}}_{2}$ to $\overline{\mathrm{RSTB}}$ Set-Up Time | 15 |  |  | ns |  |
| tcse | $\mathrm{BCR}_{1}$ and $\overline{\mathrm{BCR}}_{2}$ to $\overline{\mathrm{RSTB}}$ Hold Time | 15 |  |  | ns |  |
| trad | $\overline{\text { BCLK }}$ to $\overline{\mathrm{BREQ}}$ Delay |  |  | 35 | ns |  |
| tpRNS | $\overline{\overline{B P R N}}$ to $\overline{\text { BCLK }}$ Set-Up Time | 23 |  |  | ns |  |
| tBNO | $\overline{\text { BRPN }}$ to $\overline{\text { BPRO }}$ Delay |  |  | 30 | ns |  |
| $\mathrm{t}_{\mathrm{BYD}}$ | $\overline{\text { BCLK }}$ to $\overline{B U S Y}$ Delay |  |  | 55 | ns |  |
| tcad | $\overline{\text { MRDR, }} \overline{\text { MWTR }}, \overline{\text { IORR }}, \overline{\text { IOWR }}$ to ANYR Delay |  |  | 30 | ns |  |
| tsxD | XSTR to $\overline{X C Y}$ Delay |  |  | 40 | ns |  |
| tSCD | XSTR to $\overline{\mathrm{MRDC}}, \overline{\mathrm{MWTC}}, \overline{\mathrm{IORC}}$, IOWC Delay | 50 |  | 200 | ns | Adjustable by External R/C |
| txsw | XSTR Pulse Width | 30 |  |  | ns |  |
| tXCD | $\overline{\overline{X C P}}$ to $\overline{\mathrm{MRDC}}, \overline{\mathrm{MWTC}}, \overline{\overline{I O R C}}$, IOWC Delay |  |  | 50 | ns |  |
| txcw | $\overline{X C P}$ Pulse Width | 35 |  |  | ns |  |
| tcco | $\overline{X C P}$ to $\overline{X C Y}$ Delay | 50 |  | 200 | ns | Adjustable by External R/C |
| tcmb | $\overline{\mathrm{MRDR}}, \overline{\mathrm{MWTR}}, \overline{\mathrm{IORR}}, \overline{\text { IOWR }}$ to $\overline{M R D C}, \overline{M W T C}, \overline{I O R C}, \overline{I O W C}$ |  |  | 35 | ns |  |
| tcri | $\overline{\text { MRDR, }} \overline{\text { MWTR, }} \overline{\text { IORR }}, \overline{\text { IOWR }}$ to RDD Delay |  |  | 25 | ns |  |
| trw | $\overline{\text { RSTB }}$ Min. Neg. Pulse Width | 30 |  |  | ns |  |
| tcPD | $\overline{\mathrm{BCLK}}$ to $\overline{\mathrm{BPRO}}$ Delay |  |  | 40 | ns |  |
| tXRD | $\overline{\mathrm{XCP}}$ to $\overline{\mathrm{RDD}}$ Delay | 25 |  | 70 | ns |  |

8218/19 XSTR TO OUTPUT COMMAND DELAY ONESHOT DELAY VS. DELAY ADJUST CAPACITANCE AND RESISTANCE



FIGURE 3a. 8218/8219 SYNCHRONOUS BUS TIMING (SYSTEM BUS PREVIOUSLY NOT IN USE).


FIGURE 3b. 8218/8219 CONTROL CYCLE (SYSTEM BUS PREVIOUSLY NOT IN USE).


FIGURE 3c. 8218/8219 BUS CONTROL EXCHANGE (MASTER NO. 1 LEAVING BUS AND MASTER NO. 2 GETTING ON BUS).


FIGURE 4a. MCS-80 CPU WITH 8218.


FIGURE 4b. MCS-85 CPU WITH 8219.


FIGURE 4c. MCS-85 CPU WITH 8219 USING LOCAL MEMORY.

"DAISY CHAIN" CONFIGURATION


PARALLEL REQUEST CONFIGURATION

FIGURE 5. TWO METHODS OF CONNECTING MULTIPLE 8218/8219's TO RESOLVE BUS CONTENTION AMONG MULTIPLE MASTERS.

8257/8257-5
PROGRAMMABLE DMA CONTROLLER

\author{

- MCS-85 ${ }^{\text {TM }}$ Compatible 8257.5 <br> - 4-Channel DMA Controller <br> - Priority DMA Request Logic <br> - Channel Inhibit Logic
}

\author{

- Terminal Count and Modulo 128 Outputs <br> - Single TTL Clock <br> - Single +5V Supply <br> - Auto Load Mode
}


#### Abstract

The Intel 8257 is a 4 -channel direct memory access (DMA) controller. It is specifically designed to simplify the transfer of data at high speeds for the Intel ${ }^{\oplus}$ 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 in accomplished via the CPU's hoid 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. 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

| $\overline{1 / O R} \bar{C}$ | 1 | $\int$ | 40 | $\mathrm{Pa}_{7}$ |
| :---: | :---: | :---: | :---: | :---: |
| I/OW $\square^{\text {C }}$ | 2 |  | 39 | $\square A_{6}$ |
| MEM R | 3 |  | 38 | $\square A_{5}$ |
| MEMW | 4 |  | 37 | $\mathrm{DA}_{4}$ |
| MARK | 5 |  | 36 | -т |
| READY | 6 |  | 35 | $\mathrm{A}_{3}$ |
| HLDA | 7 |  | 34 | $\square \mathrm{A}_{2}$ |
| ADSTB | 8 |  | 33 | $\mathrm{TA}_{1}$ |
| AEN | 9 | 8257 | 32 | $\square A_{0}$ |
| HROC | 10 |  | 31 | $\mathrm{V}_{\mathrm{cc}}$ |
| $\overline{\text { cs }}$ | 11 |  | 30 | $\mathrm{D}_{0}$ |
| CLK | 12 |  | 29 | $\mathrm{D}_{1}$ |
| Reset | 13 |  | 28 | $\mathrm{D}_{2}$ |
| DACK 29 | 14 |  | 27 | $\mathrm{D}_{3}$ |
| DACK 3 | 15 |  | 26 | $\mathrm{J}_{4}$ |
| dra 3 | 16 |  | 25 | $\square$ DACK 0 |
| DRO $2 \square$ | 17 |  | 24 | ] $\overline{\text { DACK } 1}$ |
| Dra 14 | 18 |  | 23 | $\mathrm{D}_{5}$ |
| DRQ Of | 19 |  | 22 | $\mathrm{D}_{6}$ |
| gnd | 20 |  | 21 | 万0, |

PIN NAMES

| $\mathrm{D}_{7} \cdot \mathrm{D}_{0}$ | DATA BUS |
| :---: | :---: |
| $A_{7} \cdot A_{0}$ | ADDRESS BUS |
| ITOR | I/O READ |
| IOW | I/O WRITE |
| MEMR | MEMORY READ |
| MEMW | MEMORY WRITE |
| CLK | CLOCX INPUT |
| RESET | RESET INPUT |
| READY | READY |
| HRO | HOLD REQUEST (TO 8080A) |
| HLDA | HOLD ACKNOWLEDGE (FROM 8080A) |

BLOCK DIAGRAM


## FUNCTIONAL DESCRIPTION

## General

The 8257 is a programmable, Direct Memory Access (DMA) device which, when coupled with a single Intel ${ }^{\oplus}$ 8212 I/O port device, provides a complete four-channel DMA controller for use in Intel* 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:

1. Acquires control of the system bus.
2. Acknowledges that requesting peripheral which is connected to the highest priority channel.
3. Outputs the least significant eight bits of the memory address onto system address lines $A_{0}-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 $\left.A_{8}-A_{15}\right)$, and
4. 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 $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.


Figure 1. 8257 Block Diagram Showing DMA Channels

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. The $\overline{\text { DACK }}$ output acts as a "chip select" for the peripheral device requesting service. This line goes active (low) and inactive (high) once for each byte transferred even if a burst of data is being transferred.

## 2. Data Bus Buffer

This three-state, bi-directional, eight bit buffer interfaces the 8257 to the system data bus.

## ( $D_{0}-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 Cycie |
| 1 | 1 | (IIlegal) |



Figure 2. 8257 Block Diagram Showing Data Bus Buffer

## 3. Read/Write Logic

When the CPU is programming or reading one of the 8257's registers (i.e., when the 8257 is a "slave" device on the system bus), the Read/Write Logic accepts the I/O Read (IIOR) or I/O Write (I/OW) signal, decodes the least significant four address bits, $\left(A_{0}-A_{3}\right)$, and either writes the contents of the data bus into the addressed register (if I/OW is true) or places the contents of the addressed register onto the data bus (if $\overline{1 / 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

## (IIOR)

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, $\overline{\mathrm{I} O R}$ is a control output which is used to access data from a peripheral during the DMA write cycle.

## (IIOW)

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} 8224$ Clock Generator device. ( $\phi 2 \mathrm{TTL}$ ) or Intel ${ }^{\text {® }}$ 8085A CLK output.

## (RESET)

Reset: An asynchronous input (generally from an 8224 or 8085 device) which disables all DMA channels by clearing the mode register and 3 -states all control lines.

## ( $\left.A_{0}-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 .

## (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{C S}$ is automatically disabled to prevent the chip from selecting itself while performing the DMA function.


Figure 3. 8257 Block Diagram Showing Read/Write Logic Function

## 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.
( $A_{4}-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 1/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.


Figure 4. 8257 Block Diagram Showing Control Logic and Mode Set Register

## 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 <br> JUST SERVICED | $\mathrm{CH}-0$ | $\mathrm{CH}-1$ | $\mathrm{CH}-2$ | $\mathrm{CH}-3$ |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Priority $\rightarrow$ |  |  |  |  |  |
| Assignments | Highest | $\mathrm{CH}-1$ | $\mathrm{CH}-2$ | $\mathrm{CH}-3$ | $\mathrm{CH}-0$ |
|  | 4 | $\mathrm{CH}-2$ | $\mathrm{CH}-3$ | $\mathrm{CH}-0$ | $\mathrm{CH}-1$ |
|  | Lowest | $\mathrm{CH}-3$ | $\mathrm{CH}-0$ | $\mathrm{CH}-1$ | $\mathrm{CH}-2$ |
|  |  |  | $\mathrm{CH}-2$ | $\mathrm{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. There is no overhead penalty associated with this mode of operation. 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 { I/OW }}$ 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.

The user is cautioned against reading the TC status register and using this information to reenable channels that have not completed operation. Unless the DMA channels are inhibited a channel could reach terminal count (TC) between the status read and the mode write. DMA can be inhibited by a hardware gate on the HRQ line or by disabling channels with a mode word before reading the TC status.

## OPERATIONAL SUMMARY

## 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 $A_{4}-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" ( $A_{3}=0$ ) 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 ( $A_{0}=0$ ) and the terminal count register $\left(A_{0}=1\right)$, while bits $A_{1}$ and $A_{2}$ specify one of the

| CONTROL INPUT | $\overline{\mathrm{CS}}$ | $\overline{\mathrm{I} / \mathrm{OW}}$ | $\overline{\overline{1 / O R}}$ | $\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{/ / O R}$ or $\overline{/ / O W}$ is active, as this will cause an erroneous F/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}$ \& $\mathrm{A}_{2}$ \& $\mathrm{A}_{1}$ \& $\mathrm{A}_{0}$ \& \& D 7 \& D 6 \& D5 \& 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 \& $$
\begin{aligned}
& 0 \\
& 1
\end{aligned}
$$ \& $$
\begin{gathered}
\mathbf{A}_{7} \\
\mathbf{A}_{15}
\end{gathered}
$$ \& $\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 \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 0 \& 0 \& 0 \& 1 \& 0 \& C7
Rd \& C
Wr \& C
C

$\mathrm{C}_{13}$ \& C
$\mathrm{C}_{12}$ \& $\mathrm{C}_{3}$ \& $\mathrm{C}_{2}$ \& C

C \& $$
\begin{aligned}
& \mathbf{C}_{0} \\
& \mathbf{C}_{8}
\end{aligned}
$$ <br>

\hline CH-1 DMA Address \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 0 \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 1
\end{aligned}
$$
\] \& Same \& Cha \& nnel 0 \& \& \& \& \& <br>

\hline CH-1 Terminal Count \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 0 \& 0 \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 1
\end{aligned}
$$
\] \& \& \& \& \& \& \& \& <br>

\hline CH-2 DMA Address \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 0 \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$
\] \& 0 \& Same \& as Cha \& nel 0 \& \& \& \& \& <br>

\hline CH-2 Terminal Count \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 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 \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 0 \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 1 \\
& 1
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 0 \\
& 0
\end{aligned}
$$
\] \& 0 \& Same \& Cha \& nnel 0 \& \& \& \& \& <br>

\hline CH-3 Terminal Count \& $$
\begin{aligned}
& \text { LSB } \\
& \text { MSB }
\end{aligned}
$$ \& 0 \& \[

$$
\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}

[^12]

1 DRQn refers to any DRQ line on an enabled DMA channel.

Figure 6. DMA Operation State Diagram

## DMA OPERATION

## Single Byte Transfers

A single byte transfer is initiated by the I/O device raising the DRQ line of one channel of the 8257. If the channel is enabled, the 8257 will output a HRQ to the CPU. The 8257 now waits until a HLDA is received insuring that the system bus is free for its use. Once HLDA is received the DACK line for the requesting channel is activated (LOW). The $\overline{\text { DACK }}$ line acts as a chip select for the requesting I/O device. The 8257 then generates the
read and write commands and byte transfer occurs between the selected I/O device and memory. After the transfer is complete, the DACK line is set HIGH and the HRQ line is set LOW to indicate to the CPU that the bus is now free for use. DRQ must remain HIGH until $\overline{\text { DACK }}$ is issued to be recognized and must go LOW before S4 of the transfer sequence to prevent another transfer from occuring. (See timing diagram.)

## Consecutive Transfers

If more than one channel requests service simultaneously, the transfer will occur in the same way a burst does. No overhead is incurred by switching from one channel to another. In each S4 the DRQ lines are sampled and the highest priority request is recognized during the next transfer. A burst mode transfer in a lower priority channel will be overridden by a higher priority request. Once the high priority transfer has completed control will return to the lower priority channel if its DRQ is still active. No extra cycles are needed to execute this sequence and the HRQ line remains active until all DRQ lines go'LOW.

## Control Override

The continuous DMA transfer mode described above can be interrupted by an external device by lowering the HLDA line. After each DMA transfer the 8257 samples the HLDA line to insure that it is still active. If it is not active, the 8257 completes the current transfer, releases the HRQ line (LOW) and returns to the idle state. If DRQ lines are still active the 8257 will raise the HRQ line in the third cycle and proceed normally. (See timing diagram.)

## Not Ready

The 8257 has a Ready input similar to the 8080A and the 8085A. The Ready line is sampled in State 3. If Ready is LOW the 8257 enters a wait state. Ready is sampled during every wait state. When Ready returns HIGH the 8257 proceeds to State 4 to complete the transfer. Ready is used to interface memory or $/ / O$ devices that cannot meet the bus set up times required by the 8257.

## Speed

The 8257 uses four clock cycles to transfer a byte of data. No cycles are lost in the master to master transfer maximizing bus efficiency. A 2 MHz clock input will allow the 8257 to transfer at a rate of 500K bytes/second.

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


Figure 11. Detailed System Interface Schematic


Figure 7. System Interface for Memory Mapped IIO

| BIT 15 <br> READ | BIT 14 |  |
| :---: | :---: | :---: |
| 0 | 0 | WRITE |
| 0 | 1 | DMA Verify Cycle |
| 1 | 0 | DMA Read Cycle |
| 1 | 1 | Ilitegal Cycle |

Figure 8. TC Register for Memory Mapped I/O Only

SYSTEM APPLICATION EXAMPLES


Figure 9. Floppy Disk Controller (4 Drives)


Figure 10. High-Speed Communication Controller

## 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 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 \%, \mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | Volts |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+.5$ | Volts |  |
| VOL | Output Low Voltage |  | 0.45 | Volts | $\mathrm{OLL}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 | $V_{c c}$ | Volts | $L_{H}=-150 \mu A \text { for } A B \text {, }$ <br> DB and AEN <br> $\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{IOH}^{=}=-80 \mu \mathrm{~A}$ |
| ICC | Vcc Current Drain |  | 120 | mA |  |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ to 0 V |
| lofl | Output Leakage During Float |  | $\pm 10$ | $\mu \mathrm{A}$ | $V_{\text {OUT }}=V_{\text {CC }}$ to $0 V$ |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $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 <br> returned to GND |

## A.C. CHARACTERISTICS: PERIPHERAL (SLAVE) MODE

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \% ; \mathrm{GND}=0 \mathrm{~V}$ (Note 1).

## 8080 Bus Parameters

## Read Cycle:

| Symbol | Parameter | 8257 |  | 8257-5 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{T}_{\text {AR }}$ | Adr or $\overline{\mathrm{CS}} \downarrow$ Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | 0 |  | ns |  |
| TRA | Adr or $\overline{\mathrm{CS}} \uparrow$ Hold from $\overline{\mathrm{RD}} \uparrow$ | 0 |  | 0 |  | ns |  |
| TRD | Data Access from $\overline{\mathrm{RD}} \downarrow$ | 0 | 300 | 0 | 200 | ns | (Note 2) |
| $\mathrm{T}_{\text {DF }}$ | DB $\rightarrow$ Float Delay from $\overline{\mathrm{RD}} \uparrow$ | 20 | 150 | 20 | 100 | ns |  |
| TRR | $\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 |  |
| TDW | Data Setup to $\overline{W R} \uparrow$ | 200 |  | 200 |  | ns |  |
| TWD | Data Hold from $\overline{W R} \uparrow$ | 0 |  | 0 |  | ns |  |
| TwW | WR Width | 200 |  | 200 |  | ns |  |

## Other Timing:

| Symbol | Parameter | 8257 |  | 8257-5 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| TRSTW | Reset Pulse Width | 300 |  | 300 |  | ns |  |
| $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{/ / O W R}$ | 2 |  | 2 |  | ${ }^{\text {t }} \mathrm{CY}$ |  |

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 \mathrm{pF}, 8257-5: C_{L}=150 \mathrm{pF}$.

Output " 1 " at 2.0 V , " 0 " at 0.8 V

## 8257 PERIPHERAL MODE TIMING DIAGRAMS

Write Timing:


Read Timing:


Input Waveform for A.C. Tests:

A.C. CHARACTERISTICS: DMA (MASTER) MODE $\quad 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}$.

## Timing Requirements

| SYMBOL | PARAMETER | 8257 |  | 8257-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| $\mathrm{T}_{\mathrm{CY}}$ | Cycle Time (Period) | 0.320 | 4 | 0.320 | 4 | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\theta}$ | Clock Active (High) | 120 | . $8 \mathrm{~T}_{\mathrm{CY}}$ | 80 | .$^{8} \mathrm{~T}_{\mathrm{Cr}}$ | ns |
| Tas | DRQ $\uparrow$ Setup to $\theta \downarrow$ (SI, S4) | 120 |  | 30 |  | ns |
| $\mathrm{T}_{\mathrm{QH}}$ | DRQ $\downarrow$ Hold from HLDA $\uparrow$ [4] | 0 |  | 0 |  | ns |
| THS | HLDA $\uparrow$ or $\downarrow$ Setup to $\theta \downarrow$ (SI, S4) | 100 |  | 100 |  | ns |
| $T_{\text {RS }}$ | READY Setup Time to $\theta \uparrow$ (S3, Sw) | 30 |  | 30 |  | ns |
| $\mathrm{T}_{\mathrm{RH}}$ | READY Hold Time from $\theta \uparrow$ (S3, Sw) | 20 |  | 20 |  | ns |

Note: 4. Tracking Parameter.

## Tracking Parameters

Signals labeled as Tracking Parameters (footnotes 4-7 under A.C. Specifications) are signals that follow similar paths through the silicon die. The propagation speed of these signals varies in the manufacturing process but the relationship between all these parameters is constant. The variation is less than or equal to 50 ns .
Suppose the following timing equation is being evaluated,

$$
T_{A(M I N)}+T_{B(M A X)} \leq 150 \mathrm{~ns}
$$

and only minimum specifications exist for $T_{A}$ and $T_{B}$. If $T_{A(M I N)}$ is used, and if $T_{A}$ and $T_{B}$ are tracking parameters, $T_{B(M A X)}$ can be taken as $T_{B(M I N)}+50 \mathrm{~ns}$.

$$
T_{A(M I N)}+\left(T_{B(M I N)}{ }^{*}+50 \mathrm{~ns}\right) \leq 150 \mathrm{~ns}
$$

*if $T_{A}$ and $T_{B}$ are tracking parameters
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 \%, \mathrm{GND}=0 \mathrm{~V}$

## Timing Responses

| SYMBOL | PARAMETER | 8257 |  | 8257.5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| TDO | HRQî or $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI}, \mathrm{S} 4)$ (measured at 2.0 V$)^{[1]}$ |  | 160 |  | 160 | ns |
| TDa1 | HRO $\uparrow$ or $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI}, \mathrm{S} 4)$ (measured at 3.3V) ${ }^{[3]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\text {AEL }}$ | AEN $\uparrow$ Delay from $\theta \downarrow$ (S1) ${ }^{[1]}$ |  | 300 |  | 300 | ns |
| $\mathrm{T}_{\text {AET }}$ | AEN $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI})^{[1]}$ |  | 200 |  | 200 | ns |
| $T_{\text {AEA }}$ | $\operatorname{Adr}(\mathrm{AB})$ (Active) Delay from AEN $\uparrow(\mathrm{S} 1)^{[4]}$ | 20 |  | 20 |  | ns |
| T ${ }_{\text {FAAB }}$ | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Active) Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 250 |  | 250 | ns |
| TAFAB | $\operatorname{Adr}(\mathrm{AB})$ (Float) Delay from $\theta \uparrow(\mathrm{SI})^{[2]}$ |  | 150 |  | 150 | ns |
| $\mathrm{T}_{\text {ASM }}$ | Adr (AB)(Stable) Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\text {AH }}$ | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Stable) Hold from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ | $\mathrm{T}_{\text {ASM }} \mathbf{- 5 0}$ |  | $\mathrm{T}_{\text {ASM }}$-50 |  | ns |
| $\mathrm{T}_{\text {AHR }}$ | Adr (AB) (Valid) Hold from $\overline{\mathrm{Rd}} \uparrow(\mathrm{S} 1, \mathrm{SI})[4]$ | 60 |  | 60 |  | ns |
| $T_{\text {AHW }}$ | Adr (AB)(Valid) Hold from $\overline{\text { Wr }} \uparrow(\mathrm{S} 1, \mathrm{SI})^{[4]}$ | 300 |  | 300 |  | ns |
| T ${ }_{\text {FADB }}$ | Adr(DB)(Active) Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 300 |  | 300 | ns |
| TAFDB | $\operatorname{Adr}$ (DB)(Float) Delay from $\theta \uparrow$ (S2) ${ }^{[2]}$ | $\mathrm{T}_{\text {StT }}+20$ | 250 | $\mathrm{T}_{\text {STT }}+20$ | 170 | ns |
| TASS | Adr (DB) Setup to AdrStb $\downarrow$ (S1-S2) [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 |
| TSTT | AdrStb $\downarrow$ Delay from $\theta \uparrow(\mathrm{S} 2)^{[1]}$ |  | 140 |  | 140 | ns |
| $\mathrm{T}_{\text {SW }}$ | AdrStb Width (S1-S2) ${ }^{[4]}$ | $\mathrm{T}_{\mathrm{CY}-100}$ |  | TCY-100 |  | ns |
| $\mathrm{T}_{\text {ASC }}$ | $\overline{\mathrm{R} d} \downarrow$ or $\overline{\mathrm{Wr}}$ (Ext) $\downarrow$ Delay from AdrStb $\downarrow$ (S2) ${ }^{[4]}$ | 70 |  | 70 |  | ns |
| TDBC | $\overline{\mathrm{Rd}} \downarrow$ or $\overline{W_{r}}(E x t) \downarrow$ Delay from Adr (DB) (Float)(S2) ${ }^{\text {[4] }}$ | 20 |  | 20 |  | ns |
| TAK | DACK $\uparrow$ or $\downarrow$ Delay from $\theta \downarrow($ S2,S1 ) and TC/Mark $\uparrow$ Delay from $\theta \uparrow(\mathrm{S} 3)$ and TC/Mark $\downarrow$ Delay from $\theta \uparrow(S 4)^{[1,5]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\mathrm{DCL}}$ | $\overline{\mathrm{R} d} \downarrow$ or $\overline{\mathrm{Wr}}($ Ext $) \downarrow$ Delay from $\theta \uparrow(\mathrm{S} 2)$ and $\bar{W} \downarrow \downarrow$ Delay from $\theta \uparrow(S 3)^{[2,6]}$ |  | 200 |  | 200 | ns |
| TDCT | $\overline{\mathrm{Rd}} \uparrow$ Delay from $\theta \downarrow(\mathbf{S} 1, \mathbf{S I})$ and $\overline{\mathrm{Wr}} \uparrow$ Delay from $\theta \uparrow(\mathrm{S} 4)^{[2,7]}$ |  | 200 |  | 200 | ns |
| $\mathrm{T}_{\text {FAC }}$ | $\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}_{r}}$ (Float) from $\theta \uparrow(\mathrm{SI})[2]$ |  | 150 |  | 150 | ns |
| TRWM | $\overline{\mathrm{Rd}}$ Width (S2-S1 or SI) ${ }^{\text {[4] }}$ | $2 \mathrm{~T}_{C Y}+\mathrm{T}_{\theta}-50$ |  | $2 \mathrm{~T}_{C Y}+\mathrm{T}_{\theta}-50$ |  | ns |
| TWWM | $\overline{\text { Wr Width (S3-S4) }}$ [4] | $\mathrm{T}_{\mathrm{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 |

Notes: 1. Load $=1 \mathrm{TTL}$. 2. Load $=1 \mathrm{TTL}+50 \mathrm{pF}$. 3. Load $=1 \mathrm{TTL}+\left(R_{\mathrm{L}}=3.3 \mathrm{~K}\right), \mathrm{V}_{\mathrm{OH}}=3.3 \mathrm{~V}$. 4. Tracking Parameter.
5. $\Delta T_{A K}<50 \mathrm{~ns}$. 6. $\Delta T_{D C L}<50 \mathrm{~ns}$. 7. $\triangle T_{D C T}<50 \mathrm{~ns}$.

## DMA MODE WAVEFORMS

CONSECUTIVE CYCLES AND BURST MODE SEQUENCE


Figure 12. Consecutive Cycles and Burst Mode Sequence


Figure 13. Control Override Sequence


Figure 14. Not Ready Sequence

## 8259A PROGRAMMABLE INTERRUPT CONTROLLER

MCS-86 ${ }^{\text {TM }}$ Compatible<br>MCS-80/85 ${ }^{\text {TM }}$ Compatible<br>Eight-Level Priority Controller<br>Expandable to 64 Levels

- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single +5V Supply (No Clocks)
- 28-Pin Dual-In-Line Package

The Intel ${ }^{\top}$ 8259A Programmable Interrupt Controller handles up to eight vectored priority interrupts for the CPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry. It is packaged in a 28 -pin DIP, uses NMOS technology and requires a single +5 V supply. Circuitry is static, requiring no clock input.
The 8259A 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.
The 8259A is fully upward compatible with the Intel ${ }^{\circledR} 8259$. Software originally written for the 8259 will operate the 8259A in all 8259 equivalent modes (MCS-80/85, Non-Buffered, Edge Triggered).

## PIN CONFIGURATION



PIN NAMES

| $D_{7}-D_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| $\overline{R D}$ | READ INPUT |
| $\overline{W R}$ | WRITE INPUT |
| $A_{0}$ | COMMAND SELECT ADDRESS |
| $\overline{C S}$ | CHIP SELECT |
| CAS2-CASO | CASCADE LINES |
| $\overline{S P / E N}$ | SLAVE PROGRAM INPUT/ENABLE |
| INT | INTERRUPT OUTPUT |
| $\overline{\text { INTA }}$ | INTERRUPT ACKNOWLEDGE INPUT |
| IRO-IRT | INTERRUPT REQUEST INPUTS |

## 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 manner 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 continuous 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 desirable 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. This "pointer" is an address in a vectoring table and will often be referred to, in this document, as vectoring data.

## 8259A BASIC FUNCTIONAL DESCRIPTION <br> GENERAL

The 8259A 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 8259A's (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 8259A 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.


## Polled Method



## Interrupt Method

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

## INTERRUPT MASK REGISTER (IMR)

The IMR stores the bits which mask the interrupt lines to be masked. The IMR operates on the IRR. Masking of a higher priority input will not affect the interrupt request lines of lower priority.

## INT (INTERRUPT)

This output goes directly to the CPU interrupt input. The $V_{\mathrm{OH}}$ level on this line is designed to be fully compatible with the 8080A, 8085A and 8086 input levels.

## INTA (INTERRUPT ACKNOWLEDGE)

INTA pulses will cause the 8259A to release vectoring information onto the data bus. The format of this data depends on the system mode ( $\mu \mathrm{PM}$ ) of the 8259A.

## DATA BUS BUFFER

This 3-state, bidirectional 8 -bit buffer is used to interface the 8259A to the system Data Bus. Control words and status information are transferred through the Data Bus Buffer.

## READIWRITE 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 8259A to be transferred onto the Data Bus.

## $\overline{\mathbf{C S}}$ (CHIP SELECT)

A LOW on this input enables the 8259A. No reading or writing of the chip will occur unless the device is selected.

## $\overline{\text { WR }}$ (WRITE)

A LOW on this input enables the CPU to write control words (ICWs and OCWs) to the 8259A.

## $\overline{\operatorname{RD}}$ (READ)

A LOW on this input enables the 8259A to send the status of the Interrupt Request Register (IRR), In Service Register (ISR), the Interrupt Mask Register (IMR), or the Interrupt level onto the Data Bus.


8259A Block Diagram


8259A Block Diagram

## $A_{0}$

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.

## THE CASCADE BUFFER/COMPARATOR

This function block stores and compares the IDs of all 8259A's used in the system. The associated three I/O pins (CAS0-2) are outputs when the 8259A is used as a master and are inputs when the 8259A is used as a slave. As a master, the 8259A sends the ID of the interrupting slave device onto the CASO-2 lines. The slave thus selected will send its preprogrammed subroutine address onto the Data Bus during the next one or two consecutive INTA pulses. (See section "Cascading the 8259A".)

## INTERRUPT SEQUENCE

The powerful features of the 8259A in a microcomputer system are its programmability and the interrupt routine addressing capability. The latter allows direct or indirect jumping to the specific interrupt routine requested without any polling of the interrupting devices. The normal sequence of events during an interrupt depends on the type of CPU being used.
The events occur as follows in an MCS-80/85 system:

1. One or more of the INTERRUPT REQUEST lines (IR7-0) are raised high, setting the corresponding IRR bit(s).
2. The 8259A evaluates these requests, and sends an INT to the CPU, if appropriate.
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 8259A 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 INTA pulses to be sent to the 8259A from the CPU group.
6. These two INTA pulses allow the 8259A 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 and the higher 8 -bit address is released at the second $\overline{\mathrm{INTA}}$ pulse.
7. This completes the 3-byte CALL instruction released by the 8259A. In the AEOI mode the ISR bit is reset at the end of the third INTA pulse. Otherwise, the ISR bit remains set until an appropriate EOI command is issued at the end of the interrupt sequence.
The events occurring in an MCS-86 system are the same until step 4.
8. Upon receiving an INTA from the CPU group, the highest priority ISR bit is set and the corresponding IRR bit is reset. The 8259A does not drive the Data Bus during this cycle.
9. The MCS-86 CPU will initiate a second INTA pulse. During this pulse, the 8259A releases an 8-bit pointer onto the Data Bus where it is read by the CPU.
10. This completes the interrupt cycle. In the AEOI mode the ISR bit is reset at the end of the second INTA pulse. Otherwise, the ISR bit remains set until an appropriate EOI command is issued at the end of the interrupt subroutine.

If no interrupt request is present at step 4 of either sequence (i.e., the request was too short in duration) the 8259A will issue an interrupt level 7. Both the vectoring bytes and the CAS lines will look like an interrupt level 7 was requested.


## 8259A Block Diagram



## 8259A Interface to Standard System Bus

## INTERRUPT SEQUENCE OUTPUTS MCS-80/85 SYSTEM

This sequence is timed by three INTA pulses. During the first INTA pulse the CALL opcode is enabled onto the data bus.

## Content of First Interrupt <br> Vector Byte

CALL CODE

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 |

During the second INTA pulse the lower address of the appropriate service routine is enabled onto the data bus. When Interval $=4$ bits $A_{5}-A_{7}$ are programmed, while $A_{0}{ }^{-}$ $A_{4}$ are automatically inserted by the 8259A. When Inter$\mathrm{val}=8$ only $A_{6}$ and $A_{7}$ are programmed, while $A_{0}-A_{5}$ are automatically inserted.

## Content of Second Interrupt Vector Byte

| IR | Interval $=4$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | D8 | D5 | D4 | D3 | D2 | D1 | D0 |
| 7 | A7 | A6 | A5 | 1 | 1 | 1 | 0 | 0 |
| 6 | A7 | A6 | A5 | 1 | 1 | 0 | 0 | 0 |
| 5 | A7 | A6 | A5 | 1 | 0 | 1 | 0 | 0 |
| 4 | A7 | A6 | A5 | 1 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | A5 | 0 | 1 | 1 | 0 | 0 |
| 2 | A7 | A6 | A5 | 0 | 1 | 0 | 0 | 0 |
| 1 | A7 | A6 | A5 | 0 | 0 | 1 | 0 | 0 |
| 0 | A7 | A6 | A5 | 0 | 0 | 0 | 0 | 0 |


| IR | Interval $=\mathbf{8}$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathbf{D 7}$ | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| 7 | A7 | A6 | 1 | 1 | 1 | 0 | 0 | 0 |
| 6 | A7 | A6 | 1 | 1 | 0 | 0 | 0 | 0 |
| 5 | A7 | A6 | 1 | 0 | 1 | 0 | 0 | 0 |
| 4 | A7 | A6 | 1 | 0 | 0 | 0 | 0 | 0 |
| 3 | A7 | A6 | 0 | 1 | 1 | 0 | 0 | 0 |
| 2 | A7 | A6 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | A7 | A6 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | A7 | A6 | 0 | 0 | 0 | 0 | 0 | 0 |

During the third INTA pulse the higher address of the appropriate service routine, which was programmed as byte 2 of the initialization sequence $\left(A_{8}-A_{15}\right)$, is enabled onto the bus.

## Content of Third Interrupt

## Vector Byte

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

## MCS-86 SYSTEM

MCS-86 mode is similar to MCS-80 mode except that only two Interrupt Acknowledge cycles are issued by the processor and no CALL opcode is sent to the processor. The first interrupt acknowledge cycle is similar to that of MCS-80/85 systems in that the 8259A uses it to internally freeze the state of the interrupts for priority resolution and as a master it issues the interrupt code on the cascade lines at the end of the INTA pulse. On this first cycle it does not issue any data to the processor and leaves its data bus buffers disabled. On the second interrupt acknowledge cycle in MCS-86 mode the master (or slave if so programmed) will send a byte of data to the processor with the acknowledged interrupt code composed as follows (note the state of the ADI mode control is ignored and $A_{5}-A_{11}$ are unused in MCS-86 mode):

## Content of Interrupt Vector Byte for MCS-86 System Mode

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IR7 | A15 | A14 | A13 | A12 | A11 | 1 | 1 | 1 |
| IR6 | A15 | A14 | A13 | A12 | A11 | 1 | 1 | 0 |
| IR5 | A15 | A14 | A13 | A12 | A11 | 1 | 0 | 1 |
| IR4 | A15 | A14 | A13 | A12 | A11 | 1 | 0 | 0 |
| IR3 | A15 | A14 | A13 | A12 | A11 | 0 | 1 | 1 |
| IR2 | A15 | A14 | A13 | A12 | A11 | 0 | 1 | 0 |
| IR1 | A15 | A14 | A13 | A12 | A11 | 0 | 0 | 1 |
| IR0 | A15 | A14 | A13 | A12 | A11 | 0 | 0 | 0 |

## PROGRAMMING THE 8259A

The 8259A accepts two types of command words generated by the CPU:

1. Initialization Command Words (ICWs): Before normal operation can begin, each 8259A in the system must be brought to a starting point - by a sequence of 2 to 4 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 8259A 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 8259A anytime after initialization.

## INITIALIZATION <br> GENERAL

Whenever a command is issued with $\mathrm{A} 0=0$ and $\mathrm{D} 4=1$, this is interpreted as Initialization Command Word 1 (ICW1). ICW1 starts the initialization sequence during which the following automatically occur.
a. The Interrupt Mask Register is cleared.
b. IR 7 input is assigned priority 7 .
c. The slave mode address is set to 7 .
d. Special Mask Mode is cleared and Status Read is set to IRR.
e. If IC4 $=0$, then all functions selected in ICW4 are set to zero. (Non-Buffered mode*, no Auto-EOI, MCS-80/85 system, non SFNM).

[^13]| $A_{0}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\overline{\overline{R D}}$ | $\overline{W R}$ | $\overline{\mathbf{C S}}$ | INPUT OPERATION (READ) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  |  | 0 | 1 | 0 | IRR, ISR or Interrupting LeveI $\rightarrow$ DATA BUS (Note 1) <br> 1 |
|  |  |  | 0 | 1 | 0 | IMR $\rightarrow$ DATA BUS |

Notes: 1. Selection of IRR, ISR or Interrupting Level is based on the content of OCW3 written before the READ operation.
2. On-chip sequencer logic queues these commands into proper sequence.

## 8259A Basic Operation

## INITIALIZATION COMMAND WORDS 1 AND 2 (ICW1, ICW2)

$\mathrm{A}_{5}-\mathrm{A}_{15}$ : Page starting address of service routines. In an MCS 80/85 system, the 8 request levels will generate CALLs to 8 locations equally spaced in memory. These can be programmed to be spaced at intervals of 4 or 8 memory locations, thus the 8 routines will occupy a page of 32 or 64 bytes, respectively.
The address format is 2 bytes long ( $A_{0}-A_{15}$ ). When the routine interval is $4, A_{0}-A_{4}$ are automatically inserted by the 8259A, while $A_{5}-A_{15}$ are programmed externally. When the routine interval is $8, A_{0}-A_{5}$ are automatically inserted by the 8259A, while $A_{6}-A_{15}$ are programmed externally.

The 8-byte interval will maintain compatibility with current software, while the 4-byte interval is best for a compact jump table.
In an MCS-86 system $A_{15}-A_{11}$ are inserted in the five most significant bits of the vectoring byte and the 8259A sets the three least significant bits according to the interrupt level. $\mathrm{A}_{10}-\mathrm{A}_{5}$ are ignored and ADI (Address interval) has no effect.

LTIM: If LTIM $=1$, then the 8259A will operate in the level interrupt mode. Edge detect logic on the interrupt inputs will be disabled.
ADI: CALL address interval. $A D I=1$ then interval $=4$; $A D I=0$ then interval $=8$.
SNGL: Single. Means that this is the only 8259A in the system. If SNGL = 1 no ICW3 will be issued.
IC4: If this bit is set - ICW4 has to be read. If ICW4 is not needed, set IC4 $=0$.

## INITIALIZATION COMMAND WORD 3 (ICW3)

This word is read only when there is more than one 8259A in the system and cascading is used, in which case $\mathrm{SNGL}=0$. It will load the 8 -bit slave register. The functions of this register are:
a. In the master mode (either when $S P=1$, or in buffered mode when M/S = 1 in ICW4) a " 1 " is set for each slave in the system. The master then will release byte 1 of the call sequence (for MCS-80/85 system) and will enable the corresponding slave to release bytes 2 and 3 (for MCS-86 only byte 2 ) through the cascade lines.
b. In the slave mode (either when $\overline{\mathrm{SP}}=0$, or if $\mathrm{BUF}=1$ and $M / S=0$ in ICW4) bits 2-0 identify the slave. The slave compares its cascade input with these bits and, if they are equal, bytes 2 and 3 of the call sequence (or just byte 2 for MCS-86) are released by it on the Data Bus.

## INITIALIZATION COMMAND WORD 4 (ICW4)

SFNM: If $S F N M=1$ the special fully nested mode is programmed.
BUF: If BUF = 1 the buffered mode is programmed. In buffered mode $\overline{S P} / \overline{E N}$ becomes an enable outpu't and the master/slave determination is by M/S.
M/S: If buffered mode is selected: $M / S=1$ means the 8259A is programmed to be a master, $M / S=0$ means the 8259A is programmed to be a slave. If $B U F=0, M / S$ has no function.
AEOI: If $A E O I=1$ the automatic end of interrupt mode is programmed.
$\mu \mathrm{PM}$ : Microprocessor mode: $\mu \mathrm{PM}=0$ sets the 8259A for MCS-80/85 system operation, $\mu \mathrm{PM}=1$ sets the 8259A for MCS-86 system operation.


Figure 1. Initialization Sequence


NOTE 1: SLAVED ID IS EQUAL TO THE CORRESPONDING MASTER IR INPUT. NOTE 2: X INDICATED "DON'T CARE".

## OPERATION COMMAND WORDS (OCWs)

After the Initialization Command Words (ICWs) are programmed into the 8259A, the chip is ready to accept interrupt requests at its input lines. However, during the 8259A operation, a selection of algorithms can command the 8259A to operate in various modes through the Operation Command Words (OCWs).

## OPERATION CONTROL WORDS (OCWs)

| OCW1 |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| M7 | M6 | M5 | M4 | M3 | M2 | M1 | M0 |


| OCW2 |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| R | SEOI | EOI | 0 | 0 | L2 | L1 | L0 |


| OCW3 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 SSMM SMM 0 1 P SRIS |

## OPERATION CONTROL WORD 1 (OCW1)

OCW1 sets and clears the mask bits in the interrupt Mask Register (IMR). $M_{7}-M_{0}$ represent the eight mask bits. $M=1$ indicates the channel is masked (inhibited), $M=0$ indicates the channel is enabled.

## OPERATION CONTROL WORD 2 (OCW2)

R, SEOI, EOI - These three bits control the Rotate and End of Interrupt modes and combinations of the two. A chart of these combinations can be found on the Operation Command Word Format.
$L_{2}, L_{1}, L_{0}$ - These bits determine the interrupt level acted upon when the SEOI bit is active.

## OPERATION CONTROL WORD 3 (OCW3)

ESMM - Enable Special Mask Mode. When this bit is set to 1 it enables the SMM bit to set or reset the Special Mask Mode. When ESMM $=0$ the SMM bit becomes a "don't care".

SMM - Special Mask Mode. If ESMM = 1 and $S M M=1$ the 8259A will enter Special Mask Mode. If ESMM $=1$ and $S M M=0$ the 8259A will revert to normal mask mode. When $E S M M=0, S M M$ has no effect.



## INTERRUPT MASKS

Each Interrupt Request input can be masked individually by the Interrupt Mask Register (IMR) programmed through OCW1. Each bit in the IMR masks one interrupt channel if it is set (1). Bit 0 masks IR0, Bit 1 masks IR1 and so forth. Masking an IR channel does not affect the other channels operation.

## SPECIAL MASK MODE

Some applications may require an interrupt service routine to dynamically alter the system priority structure during its execution under software control. For example, the routine may wish to inhibit lower priority requests for a portion of its execution but enable some of them for another portion.
The difficulty here is that if an Interrupt Request is acknowledged and an End of Interrupt command did not reset its IS bit (i.e., while executing a service routine), the 8259A would have inhibited all lower priority requests with no easy way for the routine to enable them
That is where the Special Mask Mode comes in. In the special Mask Mode, when a mask bit is set in OCW1, it inhibits further interrupts at that level and enables interrupts from all other levels (lower as well as higher) that are not masked.
Thus, any interrupts may be selectively enabled by loading the mask register.
The special Mask Mode is set by OCW3 where: $S S M M=1, S M M=1$, and cleared where $S S M M=1$, $S M M=0$.

## BUFFERED MODE

When the 8259A is used in a large system where bus driving buffers are required on the data bus and the cascading mode is used, there exists the problem of enabling buffers.
The buffered mode will structure the 8259A to send an enable signal on $\overline{S P} / \overline{E N}$ to enable the buffers. In this mode, whenever the 8259A's data bus outputs are enabled, the $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ output becomes active.
This modification forces the use of software programming to determine whether the 8259A is a master or a slave. Bit 3 in ICW4 programs the buffered mode, and bit 2 in ICW4 determines whether it is a master or a slave.

## FULLY NESTED MODE

This mode is entered after initialization unless another mode is programmed. The interrupt requests are ordered in priority form 0 through 7 ( 0 highest). When an interrupt is acknowledged the highest priority request is determined and its vector placed on the bus. Additionally , a bit of the Interrupt Service register (ISO-7) is set. This bit remains set until the microprocessor issues an End of Interrupt (EOI) command immediately before returning from the service routine, or if AEOI (Automatic End of Interrupt) bit is set, until the trailing edge of the last INTA. While the IS bit is set, all further interrupts of the same or lower priority are inhibited, while higher levels will generate an interrupt (which will be acknowledged only if the microprocessor internal Interrupt enable flip-flop has been re-enabled through software).
After the initialization sequence, IRO has the hignest priority and IR7 the lowest. Priorities can be changed, as will be explained, in the rotating priority mode.

## THE SPECIAL FULLY NESTED MODE

This mode will be used in the case of a big system where cascading is used, and the priority has to be conserved within each slave. In this case the fully nested mode will be programmed to the master (using ICW4). This mode is similar to the normal nested mode with the following exceptions:
a. When an interrupt request from a certain slave is in service this slave is not locked out from the master's priority logic and further interrupt requests from higher priority IR's within the slave will be recognized by the master and will initiate interrupts to the processor. (In the normal nested mode a slave is masked out when its request is in service and no higher requests from the same slave can be serviced.)
b. When exiting the Interrupt Service routine the software has to check whether the interrupt serviced was the only one from that slave. This is done by sending a non-specific End of Interrupt (EOI) command to the slave and then reading its In -Service register and checking for zero. If it is empty, a non-specific EOI can be sent to the master too. If not, no EOI should be sent.

## POLL

In this mode the microprocessor internal Interrupt Enable flip-flop is reset, disabling its interrupt input. Service to devices is achieved by programmer initiative using a Poll command.

The Poll command is issued by setting $P=$ " 1 " in OCW3. The 8259A treats the next $\overline{R D}$ pulse to the 8259A (i.e., $\overline{\mathrm{RD}}=0, \overline{\mathrm{CS}}=0$ ) as an interrupt acknowledge, sets the appropriate iS bit if there is a request, and reads the priority level. Interrupt is frozen from $\overline{W R}$ to $\overline{R D}$.

The word enabled onto the data bus during $\overline{R D}$ is:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | - | - | - | - | W2 | W1 | W0 |

W0-W2: Binary 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 command common to several levels so that the INTA sequence is not needed (saves ROM space). Another application is to use the poll mode to expand the number of priority levels to more than 64.

## END OF INTERRUPT (EOI)

The In Service (IS) bit can be reset either automatically following the trailing edge of the last in sequence INTA pulse (when AEOI bit in ICW1 is set) or by a command word that must be issued to the 8259A before returning from a service routine (EOI command). An EOI command must be issued twice, once for the master and once for the corresponding slave if slaves are in use.
There are two forms of EOI command: Specific and NonSpecific. When the 8259A 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 8259A 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 serviced.
However, when a mode is used which may disturb the fully nested structure, the 8259A may no longer be able to determine the last level acknowledged. In this case a Specific End of Interrupt (SEOI) must be issued which includes as part of the command the IS level to be reset. EOI is issued whenever EOI $=1$, in OCW2, where LO-L2 is the binary level of the IS bit to be reset. Note that although the Rotate command can be issued together with an EOI where EOI $=1$, it is not necessarily tied to it.

It should be noted that an IS bit that is masked by an IMR bit will not be cleared by a non-specific EOI if the 8259A is in the Special Mask Mode.

## AUTOMATIC END OF INTERRUPT (AEOI) MODE

If AEOI = 1 in ICW4, then the 8259A will operate in AEOI mode continuously until reprogrammed by ICW4. In this mode the 8259A will automatically perform a nonspecific EOI operation at the trailing edge of the last interrupt acknowledge pulse (third pulse in MCS-80/85,
second in MCS-86). Note that from a system standpoint, this mode should be used only when a nested multilevel interrupt structure is not required within a single 8259A.
To achieve automatic rotation (Rotate Mode A) within AEOI, there is a special rotate flip-flop. It is set by OCW2 with $R=1, \mathrm{SEOI}=0, E O I=0$, and cleared with $R=0$, $S E O I=0, E O I=0$.

## ROTATING PRIORITY MODE A (AUTOMATIC ROTATION) FOR EQUAL PRIORITY DEVICES

In some applications there are a number of interrupting devices of equal priority. In this mode a device, after being serviced, receives the lowest priority, so a device requesting an interrupt will have to wait, in the worst case until each of 7 other devices are serviced at most once. For example, if the priority and "in service" status is:

Before Rotate (IR4 the highest priority requiring service)


After Rotate (IR4 was serviced, all other priorities rotated correspondingly)

| "IS" Status | 157 | 156 | IS5 | IS4 | IS3 | IS2 | IS1 | ISO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Highest Priority |  |  |  |  | Lowest Priority |  |  |
| Priority Status | 2 |  | 0 | 7 | 6 | 5 | 4 | 3 |

The Rotate command mode A is issued in OCW2 where: $R=1, E O I=1, S E O I=0$. Internal status is updated by an End of Interrupt ( EOI or AEOI ) command. If $\mathrm{R}=1, \mathrm{EOI}=0$, SEOI $=0$, a "Rotate-A" flip-flop is set. This is useful in AEOI, and described under Automatic End of Interrupt.

## ROTATING PRIORITY MODE B (ROTATION BY SOFTWARE)

The programmer can change priorities by programming the bottom priority and thus fixing all other priorities; i.e., if IR5 is programmed as the bottom priority device, then IR6 will have the highest one.
The Rotate command is issued in OCW2 where: $R=1$, SEOI = 1; L0-L2 is the binary priority level code of the bottom priority device.
Observe that in this mode internal status is updated by software control during OCW2. However, it is independent of the End of Interrupt (EOI) command (also executed by OCW2). Priority changes can be executed during an EOI command or independently.


NOTES
. MASTER CLEAR ACTIVE ONLY DURING ICWI
FAEEZE/ IS ACTIVE DURING INTA/ AND FOLL SEQUENCES ONLY
TAUTH TABLE FOR D.LATCH


Priority Cell - Simplified Logic Diagram

## LEVEL TRIGGERED MODE

This mode is programmed using bit 3 in ICW1.
If LTIM $=$ ' 1 ', an interrupt request will be recognized by a 'high' level on IR Input, and there is no need for an edge detection. The interrupt request must be removed before the EOI command is issued or the CPU interrupt is enabled to prevent a second interrupt from occurring.

The above figure shows a concep:ual circuit to give the reader an understanding of the level sensitive and edge sensitive input circuitry of the 8259A. Be sure to note that the request latch is a transparent $D$ type latch.

## READING THE 8259A 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 Mask Register: 8-bit register whose content specifies the interrupt request lines being masked. 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, a $\overline{W R}$ pulse is issued with OCW3 (ERIS $=1$, RIS $=0$.)
The ISR can be read in a similar mode when ERIS $=1$, RIS $=1$ in the OCW3.
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 8259A "remembers" whether the IRR or ISR has been previously selected by the OCW3. This is not true when poll is used.
After initialization the 8259A is set to IRR.
For reading the IMR, no OCW3 is needed. The output data bus will contain the IMR whenever $\overline{R D}$ is active and $A 0=1$.

Polling overrides status read when $P=1, E R I S=1$ in OCW3.

## SUMMARY OF 8259A INSTRUCTION SET



## SUMMARY OF 8259A INSTRUCTION SET (Cont.)



Note: 1. In the master mode $\overline{\mathrm{SP}}$ pin $=1$, in slave mode $\overline{\mathbf{S P}}=0$

## Cascading

The 8259A can be easily interconnected in a system of one master with up to eight slaves to handle up to 64 priority levels.
A typical MCS-80/85 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 slave interrupt outputs are connected to the master interrupt request inputs. When a slave request line is activated and afterwards acknowledged, the master will enable the corresponding slave to release the device routine address during bytes 2 and 3 of INTA. (Byte 2 only for MCS-86). The IRO input should
not be connected to a slave 8259A unless IR1-I.R7 also have slaves attached.

The cascade bus lines are normally low and will contain the slave address code from the trailing edge of the first INTA pulse to the trailing edge of the third pulse. It is obvious that each 8259A 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 (टS) input of each 8259A.
The cascade lines of the Master 8259A are activated for any interrupt input, even if no slave is connected to that input.


INTERRUPT REQUESTS

Figure 2. Cascading the 8259A

## PIN FUNCTIONS

| Name | I/O | Pin $\#$ | Function |
| :--- | :---: | :---: | :--- |
| $V_{\text {CC }}$ |  | 28 | +5V supply. |
| GND |  | 14 | Ground. |
| $D_{0-7}$ | I/O | $11-4$ | Bidirectional data bus, used for: | a) programming the mode of the 8259A (programming is done by software); b) the microprocessor can read the status of the 8259A; c) the 8259A will send vectoring data to the microprocessor when an interrupt is acknowledged.

$\mathrm{IR}_{0-7} \quad \mid \quad 18-25$ Interrupt Requests: These are asynchronous inputs. A positivegoing edge will generate an interrupt request. Thus a request can be generated by raising the line and holding it high until acknowledged, or by a negative pulse. In level triggered mode, no edge is required. These lines are active HIGH.
$\overline{R D} \quad 1 \quad 3$ Read (generally from 8228 in MCS-80 system or from 8086 in MCS-86 system).
$\overline{W R} 12$ Write (generally from 8228 in MCS-80 sytem or from 8086 in MCS-86 system).
INTA $\quad 26$ Interrupt Acknowledge (generally from 8228 in MCS-80 system, 8086 in MCS-86 system). The 8228 generates three distinct $\overline{\mathrm{NTA}}$ pulses when a CALL is inserted, the 8086 produces two distinct $\overline{\text { INTA }}$ pulses during an interrupt cycle.

Usually the least significant bit of the microprocessor address output (A1 in MCS-86 system). When $A 0=1$ the Interrupt Mask Register can be loaded or read. When $A 0=0$ the 8259A mode can be programmed or its status can be read. $\overline{\mathrm{CS}}$ is active LOW.

INT O 17 Goes directly to the microprocessor interrrupt input. This output will have high $\mathrm{V}_{\mathrm{OH}}$ to match the $80803.3 \mathrm{~V} \mathrm{~V}_{1 \mathrm{H}}$. INT is active HIGH.

C0-C2 I/O 12 Three cascade lines, outputs in 13 master mode and inputs in slave 15 mode. The master issues the binary code of the acknowledged interrupt level on these lines.
Each slave compares this code with its own.
$\overline{S P} / E N \quad / / O \quad 16 \quad \overline{S P} / E N$ is a dual function pin. In the buffered mode $\overline{\mathbf{S P}} / \overline{E N}$ is used to enable bus transceivers (EN). In the non-buffered mode $\overline{\mathrm{SP} / E N}$ determines if this 8259A is a master or a slave. If $\overline{\mathrm{SP}}=1$ the 8259A is master; $\overline{\mathrm{SP}}=0$ indicates a slave.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias ..... $-40^{\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 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 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

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%(8259-\mathrm{A}), \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ (8259A)

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -.5 | V |  |  |
| $\mathrm{~V}_{\mathrm{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.2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OH}(\mathrm{INT})}$ | Interrupt Output High |  |  |  |  |
| Voltage | 3.5 |  | C | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{LOL}}$ | Output Leakage Current |  | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \mathrm{to} 0 \mathrm{~V}$ |  |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | -10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{LIR}}$ | IR Input Load Current |  | 85 | mA |  |

8259A A.C. CHARACTERISTICS
$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} \quad \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ (8259A-8) $\quad \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ (8259A)
TIMING REQUIREMENTS
8259A-8
8259A

| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TAHRL | AO/CS Setup to $\overline{\text { RD }} / \overline{\mathrm{N} T A} \downarrow$ | 50 |  | 0 |  | ns |  |
| TRHAX | AO/ $\overline{C S}$ Hold after $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \uparrow$ | 5 |  | 0 |  | ns |  |
| TRLRH | $\overline{R D}$ Pulse Width | 420 |  | 235 |  | ns |  |
| TAHWL | AO/CS Setup towR $\downarrow$ | 50 |  | 0 |  | ns |  |
| TWHAX | AO/ $\overline{C S}$ Hold after $\overline{W R} \uparrow$ | 20 |  | 0 |  | ns |  |
| TWLWH | $\overline{\text { WR Pulse Width }}$ | 400 |  | 290 |  | ns |  |
| TDVWH | Data Setup to $\overline{W R} \uparrow$ | 300 |  | 240 |  | ns |  |
| TWHDX | Data Hold after $\overline{W R} \uparrow$ | 40 |  | 0 |  | ns |  |
| TJLJH | Interrupt Request Width (Low) | 100 |  | 100 |  | ns | See Note 1 |
| TCVIAL | Cascade Setup to Second or Third INTA $\downarrow$ (Slave Only) | 55 |  | 55 |  | ns |  |
| TRHRL | End of $\overline{R D}$ to Next Command | 300 |  | 160 |  | ns |  |
| TWHRL | End of $\overline{W R}$ to Next Command | 370 |  | 190 |  | ns |  |

Note: 1 . This is the low time required to clear the input latch in the edge triggered mode.

TIMING RESPONSES
8259A-8
8259A

| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TRLDV | Data Valid from $\overline{\mathrm{RD}} / \overline{\mathrm{NT}}$ / $\downarrow$ |  | 300 |  | 200 | ns | $\begin{aligned} & \text { C of Data Bus } \\ & \text { Max. test } \mathrm{C}=100 \mathrm{pF} \\ & \text { Min. test } \mathrm{C}=15 \mathrm{pF} \\ & \mathrm{C}_{\text {INT }}=100 \mathrm{pF} \\ & \text { CeNABLE }=15 \mathrm{pF} \end{aligned}$ |
| TRHDZ | Data Float after $\overline{\text { RD }} / \overline{\text { NTA }} \uparrow$ | 10 | 200 |  | 100 | ns |  |
| TJHIH | Interrupt Output Delay |  | 400 |  | 350 | ns |  |
| TIALCV | Cascade Valid from First INTA $\downarrow$ (Master Only) |  | 565 |  | 565 | ns |  |
| TRLEL | Enable Active from $\overline{\text { RD }} \downarrow$ or $\overline{\text { NTA }} \downarrow$ |  | 160 |  | 125 | ns |  |
| TRHEH | Enable Inactive from $\overline{\mathrm{RD}} \uparrow$ or $\overline{\mathrm{NTA}} \uparrow$ |  | 325 |  | 150 | ns |  |
| TAHDV | Data Valid from Stable Address |  | 350 |  | 200 | ns |  |
| TCVDV | Cascade Valid to Valid Data |  | 300 |  | 300 | ns |  |

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}_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $\mathrm{V}_{\mathrm{SS}}$ |

Input and Output Waveforms for A.C. Tests


WRITE MODE

## READINTA MODE



## OTHER TIMING



INTA SEQUENCE


[^14]
## int

# 8355*/8355-2** 16,384-BIT ROM WITH I/O *Directly Compatible with 8085A CPU **Directly Compatible with 8085A-2 

■ 2048 Words $\times 8$ Bits
■ Single + 5V Power Supply

## ■ 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 Intel® 8355 is a ROM and I/O chip to be used in the MCS-85"w microcomputer system. The ROM portion is organized as 2048 words by 8 bits. It has a maximum access time of 400 ns to permit use with no wait states in the 8085A CPU.

The I/O portion consists of 2 general purpose I/O ports. Each I/O port has 8 port lines, and each I/O port line is indivdually programmable as input or output.

The 8355-2 has a 300ns access time for compatibility with the 8085A-2 microprocessor.

PIN CONFIGURATION


BLOCK DIAGRAM


| Symbol | Function |
| :---: | :---: |
| ALE <br> (Input) | When ALE (Address Latch Enable is high, $\mathrm{AD}_{0-7}, 1 \mathrm{O} / \overline{\mathrm{M}}, \mathrm{A}_{8-10}, \mathrm{CE}$, and $\overline{\mathrm{CE}}$ enter address latched. The signals ( $\mathrm{AD}, 10 / \bar{M}, \mathrm{~A}_{8-10}, \mathrm{CE}, \overline{\mathrm{CE}}$ ) are latched in at the trailing edge of ALE. |
| AD0-7 <br> (Input) | Bidirectional Address/Data bus. The lower 8-bits of the ROM or 1/O address are applied to the bus lines when ALE is high. <br> 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{I O R}$ is low when the latched chip enables are active, the output buffers present data on the bus. |
| A8-10 (Input) | These are the high order bits of the ROM address. They do not affect I/O operations. |
| $\overline{\mathrm{CE}}$ <br> CE2 <br> (Input) | Chip Enable Inputs: $\overline{\mathrm{CE}}_{1}$ is active low and $\mathrm{CE}_{2}$ 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 $\mathrm{AD}_{0-7}$ and READY outputs will be in a high impedance state. |
| $\begin{aligned} & 10 / \bar{M} \\ & \text { (Input) } \end{aligned}$ | If the latched $10 / \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. |
| $\overline{R D}$ <br> (Input) | If the latched Chip Enables are active when $\overline{R D}$ 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{O R}$ are high, the AD0-7 output buffers are 3-state. |
| $\begin{aligned} & \overline{1 O W} \\ & \text { (Input) } \end{aligned}$ | 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 $\mathrm{AD}_{0-7}$. The state of $10 / \bar{M}$ is ignored. |

## Symbol

CLK
(Input)

READY

PB0-7
(Input/
Output)
RESET
(Input)
$\overline{\text { IOR }}$
(Input)
$V_{C C}$
Vss

## Function

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 is a 3-state output controlled by $\mathrm{CE}_{1}, C E_{2}$, 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 6).
These are general purpose $1 / 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{O W}$ is low and a 0 was previously latched from $A D_{0}$.
Read operation is selected by either $\overline{I O R}$ 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 $1 / O$ port is identical to Port A except that it is selected by a 1 latched from $A D_{0}$.
An input high on RESET causes all pins in Port $A$ and $B$ to assume input mode.
When the Chip Enables are active, a low on $\overline{\mathrm{OR}}$ will output the selected I/O port onto the AD bus. $\overline{I O R}$ low performs the same function as the combination $10 / \bar{M}$ high and $\overline{\mathrm{RD}}$ low. When $\overline{\mathrm{OR}}$ is not used in a system, $\overline{\mathrm{O}} \bar{R}$ should be tied to $\mathrm{V}_{\mathrm{CC}}$ ("1").
+5 volt supply.
Ground Reference.

## ABSOLUTE MAXIMUM RATINGS*

| ias | $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 +7V |
| Power Dissipation | 1.5 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 $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{I L}$ | Input Low Voltage | -0.5 | 0.8 | V | $V_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~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{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}_{\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 | 8355 |  | $\begin{gathered} 8355-2 \\ \text { (Preliminary) } \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| tcrc | Clock Cycle Time | 320 |  | 320 |  | ns |
| T1 | CLK Pulse Width | 80 |  | 80 |  | ns |
| $\mathrm{T}_{2}$ | CLK Pulse Width | 120 |  | 120 |  | ns |
| $\mathrm{t}_{\mathrm{f}, \mathrm{tr}_{r}}$ | CLK Rise and Fall Time |  | 30 |  | 30 | ns |
| $\mathrm{t}_{\mathrm{AL}}$ | Address to Latch Set Up Time | 50 |  | 30 |  | ns |
| tLA | Address Hold Time after Latch | 80 |  | 30 |  | ns |
| tLc | Latch to READ/WRITE Control | 100 |  | 40 |  | ns |
| $t_{\text {RD }}$ | Valid Data Out Delay from READ Control |  | 170 |  | 140 | ns |
| $t_{A D}$ | Address Stable to Data Out Valid |  | 400 |  | 330 | ns |
| tLL | Latch Enable Width | 100 |  | 70 |  | ns |
| trif | Data Bus Float after READ | 0 | 100 | 0 | 85 | ns |
| tcl | READ/WRITE Control to Latch Enable | 20 |  | 10 |  | ns |
| tcc | READ/WRITE Control Width | 250 |  | 200 |  | ns |
| tow | Data In to Write Set Up Time | 150 |  | 150 |  | ns |
| two | Data In Hold Time After WRITE | 10 |  | 10 |  | ns |
| twp | WRITE to Port Output |  | 400 |  | 400 | ns |
| tPR | Port Input Set Up Time | 50 |  | 50 |  | ns |
| $t_{\text {RP }}$ | Port Input Hold Time | 50 |  | 50 |  | ns |
| $t_{\text {RYM }}$ | READY HOLD Time | 0 | 160 | 0 | 160 | ns |
| tary | ADDRESS (CE) to READY |  | 160 |  | 160 | ns |
| trv | Recovery Time Between Controls | 300 |  | 200 |  | ns |
| trde | READ Control to Data Bus Enable | 10 |  | 10 |  | ns |

Note: CLOAD $=150 \mathrm{pF}$


Figure 1. Clock Specification for 8355


Figure 2. ROM Read and I/O Read and Write

## a. Input Mode


b. Output Mode

*DATA BUS TIMING IS SHOWN IN FIGURE 4.

Figure 3. I/O Port Timing


Figure 4. Wait State Timing (READY $=0$ )

## 8755A <br> 16,384-BIT EPROM WITH I/O <br> Directly Compatible with 8085A CPU

\author{

- 2048 Words $\times 8$ Bits <br> - Single + 5V Power Supply ( $\mathbf{V}_{\text {cc }}$ ) <br> - U.V. Erasable and Electrically Reprogrammable
}

\author{

- 2 General Purpose 8-Bit I/O Ports <br> Each I/O Port Line Individually Programmable as Input or Output <br> - Multiplexed Address and Data Bus <br> 40-Pin DIP
}

The Intel® 8755A is an erasable and electrically reprogrammable ROM (EPROM) and I/O chip to be used in the MCS-85 ${ }^{\mathrm{mm}}$ microcomputer system. The EPROM portion is organized as 2048 words by 8 bits. It has a maximum access time of 450 ns to permit use with no wait states in an 8085A CPU.
The I/O portion consists of 2 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


## 8755A FUNCTIONAL PIN DEFINITION

| Symbol | Function |
| :---: | :---: |
| ALE <br> (input) | When Address Latch Enable goes high, $A D D 0-7, ~_{\text {IO/M, }} \mathrm{A}_{8-10}, \mathrm{CE}_{2}$, and $\overline{\mathrm{CE}}_{1}$ enter the address latches. The signals (AD, IO/M, A8-10, CE) are latched in at the trailing edge of ALE. |
| AD0-7 (input/output) | Bidirectional 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. |
| A8-10 (input) | These are the high order bits of the PROM address. They do not affect I/O operations. |
| $\begin{aligned} & \text { PROG/ } \overline{\mathrm{CE}_{1}} \\ & \mathrm{CE}_{2} \\ & \text { (input) } \end{aligned}$ | Chip Enable Inputs: $\overline{\mathrm{CE}_{1}}$ is active low and $C E_{2}$ is active high. The 8755A 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 $\mathrm{AD}_{0-7}$ and READY outputs will be in a high impedance state. $\overline{\mathrm{CE}} \mathrm{F}_{1}$ is also used as a programming pin. (See section on programming.) |
| $10 / \bar{M}$ (input) | If the latched $10 / \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 PROM. |
| $\overline{R D}$ (input) | If the latched Chip Enables are active when $\overline{R D}$ goes low, the $A D_{0-7 ~ o u t p u t ~}^{\text {on }}$ buffers are enabled and output either the selected PROM location or I/O port. When both $\overline{\mathrm{RD}}$ and $\overline{\mathrm{IOR}}$ are high, the $\mathrm{AD}_{0-7}$ output buffers are 3-stated. |
| $\overline{10 W}$ (input) | If the latched Chip Enables are active, a low on IOW 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 $1 O / \bar{M}$ is ignored. |
| CLK (input) | The CLK is used to force the READY into its high impedance state after it has been forced low by $\overline{C E}_{1}$ low, $\mathrm{CE}_{2}$ high, and ALE high. |

## ERASURE CHARACTERISTICS

The erasure characteristics of the 8755A 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 8755A in approximately 3 years while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 8755A 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 for the 8755A 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 8755A 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 8755A 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 8755A can be programmed on the Intel ${ }^{\circledR}$ Universal PROM Programmer (UPP), and the PROMPT ${ }^{\text {M }} 80 / 85$ and PROMPT-48 ${ }^{\text {TM }}$ design aids. The appropriate programming modules and adapters for use in programming both 8755A's and 8755's are shown in Table 1.

The program mode itself consists of programming a single address at a time, giving a single 50 msec pulse for every address. Generally, it is desirable to have a verify cycle after a program cycle for the same address as shown in the attached timing diagram. In the verify cycle (i.e., normal memory read cycle) ' $V_{D D}$ ' should be at +5 V .
Preliminary timing diagrams and parameter values pertaining to the 8755A programming operation are contained in Figure 6.

TABLE 1. 8755A PROGRAMMING MODULE CROSS REFERENCE

| MODULE NAME | USE WITH |
| :--- | :--- |
| UPP 955 | UPP(4) |
| UPP UP2(2) | UPP 855 |
| PROMPT 975 | PROMPT 80/85(3) |
| PROMPT 475 | PROMPT 48(1) |
| NOTES: |  |
| 1. Described on p. 11-9 of 1978 System Data Catalog. |  |
| 2. Special adaptor socket. |  |
| 3. Described on p. 11-3 of 1978 System Data Catalog. |  |
| 4. Described on p. 10-85 of 1978 System Data Catalog. |  |

## SYSTEM APPLICATIONS

## System Interface with 8085A

A system using the 8755A 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 $C E_{2}$ and $\overline{C E}_{1}$. By using a combination of unused address lines $\mathrm{A}_{11-15}$ and the Chip Enable inputs, the 8085A system can use up to 5 each 8755A's without requiring a CE decoder.

If a memory mapped I/O approach is used the 8755A 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 1.

*NOTE: Optional connection.

Figure 1. 8755A in 8085A 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 to $+7 \mathrm{~V}^{*}$ |
| Power Dissipation | 1.5 W |
| *Except for programm |  |

*COMMENT
Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress ratıng 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 $\quad\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 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\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{l}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{l}_{\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 $\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 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ 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 |  |
| ${ }^{\text {t }}$ 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 |  | 170 | ns |  |
| $t_{\text {AD }}$ | Address Stable to Data Out Valid |  | 450 | ns |  |
| $t_{L L}$ | Latch Enable Width | 100 |  | ns |  |
| $t_{\text {RDF }}$ | Data Bus Float after READ | 0 | 100 | ns |  |
| ${ }^{\text {che }}$ | READ/WRITE Control to Latch Enable | 20 |  | ns |  |
| ${ }^{\text {t }} \mathrm{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 | 30 |  | ns |  |
| $t_{W P}$ | WRITE to Port Output |  | 400 | ns |  |
| $t_{\text {PR }}$ | Port Input Set Up Time | 50 |  | ns |  |
| $t_{\text {R }}$ | Port Input Hold Time | 50 |  | ns |  |
| $t_{\text {RYH }}$ | READY HOLD TIME | 0 | 160 | ns |  |
| $t_{\text {ARY }}$ | ADDRESS (CE) to READY |  | 160 | ns |  |
| $t_{\text {R }} \mathrm{V}$ | Recovery Time between Controls | 300 |  | ns |  |
| $t_{\text {RDE }}$ | Data Out Delay from READ Control | 10 |  | ns |  |
| ${ }^{\text {L LD }}$ | ALE to Data Out Valid |  | 350 | ns | Preliminary |

## WAVEFORMS



Figure 2. Clock Specification for 8755A


Figure 3. PROM Read, I/O Read and Write Timing

## A. INPUT MODE


B. OUTPUT MODE

*DATA BUS TIMING IS SHOWN IN FIGURE 4.

Figure 4. I/O Port Timing


Figure 5. Wait State Timing (READY $=0$ )
D.C. SPECIFICATION PROGRAMMING
( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$; $\mathrm{V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| VDD | Programming Voltage (during Write <br> to EPROM) | 24 | 25 | 26 | V |
| IDD | Prog Supply Current |  | 15 | 30 | mA |

## A.C. SPECIFICATION FOR PROGRAMMING

( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$; $\mathrm{VSS}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{P S}$ | Data Setup Time | 10 |  |  | ns |
| $t_{P D}$ | Data Hold Time | 0 |  |  | ns |
| $\mathrm{ts}_{\mathrm{s}}$ | Prog Pulse Setup Time | 2 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{H}}$ | Prog Pulse Hold Time | 2 |  |  | $\mu \mathrm{~s}$ |
| tPR $^{\text {tPF }}$ | Prog Pulse Rise Time | Prog Pulse Fall Time | 0.01 | 2 |  |
| tPRG | Prog Pulse Width | 0.01 | 2 | $\mu \mathrm{~s}$ |  |

## WAVEFORMS


*VERIFY CYCLE IS A REGULAR MEMORY READ CYCLE (WITH VDD $=+5 \mathrm{~V}$ FOR 8755A)

Figure 6. 8755A Program Mode Timing Diagram


## MCS-86 MICROPROCESSOR

## TABLE OF CONTENTS

8086/8086-4 16-Bit HMOS Microprocessor ..... 10-4
8282/8283 Octal Latch ..... 10-23
8284 Clock Generator and Drive for 8086 CPU ..... 10-27
8286/8287 Octal Bus Transceiver ..... 10-33
8288 Bus Controller for the 8086 CPU ..... 10-37

## THE MCS-86 MICROPROCESSOR FAMILY

## INTRODUCTION

The Intel ${ }^{\circledR}$ 8086, a new microcomputer, extends the midrange 8080 family into the 16 -bit arena. The chip has attributes of both 8 - and 16 -bit processors. By executing the full set of 8080A/8085 8-bit instructions plus a powerful new set of 16 -bit instructions, it enables a system designer familiar with existing 8080 devices to boost performance by a factor of as much as 10 while using essentially the same 8080 software package and development tools.

The goals of the 8086 architectural design were to extend existing 8080 features symmetrically, across the board, and to add processing capabilities not to be found in the 8080. The added features include 16-bit arithmetic, signed 8 - and 16 -bit arithmetic (including multiply and divide), efficient interruptible byte-string
operations, and improved bit manipulation. Significantly, they also include mechanisms for such mini-computer-type operations as reentrant code, positionindependent code, and dynamically relocatable programs. In addition, the processor may directly address up to 1 megabyte of memory and has been designed to support multiple-processor configurations.
Support for the 8086 is provided by offering a complete line of bipolar components: clock generator, octal latches, octal transceivers, and a bus controller. Existing 8-bit peripherals and memories can be used to build your complete system. A configuration option in the 8086 allows a complete 16 -bit system to be built with as little as 11 components (including memory and I/O).

## FURTHER INFORMATION

For more detailed information on the MCS-86 microcomputer family please consult the following Intel publication: MCS-86 User's Manual (order number 9800722A).

RECOMMENDED PRODUCTS FOR MCS-86 MICROCOMPUTER APPLICATIONS

| Function | Part No. | Page No. | Description |
| :---: | :---: | :---: | :---: |
| RAMs (Static) | $\begin{aligned} & 2114 \\ & 2141 \\ & 2142 \\ & 2148 \end{aligned}$ | $\begin{aligned} & 3-54 \\ & 3-89 \\ & 3-95 \\ & 3-106 \end{aligned}$ | $\begin{aligned} & 1 \mathrm{~K} \times 4 \\ & 4 \mathrm{~K} \times 1 \\ & 1 \mathrm{~K} \times 4 \\ & 1 \mathrm{~K} \times 4 \text { High Speed } \end{aligned}$ |
| RAMs (Dynamic) | $\begin{aligned} & 2117 \\ & 2118 \end{aligned}$ | $\begin{aligned} & 3-64 \\ & 3-88 \end{aligned}$ | $\begin{aligned} & 16 K \times 1 \\ & 16 K \times 1 \end{aligned}$ |
| RAM Support | 8202 | 11-14 | Dynamic RAM Controller |
| ROMs | 2316E | 4-12 | $2 \mathrm{~K} \times 8$ |
| EPROMs | $\begin{aligned} & 2716 \\ & 2732 \end{aligned}$ | $\begin{aligned} & 4-23 \\ & 4-28 \end{aligned}$ | $\begin{aligned} & 2 K \times 8 \\ & 4 K \times 8 \end{aligned}$ |
| Microprocessor Support | 8205 <br> 8257-5 <br> 8259A <br> 8282 <br> 8283 <br> 8284 <br> 8286 <br> 8287 <br> 8288 | $\begin{gathered} 9-29 \\ 9-92 \\ 9-109 \\ 10-23 \\ 10-23 \\ 10-27 \\ 10-33 \\ 10-33 \\ 10-37 \end{gathered}$ | 1-of-8 Decoder <br> DMA Controller Interrupt Controller 8-Bit Non-Inverting Latch 8-Bit Inverting Latch Clock Generator 8-Bit Non-Inverting Transceiver 8-Bit Inverting Transceiver Bus Controller |
| Peripherals | 8251A <br> 8253-5 <br> 8255A-5 <br> 8271 <br> 8273 <br> 8275 <br> 8278 <br> 8279-5 <br> 8291 <br> 8292 <br> 8294 <br> 8295 <br> 8041/8741 | $\begin{aligned} & 11-24 \\ & 11-32 \\ & 11-43 \\ & 11-64 \\ & 11-93 \\ & 11-118 \\ & 11-142 \\ & 11-152 \\ & 11-164 \\ & 11-188 \\ & 11-190 \\ & 11-201 \\ & 11-3 \end{aligned}$ | USART <br> Counter/Timer <br> Programmable Peripheral Interface <br> Floppy Disk Controller <br> Communications Controller <br> CRT Controller <br> Keyboard/Display Controller <br> Keyboard/Display Controller <br> GPIB Talker/Listener <br> GPIB Controller <br> Data Encrypter <br> Dot Matrix Printer Controller <br> Universal Peripheral Interface |

## 8086/8086-4 16-BIT HMOS MICROPROCESSOR

\author{

- Direct Addressing Capability to 1 MByte of Memory <br> \section*{- Assembly Language Compatible with 8080/8085} <br> - 14 Word, By 16-Bit Register Set with Symmetrical Operations <br> \section*{- 24 Operand Addressing Modes}
}
- Bit, Byte, Word, and Block Operations
- 8-and 16-Bit Signed and Unsigned Arithmetic in Binary or Decimal Including Multiply and Divide
- 5 MHz Clock Rate (4 MHz for 8086-4)
- MULTIBUS ${ }^{\text {TM }}$ System Compatible Interface

The Intel ${ }^{\circledR} 8086$ is a new generation, high performance microprocessor implemented in N -channel, depletion load, silicon gate technology (HMOS), and packaged in a 40-pin CerDIP package. The processor has attributes of both 8 - and 16 -bit microprocessors. It addresses memory as a sequence of 8 -bit bytes, but has a 16 -bit wide physical path to memory for high performance.



40 LEAD

Figure 1. 8086 CPU Functional Block Diagram
Figure 2. 8086 Pin Diagram

## FUNCTIONAL DESCRIPTION

## GENERAL OPERATION

The internal functions of the 8086 processor are partitioned logically into two processing units. The first is the Bus Interface Unit (BIU) and the second is the Execution Unit (EU) as shown in the block diagram of Figure 1.

These units can interact directly but for the most part perform as separate asynchronous operational processors. The bus interface unit provides the functions related to instruction fetching and queuing, operand fetch and store, and address relocation. This unit also provides the basic bus control. The overlap of instruction pre-fetching provided by this unit serves to increase processor performance through improved bus bandwidth utilization. Up to 6 bytes of the instruction stream can be queued while waiting for decoding and execution.
The instruction stream queuing mechanism allows the BIU to keep the memory utilized very efficiently. Whenever there is space for at least 2 bytes in the queue, the BIU will attempt a word fetch memory cycle. This greatly reduces "dead time" on the memory bus. The queue acts as a First-In-First-Out (FIFO) buffer, from which the EU extracts instruction bytes as required. If the queue is empty (following a branch instruction, for example), the first byte into the queue immediately becomes available to the EU.

The execution unit receives pre-fetched instructions from the BIU queue and provides un-relocated operand addresses to the BIU. Memory operands are passed through the BIU for processing by the EU, which passes results to the BIU for storage. See the Instruction Set description for further register set and architectural descriptions.

## MEMORY ORGANIZATION

The processor provides a 20-bit address to memory which locates the byte being referenced. The memory is logically organized as a linear array of 1 million bytes, addressed as $00000(\mathrm{H})$ to FFFFF(H). The memory can be further logically divided into code, data, alternate data, and stack segments of up to 64 K bytes each, with each segment falling on 16 -byte boundaries. (See Figure 3a.)
Word (16-bit) operands can be located on even or odd address boundaries and are thus not constrained to even boundaries as is the case in many 16 -bit computers. For address and data operands, the least significant byte of the word is stored in the lower valued address location and the most significant byte in the next higher address location. The BIU automatically performs the proper number of memory accesses, one if the word operand is on an even byte boundary and two if it is on an odd byte boundary. Except for the performance penalty, this double access is transparent to the software. This performance penalty does not occur for instruction fetches, only word operands.
Physically, the memory is organized as a high bank $\left(D_{15}-D_{8}\right)$ and a low bank ( $D_{7}-D_{0}$ ) of 512 K 8 -bit bytes addressed in parallel by the processor's address lines
$A_{19}-A_{1}$. Byte data with even addresses is transferred on the $D_{7}-D_{0}$ bus lines while odd addressed byte data ( $A_{0}$ HIGH) is transferred on the $D_{15}-D_{8}$ bus lines, The processor provides two enable signals, $\overline{B H E}$ and $A_{0}$, to selectively allow reading from or writing into either an odd byte location, even byte location, or both. The instruction stream is fetched from memory as words and is addressed internally by the processor to the byte level as necessary.


Figure 3a. Memory Organization
In referencing word data the BIU requires one or two memory cycles depending on whether or not the starting byte of the word is on an even or odd address, respectively. Consequently, in referencing word operands performance can be optimized by locating data on even address boundaries. This is an especially useful technique for using the stack, since odd address references to the stack may adversely affect the context switching time for interrupt processing or task multiplexing.
Certain locations in memory are reserved for specific CPU operations (see Figure 3b.) Locations from address FFFFFOH through FFFFFH are reserved for operations including a jump to the initial program loading routine. Following RESET, the CPU will always begin execution at location FFFFOH where the jump must be. Locations 00000 H through 003FFH are reserved for interrupt operations. Each of the 256 possible interrupt types has its service routine pointed to by a 4-byte pointer element consisting of a 16 -bit segment address and a 16 -bit offset address. The pointer elements are assumed to have been stored at the respective places in reserved memory prior to occurrence of interrupts.


Figure 3b. Reserved Memory Locations

## MINIMUM AND MAXIMUM MODES

The requirements for supporting minimum and maximum 8086 systems are sufficiently different that they cannot be done efficiently with 40 uniquely defined pins. Consequently, the 8086 is equipped with a strap
 The definition of a certain subset of the pins changes dependent on the condition of the strap pin. When $M N / \overline{M X}$ pin is strapped to GND, the 8086 treats pins 24 through 31 in maximum mode. An 8288 bus controller interprets status information coded into $\overline{\mathrm{S}}_{0}, \overline{\mathrm{~S}}_{1}, \overline{\mathrm{~S}}_{2}$ to generate bus timing and control signals compatible with the MULTIBUS ${ }^{T M}$. When the MN/MX pin is strapped to $\mathrm{V}_{\mathrm{CC}}$, the 8086 generates bus control signals itself on pins 24 through 31, as shown in parentheses in Figure 2. Examples of minimum mode and maximum mode systems are shown in Figure 4.


Figure 4a. Minimum Mode 8086 Typical System Configuration


Figure 4b. Maximum Mode 8086 Typical System Configuration

## BUS OPERATION

The 8086 has a combined address and data bus commonly referred to as a time multiplexed bus. This technique provides the most efficient use of pins on the processor while permitting the use of a standard 40-lead package. This "local bus" can be buffered directly and used throughout the system with address latching provided on memory and I/O modules. In addition, the bus can also be demultiplexed at the processor with a single set of address latches if a standard non-multiplexed bus is desired for the system.

Each processor bus cycle consists of at least four CLK cycles. These are referred to as $T_{1}, T_{2}, T_{3}$ and $T_{4}$ (see Figure 5). The address is emitted from the processor during $T_{1}$ and data transfer occurs on the bus during $T_{3}$ and $T_{4} . T_{2}$ is used primarily for changing the direction of the bus during read operations. In the event that a "NOT READY" indication is given by the addressed device, "Wait" states ( $T_{W}$ ) are inserted between $T_{3}$ and $T_{4}$. Each inserted "Wait" state is of the same duration as a CLK cycle. Periods can occur between 8086 driven bus cycles. These are referred to as "Idle" states ( $T_{1}$ ) or inactive CLK cycles. The processor uses these cycles for internal housekeeping.
During $T_{1}$ of any bus cycle the ALE (Address Latch Enable) signal is emitted (by either the processor or the 8288 bus controller, depending on the $M N / \overline{M X}$ strap). At the trailing edge of this pulse, a valid address and certain status information for the cycle may be latched.

Status bits $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}$, and $\overline{\mathrm{S}_{2}}$ are used, in maximum mode, by the bus controller to identify the type of bus transaction according to the following table:

| $\overline{\mathbf{S}_{\mathbf{2}}}$ | $\overline{\mathbf{S}_{\mathbf{1}}}$ | $\overline{\mathbf{S}_{\mathbf{0}}}$ |  |
| :--- | :---: | :---: | :--- |
| 0 (LOW) | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Instruction Fetch |
| 1 | 0 | 1 | Read Data from Memory |
| 1 | 1 | 0 | Write Data to Memory |
| 1 | 1 | 1 | Passive (no bus cycle) |

Status bits $S_{3}$ through $\mathrm{S}_{7}$ are multiplexed with highorder address bits and the $\overline{\mathrm{BHE}}$ signal, and are therefore valid during $T_{2}$ through $T_{4} . S_{3}$ and $S_{4}$ indicate which segment register (see Instruction Set description) was used for this bus cycle in forming the address, according to the following table:

| $\mathbf{S}_{\mathbf{4}}$ | $\mathbf{S}_{\mathbf{3}}$ |  |
| :--- | :--- | :--- |
| 0 (LOW) | 0 | Alternate Data (extra segment) |
| 0 | 1 | Stack |
| 1 (HIGH) | 0 | Code or None |
| 1 | 1 | Data |

$S_{5}$ is a reflection of the PSW interrupt enable bit. $\mathrm{S}_{6}=0$ and $\mathrm{S}_{7}$ is a spare status bit.


Figure 5. Basic System Timing

## I/O ADDRESSING

In the 8086, I/O operations can address up to a maximum of 64 K I/O byte registers or 32 K I/O word registers. The I/O address appears in the same format as the memory address on bus lines $A_{15}-A_{0}$. The address lines $A_{19}-A_{16}$ are zero in I/O operations. The variable I/O instructions which use register DX as a pointer have full address capability while the direct I/O instructions directly address one or two of the 256 I/O byte locations in page 0 of the I/O address space.
I/O ports are addressed in the same manner as memory locations. Even addressed bytes are transferred on the
$D_{7}-D_{0}$ bus lines and odd addressed bytes on $D_{15}-D_{8}$. Care must be taken to assure that each register within an 8 -bit peripheral located on the lower portion of the bus be addressed as even.

## EXTERNAL INTERFACE

## PROCESSOR RESET AND INITIALIZATION

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The 8086 RESET is required to be HIGH for greater than 4 CLK cycles. The

8086 will terminate operations on the high-going edge of RESET and will remain dormant as long as RESET is HIGH. The low-going transition of RESET triggers an internal reset sequence for approximately 10 CLK cycles. After this interval the 8086 operates normally beginning with the instruction in absolute location FFFFOH (see Figure 3b). The details of this operation are specified in the Instruction Set description of the MCS-86 Users' Manual. The RESET input is internally synchronized to the processor clock. At initialization the HIGH-to-LOW transition of RESET must occur no sooner than $50 \mu \mathrm{~s}$ after power-up, to allow complete initialization of the 8086.

If INTR is asserted sooner than 9 CLK cycles after the end of RESET, the processor may execute one instruction before responding to the interrupt. NMI may not be asserted prior to the 2nd CLK cycle following the end of RESET.

## INTERRUPT OPERATIONS

Interrupt operations fall into two classes; software or hardware initiated. The software initiated interrupts and software aspects of hardware interrupts are specified in the Instruction Set description. Hardware interrupts can be classified as non-maskable or maskable.
Interrupts result in a transfer of control to a new program location. A 256-element table containing address pointers to the interrupt service program locations resides in absolute locations 0 through 3FFH (see Figure 3b), which are reserved for this purpose. Each element in the table is 4 bytes in size and corresponds to an interrupt "type". An interrupting device supplies an 8 -bit type number, during the interrupt acknowledge sequence, which is used to "vector" through the appropriate element to the new interrupt service program location.

NON-MASKABLE INTERRUPT $(N M H) W$ git
The processor provides a single non-maskabletrupt pin (NMI) which has higher priority than the maskablein. terrupt request pin (INTR). A typical use would be to act tivate a power failure routine. The NMI is edge-triggered, on a LOW-to-HIGH transition. The activation of this pin causes a type 2 interrupt. (See Instruction Set description.)

NMI is required to have a duration in the HIGH state of greater than two CLK cycles, but is not required to be synchronized to the clock. Any high-going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves of a block-type instruction. Worst case response to NMI would be for multiply, divide, and variable shift instructions. There is no specification on the occurrence of the low-going edge; it may occur before, during, or after the servicing of NMI. Another high-going edge triggers another response if it occurs after the start of the NMI procedure. The signal must be free of logical spikes in general and be free of bounces on the low-going edge to avoid triggering extraneous responses.

## MASKABLE INTERRUPT (INTR)

The 8086 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable FLAG status bit. The interrupt request signal is level triggered. It is internally synchronized during each clock cycle on the high-going edge of CLK. To be responded to, INTR must be present (HIGH) during the clock period preceding the end of the current instruction or the end of a whole move for a block-type instruction. During the interrupt response sequence further interrupts are disabled. The enable bit is reset as part of the response to any interrupt (INTR, NMI, software interrupt or single-step), although the


Figure 6. Interrupt Acknowledge Sequence

FLAGS register which is automatically pushed onto the stack reflects the state of the processor prior to the interrupt. Until the old FLAGS register is restored the enable bit will be zero unless specifically set by an instruction.
During the response sequence (figure 6) the processor executes two successive (back-to-back) interrupt acknowledge cycles. The 8086 emits the LOCK signal from $T_{2}$ of the first bus cycle until $T_{2}$ of the second. $A$ local bus "hold" request will not be honored until the end of the second bus cycle. In the second bus cycle a byte is fetched from the external interrupt system (e.g., 8259A PIC) which identifies the source (type) of the interrupt. This byte is multiplied by four and used as a pointer into the interrupt vector lookup table. An INTR signal left HIGH will be continually responded to within the limitations of the enable bit and sample period. The INTERRUPT RETURN instruction includes a FLAGS pop which returns the status of the original interrupt enable bit when it restores the FLAGS.

## HALT

When a software "HALT" instruction is executed the processor indicates that it is entering the "HALT" state in one of two ways depending upon which mode is strapped. In minimum mode, the processor issues one ALE with no qualifying bus control signals. In Maximum Mode, the processor issues appropriate HALT status on $\bar{S}_{2} \bar{S}_{1} \bar{S}_{0}$ and the 8288 bus controller issues one ALE. The 8086 will not leave the "HALT" state when a local bus "hold" is entered while in "HALT". In this case, the processor reissues the HALT indicator. An interrupt request or RESET will force the 8086 out of the "HALT" state.

## READ/MODIFY/WRITE (SEMAPHORE) OPERATIONS VIA LOCK

The $\overline{\text { LOCK }}$ status information is provided by the processor when directly consecutive bus cycles are required during the execution of an instruction. This provides the processor with the capability of performing read/modify/ write operations on memory (via the Exchange Register With Memory instruction, for example) without the possibility of another system bus master receiving intervening memory cycles. This is useful in multiprocessor system configurations to accomplish "test and set lock" operations. The LOCK signal is activated (forced LOW) in the clock cycle following the one in which the software "LOCK" prefix instruction is decoded by the EU. It is deactivated at the end of the last bus cycle of the instruction following the "LOCK" prefix instruction. While $\overline{\text { LOCK }}$ is active all interrupts are masked and a request on a $\overline{R Q / G T}$ pin will be recorded and then honored at the end of the $\overline{\mathrm{LOCK}}$.

## EXTERNAL SYNCHRONIZATION VIA TEST

As an alternative to the interrupts and general I/O capabilities, the 8086 provides a single softwaretestable input known as the TEST signal. At any time the program may execute a WAIT instruction. If at that time the TEST signal is inactive (HIGH), program execution becomes suspended while the processor waits for TEST
to become active. It must remain active for at least 5 CLK cycles. The WAIT instruction is reexecuted repeatedly until that time. This activity does noticonsume bus cycles. The processor remains in an dole state while waiting. All 8086 drivers go to 3 -state OFF if bus "Hold"'is entered. If interrupts are enabled, they" may" occur while the processor is waiting. When this occurs the processor fetches the WAIT instruction one extra time, processes the interrupt, and then re-fetches and re-executes the WAIT instruction upon returning from the interrupt.

## 8086 COMPARED WITH 8080/8085

While the 8086 has new instruction coding patterns to allow for the greatly expanded capabilities, all functions of the $8080 / 8085$ may be performed by the 8086 with identical program semantics to their 8080/8085 versions. For every $8080 / 8085$ instruction there is a corresponding 8086 instruction (or, in rare cases, a short sequence of instructions). Virtually all 8086 data manipulation instructions may be specified to operate on either the full set of 16 -bit registers or on an 8 -bit subset of them which corresponds to the 8080 register set. This relationship is shown in Figure 7 where the shaded registers (names in parentheses) represent the 8080 register set.

## BASIC SYSTEM TIMING

Typical system configurations for the processor operating in minimum mode and in maximum mode are shown in Figures 4a and 4b, respectively. In minimum mode, the $M N / \overline{M X}$ pin is strapped to $V_{C C}$ and the processor emits bus control signals in a manner similar to the 8085. In maximum mode, the $M N / \overline{M X}$ pin is strapped to $\mathrm{V}_{\mathrm{SS}}$ and the processor emits coded status information which the 8288 bus controller uses to generate MULTIBUSTM compatible bus control signals. Figure 5 illustrates the signal timing relationships.


Figure 7. 8086 Register Model; ( 8080 Registers Shaded)

## SYSTEM TIMING - MINIMUM SYSTEM

The read cycle begins in $T_{1}$ with the assertion of the Address Latch Enable (ALE) signal. The trailing (lowgoing) edge of this signal is used to latch the address information, which is valid on the local bus at this time, into the 8282/8283 latch. The $\overline{B H E}$ and $A_{0}$ signals address the low, high, or both bytes. From $T_{1}$ to $T_{4}$ the $\mathrm{M} / \overline{\mathrm{O}}$ signal indicates a memory or I/O operation. At $\mathrm{T}_{2}$ the address is removed from the local bus and the bus goes to a high impedance state. The read control signal is also asserted at $T_{2}$. The read ( $\overline{\mathrm{RD}}$ ) signal causes the addressed device to enable its data bus drivers to the local bus. Some time later valid data will be available on the bus and the addressed device will drive the READY line HIGH. When the processor returns the read signal to a HIGH level, the addressed device will again 3 -state its bus drivers. If a transceiver ( $8286 / 8287$ ) is required to buffer the 8086 local bus, signals DT/R and $\overline{\mathrm{DEN}}$ are provided by the 8086.

A write cycle also begins with the assertion of ALE and the emission of the address. The M/IO signal is again asserted to indicate a memory or I/O write operation. In the $T_{2}$ immediately following the address emission the processor emits the data to be written into the addressed location. This data remains valid until the middle of $T_{4}$. During $T_{2}, T_{3}$, and $T_{W}$ the processor asserts the write control signal. The write ( $\overline{\mathrm{WR})}$ signal becomes active at the beginning of $T_{2}$ as opposed to the read which is delayed somewhat into $T_{2}$ to provide time for the bus to float.

The $\overline{B H E}$ and $A_{0}$ signals are used to select the proper byte(s) of the memory/lO word to be read or written according to the following table:

| $\overline{\text { BHE }}$ | AO |  |
| :---: | :---: | :--- |
| 0 | 0 | Whole word <br> 0 |
| 1 | 0 | Upper byte from/ <br> to odd address |
| 1 | Lower byte from/ <br> to even address |  |
| 1 | 1 | None |

I/O ports are addressed in the same manner as memory location. Even addressed bytes are transferred on the $D_{7}-D_{0}$ bus lines and odd addressed bytes on $D_{15} D_{8}$ The basic difference between the interrupt, acknowt edge cycle and a read cycle is that the interfapt acknowledge signal (INTA) is asserted in place of the read ( $\overline{\mathrm{RD}}$ ) signal and the address bus is floated. (See Figure 6.) In the second of two successive INTA cycles, a byte of information is read from bus lines $D_{7}-D_{0}$ as supplied by the interrupt system logic (i.e., 8259A Priority Interrupt Controller). This byte identifies the source (type) of the interrupt. It is multiplied by four and used as a pointer into an interrupt vector lookup table, as described earlier.

## BUS TIMING - MEDIUM COMPLEXITY SYSTEMS

For medium complexity systems the $\mathrm{MN} / \overline{\mathrm{MX}}$ pin is connected to $\mathrm{V}_{\text {SS }}$ and the 8288 Bus Controller is added to the system as well as an 8282/8283 latch for latching the system address, and a $8286 / 8287$ transceiver to allow for bus loading greater than the 8086 is capable of handling. Signals ALE, DEN, and DT/R are generated by the 8288 instead of the processor in this configuration although their timing remains relatively the same. The 8086 status outputs ( $\bar{S}_{2}, \overline{\mathrm{~S}}_{1}$, and $\overline{\mathbf{S}}_{0}$ ) provide type-of-cycle information and become 8288 inputs. This bus cycle information specifies read (code, data, or I/O), write (data or I/O), interrupt acknowledge, or software halt. The 8288 thus issues control signals specifying memory read or write, I/O read or write, or interrupt acknowledge. The 8288 provides two types of write strobes, normal and advanced, to be applied as required. The normal write strobes have data valid at the leading edge of write. The advanced write strobes have the same timing as read strobes, and hence data isn't valid at the leading edge of write. The $8286 / 8287$ transceiver receives the usual $T$ and $\overline{O E}$ Inputs from the 8288's DT/ $\bar{R}$ and DEN.
The pointer into the interrupt vector table, which is passed during the second INTA cycle, can derive from an 8259A located on either the local bus or the system bus. If the master 8259A Priority Interrupt Controller is positioned on the local bus, a TTL gate is required to disable the $8286 / 8287$ transceiver when reading from the master 8259A during the interrupt acknowledge sequence and software "poll".

## 8086 FUNCTIONAL PIN DEFINITION

The following pin function descriptions are for 8086 systems in either minimum or maximum mode. The "Local Bus" in these descriptions is the direct multiplexed bus interface connection to the 8086 (without regard to additional bus buffers).

## $A D_{15-A D_{0}}$ (INPUT/OUTPUT 3-STATE)

These lines constitute the time multiplexed memory/IO address $\left(T_{1}\right)$ and data ( $\left.T_{2}, T_{3}, T_{W}, T_{4}\right)$ bus. $A_{0}$ is analogous to $\overline{B H E}$ for the lower byte of the data bus, pins $D_{7}-D_{0}$. It is LOW during $T_{1}$ when a byte is to be transferred on the lower portion of the bus in memory or I/O operations. Eight-bit oriented devices tied to the lower half would normally use $A_{0}$ to condition chip select functions. (See table on page 8.) These lines are active HIGH and float to 3-state OFF during interrupt acknowledge and local bus "hold acknowledge".

## $A_{19} / \mathbf{S}_{6}, A_{18} / \mathbf{S}_{5}, A_{17} / \mathbf{S}_{4}, A_{16} / \mathbf{S}_{3}$ (OUTPUT 3-STATE)

During $T_{1}$ these are the four most significant address lines for memory operations. During I/O operations these lines are LOW. During memory and I/O operations, status information is available on these lines during $T_{2}$, $T_{3}, T_{W}$, and $T_{4}$. The status of the interrupt enable FLAG bit $\left(\mathrm{S}_{5}\right)$ is updated at the beginning of each CLK cycle. $A_{17} / S_{4}$ and $A_{16} / S_{3}$ are encoded as follows:

| $\mathbf{A}_{17} / \mathbf{S}_{\mathbf{4}}$ | $\mathbf{A}_{16} / \mathbf{S}_{\mathbf{3}}$ |  |
| :--- | :---: | :--- |
| 0 (LOW) | 0 | Alternate Data |
| 0 | 1 | Stack |
| 1 (HIGH) | 0 | Code or None |
| 1 | 1 | Data |
| $\mathrm{S}_{6}$ is 0 (LOW |  |  |

This information indicates which relocation register is presently being used for data accessing.
These lines float to 3-state OFF during local bus "hold acknowledge".

## $\overline{\mathrm{BHE}} / \mathrm{S}_{7}$ (OUTPUT 3-STATE)

During $T_{1}$ the bus high enable signal ( $\overline{\mathrm{BHE}}$ ) should be used to enable data onto the most significant half of the data bus, pins $D_{15}-D_{8}$. Eight-bit oriented devices tied to the upper half of the bus would normally use $\overline{B H E}$ to condition chip select functions. $\overline{\mathrm{BHE}}$ is LOW during $\mathrm{T}_{1}$ for read, write, and interrupt acknowledge cycles when a byte is to be transferred on the high portion of the bus. (See table on page 8.) The $\mathrm{S}_{7}$ status information is available during $T_{2}, T_{3}$, and $T_{4}$. The signal is active LOW, and floats to 3-state OFF in "hold". It is LOW during $T_{1}$ for the first interrupt acknowledge cycle.

## $\overline{\mathrm{RD}}$ (OUTPUT 3-STATE)

Read strobe indicates that the processor is performing a memory or I/O read cycle, depending on the state of the $\mathrm{S}_{2}$ pin. This signal is used to read devices which reside
on the 8086 local bus. $\overline{R D}$ is active LOW during $T_{2}, T_{3}$ and $T_{W}$ of any read cycle, and is guaranteed topremain HIGH in $T_{2}$ until the 8086 local bus has floated. This signal floats to 3-state OFF in "hold acknowledge"

## READY (INPUT)

READY is the acknowledgement from the addressed memory or I/O device that it will complete the data transfer. The RDY signal from memory/IO is synchronized by the 8284 Clock Generator to form READY. This signal is active HIGH.

## INTR (INPUT)

Interrupt request is a level triggered input which is sampled during the last clock cycle of each instruction to determine if the processor should enter into an interrupt acknowledge operation. A subroutine is vectored to via an interrupt vector lookup table located in system memory. It can be internally masked by software resetting the interrupt enable bit. INTR is internally synchronized. This signal is active HIGH.

## TEST (INPUT)

The TEST input is examined by the "Wait For Test" instruction. If the TEST input is LOW execution continues, otherwise the processor waits in an "Idle" state. This input is synchronized internally during each clock cycle on the leading edge of CLK.

## NMI (INPUT)

Non-maskable interrupt is an edge triggered input which causes a type 2 interrupt. A subroutine is vectored to via an interrupt vector lookup table located in system memory. NMI is not maskable internally by software. A transition from a LOW to HIGH initiates the interrupt at the end of the current instruction. This input is internally synchronized.

## RESET (INPUT)

RESET causes the processor to immediately terminate its present activity. The signal must be active HIGH for at least four clock cycles. It restarts execution, as described in the Instruction Set description, when RESET returns LOW. RESET is internally synchronized.

## CLK (INPUT)

The clock provides the basic timing for the processor and bus controller. It is asymmetric with a $33 \%$ duty cycle to provide optimized internal timing.
$V_{C c}$
$V_{C C}$ is the $+5 \mathrm{~V} \pm 10 \%$ power supply pin.

## GND

GND are the ground pins

The following pin function descriptions are for the 8086 minimum mode (i.e., $M N / \overline{M X}=V_{C C}$ ). Only the pin functions which are unique to minimum mode are described; all other pin functions are as described above.

## M/ĪO (OUTPUT 3-STATE)

This status line is logically equivalent to $S_{2}$ in the maximum mode. It is used to distinguish a memory access from an $1 / O$ access. $M / \overline{\mathrm{O}}$ becomes valid in the $\mathrm{T}_{4}$ preceding a bus cycle and remains valid until the final $\mathrm{T}_{4}$ of the cycle $(M=H I G H, I O=L O W) . M / \overline{\mathrm{O}}$ floats to 3 -state OFF in local bus "hold acknowledge".

## WR (OUTPUT 3-STATE)

Write strobe indicates that the processor is performing a write memory or write I/O cycle, depending on the state of the $M / \overline{\mathrm{IO}}$ signal. $\overline{W R}$ is active for $T_{2}, T_{3}$ and $T_{W}$ of any write cycle. It is active LOW, and floats to 3 -state OFF in local bus "hold acknowledge".

## INTA (OUTPUT 3-STATE)

$\overline{\text { INTA }}$ is used as a read strobe for interrupt acknowledge cycles. It is active LOW during $T_{2}, T_{3}$ and $T_{W}$ of each interrupt acknowledge cycle. INTA floats to 3-state OFF in "hold acknowledge".

## ALE (OUTPUT)

Address latch enable is provided by the processor to latch the address into the 8282/8283 address latch. It is a HIGH pulse active during $T_{1}$ of any bus cycle. Note that ALE is never floated.

## DT/何 (OUTPUT 3.STATE)

Data transmit/receive is needed in minimum system that desires to use an 8286/8287 data bus transceiver. If is: used to control the direction of data flow through the transceiver. Logically $D T / \bar{R}$ is equivalent to $\overline{S_{1}}$ in the maximum mode, and its timing is the same as for $\mathrm{M} / \overline{\mathrm{IO}} .(\mathrm{T}=\mathrm{HIGH}, \mathrm{R}=\mathrm{LOW}$.) This signal floats to 3 -state OFF in local bus "hold acknowledge".

## $\overline{\mathrm{DEN}}$ (OUTPUT 3-STATE)

Data enable is provided as an output enable for the 8286/8287 in a minimum system which uses the transceiver. $\overline{\mathrm{DEN}}$ is active LOW during each memory and I/O access and for INTA cycles. For a read or INTA cycle it is active from the middle of $T_{2}$ until the middle of $T_{4}$, while for a write cycle it is active from the beginning of $T_{2}$ until the middle of $T_{4}$. $\overline{D E N}$ floats to 3-state OFF in local bus "hold acknowledge".

## HOLD (INPUT), HLDA (OUTPUT)

HOLD indicates that another master is requesting a local bus "hold". To be acknowledged, HOLD must be active HIGH. The processor receiving the "hold" request will issue HLDA (HIGH) as an acknowledgement in the middle of $T_{4}$ or $T_{1}$. Simultaneous with the issuance of HLDA the processor will float the local bus and control lines. After HOLD is detected as being LOW, the processor will LOWer HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control lines. (See Figure 13.)

The following pin function descriptions are for the 8086/8288 system in maximum mode (i.e., MN/ $\overline{M X}=$ $\mathbf{V}_{\mathbf{S S}}$ ). Only the pin functions which are unique to maximum mode are described; all other pin functions are as described above.

## $\overline{\mathbf{S}_{\mathbf{2}}}, \overline{\mathbf{S}_{\mathbf{1}}}, \overline{\mathbf{S}_{\mathbf{0}}}$ (OUTPUT 3-STATE)

These status lines are encoded as follows:

| $\overline{\mathbf{S}_{\mathbf{2}}}$ | $\overline{\mathbf{S}_{1}}$ | $\overline{\mathbf{S}_{\mathbf{0}}}$ |  |
| :--- | :---: | :--- | :--- |
| 0 (LOW) | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | Read I/O Port |
| 0 | 1 | 0 | Write I/O Port |
| 0 | 1 | 1 | Halt |
| 1 (HIGH) | 0 | 0 | Code Access |
| 1 | 0 | 1 | Read Memory |
| 1 | 1 | 0 | Write Memory |
| 1 | 1 | 1 | Passive |

Status is active during $T_{4}, T_{1}$, and $T_{2}$ and is returned to the passive state $(1,1,1)$ during $T_{3}$ or during $T_{W}$ when READY is HIGH. This status is used by the 8288 Bus Controller to generate all memory and $1 / O$ access control signals. Any change by $\overline{\mathrm{S}_{2}}, \overline{\mathrm{~S}_{1}}$, or $\overline{\mathrm{S}_{0}}$ during $\mathrm{T}_{4}$ is used to indicate the beginning of a bus cycle, and the return to the passive state in $T_{3}$ or $T_{W}$ is used to indicate the end of a bus cycle.
These signals float to 3 -state OFF in "hold acknowledge".

## $\overline{\operatorname{RQ}} / \overline{\mathrm{GT}}_{0}, \overline{\mathrm{RQ}} / / \overline{\mathrm{GT}}_{1}$ (INPUT/OUTPUT)

The request/grant pins are used by other local bus masters to force the processor to release the local bus at the end of the processor's current bus cycle. Each pin is bidirectional with $\overline{\mathrm{RQ}} / \overline{G T}_{0}$ having higher priority than $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}_{1} . \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ has an internal pull-up resistor so may be left unconnected. The request/grant sequence is as follows (see Figure 12):

1. A pulse of 1 CLK wide from another local bus master indicates a local bus request ("hold") to the 8086 (pulse 1).
2. During the CPU's next $T_{4}$ or $T_{4}$ a pulse 1 CLK wide from the 8086 to the requesting master (pulse 2), indicates that the 8086 has allowed the local bus to float and that it will enter the 'hold acknowledge" state at the next CLK. The CPU's bus interface unit is disconnected logically from the local bus during "hold acknowledge".
3. A pulse 1 CLK wide from the requesting master indicates to the 8086 (pulse 3) that the "hold" request is about to end and that the 8086 can reclaim the local bus at the next CLK. The CPU then enters $T_{4}$.
Each master-master exchange of the local bus is a sequence of 3 pulses. There must be one dead CL.K cycle after each bus exchange. Pulses are active LOW.

## $\overline{\text { LOCK }}$ (OUTPUT 3-STATE)

The $\overline{\text { LOCK }}$ output indicates that other system bus masters are not to gain control of the system bus while $\overline{\text { LOCK }}$ is active LOW. The $\overline{\text { LOCK }}$ signal is activated by the "LOCK" prefix instruction and remains active until the completion of the next instruction. This signal is active LOW, and floats to 3-state OFF in "hold acknowledge".

## $\mathbf{Q S}_{\mathbf{1}}, \mathbf{Q S}_{\mathbf{0}}$ (OUTPUT)

$\mathrm{QS}_{1}$ and $\mathrm{QS}_{0}$ provide status to allow external tracking of the internal 8086 instruction queue.

| QS $_{\mathbf{1}}$ | QS $_{\mathbf{0}}$ |  |
| :--- | :---: | :--- |
| 0 (LOW) | 0 | No Operation |
| 0 | 1 | First Byte of Op Code from Queue |
| 1 (HIGH) | 0 | Empty the Queue |
| 1 | 1 | Subsequent Byte from Queue |

The queue status is valid during the CLK cycle after which the queue operation is performed.

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

$8086 / 8086-4: T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | + 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{l}_{\mathrm{OH}}=400 \mu \mathrm{~A}$ |
| $I_{\text {CC }}$ | Power Supply Current |  | 275 | mA |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{V}_{\mathrm{CL}}$ | Clock Input Low Voltage | $-0.5$ | + 0.6 | V |  |
| $\mathrm{V}_{\mathrm{CH}}$ | Clock Input High Voltage | 3.9 | $\mathrm{V}_{\mathrm{CC}}+1.0$ | V |  |
| $\mathrm{C}_{\text {IN }}$ | Capacitance of Input Buffer (All input except $\left.A D_{0}-A D_{15}, R Q / G T\right)$ |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{ClO}_{10}$ | Capacitance of I/O Buffer $\left(A D_{0}-A D_{15}, R Q / G T\right)$ |  | 20 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

## A.C. CHARACTERISTICS

$8086 / 8086-4: \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
$\mathbf{8 0 8 6}$ MINIMUM COMPLEXITY SYSTEM (Figure 8) TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | $\begin{aligned} \text { CLK Cycle Period } & -8086 \\ & -8086-4 \end{aligned}$ | $\begin{aligned} & 200 \\ & 250 \end{aligned}$ | $\begin{aligned} & 2000 \\ & 2000 \end{aligned}$ | ns ns |  |
| TCLCH | CLK Low Time | (2/3TCLCL)-15 |  | ns |  |
| TCHCL | CLK High Time | $(1 / 3 T C L . C L)+2$ |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 | ns | From 1.0V to 3.5V |
| TCL2CL1 | CLLK Fall Time |  | 10 | ns | From 3.5 V to 1.0 V |
| TDVCL | Data In Setup Time | 30 |  | ns |  |
| TCLDZ | Data In Hold Time | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into 8284 (See Notes 1, 2) | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into 8284 (See Notes 1, 2) | 0 |  | ns |  |
| TRYHCH | READY Setup Time into 8086 | (2/3TCLCL)-15 |  | ns |  |
| TCHRYX | READY Hold Time into 8086 | 30 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 3) | -8 |  | ns |  |
| THVCH | Hold Setup Time | 35 |  | ns |  |
| TINVCH | INTR, NMI, $\overline{\text { TEST }}$ Setup Time (See Note 2) | 30 |  | ns |  |

TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLAV | Address Valid Delay | 15 | 110 | ns | $C_{L}=20.100 \mathrm{pF}$ <br> for all 8086 Outputs |
| TCLAX | Address Hold Time | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | ns |  |
| TLHLL | ALE Width | TCLCH-20 |  | ns |  |
| TCLLH | ALE Active Delay |  | 80 | ns |  |
| TCHLL | ALE Inactive Delay |  | 85 | ns |  |
| TLLAZ | ALE Inactive to Address Float | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 15 | 110 | ns |  |
| TCHDZ | Data Float Delay | TCLAX | 85 | ns |  |
| TWHDZ | Data Hold Time After $\overline{W R}$ | TCLCH-30 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | ns |  |
| TCHCTV | Control Active Delay 2 | 15 | 110 | ns |  |
| TCVCTX | Control Inactive Delay | 10 | 110 | ns |  |
| TAZRL | Address Float to READ Active | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 165 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 150 | ns |  |
| TRHAV | ' $\overline{R D}$ Inactive to Next Address Active | TCLCL-45 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | ns |  |

NOTES: 1. SIGNAL AT 8284 SHOWN FOR REFERENCE ONLY.
2. SETUP REQUIREMENT FOR ASYNCHRONOUS SIGNAL ONLY TO GUARANTEE RECOGNITION AT NEXT CLK.
3. APPLIES ONLY TO T2 STATE.

## 8086 MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) (Figure 9) TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | $\begin{aligned} \text { CLK Cycle Period }-8086 \\ -8086-4 \end{aligned}$ | $\begin{aligned} & 200 \\ & 250 \end{aligned}$ | $\begin{aligned} & 2000 \\ & 2000 \end{aligned}$ | ns ns | : |
| TCLCH | CLK Low Time | (2/3TCLCL)-15 |  | ns |  |
| TCHCL | CLK High Time | $(1 / 3$ TCLCL) +2 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 | ns | From 1.0 V to 3.5 V |
| TCL2CL1 | CLK Fall Time |  | 10 | ns | From 3.5 V to 1.0 V |
| TDVCL | Data In Setup Time | 30 |  | ns |  |
| TCLDZ | Data In Hold Time | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into 8284 (See Notes 1, 2) | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into 8284 (See Notes 1, 2) | 0 |  | ns |  |
| TRYHCH | READY Setup Time into 8086 | (2/3TCLCL)-15 |  | ns |  |
| TCHRYX | READY Hold Time into 8086 | 30 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 4) | -8 |  | ns |  |
| TINVCH | Setup Time for Recognition (INTR, NMI, $\overline{\text { TEST) }}$ (See Note 2) | 30 |  | ns |  |
| TGVCH | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | 35 |  | ns |  |
| TCHGX | $\overline{\mathrm{RQ}}$ Hold Time into 8086 | 40 |  | $\therefore \mathrm{ns}$ |  |

TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=20-100 \mathrm{pF} \\ & \text { for all } 8086 \\ & \text { Outputs } \end{aligned}$ |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | ns |  |
| TRYHSH | READY Active to Status Passive (See Note 3) |  | 110 | ns |  |
| TCHSV | Status Active Delay | 10 | 110 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 130 | ns |  |
| TCLAV | Address Valid Delay | 15 | 110 | ns |  |
| TCLAX | Address Hold Time | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | ns |  |
| TSVLH | Status Valid to ALE High (See Note 1) |  | 15 | ns |  |
| TSVMCH | Status Valid to MCE High (See Note 1) |  | 15 | ns |  |
| TCLLH | CLK Low to ALE Valid (See Note 1) |  | 15 | ns |  |
| TCLMCH | CLK Low to MCE High (See Note 1) |  | 15 | ns |  |
| TCHLL | ALE Inactive Delay (See Note 1) |  | 15 | ns |  |
| TCLMCL | MCE Inactive Delay (See Note 1) |  | 15 | ns |  |
| TCLDV | Data Valid Delay | 15 | 110 | ns |  |
| TCHDZ | Data Float Delay | TCLAX | 85 | ns |  |
| TCVNV | Control Active Delay (See Note 1) | 5 | 45 | ns |  |
| TCVNX | Control Inactive Delay (See Note 1) | 10 | 45 | ns |  |
| TAZRL | Address Float to Read Active | 0 |  | ns |  |
| TCLRL | RD Active Delay | 10 | 165 | ns |  |
| TCLRH | RD Inactive Delay | 10 | 150 | ns |  |
| TRHAV | RD Inactive to Next Address Active | TCLCL-45 |  | ns |  |
| TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 | ns |  |
| TCLGL | $\overline{\text { GT }}$ Active Delay |  | 85 | ns |  |
| TCLGH | $\overline{\mathrm{GT}}$ Inactive Delay |  | 85 | ns |  |

NOTES: 1. SIGNAL AT 8284 OR 8288 SHOWN FOR REFERENCE ONLY.
2. SETUP REQUIREMENT FOR ASYNCHRONOUS SIGNAL ONLY TO GUARANTEE RECOGNITION AT NEXT CLK.
3. APPLIES ONLY TO T3 AND WAIT STATES.
4. APPLIES ONLY TO T2 STATE.


SOFTWARE HALT $-\left(D E N=V_{O L} ; \overline{R D} \cdot \overline{W R}, \overline{N N T A} D T / \bar{R}=V_{O H}: T I\right.$ 's follow $T 1$, then NMI or INTR $\rightarrow$ Begin a new T1

$$
\text { D.WR,INTA DT/R = VOH: TI's follow T1, then NMI or INTR } \rightarrow \text { Begin a new T1 }
$$

[^15]Figure 8. 8086 Bus Timing - Minimum Mode System


NOTES: 1. ALL SIGNALS SWITCH BETWEEN $V_{O H}$ AND $V_{\text {OL }}$ UNLESS OTHERWISE SPECIFIED
RDY IS SAMPLED NEAR THE END OF $T_{2}, T_{3}, T_{W}$ TO DETERMINE IF $T_{W}$ MACHINES STATES ARE TO BE INSERTED
FOLLOWING A WRITE CYCLE THE LOCAL BUS IS :FLOATED BY THE 8086 ONLY WHEN THE BOBS ENTERS' A A "HOLD ACKNOWLEDGE" STATE
4 TWO INTA CYCLES RUN BACK-TO-BACK. THE BOB6 LOCAL ADDR/DATA BUS IS FLOATING DURING THE SECONO INTA CYCLE
TGNALS AT 8284 OR 8268 ARE SHOWN FOR REFERENCE ONLI
ALL TIMING MEASUREMENTS ARE MADE AT $15 V$ UNLESS OTHERWISE NOTED.
status inactive in state just prior to ta
Figure 9. 8086 Bus Timing - Maximum Mode System (Using 8288)


NOTE:

1. SETUP REQUIREMENTS FOR ASYNCHRONOUS SIGNALS ONLY TO GUARANTEE RECOGNITION AT NEXT CLK

Figure 10. Asynchronous Signal Recognition


Figure 11. Bus Lock Signal Timing (Maximum Mode Only)


NOTES:

1. THE 8086 FLOATS $\overline{\mathrm{S}_{2}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{0}}$ FROM 1.1.1 STATE ON THIS EDGE
2. THE 8086 FLOATS $A_{x} D_{x}$ BUS RD AND LOCK ON THIS EDGE
3. THE OTHER MASTER FLOATS $\overline{\bar{S}_{2}}, \overline{\bar{S}_{1}}, \overline{\bar{S}_{0}}$ FROM 1.1.1 STATE ON THIS EDGE
4. THE OTHER MASTER FLOATS $A_{x} D_{x}$ BUS, BHE, AND LOCK ON THIS EDGE

Figure 12. Request/Grant Sequence Timing (Maximum Mode Only)


NOTE:

1. BUS FLOATS ON THIS EDGE (SEE TCHDZ)

Figure 13. Hold/Hold Acknowledge Timing (Minimum Mode Only)

# 8086 <br> INSTRUCTION SET SUMMARY 

## 3ANSFER

love:
memory to/from register e to register/memory
e to register 10 accumulator ator to memory memory to segment registe register to register/memory

| 10 dw | mod reg r/m |  |  |
| :---: | :---: | :---: | :---: |
| 011 w | mod $000 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| w reg | data | data if w=1 |  |
| 000 w | addr-low | addr-high |  |
| 001 w | addr-low | addr-high |  |
| 11110 | mod 0 reg r/m |  |  |
| 31100 | mod 0 reg r/m |  |  |

Push:

## 'memory

register

op:
Imemory
: register


Exchange:
Imemory with register with accumulator

It from:
nt
: port
Jutput to:
ort
; port
ranslate byte to AL
ad EA to register
ad pointer to OS
ad pointer to ES oad AH with flags itore AH into flags Push flags 'op flags

## METIC

Add:
emory with register to either ate to register/memory ate to accumulator

Add with carry:
emory with register to either ate to register/memory late to accumulator

Increment:
r/memory

SCll adjust for add ecimal adjust for add

## subtract:

nemory and register to either liate from register/memory liate from accumulator

## Subtract with berrow

semory and register to either liate from register/memory liate from accumulator

| 00000 dw | mod reg r/m |  |  |
| :---: | :---: | :---: | :---: |
| 10000 sw | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s} . \mathrm{w}=01$ |
| 000010 w | data | data if $w=1$ |  |


| [0100dw | mod reg r/m |  |  |
| :---: | :---: | :---: | :---: |
| 10000 sw | $\bmod 010 \mathrm{r} / \mathrm{m}$ | data | data it $s: w=01$ |
| O 01010 w | data | data if w=1 |  |

$$
\begin{aligned}
& {\left[\begin{array}{ll}
1 & 11111 \mathrm{w} \\
\hline 0 & \bmod 000 \mathrm{r} / \mathrm{m} \\
\hline 0 & 000 \mathrm{reg} \\
\hline 0 & 110111 \\
\hline 0 & 100111 \\
\hline
\end{array}\right.} \\
& \hline
\end{aligned}
$$

| 0 | 11010 d | $\bmod$ reg $\mathrm{r} / \mathrm{m}$ |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 1 |  |  |  |  |
| $00000 \mathrm{~s} w$ | $\bmod 101 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{s}: \mathrm{w}=01$ |  |
| 0 | 10110 w | data | data if $\mathrm{w}=1$ |  |

DEC = Decrement:
Register/memory
Register
MEG=Change sign
CMP = Compare:
Register/memory and register Immediate with register/memory Immediate with accumulator AAS=ASCII adjust for subtract DAS=Decimal adjust for subtract MUL=Multiply (unsigned) IMUL=Integer multiply (signed) AAM=ASCII adjust for multiply DIV = Divide (unsigned) LIIV=Integer divide (signed) AAD=ASCII adjust for divide CBW=Convert byte to word CWD=Convert word to double word
$76543210 \quad 765432107654321076543210$,

| 1111111 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |
| :--- | :--- | :--- |
| 01001 reg |  |
| 1111011 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |


| 001110 dw | mod reg r/m |  |  |
| :---: | :---: | :---: | :---: |
| 100000 sw | mod $111 \mathrm{r} / \mathrm{m}$ | data | data if s w $=01$ |
| 0011110 w | data | data if w=1 |  |
| 001111111 |  |  |  |
| 00101111 |  |  |  |
| 1111011 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ |  |  |
| 1111011 w | mod $101 \mathrm{r} / \mathrm{m}$ |  |  |
| 11010100 | 00001010 |  |  |
| 1111011w | mod $110 \mathrm{r} / \mathrm{m}$ |  |  |
| 1111011w | $\bmod 111 \mathrm{r} / \mathrm{m}$ |  |  |
| 11010101 | 00001010 |  |  |
| 10011000 |  |  |  |
| 10011001 |  |  |  |

LOGIC
MOT = Invert
SHL/SAL=Shift logical/arithmetic left
SHR=Shift logical right
SAR=Shift arthmetic right
MOL =Rotate left
ROR=Rotate right
RCL=Rotate through carry flag left
RCR=Rotate through carry right

| 1111011 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |
| :---: | :---: |
| 11.0100 V | $\bmod 100 \mathrm{r} / \mathrm{m}$ |
| 110100 VW | $\bmod 101 \mathrm{r} / \mathrm{m}$ |
| 110100 w | $\bmod 111 \mathrm{r} / \mathrm{m}$ |
| 110100 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ |
| 110100 w | $\bmod 001 \mathrm{r} / \mathrm{m}$ |
| 110100 w | $\bmod 010 \mathrm{r} / \mathrm{m}$ |
| 110100 w | $\bmod 011 \mathrm{r} / \mathrm{m}$ |

AND = And:
Reg /memory and register to either
Immediate to register/memory
Immediate to accumulator

| 001000 d | $\bmod \mathrm{reg} \mathrm{r} / \mathrm{m}$ |  |  |
| :---: | :---: | :---: | :---: |
| 1000000 w | $\bmod 100 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{w}=1$ |
| 0010010 w | data | data $\mathrm{f} \mathrm{w}=1$ |  |

TEST $=$ And function to flags, no result:
Register/memory and register
Immediate data and register/memory Immediate data and accumulator

OR $=0 \mathrm{O}$ :
Reg./memory and register to either Immediate to register/memory Immediate to accumulator

| 1000010 w | $\bmod \mathrm{reg} \mathrm{r/m}$ |  |  |
| :---: | :---: | :---: | :---: |
| 1111011 w | $\bmod 000 \mathrm{r} / \mathrm{m}$ | data | data if $\mathrm{w}=1$ |
| 1010100 w | data | data if $\mathrm{w}=1$ |  |

## XOR $=$ Exclusive or:

Reg./memory and register to either Immediate to register/memory Immediate to accumulator

| 0000100 w | $\bmod$ reg $\mathrm{r} / \mathrm{m}$ |  |  |
| :---: | :---: | :---: | :---: |
| 1000000 w | modo $01 \mathrm{r} / \mathrm{m}$ | data | data if $w=1$ |
| 0000110 w | data | data if $w=1$ |  |

CONTROL TRANSFER
CALL = Call:
Direct within segment
indirect within segment
Direct intersegment

Indirect intersegment

| 11101000 | disp-low | disp-high |
| :---: | :---: | :---: |
| 11111111 | mod $010 \mathrm{r} / \mathrm{m}$ |  |
| 10011010 | offset-10w | offset-high |
|  | seg-low | seg-high |
| 11111111 | mod $011 \mathrm{r} / \mathrm{m}$ |  |

JMP = Unconditional Jump:
Direct within segment Direct within segment-short Indirect within segment Direct intersegment

Indirect intersegment

| 11101001 | disp-low | disp-high |
| :---: | :---: | :---: |
| 11101011 | disp |  |
| 11111111 | mod $100 \mathrm{r} / \mathrm{m}$ |  |
| 11101010 | offset-1ow | offset-high |
|  | seg-low | seg-high |
| 11111111 | $\bmod 101 \mathrm{r} / \mathrm{m}$ |  |

RET $=$ Return from CALL:
Within segment
Within seg. adding immed to SP Intersegment
Intersegment, adding immediate to SP

## JE/JZ=Jump on equal/zero

 $\mathrm{JL} / \mathrm{JNGE}=\mathrm{Jump}$ on less/not greater JLE/JMG Jump on less or equal/not JB/JMAE = =Jump on below/not above $J B E / J M A=$ Jump on EE/JAA $=$ Jump on below or equal/not above JP/JPE=Jump on parity/parity even
JO= Jump on overfiow
JS=Jump on sign
JME/JMZ=Jump on not equal/not zero JNL/JGE $=J u m p$ on not less/greater
JWLE/JG =Jump on not less or equal/
$G=$ greater

| 11000011 |  |  |
| :---: | :---: | :---: |
| 11000010 | data-low | data-high |
| 11001011 |  |  |
| 11001010 | data-low | data-high |
| 01110100 | disp |  |
| 01011111100 | dısp |  |
| 01011111110 | disp |  |
| 010 | disp |  |
| 01110110 | disp |  |
| 01111010 | dısp |  |
| 01110000 | disp |  |
| 01111000 | disp |  |
| 01110101 | disp |  |
| 0101111101 | disp |  |
| 01111111 | dısp |  |

## Footnotes:

$\mathrm{AL}=8$-bit accumulator
$A X=16$-bit accumulator
$C X=$ Count register
DS = Data segment
ES = Extra segment
Above/below refers to unsigned value.
Greater = more positive;
Less = less positive (more negative) signed values
if $d=1$ then "to" reg; if $d=0$ then "from" reg
if $w=1$ then word instruction; if $w=0$ then byte instruction
if $\mathrm{mod}=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if mod $=00$ then DISP $=0 *$, disp-low and disp-high are absent
if $\bmod =01$ then DISP $=$ disp-low sign-extended to 16 -bits, disp-high is absent
if $\bmod =10$ then DISP $=$ disp-high: disp-low
if $r / m=000$ then $E A=(B X)+(S I)+D I S P$
if $r / m=001$ then $E A=(B X)+(D I)+D I S P$
if $r / m=010$ then $E A=(B P)+(S I)+D I S P$
if $r / m=011$ then $E A=(B P)+(D I)+D I S P$
if $\mathrm{r} / \mathrm{m}=100$ then $E A=(S I)+$ DISP
if $\mathrm{r} / \mathrm{m}=101$ then $E A=(\mathrm{DI})+$ DISP
if $\mathrm{r} / \mathrm{m}=110$ then $E A=(B P)+$ DISP* $^{*}$
if $\mathrm{r} / \mathrm{m}=111$ then $E A=(B X)+D I S P$
DISP follows 2nd byte of instruction (before data if required)
*except if $\bmod =00$ and $\mathrm{r} / \mathrm{m}=110$ then $E A=$ disp-high: disp-low.
if $\mathrm{s}: \mathrm{w}=01$ then 16 bits of immediate data form the operand.
if $s: w=11$ then an immediate data byte is sign extended to form the 16 -bit operand.
if $v=0$ then "count'" $=1$; if $v=1$ then "count'" in (CL)
$x=$ don't care
$z$ is used for string primitives for comparison with Z.F FLAG.

## SEGMENT OVERRIDE PREFIX

001 reg 110

REG is assigned according to the following table:

| 16-Bit [ $\mathrm{w}=1$ ] | 8-Bit ( | $=0)$ | Segment |  |
| :---: | :---: | :---: | :---: | :---: |
| 000 AX | 000 | AL | 00 | ES |
| 001 CX | 001 | CL | 01 | CS |
| 010 DX | 010 | DL | 10 | SS |
| 011 BX | 011 | BL | 11 | DS |
| 100 SP | 100 | AH |  |  |
| 101 BP | 101 | CH |  |  |
| 110 SI | 110 | DH |  |  |
| 111 DI | 111 | BH |  |  |

Instructions which reference the flag register file as a 16-bit object use the symbol FLAGS to represent the file:

FLAGS = $X: X: X: X:(O F):(D F):(I F):(T F):(S F):(Z F): X:(A F): X:(P F): X:(C F)$

## intel

## 8282/8283 OCTAL LATCH

## - Fully Parallel 8-Bit Data Register and Buffer

- Transparent during Active Strobe
- Supports 8080, 8085, 8048, and 8086 Systems


## - High Output Drive Capability for Driving System Data Bus

- 3-State Outputs
- 20-Pin Package with 0.3" Center
- No Output Low Noise when Entering or Leaving High Impedance State

The 8282 and 8283 are 8 -bit bipolar latches with 3 -state output buffers. They can be used to implement latches, buffers, or multiplexers. The 8283 inverts the input data at its outputs while the 8282 does not. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with these devices.

## PIN CONFIGURATIONS

LOGIC DIAGRAMS


PIN NAMES



## PIN DEFINITIONS

Pin

## Description

$\mathrm{DO}_{0}-\mathrm{DO}_{7}$ (8282)
$\overline{\mathrm{DO}}_{0}-\overline{\mathrm{DO}}_{7}$
(8283)

DATA OUTPUT PINS, OOtput When $\overline{O E}$ is true, the data in the data latchestispresented as inverted (8283) or non-inverted (8282) data onto the data output pins.

## OPERATIONAL DESCRIPTION

The 8282 and 8283 octal latches are 8 -bit latches with 3 -state output buffers. Data having satisfied the setup time requirements is latched into the data latches by strobing the STB line HIGH to LOW. Holding the STB line in its active HIGH state makes the latches appear transparent. Data is presented to the data output pins by activating the $\overline{O E}$ input line. When $\overline{O E}$ is inactive HIGH the output buffers are in their high impedance state. Enabling or disabling the output buffers will not cause negative-going transients to appear on the data output bus.

## D.C. AND OPERATING CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$ $.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. . . . . . . . . . . . . . . . . . -1.0 V to +5.5 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 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 FOR 8282/8283

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 160 | mA |  |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.2 | mA | $\mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Current |  | 50 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.50 | V | $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{OFF}}$ | Output Off Current |  | $\pm 50$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OFF}}=0.45$ to 5.25V |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \quad$ See Note 1 |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \quad$ See Note 1 |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 12 | pF |

Notes: 1. Output Loading $\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$

## A.C. CHARACTERISTICS FOR $8282 / 8283$

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Loading: Outputs $-\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TIVOV | Input to Output Delay <br> -Inverting <br> -Non-Inverting |  | 25 | ns | (See Note 1) |
| TSHOV | STB to Output Delay <br> -Inverting <br> -Non-Inverting | ns |  |  |  |

NOTE: 1. See waveforms and test load circuit on following page.

## 8282/8283 TIMING



NOTE: 1.8283 ONLY - OUTPUT MAY BE MOMENTARILY INVALID FOLLOWING THE HIGH GOING STB TRANSITION.
2. ALL TIMING MEASUREMENTS ARE MADE AT 1.5 V UNLESS OTHERWISE NOTED


## OUTPUT TEST LOAD CIRCUITS



# 8284 <br> CLOCK GENERATOR AND DRIVER FOR 8086 CPU 

\author{

- Generates the System Clock for the 8086 <br> - Uses a Crystal or a TTL Signal for Frequency Source <br> Single +5V Power Supply <br> 18-Pin Package
}


## - Generates System Reset Output from Schmitt Trigger Input

## Provides Local Ready and MULTIBUS ${ }^{\text {TM }}$ Ready Synchronization

- Capable of Clock Synchronization with other 8284's

The 8284 is a bipolar clock generator/driver designed to provide clock signals for the 8086 CPU and peripherals. It also contains READY logic for operation with two MULTIBUS ${ }^{T M}$ systems and provides the 8086's required READY synchronization and timing. Reset logic with hysteresis and synchronization is also provided.

8284 BLOCK DIAGRAM


## 8284 PIN NAMES

CONNECTIONS FOR CRYSTAL
USED WITH OVERTONE CRYSTAL
CLOCK SOURCE SELECT
EXTERNAL CLOCK INPUT
CLOCK SYNCHRONIZATION INPUT
READY SIGNAL FROM TWO MULTIBUS ${ }^{\text {TM }}$ SYSTEMS
ADDRESS ENABLED QUALIFIERS FOR RDY1, 2
RESET INPUT
SYNCHRONIZED RESET OUTPUT
OSCILLATOR OUTPUT
MOS CLOCK FOR 8086
TTL CLOCK FOR PERIPHERALS
SYNCHRONIZED READY OUTPUT
+5 VOLTS
0 VOLTS
PIN DEFINITIONS

| Pin | I/O | Definition |
| :---: | :---: | :---: |
| $\overline{\text { AEN1, }}$, | I | ADDRESS ENABLE. $\overline{\text { AEN }}$ is an active <br> LOW signal. $\overline{\text { AEN serves to qualify its }}$ |
|  |  | respective Bus Ready Signal (RDY1 or <br> RDY2). $\overline{\text { AEN1 }}$ validates RDY1 while $\overline{\text { AEN2 }}$ |
|  | validates RDY2. Two AEN signal inputs <br> are useful in system configurations |  |
| which permit the processor to access |  |  |
| two Multi-Master System Busses. In non |  |  |


| RDY1, I $\quad$ BUS READY (Transfer Complete). RDY is |  |
| :--- | :--- |
| RDY2 | an active HIGH signal which is an indica- | tion from a device located on the system data bus that data has been received, or is available. RDY1 is qualified by $\overline{\text { AEN1 }}$ while RDY2 is qualified by $\overline{\mathrm{AEN2}}$.

READY $O$ READY. READY is an active HIGH signal which is the synchronized RDY signal input. Since RDY occurs asynchronously with respect to the processor's clock (CLK) it is necessary for them to be synchronized before being presented to the processor. READY is cleared after the guaranteed hold time to the processor has been met.
X1, X2, I CRYSTAL IN. X1 and X2 are the pins to
TNK which a crystal is attached with TNK (TANK) serving as the overtone input. The crystal frequency is 3 times the desired processor clock frequency.
FI $\bar{C} \quad 1$ FREQUENCY/CRYSTAL SELECT. F/ $\overline{\mathrm{C}}$ is a strapping option. When strapped LOW, $F / \bar{C}$ permits the processor's clock to be generated by the crystal. When $F / \bar{C}$ is strapped HIGH, CLK is generated from the EFI input.
EFI I EXTERNAL FREQUENCY IN. When F/ $\bar{C}$ is strapped HIGH, CLK is generated from the input frequency appearing on this pin. The input signal is a square wave 3 times the frequency of the desired CLK output.
CLK O PROCESSOR CLOCK. CLK is the clock output used by the processor and all devices which directly connect to the processor's local bus (i.e., the bipolar support chips and other MOS devices). CLK has an output frequency which is $1 / 3$ of the crystal or EFI input frequency and a $1 / 3$ duty cycle. An output HIGH of 4.5 volts ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ ) is provided on this pin to drive MOS devices.
PCLK 0 PERIPHERAL CLOCK. PCLK is a TTL level peripheral clock signal whose output frequency is $1 / 2$ that of CLK and has a $50 \%$ duty cycle.

| Pin | 1/0 | Definition |
| :---: | :---: | :---: |
| OSC | 0 | OSCILLATOR OUTPUT. OSC Is the TTL level output of the internal oscillator circuitry. Its frequency is equal to that of the crystal. |
| $\overline{\text { RES }}$ | 1 | RESET IN. $\overline{R E S}$ is an active LOW signal which is used to generate RESET. The 8284 provides a Schmitt trigger input so that an RC connection can be used to establish the power-up reset of proper duration. |
| RESET | 0 | RESET. Reset is an active HIGH signal which is used to reset the 8086 family processors. Its timing characteristics are determined by $\overline{\mathrm{RES}}$. |
| CSYNC | 1 | CLOCK SYNCHRONIZATION. CSYNC is an active HIGH signal which allows multiple 8284's to be synchronized to provide clocks that are in phase. When CSYNC is HIGH the internal counters are reset. When CSYNC goes LOW the internal counters are allowed to resume counting. CSYNC needs to be externally synchronized to EFI. When using the internal oscillator CSYNC should be hardwired to ground. |
| GND |  | Ground |
| $\mathrm{V}_{\mathrm{CC}}$ |  | +5V supply |

## FUNCTIONAL DESCRIPTION

## GENERAL

The 8284 is a single chip clock generator/driver for the 8086 CPU. The chip contains a crystal controlled oscillator, a "divide by three" counter, complete MULTIBUSTM "Ready" synchronization and reset logic.

## OSCILLATOR

The oscillator circuit of the 8284 is designed primarily for use with an external series resonant, fundamental mode, crystal from which the basic operating frequency is derived. However, overtone mode crystals can be used with a tank circuit as shown in Figure 1.

The crystal frequency should be selected at three times the required CPU clock. $X_{1}$ and $X_{2}$ are the two crystal input crystal connections.

The output of the oscillator is buffered and brought out on OSC so that other system timing signals can be derived from this stable, crystal-controlled source.


The tank input to the oscillator allows the use of overtone mode crystals. The tank circuit shunts the crystal's fundamental and high overtone frequencies and allows the third harmonic to oscillate. The external LC network is connected to the TANK input and is AC coupled to ground.

## Figure 1

## CLOCK GENERATOR

The clock generator consists of a synchronous divide-by-three counter with a special clear input that inhibits the counting. This clear input (CSYNC) allows the output clock to be synchronized with an external event (such as another 8284 clock). It is necessary to synchronize the CSYNC input to the EFI clock external to the 8284. This is accomplished with two Schottky flip-flops. (See Figure 2.) The counter output is a $33 \%$ duty cycle clock at one-third the input frequency.

The F/ $\overline{\mathrm{C}}$ input is a strapping pin that selects either the crystal oscillator or the EFI input as the clock for the $\div 3$ counter. If the EFI input is selected as the clock source, the oscillator section can be used independently for another clock source. Output is taken from OSC.


Figure 2. CSYNC Synchronization

## CLOCK OUTPUTS

The CLK output is a $33 \%$ duty cycle MOS clock driver designed to drive the 8086 processor directly. PCLK is a TTL level peripheral clock signal whose output frequency is $1 / 2$ that of CLK. PCLK has a $50 \%$ duty cycle.

## RESET LOGIC

The reset logic provides a Schmitt trigger input (RES) and a synchronizing flip-flop to generate the reset timing. The reset signal is synchronized to the falling edge of CLK. A simple RC network can be used to provide power on reset by utilizing this function of the 8284.

## READY SYNCHRONIZATION

Two READY inputs (RDY1, RDY2) are provided to accomomodate two Multi-Master system busses. Each input has a qualifier ( $\overline{\mathrm{AEN1}}$ and $\overline{\mathrm{AEN2}}$, respectively). The $\overline{\mathrm{AEN}}$ signals validate their respective RDY signals. If a Multi-Master system is not being used the $\overline{\mathrm{AEN}}$ pin should be tied LOW.

The READY output is an active HIGH signal which is the synchronized RDY1 or RDY2 inpút. Since RDY1 and RDY2 occur asynchronously with respect to the processor's clock (CLK), it is necessary to synchronize them before presenting them to the processor to insure they meet the required set-up time. The READY logic does this job and also guarantees the required hold time before clearing the READY signal.

## 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. . . . . . . . . . . . . . . . . . . . . . . . +1 Watt

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
Power Dissipation.

## D.C. CHARACTERISTICS FOR 8284

Conditions: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.5 | mA | $\mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Current |  | 50 | $\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}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 140 | mA |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input LOW Voltage |  | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 |  | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Reset Input HIGH Voltage | 2.6 |  | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output LOW Voltage |  | 0.45 | V | 5 mA |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output HIGH Voltage CLK |  |  |  |  |
| Other Outputs | 4 |  | V | -1 mA |  |
| $\mathrm{~V}_{\mathrm{IH}}-\mathrm{V}_{\mathrm{IL}}$ | RES Input Hysteresis | 2.4 |  | V | -1 mA |

## A.C. CHARACTERISTICS FOR 8284

Conditions: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
TIMING REQUIREMENTS

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TEHEL | External Frequency High Time | 20 |  | ns |  |
| TELEH | External Frequency Low Time | 20 |  | ns |  |
| TELEL | EFI Period | TEHEL + TELEH + $\delta$ |  | ns | (Note 1) |
|  | XTAL Frequency | 12 | 25 | MHz |  |
| TR1VCL | RDY1, RDY2 Set-Up to CLK | 35 |  | ns |  |
| TCLR1X | RDY1, RDY2 Hold to CLK | 0 |  | ns |  |
| TA1VR1V | $\overline{\text { AEN1 }}$, $\overline{\text { AEN2 }}$ Set-Up to RDY1, RDY2 | 15 |  | ns |  |
| TCLA1X | $\overline{\text { AEN1, }}$ AEN2 Hold to CLK | 0 |  | ns |  |
| TYHEH | CSYNC Set-Up to EFI | 20 |  | ns |  |
| TEHYL | CSYNC Hold to EFI | 20 |  | ns |  |
| TYHYL | CSYNC Width | 2.TELEL |  | ns |  |
| T11HCL | $\overline{\text { RES }}$ Set-Up to CLK | 65 |  | ns | (Note 2) |
| TCLITH | $\overline{\text { RES }}$ Hold to CLK | 20 |  | ns | (Note 2) |

## TIMING RESPONSES

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 |  | ns |  |
| TCHCL | CLK High Time | $(1 / 3 \mathrm{TCLCL})+2.0$ |  | ns | Fig. 3 \& Fig. 4 |
| TCLCH | CLK Low Time | (2/3TCLCL) - 15.0 |  | ns | Fig. 3 \& Fig. 4 |
| TCH1CH2 TCL2CL1 | CLK Rise and Fall Time |  | 10 | ns | 1.0 V to 3.5 V |
| TPHPL | PCLK High Time | TCLCL - 20 |  | ns |  |
| TPLPH | PCLK Low Time | TCLCL-20 |  | ns |  |
| TRYLCL | Ready Inactive to CLK (See Note 4) | -8 |  | ns | Fig. 5 \& Fig. 6 |
| TRYHCH | Ready Active to CLK (See Note 3) | (2/3TCLCL)-15.0 |  | ns | Fig. 5 \& Fig. 6 |
| TCLIL | CLK to Reset Delay | 40 |  | ns |  |

Notes: 1. $\delta=\mathrm{EFI}$ rise +EFI fall.
2. Set up and hold only necessary to guarantee recognition at next clock.
3. Applies only to T3 and TW states.
4. Applies only to T2 states.


## A.C. TEST CIRCUITS



Figure 3. Clock High and Low Time
Figure 4. Clock High and Low Time


Figure 5. Ready to Clock


Figure 6. Ready to Clock


NOTES: $1 . \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
2. $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$
3. $C_{L}$ INCLUDES PROBE AND JIG CAPACITANGE

## 8286/8287 <br> OCTAL BUS TRANSCEIVER

## - Data Bus Buffer Driver for MCS-86 ${ }^{\text {TM }}$ MCS-80 ${ }^{\text {TM }}$, MCS-85 ${ }^{\text {TM }}$, and MCS-48 ${ }^{\text {TM }}$ Families

## - High Output Drive Capability for Driving System Data Bus

Fully Parallel 8-Bit Transceivers

- 3-State Outputs


## 20-Pin Package with 0.3" Center

- No Output Low Noise when Entering or Leaving High Impedance State

The 8286 and 8287 are 8 -bit bipolar transceivers with 3 -state outputs. The 8287 inverts the input data at its outputs while the 8286 does not. Thus, a wide variety of applications for buffering in microcomputer systems can be met.



| $A_{0}-A_{7}$ | LOCAL BUS DATA |
| :--- | :--- |
| $B_{0}-B_{7}$ | SYSTEM BUS DATA |
| $\overline{O E}$ | OUTPUT ENABLE |
| $T$ | TRANSMIT |

## PIN NAMES



PIN DEFINITIONS
Pin Description
T TRANSMIT (Input). $T$ is an input control signal used to control the direction of the transceivers. When HIGH, it configures the transceiver's $B_{0}-B_{7}$ as outputs with $A_{0}-A_{7}$ as inputs. T LOW configures $A_{0}-A_{7}$ as the outputs with $B_{0}-B_{7}$ serving as the inputs.
$\overline{O E} \quad$ OUTPUT ENABLE (Input). $\overline{O E}$ is an input control signal used to enable the appropriate output driver (as selected by $T$ ) onto its respective bus. This signal is active LOW.
$A_{0}-A_{7} \quad$ LOCAL BUS DATA PINS (Input/Output). These pins serve to either present data to or accept data from the processor's local bus depending upon the state of the $T$ pin.

SYSTEM BUS DATA PINS (Input/Output). These pins serve to either present data to or accept data from the system bus depending upon the state of the $T$ pin.

## OPERATIONAL DESCRIPTION

The 8286 and 8287 transceivers are 8-bit transceivers with high impedance outputs. With T active HIGH and $\overline{O E}$ active LOW, data at the $A_{0}-A_{7}$ pins is driven onto the $B_{0}-B_{7}$ pins. With $T$ inactive LOW and $\overline{O E}$ active LOW, data at the $B_{0}-B_{7}$ pins is driven onto the $A_{0}-A_{7}$ pins. No output low glitching will occur whenever the transceivers are entering or leaving the high impedance state.

## 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................... . . . -1.0 V to +5.5 V
Power Dissipation. . . . . . . . . . . . . . . . . . . . . . . . . . 1 Watt

[^16]
## D.C. CHARACTERISTICS FOR 8286/8287

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current-8287 -8286 |  | $\begin{aligned} & 130 \\ & 160 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.2 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} \text { Output Low Voltage } & \text { - B Outputs } \\ & \text { - A Outputs } \end{aligned}$ |  | $\begin{aligned} & 0.5 \\ & 0.5 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage -B Outputs -A Outputs | $\begin{aligned} & 2.4 \\ & 2.4 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| IOfF IOFF | Output Off Current Output Off Current |  | $\begin{aligned} & I_{F} \\ & I_{R} \end{aligned}$ |  | $\begin{aligned} & \mathrm{V}_{\text {OFF }}=0.45 \mathrm{~V} \\ & \mathrm{~V}_{\text {OFF }}=5.25 \mathrm{~V} \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage $\begin{array}{r}\text { —A Side } \\ \text { —B Side }\end{array}$ |  | $\begin{aligned} & 0.8 \\ & 0.9 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, See Note 1 <br> $V_{C C}=5.0 \mathrm{~V}$, See Note 1 |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, See Note 1 |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 12 | pF | $\begin{aligned} & \mathrm{F}=1 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |

[^17]
## A.C. CHARACTERISTICS FOR 8286/8287

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Loading: B Outputs $-\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ A Outputs $-\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| TIVOV | Input to Output Delay <br> Inverting <br> Non-Inverting |  | 25 | ns | (See Note 1) |
| TEHTV | Transmit/Receive Hold Time | TEHOZ |  | ns |  |
| TTVEL | Transmit/Receive Setup | 30 |  | ns |  |
| TEHOZ | Output Disable Time |  | 25 | ns |  |
| TELOV | Output Enable Time | 10 | 50 | ns |  |

Note: 1. See waveforms and test load circuit on following page.

## 8286/8287 TIMING



NOTE: 1. ALL TIMING MEASUREMENTS ARE MADE AT 1.5V UNLESS OTHERWISE NOTED.



TEST LOAD CIRCUITS


## intel

8288

## BUS CONTROLLER FOR THE 8086 CPU

- Bipolar Drive Capability
- Provides Advanced Commands
- Provides Wide Flexibility in System Configurations
- 3-State Command Output Drivers
- Configurable for Use with an I/O Bus
- Facilitates Interface to One or Two Multi-Master Busses

The Intel® 8288 Bus Controller is a 20-pin bipolar component for use with medium-to-large 8086 processing systems. The bus controller provides command and control timing generation as well as bipolar bus drive capability while optimizing system performance.
A strapping option on the bus controller configures it for use with a multi-master system bus and separate I/O bus.


## PIN DEFINITIONS

| Name | 1/0 | Function |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ |  | +5V supply. |
| GND |  | Ground. |
| $\overline{S_{0}}, \overline{S_{1}}, \overline{S_{2}}$ | 1 | Status Input Pins: These pins are the status input pins from the 8086 proc essor. The 8288 decodes these in puts to generate command and control signals at the appropriate time When these pins are not in use (pas sive) they are all HIGH. (See chart under Command and Control Logic.) |
| CLK | 1 | Clock: This is a clock signal from the 8284 clock generator and serves to establish when command and con trol signals are generated. |
| ALE | 0 | Address Latch Enable: This signal | serves to strobe an address into the address latches. This signal is active HIGH and latching occurs on the falling (HIGH to LOW) transition. ALE is intended for use with transparent D type latches.

DEN
dT/R
$\overline{\text { AEN }}$

CEN

IOB

O Data Enable: This signal serves to enable data transceivers onto either the local or system data bus. This signal is active HIGH.
O Data Transmit/Receive: This signal establishes the direction of data flow through the transceivers. A HIGH on this line indicates Transmit (write to I/O or memory) and a LOW indicates Receive (Read).
1 Address Enable: $\overline{\mathrm{AEN}}$ enables command outputs of the 8288 Bus Controller at least 85 ns after it becomes active (LOW). $\overline{\mathrm{AEN}}$ going inactive immediately 3 -states the command output drivers. $\overline{\text { AEN }}$ does not affect the I/O command lines if the 8288 is in the I/O Bus mode (IOB tied HIGH).
I Command Enable: When this signal is LOW all 8288 command outputs ; and the DEN and $\overline{\text { PDEN }}$ control outputs are forced to their inactive state. When this signal is HIGH, these same outputs are enabled.
I Input/Output Bus Mode: When the IOB is strapped HIGH the 8288 functions in the I/O Bus mode. When it is strapped LOW, the 8288 functions in the System Bus mode. (See sections on I/O Bus and System Bus modes).

| Name | 1/0 | Function |
| :---: | :---: | :---: |
| $\overline{\text { AlOWC }}$ | 0 | Advanced I/O Write Command: The $\overline{A I O W C}$ issues an I/O Write Command earlier in the machine cycle to give I/O devices an early indication of a write instruction. Its timing is the same as a read command signal. $\overline{\mathrm{AIOWC}}$ is active LOW. |
| $\overline{\text { IOWC }}$ | 0 | I/O Write Command: This command line instructs an I/O device to read the data on the data bus. This signal is active LOW. |
| $\overline{\text { ORC }}$ | 0 | I/O Read Command: This command line instructs an I/O device to drive its data onto the data bus. This signal is active LOW. |
| $\overline{\text { AMWC }}$ | 0 | Advanced Memory Write Command: The $\overline{A M W C}$ issues a memory write command earlier in the machine cycle to give memory devices an early indication of a write instruction. Its timing is the same as a read command signal. $\overline{\text { AMWC }}$ is active LOW. |
| $\overline{M W T C}$ | 0 | Memory Write Command: This command line instructs the memory to record the data present on the data bus. This signal is active LOW. |
| $\overline{\text { MRDC }}$ | 0 | Memory Read Command: This command line instructs the memory to drive its data onto the data bus. This signal is active LOW. |
| $\overline{\text { INTA }}$ | 0 | Interrupt Acknowledge: This command line tells an interrupting device that its interrupt has been acknowledged and that it should drive vectoring information onto the data bus. This signal is active LOW. |
| MCE/PDEN | 0 | This is a dual function pin. <br> MCE (IOB is tied LOW): Master Cascade Enable occurs during an interrupt sequence and serves to read a Cascade Address from a master PIC (Priority Interrupt Controller) onto the data bus. The MCE signal is active HIGH. <br> PDEN (IOB is tied HIGH): Peripheral Data Enable enables the data bus transceiver for the I/O bus during I/O instructions. It performs the same function for the I/O bus that DEN performs for the system bus. $\overline{\text { PDEN }}$ is active LOW. |

## COMMAND AND CONTROL LOGIC

The command logic decodes the three 8086 CPU status lines ( $\overline{\mathrm{S}_{0}}, \overline{\mathrm{~S}_{1}}, \overline{\mathrm{~S}_{2}}$ ) to determine what command is to be issued.
This chart shows the meaning of each status "word".

| $\overline{\mathbf{S}_{\mathbf{2}}}$ | $\overline{\mathbf{S}_{1}}$ | $\overline{\mathbf{S}_{\mathbf{0}}}$ | $\mathbf{8 0 8 6}$ State | $\mathbf{8 2 8 8}$ Command |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | 0 | Interrupt Acknowledge | $\overline{\overline{I N T A}}$ |
| 0 | 0 | 1 | Read I/O Port | $\overline{\text { IORC }}$ |
| 0 | 1 | 0 | Write I/O Port | $\overline{\text { IOWC, }}, \overline{\text { AIOWC }}$ |
| 0 | 1 | 1 | Halt | $\overline{\text { None }}$ |
| 1 | 0 | 0 | Code Access | $\overline{M R D C}$ |
| 1 | 0 | 1 | Read Memory | $\overline{M R D C}$ |
| 1 | 1 | 0 | Write Memory | $\overline{M W T C}, \overline{\text { AMWC }}$ |
| 1 | 1 | 1 | Passive | None |

The command is issued in one of two ways dependent on the mode of the 8288 Bus Controller.

I/O Bus Mode - The 8288 is in the I/O Bus mode if the IOB pin is strapped HIGH. In the I/O Bus mode all I/O command lines ( $\overline{\mathrm{ORC}}, \overline{\mathrm{IOWC}}, \overline{\mathrm{AIOWC}}, \overline{\mathrm{INTA}}$ ) are always enabled (i.e., not dependent on $\overline{\mathrm{AEN}}$ ). When an I/O command is initiated by the processor, the 8288 immediately activates the command lines using $\overline{P D E N}$ and DT/ $\bar{R}$ to control the I/O bus transceiver. The I/O command lines should not be used to control the system bus in this configuration because no arbitration is present. This mode allows one 8288 Bus Controller to handle two external busses. No waiting is involved when the CPU wants to gain access to the I/O bus. Normal memory access requires a "Bus Ready" signal ( $\overline{\mathrm{AEN}}$ LOW) before it will proceed. It is advantageous to use the IOB mode if I/O or peripherals dedicated to one processor exist in a multi-processor system.

System Bus Mode - The 8288 is in the System Bus mode if the IOB pin is strapped LOW. In this mode no command is issued until 85 ns after the $\overline{\mathrm{AEN}}$ Line is activated (LOW). This mode assumes bus arbitration logic will inform the bus controller (on the $\overline{\text { AEN }}$ line) when the bus is free for use. Both memory and I/O commands wait for bus arbitration. This mode is used when only one bus exists. Here, both I/O and memory are shared by more than one processor.

## Command Outputs

The advanced write commands are made available to initiate write procedures early in the machine cycle. This signal can be used to prevent the 8086 CPU from entering an unnecessary wait state.

The command outputs are:
$\overline{\text { MRDC }}$ - Memory Read Command
$\overline{M W T C}$ - Memory Write Command
$\overline{\overline{I O R C}}$ - I/O Read Command
$\overline{\overline{I O W C}}$ - I/O Write Command
$\overline{\text { AMWC }}$ - Advanced Memory Write Command
$\overline{\text { AIOWC }}$ - Advanced I/O Write Command
$\overline{\text { INTA }}$ - Interrupt Acknowledge

INTA (Interrupt Acknowledge) acts as an IVO read during an interrupt cycle. Its purpose is to inform an interrupting device that its interrupt is being acknowfedged and that it should place vectoring information onto the data bus.

## Control Outputs

The control outputs of the 8288 are Data Enable (DEN), Data Transmit/Receive ( $\mathrm{DT} / \overline{\mathrm{R}}$ ) and Master Cascade Enable/Peripheral Data Enable (MCE/PDEN). The DEN signal determines when the external bus should be enabled onto the local bus and the $D T / \bar{R}$ determines the direction of data transfer. These two signals usually go to the chip select and direction pins of a transceiver.
The MCE/PDEN pin changes function with the two modes of the 8288 . When the 8288 is in the IOB mode (IOB HIGH) the PDEN signal serves as a dedicated data enable signal for the I/O or Peripheral System bus.

## Interrupt Acknowledge and MCE

The MCE signal is used during an interrupt acknowledge cycle if the 8288 is in the System Bus mode (IOB LOW). During any interrupt sequence there are two interrupt acknowledge cycles that occur back to back. During the first interrupt cycle no data or address transfers take place. Logic should be provided to mask off MCE during this cycle. Just before the second cycle begins the MCE signal gates a master Priority Interrupt Controller's (PIC) cascade address onto the processor's local bus where ALE (Address Latch Enable) strobes it into the address latches. On the leading edge of the second interrupt cycle the addressed slave.PIC gates an interrupt vector onto the system data bus where it is read by the processor.
If the system contains only one PIC, the MCE signal is not used. In this case the second Interrupt Acknowledge signal gates the interrupt vector onto the processor bus.

## Address Latch Enable and Halt

Address Latch Enable (ALE) occurs during each machine cycle and serves to strobe data into the address latches. ALE also serves to strobe the status ( $\overline{\mathrm{S}_{0}}$, $\overline{S_{1}}, \overline{S_{2}}$ ) into a latch within the 8288 . For this reason an ALE occurs when entering a halt state.

## Command Enable

The Command Enable (CEN) input acts as a command qualifier for the 8288 . If the CEN pin is high the 8288 functions normally. If the CEN pin is pulled LOW, all command lines are held in their inactive state (not 3 -state). This feature can be used to implement memory partitioning and to eliminate address conflicts between system bus devices and resident bus devices.

## 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.
-1.0 V to +5.5 V
Power Dissipatıon
*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 FOR THE 8288

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $I^{\prime}=-5 \mathrm{~mA}$ |
| ${ }^{1} \mathrm{CC}$ | Power Supply Current |  | 230 | mA |  |
| IF | Forward Input Current |  | -0.7 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage-Command Outputs Control Outputs |  | $\begin{aligned} & 0.5 \\ & 0.5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I} \mathrm{OL}=32 \mathrm{~mA} \\ & \mathrm{IOL}=16 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage - Command Outputs Control Outputs | $\begin{aligned} & 2.4 \\ & 2.4 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA} \\ & \mathrm{IOH}=-1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage | 2.0 |  | V |  |
| IOFF | Output Off Current |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OFF }}=0.4$ to 5.25 V |

## A.C. CHARACTERISTICS FOR THE 8288

Conditions: $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
TIMING REQUIREMENTS

| Symbol | Parameter | Min | Max | Unit | Loading |
| :--- | :--- | :--- | :--- | :--- | :--- |
| TCLCL | CLK Cycle Period | 125 |  | ns |  |
| TCLCH | CLK Low Time | 66 |  | ns |  |
| TCHCL | CLK High Time | 40 |  | ns |  |
| TSVCH | Status Active Setup Time | 65 |  | ns |  |
| TCHSV | Status Active Hold Time | 10 |  | ns |  |
| TSHCL | Status Inactive Setup Time | 55 |  | ns |  |
| TCLSH | Status Inactive Hold Time | 10 |  | ns |  |

TIMING RESPONSES

| Symbol | Parameter | Min | Max | Unit | Loading |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCVNV | Control Active Delay | 5 | 45 | ns | $\overline{M R D C}$ <br> $\overline{I O R C}$ <br> $\overline{M W T C}$ <br> $\overline{I O W C}$ <br> $\overline{I N T A}$ <br> $\overline{A M W C}$ <br> $\overline{A I O W C}$ <br> $I_{\mathrm{OL}}=32 \mathrm{~mA}$ <br> $\mathrm{I}_{\mathrm{OH}}=-2 \mathrm{~mA}$ <br> $\mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$Other $\left\{\begin{array}{l}\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}\end{array}\right.$ |
| TCVNX | Control Inactive Delay | 10 | 45 | ns |  |
| TCLLH, TCLMCH | ALE MCE Active Delay (from CLK) |  | 15 | ns |  |
| TSVLH, TSVMCH | ALE MCE Active Delay (from Status) |  | 15 | ns |  |
| TCHLL | ALE Inactive Delay |  | 15 | ns |  |
| TCLML | Command Active Delay | 10 | 35 | ns |  |
| TCLMH | Command Inactive Delay | 10 | 35 | ns |  |
| TCHDTL | Direction Control Active Delay |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay |  | 30 | ns |  |
| TAELCH | Command Enable Time |  | 40 | ns |  |
| TAEHCZ | Command Disable Time |  | 40 | ns |  |
| TAELCV | Enable Delay Time | 85 | 275 | ns |  |
| TAEVNV | $\overline{\text { AEN }}$ to DEN |  | 20 | ns |  |
| TCEVNV | CEN to DEN, PDEN |  | 20 | ns |  |
| TCELRH | CEN to Command |  | TCLML | ns |  |

## 8288 TIMING DIAGRAM



Nores:

1. ADDRESSIDATA BUS IS SHOWN ONLY FOR REFERENCE PURPOSES.

LEADING EDGE OF ALE AND MCE IS DETERMINED BY THE FALLING EDGE OF CLK OR STATUS GOING ACTIVE, WHICHEVER OCCURS LAST 3. ALL TIMING MEASUREMENTS ARE MADE AT $\mathbf{1 . 5 V}$ UNLESS SPECIFIED OTHERWISE.

DEN, PDEN QUALIFICATION TIMING


## 8288 ADDRESS ENABLE ( $\overline{\text { AEN }})$ TIMING (3-STATE ENABLE/DISABLE)


test load circuits

3.STATE COMMAND OUTPUT TEST LOAD


Microprocessor Peripherals

## MICROPROCESSOR PERIPHERALS

## INTRODUCTION

Intel peripherals greatly enhance the 8080, the 8085, and many other microcomputers. These peripherals can significantly reduce development time, operating software, package count, board space, and parts costs while improving performance and increasing throughput in microcomputer systems. This section contains the most up-to-date data about Intel peripherals now available.

## TABLE OF CONTENTS

8041A/8741A Universal Peripheral Interface 8-Bit Microcomputer ..... $11-3$
8202 Dynamic RAM Controller ..... 11-14
8251A Programmable Communication Interface ..... 11-24
8253/8253-5 Programmable Interval Timer ..... 11-32
8255A/8255A-5 Programmable Peripheral Interface ..... $11-43$
8271 Programmable Floppy Disk Controller ..... 11.64
8273 Programmable HDLC/SDLC Protocol Controller ..... $11-93$
8275 Programmable CRT Controller ..... 11-118
8278 Programmable Keyboard Interface ..... 11-142
8279/8279-5 Programmable Keyboard/Display Interface ..... 11-152
8291 GPIB Talker/Listener ..... 11-164
8292 GPIB Controller. ..... 11-188
8294 Data Encryption Unit ..... 11-190
8295 Dot Matrix Printer Controller ..... 11-201 8041A/8741A UNIVERSAL PERIPHERAL INTERFACE 8-BIT MICROCOMPUTER

- 8-Bit CPU plus ROM, RAM, I/O, Timer
and Clock in a Single Package
- One 8-Bit Status and Two Data Registers for Asynchronous Slave-to-Master Interface

■ DMA, Interrupt, or Polled Operation Supported

- $1024 \times 8$ ROM/EPROM, $64 \times 8$ RAM, 8-Bit Timer/Counter, 18 Programmable I/O Pins
- Fully Compatible with MCS-48 ${ }^{\text {TM }}$, MCS-80 ${ }^{\text {TM }}$, MCS- $85^{\text {TM }}$, and MCS- $86^{\text {TM }}$ Microprocessor Families
- Expandable I/O

\author{

- ROM Power-Down Capability
}


## - Single 5V Supply

The Intel ${ }^{\circledR}$ 8041A/8741A is a general purpose, programmable interface device designed for use with a variety of 8 -bit microprocessor systems. It contains a low cost microcomputer with program memory, data memory, 8-bit CPU, I/O ports, timer/counter, and clock in a single 40-pin package. Interface registers are included to enable the UPI device to function as a peripheral controller in MCS-48 ${ }^{T M}$, MCS- $80^{\top M}$, MCS- $85^{\top M}$, MCS- $86^{\top M}$, and other 8-bit systems.

The UPI-41A ${ }^{T M}$ has 1 K words of program memory and 64 words of data memory on-chip. To allow full user flexibility the program memory is available as ROM in the 8041A version or as UV-erasable EPROM in the 8741A version. The 8741A and the 8041 A are fully pin compatible for easy transition from prototype to production level designs.

The device has two 8-bit, TTL compatible I/O ports and two test inputs. Individual port lines can function as either inputs or outputs under software control. I/O can be expanded with the 8243 device which is directly compatible and has 16 I/O lines. An 8-bit programmable timer/counter is included in the UPI device for generating timing sequences or counting external inputs. Additional UPI features include: single 5V supply, low power standby mode (in the 8041A), single-step mode for debug (in the 8741A), and dual working register banks.
Because it's a complete microcomputer, the UPI provides more flexibility for the designer than conventional LSI interface devices. It is designed to be an efficient controller as well as an arithmetic processor. Applications include keyboard scanning, printer control, display multiplexing and similar functions which involve interfacing peripheral devices to microprocessor systems.


PIN DESCRIPTION

Signa
Description
$D_{0}-D_{7}$
$P_{10}-P_{17}$
$P_{20}-P_{27}$
$\overline{W R} \quad 1 / O$ write input which enables the master CPU to write data and command words to the UPI-41A INPUT DATA BUS BUFFER.
$\overline{R D} \quad / / O$ read input which enables the master CPU to read data and status words from the OUTPUT DATA BUS BUFFER or status register.

Chip select input used to select one UPI-41A out of several connected to a common data bus.
$A_{0} \quad$ Address input used by the master processor to indicate whether byte transfer is data or command.
$T_{0}, T_{1} \quad$ Input pins which can be directly tested using conditional branch instructions.
$T_{1}$ also functions as the event timer input (under software control). $\mathrm{T}_{0}$ is used during PROM programming and verification in the 8741A.
$X_{1}, X_{2} \quad$ Inputs for a crystal, LC or an external timing signal to determine the internal oscillator frequency.

SYNC Output signal which occurs once per UPI-41A instruction cycle. SYNC can be used as a strobe for external circuitry; it is also used to synchronize single step operation.

EA External access input which allows emulation, testing and PROM/ROM verification.

PROG Multifunction pin used as the program pulse input during PROM programming.

During I/O expander access the PROG pin acts as an address/data strobe to the 8243.
$\overline{\text { RESET }}$ Input used to reset status flip-flops and to set the program counter to zero.
$\overline{\text { RESET }}$ is also used during PROM programming and verification.
$\overline{\mathrm{SS}}$
$\mathrm{V}_{\mathrm{CC}} \quad+5 \mathrm{~V}$ power supply pin.
$\mathrm{V}_{\mathrm{DD}} \quad+5 \mathrm{~V}$ during normal operation. Programming supply pin during PROM programming. Low power standby pin in ROM version.
$V_{S S} \quad$ Circuit ground potential.

UPI INSTRUCTION SET

| Mnemonic | Description " ${ }^{\text {a }}$, ${ }^{\text {a }}$ | Bytos Cycles |
| :---: | :---: | :---: |
| ACCUMULATOR |  |  |
| ADD A,Rr | Add register to A | 11 |
| ADD A,@Rr | Add data memory to A | 1 - 1 |
| ADD A,\#data | Add immediate to A | 22 |
| ADDC A,Rr | Add immed. to A with carry | $1 \quad 1$ |
| ADDC A,@Rr | Add immed. to A with carry | $1 \quad 1$ |
| ADDC A,\#data | Add immed. to A with carry | 22 |
| ANL A, Rr | AND register to A | 11 |
| ANL A,@Rr | AND data memory to $A$ | 11 |
| ANL A.\#data | AND immediate to A | 22 |
| ORL A,Rr | OR register to A | 11 |
| ORL A,@Rr | OR data memory to $A$ | $1 \quad 1$ |
| ORL A, \#data | OR immediate to $A$ | 22 |
| XRL A, Rr | Exclusive OR register to $A$ | $1 \quad 1$ |
| XRL A,@Rr | Exclusive OR data memory to $A$ | A 11 |
| XRL A,\#data | Exclusive OR immediate to $A$ | 22 |
| INC A | Increment A | 11 |
| DEC A | Decrement A | $1 \quad 1$ |
| CLR A | Clear A | 11 |
| CPL A | Complement A | 11 |
| DA A | Decimal Adjust A | 11 |
| SWAP A | Swap digits of A | 11 |
| RL A | Rotate A left | 11 |
| RLC A | Rotate A left through carry | $1 \quad 1$ |
| RR A | Rotate A right | 1 |
| RRC A | Rotate A right through carry | 11 |

## INPUT/OUTPUT

| IN A,Pp | Input port to A | 1 | 2 |
| :--- | :--- | :--- | :--- |
| OUTL Pp,A | Output A to port | 1 | 2 |
| ANL Pp,\#data | AND immediate to port | 2 | 2 |
| ORL Pp,\#data | OR immediate to port | 2 | 2 |
| IN A,DBB | Input DBB to A, clear IBF | 1 | 1 |
| OUT DBB,A | Output A to DBB, set OBF | 1 | 1 |
| MOVD A,Pp | Input Expander port to A | 1 | 2 |
| MOVD Pp,A | Output A to Expander port | 1 | 2 |
| ANLD Pp,A | AND A to Expander port | 1 | 2 |
| ORLD Pp,A | OR A to Expander port | 1 | 2 |

## DATA MOVES

| MOV A,Rr | Move register to A | 1 | 1 |
| :--- | :--- | :--- | :--- |
| MOV A,@Rr | Move data memory to A | 1 | 1 |
| MOV A,\#data | Move immediate to A | 2 | 2 |
| MOV Rr,A | Move A to register | 1 | 1 |
| MOV @Rr,A | Move A to data memory | 1 | 1 |
| MOV Rr,\#data | Move immediate to register | 2 | 2 |
| MOV @Rr,\#data | Move immediate to data memory | 2 | 2 |
| MOV A,PSW | Move PSW to A | 1 | 1 |
| MOV PSW,A | Move A to PSW | 1 | 1 |
| XCH A,Rr | Exchange A and register | 1 | 1 |
| XCH A,@Rr | Exchange A and data memory | 1 | 1 |
| XCHD A,@Rr | Exchange digit of A and register | 1 | 1 |
| MOVP A,@A | Move to A from current page | 1 | 2 |
| MOVP3, A,@A | Move to A from page 3 | 1 | 2 |

## TIMER/COUNTER

| MOV A,T | Read Timer/Counter | 1 | 1 |
| :--- | :--- | :--- | :--- |
| MOV T,A | Load Timer/Counter | 1 | 1 |
| STRT T | Start Timer | 1 | 1 |
| STRT CNT | Start Counter | 1 | 1 |
| STOP TCNT | Stop Timer/Counter | 1 | 1 |
| EN TCNTI | Enable Timer/Counter Interrupt | 1 | 1 |
| DIS TCNTI | Disable Timer/Counter Interrupt | 1 | 1 |

UPI-41

1. Single Data Bus Buffer

2. 4 Bits of Status

3. $\overline{R D}$ and $\overline{W R}$ are level triggered. IBF, OBF, $F_{1}$ and INT change internally when $\overline{R D}$ or $\overline{W R}$ are low.

4. $P_{24}$ and $P_{25}$ are port pins only.
5. Two Data Bus Buffers, one for input and one for output. This allows a much cleaner Master/Slave protocol.

6. 8 Bits of Status

| $\mathrm{ST}_{7}$ | $\mathrm{ST}_{6}$ | $\mathrm{ST}_{5}$ | $\mathrm{ST}_{4}$ | $\mathrm{~F}_{1}$ | $\mathrm{~F}_{0}$ | IBF | OBF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |

$\mathrm{ST}_{4}-\mathrm{ST} T_{7}$ are user definable status bits. These bits are defined by the "MOV STS, A" single byte, single cycle instruction. Bits 4-7 of the accumulator are moved to bits 4-7 of the status register. Bits $0-3$ of the status register are not affected.

3. $\overline{R D}$ and $\overline{W R}$ are edge triggered. IBF, OBF, $F_{1}$ and INT change internally after the trailing edge of $\overline{R D}$ or $\overline{W R}$.

4. $P_{24}$ and $P_{25}$ are port pins or Buffer Flag pins which can be used to interrupt a master processor. These pins default to port pins on Reset.
If the "EN FLAGS" instruction has been executed, $P_{24}$ becomes the OBF (Output Buffer Full) pin. A " 1 " written to $P_{24}$ enables the OBF pin (the pin outputs the OBF Status Bit). A " 0 " written to $\mathrm{P}_{24}$ disables the OBF pin (the pin remains low). This pin can be used to indicate that valid data is available from the UPI41A (in Output Data Bus Buffer).

If "EN FLAGS" has been executed, $\mathrm{P}_{25}$ becomes the $\overline{\overline{1 B F}}$ (Input Buffer Full) pin. A "1" written to $\mathrm{P}_{25}$ enables the $\overline{I B F}$ pin (the pin outputs the inverse of the $\overline{\text { IBF }}$ Status Bit). A " 0 " written to $\mathrm{P}_{25}$ disables the IBF pin (the pin remains low). This pin can be used to indicate that the UPI-41 is ready for data.


DATA BUS BUFFER INTERRUPT CAPABILITY

EN FLAGS Op Code: OF5H

5. $P_{26}$ and $P_{27}$ are port pins or DMA handshake pins for use with a DMA controller. These pins default to port pins on Reset.

If the "EN DMA" instruction has been executed, $\mathrm{P}_{26}$ becomes the DRQ (DMA ReQuest) pin. A " 1 " written to $P_{26}$ causes a DMA request (DRQ is activated). DRQ is deactivated by DACK•RD, DACK•WR, or execution of the "EN DMA" instruction.

If "EN DMA" has been executed, $P_{27}$ becomes the $\overline{\text { DACK }}$ (DMA ACKnowledge) pin. This pin acts as a chip select input for the Data Bus Buffer registers during DMA transfers.


DMA HANDSHAKE CAPABILITY

EN DMA Op Code: OE5H


## 8041A/8741A

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\qquad$ $.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.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 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{SS}}=0 \mathrm{~V}, 8041 \mathrm{~A}: \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, 8741 \mathrm{~A}: \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (All Except $\mathrm{X}_{1}, \mathrm{X}_{2}$ ) | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage (All Except $\mathrm{X}_{1}, \mathrm{X}_{2}, \overline{\mathrm{RESET}}$ ) | 2.2 | $\mathrm{V}_{\mathrm{CC}}$ |  |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | Input High Voltage ( $\mathrm{X}_{1}, \mathrm{X}_{2}, \overline{\text { RESET }}$ ) | 3.0 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\mathrm{D}_{2}-\mathrm{D}_{7}$, Sync) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage (All Other Outputs Except Prog) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 3}$ | Output Low Voltage (Prog) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output Higi Voltage (All Other Outputs) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| $I_{\text {IL }}$ | Input Leakage Current ( $\mathrm{T}_{0}, \mathrm{~T}_{1}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}, \mathrm{A}_{0}, \mathrm{EA}$ ) |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| IOZ | Output Leakage Current ( $\mathrm{D}_{0}-\mathrm{D}_{7}$, High Z State) |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+0.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LI} 1}$ | Low Input Load Current ( $\mathrm{P}_{10} \mathrm{P}_{17}, \mathrm{P}_{20} \mathrm{P}_{27}$ |  | 0.5 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{LI} 2}$ | Low Input Load Current ( $\overline{\mathrm{RESET}}$, SS) |  | 0.2 | mA | $\mathrm{V}_{1 \mathrm{~L}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 1.5 | mA |  |
| $I_{C C}+I_{D D}$ | Total Supply Current |  | 125 | mA |  |

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, 8041 \mathrm{~A}: \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, 8741 \mathrm{~A}: \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 5 \%$
DBB READ

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A R}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | ns |  |
| $t_{R A}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After $\overline{\mathrm{RD}} \uparrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\mathrm{RD}}$ Pulse Width | 250 |  | ns | $\mathrm{t}_{\mathrm{CY}}=2.5 \mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{AD}}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ to Data Out Delay |  | 225 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RD}}$ | $\overline{\mathrm{RD}} \downarrow$ to Data Out Delay |  | 225 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RDF}}$ | $\overline{\mathrm{RD}} \uparrow$ to Data Float Delay |  | 100 | ns |  |
| $\mathrm{t}_{\mathrm{RV}}$ | Recovery Time Between Reads And/Or Write | 300 |  | ns |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Cycle Time | 2.5 | 15 | $\mu \mathrm{~s}$ |  |

DBB WRITE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | CS, $A_{0}$ Setup to WR $\downarrow$ | 0 |  | ns |  |
| $t_{W A}$ | CS, $A_{0}$ Hold After WR $\uparrow$ | 0 |  | ns |  |
| $t_{W W}$ | WR Pulse Width | 250 |  | ns |  |
| $t_{\text {DW }}$ | Data Setup to WR $\uparrow$ | 150 |  | ns |  |
| $t_{W D}$ | Data Hold Aftert WR $\uparrow$ | 0 |  | ns |  |

## A.C. TEST CONDITIONS

$$
\begin{aligned}
& D_{7}-D_{0} \text { Outputs } \\
& R_{L}=2.2 \mathrm{k} \text { to } \mathrm{V}_{\mathrm{SS}} \\
& 4.3 \mathrm{k} \text { to } \mathrm{V}_{\mathrm{CC}} \\
& C_{L}=100 \mathrm{pF}
\end{aligned}
$$

## WAVEFORMS

1. READ OPERATION—DATA BUS BUFFER REGISTER.

2. WRITE OPERATION-DATA BUS BUFFER REGISTER.


## A.C. CHARACTERISTICS—PORT 2

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, 8041 \mathrm{~A}: \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, 8741 \mathrm{~A}: \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{C P}$ | Port Control Setup Before Falling Edge of $\overline{\text { PROG }}$ | 110 |  | ns |  |
| $t_{P C}$ | Port Control Hold After Falling Edge of $\overline{\text { PROG }}$ | 140 |  | ns |  |
| $t_{D P}$ | Output Data Setup Time | 220 |  | ns |  |
| $t_{P F}$ | Input Data Hold Time | 110 |  | ns |  |
| $t_{P P}$ | $\overline{\text { PROG Pulse Width }}$ | 1400 |  | ns |  |
| $t_{P S}$ | Input Data Setup Time | 700 |  | ns |  |

## WAVEFORMS—PORT 2



## A.C. CHARACTERISTICS—DMA

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A C C}$ | DAC to $\overline{W R}$ or $\overline{R D}$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{CAC}}$ | $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ to $\overline{\mathrm{DACK}}$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{ACD}}$ | $\overline{\mathrm{DACK}}$ to Data Valid |  | 225 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{CRQ}}$ | $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ to DRQ Cleared |  | 200 | ns |  |

## WAVEFORMS—DMA



| Mnemonic | Description | Bytes | Cycles | Mnemonic | Description |  | Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CONTROL |  |  |  | CLR F1 | Clear F1 Flag |  |  |
| EN DMA | Enable DMA Handshake Lines | 1 | 1 | CPL F1 | Complement F1 Flag |  | 4. |
| EN I | Enable IBF Interrupt | 1 | 1 | MOV STS, A | $\mathrm{A}_{4}-\mathrm{A}_{7}$ to Bits 4-7 of Status |  | 1 |
| DIS I | Disable IBF Interrupt | 1 | 1 |  |  |  | $\checkmark$ |
| EN FLAGS | Enable Master Interrupts | 1 | 1 |  |  |  | $\cdots$ |
| SEL RB0 | Select register bank 0 | 1 | 1 | BRANCH |  |  |  |
| SEL RB1 | Select register bank 1 | 1 | 1 | JMP addr | Jump unconditional | 2 | 2 |
| NOP | No Operation | 1 | 1 | JMPP @ A | Jump indirect | 1 | 2 |
| REGISTERS |  |  |  | DJNZ R,addr | Decrement register and skip | 2 | 2 |
| INC Rr | Increment register | 1 | 1 | JC addr | Jump on Carry = 1 | 2 | 2 |
| INC@Rr | Increment data memory | 1 | 1 | JNC addr | Jump on Carry $=0$ | 2 | 2 |
| DEC Rr | Decrement register | 1 | 1 | JZ addr | Jump on A Zero | 2 | 2 |
| SUBROUTINE |  |  |  | JNZ addr | Jump on $A$ not Zero Jump on $\mathrm{T} 0=1$ | 2 | 2 |
| CALL addr | Jump to subroutine | 2 | 2 | JNT0 addr | Jump on $\mathrm{TO}=0$ | 2 | 2 |
| RET | Return | 1 | 2 | JT1 addr | Jump on $\mathrm{T} 1=1$ | 2 | 2 |
| RETR | Return and restore status | 1 | 2 | JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
| FLAGS |  |  |  | JFO addr | Jump on FO Flag $=1$ | 2 | 2 |
| Flags |  |  |  | JF1 addr | Jump on F1 Flag $=1$ | 2 | 2 |
| CLR C | Clear Carry | 1 | 1 | JTF addr | Jump on Timer Flag = 1, Clear Flag | 2 | 2 |
| CPL C | Complement Carry | 1 | 1 | JNIBF addr | Jump on IBF Flag $=0$ | 2 | 2 |
| CLR FO | Clear Flag 0 | 1 | 1 | JOBF addr | Jump on OBF Flag $=1$ | 2 | 2 |
| CPL FO | Complement Flag 0 | 1 | 1 | JBb addr | Jump on Accumulator Bit | 2 | 2 |

## APPLICATIONS



Figure 1. 8085A-8041A Interface


Figure 3. 8041A-8243 Keyboad Scanner
Figure 2. 8048-8041A Interface


Figure 4. 8041A Matrix Printer Interface

## PROGRAMMING, VERIFYING, AND ERASING THE 874IA EPROM

## Programming/Verification

In brief, the programming process consists of: activating the program mode, applying an address, latching the address, applying data, and applying a programming pulse. Each word is programmed completely before moving on to the next and is followed by a verification step. The following is a list of the pins used for programming and a description of their functions:

| Pin | Function |
| :--- | :--- |
| XTAL 1 | Clock input (1 to 6 MHz ) |
| RESET | Initialization and address latching |
| TEST 0 | Selection of program or verify mode |
| EA | Activation of program/verify modes |
| BUS | Address and data input data output during <br> verify |
| P20-1 | Address input |
| VDD $^{\text {PROG }}$ | Programming power supply |
| Program pulse input |  |

The program/verify sequence is:

1. $V_{D D}=5 \mathrm{~V}$, clock applied or internal oscllator operating, RESET $=0 \mathrm{~V}$, TEST $0=5 \mathrm{~V}, E A^{4}=5 \mathrm{~V}$, BUS and PROG floating.
2. Insert 8741A in programming socket.
3. TEST $0=O V$ (select program mode).
4. $E A=25 \mathrm{~V}$ (activate program mode).
5. Address applied to BUS and P20-1.
6. RESET $=5 \mathrm{~V}$ (latch address).
7. Data applied to BUS.
8. $V_{D}=25 \mathrm{~V}$ (programming power).
9. $\mathrm{PROG}=0 \mathrm{~V}$ followed by one 50 ms pulse to 25 V .
10. $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$.
11. TEST $0=5 \mathrm{~V}$ (verify mode).
12. Read and verify data on BUS.
13. TEST $0=0 \mathrm{~V}$.
14. RESET $=0 \mathrm{~V}$ and repeat from step 5 .
15. Programmer should be at conditions of step 1 when 8741A is removed from socket.

## Programming Options

The 8741A EPROM can be programmed by either of two Intel products:

1. PROMPT-48 Microcomputer Design Aid.
2. Universal PROM Programmer (UPP-101 or UPP-102) Peripheral of the Intellec ${ }^{\circledR}$ Development System with a UPP-848 Personality Card.


WARNING: An attempt to program a missocketed 8741A will result in severe damage to the part. An indication of a properly socketed part is the appearance of the SYNC output. The lack of this clock may be used to disable the programmer.

Figure 5. Programming/Verification Sequence

## 8741A Erasure Characteristics

The erasure characteristics of the 8741A 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 8741A in approximately 3 years while it would take approximately one week to cause erasure when exposed to direct sunlight. If the 8741A 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 8741A window to prevent unintentional erasure.

The recommended erasure procedure for the 8741 is exposure to shortwave ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (i.e., UV intensity $\times$ 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 $12,000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ power rating. The 8741 A should be placed within one inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.

## A.C. TIMING SPECIFICATION FOR PROGRAMMING

$T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | Address Setup Time to $\overline{\text { RESET }}$, | 4tcy |  |  |  |
| twa | Address Hold Time After $\overline{\text { RESET }}$, | 4tcy |  |  |  |
| tow | Data in Setup Time to PROG 1 | 4tcy |  |  |  |
| two | Data in Hold Time After PROG 1 | 4tcy |  |  |  |
| tPh | RESET Hold Time to Verify | 4tcy |  |  |  |
| tvodw | VDD | 4tcy |  |  |  |
| tVDDH | VDD Hold Time After PROG ! | 0 |  |  |  |
| tpw | Program Pulse Width | 50 | 60 | MS |  |
| trw | Test 0 Setup Time for Program Mode | 4 tcy |  |  |  |
| twT | Test 0 Hold Time After Program Mode | 4tcy |  |  |  |
| too | Test 0 to Data Out Delay |  | 4tcy |  |  |
| tww | $\overline{\text { RESET Pulse Width to Latch Address }}$ | 4 tcy |  |  |  |
| $\mathrm{tr}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | VDD and PROG Rise and Fall Times | 0.5 | 2.0 | $\mu \mathrm{S}$ |  |
| tcr | CPU Operation Cycle Time | 5.0 |  | $\mu \mathrm{S}$ |  |
| tre | $\overline{\text { RESET }}$ Setup Time Before EA $\dagger$ | 4 tcy |  |  |  |

Note: If TEST 0 is high, DO $_{\text {DO }}$ can be triggered by $\overline{\text { RESET } 1}$.

## D.C. SPECIFICATION FOR PROGRAMMING

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VDOH | VDD Program Voltage High Level | 24.0 | 26.0 | V |  |
| VDDL | VDD Voltage Low Level | 4.75 | 5.25 | V |  |
| VPH | PROG Program Voltage High Level | 21.5 | 24.5 | V |  |
| $V_{P L}$ | PROG Voltage Low Level |  | 0.2 | V |  |
| VEAH | EA Program or Verify Voltage High Level | 21.5 | 24.5 | V |  |
| VEAL | EA Voltage Low Level |  | 5.25 | V |  |
| IDD | VOD High Voltage Supply Current |  | 30.0 | mA |  |
| Iprog | PROG High Voltage Supply Current |  | 16.0 | mA |  |
| IEA | EA High Voltage Supply Current |  | 1.0 | mA |  |

## WAVEFORMS

## Combination Program/Verify Mode (EPROMs Only)



## Verify Mode (ROM/EPROM)

VERIFY MODE (ROM/EPROM)

$\mathrm{DB}_{0}-\mathrm{DB}_{7}$


## 8202 DYNAMIC RAM CONTROLLER

Provides All Signals Necessary toControl 2104A, 2117, or 2118 Dynamic Memories

- Directly Addresses and Drives Up to 128K Bytes Without External Drivers
- Provides Address Multiplexing and Strobes
- Provides a Refresh Timer and a Refresh Counter
- Refresh Cycles May be Internally or Externally Requested
- Provides Transparent Refresh Capability
- Fully Compatible with Intel ${ }^{\circledR}$ 8080A, 8085A and 8086 Microprocessors
- Decodes 8085A Status for Advanced Read Capability


## Provides System Acknowledge and Transfer Acknowledge Signals

- Internal or External Clock Capability

The 8202 is a Dynamic RAM System Controller designed to provide all signals necessary to use 2104A, 2117, or 2118 Dynamic RAMs in microcomputer systems. The 8202 provides multiplexed addresses and address strobes, as well as refresh/access arbitration. Refresh cycles can be started internally or externally.

PIN CONFIGURATION


PIN DESCRIPTIONS

| Pin Name | \# | 1/0 | Pin Description |
| :---: | :---: | :---: | :---: |
| ALo | 6 | 1 | Low-Ǒrder Address. These Address |
| AL. 1 | 8 | 1 | inputs are used to generate the Row |
| AL2 | 10 |  | Address for the Multiplexer. If the |
| AL3 | 12 |  | $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ input is pulled to +12 V |
| AL4 | 14 |  | through a $5 \mathrm{~K} \Omega$ resistor, the 8202 |
| AL5 | 16 |  | configures itself for 4K RAMs. If |
| $\mathrm{AL6}_{6} / \mathrm{OP}_{3}$ | 18 |  | $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ is driven with TTL levels, the 8202 configures itself for 16 K RAMs. |

$\mathrm{AH}_{0} 5 \quad \mathrm{I}$ High-Order Address. These Ad-
$\mathrm{AH}_{1} \quad 4 \quad 1$ dress inputs are used to generate
$\mathrm{AH}_{2} \quad 3 \quad 1$ the Column Address for the Multi-
$\mathrm{AH}_{3} 2 \quad 1$ plexer. If the 8202 is configured for
$\mathrm{AH}_{4} \quad 1 \quad$ I 4 K RAMs, $\mathrm{AH}_{6}$ can be used as an
$\mathrm{AH}_{5} 39$ I active high Chip select for the mem-
$\mathrm{AH}_{6} \quad 38 \quad$ I ory controlled by 8202. For 16 K RAM operation, $\mathrm{AH}_{6}$ becomes the most significant column address bit.

| $\overline{\mathrm{OUT}}_{0}$ | 7 | O Output of the Multiplexer. These |
| :--- | ---: | :--- |
| $\overline{\mathrm{OUT}}_{1}$ | 9 | O outputs are designed to drive the ad- |
| $\overline{\mathrm{OUT}}_{2}$ | 11 | O dresses of the Dynamic RAM array. |
| $\overline{\mathrm{OUT}}_{3}$ | 13 | O For 4K RAM operation, $\overline{\mathrm{OUT}}_{6}$ is de- |
| $\overline{\mathrm{OUT}}_{4}$ | 15 | O signed to drive the $2104 \mathrm{~A} \overline{\mathrm{CS}}$ input. |
| $\overline{\mathrm{OUT}} 5^{\mathrm{OUT}_{6}}$ | 17 | O (Note that the $\mathrm{OUT}_{0-6}$ pins do not <br> O require inverters or drivers for <br> proper operation. |
| $\overline{\mathrm{OUT}_{6}}$ | 28 | OWrite Enable. This output is de- <br> signed to drive the Write Enable in- <br> puts of the Dynamic RAM array. |

$\overline{\text { CAS }} 27$ O Column Address Strobe. This output is used to latch the Column Address into the Dynamic RAM array.
$\overline{\mathrm{RAS}}_{0} \quad 21 \quad \mathrm{O}$ Row Address Strobe. These outputs
$\overline{\mathrm{RAS}}_{1} \quad 22 \quad \mathrm{O}$ are used to latch the Row Address
$\widehat{R A S}_{2} 230$ into the bank of dynamic RAMs,
$\overline{\operatorname{RAS}}_{3} 26$ O selected by the 8202 Bank Address pins ( $\mathrm{B}_{0}, \mathrm{~B}_{1} / \mathrm{OP}_{1}$ )

Bo
24 I Bank Address. These inputs are
$\mathrm{B}_{1} / \mathrm{OP}_{1} \quad 25 \quad \mid$ used to select one of four banks of dynamic RAM via the $\overline{\operatorname{RAS}}_{0-3}$ outputs. If the $\mathrm{B}_{1} / \mathrm{OP}_{1}$ input is pulled to +12 V through a $5 \mathrm{~K} \Omega$ resistor, the 8202 configures itself to the Advanced Read mode. This mode changes the function of the 8202 $\overline{\mathrm{RD}} / \mathrm{S}_{1}$ and REFRQ/ALE inputs and disables the $\overline{\operatorname{RAS}}_{0}$ and $\overline{\mathrm{RAS}}_{1}$ outputs.

| Pin Name | \# | 1/0 | Pin Description |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{RD}} / \mathrm{S}_{1}$ | 32 | 1 | Read $/ S_{1}$ input. This input is used to request a read cycle. In normal operation, a low on this input informs the arbiter that a read cycle is requested. In the Advanced Read Mode, this input is designed to accept the S 1 status signal from the 8085A (fully decoded for a read). The trailing edge of ALE informs the arbiter that a read cycle is requested by latching $\mathrm{S}_{1}$. |
| $\overline{W R}$ | 31 |  | Write Input. This input is used to request a write cycle. A low on this input informs the arbiter that a write cycle is desired. |
| $\overline{\text { PCS }}$ | 33 | 1 | Protected Chip Select. A low on this input enables the $\overline{W R}$ and $\overline{R D} / S_{1}$ inputs. $\overline{\mathrm{PCS}}$ is protected against terminating a cycle in progress. |
| REFRQ/ ALE | 34: | 1 | Refresh Request/Address Latch Enable. During normal operation, a high on this input indicates to the arbiter that a refresh cycle is being requested. In the Advanced Read Mode, this input is used to latch the state of the 8085 S 1 signal into the $\overline{R D} / S_{1}$ input. If $S_{1}$ is high at this time, a Read Cycle is requested. In this mode, transparent refresh is not possible. |
| $\overline{\text { XACK }}$ | 29 |  | Transfer acknowledge. This output is a strobe indicating valid data during a read cycle or data written during a write cycle. $\overline{\text { XACK }}$ can be used to latch valid data from the RAM array. |
| $\overline{\text { SACK }}$ | 30 |  | System Acknowledge. This output indicates the beginning of a memory access cycle. It can be used as an advanced transfer acknowledge to eliminate wait states. (Note: If a memory access request is made during a refresh cycle, $\overline{\text { SACK }}$ is delayed until XACK in the memory access cycle). |
| $\mathrm{X}_{0} / \mathrm{OP}_{2}$ | 36 | 1 | Crystal Inputs. These inputs are de- |
| $\mathrm{X}_{1} /$ CLK | 37 |  | signed for a quartz crystal to control the frequency of the oscillator. If $\mathrm{X}_{0} / \mathrm{OP}_{2}$ is pulled to +12 V through a $1 \mathrm{~K} \Omega$ resistor, $\mathrm{X}_{1} /$ CLK becomes a TTL input for an external clock. |
| TNK | 35 |  | Tank. This pin is used for a tank circuit connection. |
| Vcc | 40 |  | $+5 \mathrm{~V} \pm 10 \%$ |
| VSS | 20 |  | Ground. |

## BASIC FUNCTIONAL DESCRIPTION

The 8202 consists of six basic blocks; the oscillator, the arbiter, the refresh timer, the refresh counter, the multiplexer, and the timing and control block.

## Oscillator

The oscillator provides the basic timing for all 8202 operations. The oscillator circuit is designed primarily for use with an external series resonant fundamental mode crystal. Overtone crystals may be used with the tank circuit shown in Figure 1. A small capacitor (3-5) pF should be placed in series with any crystal to block D.C. stress and assure oscillation at the proper frequency.


The tank input to the oscillator allows the use of overtone mode crystals. The tank circuit shunts the crystal's fundamental and high overtone frequencies and allows the third harmonic to oscillate. The external LC network is connected to the TANK input and is AC coupled to ground.

If the $\mathrm{X}_{0} / \mathrm{OP}_{2}$ pin is pulled to +12 V , through a $1 \mathrm{~K} \Omega$ resistor, the 8202 can be driven by a TTL clock on the $X_{1} /$ CLK input. No tank circuit is required in this mode.

## Arbiter

The 8202 provides 3 different operational cycles:

1. Read Cycle
2. Write Cycle
3. Refresh Cycle

The read and write cycles are initiated by external requests ( $\overline{\mathrm{RD}} / \mathrm{S}_{1}$ and $\overline{\mathrm{PCS}}$ or $\overline{\mathrm{WR}}$ and $\overline{\mathrm{PCS}}$ ). A refresh cycle may be initiated by the internal refresh timer, or by an external request (REFRQ/ALE). The arbiter resolves conflicts between cycle requests and cycles in execution.

If the $B_{1} / O P_{1}$ input is pulled to +12 V through a $5 \mathrm{~K} \Omega$ resistor (Advanced Read mode), ' $\overline{R D} / S_{1}$ becones an input for the $\mathrm{S}_{1}$ status signal of the 8085A (fully decoded for read). REFRQ/ALE becomes an input for the ALE' signal of the 8085 (used to latch $\mathrm{S}_{1}$. If $\mathrm{S}_{1}$ is "high", at the falling edge of ALE, a read cycle will be requested. Transparent refresh is not possible in this mode.

## Refresh Timer

The refresh timer is a simple timer that indicates to the arbiter that it is time for a refresh cycle. The refresh timer is reset when a refresh cycle is requested.

## Refresh Counter

The refresh counter contains the address of the row to be refreshed. This counter is incremented after every refresh cycle.

## Multiplexer

The multiplexer is designed to provide the dynamic RAM array with row addresses, column addresses and refresh addresses at the proper times. Its inputs consist of $\mathrm{AL}_{0-5}$, $\mathrm{AL}_{6} / \mathrm{OP}_{3}, \mathrm{AH}_{0-6}$, and the refresh counter.
If $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ is pulled to +12 V through a $5 \mathrm{~K} \Omega$ resistor, the 8202 configures itself for 4K RAMs. In this mode, ALO-5 provides the multiplexer with the six bit row address. $\mathrm{AH}_{0-}$ 5 provides the multiplexer with the six bit column address.

$\overline{\mathrm{OUT}}_{0-5}$ provide the RAM array with twelve bits of multiplexed address. $\mathrm{AH}_{6}$ can be used as an active high chip select for the RAM array if $\overline{\mathrm{OUT}}_{6}$ drives $\overline{\mathrm{CS}}$. Note that the $\overline{O U T}_{0-6}$ signals do not require inverters or drivers.
If the 8202 is configured for 16 K RAMs, $\mathrm{ALO}_{0} 5$ and $\mathrm{AL} / \mathrm{OP}_{3}$ provide the multiplexer with seven bits of row
address. $\mathrm{AH}_{0-6}$ provides it with seven bits of column address. $\overline{O U T}_{0-6}$ provides the RAM array with fourteen bits of multiplexed address.

## Timing and Control Block

The timing and control block executes one of three operational cycles at the request of the arbiter (Read, Write, and Refresh cycles). It provides the RAM array with $\overline{W E}, \overline{C A S}$, and $\overline{R A S}$ signals. It provides the CPU with transfer and system acknowledge ( $\overline{\mathrm{XACK}}$ and $\overline{\mathrm{SACK}}$ ) signals. It controls the multiplexer during all cycles. It resets the refresh timer and increments the refresh counter during refresh cycles.
Inputs $\mathrm{B}_{0}$ and $\mathrm{B}_{1} / O P_{1}$ are used to select one of four banks of dynamic RAM via the $\overline{\operatorname{RAS}}_{0-3}$ outputs.
If $\mathrm{B}_{1} / O P_{1}$ is pulled to +12 V through a $5 \mathrm{~K} \Omega$ resistor, the 8202 configures itself to the Advanced Read Mode. This mode changes the function of the $\overline{R D} / S_{1}$ and REFRQ/ALE inputs and disables the $\overline{\operatorname{RAS}}_{0}$ and $\overline{\operatorname{RAS}}_{1}$ outputs.

## SYSTEM OPERATION

The 8202 is always in one of the following states:

1. Idle.
2. Performing a Test Cycle.
3. Performing a Write Cycle.
4. Performing a Read Cycle.
5. Performing a Refresh Cycle.

## Idle

When the 8202 is idle, no cycle is in progress, the arbiter monitors internal and external cycle requests, and the refresh timer counts towards an internal refresh cycle request. (Fig. X.1)
While the 8202 is idle, the arbiter samples access cycle requests and refresh cycle requests, internal or external, on the rising edge of clock. If both Read and Write cycle requests are active when sampled, a test cycle is started. If a write-cycle request is active when sampled, a write cycle is started. If a read cycle request is active when sampled, a read cycle is started. If a refresh cycle request was previously pulsed or is active when sampled, a refresh cycle is started. Due to internal delays, if an access cycle request and a refresh cycle request occur simultaneously, the access cycle will be executed before the refresh cycle is executed.

## Test Cycle

When a test cycle is started, (Read and Write Cycle Requests both active when sampled) the refresh counter is set to zero and the delayed $\overline{\text { SACK }}$ mode is reset, while the 8202 executes a write cycle. This cycle is used for testing only and is not recommended for normal system operation.


## Write Cycle (Fig. X.2)

When a write cycle is started, (Write-Cycle Request active when sampled) the Multiplexer drives the OUT 0-6 pins with the low order address. Then, if the delayed $\overline{\text { SACK }}$ Mode is not set, $\overline{\text { SACK }}$ is activated. The row address is strobed into the selected bank of RAMs. The multiplexer then drives the $\overline{O U T} 0-6$ pins with the high order address and the write enable ( $\overline{\mathrm{WE}}$ ) pin is activated. The column address is then strobed into the RAM array.
Near the end of the cycle, the $\overline{\text { XACK }}$ output is activated. If the Delayed SACK Mode is set, $\overline{\text { SACK }}$ had the same timing as XACK. At the end of the cycle, all signals are deactivated, the Delayed $\overline{\text { SACK }}$ Mode is exited, and the precharge time begins. After the precharge time, the 8202 re-enters the idle state. The refresh timer continues to count during access cycles.
If the REFRQ pin is pulsed or held active while a write cycle is in progress, a refresh cycle will occur immediately following the write cycle, if the Advanced Read Mode is not selected.

## Read Cycle (Fig. X.3)

Read cycle operation is the same as write cycle operation, except the write enable $(\overline{\mathrm{WE}})$ signal is not activated.

If the REFRQ pin is pulsed or held active while a read cycle is in progress, a refresh cycle will occur immedi-
ately following the read cycle, if the Advanced Read Mode is not selected.



## Refresh Cycle (Fig. X.4)

When a refresh cycle is started, (refresh-cycle request previously pulsed or active when sampled) the 8202 resets the Refresh Timer. The Multiplexer drives the OUT 0-6 pins with the refresh address contained in the

Refresh Counter. The 8202 then activates the Row Address Strobe ( $\overline{\operatorname{RAS}} 0-3$ ) signals. At the end of the refresh cycle, all signals are deactivated, the refresh counter is incremented, and the precharge time begins. After the precharge time, the 8202 re-enters the Idle State.
$\qquad$

## Hidden Refresh Cycle

Distributed hidden refresh operation is most efficient if REFRQ is strobed during a command cycle such as fetch, where it is intended for the refresh cycle to follow. This is illustrated for 8085 in the following diagram.

## System Configurations

Currently, there exists a wide range of processor bus structures, processor speeds, and memory speeds. As a result, the 8202 offers many possible system configurations with equally many cost-performance tradeoffs.


The following system block diagram illustrates just one of the possible system configurations supported by the 8202:


Other system configurations are described in the Intel, Application Note AP45, "Using the 8202 Dynamic RAM Controller." Other related documents are:

- "Intel Memory Design Handbook" (Dynamic Ram sections).
- AR-1, "Simplify Your Dynamic RAM/Microprocessor Interface."
- AP-38, "Application Techniques for the Intel 8085A Bus."


## 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.4 Watts
*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 10 \% ; \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1.0 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 250 | mA |  |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  |  |  |  |
|  | $\mathrm{X}_{1} / \mathrm{CLK}$ |  | -2.0 | mA | $\mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
|  | All Other Inputs |  | -320 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Current |  | 40 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |
|  | SACK, $\overline{\text { XACK }}$ |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=3 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | All Other Outputs |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
|  | Output High Voltage |  | 2.4 |  | V |
|  | SACK, XACK |  | $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |  |  |
|  | All Other Outputs | 2.6 |  | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage |  | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V |  |

## CAPACITANCE

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 30 | pF | $\begin{aligned} & \mathrm{F}=1 \mathrm{MHz} \\ & \mathrm{~V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \hline \end{aligned}$ |

## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$
Loading

$$
\begin{aligned}
& \overline{\mathrm{SACK}}, \overline{\mathrm{XACK}} \\
& \overline{\mathrm{OUT}}_{0}-\mathrm{OUT} \\
& \overline{\mathrm{AAS}}_{1} \\
& \overline{\mathrm{RAS}}_{4} \\
& \overline{\mathrm{WE}}
\end{aligned}
$$

$\mathrm{CL}=30 \mathrm{pF}$
$C L=160 \mathrm{pF}$
$C L=115 \mathrm{pF}$

Measurements made with respect to $\mathrm{RAS}_{1}-\mathrm{RAS}_{4}, \mathrm{CAS}$, $\mathrm{WE}, \mathrm{OUT}_{0}-\mathrm{OUT}_{6}$ are at 2.4 V and 0.8 V . All other pins are measured at 1.5 V .

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $t_{p}$ | Clock (Internal/External) Period (See Note 1) | 40 | 54 | ns |
| $\mathrm{t}_{\text {RC }}$ | Memory Cycle Time | $10 \mathrm{t}_{\mathrm{p}}-30$ | $12 \mathrm{t}_{\mathrm{p}}$ | ns |
| $\mathrm{t}_{\text {RAH }}$ | Row Address Hold Time | $t_{p}-10$ |  | ns |
| $\mathrm{t}_{\text {ASR }}$ | Row Address Setup Time | $\mathrm{t}_{\mathrm{PH}}$ |  | ns |
| ${ }_{\text {t }}$ | Column Address Hold Time | $5 \mathrm{tp}_{\mathrm{p}}$ |  | ns |
| ${ }_{\text {tasc }}$ | Column Address Setup Time | $t_{p}-35$ |  | ns |
| $t_{\text {tred }}$ | RAS to $\overline{\text { CAS }}$ Delay Time | $2 \mathrm{t}_{\mathrm{p}}-10$ | $2 \mathrm{t}_{\mathrm{p}}+30$ | ns |
| $t_{\text {wCs }}$ | $\overline{\text { WE Setup to CAS }}$ | $\mathrm{t}_{\mathrm{p}}-40$ |  | ns |
| $\mathrm{t}_{\text {RSH }}$ | $\overline{\text { RAS Hold Time }}$ | $5 \mathrm{t}_{\mathrm{p}}-30$ |  | ns |
| $\mathrm{t}_{\text {CAS }}$ | $\overline{\text { CAS Pulse Width }}$ | $5 \mathrm{tp}_{\mathrm{p}}$ |  | ns |
| $\mathrm{t}_{\text {RP }}$ | $\overline{\text { RAS }}$ Precharge Time (See Note 2) | $4 \mathrm{t}_{\mathrm{p}}-30$ |  | ns |
| ${ }_{\text {twCH }}$ |  | $5 \mathrm{t}_{\mathrm{p}}-20$ |  | ns |
| $\mathrm{t}_{\text {ref }}$ | Internally Generated Refresh to Refresh Time 64 Cycle 128 Cycle | $\begin{aligned} & 548 t_{p} \\ & 264 t_{p} \end{aligned}$ | $\begin{aligned} & 576 t_{p} \\ & 288 t_{p} \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| $t_{\text {cr }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ to $\overline{\mathrm{RAS}}$ Delay | $\mathrm{t}_{\mathrm{PH}}+30$ | $t_{\text {PH }}+t_{\text {p }}+75$ | ns |
| $\mathrm{t}_{\mathrm{CC}}$ | $\overline{\mathrm{RD}}$, $\overline{\text { WR }}$ to CAS Delay | $\mathrm{t}_{\mathrm{PH}}+2 \mathrm{t}_{\mathrm{P}}+25$ | $\mathrm{t}_{\mathrm{PH}}+3 \mathrm{t}_{\mathrm{p}}+85$ | ns |
| $\mathrm{t}_{\text {RFR }}$ | REFRQ to $\overline{\text { RAS }}$ Delay | $1.5 t_{p}+30$ | $2.5 \mathrm{t}_{\mathrm{p}}+100$ | ns |
| $\mathrm{t}_{\text {AS }}$ | $\mathrm{A}_{0}-\mathrm{A}_{15}$ to $\overline{\mathrm{RD}}, \overline{\mathrm{Wr}}$ Setup Time (See Note 4) | 0 |  | ns |
| $t_{\text {ca }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ to $\overline{\text { SACK }}$ Leading Edge |  | $\mathrm{t}_{\mathrm{p}}+40$ | ns |
| $\mathrm{t}_{\mathrm{CK}}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ to $\overline{\text { XACK, }}$, $\overline{\text { SACK }}$ Trailing Edge Delay |  | 30 | ns |
| $\mathrm{t}_{\mathrm{KCH}}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Inactive Hold to $\overline{\text { SACK }}$ Trailing Edge | 10 |  | ns |
| $\mathrm{tsc}_{\text {S }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PCS}}$ to X/CLK Setup Time (See Note 3) | 15 |  | ns |
| $\mathrm{t}_{\mathrm{Cx}}$ | $\overline{\text { CAS }}$ to XACK Time | $5 \mathrm{t}_{\mathrm{p}}-25$ | $5 \mathrm{t}+{ }^{\text {d }} 20$ | ns |
| $\mathrm{t}_{\text {ACK }}$ | $\overline{\text { XACK }}$ Leading Edge to $\overline{\text { CAS }}$ Trailing Edge Time | 10 |  | ns |
| ${ }_{\text {t }}{ }_{\text {w }}$ | XACK Pulse Width | $2 \mathrm{t}_{\mathrm{p}}-25$ |  | ns |
| $\mathrm{t}_{\text {LL }}$ | REFRQ Pulse Width | 20 |  | ns |
| $\mathrm{t}_{\mathrm{CHS}}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PCS}}$ Active Hold to $\overline{\mathrm{RAS}}$ | 0 |  | ns |
| $t_{\text {ww }}$ | $\overline{\mathrm{WR}}$ to $\overline{\mathrm{WE}}$ Propagation Delay | 8 | 50 | ns |
| $t_{\text {AL }}$ | $\mathrm{S}_{1}$ to ALE Setup Time | 40 |  | ns |
| $t_{\text {LA }}$ | $\mathrm{S}_{1}$ to ALE Hold Time | $2 \mathrm{t}_{\mathrm{p}}+40$ |  | ns |
| $t_{\text {PL }}$ | External Clock Low Time | 15 |  | ns |
| $\mathrm{t}_{\mathrm{PH}}$ | External Clock High Time | 20 |  | ns |
| $\mathrm{t}_{\mathrm{PH}}$ | External Clock High Time for $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ | 17 |  | ns |

## Notes:

1. tp minimum determines maximum oscillator frequency.
$t_{p}$ maximum determines minimum frequency to maintain 2 ms refresh rate and $t_{R P}$ minimum.
2. To achieve the minimum time between the $\overline{R A S}$ of a memory cycle and the $\overline{R A S}$ of a refresh cycle, such as a transparent refresh, REFRQ should be pulsed in the previous memory cycle.
3 . tSC is not required for proper operation which is in agreement with the other specs, but can be used to synchronize external signals with X/CLK if it is desired.
3. If $t_{A S}$ is less than 0 then the only impact is that $t_{A S R}$ decreases by a corresponding amount.

## 8202 TIMING

## NORMAL READ OR WRITE CYCLE



## REFRESH CYCLE



## ADVANCED READ MODE USING THE SIMPLIFIED 8085 INTERFACE OPTION



OTHER TIMING PARAMETERS ARE THE SAME AS NORMAL MODE WRITE CYCLE IS THE SAME AS NORMAL MODE EXCEPT THAT XACK AND S SACK GO INACTIVE ON THE RISING EDGE OF ALE

OUTPUT TEST LOAD CIRCUIT


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


## - Synchronous Baud Rate - DC to 64K Baud

- Asynchronous Baud Rate - DC to 19.2K 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

\author{

- Single +5V Supply
}


## - Single TTL Clock

The Intel ${ }^{\circledR}$ 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 NAMES

| $D, D_{0}$ | Data Bus (8 bits) |
| :--- | :--- |
| $C / D$ | Control or Data is to be Written or Read |
| $R \overline{R D}$ | Read Data Conimand |
| $\overline{W R}$ | Write Data or Control Command |
| $\overline{C S}$ | Chip Enable |
| $C L K$ | Clock Pulse (TTL) |
| RESET | Reset |
| $\overline{T \times C}$ | Transmitter Clock |
| $T \times D$ | Transmitter Data |
| $\overline{R \times C}$ | Receiver Clock |
| $R \times D$ | Receiver Data |
| $R \times R D Y$ | Receiver Ready (has character for 8080) |
| $T \times R D Y$ | Transmitter Ready (ready for char from 8080) |

BLOCK DIAGRAM


## FEATURES AND ENHANCEMENTS

8251A is an advanced design of the industry standard USART, the Intel ${ }^{\circledR}$ 8251. The 8251A operates with an extended range of Intel microprocessors that includes the new 8085 CPU and maintains compatibility with the 8251. Familiarization time is minimal because of compatibility and involves only knowing the additional features and enhancements, and reviewing the AC and DC specifications of the 8251A.

The 8251A incorporates all the key features of the 8251 and has the following additional features and enhancements:

- 8251A has double-buffered data paths with separate I/O registers for control, status, Data In, and Data Out, which considerably simplifies control programming and minimizes CPU overhead.
- In asynchronous operations, the Receiver detects and handles "break" automatically, relieving the CPU of this task.
- A refined Rx initialization prevents the Receiver from starting when in "break" state, preventing unwanted interrupts from a disconnected USART.
- At the conclusion of a transmission, TxD line will always return to the marking state unless SBRK is programmed.
- Tx Enable logic enhancement prevents a Tx Disable command from halting transmission until all data previously written has been transmitted. The logic also prevents the transmitter from turning off in the middle of a word.
- When External Sync Detect is programmed, Internal Sync Detect is disabled, and an External Sync Detect status is provided via a flip-flop which clears itself upon a status read.
- Possibility of false sync detect is minimized by ensuring that if double character sync is programmed, the characters be contiguously detected and also by clearing the Rx register to all ones whenever Enter Hunt command is issued in Sync mode.
- As long as the 8251 A is not selected, the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ do not affect the internal operation of the device.
- The 8251A Status can be read at any time but the status update will be inhibited during status read.
- The 8251A is free from extraneous glitches and has enhanced AC and DC characteristics, providing higher speed and better operating margins.
- Synchronous Baud rate from DC to 64 K .
- Fully compatible with Intel's new industry standard, the MCS-85.

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. When External SYNC Detect is programmed, the Internal SYNC Detect is disabled.

## BREAK DETECT (Async Mode Only)

This output will go high whenever the receiver remains low through two consecutive stop bit sequences (including the start bits, data bits, and parity bits). 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.


Figure 4. 8251A Interface to 8080 Standard System Bus

## DETAILED OPERATION DESCRIPTION

## General

The complete functional definition of the 8251 A 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 until the Tx Enable (Transmitter Enable) bit is set in the Command Instruction and it has received a Clear To Send (CTS) input. The TxD 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 8251A. 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.


Figure 5. Typical Data Block

## Synchronous Mode (Transmission)

The TxD output is continuously high until the CPU sends its first character to the 8251A which usually is a SYNC character. When the $\overline{\mathrm{CTS}}$ line goes low, the first character is serially transmitted out. All characters are shifted out on the falling edge of $\overline{T \times C}$. Data is shifted out at the same rate as the $\overline{T \times C}$.
Once transmission has started, the data stream at the $T \times D$ output must continue at the $\overline{\mathrm{TxC}}$ 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 8251A 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.


Figure 8. Mode Instruction Format, Synchronous Mode


RECEIVE FORMAT


Figure 9. Data Format, Synchronous Mode

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias. . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperatura . . . . . . . . . . . . . $-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 Mabsolute Maximum Ratings" may cause permanent damage fowthe device. This is a stress rating only and functional operay tion of the device at these or any other conditions above those indicated in the operational sections of this specifi** cation 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.2 | $\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.45V |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 100 | mA | All Outputs $=$ High |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{C}}=\mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathbb{I}}$ | 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 |

$\qquad$


Figure 16. Test Load Circuit


Figure 17. Typical $\Delta$ Output Delay vs. $\Delta$ Capacitance (pF)

## 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 | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A R}$ | Address Stable Before $\overline{\operatorname{READ}}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | 50 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RA}}$ | Address Hold Time for $\overline{\mathrm{READ}}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | 50 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\text { READ Pulse Width }}$ | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Delay from $\overline{\mathrm{READ}}$ |  | 250 | ns | $3, C_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | $\overline{\mathrm{READ}}$ to Data Floating | 10 | 100 | ns |  |

## Write Cycle:

| PYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A W}$ | Address Stable Before $\overline{W R I T E}$ | 50 |  | ns |  |
| $\mathrm{t}_{\text {WA }}$ | Address Hold Time for $\overline{\text { WRITE }}$ | 50 |  | ns |  |
| $\mathrm{t}_{\text {WW }}$ | $\overline{\text { 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 }}$ | 30 |  | ns |  |
| $\mathrm{t}_{\text {RV }}$ | Recovery Time Between WRITES | 6 |  | $\mathrm{t}_{\mathrm{CY}}$ | Note 4 |

NOTES: 1. AC timings measured $\mathrm{V}_{\mathrm{OH}}=2.0, \mathrm{VOL}_{\mathrm{OL}}=0.8$, and with load circuit of Figure 1.
2. Chip Select ( $\overline{\mathrm{CS}}$ ) and Command/Data (C/ $\overline{\mathrm{D}}$ ) are considered as Addresses.
3. Assumes that Address is valid before $\overline{R_{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}} \mathrm{CY}$ and for Synchronous Mode is $16 \mathrm{t}_{\mathrm{CY}} \mathrm{Y}$.

## Input Waveforms for AC Tests



Other Timings:

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |

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{ }^{\mathrm{t}} \mathrm{C} Y$ 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.

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



## 8253/8253-5 <br> PROGRAMMABLE INTERVAL TIMER

- MCS-85 ${ }^{\text {TM }}$ Compatible 8253-5
- 3 Independent 16-Bit Counters
- DC to 2 MHz
- Programmable Counter Modes
- Count Binary or BCD
- Single + 5V Supply
- 24-Pin Dual In-Line Package

The Intel ${ }^{(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 3 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} \cdot D_{0}$ | DATA BUS (8-BIT) |
| :--- | :--- |
| CLKN | COUNTER CLOCK INPUTS |
| GATEN | COUNTER GATE INPUTS |
| OUT $N$ | COUNTER OUTPUTS |
| $R \bar{D}$ | READ COUNTER |
| WR | WRITE COMMAND OR DATA |
| $C S$ | CHIP SELECT |
| $A_{0} \cdot A_{1}$ | COUNTER SELECT |
| $V_{C C}$ | +5 VOLTS |
| GND | GROUND |

BLOCK DIAGRAM


## 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{\text { RD }}$ (Read)

A "low" on this input informs the 8253 that the CPU is inputting data in the form of a counters value.

## $\overline{\text { 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.


Figure 1. Block Diagram Showing Data Bus Buffer and Read/Write Logic Functions

| $\overline{\mathbf{C S}}$ | $\overline{\mathrm{RD}}$ | $\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 {Tw }}$ 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{C S}$ 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.


Figure 2. Block Diagram Showing Control Word Register and Counter Functions


Figure 3. 8253 System Interface

## 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 $\mathbf{8 2 5 3}$

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}_{\mathbf{3}}$ | $\mathrm{D}_{\mathbf{2}}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{\mathbf{0}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC 1 | $\mathrm{SC0}$ | RL 1 | RLO | M 2 | M 1 | M 0 | BCD |

## Definition of Control

SC - Select Counter:
SC1
SCO

| 0 | 0 | Select Counter 0 |
| :--- | :--- | :--- |
| 0 | 1 | Select Counter 1 |
| 1 | 0 | Select Counter 2 |
| 1 | 1 | Illegal |

RL - Read/Load:
RL1

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

## Counter Loading

The count register is not loaded until the count value is written (one or two bytes, depending on the mode selected by the RL bits), followed by a rising edge and a falling edge of the clock. Any read of the counter prior to that falling clock edge may yield invalid data.

## 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 or a new count is loaded. The counter continues to decrement after terminal count has been reached.
Rewriting a counter register during counting results in the following:
(1) Write 1st byte stops the current counting.
(2) Write 2nd byte starts the new count.

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. This is accomplished by decrementing the counter by two on the falling edge of each clock pulse. When the counter reaches terminal count, the state of the output is changed and the counter is reloaded with the full count and the whole process is repeated.
If the count is odd and the output is high, the first clock pulse (after the count is loaded) decrements the count by 1 . Subsequent clock pulses decrement the clock by 2. After timeout, the output goes low and the full count is reloaded. The first clock pulse (following the reload) decrements the counter by 3 . Subsequent clock pulses decrement the count by 2 until timeout. Then the whole process is repeated. In this way, if the count is odd, the output will be high for $(N+1) / 2$ counts and low for ( $\mathrm{N}-1$ )/2 counts.

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.

| Modes | Signal <br> Status | Low <br> Or Going <br> Low | Rising |
| :---: | :---: | :---: | :---: |

Figure 4. Gate Pin Operations Summary

MODE 0: Interrupt on Terminal Count


MODE 1: Programmable One-Shot


MODE 2: Rate Generator


MODE 3: Square Wave Generator


MODE 4: Software Triggered Strobe



MODE 5: Hardware Triggered Strobe


gate
OUTPUT ( $n=4$ )


Figure 5. 8253 Timing Diagrams

## 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 (RLO, RL1) are programmed. Then proceed with the restart operation.

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

Figure 6. Programming Format

| 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 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 | MSBCount Register Byte <br> Counter 2 |  | 1 | 0 |
| No. 8 | LSB | Count Register Byte Counter 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.

Figure 7. Alternate Programming Formats

## 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 contents 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. This command has no effect on the counter's mode.


[^18]Figure 8. MCS-85 ${ }^{\text {TM }}$ Clock 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
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 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 $\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 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\text {IH }}$ | Input High Voltage | 2.2 | $\mathrm{~V}_{\mathrm{CC}}+.5 \mathrm{~V}$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | Note 1 |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | Note 2 |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ to 0V |
| $\mathrm{I}_{\mathrm{OFL}}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}}$ to 0V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 140 | mA |  |

Note 1: $8253, \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} ; 8253-5, \mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$.
Note 2: $8253, \mathrm{I}_{\mathrm{OH}}=-150 \mu \mathrm{~A} ; 8253-5, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.

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 $\mathrm{V}_{\mathrm{SS}}$ |

A.C. CHARACTERISTICS $\quad 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. |  |
| $t_{\text {AR }}$ | Address Stable Before $\overline{\mathrm{READ}}$ | 50 |  | 30 |  | ns |
| $t_{\text {RA }}$ | Address Hold Time for $\overline{\text { READ }}$ | 5 |  | 5 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\text { READ Pulse Width }}$ | 400 |  | 300 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Delay From $\overline{R E A D}{ }^{21}$ |  | 300 |  | 200 | ns |
| ${ }^{\text {t }}$ D | $\overline{\mathrm{READ}}$ to Data Floating | 25 | 125 | 25 | 100 | ns |
| $t_{\text {RV }}$ | Recovery Time Between READ and Any Other Control Signal | 1 |  | 1 |  | $\mu \mathrm{s}$ |

Write Cycle:

| SYMBOL | PARAMETER | 8253 |  | 8253-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| ${ }^{\text {A }}$ W | Address Stable Before $\overline{\text { WRITE }}$ | 50 |  | 30 |  | ns |
| twa | Address Hold Time for WRITE | 30 |  | 30 |  | ns |
| ${ }^{\text {tww }}$ | $\overline{\text { WRITE Pulse Width }}$ | 400 |  | 300 |  | ns |
| $t_{\text {DW }}$ | Data Set Up Time for $\overline{\text { WRITE }}$ | 300 |  | 250 |  | ns |
| $t_{\text {w }}$ | Data Hold Time for WRITE | 40 |  | 30 |  | ns |
| $t_{R V}$ | Recovery Time Between WRITE and Any Other Control Signal | 1 |  | 1 |  | $\mu \mathrm{s}$ |

Notes: 1. AC timings measured at $\mathrm{V}_{\mathrm{OH}}=2.2, \mathrm{~V}_{\mathrm{OL}}=0.8$
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:



## Clock and Gate Timing:

| SYMBOL | PARAMETER | 8253 |  | 8253-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| ${ }^{\text {t CLK }}$ | Clock Period | 380 | dc | 380 | dc | ns |
| $\mathrm{t}_{\text {PWH }}$ | High Pulse Width | 230 |  | 230 |  | ns |
| $\mathrm{t}_{\text {PWL }}$ | Low Pulse Width | 150 |  | 150 |  | ns |
| $\mathrm{t}_{\mathrm{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 |
| ${ }_{\text {t }}^{\text {G }}$ H | Gate Hold Time After CLK $\uparrow$ | 50 |  | 50 |  | ns |
| ${ }^{\text {tod }}$ | Output Delay From CLK $\downarrow^{[1]}$ |  | 400 |  | 400 | ns |
| todg | Output Delay From Gate ${ }^{[1]}$ |  | 300 |  | 300 | ns |

Note 1: Test Conditions: 8253: $C_{L}=100 p F ; 8253-5: C_{L}=150 p F$.


## 8255A/8255A-5 PROGRAMMABLE PERIPHERAL INTERFACE

- MCS. $85^{\text {TM }}$ Compatible 8255A. 5

24 Programmable I/O Pins

- Completely TTL Compatible
- Fully Compatible with Intel ${ }^{\circledR}$ Microprocessor Families
- Improved Timing Characteristics
- Direct Bit Set/Reset Capability Easing Control Application Interface
- 40-Pin Dual In-Line Package
- Reduces System Package Count
- Improved DC Driving Capability

The Intel® ${ }^{\circledR}$ 8255A is a general purpose programmable I/O device designed for use with Intel ${ }^{\circledR}$ microprocessors. It has 24 I/O pins which may be individually programmed in 2 groups of 12 and used in 3 major modes of operation. In the first mode (MODE 0 ), each group of 12 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 4 pins, 3 are used for handshaking and interrupt control signals. The third mode of operation (MODE 2) is a bidirectional bus mode which uses 8 lines for a bidirectional bus, and 5 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{W R}$ | WRITE INPUT |
| $A 0, A 1$ | PORT ADDRESS |
| PA7-PAO | PORT A (BIT) |
| PB7.PBO | PORT B (BIT) |
| PC7.PCO | PORT C (BIT) |
| VCC | +5 VOLTS |
| GND | OVOLTS |

8255A BLOCK DIAGRAM


## 8255A FUNCTIONAL DESCRIPTION

## General

The 8255A is a programmable peripheral interface (PPI) device designed for use in Intel ${ }^{\circledR}$ 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 A 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 bidirectional 8 -bit buffer is used to interface the 8255A 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 communiction between the 8255A and the CPU.

## (RD)

Read. A "low" on this input pin enables the 8255A to send the data or status information to the CPU on the data bus. In essence, it allows the CPU to "read from" the 8255A.

## (WR)

Write. A "low" on this input pin enables the CPU to write data or control words into the 8255A.

## ( $A_{0}$ and $A_{1}$ )

Port Select 0 and Port Select 1. These input signals, in conjunction with the RD and WR inputs, control the selection of one of the three ports or the control word registers. They are normally connected to the least significant bits of the address bus ( $A_{0}$ and $A_{1}$ ).

8255A BASIC OPERATION

| $\mathbf{A}_{1}$ | $A_{0}$ | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{WR}}$ | $\overline{\mathrm{CS}}$ | 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 $\mathrm{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 |



Figure 1. 8255A Block Diagram Showing Data Bus Buffer and Read/Write Control Logic Functions

## (RESET)

Reset. A "high on this input clears the control register and all ports (A, C, 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 8255A. 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 8255A contains three 8 -bit ports (A, 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 8255A.

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 4-bit 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 .


PIN CONFIGURATION


PIN NAMES

| $D_{7} \cdots D_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| RESET | RESET INPUT |
| $\overline{C S}$ | CHIP SELECT |
| $\overline{R D}$ | READ INPUT |
| $\overline{W R}$ | WRITE INPUT |
| $A 0, A 1$ | PORT ADDRESS |
| PA7-PAO | PORT A (BIT) |
| PB7.PB0 | PORT B (BIT) |
| PC7.PC0 | PORT C (BIT) |
| VCC | +5 VOLTS |
| GND | $\square$ VOLTS |

Figure 2. 8225A Block Diagram Showing Group A and Group B Control Functions

## 8255A 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 8255A 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 8255A to service a variety of peripheral devices with a simple software maintenance routine.
ule.
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.


Figure 3. Basic Mode Definitions and Bus Interface


Figure 4. 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 I/O approach will surface. The design of the 8255A 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.


Figure 5. 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 8255A 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 flipflop, 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 (Basic Output)

## MODE 0 Port Definition

| A |  | B |  | GROUP A |  |  | GROUP B |  |
| :---: | :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{D}_{\mathbf{4}}$ | $\mathrm{D}_{\mathbf{3}}$ | $\mathrm{D}_{\mathbf{1}}$ | $\mathrm{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 \#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 \#8

| $\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 | 0 |



CONTROL WORD \#9

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |



CONTROL WORD \#10

| $\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 | 0 |



CONTROL WORD \#7

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 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


CONTROL WORD \#13

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 |



CONTROL WORD \#15

| $\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 | 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

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}$.


Figure 6. MODE 1 Input


Figure 7. MODE 1 (Strobed Input)

## Output Control Signal Definition

$\overline{\text { OBF (Output Buffer Full F/F). The OBF 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 ACK Input being low.
$\overline{\text { ACK }}$ (Acknowledge Input). A "low" on this input informs the 8255A 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 ACK is a "one", OBF is a "one" and INTE is a "one". It is reset by the falling edge of WR.

## INTE A

Controlled by bit set/reset of $\mathrm{PC}_{6}$.
INTE B
Controlled by bit set/reset of $\mathrm{PC}_{2}$.


Figure 8. MODE 1 Output


Figure 9. 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.


Figure 10. Combinations of MODE 1

## Operating Modes

MODE 2 (Strobed Bidirectional 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 (bidirectional 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).


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

OBF (Output Buffer Ful). The OBF output will go "low" to indicate that the CPU has written data out to port A.

ACK (Acknowledge). 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 OBF). Controlled by bit set/reset of $\mathrm{PC}_{6}$.


## Input Operations

## $\overline{\text { STB }}$ (Strobe Input)

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}$.

## CONTROL WORD



Figure 11. MODE Control Word


Figure 12. MODE 2


Figure 13. MODE 2 (Bidirectional)

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 1 (OUTPUT)


MODE 2 AND MODE 0 (OUTPUT)


MODE 2 AND MODE 1 (INPUT)


Figure 14. MODE 2 Combinations

## Mode Definition Summary

|  | MODE 0 |  |
| :---: | :---: | :---: |
|  | IN | OUT |
| $\mathrm{PA}_{0}$ | IN | OUT |
| $\mathrm{PA}_{1}$ | IN | OUT |
| $P A_{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}_{B}$ | ${ }^{\text {INTR }}$ B |
| $\mathrm{IBF}_{\mathrm{B}}$ | $\overline{\mathrm{OBF}}_{\mathrm{B}}$ |
| $\overline{S T B}_{B}$ | $\overline{\mathrm{ACK}}_{\mathrm{B}}$ |
| $\mathrm{INTR}_{\text {A }}$ | $\mathrm{INTR}_{\text {A }}$ |
| $\overline{S T B}_{A}$ | I/O |
| $\mathrm{IBF}_{\text {A }}$ | I/O |
| 1/O | $\overline{\text { ACK }}_{\text {A }}$ |
| 1/0 | $\overline{\mathrm{OBF}}_{\mathrm{A}}$ |



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


Figure 15. MODE 1 Status Word Format


Figure 16. MODE 2 Status Word Format

## APPLICATIONS OF THE 8255A

The 8255A 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 8255A is programmed by the I/O service routine and becomes an extension of the system 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 8255A to exactly "fit" the application. Figures 17 through 23 present a few examples of typical applications of the 8255A.


Figure 17. Printer Interface


Figure 18. Keyboard and Display Interface


Figure 19. Keyboard and Terminal Address Interface


Figure 20. Digital to Analog, Analog to Digital


Figure 21. Basic CRT Controller 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
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 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 \% ; \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}}$ (DB) | Output Low Voltage (Data Bus) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ (PER) | Output Low Voltage (Peripheral Port) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.7 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ (DB) | Output High Voltage (Data Bus) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ (PER) | Output High Voltage (Peripheral Port) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{DAR}}{ }^{11]}$ | 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

$\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}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to GND |


${ }^{*} \mathrm{~V}_{\text {EXT }}$ is set at various voltages during testing to guarantee the specification.

Figure 24. Test Load Circuit (for dB)

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

| SYMBOL | PARAMETER | 8255A |  | 8255A.5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MiN. | MAX.: |  |
| ${ }^{\text {AR }}$ | Address Stable Before READ | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | Address Stable After READ | 0 |  | 0 |  | ns |
| $t_{\text {RR }}$ | READ Pulse Width | 300 |  | 300 | \% | ns |
| trD | Data Valid From READ ${ }^{\text {[1] }}$ |  | 250 |  | 200 | ns |
| $\mathrm{t}_{\mathrm{DF}}$ | Data Float After READ | 10 | 150 | 10 | -100 | ns |
| tr V | Time Between READs and/or WRITEs | 850 |  | . 850 |  | ns |

## Write:

| SYMBOL | PARAMETER | 8255A |  | 8255A-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MiN. | MAX. |  |
| $\mathrm{t}_{\text {AW }}$ | Address Stable Before WRITE | 0 |  | 0 | $4$ | ns |
| twa | Address Stable After WRITE | 20 |  | 20 | $\sqrt{51}$ | ns |
| ${ }^{\text {tww }}$ | WRITE Pulse Width | 400 |  | 300 |  | ns |
| t ${ }_{\text {DW }}$ | Data Valid to WRITE (T.E.) | 100 |  | 100 | ( | ns |
| tWD | Data Valid After WRITE | 30 |  | 30 | $4$ | ns |

## Other Timings:

| SYMBOL | PARAMETER | 8255A |  | - 82554.5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. | MIN. | MAX. |  |
| $t_{\text {WB }}$ | WR = 1 to Output ${ }^{[1]}$ |  | 350 | $4$ | 350 . | ns |
| $\mathrm{t}_{\text {IR }}$ | Peripheral Data Before RD | 0 |  | - 0 . | $4 .$ | ns |
| $t_{\text {HR }}$ | Peripheral Data After RD | 0 |  | 0 \% | , | ns |
| ${ }_{\text {t }}^{\text {AK }}$ | ACK Pulse Width | 300 |  | 300 |  | ns |
| ${ }_{\text {t }}^{\text {ST }}$ | STB Pulse Width | 500 |  | 500 | - 5 | ns |
| tPS | Per. Data Before T.E. of STB | 0 |  | 0 | $\sqrt[3]{4}$ | ns |
| tPH | Per. Data After T.E. of STB | 180 |  | 180 |  | ns |
| tad | ACK $=0$ to Output ${ }^{[1]}$ |  | 300 |  | 300 | ns |
| $\mathrm{t}_{\mathrm{KD}}$ | ACK = 1 to Output Float | 20 | 250 | - 20 | - 250 | ns |
| ${ }^{\text {twob }}$ | $W \mathrm{~W}=1$ to $\mathrm{OBF}=0^{[1]}$ |  | 650 |  | , 650 | ns |
| ${ }^{\text {t }}$ AOB | $\mathrm{ACK}=0$ to $\mathrm{OBF}=1^{[1]}$ |  | 350 |  | 350 | ns |
| ${ }_{\text {t }}{ }^{\text {I }}$ | $\mathrm{STB}=0$ to $\mathrm{IBF}=1^{[1]}$ |  | 300 | $5$ | 300 | ns |
| $\mathrm{t}_{\text {RIB }}$ | $\mathrm{RD}=1$ to $\mathrm{IBF}=0^{[1]}$ |  | 300 | 4. | 300 | ns |
| $t_{\text {RIT }}$ | $\mathrm{RD}=0$ to $\mathrm{INTR}=0^{[1]}$ |  | 400 | 4. | 400 | ns |
| ${ }_{\text {t }}^{\text {IT }}$ | STB $=1$ to $\mathrm{INTR}=1^{[1]}$ |  | 300 | \% | + 300 | ns |
| ${ }^{\text {taIT }}$ | $\mathrm{ACK}=1$ to $\mathrm{INTR}=1^{[1]}$ |  | 350 |  | - 350 | ns |
| ${ }^{\text {twIT }}$ | WR $=0$ to $\mathrm{INTR}=0^{[1]}$ |  | 850 | $4$ | - 850 | ns |

Notes: 1. Test Conditions: 8255A: $C_{L}=100 \mathrm{pF}$; 8255A-5: $C_{L}=150 \mathrm{pF}$.
2. Period of Reset pulse must be at least $50 \mu$ s during or after power on. Subsequent Reset pulse can be 500 ns min.


Figure 25. Input Waveforms for A.C. Tests


Figure 26. MODE 0 (Basic Input)


Figure 27. MODE 0 (Basic Output)


Figure 28. MODE 1 (Strobed Inut)


Figure 29. MODE 1 (Strobed Output)


Figure 30. MODE 2 (Bidirectional)

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{\mathrm{STB}} \cdot \overline{\mathrm{RD}}+\overline{\mathrm{OBF}} \cdot \overline{\mathrm{MASK}} \cdot \overline{\mathrm{ACK}} \cdot \overline{\mathrm{WR}})$

# PROGRAMMABLE FLOPPY DISK CONTROLLER 

\author{

- 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
}
- Internal CRC Generation and Checking
- Programmable Step Rate, Settle-Time, Head Load Time, Head Unload Index Count
- Fully MCS-80 and MCS-85 Compatible
- Single + 5V Supply
- 40-Pin Package

The Intel ${ }^{\oplus} 8271$ Programmable Floppy Disk Controller (FDC) is an LSI component designed to interface one to 4 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.

BLOCK DIAGRAM

PIN CONFIGURATION


PIN NAMES

| D87-080 | data bus (Bi directional) | PLo/ss | plodingles |
| :---: | :---: | :---: | :---: |
|  | clockinput (ttl) | OATA WINDOW | data window |
| select 1.0 | SELECT 1.0 | UnSEP data | UNSEPARATED DATA |
| fault reset/opo | fault reset/optional output | FAULT | fault |
| Reset | CHIP RESET | wr data | white data |
|  | READY 1,0 | COUNT/OPT | COUNT/OPTIONAL InPUT |
| OACR | OMA ACKNOWLEDGE | TRKO | track o |
| DRO | DTAA REQUEST | WR PROTEC | WRITE PROTECT |
| $\stackrel{\text { M0 }}{\text { Ma }}$ | CPP READ INPUT | TNDEX | INDEX |
| W/ | CPU WRITE INPUT | wr enable | write enable |
| INT | interrupt | SEEK/STEP | seekistep |
| $\mathrm{A}_{1} \mathrm{O}$ | Register select | DIRECTION | direction |
|  | READ DATA INSYNC | LOAD HEAD | LOAD HEAD |
| cs | Chip SELECT | low current | Low Current |

## 8271 BASIC FUNCTIONAL DESCRIPTION

## General

The 8271 Floppy Disk Controller (FDC) interfaces either two single or one dual floppy drive to an eight bit microprocessor and is fully compatible with Intel's new high performance MCS-85 microcomputer system. With minimum external circuitry, this innovative controller supports most standard, commonly-available flexible disk drives including the mini-floppy.
The 8271 FDC supports a comprehensive soft sectored format which is IBM 3740 compatible and includes provision for the designating and handling of bad tracks. It 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 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 instructs the FDC to search for that pattern on a track. Any application that is required to search the disk for information (such as point of sale price lookup, disk directory search, etc.), 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 | Pin <br> No. | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| $V_{c c}$ | (40) |  | +5V supply |
| GND | (20) |  | Ground |
| Clock | (3) | 1 | A square wave clock |
| Reset | (4) | 1 | A high signal on the reset input forces the 8271 to an idle state. The 8271 remains idle until a command is issued by the CPU. The output signals of the drive interface are forced inactive (LOW). Reset must be active for 10 or more clock cycles. |
| $\overline{\mathrm{CS}}$ | (24) | 1 | The I/O Read and I/O Write inputs are enabled by the chip select signal. |
| $\mathrm{DB}_{7}-\mathrm{DB}_{0}$ | (19-12) | I/O | The Data Bus lines are bidirectional, three-state lines ( 8080 data bus compatible). |
| $\overline{W R}$ | (10) | 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}}$ | (9) | 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 | (11) | 0 | The interrupt signal indicates that the 8271 requires service. |


| Pin Name | Pin <br> No. | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| $A_{1}-A_{0}$ | (22-21) | 1 | These two lines are CPU Interface Register select lines. |
| DRQ | (8) | 0 | The DMA request signal is used to request a transfer of data between the 8271 and memory. |
| $\overline{\text { DACK }}$ | (7) | 1 | The DMA acknowledge signal notifies the 8271 that a DMA cycle has been granted. For non-DMA transfers, this signal should be driven in the manner of a "Chip Select". |
| Select 1- <br> Select 0 | $\begin{aligned} & \text { (6) } \\ & \text { (2) } \end{aligned}$ | 0 | These lines are used to specify the selected drive. These lines are set by the command byte. |
| Fault Reset OPO |  | 0 | The optional fault reset output line is used to reset an error condition which is latched by the drive. If this line is not used for a fault reset it can be used as an optional output line. This line is set with the write special register command. |
| Write Enable | (35) | 0 | This signal enables the drive write logic. |
| Seek/Step | (36) | 0 | This multi-function line is used during drive seeks. |
| Direction | (37) | 0 | The direction line specifies the seek direction. A high level on this pin steps the R/W head toward the spindle (step-in), a low level steps the head away from the spindle (step-out). |
| Load Head | (38) | 0 | The load head line causes the drive to load the Read/Write head against the diskette. |
| Low Current | (39) | 0 | This line notifies the drive that track 43 or greater is selected. |
| $\begin{aligned} & \overline{\text { Ready } 1,} \\ & \overline{\text { Ready } 0} \end{aligned}$ | $\begin{gathered} (5) \\ (32) \end{gathered}$ | 1 | These two lines indicate that the specified drive is ready. |
| $\overline{\text { Fault }}$ | (28) | 1 | This line is used by the drive to specity a file unsafe condition. |
| $\overline{\text { Count/OPI }}$ | (30) | 1 | If the optional seek/direction/ count seek mode is selected, the count pin receives pulses to step the R/W head to the desired track. Otherwise, this line can be used as an optional input. |

$\overline{\text { Write Protect (33) } 1 \text { This signal specifies that the }}$ diskette inserted is write protected.
$\overline{\text { TRKO }}$ (31) I This signal indicates when the R/W head is positioned over track zero.
Index (34) 1 The index signal gives an indication of the relative position of the diskette.

PLO/SS (25) I This pin is used to specify the type of data separator used. PhaseLocked Oscillator/Single Shot.

[^19]| Pin <br> Name | Pin <br> No. | V/O | Description |
| :---: | :---: | :---: | :---: |

Unseparated (27) I This input is the unseparated data $\overline{\text { Data }}$
$\overline{\text { Data Window (26) }}$ | This is a data window established by a single-shot or phase-locked oscillator data separator.

INSYNC (23) $O$ This line is high when 8271 has attained input data synchronization, by detecting 2 bytes of zeros followed by an expected Address Mark. It will stay high until the end of the ID or data field.

## CPU Interface Description

This interface minimizes CPU involvement by supporting a set of high level commands and both DMA and non-DMA type data transfers and by providing hierarchical status information regarding the result of command execution.

The CPU utilizes the control interface (see the Block diagram) to specify the FDC commands and to determine the result of an executed command. This interface is supported by five Registers which are addressed by the CPU via the $A_{1}, A_{0}, \overline{R D}$ and $\overline{W R}$ signals. If an 8080 based system is used, the $\overline{R D}$ and $\overline{W R}$ signals can be driven by the 8228's $\overline{/ / O R}$ and $\overline{1 / O W}$ signals. The registers are defined as follows:

## Command Register

The CPU loads an appropriate command into the Command Register which has the following format:


## Parameter Register

Accepts parameters of commands that require further description; up to five parameters may be required, example:


## Result Register



The Result Register is used to supply the outcome of FDC command execution (such as a good/bad completion) ito the CPU. The standard Result byte format is:


Figure 1. 8271 Block Diagram Showing CPU Interface Functions

## Status Register

Reflects the state of the FDC.


## Reset Register

Allows the 8271 to be reset by the program. Reset must be active for 11 or more chip clocks.

## INT (Interrupt Line)

Another element of the control interface is the Interrupt line (INT). This line is used to signal the CPU that an FDC operation has been completed. It remains active until the result register is read.

## DMA Operation

The 8271 can transfer data in either DMA or non DMA mode. The data transfer rate of a floppy disk drive is high enough (one byte every 32 usec ) to justify DMA transfer. In DMA mode the elements of the DMA interface are:

## DRQ: DMA Request:

The DMA request signal is used to request a transfer of data between the 8271 and memory.
$\overline{\text { DACK: DMA Acknowledge: }}$
The DMA acknowledge signal notifies the 8271 that a DMA cycle has been granted.

## RD, WR: Read, Write

The read and write signals are used to specify the direction of the data transfer.
DMA transfers require the use of a DMA controller such as the Intel ${ }^{\circledR} 8257$. The function of the DMA controller is to provide sequential addresses and timing for the transfer at a starting address determined by the CPU. Counting of data block lengths is performed by the FDC.
To request a DMA transfer, the FDC raises DRQ. DACK and RD enable DMA data onto the bus (independently of CHIP SELECT). DACK and WR transfer DMA data to the FDC. If a data transfer request (read or write) is not serviced within $31 \mu \mathrm{sec}$, the command is cancelled, a late DMA status is set, and an interrupt is generated. In DMA mode, an interrupt is generated at the completion of the data block transfer.

When configured to transfer data in non-DMA mode, the CPU must pass data to the FDC in response to the nonDMA data requests indicated by the status word. The data is passed to and from the chip by asserting the DACK and the RD or WR signals. Chip select should be inactive (HIGH).


Figure 2. 8271 Block Diagram Showing Disk Interface Functions

## Disk Drive Interface

The 8271 disk drive interface supports the high level command structure described in the Command Descrip tion section. The 8271 maintains the location of badtracks and the current track location for two drives. However, with minor software support, this interface can support four drives by expanding the two drive select lines (select 0 , select 1 ) with the addition of minimal support hardware.

The FDC Disk Drive Interface has the following major functions.

## READ FUNCTIONS

Utilize the user supplied data window to obtain the clock and data patterns from the unseparated read data.
Establish byte synchronization.
Compute and verify the ID and data field CRCs.

## WRITE FUNCTIONS

Encode composite write data.
Compute the ID and data field CRCs and append them to their respective fields.

## CONTROL FUNCTIONS

Generate the programmed step rate, head load time, head settling time, head unload delay, and monitor drive functions.


NOTE: INPUTS TO CHIP MAY REQUIRE RECEIVERS (AT LEAST PULL UP/DOWN PAIRS)

Figure 3. 8271 Disk Drive Interface

## Data Separation

The 8271 needs only a data window to separate the data from the composite read data as well as to detect missing clocks in the Address Marks.

The window generation logic may be implemented using either a single-shot separator or a phase-locked oscillator.

## Single-Shot Separator

The single-shot separator approach is the lowest cost solution.

The FDC samples the value of Data Window on the leading edge of Unseparated Data and determines whether the delay from the previous pulse was a half or full bit-cell (high input $=$ full bit-cell, low input $=$ half bit-cell). PLO/SS should be tied to Ground.

## Insync Pin

This pin gives an indication of whether the 8271 is synchronized with the serial data stream during read operations. This pin can be used with a phaselocked oscillator for soft and hard locking.


Figure 4. Insync Waveform

*FOR MINI-FLOPPY DATA WINDOW $=5.7 \mu \mathrm{sec}$

Figure 5. Single-Shot Data Separator Block Diagram


Figure 6. Single-Shot Data Window Timing

## Phase-Locked Oscillator Separator

The FDC samples the value of Data Window on the leading edge of Unseparated Data and determines whether the pulse represents a Clock or Data Pulse.

Insync may be used to provide soft and hard locking control for the phase-locked oscillator.

PLO/SS should be tied to $\mathrm{VCC}(+5 \mathrm{~V})$.

*OPTIONAL
Figure 7. PLO Data Separator Block Diagram

*DATA WINDOW MAY BE $180^{\circ}$ OUT OF PHASE IN PLO DATA SEPARATION MODE.
Figure 8. PLO Data Window Timing

## Disk Drive Control Interface

The disk drive control interface performs the high level and programmable flexible disk drive operations. It custom tailors many varied drive performance parameters such as the step rate, settling time, head load time, and head unload index count. The following is the description of the control interface.

## Write Enable

The Write Enable controls the read and write functions of a flexible disk drive. When Write Enable is a logical one, it enables the drive write electronics to pass current through the Read/Write head. When Write Enable is a logical zero, the drive Write circuitry is disabled and the Read/Write head detects the magnetic flux transitions recorded on a diskette. The write current turn-on is as follows.


$$
1 \mu \mathrm{~s} \leqslant \mathrm{t}_{\mathrm{WE}} \leqslant 3 \mu \mathrm{~s}
$$

Figure 9. Write Enable Timing

## Seek Control

Seek Control is accomplished by Seek/Step, Direction, and Count pins and can be implemented two ways to provide maximum flexibility in the subsystem design. One instance is when the programmed step rate is not equal to zero. In this case, the 8271 uses the Seek/Step and Direction pins (the Seek/Step pin becomes a Step pin). Programmable Step timing parameters are shown.
Another instance is when the programmable step rate is equal to zero, in which case the 8271 holds the seek line high until the appropriate number of user-supplied step pulses have been counted on the count input pin.

The Direction pin is a control level îndicating the direction in which the R/W head is stepped. Alogichigh levelon this line moves the head toward the spindle (step-in). Alogic low level moves the head away from the spinde (step-out)


Figure 10. Seek Timing


Figure 11. Seek/Step/Count Timing

## Head Seek Settling Time

The 8271 allows the head settling time to be programmed from 0 to 255 ms , in increments of 1 ms .

The head settling time is defined as the interval of time from completion of the last step to the time when reading or writing on the diskette is possible (R/W Enable). The R/W head is assumed loaded.


Figure 12. Head Load Settling Timing

## Load Head

When active, load head output pin causes the drive's read/write head to be loaded on the diskette. When the head is initially loaded, there is a programmed delay ( 0 to 60 ms in 4 ms increments) prior to any read or write operation. Provision is also made to unload the head following an operation within a programmed number of diskette revolutions.


Figure 13. Head Load to Read/Write Timing

## Index

The Index input is used to determine "Sector not found" status and to initiate format track/read ID commands and head unload Index and Count operations.


Figure 14. Index Timing

## Track 0

This input pin indicates that the diskette is at track 0. During any seek operation, the stepping out of the actuator ceases when the track 0 pin becomes active.

## Select 1, 0

Only one drive may be selected at a time. The Input/Output pins that must be externally qualified with Select 0 and Select 1 are:

```
Unseparated Data
Data Window
Write Enable
Seek/Step
Count/Optional Input
Load Head
Track 0
Low Current
Write Protect
Write Fault
Fault Reset/Optional Output
Index
```

When a new set of select bits is specified by a new command or the FDC finishes the index count before head unload, the following pins will be set to the 0 state:

Write Enable (35)
Seek/Step (36)
Direction (37)
Load Head (38)
Low Head Current (39)
The select pins will be set to the state specified by the command or both are set to zero following the index count before head unload.

## Low Current

This output pin is active whenever the physical track location of the selected drive is greater than 43. Generally
this signal is used to enable compensation for the lower velocities encountered while recording on the inner tracks.

## Write Protect

The 8271 will not write to a disk when this input pin is active and will interrupt the CPU if a Write attempt is made. Operations which check Write Protect are aborted if the Write Protect line is active.

This signal normally originates from a sensor which detects the presence or absence of the Write Protect hole in the diskette jacket.

## Write Fault and Write Fault Reset

The Write Fault input is normally latched by the drive and indicates any condition which could endanger data integrity. The 8271 interrupts the CPU anytime Write Fault is detected during an operation and immediately resets the Write Enable, Seek/Step, Direction, and Low Current signals. The write fault condition can be cleared by using the write fault reset pin. If the drive being used does not support write fault, then this pin should be connected to $\mathrm{V}_{\mathrm{CC}}$ through a pull-up resistor.

## Ready 1, 0

These two pins indicate the functional status of the disk drives. Whenever an operation is attempted on a drive which is not ready, an interrupt is generated. The interface continually monitors this input during an operation and if a Not Ready condition occurs, immediately terminates the operation. Note that the 8271 latches the Not Ready condition and it can only be reset by the execution of a Read Drive Status command. For drives that do not support a ready signal, either one can be derived with a one shot and the index pulse, or the ready inputs can be grounded and Ready determined through some software means.

## PRINCIPLES OF OPERATION

As an 8080 peripheral device, the 8271 accepts commands from the CPU, executes them and provides a RESULT back to the 8080 CPU at the end of command execution. The communication with the CPU is established by the activation of $\overline{C S}$ and $\overline{R D}$ or $\overline{W R}$. The $A_{1}, A_{0}$ inputs select the appropriate registers on the chip:

| $\overline{\mathbf{D A C K}}$ | $\overline{\mathbf{C S}}$ | $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathrm{WR}}$ | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 1 | 0 | 0 | 0 | 0 | 1 | Read Status |
| 1 | 0 | 0 | 0 | 1 | 0 | Write Command |
| 1 | 0 | 0 | 1 | 0 | 1 | Read Result |
| 1 | 0 | 0 | 1 | 1 | 0 | Write Parameter |
| 1 | 0 | 1 | 0 | 1 | 0 | Write Reset Reg. |
| 0 | 1 | X | X | 1 | 0 | Write Data |
| 0 | 1 | X | X | 0 | 1 | Read Data |
| 0 | 0 | X | X | X | X | Not Allowed |

The FDC operation is composed of the following sequence of events.


Figure 15. Passing the Command and Parameters to the 8271

## The Command Phase

The software writes a command to the command register. As a function of the command issued, from zero to five parameters are written to the parameter register. Refer to diagram showing a flow chart of the command phase. Note that the flow chart shows that a command may not be issued if the FDC status register indicates that the device is busy. Issuing a command while another command is in progress is illegal. The flow chart also shows a parameter buffer full check. The FDC status indicates the state of the parameter buffer. If a parameter is issued while the parameter buffer is full, the previous parameter is over written and lost.


NOTE
STANDARD RESULT RETURNED CAN BE DETERMINED BY MASKING OUT THE DRIVE SELECT BITS OF THE COMMAND BYTE (BITS 7 AND 6) ANO CHECKING FOR A VALUE OF LESE THAN $2 \mathrm{C}_{16}$ (IF less than 2C16, standard result IS RETURNED).
IMMEDIATE RESULT RETURNED CAN BE DETERMINED BY ADDITIONALLY MASKING OUT BITS 5 AND 4 OF THE COMMAND BYTE AND CHECKING FOR A VALUE OF C16 OR GREATER (IF C16 RETURNED).

Figure 16. Checking for Result Type Following 8271 Command and Parameters

## The Execution Phase

During the execution phase the operation specified during the command phase is performed. During this phase, there is no CPU involvement if the system utilizes DMA for the data transfers. The execution phase of each command is discussed within the detailed command descriptions. The following table summarizes many of the basic execution phase characteristics.

## EXECUTION PHASE BASIC CHARACTERISTICS

The following table summarizes the various commands with corresponding execution phase characteristics.

| COMMANDS | 1 <br> Deleted Data | 2 Head | 3 Ready | 4 <br> Write/ Protect | 5 Seek | 6 <br> Seek Check | 7 Result | 8 <br> Completion Interrupt |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SCAN DATA | SKIP | LOAD | $\checkmark$ | $x$ | YES | YES | YES | YES |
| SCAN DATA AND DEL DATA | XFER | LOAD | $\checkmark$ | x | YES | YES | YES | YES |
| WRITE DATA | $x$ | LOAD | $\checkmark$ | $\checkmark$ | YES | YES | YES | YES |
| WRITE DEL DATA | X | 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 |
| FORMAT TRACK | $x$ | LOAD | $\checkmark$ | $\checkmark$ | YES | NO | YES | YES |
| SEEK | x | LOAD | $y$ | x | YES | NO | YES | YES |
| READ DRIVE STATUS | x | - | x | x | NO | NO | NOTE 5 | NO |
| SPECIFY | x | - | x | x | NO | NO | NO | NO |
| RESET | x | UNLOAD | x | x | NO | NO | NO | NO |
| R SP REGISTERS | $x$ | - | x | $x$ | NO | NO | NOTE 6 | NO |
| W SP REGISTERS | x | - | x | x | NO | NO | NO | NO |

Table 1. Execution Phase Basic Characteristics

Explanation of the execution phase characteristics table.

## 1. Deleted Data Processing

If deleted data is encountered during an operation that is marked skip in the table, the deleted data record is not transferred into memory, but the record is counted. For example, if the command and parameters specify a read of five records and one of the records was written with a deleted data mark, four records are transferred to memory. The deleted data flag is set in the result byte. However, if the operation is marked transfer, all data is transferred to memory regardless of the type of data mark.
2. Head

The Head column in the table specifies whether the Read/Write head will be loaded or not. If the table specifies load, the head is loaded after it is positioned over the track. The head loaded by a command remains loaded until the user specified number of index pulses have occurred.
3. Ready

The Ready column indicates if the ready line (Ready 1, Ready 0) associated with the selected drive is checked. A not ready state is latched by the 8271 until the user executes a read status command.

## 4. Write Protect

The operations that are marked check Write Protect are immediately aborted if Write Protect line is active at the beginning of an operation.
5. Seek

Many of the 8271 commands cause a seek to the desired track. A current track register is maintained for each drive or surface.
6. Seek Check

Operations that perform Seek Check verify that selected data in the ID field is correct before the 8271 accesses the data field.


Figure 17. Getting the Result

## The Result Phase

During the Result Phase, the FDC 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.

## PROGRAMMING

| $\mathbf{A}_{1}$ | $\mathbf{A}_{0}$ | CS RD | CS WR |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Status Reg | Command Reg |
| 0 | 1 | Result Reg | Parameter Reg |
| 1 | 0 | - | Reset Reg |
| 1 | 1 | - | - |

## STATUS REGISTER

## FDC Status



## Bit 7: Command Busy

The command busy bit is set on writing to the command register. Whenever the FDC is busy processing a command, the command busy bit is set to a one. This bit is set to zero after the command is completed.

## Bit 6: Command Full

The command full bit is set on writing to the command buffer and cleared when the FDC begins processing the command.

## Bit 5: Parameter Full

This bit indicates the state of the parameter buffer. This bit is set when a parameter is written to the FDC and reset after the FDC has accepted the parameter.

## Bit 4: Result Full

This bit indicates the state of the result buffer. It is valid only after Command Busy bit is low. This bit is set when the FDC finishes a command and is reset after the result byte is read by the CPU. The data in the result buffer is valid only after the FDC has completed a command. Reading the result buffer while a command is in progress yields no useful information.

## Bit 3: Interrupt Request

This bit reflects the state of the FDC INT pin. It is set when FDC requests attention as a result of the completion of an operation or failure to complete an intended operation. This bit is cleared by reading the result register.

## Bit 2: Non-DMA Data Request

When the FDC is utilized without a DMA controller, this bit is used to indicate FDC data requests. Note that in the non-DMA mode, an interrupt is generated (interrupt request bit is set) with each data byte written to or read from the diskette.

## Bits 1 and 0 :

Not used (zero returned).
After reading the Status Register, the CPU then reads the Result Register for more information.

## THE RESULT REGISTER

This byte format facilitates the use of an address table to look up error routines and messages. The standard result byte format is:


## Bits 7 and 6:

Not used (zero returned).
Bit 5:
Deleted Data Found: This bit is set when deleted data is encountered during a transaction.

## Bits 4 and 3: Completion Type

The completion type field provides general information regarding the outcome of an operation.
The completion type field provides general information regarding the outcome of an operation.

| Completion <br> Type | $\frac{\text { Event }}{}$ |
| :---: | :--- |
| 00 Good Completion - No Error <br> 01 System Error - recoverable errors; <br> 10 operator intervention probably required <br> for recovery. <br> 11 Command/Drive Error - either a program <br> error or drive hardware failure.. |  |

## Bits 2 and 1: Completion Code

The completion code field provides more detailed information about the completion type (See Table).

| Completion <br> Type | Completion <br> Code | Event |
| :---: | :---: | :--- |
| 00 | 00 | Good Completion/ <br> Scan Not Met |
| 00 | 01 | Scan Met Equal |
| 00 | 10 | Scan Met Not Equal |
| 00 | 11 | - |
| 01 | 00 | Clock Error |
| 01 | 01 | Late DMA |
| 01 | 10 | ID CRC Error |
| 01 | 11 | Data CRC Error |
| 10 | 00 | Drive Not Ready |
| 10 | 01 | Write Protect |
| 10 | 10 | Track O Not Found |
| 10 | 11 | Write Fault |
| 11 | 00 | Sector Not Found |
| 11 | 01 | -- |
| 11 | 10 | - |
| 11 | 11 | - |

It is important to note the hiefarchical structure of the result byte. In very simple systems where only a GO-NO GO result is required, the user may simply branch on a zero result (a zero result is a good completion), The next. level of complexity is at the completion type interface. The completion type supplies enough information so that 报 ${ }^{2}$ software may distinguish between fatal and non-fatal errors. If a completion type 01 occurs, ten retries should be performed before the error is considered unrecoverable.

The Completion Type/Completion Code interface supplies the greatest detail about each type of completion. This interface is used when detailed information about the transaction completion is required.

## Bit 0:

Not used (zero returned).

| Definition | Interpretation |
| :---: | :---: |
| Successful Completion/ Scan Not Met | The diskette operation specified was completed without error. If scan operation was specified, the pattern scanned was not found on the track addressed. |
| Scan Met Equal | The data pattern specified with the scan command was found on the track addressed with the specified comparison, and the equality was met. |
| Scan Met Not Equal | The data pattern specified with the scan command was found with the specified comparison on the track addressed, but the equality was not met. |
| Clock Error | During a diskette read operation, a clock bit was missing (dropped). Note that this function is disabled when reading any of the ID address marks (which contain missing clock pulses). If this error occurs, the operation is termınated immediately and an interrupt is generated. |
| Late DMA | During either a diskette read or write operation, the data channel did not respond within the allotted time interval to prevent data from being overwritten or lost. This error immediately terminates the operation and generates an interrupt. |
| ID Field CRC Error | The CRC word (two bytes) derived from the data read in an ID field did not match the CRC word written in the ID field when the track was formatted. If this error occurs, the associated diskette operation is prevented and no data is transferred. |
| Data Field CRC Error | During a diskette read operation, the CRC word derived from the data field read did not match the data field CRC word previously written. If this error occurs, the data read from the sector should be considered invalid. |
| Drive Not Ready | The drive addressed was not ready. This indication is caused by any of the following conditions: <br> 1. Drive not powered up <br> 2. Diskette not loaded <br> 3. Non-existent drive addressed <br> 4. Drive went not ready during an operation <br> Note that this completion code is cleared only through an FDC read drive status command. |
| Write Protect | A diskette write operation was specified on a write protected diskette. The intended write operation is prevented and no data is written on the diskette. |
| Track 00 Not Found | During a seek to track 00 operation, the drive failed to provide a track 00 indication after being stepped 255 times. |
| Write Fault | This error is dependent on the drive supported and indicates that the fault input to the FDC has been activated by the drive. |
| Sector Not Found | Either the sector addressed could not be found within one complete revolution of the diskette (two index marks encountered) or the track address specified did not match the track address contained in the ID field. Note that when the track address specified and the track address read do not match, the FDC automatically increments its track address register (stepping the drive to the next track) and again compares the track addresses. If the track addresses still do not match, the track address register is incremented a second time and another comparison is made before the sector not found completion code is set. |

Table 2. Completion Code Interpretation

## INITIALIZATION

## Reset Command

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PAR: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| PAR: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Function: The Reset command emulates the action of the reset pin. It is issued by outputting a one followed by a zero to the Reset register.

1. The drive control signals are forced low.
2. An in-progress command is aborted.
3. The FDC status register flags are cleared.
4. The FDC enters an idle state until the next command is issued.
Reset must be active for 10 or more clock cycles.

## SPECIFY COMMAND

Many of the interface characteristics of the FDC are specified by the systems software. Prior to initiating any drive operation command, the software must execute the three specify commands. There are two types of specify commands selectable by the first parameter issued.

## First Parameter

ODH
10 H

## Specify Type

Initialization
Load bad Tracks Surface '0'
Load bad Tracks Surface ' 1 '
The Specify command is used prior to performing any diskette operation (including formatting of a diskette) to define the drive's inherent operating characteristics and also is used following a formatting operation or installation of another diskette to define the locations of bad tracks. Since the Specify command only loads internal registers within the 8271 and does not involve an actual diskette operation, command processing is limited to only Command Phase. Note that once the operating characteristics and bad tracks have been specified for a given drive and diskette, redefining these values need only be done if a diskette with unique bad tracks is to be used or if the system is powered down.

## Initialization:

|  | $A_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| PAR: | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 |
| PAR: | 0 | 1 | STEP RATE* |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | HEAD SETTLING TIME* |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | INDEX CNT BEFORE HEAD UNLOAD* |  |  |  | HEAD LOAD TIME* |  |  |  |

*Note: Mini-floppy parameters are doubled.
Parameter $0-0 D_{H}=$ Select Specify Initialization.
Parameter $1-D_{7}-D_{0}=$ Step Rate $(0-255 \mathrm{~ms}$ in 1 ms steps).
Parameter $2-\mathrm{D}_{7}-\mathrm{D}_{0}=$ Head Settling Time ( $0-255 \mathrm{~ms}$ in 1 ms steps). $\{0-510 \mathrm{~ms}$ in 2 ms steps $\}()=$ standard, $\}=\mathrm{mini}$
Parameter $3-D_{7}-D_{4}=$ Index Count - Specifies the number of Revolutions $(0-14)$ which are to occur before the FDC automatically unloads the R/W head. If 15 is specified, the head remains loaded.
$\mathrm{D}_{3}-\mathrm{D}_{0}=$ Head Load Time ( $0-60 \mathrm{~ms}$ in steps of 4 ms ).
$\{0-120 \mathrm{~ms}$ in 8 ms steps $\}()=$ standard, $\}=\mathrm{mini}$

## Load Bad Tracks



## Parameter 0:10H = Load Su: face zero bad tracks $18 \mathrm{H}=$ Load Surface one bad track

Parameter 1:
Bad track address number 1 (Physical Address).
It is recommended to program both bad tracks and current track to $\mathrm{FF}_{\mathrm{H}}$ during initialization.

## SEEK COMMAND

The seek command moves the head to the specified track without loading the head or verifying the track.
The seek operation uses the specified bad tracks to compute the physical track address. This feature insures that the seek operation positions the head over the correct track.
When a seek to track zero is specified, the FDC steps the head until the track 00 signal is detected.

If the track 00 signal is not detected within $\left(\mathrm{FF}_{\mathrm{H}}\right.$ steps, a track 0 not found error status is returned.

A seek to track zero is used to position the read/write head when the current head position is unknown (such as after a power up).

|  | $\mathrm{A}_{1}$ | $A_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | SEL | $\begin{gathered} \hline \text { SEL } \\ 0 \end{gathered}$ | 1 | 0 | 1 | 0 | 0 | 1 |
| PAR. | 0 | 1 | TRACK ADDRESS 0.255 |  |  |  |  |  |  |  |

Seek operations are not verified. A subsequent read or write operation must be performed to determine if the correct track is located.

## READ DRIVE STATUS COMMAND

This command is used to interrogate the drive status. Upon completion the result register will hold the final drive status.


IF A DRIVE NOT READY RESULT IS RETURNED, THE READ STATUS MUST BE ISSUED TO CLEAR THE CONDITION.

[^20]

Figure 18. Initialization of the $\mathbf{8 2 7 1}$ by the User

## Read/Write Special Registers

This command is used to access special registers within the 8271 .

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | SEL | SEL 0 | COMMAND OPCODE |  |  |  |  |  |
| PAR: | 0 | 1 | REGISTER ADDRESS |  |  |  |  |  |  |  |

Command code:
3DH Read Special Register
ЗАн Write Special Register
For both commands, the first parameter is the register address; for Write commands a second parameter specifies data to be written. Only the Read Special Register command supplies a result.

| Description | Register Address in Hex | Comment |
| :---: | :---: | :---: |
| Scan Sector Number | 06 | See Scan Description |
| Scan MSB of Count | 14 | See Scan Description |
| Scan LSB of Count | 13 | See Scan Description |
| Surface 0 Current Track | 12 |  |
| Surface 1 Current Track | 1 A |  |
| Mode Register | 17 | See Mode Register Description |
| Drive Control Output Port | 23 | See Drive Output Port Description |
| Drive Control Input Port | 22 | See Drive Input Port Description |
| Surface 0 Bad Track 1 | 10 |  |
| Surface 0 Bad Track 2 | 11 |  |
| Surface 1 Bad Track 1 | 18 |  |
| Surface 1 Bad Track 2 | 19 |  |

Table 3. Special Registers

## Mode Register Write Parameter Format



Bits 6 \& 7
Must be one.

## Bits 5-2

(Not used). Must be set to zero.

## *Bit 1

Double/Single Actuator: Selects single or double actuator mode. If the single actuator mode is selected, the FDC assumes that the physical track location of both disks is always the same. This mode facilitates control of a drive which has a single actuator mechanism to move two heads.

## *Bit 0

Data Transfer Mode: This bit selects the data transfer mode. If this bit is a zero, the FDC operates in the DMA mode (DMA Request/ACK). If this bit is a one, the FDC operates in non-DMA mode. When the FDC is operating in DMA mode, interrupts are generated at the completion of commands. If the non-DMA mode is selected, the FDC generates an interrupt for every data byte transferred.

[^21]
## Non-DMA Transfers in DMA Mode

If the user desires, he may retain the use of interrupts generated upon command completions. This mode is accomplished by selecting the DMA capability, but using the DMA REQ/ACK pins as effective INT and CS signals, respectively.

## Drive Control Input Port

Reading this port will give the CPU exactly the data that the FDC sees at the corresponding pins. Reading this port will update the drive not ready status, but will not clear the status. (See Read Drive Status Command for Bit locations.)

## Drive Control Output Port Format



Each of these signals correspond to the chip pin of the same name. On standard-sized drives with write fault detection logic, bit 5 is set to generate the write fault reset signal. This signal is used to clear a write fault indication within the drive. On mini-sized drives, this bit can be used to turn on or off the drive motor prior to initiating a drive operation. A time delay after turn on may be necessary for the drive to come up to speed. The register must be read prior to writing the register in order to save the states of the remaining bits. When the register is subsequently written to modify bit 5 , the remaining bits must be restored to their previous states.

## IBM DISKETTE GENERAL FORMAT INFORMATION

The IBM Flexible Diskette used for data storage and retrieval is organized into concentric circular paths or TRACKS. There are 77 tracks on either one or both sides (surfaces) of the diskette. On double-sided diskettes, the corresponding top and bottom tracks are referred to as a CYLINDER. Each track is further divided into fixed length sections or SECTORS. The number of sectors per track 26,15 or 8 - is determined when a track is formatted and is dependent on the sector length $-128,256$ or 512 bytes respectively - specified.
All tracks on the diskette are referenced to a physical index mark (a small hole in the diskette). Each time the hole passes a photodetector cell (one revolution of the diskette), an Index pulse is generated to indicate the logical beginning of a track. This index pulse is used to initiate a track formatting operation.

## Track Format

Each Diskette Surface is divided into 77 tracks with each track divided into fixed length sectors. A sector can hold a whole record or a part of a record. If the record is shorter than the sector length, the unused bytes are filled with binary zeros. If a record is longer than the sector length, the record is written over as many sectors as its length requires. The sector size that provides the most efficient use of diskette space can be chosen depending upon the record length required.
Tracks are numbered from 00 (outer-most) to 76 (innermost) and are used as follows:

TRACK 00 reserved as System Label Track
TRACKS 01 through 74 used for data
TRACKS 75 and 76 used as alternates.
Each sector consists of an ID field (which holds a unique address for the sector) and a data field.
The ID field is seven bytes long and is written for each sector when the track is formatted. Each ID field consists of an ID field Address Mark, a Cylinder Number byte which identifies the track number, a Head Number byte which specifies the head used (top or bottom) to access the sector, a Record Number byte identifying the sector number ( 1 through 26 for 128 byte sectors), an N -byte specifying the byte length of the sector and two CRC (Cyclic Redundancy Check) bytes.

The Gaps separating the index mark and the ID and data fields are written on a track when it is formatted. These gaps provide both an interval for switching the drive electronics from reading or writing and compensation for rotational speed and other diskette-to-diskette and drive-todrive manufacturing tolerances to ensure that data written on a diskette by one system can be read by another (diskette interchangeability).

## IBM Format Implementation Summary

## Track Format

The disk has 77 tracks, numbered physically from 00 to 76 , with track 00 being the outermost track. There are logically 75 data tracks and two alternate tracks. Any two tracks may be initialized as bad tracks. The data tracks are numbered logically in sequence from 00 to 74 , skipping over bad tracks (alternate tracks replace bad tracks). Note: In IBM format track 00 cannot be a bad track.

## Sector Format

Each track is divided into 26,15 , or 8 sectors of 128,256 , or 512 bytes length respectively. The first sector is numbered 01, and is physically the first sector after the physical index mark. The logical sequence of the remaining sectors may be nonsequential physically. The location of these is determined at initialization by CPU software.
Each sector consists of an ID field and a data field. All fields are separated by gaps. The beginning of each field is indicated by 6 bytes of $(00)_{\mathrm{H}}$ followed by a one byte address mark.

## Address Marks

Address Marks are unique bit patterns one byte in length which are used to identify the beginning of ID and Data fields. Address Mark bytes are unique from all other data


Figure 19. Track Format
bytes in that certain bit cells do not contain a clock bit (all other data bytes have clock bits in every bit cell.) There are four different types of Address Marks used. Each of these is used to identify different types of fields.

## Index Address Mark

The Index Address Mark is located at the beginning of each track and is a fixed number of bytes in front of the first record.

## ID Address Mark

The ID Address Mark byte is located at the beginning of each ID field on the diskette.

## Data Address Mark

The Data Address Mark byte is located at the beginning of each non-deleted Data Field on the diskette.

## Deleted Data Address Mark

The Deleted Data Address Mark byte is located at the beginning of each deleted Data Field on the diskette.

| Address Mark Summary | Clock <br> Pattern | Data <br> Pattern |
| :--- | :---: | :---: |
| Index Address Mark | D7 | FC |
| ID Address Mark | C7 | FE |
| Data Address Mark | C7 | FB |
| Deleted Data Address Mark | C7 | F8 |
| Bad Track ID Address Mark | C7 | FE |

## ID Field

| MARK | C | H | R | N | CRC | CRC |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |

C $=$ Cylinder (Track) Address, 00-74
H = Head Address
R $=$ Record (Sector) Address, 01-26
$\mathrm{N}=$ Record (Sector) Length, 00-02
Note: Sector Length $=128 \times 2^{\mathrm{N}}$ bytes
CRC $=16$ Bit CRC Character (See Below)

## Data Field

| MARK | DATA | CRC | CRC |
| :---: | :---: | :---: | :---: |

Data is 128,256 , or 512 bytes long.
Note: All marks, data, ID characters and CRC characters are recorded and read most significant bit first.

## CRC Character

The 16-bit CRC character is generated using the generator polynominal $X^{16}+X^{12}+X^{5}+1$, normally initialized to $\left(\mathrm{FFF}_{\mathrm{H}}\right.$. It is generated from all characters (except the CRC in the ID or data field), including the data (not the clocks) in the address mark. It is recorded and read most significant bit first.

## Data Format

Data is written (general case) in the following manner:


Figure 20. Data Format

## References

"The IBM Diskette for Standard Data Interchange," IBM Document GA21-9182-0. "System 32," Chapter 8, IBM Document GA21-9176-0.

## Bad Track Format

The Bad Track Format is the same as the good track format except that the bad track ID field is initialized as follows:

$$
C=H=R=N=(F F)_{H}
$$

When formatting, bad track registers should be set to $\mathrm{FF}_{\mathrm{H}}$ for the drive during the formatting, thus specifying no bad tracks. Thus, all tracks are left available for formatting.

The track following the bad track(s) should be one higher in number than track before the bad track(s).

Upon completion of the format the bad tracks should be set up using the write special register command. The 8271 will then generate an extra step pulse to cross the bad track, locating a new track that now happens to be an extra track out.

## Format Track

## Format Command

|  | $A_{1}$ | $A_{0}$ | D7 | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | $\begin{gathered} \text { SEL } \\ 1 \end{gathered}$ | SEL | 1 | 0 | 0 | 0 | 1 | 1 |
| PAR: | 0 | 1 | TRACK ADDRESS |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | GAP 3 SIZE MINUS 6 |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | RECORD LENGTH |  |  | No. Of SECTORS/TRACK |  |  |  |  |
| PAR: | 0 | 1 | GAP 5 SIZE MINUS 6 |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | GAP 1 SIZE MINUS 6 |  |  |  |  |  |  |  |

The format command can be used to initialize a disk track compatible with the IBM 3740 format. A Shugart "IBM Type" mini-floppy format may also be generated.

The Format command can be used to initialize a diskette, one track at a time. When format command is used, the program must supply ID fields for each sector on the track. During command execution, the supplied ID fields (track head sector addresses and the sector length) are written sequentially on the diskette. The ID address marks originate from the 8271 and are written automatically as the first byte of each ID field. The CRC character is written in the last two bytes of the ID field and is derived from the data written in the first five bytes. During the formatting operation, the data field of each sector is filled with data pattern $(E 5)_{\mathrm{H}}$. The CRC, derived from the data pattern is also appended to the last byte.

1. The parameter $2\left(D_{7}-D_{5}\right)$ of the Format command specify record length, the bits are coded the same way as in the Read Data commands.
2. The programmable gap sizes (gap 3, gap 5, and gap 1) must be programmed such that the 6 bytes of zero (sync) are sub tracted from the intended gap size i.e., if gap 1 is intended to be 16 bytes long, programmed length must be $16-6=10$ bytes (of $\mathrm{FF}_{\mathrm{H}}$ 's).

## Mini-Floppy Disk Format

The mini-floppy disk format differs from the standard disk format in the following ways:

1. Gap 5 and the Index Address mark have been eliminated.
2. There are fewer sectors/tracks.

## GAPS

The following is the gap size and description summary:
Gap 1 Programmable
Gap 217 Bytes
Gap 3 Programmable
Gap 4 Variable
Gap 5 Programmable
The last six bytes of gaps $1,2,3$ and 5 are ( 00$)_{\mathrm{H}}$, all other bytes in the gaps are $(\mathrm{FF})_{H}$. The Gap 1,3 and 5 count specified by the user are the number of bytes of $(\mathrm{FF})_{\mathrm{H}}$. Gap 4 is written until the leading edge of the index pulse. If a Gap 5 size of zero is specified, the Index Mark is not written.

Gap 1:
$N$ bytes FF's
6 bytes 0's for sync the first ID mark. It is used to protect the first ID field from a write on the last physical sector of the current track.
Gap 2:
11 bytes FF's
6 bytes 0's for sync
This gap separates the ID field from the data mark and field such that during a write only the data field will be changed even if the write gate turns on early, due to drive speed changes.
Gap 3:
N bytes FF's
6 bytes 0's for sync
This gap separates a data area from the next ID field. It is used so that during drive speed changes the next ID mark will not be overwritten, thus causing loss of data.
Gap 4: $\quad$ This gap fills out the rest of the disk FF's only

Gap 5: $N$ bytes FF's 6 bytes 0's for sync his gap separates the last sector from the Index Address mark and is used to assure that the index address mark is not destroyed by writing on the last physical data sector on the track.
The number of FF bytes is programmable for gaps 1,3 and 5.
index

| GATA <br> FIELD | GAP 4 | GAP 5 | GAP 1 | $\begin{aligned} & \text { ID } \\ & \text { FIELD } \end{aligned}$ | GAP 2 | DATA <br> FIELD | GAP 3 | $\begin{aligned} & \text { ID } \\ & \text { FIELD } \end{aligned}$ | GAP 2 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

GAPS
INDEX ADDRESS MARK
GAP 1: POST INDEX GAP


GAP 2: POST ID FIELD GAP


WRITE GATE TURN-ON FOR UPDATE OF NEXT DATA FIELD.
NOTE: THE WRITE GATE TURN-ON SHOULD BE TIMED TO WITHIN $\pm=1$ BIT BY COUNTING THE BYTES IN THE GAP UNTIL 1 BYTE BEFORE THE TURN-ON.
GAP 3: POST DATA FIELD GAP


GAP 4: FINAL GAP


GAP 5: INITIAL GAP


Figure 21. Track Format


| NUMBER OF SECTORS | NUMBER OF BYTES |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | GAP 1 |  | ID FIELD | GAP 2 |  | DATA FIELD | GAP 3 |  | GAP 4 | GAP 5 |  |
|  | *ONES | SYNC |  | ONES | SYNC |  | *ONES | SYNC |  | *ONES | SYNC |
| 26 | 26 | 6 | 7 | 11 | 6 | 131 | 27 | 6 | 275 | 40 | 6 |
| 15 | 26 | 6 | 7 | 11 | 6 | 259 | 48 | 6 | 129 | 40 | 6 |
| 8 | 26 | 6 | 7 | 11 | 6 | 515 | 90 | 6 | 146 | 40 | 6 |
| 4 | 26 | 6 | 7 | 11 | 6 | 1027 | 224 | 6 | 236 | 40 | 6 |
| 2 | 26 | 6 | 7 | 11 | 6 | 2051 | 255 | 6 | 719 | 40 | 6 |
| 1 | 26 | 6 | 7 | 11 | 6 | 4099 | 0 | 0 | 1007 | 40 | 6 |

*Program Specified
5208 Bytes Per Track

Figure 22. Standard Diskette Track Format


| NUMBER OF SECTORS | NUMBER OF BYTES |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | GAP 1 |  | ID FIELD | GAP 2 |  | DATA FIELD | GAP 3 |  | GAP 4 |
|  | *ONES | SYNC |  | ONES | SYNC |  | *ONES | SYNC |  |
| 18 | 16 | 6 | 7 | 11 | 6 | 131 | 11 | 6 | 24 |
| 10 | 16 | 6 | 7 | 11 | 6 | 259 | 21 | 6 | 30 |
| 5 | 16 | 6 | 7 | 11 | 6 | 515 | 74 | 6 | 88 |
| 2 | 16 | 6 | 7 | 11 | 6 | 1027 | 255 | 6 | 740 |
| 1 | 16 | 6 | 7 | 11 | 6 | 2051 | 0 | 0 | 1028 |

*Program Specified
3125 Bytes Per Track

Figure 23. Mini-Diskette Track Format


Figure 23. User DMA Channel Initialization Flowchart

## Read ID Command

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | $\begin{gathered} \text { SEL } \\ 1 \end{gathered}$ | $\begin{gathered} \text { SEL } \\ 0 \end{gathered}$ | 0 | 1 | 1 | 0 | 1 | 1 |
| PAR: | 0 | 1 | TRACK ADDRESS |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| PAR: | 0 | 1 | NUMBER OF ID FIELDS |  |  |  |  |  |  |  |

The Read ID command transfers the specified number of ID fields into memory (beginning with the first ID field after Index). The CRC character is checked but not transferred.

These fields are entered into memory in the order in which they are physically located on the disk, with the first field being the one starting at the index pulse.

## Data Processing Commands

All the routine Read/Write commands examine specific drive status lines before beginning execution, perform an implicit seek to the track address and load the drive's read/write head. Regardless of the type of command (i.e., read, write or verify), the 8271 first reads the ID field(s) to verify that the correct track has been located (see sector not found completion code) and also to locate the addressed sector. When a transfer is complete (or cannot be completed), the 8271 sets the interrupt request bit in the status register and provides an indication of the outcome of the operation in the result register.

If a CRC error is detected during a multisector transfer, processing is terminated with the sector in error. The address of the failing sector number can be determined by examining the Scan Sector Number register using the Read Special Register command.

Full power of the multisector read/write commands can be realized by doing DMA transfer using Intel ${ }^{\circledR} 8257$ DMA Controller, For example, in a 128 byte per sector multisector write command, the entire data block (containing 128 bytes times the number of sectors) can be located in a disk memory buffer. Upon completion of the command phase, the 8271 begins execution by accessing the desired track, verifying the ID field, and locating the data field of the first record to be written. The 8271 then DMA-accesses the first sector and starts counting and writing one byte at a time until all 128 bytes are written. It then locates the data field of the next sector and repeats the procedure until all the specified sectors have been written. Upon completion of the execution phase the 8271 enters into the result phase and interrupts the CPU for availability of status and completion results. Note that all read/write commands, single or multisector are executed without CPU intervention.

Note, execution of multi-sector operations are faster if the sectors are not interleaved.

## 128 Byte Single Record Format



| Commands | Opcode |
| :--- | :---: |
| READ DATA | 12 |
| READ DATA AND DELETED DATA | 16 |
| WRITE DATA | $0 A$ |
| WRITE DELETED DATA | $0 E$ |
| VERIFY DATA AND DELETED DATA | $1 E$ |

## Variable Length/Multi-Record Format

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

$\mathrm{D}_{7}-\mathrm{D}_{5}$ of Parameter 2 determine the length of the disk record.

| 00 | 128 Bytes |
| :---: | :---: |
| 001 | 256 Bytes |
| 010 | 512 Bytes |
| 011 | 1024 Bytes |
| 100 | 2048 Bytes |
| 101 | 4096 Bytes |
| 110 | 8192 Bytes |
| 111 | 16,384 Bytes |


| Commands | Opcode |
| :--- | :---: |
| READ DATA | 13 |
| READ DATA AND DELETED DATA | 17 |
| WRITE DATA | $0 B$ |
| WRITE DELETED DATA | $0 F$ |
| VERIFY DATA AND DELETED DATA | $1 F$ |
| SCAN DATA | 00 |
| SCAN DATA AND DELETED DATA | 04 |

## Read Commands

Read Data, Read Data and Deleted Data.

## Function

The read command transfers data from a specified disk record or group of records to memory. The operation of this command is outlined in execution phase table.

## Write Commands

Write Data, Write Deleted Data.

## Function

The write command transfers data from memory to a specified disk record or group of records.

## Verify Command

Verify Data and Deleted Data.

## Function

The verify command is identical to the read data and deleted data command except that the data is not transferred to memory. This command is used to check that a record or a group of records has been written correctly by verifying the CRC character.

## Scan Commands

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{O}_{3}$ | $\mathrm{D}_{2}$ | $p_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | $\begin{gathered} \hline \text { SEL } \\ 1 \\ \hline \end{gathered}$ | SEL | 0 | 0 | 0 | S.DATA <br> SDELD | 0 | 0 |
| PAR. | 0 | 1 | TRACK ADDR 0255 |  |  |  |  |  |  |  |
| PAR. | 0 | 1 | SECTOR 0255 |  |  |  |  |  |  |  |
| PAR | 0 | 1 | LENGTH |  |  | NO OF SECTORS |  |  |  |  |
| PAR | 0 | 1 | SCAN TYPE |  |  | STEP SIZE |  |  |  |  |
| PAR: | 0 | 1 | FIELD LENGTH (KEY) |  |  |  |  |  |  |  |

$$
\begin{array}{lll}
\text { Command } & D_{2}=0 & \text { Scan Data } \\
& D_{2}=1 & \text { Scan Data and Deleted Data }
\end{array}
$$

Scan Commands, Scan Data and Scan Data and Deleted Data, are used to search a specific data pattern or "key" from memory. The 8271 FDC operation during a scan is unique in that data is read from memory and from the diskette simultaneously.

During the scan operation, the key is compared repetitively (using the 8257 DMA Controller in auto load mode) with the data read from the diskette (e.g., an eight byte key would be compared with the first eight bytes (1-8) read from the diskette, the second eight bytes (9-16), the third eight bytes (17-24), etc.). The scan operation is concluded when the key is located or when the specified number of sectors have been searched without locating the key. When concluded, the 8271 FDC requests an interrupt. The program must then read the result register to determine if the scan was successful (if the key was located). If successful, several of the FDC's special registers can be examined (read special registers command) to determine more specific information relating to the scan (i.e., the sector number in which the key was located, and the number of bytes within the sector that were not compared when the key was located).

The 8271 does not do a sliding scan, it does a fixed block linear search. This means the key in memory is compared to an equal length block in a sector; when these blocks meet the scan conditions the scan will stop. Otherwise, the scan continues until all the sectors specified have been searched.

The following factors regarding key length must be considered when establishing a key in memory.

1. When searching multiple sectors, the length of the key must be evenly divisible into the sector length to prevent the key from being split at subsequent sector boundaries. Since the character $\mathrm{FFH}_{H}$ is not compared, the key in memory can be padded to the required length using this character. For example, if the actual pattern compared on the diskette is twelve characters in length, the field length should be sixteen and four bytes of FFH
would be appended to the key. Consequently, the last block of sixteen bytes compared within the first sector would end at the sector boundary and the first byte of the next sector would be compared with the first byte of the key. Splitting data over sector boundarys will not work properly since the FDC expects the start of key at each sector boundary.
2. Since the first byte of the key is compared with the first byte of the sector, when the pattern does not begin with the first byte of the sector, the key must be offset using the character $\mathrm{FF}_{16}$. For example, if the first byte of a nine byte pattern begins on the fifth byte of the sector, four bytes of $\mathrm{FF}_{16}$ are prefixed to the key (and three bytes of $\mathrm{FF}_{16}$ are appended to the key to meet the length requirement) so that the first actual comparison begins on the fifth byte.

The Scan Commands require five parameters:

## Parameter 0, Track Address

Specifies the track number containing the sectors to be scanned. Legal values range from $00_{H}$ to $4 \mathrm{C}_{\mathrm{H}}(0$ to 76$)$ for a standard diskette and from $00_{\mathrm{H}}$ to $22_{\mathrm{H}}(0$ to 34$)$ for a mini-sized diskette.

## Parameter 1, Sector Address

Specifies the first sector to be scanned. The number of sectors scanned is specified in parameter 2, and the order in which sectors are scanned is specified in parameter 3.

## Parameter 2, Sector Length/Number of Sectors

The sector length field (bits 7-5) specifies the number of data bytes allocated to each sector (see parameter 2, routine read and write commands for field interpretation). The number of sectors field (bits 4-0) specifies the number of sectors to be scanned. The number specified ranges from one sector to the physical number of sectors on the track.

## Parameter 3

## $D_{7}-D_{6}$ : Indicate scan type

00-EQ Scan for each character within the field length (key) equal to the corresponding character within the disk sector. The scan stops after the first equal condition is met.
01-GEQ Scan for each character within the disk sector greater than or equal to the corresponding character within the field length (key). The scan stops after the first greater than or equal condition is met.

10-LEQ Scan for each character within the disk sector less than or equal to the corresponding character within the field length (key), The scan stops after the first less than or equal condition is met.
$D_{5}-D_{0}$ : Step Size: The Step Size field specifies the offset to the next sector in a multisector scan. In this case, the next sector address is generated by adding the Step Size to the current sector address.

## Parameter 4, Fieid Length

Specifies the number of bytes to be compared (length of key). While the range of legal values is from 1 to 255 , the field length specified should be evenly divisible into the sector length to prevent the key from being split at sector boundaries, if the multisector scan commands are used.

## Scan Command Results

More detailed information about the completion of Scan Commands may be obtained by executing Read Special Register commands.

## Read Special Register

| Paramete (Hex) | er Results |
| :---: | :---: |
| 06 T | The sector number of the sector in which the specified scan data pattern was located. |
|  | MSB Count - The number of 128 byte blocks remaining to be compared in the current sector when the scan data pattern was located. This register is decremented with each 128 byte block read. |
| 13 l | LSB Count - The number of bytes remaining to be compared in the current sector when the scan data pattern is located. This register is initialized to 128 and is decremented with each byte compared. |

Upon a scan met condition, the equation below can be used to determine the last byte in the located pattern.

[^22]
## 8271 Scan Command Example

Assume there are only 2 records on track 0 with the following data:
Record 01: 0102030405060708 000.... 00
Record 02: 0102 AA 5500000000 $\qquad$

| Command | Field Length | Starting <br> Sector \# | \# of Sectors | Key ${ }^{[2]}$ | Completion Code ${ }^{(3)}$ | Special Registers ${ }^{[4]}$ |  |  | Comment |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | R06 | R14 | R13 |  |
| * SCAN EQ | 2 | 1 | 1 | 01,02 | SME | 01 | 0 | 127D | Met in first field |
| SCAN EQ | 2 | 1 | 1 | 02,03 | SNM | X | X | X | Not met |
| SCAN EQ | 2 | 1 | 1 | $\mathrm{FF}^{[5]}, 05$ | SNM | X | X | X | Not met with don't care |
| * SCAN EQ | 2 | 1 | 1 | $\mathrm{FF}^{[5]}, 06$ | SME | 01 | 0 | 123D | Met with don't care |
| * SCAN EQ | 2 | 1 | 2 | AA, 55 | SME | 02 | 0 | 125D | Met in Record 02 |
| * SCAN EQ | 2 | 2 | 1 | 01,02 | SME | 02 | 0 | 127D | Starting sector $\neq 1$ |
| * SCAN EQ | 4 | 1 | 1 | 05,06,07,08 | SME | 01 | 0 | 121D | Field, Key length $=4$ |
| * SCAN GEQ | 4 | 1 | 1 | 05,06,07,08 | SME | 01 | 0 | 121D | GEQ-SME |
| * SCAN GEQ | 4 | 1 | 1 | 05,04,07,08 | SMNE | 01 | 0 | 121D | GEQ-SMNE |
| * SCAN GEQ | 4 | 1 | 2 | 00,03, AA, $44^{[6]}$ | SNM | X | X | X | GEQ-SNM |
| * SCAN LEQ | 4 | 1 | 1 | 01,03, FF, 04 | SMNE | 01 | 0 | 125D | LEQ-SMNE |
| * SCAN LEQ | 4 | 1 | 1 | 01,02,FF, 04 | SME | 01 | 0 | 125D | LEQ-SME |

## NOTES:

1. Field Length - Each record is partitioned into a number of fields equal to the record size divided by the field length. Note that the record size should be evenly divisable by the field length to insure proper operation of multi record scan. Also, maximum field length $=256$ bytes.
2. Key - The key is a string of bytes located in the user system memory. The key length should equal the field length. By programming the 8257 DMA Controller into the auto load mode, the key will be recursively read in by the chip (once per field).
3. Completion Code - Shows how Scan command was met or not met.

SNM - SCAN Not Met - 00 (also Good Complete)
SME - SCAN Met Equal - 01
SMNE - SCAN Met Not Equal - 10
4. Special Registers

R06 - This register contains the record number where the scan was met.
R14 - This register contains the MSB count and is decremented every 128 characters.

| Length $(\ell)$ <br> (D7-D5 of PAR 2) | Record Size | R14 $=2 \ell-\mathbf{l}$ <br> (Initialize at <br> Beginning of Record) |
| :---: | :---: | :---: |
| 000 | 128 Bytes | 0 |
| 001 | 256 Bytes | 1 |
| 010 | 512 Bytes | 3 |
| 011 | 1024 Bytes | 7 |
| $\vdots$ | $\vdots$ | $\vdots$ |

R13 - This register contains a modulo 128 LSB count which is initialized to 128 at beginning of each record. This count is decremented after each character is compared except for the last character in a pattern match situation.
5. The OFFH character in the key is treated as a don't care character position.
6. The Scan comparison is done on a byte by byte basis. That is, byte 1 of each field is compared to byte 1 of the key, byte 2 of each field is compared to byte 2 of the key, etc.

## 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 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 cont ditions 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 \%$

| 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 | $\left(\mathrm{~V}_{\mathrm{CC}}+0.5\right)$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ for Data Bus Pins <br> $I_{\mathrm{OL}}=1.7 \mathrm{~mA}$ for All Other Pins |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-220 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to OV |
| $\mathrm{I}_{\mathrm{OZ}}$ | Off-State Output Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to OV |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 180 | mA |  |

## 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}_{/ \mathrm{N}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{t}_{\mathrm{c}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{/ / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured Pins Returned to GND |

## 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 \%$
Read Cycle

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A C}$ | Select Setup to $\overline{\mathrm{RD}}$ | 0 |  | ns | Note 2 |
| $t_{\text {CA }}$ | Select Hold from $\overline{\mathrm{RD}}$ | 0 |  | ns | Note 2 |
| $t_{\text {RR }}$ | $\overline{\mathrm{RD}}$ Pulse Width | 250 |  | ns |  |
| $t_{\text {AD }}$ | Data Delay from Address |  | 250 | ns | Note 2 |
| $t_{\text {RD }}$ | Data Delay from $\overline{\mathrm{RD}}$ |  | 150 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$, Note 2 |
| $t_{\text {DF }}$ | Output Float Delay | 20 | 100 | ns | $C_{L}=20 \mathrm{pF}$ for Minimum; 150 pF for Maximum |
| $t_{\text {DC }}$ | DACK Setup to $\overline{\mathrm{RD}}$ | 25 |  | ns |  |
| $t_{\text {cD }}$ | DACK Hold from RD | 25 |  | ns |  |
| $t_{K D}$ | Data Delay from DACK |  | 250 | ns |  |

## Write Cycle

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A C}$ | Select Setup to $\overline{W R}$ | 0 |  | ns |  |
| $t_{C A}$ | Select Hold from $\overline{W R}$ | 0 |  | ns |  |
| $t_{W W}$ | $\overline{W R}$ Pulse Width | 250 |  | ns |  |
| $t_{D W}$ | Data Setup to $\overline{W R}$ | 150 |  | ns |  |
| $t_{W D}$ | Data Hold from $\overline{W R}$ | 0 |  | ns |  |
| $t_{D C}$ | DACK Setup to $\overline{W R}$ | 25 |  | ns |  |
| $t_{C D}$ | DACK Hold from $\overline{W R}$ | 25 |  | ns |  |

DMA

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CQ}}$ | Request Hold from $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ (for Non-Burst Mode) |  | 150 | ns |  |

Other Timing

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {RSTW }}$ | Reset Pulse Width | 10 |  | $t_{C Y}$ |  |
| $t_{r}$ | Input Signal Rise Time |  | 20 | ns |  |
| $t_{f}$ | Input Signal Fall Time |  | 20 | ns |  |
| $t_{\text {RSTS }}$ | Reset to First IOWR | 2 |  | $t_{C Y}$ |  |
| $t_{C Y}$ | Clock Period | 250 |  |  | Note 3 |
| $t_{C L}$ | Clock Low Period | 110 |  | ns |  |
| $t_{C H}$ | Clock High Period | 122 |  | ns |  |
| $t_{D S}$ | Data Window Setup to Unseparated Clock and Data | 50 |  | ns |  |
| $t_{D H}$ | Data Window Hold from Unseparated Clock and Data | 0 |  | ns |  |

## NOTES:

[^23]
## WAVEFORMS

## Read Waveforms



Write Waveforms


DMA Waveforms


WRITE DATA


PULSE WIDTH PW $=\mathbf{t} \mathbf{t} Y \pm 30 \mathrm{~ns}$
$\mathrm{H}(\mathrm{HALF}$ BIT CELL $)=8$ tcy
F (FULL BIT CELL) $=16 \mathrm{t} \mathbf{C Y}$
${ }^{*} \mathrm{t} \mathrm{CY}=250 \mathrm{~ns} \pm 0.4 \% \quad * * \mathrm{t} \mathrm{CY}=\mathbf{5 0 0 \mathrm { ns } \pm 0 . 4 \%} \begin{aligned} & 500 \mathrm{~ns} \pm 30 \mathrm{~ns}\end{aligned}$ $250 \mathrm{~ns} \pm 30 \mathrm{~ns} \quad 500 \mathrm{~ns} \pm 30 \mathrm{~ns}$ $2.0 \mu \mathrm{~s} \pm 8 \mathrm{~ns} \quad 4.0 \mu \mathrm{~s} \pm 16 \mathrm{~ns}$ $4.0 \mu \mathrm{~s} \pm 16 \mathrm{~ns} \quad 8.0 \mu \mathrm{~s} \pm 32 \mathrm{~ns}$

Figure 24. Write Data


Figure 25. Read Data


Figure 26. Single-Shot Data Separator

*DATA WINDOW MAY BE $180^{\circ}$ OUT OF PHASE IN PLO DATA SEPARATION MODE.

Figure 27. PLO Data Separator CONTROLLER

- HDLC/SDLC Compatible

Frame Level Commands
Full Duplex, Half Duplex, or Loop SDLC Operation

## Up to 64K Baud Transfers

- Two User Programmable Modem Control Ports


## - Automatic FCS (CRC) Generation and Checking

- Programmable NRZI Encode/Decode
- N-Bit Reception Capability
- Digital Phase Locked Loop Clock Recovery


## - Minimum CPU Overhead

- Fully Compatible with 8080/8085 CPUs
- Single + 5V Supply
- 40-Pin Package

The Intel 8273 Programmable HDLCISDLC Protocol Controller is a dedicated device designed to support the ISO/CCITT's HDLC and IBM's SDLC communication line protocols. It is fully compatible with Intel's new high performance microcomputer systems such as the MCS-85 ${ }^{\text {TM }}$. A frame level command set is achieved by a unique microprogrammed dual processor chip architecture. The processing capability supported by the 8273 relieves the system CPU of the low level real-time tasks normally associated with controllers.


## A BRIEF DESCRIPTION OF HDLC/SDLC PROTOCOLS

## General

The High Level Data Link Control (HDLC) is a standard communication link protocol established by international Standards Organization (ISO). HDLC is the discipline used to implement ISO X. 25 packet switching systems.
The Synchronous Data Link Control (SDLC) is an IBM communication link protocol used to implement the System Network Architecture (SNA). Both the protocols are bit oriented, code independent, and ideal for full duplex communication. Some common applications include terminal to terminal, terminal to CPU, CPU to CPU, satellite communication, packet switching and other high speed data links. In systems which require expensive cabling and interconnect hardware, any of the two protocols could be used to simplify interfacing (by going serial), thereby reducing interconnect hardware costs. Since both the protocols are speed independent, reducing interconnect hardware could become an important application.

## Network

In both the HDLC and SDLC line protocols, according to a pre-assigned hierarchy, a PRIMARY (Control) STATION controls the overall network (data link) and issues commands to the SECONDARY (Slave) STATIONS. The latter comply with instructions and respond by sending appropriate RESPONSES. Whenever a transmitting station must end transmission prematurely it sends an ABORT character. Upon detecting an abort character, a receiving station ignores the transmission block called a FRAME. Time fill between frames can be accomplished by transmitting either continuous frame preambles called FLAGS or an abort character. A time fill within a frame is not permitted. Whenever a station receives a string of more that fifteen consecutive ones, the station goes into an IDLE state.

## Frames

A single communication element is called a FRAME which can be used for both Link Control and data transfer purposes. The elements of a frame are the beginning eight bit FLAG (F) consisting of one zero, six ones, and a zero, an eight bit ADDRESS FIELD (A), an eight bit CONTROL FIELD (C), a variable ( N -bit) INFORMATION FIELD ( 1 ), a sixteen bit FRAME CHECK SEQUENCE (FCS), and an eight bit end FLAG (F), having the same bit pattern as the beginning flag. In HDLC the Address (A) and Control (C) bytes are extendable. The HDLC and the SDLC use three
types of frames; an Information Frame is used to transfer data, a Supervisory Frame is used for control purposes, and a Non-sequenced Frame is used for initialization and. control of the secondary stations.

## Frame Characteristics

An important characteristic of a frame is that its contents are made code transparent by use of a zero bit insertion and deletion technique. Thus, the user can adopt any format or code suitable for his system - it may even be a computer word length or a "memory dump". The frame is bit oriented that is, bits, not characters in each field, have specific meanings. The Frame Check Sequence (FCS) is an error detection scheme similar to the Cyclic Redundancy Checkword (CRC) widely used in magnetic disk storage devices. The Command and Response information frames contain sequence numbers in the control fields identifying the sent and received frames. The sequence numbers are used in Error Recovery Procedures (ERP) and as implicit acknowledgement of frame communication, enhancing the true fullduplex nature of the HDLC/SDLC protocols.
In contrast, BISYNC is basically half-duplex (two way alternate) because of necessity to transmit immediate acknowledgement frames. HDLC/SDLC therefore saves propagation delay times and have a potential of twice the throughput rate of BISYNC.
It is possible to use HDLC or SDLC over half duplex lines but there is a corresponding loss in throughput because both are primarily designed for full-duplex communication. As in any synchronous system, the bit rate is determined by the clock bits supplied by the modem, protocols themselves are speed independent.
A byproduct of the use of zero-bit insertion-deletion technique is the non-return-to-zero invert (NRZI) data transmission/reception compatibility. The latter allows HDLC/SDLC protocols to be used with asynchronous data communication hardware in which the clocks are derived from the NRZI encoded data.

## References

IBM Synchronous Data Link Control General Information, IBM, GA 27-3093-1.
Standard Network Access Protocol Specification, DATAPAC, TransCanada Telephone System CCG111
Recommendation X.25, ISO/CCITT March 2, 1976.
IBM 3650 Retail Store System Loop Interface OEM Information, IBM, GA 27-3098-0
Guidebook to Data Communications, Training Manual, Hewlett-Packard 5955-1715
IBM Introduction to Teleprocessing, IBM, GC 20-8095-02
System Network Architecture, Technical Overview, IBM, GA 27-3102
System Network Architecture Format and Protocol, IBM GA 27-3112

| OPENING FLAG (F) | ADDRESS <br> FIELD (A) | CONTROL FIELD (C) | INFORMATION FIELD (I) | FRAME CHECK SEQUENCE (FCS) | $\begin{aligned} & \text { CLOSING } \\ & \text { FLAG (F) } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 01111110 | 8 BITS | 8 BITS | VARIABLE LENGTH (ONLY IN I FRAMES) | 16 BITS | 01111110 |

Figure 1. Frame Format

## FUNCTIONAL DESCRIPTION

## General

The Intel* 8273 HDLC/SDLC controller is a microcomputer peripheral device which supports the International Standards Organization (ISO) High Level Data Link Control (HDLC), and IBM Synchronous Data Link Control (SDLC) communications protocols. This controller minimizes CPU software by supporting a comprehensive frame-level instruction set and by hardware implementation of the low level tasks associated with frame assembly/disassembly and data integrity. The 8273 can be used in either synchronous or asynchronous applications. In asynchronous applications the data can be programmed to be encoded/decoded in NRZI code. The clock is derived from the NRZI data using a digital phase locked loop. The data transparency is achieved by using a zerobit insertion/deletion technique. The frames are automatically checked for errors during reception by verifying the Frame Check Sequence (FCS); the FCS is automatically generated and appended before the final flag in transmit. The 8273 recognizes and can generate flags (01111110), Abort, Idle, and GA (EOP) characters.
The 8273 can assume either a primary (control) or a secondary (slave) role. It can therefore be readily implemented in an SDLC loop configuration as typified by the IBM 3650 Retail Store System by programming the 8273 into a one-bit delay mode. In such a configuration, a two wire pair can be effectively used for data transfer between controllers and loop stations. The digital phase locked loop output pin can be used by the loop station without the presence of an accurate Tx clock.

## Hardware Description

The 8273 is packaged in a 40 pin DIP. The following is a functional description of each pin.

| Pin Name (No.) | 1/0 | Description |
| :---: | :---: | :---: |
| Vcc (40) |  | +5V Supply |
| GND (20) |  | Ground |
| RESET (4) | 1 | 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. Reset must be true for a minimum of 10 TCY. |

$\overline{\mathrm{CS}}$ (24) . $\quad 1 \quad$ The $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs are en-
$\mathrm{DB}_{7}-\mathrm{DB}_{0}$ (19-12) I/O The Data Bus lines are bidirectional three-state lines which interface with the system Data Bus.
$\overline{W R}(10)$
$\overline{\mathrm{RD}}$ (9)

TXINT (2) $O$ The Transmitter interrupt signal indicates that the transmitter logic requires service.
RxINT (11) O The Receiver interrupt signal indicates that the Receiver logic requires service.

TxDRQ (6)

RxRDQ (8)
$\overline{\text { TxDACK }}$ (5)
$\overline{\text { RXDACK }}$ (7)
$A_{1}-A_{0}(22-21)$

TxD (29)
$\overline{T x C}(28)$

RxD (26)
$\overline{\mathrm{RxC}}(27)$
$\overline{32 X ~ C L K}$ (25)
$\overline{\text { DPLL }}$ (23)
$\overline{\text { FLAG DET }}$ (1)
$\overline{R T S}$ (35)
$\overline{\mathrm{CTS}}(30)$
$\overline{\mathrm{CD}}$ (31)
$\overline{\mathrm{PA}}_{2-4}(32-34)$
$\overline{\mathrm{PB}}_{1-4}(36-39)$

O Requests a transfer of data between memory and the 8273 for a transmit operation.
O Requests a transfer of data between the 8273 and memory for a receive operation.

1 The Transmitter DMA acknowledge signal notifies the 8273 that the TxDMA cycle has been granted.
The Receiver DMA acknowledge signal notifies the 8273 that the RxDMA cycle has been granted.

1 These two lines are CPU Interface Register Select lines.

O This line transmits the serial data to the communication channel.

I The transmitter clock is used to synchronize the transmit data.

1 This line receives serial data from the communication channel.

I The Receiver Clock is used to synchronize the receive data.

I The 32X clock is used to provide clock recovery when an asynchronous modem is used. In loop configuration the loop station can run without an accurate 1 X clock by using the 32X CLK in conjunction with the DPLL output. (This pin must be grounded when not used).

O Digital Phase Locked Loop output can be tied to RxC and/or TxC when 1X clock is not available. DPLL is used with 32 X CLK.

O Flag Detect signals that a flag ( 01111110 ) has been received by an active receiver.

O Request to Send signals that the 8273 is ready to transmit data.

I Clear to Send signals that the modem is ready to accept data from the 8273.

1 Carrier Detect signals that the line transmission has started and the 8273 may begin to sample data on RxD line.
1 General purpose input ports. The logic levels on these lines can be Read by the CPU through the Data Bus Buffer.

O General purpose output ports. The CPU can write these output lines through Data Bus Buffer.
CLK (3)

## CPU Interface

The CPU interface is optimized for the MCS-80/85 ${ }^{\text {TM }}$ bus with an 8257 DMA controller. However, the interface is flexible, and allows either DMA or non-DMA data transfers, interrupt or non-interrupt driven. It further allows maximum line utilization by providing early interrupt mechanism for buffered (only the information field can be transferred to memory) Tx command overlapping. It also provides separate Rx and Tx interrupt output channels for efficient operation. The 8273 keeps the interrupt request active until all the associated interrupt results have been read.

The CPU utilizes the CPU interface to specify commands and transfer data. It consists of seven registers addressed via $\overline{C S}, A_{1}, A_{0}, \overline{R D}$ and $\overline{W R}$ signals and two independent data registers for receive data and transmit data. $A_{1}, A_{0}$ are generally derived from two low order bits of the address bus. If an 8080 based CPU is utilized, the $\overline{R D}$ and $\overline{W R}$ signals may be driven by the $8228 \overline{\mathrm{I} O R}$ and $\overline{/ O W}$. The table shows the seven register select decoding:

| $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ | $\overline{\mathbf{T X D A C K}}$ | $\overline{\text { RXDACK }}$ | $\overline{\mathbf{C S}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | Register |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | 1 | 0 | 1 | 0 | Command |
| 0 | 0 | 1 | 1 | 0 | 0 | 1 | Status |
| 0 | 1 | 1 | 1 | 0 | 1 | 0 | Parameter |
| 0 | 1 | 1 | 1 | 0 | 0 | 1 | Result |
| 1 | 0 | 1 | 1 | 0 | 1 | 0 | Reset |
| 1 | 0 | 1 | 1 | 0 | 0 | 1 | TxINT Result |
| 1 | 1 | 1 | 1 | 0 | 1 | 0 | - |
| 1 | 1 | 1 | 1 | 0 | 0 | 1 | RxINT Result |
| X | X | 0 | 1 | 1 | 1 | 0 | Transmit Data |
| X | X | 1 | 0 | 1 | 0 | 1 | Receive Data |



Figure 2. 8273 Block Diagram Showing CPU Interface Functions

## Register Description

## Command

Operations are initiated by writing an appropriat command in the Command Register.

## Parameter

Parameters of commands that require additional information are written to this register.

## Result

Contains an immediate result describing an outcome of an executed command.

## Transmit Interrupt Result

Contains the outcome of 8273 transmit operation (good/bad completion).

## Receive Interrupt Result

Contains the outcome of 8273 receive operation (good/ bad completion), followed by additional results which detail the reason for interrupt.

## Status

The status register reflects the state of the 8273 CPU Interface.

## DMA Data Transfers

The 8273 CPU interface supports two independent data interfaces: receive data and transmit data. At high data transmission speeds the data transfer rate of the 8273 is great enough to justify the use of direct memory access (DMA) for the data transfers. When the 8273 is configured in DMA mode, the elements of the DMA interfaces are:

## TxDRQ: Transmit DMA Request

Requests a transfer of data between memory and the 8273 for a transmit operation.

## TxDACK: Transmit DMA Acknowledge

The TxDACK signal notifies the 8273 that a transmit DMA cycle has been granted. It is also used with $\overline{W R}$ to transfer data to the 8273 in non-DMA mode.

## RxDRQ: Receive DMA Request

Requests a transfer of data between the 8273 and memory for a receive operation.

## RxDACK: Receive DMA Acknowledge

The $\overline{\text { RXDACK }}$ signal notifies the 8273 that a receive DMA cycle has been granted. It is also used with $\overline{\mathrm{RD}}$ to read data from the 8273 in non-DMA mode.

## $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ : Read, Write

The $\overline{R D}$ and $\overline{W R}$ signals are used to specify the direction of the data transfer.

DMA transfers require the use of a DMA controller such as the Intel 8257. The function of the DMA controller is to provide sequential addresses and timing for the transfer, at a starting address determined by the CPU. Counting of data block lengths is performed by the 8273 .

To request a DMA transfer the 8273 raises the appropriate DMA REQUEST. DMA ACKNOWLEDGE and READ enables DMA data onto the bus (independently of CHIP SELECT). DMA ACKNOWLEDGE and WRITE transfers DMA data to the 8273 (independent of CHIP SELECT).

It is also possible to configure the 8273 in the non-DMA data transfer mode. In this mode the CPU module must pass data to the 8273 in response to non-DMA data requests indicated by the status word.

## Modem Interface

The 8273 Modem interface provides both dedicated and user defined modem control functions. All the control signals are active low so that EIA RS-232C inverting drivers (MC 1488) and inverting receivers (MC 1489) may be used to interface to standard modems. For asynchronous operation, this interface supports programmable NRZI data encode/decode, a digital phase locked loop for efficient clock extraction from NRZI data, and modem control ports with automatic $\overline{C T S}, \overline{C D}$ monitoring and $\overline{\mathrm{RTS}}$ generation. This interface also allows the 8273 to operate in PRE-FRAME SYNC mode in which the 8273 prefixes 16 transitions to a frame to synchronize idle lines before transmission of the first flag.
It should be noted that all the 8273 port operations deal with logical values, for instance, bit D0 of Port A will be a one when $\overline{C T S}$ ( $\operatorname{Pin} 30$ ) is a physical zero (logical one).

## Port A - Input Port

During operation, the 8273 interrogates input pins $\overline{C T S}$ (Clear to Send) and $\overline{C D}$ (Carrier Detect). $\overline{\mathrm{CTS}}$ is used to condition the start of a transmission. If during transmission CTS is lost the 8273 generates an interrupt. During reception, if $\overline{C D}$ is lost, the 8273 generates an interrupt.


The user defined input bits correspond to the $8273 \mathrm{PA}_{4}$, $\mathrm{PA}_{3}$ and $\mathrm{PA}_{2}$ pins. The 8273 does not interrogate or manipulate these bits.


Figure 3. 8273 Block Diagram Showing Control Logic Functions

## Port B - Output Port

During normal operation, if the CPU sets $\overline{\mathrm{RTS}}$ active, the 8273 will not change this pin; however, if the CPU sets $\overline{\mathrm{RTS}}$ inactive, the 8273 will activate it before each transmission and deactivate it one byte time after transmission. While the receiver is active the flag detect pin is pulsed each time a flag sequence is detected in the receive data stream. Following an 8273 reset, all pins of Port $B$ are set to a high, inactive level.


The user defined output bits correspond to the state of $\mathrm{PB}_{4}-\mathrm{PB}_{1}$ pins. The 8273 does not interrogate or manipulate these bits.

## Serial Data Logic

The Serial data is synchronized by the user transmit ( $\overline{T \times C)}$ and receive ( $\overline{\mathrm{RxC}}$ ) clocks. The leading edge of $\overline{\mathrm{TxC}}$ generates new transmit data and the trailing edge of $\overline{R \times C}$ is used to capture receive data. The NRZI encoding/ decoding of the receive and transmit data is programmable.
The diagnostic features included in the Serial Data logic are programmable loop back of data and selectable clock for the receiver. In the loop-back mode, the data presented to the TxD pin is internally routed to the receive data input
circuitry in place of the RxD pin, thus allowing a CPU to send a message to itself to verify operation of the 8273 ,
In the selectable clock diagnostic feature, when the data is looped back, the receiver may be presented incorrect sample timing by the external circuitry. The user may select to substitute the $\overline{\overline{T x C}}$ pin for the $\overline{\mathrm{RxC}}$ input on-chip so that the clock used to generate the loop back data is used to sample it. Since TxD is generated off the leading edge of $\overline{T \times C}$ and RxD is sampled on the trailing edge, the selected clock allows bit synchronism.


Figure 4. Transmit/Receive Timing

## Asynchronous Mode Interface

Although the 8273 is fully compatible with the HDLC/ SDLC communication line protocols, which are primarily designed for synchronous communication, the 8273 can also be used in asynchronous applications by using this interface. The interface employs a digital phase locked loop (DPLL) for clock recovery from a receive data stream and programmable NRZI encoding and decoding of data. The use of NRZI coding with SDLC transmission
guarantees that within a frame, data transitions will occur at least every five bit times - the longest sequence of ones which may be transmitted without zero-bit insertion. The DPLL should be used only when NRZI coding is used since the NRZI coding will transmit zero sequence as line transitions. The digital phase locked loop also facilitates full-duplex and half-duplex asynchronous implementation with, or without modems.

## Digital Phase Locked Loop

In asynchronous applications, the clock is derived from the receiver data stream by the use of the digital phase locked loop (DPLL). The DPLL requires a clock input at 32 times the required baud rate. The receive data ( $R \times D$ ) is sampled with this $\overline{32 X C L K}$ and the 8273 DPLL supplies a sample pulse nominally centered on the RxD bit cells. The DPL.L has a built-in "stiffness" which reduces sensitivity to line noise and bit distortion. This is accomplished by making phase error adjustments in discrete increments. Since the nominal pulse is made to occur at 32 counts of the $\overline{32 \times ~ C L K}$, these counts are subtracted or added to the nominal, depending upon which quadrant of the four error quadrants the data edge occurs in. For example if an RxD edge is detected in quadrant $A 1$, it is apparent that the $\overline{D P L L}$ sample " $A$ " was placed too close to the trailing edge of the data cell; sample " $B$ " will then be placed at $T=$ ( $T_{\text {nominal }}-2$ counts) $=30$ counts of the $32 \times$ CLK to move the sample pulse " $B$ " toward the nominal center of the next bit cell. A data edge occuring in quadrant B1 would cause a smaller adjustment of phase with $T=31$ counts of the $\overline{32 X ~ C L K}$. Using this technique the $\overline{D P L L}$ pulse will converge to nominal bit center within 12 data bit times, worst case, with constant incoming RxD edges.
A method of attaining bit synchronism following a line idle is to use PRE-FRAME SYNC mode of transmission.


Figure 5. DPLL Sample Timing

## Synchronous Modem - Duplex or Half Duplex Operation



## Asynchronous Modems - Duplex or Half Duplex Operation



## Asynchronous - No Modems - Duplex or Half Duplex



## SDLC Loop

The DPLL simplifies the SDLC loop station implementation. In this application, each secondary station on a loop data link is a repeater set in one-bit delay mode. The signals sent out on the loop by the loop controller (primary station) are relayed from station to station then, back to the controller. Any secondary station finding its address in the A field captures the frame for action at that station. All received frames are relayed to the next station on the loop.

Loop stations are required to derive bit timing from the incoming NRZI data stream. The DPLL generates sample Rx clock timing for reception and uses the same clock to implement Tx clock timing.


Figure 6. SDLC Loop Application

## PRINCIPLES OF OPERATION

The 8273 is an intelligent peripheral controller which relieves the CPU of many of the rote tasks associated with constructing and receiving frames. It is fully compatible with the MCS-80/85 ${ }^{\text {tM }}$ system bus. As a peripheral device, it accepts commands from a CPU, executes these commands and provides an Interrupt and Result back to the CPU at the end of the execution. The communication with the CPU is done by activation of $\overline{C S}, \overline{R D}, \overline{W R}$ pins, while the $A_{1}, A_{0}$ select the appropriate registers on the chip as described in the Hardware Description Section.

The 8273 operation is composed of the following sequence of events:


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 MUST PERFORM A READ HAS FINISHED. THE CPU MUST PERFORM A READ
OPERATION OF ONE OR MORE OF THE REGISTERS.

## The Command Phase

During the command phase, the software writes a command to the command register. The command bytes provide a general description of the type of operation requested. Many commands require more detailed information about the command. In such a case up to four parameters are written into the parameter register. The flowchart of the command phase indicates that a command may not be issued if the Status Register indicates that the device is busy. Similarly if a parameter is issued when the Parameter Buffer shows full, incorrect operation will occur.

The 8273 is a duplex device and both transmitter and receiver may each be executing a command or passing results at any given time. For this reason separate interrupt pins are provided. However, the command register must be used for one command sequence at a time.

## Status Register

The status register contains the status of the 8273 activity. The description is as follows.

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $D_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CBSY | CBF | CPBF | CRBF | RxINT | TxINT | RxIRA | TxIRA |

## Bit 7 CBSY (Command Busy)

Indicates in-progress command, set for CPU poll when Command Register is full, reset upon command phase completion. It is improper to write a command when CBSY is set; it results in incorrect operation.


Figure 7. Command Phase Flowchart

## Bit 6 CBF (Command Buffer Full)

Indicates that the command register is full, it is reset when the 8273 accepts the command byte but does not imply that execution has begun.

## Bit 5 CPBF (Command Parameter Buffer Full)

CPBF is set when the parameter buffer is full, and is reset by the 8273 when it accepts the parameter. The CPU may poll CPBF to determine when additional parameters may be written.

## Bit 4 CRBF (Command Result Buffer Full)

Indicates that an executed command immediate result is present in the Result Register. It is set by 8273 and reset when CPU reads the result.

## Bit 3 RxINT (Receiver Interrupt)

RxINT indicates that the receiver requires CPU attention. It is identical to RxINT (pin 11) and is set by the 8273 either upon good/bad completion of a specified command or by Non-DMA data transfer. It is reset only after the CPU has read the result byte or has received a data byte from the 8273 in a Non-DMA data transfer.

## Bit 2 TxINT (Transmitter Interrupt)

The TxINT indicates that the transmitter requires CPU attention. It is identical to TxINT (pin 2). It is set by 8273 either upon good/bad completion of a specified command or by Non-DMA data transfer. It is reset only after the CPU has read the result byte or has transferred transmit data byte to the 8273 in a Non-DMA transfer.

## Bit 1 RxIRA (Receiver Interrupt Result Available)

The RxiRA is set by the 8273 when an interrupt result byte is placed in the RxINT register. It is reset after the CPU has read the RxINT register.

## Bit 0 TxIRA (Transmitter Interrupt Result Available)

The TxIRA is set by the 8273 when an interrupt result byte is placed in the TxINT register. It is reset when the CPU has read the TxINT register.

## The Execution Phase

Upon accepting the last parameter, the $8273^{\prime}$ enters intoo the Execution Phase. The execution phase may consist of a DMA or other activity, and may or may not require, CPU intervention. The CPU intervention is eliminated $n$ this phase if the system utilizes DMA for the data transfers, otherwise, for non-DMA data transfers, the CPU is interrupted by the 8273 via TxINT and RxINT pins, for each data byte request.

## The Result Phase

During the result phase, the 8273 notifies the CPU of the execution outcome of a command. This phase is initiated by:

1. The successful completion of an operation
2. An error detected during an operation.

To facilitate quick network software decisions, two types of execution results are provided:

1. An Immediate Result
2. A Non-Immediate Result


Figure 8. Rx Interrupt Result Byte Format


Figure 10. Tx Interrupt Result Byte Format

Immediate result is provided by the 8273 for commands such as Read Port $A$ and Read Port B which have information ( $\overline{\mathrm{CTS}}, \overline{\mathrm{CD}}, \overline{\mathrm{RTS}}$, etc.) that the network software needs to make quick operational decisions.

A command which cannot provide an immediate result will generate an interrupt to signal the beginning of the Result phase. The immediate results are provided in the Result Register; all non-immediate results are available upon device interrupt, through Tx Interrupt Result Register TxI/R or Rx Interrupt Result Register RxI/R. The result may consist of a one-byte interrupt code indicating the
condition for the interrupt and, if required, one or more bytes which detail the condition.

## Tx and Rx Interrupt Result Registers

The Result Registers have a result code, the three high order bits $\mathrm{D}_{7}-\mathrm{D}_{5}$ of which are set to zero for all but the receive command. This command result contains a count that indicates the number of bits received in the last byte. If a partial byte is received, the high order bits of the last data byte are indeterminate.

All results indicated in the command summary must be read during the result phase.


RESULT PHASE FLOWCHART - INTERRUPT RESULTS

AFTER COMMAND PHASE COMPLETION (READ PORT A, PORT B)


## RESULT PHASE FLOWCHART - IMMEDIATE RESULTS

Figure 9. Rx Interrupt Service

## DETAILED COMMAND DESCRIPTION

## General

The 8273 HDLC/SDLC controller supports a comprehensive set of high level commands which allows the 8273 to be readily used in full-duplex, half-duplex, synchronous, asynchronous and SDLC loop configuration, with or without modems. These frame-level commands minimize CPU and software overhead. The 8273 has address and control byte buffers which allow the receive and transmit commands to be used in buffered or non-buffered modes.
In buffered transmit mode, the 8273 transmits a flag automatically, reads the Address and Control buffer registers and transmits the fields, then via DMA, it fetches the information field. The 8273, having transmitted the information field, automatically appends the Frame Check Sequence (FCS) and the end flag. Correspondingly, in buffered read mode, the Address and Control fields are stored in their respective buffer registers and only Information Field is transferred to memory.
In non-buffered transmit mode, the 8273 transmits the beginning flag automatically, then fetches and transmits the Address, Control and Information fields from the memory, appends the FCS character and an end flag. In the non-buffered receive mode the entire contents of a frame are sent to memory with the exception of the flags and FCS.

## HDLC Implementation

HDLC Address and Control field are extendable. The extension is selected by setting the low order bit of the field to be extended to a one, a zero in the low order bit indicates the last byte of the respective field.
Since Address/Control field extension is normally done with software to maximize extension flexibility, the 8273 does not create or operate upon contents of the extended HDLC Address/Control fields. Extended fields are transparently passed by the 8273 to user as either interrupt results or data transfer requests. Software must assemble the fields for transmission and interrogate them upon reception.
However, the user can take advantage of the powerful 8273 commands to minimize CPU/Software overhead and simplify buffer management in handling extended fields. For instance buffered mode can be used to separate the first two bytes, then interrogate the others from buffer. Buffered mode is perfect for a two byte address field.
The 8273 when programmed, recognizes protocol characters unique to HDLC such as Abort, which is a string of seven or more ones (01111111). Since Abort character is the same as the GA (EOP) character used in SDLC Loop applications, Loop Transmit and Receive commands are not recommended to be used in HDLC. HDLC does not support Loop mode.

## Initialization Set/Reset Commands

These commands are used to manipulate data within the 8273 registers. The Set commands have a single parameter which is a mask that corresponds to the bits to be set, (They perform a logical-OR of the specified register with the mask provided as a parameter). The Register commands have a single parameter which is a mask that has a zero in the bit positions that are to be reset. (They perform a logical-AND of the specified register with the mask).

## Set One-Bit Delay (CMD Code A4)



When one bit delay is set, 8273 retransmits the received data stream one bit delayed. This mode is entered at a receiver character boundary, and should only be used by Loop Stations.

## Reset One-Bit Delay (CMD Code 64)

|  | $A_{1}$ | $A_{0}$ | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| CMD: | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 |
| PAR: | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

The 8273 stops the one bit delayed retransmission mode.

## Set Data Transter Mode (CMD Code 97)

|  | $\mathrm{A}_{1}$ | ${ }_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 1 |
| PAR: | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

When the data transfer mode is set, the 8273 will interrupt when data bytes are required for transmission or are available from a receive. If a transmit interrupt occurs and the status indicates that there is no Transmit Result ( $T \times I R A=0$ ), the interrupt is a transmit data request. If a receive interrupt occurs and the status indicates that there is no receive result ( Rx IRA $=0$ ), the interrupt is a receive data request.

## Reset Data Transfer Mode (CMD Code 57)

| CMD: | $A_{1}$ | A |  | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ |  | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 |
| PAR: | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |

If the Data Transfer Mode is reset, the 8273 data transfers are performed through the DMA requests without interrupting the CPU.

## Set Operating Mode (CMD Code 91)



## Reset Operating Mode (CMD Code 51)



Any mode switches set in CMD code 91 can be reset using this command by placing zeros in the appropriate positions.

## (D5) HDLC Mode

In HDLC mode, a bit sequence of seven ones (01111111) is interpreted as an abort character. Otherwise, eight ones (011111111) signal an abort.

## (D4) EOP Interrupt Mode

In EOP interrupt mode, an interrupt is generated whenever an EOP character (01111111) is detected by an active receiver. This mode is useful for the implementation of an SDLC loop controller in detecting the end of a message stream after a loop poll.

## (D3) Transmitter Early Interrupt Mode (Tx)

The early interrupt mode is specified to indicate when the 8273 should generate an end of frame interrupt. When set, an early interrupt is generated when the last data character has been passed to the 8273 . If the user software responds with another transmit command before the final flag is sent, the final flag interrupt will not be generated and a new frame will immediately begin when the current frame is complete. This permits frames to be separated by a single flag. If no additional Tx commands are provided, a final interrupt will follow.

If this bit is zero, the interrupt will be generated only after the final flag has been transmitted.

## (D2) Buffered Mode

If the buffered mode bit is set to a one, the first two bytes (normally the address (A) and control (C) fields) of a frame are buffered by the 8273. If this bit is a zero the address and control fields are passed to and from memory.

## (D1) Preframe Sync Mode

If this bit is set to a one the 8273 will transmit two characters before the first flag of a frame.
To guarantee sixteen line transitions, the 8273 sends two bytes of data $(00)_{H}$ if NRZI is set or data $(55)_{\mathrm{H}}$ if NRZI is not set.

## (D0) Flag Stream Mode

If this bit is set to a one, the following table outlines the operation of the transmitter.


If this bit is reset to zero the following table outlines the operation of the transmitter.

| TRANSMITTER STATE | ACTION |
| :--- | :--- |
| IDLE | Send Idles on next character <br> boundary. |
| Transmit or Transmit- | Send Idles after the transmission <br> Transparent Active <br> is complete. <br> Loop Transmit Active <br> Ignore command. <br> 1 Bit Delay Active |

## Set Serial I/O Mode (CMD Code AO)



## Reset Serial I/O Mode (CMD Code 60)

This command allows bits set in CMD code AO to be reset by placing zeros in the appropriate positions.


## (D2) Loop Back

If this bit is set to a one, the transmit data is internally routed to the receive data circuitry.
(D1) TxC $\rightarrow$ RxC
If this bit is set to a one, the transmit clock is internally routed to the receive clock circuitry. It is normally used with the loop back bit (D2).

## (D0) NRZI Mode

If this bit is set to a one, NRZI encoding and decoding of transmit and receive data is provided. If this bit is a zero, the transmit and receive data is treated as a normal positive logic bit stream.
NRZI encoding specifies that a zero causes a change in the polarity of the transmitted signal and a one causes no polarity change. NRZI is used in all asynchronous operations. Refer to IBM document GA27-3093 for details.

## Reset Device Command

| TMR: | A | $A_{0}$ | $\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 | 0 | 0 | 0 | 0 | 0 | 1 |
| TMR: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

An 8273 reset command is executed by outputing a $(01)_{\mathrm{H}}$ followed by $(00)_{H}$ to the reset register (TMR). See 8273 AC timing characteristics for Reset pulse specifications.

The reset command emulates the action of the reset pin.

1. The modem control signals are forced high (inactive level).
2. The 8273 status register flags are cleared.
3. Any commands in progress are terminated immediately.
4. The 8273 enters an idle state until the next command is issued.
5. The Serial I/O and Operating Mode registers are set to zero and DMA data register transfer mode is selected.
6. The device assumes a non-loop SDLC terminal role.

## Receive Commands

The 8273 supports three receive commands: General Receive, Selective Receive, and Selective Loop Receive.

## General Receive (CMD Code C0)

General receive is a receive mode in which frames are received regardless of the contents of the address field.


## NOTES:

1. If buffered mode is specified, the R0; R1 receive frame length (result) is the number of data bytes received.
2. If non-buffered mode is specified, the R0, R1 receive frame length (result) is the number of data bytes received plus two (the count includes the address and control bytes).
3. The frame check sequence (FCS) is not transferred to memory.
4. Frames with less than 32 bits between flags are ignored (no interrupt generated) if the buffered mode is specified.
5. In the non-buffered mode an interrupt is generated when a less than 32 bit frame is received, since data transfer requests have occurred.
6. The 8273 receiver is always disabled when an Idle is received after a valid frame. The CPU module must issue a receive command to re-enable the receiver.
7. The intervening ABORT character between a final flag and an IDLE does not generate an interrupt.
8. If an ABORT Character is not preceded by a flag and is followed by an IDLE, an interrupt will be generated for the ABORT followed by an IDLE interrupt one character time later. The reception of an ABORT will disable the receiver.

## Selective Receive (CMD Code C1)

|  |  | $A_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |
| PAR: | 0 | 1 | LEAST SIGNIFICANT BYTE OF THE RECEIVE BUFFER LENGTH (BO) |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | MOST SIGNIFICANT BYTE OF RECEIVE BUFFER LENGTH (B1) |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | RECEIVE FRAME ADDRESS MATCH FIELD ONE (A1) |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | RECEIVE FRAME ADDRESS MATCH FIELD TWO (A2) |  |  |  |  |  |  |  |

Selective receive is a receive mode in which frames are ignored unless the address field matches any one of two address fields given to the 8273 as parameters.
When selective receive is used in HDLC the 8273 looks at the first character, if extended, software must then decide if the message is for this unit.

## Selective Loop Receive (CMD Code C2)



Selective loop receive operates like selective receive except that the transmitter is placed in flag stream mode automatically after detecting an EOP (01111111) following a valid received frame. The one bit delay mode is also reset at the end of a selective loop receive.


## Receive Disable (CMD Code C5)

Terminates an active receive command immediately.


## Transmit Commands

The 8273 supports three transmit commands: Transmit Frame, Loop Transmit, Transmit Transparent.

## Transmit Frame (CMD Code C8)

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | D7 | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 |  |
| PAR: | 0 | 1 | LEAST SIGNIFICANT BYTE OF FRAME LENGTH (LO) |  |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | MOST SIGNIFICANT BYTE OF FRAME LENGTH (L1) |  |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | ADDRESS FIELD OF TRANSMIT FRAME (A) |  |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | CONTROL FIELD OF TRANSMIT FRAME (C) |  |  |  |  |  |  |  |  |

Transmits one frame including: initial flag, frame check sequence, and the final flag.

If the buffered mode is specified, the LO, L1, frame length provided as a parameter is the length of the information field and the address and control fields must be input.
In unbuffered mode the frame length provided must be the length of the information field plus two and the address and control fields must be the first two bytes of data. Thus only the frame length bytes are required as parameters.

## Loop Transmit (CMD Code CA)

|  | $A_{1}$ | $A_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 |
| PAR: | 0 | 1 | LEAST SIGNIFICANT BYTE OF FRAME LENGTH (LO) |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | MOST SIGNIFICANT BYTE OF FRAME LENGTH (L1) |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | ADDRESS FIELD OF TRANSMIT FRAME (A) |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | CONTROL FIELD OF TRANSMIT FRAME (c) |  |  |  |  |  |  |  |

Transmits one frame in the same manner as the transmit frame command except:

1. This command should be given only in one-bit delay mode.
2. If the flag stream mode is not active transmission will begin after a received EOP hàs been converted to a flag.
3. If the flag stream mode is active transmission will begin at the next flag boundary for buffered mode or at the third flag boundary for non-buffered mode.
4. At the end of a loop transmit the one-bit delay mode is entered and the flag stream mode is reset.

## Transmit Transparent (CMD Coded ©9)



The 8273 will transmit a block of raw data without protocol, i.e., no zero bit insertion, flags, or frame check sequences.

## Abort Transmit Commands

An abort command is supported for each type of transmit command. The abort commands are ignored if a transmit command is not in progress.

## Abort Transmit Frame (CMD Code CC)



After an abort character (eight contiguous ones) is transmitted, the transmitter reverts to sending flags or idles as a function of the flag stream mode specified.

## Abort Loop Transmit (CMD Code CE)



After a flag is transmitted the transmitter reverts to one bit delay mode.

## Abort Transmit Transparent (CMD Code CD)



The transmitter reverts to sending flags or idles as a function of the flag stream mode specified.

## Modem Control Commands

The modem control commands are used to manipulate the modem control ports.

When read Port A or Port B commands are executed the result of the command is returned in the result register. The Bit Set Port B command requires a parameter that is a mask that corresponds to the bits to be set. The Bit Reset Port B command requires a mask that has a zero in the bit positions that are to be reset.

## Read Port A (CMD Code 22)



## Read Port B (CMD Code 23)



## Set Port B Bits (CMD Code A3)

This command allows user defined Port $B$ pins to be set.


## (D5) Flag Detect

This bit can be used to set the flag detect pin: However, it will be reset when the next flag is detected.
(D4-D1) User Defined Outputs
These bits correspond to the state of the $\mathrm{PB}_{4}-\mathrm{PB}_{1}$ outpuf pins.
(Do) Request to Send
This is a dedicated 8273 modem control signal, and reflects the same logical state of RTS pin.

## Reset Port B Bits (CMD Code 63)

This command allows Port $B$ user defined bits to be reset.


This command allows Port B ( $\left.D_{4}-D_{1}\right)$ user defined bits to be reset. These bits correspond to Output Port pins (PB4$P B_{1}$ ).

## 8273 Command Summary

| Command Description | Command (HEX) | Parameter | Results | Result Port | Completion Interrupt |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Set One Bit Delay | A4 | Set Mask | None | - | No |
| Reset One Bit Delay | 64 | Reset Mask | None | - | No |
| Set Data Transfer Mode | 97 | Set Mask | None | - | No |
| Reset Data Transfer Mode | 57 | Reset Mask | None | - | No |
| Set Operating Mode | 91 | Set Mask | None | - | No |
| Reset Operating Mode | 51 | Reset Mask | None | - | No |
| Set Serial I/O Mode | AO | Set Mask | None | - | No |
| Reset Serial I/O Mode | 60 | Reset Mask | None | - | No |
| General Receive | C0 | B0,B1 | RIC,R0,R1, (A,C) ${ }^{(2)}$ | RXI/R | Yes |
| Selective Receive | C1 | B0,B1,A1,A2 | RIC,R0,R1, $(\mathrm{A}, \mathrm{C})^{(2)}$ | RXI/R | Yes |
| Selective Loop Receive | C2 | B0,B1,A1,A2 | RIC,R0,R1, (A,C) ${ }^{(2)}$ | RXI/R | Yes |
| Receive Disable | C5 | None | None | - | No |
| Transmit Frame | C8 | L0,L1, (A,C) ${ }^{(1)}$ | TIC | TXI/R | Yes |
| Loop Transmit | CA | L0,L1, (A,C) ${ }^{(1)}$ | TIC | TXI/R | Yes |
| Transmit Transparent | C9 | L0,L1 | TIC | TXI/R | Yes |
| Abort Transmit Frame | CC | None | TIC | TXI/R | Yes |
| Abort Loop Transmit | CE | None | TIC | TXI/R | Yes |
| Abort Transmit Transparent | CD | None | TIC | TXI/R | Yes |
| Read Port A | 22 | None | Port Value | Result | No |
| Read Port B | 23 | None | Port Value | Result | No |
| Set Port B Bit | A3 | Set Mask | None | - | No |
| Reset Port B Bit | 63 | Reset Mask | None | - | No |

Notes: 1. Issued only when in buffered mode. 2. Read as results only in buffered mode.

## 8273 Command Summary Key

B0 - Least significant byte of the receive buffer length.
B1 - Most significant byte of the receive buffer length.
L0 - Least significant byte of the Tx frame length.
L1 - Most significant byte of the Tx frame length.
A1 - Receive frame address match field one.
A2 - Receive frame address match field two.
A - Address field of received frame. If non-buffered mode is specified, this result is not provided.
C - Control field of received frame. If non-buffered mode is specified this result is not provided.
$\mathbf{R X I} / \mathbf{R}$ - Receive interrupt result register.
TXI/R - Transmit interrupt result register.
R0 - Least significant byte of the length of the frame received.
R1 - Most significant byte of the length of the frame received.
RIC - Receiver interrupt result code.
TIC - Transmitter interrupt result code.


| DATA IN | $\begin{aligned} & \text { IDLE } \\ & \text { OR } \\ & \text { FLAG } \end{aligned}$ | $\begin{aligned} & \text { IDLE } \\ & \text { OR } \\ & \text { FLAG } \end{aligned}$ | FLAG | A | C | $I_{1}$ | FCS ${ }_{1}$ | $\mathrm{FCS}_{2}$ | FLAG | $\begin{aligned} & \text { FLAG } \\ & \text { OR } \\ & \text { ABORT } \end{aligned}$ | $\begin{aligned} & \text { FLAG } \\ & \text { OR } \\ & \text { IDLE } \end{aligned}$ | $\begin{gathered} \text { FLAG } \\ \text { OR } \\ \text { IDLE } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |



Figure 12. Typical Frame Reception


| Tx DATA | $\begin{aligned} & \text { IDLE } \\ & \text { OR } \\ & \text { FLAG } \end{aligned}$ | $\begin{aligned} & \text { IDLE } \\ & \text { OR } \\ & \text { FLAG } \end{aligned}$ | FLAG | A | C | 1 | $\mathrm{I}_{2}$ | $I_{3}$ | $\mathrm{FCS}_{1}$ | $\mathrm{FCS}_{2}$ | FLAG | $\begin{aligned} & \text { IDLE } \\ & \text { OR } \\ & \text { FLAG } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |



CTS


Figure 13. Typical Frame Transmission


Figure 14. 8273 System Diagram

## 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 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}, V_{C C}=+5.0 \mathrm{~V} \pm 5 \%$

| 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}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ for Data Bus pins <br> I |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \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{OZ}}$ | Off-State Output Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to OV |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 180 | mA |  |

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{VCC}=\mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{t}_{\mathrm{c}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured Pins <br> Returned to GND |

## A.C. CHARACTERISTICS <br> $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%$

Read Cycle

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A C}$ | Select Setup to $\overline{R D}$ | 0 |  | ns | Note 3 |
| $t_{C A}$ | Select Hold from $\overline{R D}$ | 0 |  | ns | Note 3 |
| $t_{R R}$ | RD Pulse Width | 0 |  | ns |  |
| $t_{A D}$ | Data Delay from Address |  | 250 | ns | Note 3 |
| $t_{R D}$ | Data Delay from $\overline{R D}$ |  | 150 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$, Note 3 |
| $t_{D F}$ | Output Float Delay | 20 | 100 | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ for Minimum; <br> 150 pF for Maximum |
| $t_{D C}$ | DACK Setup to $\overline{R D}$ | 25 |  | ns |  |
| $t_{C D}$ | DACK Hold from $\overline{R D}$ | 25 |  | ns |  |
| $t_{K D}$ | Data Delay from $\overline{D A C K}$ |  | 250 | ns |  |

Write Cycle

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A C}$ | Select Setup to $\overline{W R}$ | 0 |  | ns |  |
| $t_{C A}$ | Select Hold from $\overline{W R}$ | 0 |  | ns |  |
| $t_{W W}$ | $\overline{W R}$ Pulse Width | 250 |  | ns |  |
| $t_{D W}$ | Data Setup to $\overline{W R}$ | 150 |  | ns |  |
| $t_{W D}$ | Data Hold from $\overline{W R}$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{DC}}$ | DACK Setup to $\overline{\mathrm{WR}}$ | 25 |  | ns |  |
| $t_{C D}$ | DACK Hold from $\overline{W R}$ | 25 |  | ns |  |

DMA

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $t_{\mathrm{CQ}}$ | Request Hold from $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ (for Non-Burst Mode) |  | 150 | ns |  |

Other Timing

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {RSTW }}$ | Reset Pulse Width | 10 |  | $t_{\text {CY }}$ |  |
| $t_{r}$ | Input Signal Rise Time |  | 20 | ns |  |
| $t_{f}$ | Input Signal Fall Time |  | 20 | ns |  |
| $\mathrm{t}_{\text {RSTS }}$ | Reset to First $\overline{\text { IOWR }}$ | 2 |  | $t_{\text {cY }}$ |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Clock | 250 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock Low | 110 |  | ns |  |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock High | 122 |  | ns |  |
| ${ }^{\text {t }}$ DCL | Data Clock Low | 200 |  | ns |  |
| $t_{\text {DCH }}$ | Data Clock High | 200 |  | ns |  |
| $t_{\text {DCY }}$ | Data Clock | 15625 |  | ns | Note 2 |
| ${ }_{t}{ }_{\text {D }}$ | Transmit Data Delay |  | 100 | ns |  |
| $t_{\text {DS }}$ | Data Setup Time | 100 |  | ns |  |
| $t_{\text {DH }}$ | Data Hold Time | 0 |  | ns |  |
| $t_{\text {DPLL }}$ | $\overline{\text { DPLL Output Low }}$ | 200 |  | ns |  |
| $\mathrm{t}_{\text {FLD }}$ | FLAG DET Output Low | $8 \cdot t_{\mathrm{CY}} \pm 50$ |  | ns |  |

## NOTES:

1. All timing measurements are made at the reference voltages uniess otherwise specified: Input " 1 " at 2.0 V , " 0 " at 0.8 V Output " 1 " at 2.0 V , " 0 " at 0.8 V
2. $\mathbf{6 4 K}$ baud maximum operating rate.
3. $t_{A D}, t_{R D}, t_{A C}$, and $t_{C A}$ are not concurrent specs.

WAVEFORMS
Read Waveforms


## Write Waveforms



## DMA Waveforms



CHIP CLOCK


## Transmit Data Waveforms



## Receive Data Waveforms



## DPLL Output Waveform



## Flag Detect Output Waveform

FLAG DET

## 8275 <br> PROGRAMMABLE CRT CONTROLLER

Programmable Screen and Character Format

## 6 Independent Visual Field Attributes

## 11 Visual Character Attributes

 (Graphic Capability)Cursor Control (4 Types)
Light Pen Detection and Registers

- Fully MCS-80 ${ }^{\text {TM }}$ and MCS-85 ${ }^{\text {TM }}$ Compatible
- Dual Row Buffers
- Programmable DMA Burst Mode
- Single +5V Supply
- 40-Pin Package

The Intel ${ }^{\circledR} 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



PIN NAMES

| DB $_{0-1}$ | B1-DIRECTIONAL DATA BUS | LC $_{0-3}$ | LINE COUNTER OUTPUTS |
| :--- | :--- | :--- | :--- |
| DRO | DMA REQUEST OUTPUT | LA $A_{0-1}$ | LINE ATTRIBUTE OUTPUTS |
| $\overline{D A C K ~}$ | DMA ACKNOWLEDGE INPUT | HRTC | HORIZONTAL RETRACE OUTPUT |
| $\overline{I R Q}$ | INTERRUPT REQUEST OUTPUT | VRTC | VERTICAL RETRACE OUTPUT |
| $\overline{R D}$ | READ STROBE INPUT | HLGT | HIGHLIGHT OUTPUT |
| $\overline{W R}$ | WRITE STROBE INPUT | RVV | REVERSE VIDEO OUTPUT |
| $A_{0}$ | REGISTER ADDRESS INPUT | LTEN | LIGHT ENABLE OUTPUT |
| $\overline{C S}$ | CHIP SELECT INPUT | VSP | VIDEO SUPPRESS OUTPUT |
| CCLK | CHARACTER CLOCK INPUT | GPA $0-1$ | GENERAL PURPOSE ATTRIBUTE OUTPUTS |
| $C_{0}-6$ | CHARACTER CODE OUTPUTS | LPEN | LIGHT PEN INPUT |

BLOCK DIAGRAM


PIN DESCRIPTIONS

| Pin \# | Pin Name | 110 | Pin Description |
| :---: | :---: | :---: | :---: |
| 1 | $\mathrm{LC}_{3}$ | 0 | Line count. Output from the line count- |
| 2 | $L^{L}{ }_{2}$ |  | er which is used to address the character |
| 3 | $L^{\text {L }} 1$ |  | generator for the line positions on the |
| 4 | $L^{\text {c }} 0$ |  | screen. |
| 5 | DRQ | 0 | DMA request. Output signal to the 8257 DMA controller requesting a DMA cycle. |
| 6 | $\overline{\text { DACK }}$ | 1 | DMA acknowledge. Input signal from the 8257 DMA controller acknowledging that the requested DMA cycle has been granted. |
| 7 | HRTC | 0 | Horizontal retrace. Output signal which is active during the programmed horizonta' retrace interval. During this period the VSP output is high and the LTEN output is low. |
| 8 | VRTC | 0 | 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. |
| 9 | $\overline{R D}$ | 1 | Read input. A control signal to read registers. |
| 10 | $\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. |
| 11 | LPEN | 1 | Light pen. Input signal from the CRT system signıfying that a light pen signal has been detected. |
| 12 | $\mathrm{DB}_{0}$ | 1/0 | Bi-directional three-state data bus lines. |
| 13 | DB1 |  | 7 he outputs are enabled during a read of |
| 14 | $\mathrm{DB}_{2}$ |  | the C or P ports. |
| 15 | $\mathrm{DB}_{3}$ |  |  |
| 16 | $\mathrm{DB}_{4}$ |  |  |
| 17 | $\mathrm{DB}_{5}$ |  |  |
| 18 | $\mathrm{DB}_{6}$ |  |  |
| 19 | DB7 |  |  |
| 20 | Ground |  | Ground |


| Pin \# |  |  | Pin Description |
| :---: | :---: | :---: | :---: |
| 40 | $V_{\text {CC }}$ |  | +5V power supply |
| $\begin{aligned} & 39 \\ & 38 \end{aligned}$ | $\begin{aligned} & \mathrm{LA}_{0} \\ & \mathrm{LA}_{1} \end{aligned}$ | 0 | 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. |
| 37 | LTEN | 0 | 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 attribute codes. |
| 36 | RVV | 0 | 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. |
| 35 | VSP | 0 | 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 underline is proarammed to be number 8 or greater.
- 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.
$\mathrm{CC}_{5}$ buffers used for character selection in


## FUNCTIONAL DESCRIPTION

## Data Bus Buffer

This 3 -state, bidirectional, 8 -bit buffer is used to interface the 8275 to the system Data Bus.

This functional block accepts inputs from the System Control Bus and generates control signals for overall device operation. It contains the Command, Parameter, and Status Registers that store the various control formats for the device functional definition.

| $A_{0}$ | OPERATION | REGISTER |
| :---: | :---: | :---: |
| 0 | Read | PREG |
| 0 | Write | PREG |
| 1 | Read | SREG |
| 1 | Write | CREG |

## RD (Read)

A "low" on this input informs the 8275 that the CPU is reading data or status information from the 8275.

## WR (Write)

A "low" on this input informs the 8275 that the CPU is writing data or control words to the 8275 .

## $\overline{\mathbf{C S}}$ (Chip Select)

A "low" on this input selects the 8275 . 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.

## DRQ (DMA Request)

A "high" on this output informs the DMA Controller that the 8275 desires a DMA transfer.

## DACK (DMA Acknowledge)

A "low" on this input informs the 8275 that a DMA cycle is in progress.

## IRQ (Interrupt Request)

A "high" on this output informs the CPU that the 8275 desires interrupt service.

Figure 1. 8275 Block Diagram Showing Data Bus Buffer and Read/Write Functions

| $\mathbf{A}_{\mathbf{0}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\overline{\mathbf{C S}}$ |  |
| :---: | :---: | :---: | :---: | :--- |
| $\mathbf{0}$ | 0 | 1 | 0 | Write 8275 Parameter |
| 0 | 1 | 0 | 0 | Read 8275 Parameter |
| 1 | 0 | 1 | 0 | Write 8275 Command |
| 1 | 1 | 0 | 0 | Read 8275 Status |
| X | 1 | 1 | 0 | Three-State |
| X | X | X | 1 | Three-state |



## Character Counter

The Character Counter is a programmable counter that is used to determine the number of characters to be displayed per row and the length of the horizontal retrace interval. It is driven by the CCLK (Character Clock) input, which should be a derivative of the external dot clock.

## Line Counter

The Line Counter is a programmable counter that is used to determine the number of horizontal lines (Sweeps) per character row. Its outputs are used to address the external character generator ROM.

## Row Counter

The Row Counter is a programmable counter that is used to determine the number of character rows to be displayed per frame and length of the vertical retrace interval.

## Light Pen Registers

The Light Pen Registers are two registers that store the contents of the character counter and the row counter whenever there is a rising edge on the LPEN (Light Pen) input.

Note: Software correction is required.

## Raster Timing and Video Controls

The Raster Timing circuitry controls the timing of the HRTC (Horizontal Retrace) and VRTC (Vertical Retrace) outputs. The Video Control circuitry controls the generation of LA $0-1$ (Line Attribute), HGLT (Highlight), RVV (Reverse Video), LTEN (Light Enable), VSP (Video Suppress), and GPA O-1 $^{1}$ (General Purpose Attribute) outputs.

## Row Buffers

The Row Buffers are two 80 character buffers. They are filled from the microcomputer system memory with the character codes to be displayed. While one row buffer is displaying a row of characters, the other is being filled with the next row of characters.


Figure 2. 8275 Block Diagram Showing Counter and Register Functions

## FIFOs

There are two 16 character FIFOs in the 8275 . They are used to provide extra row buffer length in the Transparent Attribute Mode (see Detailed Operation section).

## Buffer Input/Output Controllers

The Buffer Input/Output Controllers decode the characters being placed in the row buffers. If the character is a character attribute, field attribute or special code, these controllers control the appropriate action. (Examples: An "End of Screen-Stop DMA" special code will cause the Buffer Input Controller to stop further DMA requests. A "Highlight" field attribute will cause the Buffer Output Controller to activate the HGLT output.)

## SYSTEM OPERATION

The 8275 is programmable to a large number of different display formats. It provides raster timing, display row buffering, visual attribute decoding, cursor timing, and light pen detection.

It is designed to interface with the 8257 DMA Controller and standard character generator ROMs for dot matrix decoding. Dot level timing must be provided by external circuitry.


Figure 3. 8275 Systems Block Diagram Showing Systems Operation

## General Systems Operational Description

The 8275 provides a "window" into the microcomputer system memory.

Display characters are retrieved from memory and displayed on a row by row basis. The 8275 has two row buffers. While one row buffer is being used for display, the other is being filled with the next row of characters to be displayed. The number of display characters per row and the number of character rows per frame are software programmable, providing easy interface to most CRT displays. (See Programming Section.)

The 8275 requests DMA to fill the row buffer that is not being used for display. DMA burst length and spacing is programmable. (See Programming Section.)

The 8275 displays character rows one line at a time.

The number of lines per character row, the underline position, and blanking of top and bottom lines are programmable. (See Programming Section.)

The 8275 provides special Control Codes which can be used to minimize DMA or software overhead. It also provides Visual Attribute Codes to cause special action or symbols on the screen without the use of the character generator (see Visual Attributes Section).
The 8275 also controls raster timing. This is done by generating Horizontal Retrace (HRTC) and Vertical Retrace (VRTC) signals. The timing of these signals is programmable.

The 8275 can generate a cursor. Cursor location and format are programmable. (See Programming Section.)
The 8275 has a light pen input and registers. The light pen input is used to load the registers. Light pen registers can be read on command. (See Programming Section.)


Second Line of a Character Row


Seventh Line of a Character Row


Figure 4. Display of a Character Row

## Display Row Buffering

Before the start of a frame, the 8275 requests DMA and one row buffer is filled with characters.


Figure 5. First Row Buffer Filled

When the first horizontal sweep is started, character codes are output to the character generator from the row buffer just filled. Simultaneously, DMA begins filling the other row buffer with the next row of characters.


Figure 6. Second Buffer Filled, First Row Displayed

After all the lines of the character row are scanned, the roles of the two row buffers are reversed and the same procedure is followed for the next row.


Figure 7. First Buffer Filled with Third Row, Second Row Displayed

This is repeated until all of the character rows are displayed.

## Display Format

## Screen Format

The 8275 can be programmed to generate from 1 to 80 characters per row, and from 1 to 64 rows per frame.


Figure 8. Screen Format

The 8275 can also be programmed to blank alternate rows. In this mode, the first row is displayed, the second blanked, the third displayed, etc. DMA is not requested for the blanked rows.


Figure 9. Blank Alternate Rows Mode

## Row Format

The 8275 is designed to hold the line count stable while outputting the appropriate character codes during each horizontal sweep. The line count is incremented during horizontal retrace and the whole row of character codes are output again during the next sweep. This is continued until the whole character row is displayed.

The number of lines (horizontal sweeps) per character row is programmable from 1 to 16.
The output of the line counter can be programmed to be in one of two modes.

In mode 0 , the output of the line counter is the same as the line number.
In mode 1, the line counter is offset by one from the line number.

Note: In mode 1, while the first line (line number 0 ) is being displayed, the last count is output by the line counter (see examples).

| Line Number |  |  |  |  |  |  |  |  |  | Line Counter Mode 0 | Line Counter Mode 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0000 | 1111 |
| 1 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0001 | 0000 |
| 2 | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | - | 0010 | 0001 |
| 3 | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | 0011 | 0010 |
| 4 | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 0100 | 0011 |
| 5 | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | 0101 | 0100 |
| 6 | $\square$ | - | $\square$ | - | - | ■ | ■ | ! | $\square$ | 0110 | 0101 |
| 7 | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0111 | 0110 |
| 8 | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1000 | 0111 |
| 9 | ㅁ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 1001 | 1000 |
| 10 | ㅁ | - | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | 1010 | 1001 |
| 11 | $\square$ | - | - | - | $\square$ | - | $\square$ | $\square$ | $\square$ | 1011 | 1010 |
| 12 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1100 | 1011 |
| 13 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1101 | 1100 |
| 14 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | 1110 | 1101 |
| 15 | - | - | $\square$ | - | $\square$ | - | $\square$ | $\square$ | $\square$ | 1111 | 1110 |

Figure 10. Example of a 16-Line Format

| Line Number |  |  |  |  |  |  |  | Line Counter Mode 0 | Line Counter Mode 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0000 | 1001 |
| 1 | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | 0001 | 0000 |
| 2 | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | 0010 | 0001 |
| 3 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 0011 | 0010 |
| 4 | $\square$ | - | - | $\square$ | $\square$ | $\square$ | $\square$ | 0100 | 0011 |
| 5 | $\square$ | - | - | - | - | - | $\square$ | 0101 | 0100 |
| 6 | $\square$ | - | $\square$ | $\square$ | $\square$ | - | $\square$ | 0110 | 0101 |
| 7 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 0111 | 0110 |
| 8 | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | 1000 | 0111 |
| 9 | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | 1001 | 1000 |

Figure 11. Example of a $\mathbf{1 0}$-Line Format

Mode 0 is useful for character generators that leave address zero blank and start at address 1 . Mode 1 is useful for character generators which start at address zero.

Underline placement is also programmable（from line num－ ber 0 to 15）．This is independent of the line counter mode．

If the line number of the underline is greater than 7 （line number MSB $=1$ ），then the top and bottom lines will be blanked．

| Line Number |  |  |  |  |  |  |  |  |  | Line Counter Mode 0 | Line Counter Mode 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0 | $\square$ | $\square$ | $\square$ | 0000 | 1011 |
| 1 | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | 0001 | 0000 |
| 2 | $\square$ | $\square$ | $\square$ | － | $\square$ | － | $\square$ | $\square$ | $\square$ | 0010 | 0001 |
| 3 | 口 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\bullet$ | $\square$ | $\square$ | 0011 | 0010 |
| 4 | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | 0100 | 0011 |
| 5 | $\square$ | － | $\square$ | － | － | － | － | － | $\square$ | 0101 | 0100 |
| 6 | $\square$ | － | $\square$ | － | － | － | $\square$ | $\square$ | $\square$ | 0110 | 0101 |
| 7 | 口 | － | $\square$ | $\square$ | $\square$ | $\square$ | 口 | $\square$ | $\square$ | 0111 | 0110 |
| 8 | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1000 | 0111 |
| 9 | 口 | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | 1001 | 1000 |
| 10 | － | － | － | － | － | － | － | － | － | 1010 | 1001 |
| 11 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1011 | 1010 |
| Top and Bottom Lines are Blanked |  |  |  |  |  |  |  |  |  |  |  |

Figure 12．Underline in Line Number 10

If the line number of the underline is less than or equal to 7 （line number MSB $=0$ ），then the top and bottom lines will
not be blanked．


Figure 13．Underline in Line Number 7

If the line number of the underline is greater than the maxi－ mum number of lines，the underline will not appear．
Blanking is accomplished by the VSP（Video Suppression） signal．Underline is accomplished by the LTEN（Light Enable）signal．

Top and Bottom
Lines are not Blanked

## Dot Format

Dot width and character width are dependent upon the external timing and control circuitry．

Dot level timing circuitry should be designed to accept the parallel output of the character generator and shift it out serially at the rate required by the CRT display．


Figure 14．Typical Dot Level Block Diagram

Dot width is a function of dot clock frequency．
Character width is a function of the character generator width．

Horizontal character spacing is a function of the shift register length．
Note：Video control and timing signals must be synchronized with the video signal due to the character generator access delay．

## 8275

## Raster Timing

The character counter is driven by the character clock input (CCLK). It counts out the characters being displayed (programmable from 1 to 80 ). It then causes the line counter to increment, and it 'starts counting out the horizontal retrace interval (programmable from 2 to 32). This is constantly repeated.


Figure 15. Line Timing

The line counter is driven by the character counter. It is used to generate the line address outputs ( $\mathrm{LC}_{0-3}$ ) for the character generator. After it counts all of the lines in a character row (programmable from 1 to 16), it increments the row counter, and starts over again. (See Character Format Section for detailed description of Line Counter functions.)

The row counter is an internal counter driven by the line counter. It controls the functions of the row buffers and counts the number of character rows displayed.


Figure 16. Row Timing

After the row counter counts all of the rows in a frame (programmable from 1 to 64), it starts counting out the vertical retrace interval (programmable from 1 to 4).


Figure 17. Frame Timing

The Video Suppression Output (VSP) is active during horizontal and vertical retrace intervals.

Dot level timing circuitry must synchronize these outputs with the video signal to the CRT Display.

## DMA Timing

The 8275 can be programmed to request burst DMA transfers of 1 to 8 characters. The interval between bursts is also programmable (from 0 to 55 character clock periods $\pm 1$ ). This allows the user to tailor his DMA overhead to fit his system needs.

The first DMA request of the frame occurs one row time before the end of vertical retrace. DMA requests continue as programmed, until the row buffer is filled. If the row buffer is filled in the middle of a burst, the 8275 terminates the burst and resets the burst counter. No more DMA requests will occur until the beginning of the next row. At that time, DMA requests are activated as programmed until the other buffer is filled.

If, for any reason, there is a DMA underrun, a flag in the status word will be set.


Figure 18. DMA Timing

The DMA controller is typically initialized for the next frame at the end of the current frame.

## Interrupt Timing

The 8275 can be programmed to generate an interroupt request at the end of each frame. This can be used to reinitialize the DMA controller. If the 8275 interrupt enable flag is set, an interrupt request will occur at the beginning of the last display row.


Figure 19. Beginning of Interrupt Request

IRO will go inactive after the status register is read.


Figure 20. End of Interrupt Request

A reset command will also cause IRQ to go inactive, but this is not recommended during normal service.
Another method of reinitializing the DMA controller is to have the DMA controller itself interrupt on terminal count. With this method, the 8275 interrupt enable flag should not be set.

Note: Upon power-up, the 8275 Interrupt Enable Flag may be set. As a result, the user's cold start routine should write a reset command to the 8275 before system interrupts are enabled.

## VISUAL ATTRIBUTES AND SPECIAL CODES

The characters processed by the 8275 are 8 -bit quantities. The character code outputs provide the character generator with 7 bits of address. The Most Significant Bit is the extra bit and it is used to determine if it is a normal display character ( $M S B=0$ ), or if it is a Visual Attribute or Special Code (MSB = 1).

There are two types of Visual Attribute Codes. They are Character Attributes and Field Attributes.

## Character Attribute Codes

Character attribute codes are codes that can be used to generate graphics symbols without the use of a character generator. This is accomplished by selectively activating the Line Attribute outputs ( ${\left.L A_{0-1}\right) \text { ), the Video Suppresion }}^{2}$ output (VSP), and the Light Enable output. The dot level timing circuitry can use these signals to generate the proper symbols.

Character attributes can be programmed to blink or be highlighted individually. Blinking is accomplished with the Video Suppression output (VSP). Blink frequency is equal to the screen refresh frequency divided by 32 . Highlighting is accomplished by activating the Highlight output (HGLT).

## Character Attributes



CHARACTER ATTRIBUTE CODE


Figure 21. Typical Character Attribute Logic

Character attributes were designed to produce the following graphics:

| CHARACTER ATTRIBUTE CODE "CCCC" |  | OUTPUTS |  |  |  | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LA1 | LA0 | VSP | LTEN |  |  |
| 0000 | Above Underline | 0 | 0 | 1 | 0 |  | Top Left Corner |
|  | Underline | 1 | 0 | 0 | 0 |  |  |
|  | Below Underline | 0 | 1 | 0 | 0 |  |  |
| 0001 | Above Underline | 0 | 0 | 1 | 0 |  | Top Right Corner |
|  | Underline | 1 | 1 | 0 | 0 |  |  |
|  | Below Underline | 0 | 1 | 0 | 0 |  |  |
| 0010 | Above Underline | 0 | 1 | 0 | 0 |  | Bottom Left Corner |
|  | Underline | 1 | 0 | 0 | 0 |  |  |
|  | Below Underline | 0 | 0 | 1 | 0 |  |  |
| 0011 | Above Underline | 0 | 1 | 0 | 0 |  | Bottom Right Corner |
|  | Underline | 1 | 1 | 0 | 0 |  |  |
|  | Below Underline | 0 | 0 | 1 | 0 |  |  |
| 0100 | Above Underline | 0 | 0 | 1 | 0 |  | Top Intersect |
|  | Underline | 0 | 0 | 0 | 1 |  |  |
|  | Below Underline | 0 | 1 | 0 | 0 |  |  |
| 0101 | Above Underline | 0 | 1 | 0 | 0 |  | Right Intersect |
|  | Underline | 1 | 1 | 0 | 0 |  |  |
|  | Below Underline | 0 | 1 | 0 | 0 |  |  |
| 0110 | Above Underline | 0 | 1 | 0 | 0 |  | Left Intersect |
|  | Underline | 1 | 0 | 0 | 0 |  |  |
|  | Below Underline | 0 | 1 | 0 | 0 |  |  |
| 0111 | Above Underline | 0 | 1 | 0 | 0 |  | Bottom Intersect |
|  | Underline | 0 | 0 | 0 | 1 |  |  |
|  | Below Underline | 0 | 0 | 1 | 0 |  |  |
| 1000 | Above Underline | 0 | 0 | 1 | 0 |  | Horizontal Line |
|  | Underline | 0 | 0 | 0 | 1 | - |  |
|  | Below Underline | 0 | 0 | 1 | 0 |  |  |
| 1001 | Above Underline | 0 | 1 | 0 | 0 |  | Vertical Line |
|  | Underline | 0 | 1 | 0 | 0 |  |  |
|  | Below Underline | 0 | 1 | 0 | 0 |  |  |
| 1010 | Above Underline | 0 | 1 | 0 | 0 |  | Crossed Lines |
|  | Underline | 0 | 0 | 0 | 1 |  |  |
|  | Below Underline | 0 | 1 | 0 | 0 |  |  |
| 1011 | Above Underline | 0 | 0 | 0 | 0 |  | Not Recommended * |
|  | Underline | 0 | 0 | 0 | 0 |  |  |
|  | Below Underline | 0 | 0 | 0 | 0 |  |  |
| 1100 | Above Underline | 0 | 0 | 1 | 0 |  | Special Codes |
|  | Underline | 0 | 0 | 1 | 0 |  |  |
|  | Below Underline | 0 | 0 | 1 | 0 |  |  |
| 1101 | Above Underline |  | Undefined |  |  |  | Illegal |
|  | Underline |  |  |  |  |  |  |
|  | Below Underline |  |  |  |  |  |  |
| 1110 | Above Underline |  | Undefined |  |  |  | Illegal |
|  | Underline |  |  |  |  |  |  |
|  | Below Underline |  |  |  |  |  |  |
| 1111 | Above Underline |  | Undefined |  |  |  | Illegal |
|  | Underline |  |  |  |  |  |  |
|  | Below Underline |  |  |  |  |  |  |

[^24]Character Attribute Codes 1101, 1110, and 1111 are illegal.
Blinking is active when $B=1$.
Highlight is active when $\mathrm{H}=1$.

## Special Codes

Four special codes are available to help reduce memory, software, or DMA overhead.

## Special Control Character



| $\mathbf{S}$ | $\mathbf{S}$ | FUNCTION |
| :--- | :--- | :--- |
| 0 | 0 | End of Row |
| 0 | 1 | End of Row-Stop DMA |
| 1 | 0 | End of Screen |
| 1 | 1 | End of Screen-Stop DMA |

The End of Row Code (00) activates VSP and holds it to the end of the line.
The End of Row-Stop DMA Code (01) causes the DMA Control Logic to stop DMA for the rest of the row when it is written into the Row Buffer. It affects the display in the same way as the End of Row Code (00).

The End of Screen Code (10) activates VSP and holds it to the end of the frame.

The End of Screen-Stop DMA Code (11) causes the DMA Control Logic to stop DMA for the rest of the frame when it is written into the Row Buffer. It affects the display in the same way as the End of Screen Code (10).
If the Stop DMA feature is not used, all characters after an End of Row character are ignored, except for the End of Screen character, which operates normally. All characters after an End of Screen character are ignored.

Note: If a Stop DMA character is not the last character in a burst or row, DMA is not stopped until after the next character is read. In this situation, a dummy character must be placed in memory after the Stop DMA character.

## Field Attributes

The field attributes are control codes which affect the visual characteristics for a field of characters, starting at the character following the code up to, and including, the character which precedes the next field attribute code, or up to the end of the frame. The field attributes are reset during the vertical retrace interval.

There are six field attributes:

1. Blink - Characters following the code are caused to blink by activating the Video Suppression output (VSP). The blink frequency is equal to the screen refresh frequency divided by 32.
2. Highlight - Characters following the code are caused to be highlighted by activating the Highlight output (HGLT).
3. Reverse Video - Characters following the code are caused to appear with reverse video by activating the Reverse Video output (RVV).
4. Underline - Characters following the code are caused to be underlined by activating the Light Enable output (LTEN).

5,6. General Purpose - There are two additional 8275 outputs which act as general purpose, independently programmable field attributes. GPA 0-1 are active high outputs.

## Field Attribute Code



H = 1 FOR HIGHLIGHTING
$B=1$ FOR BLINKING
R = 1 FOR REVERSE VIDEO
$\mathrm{U}=1$ FOR UNDERLINE
$G \mathbf{G}=\mathrm{GPA}_{1}, \mathrm{GPA}_{0}$

The 8275 can be programmed to provide visible or invisible field attribute characters.

If the 8275 is programmed in the visible field attribute mode, all field attributes will occupy a position on the screen. They will appear as blanks caused by activation of the Video Suppression output (VSP). The chosen visual attributes are activated after this blanked character.


Figure 22. Example of the Visible Field Attribute Mode (Underline Attribute)

If the 8275 is programmed in the invisible field attribute mode, the 8275 FIFO is activated.


Figure 23. Block Diagram Showing FIFO Activation

Each row buffer has a corresponding FAFO. These FIFOs are 16 characters by 7 bits in size.

When a field attribute is placed in the row buffer during DMA, the buffer input controller recognizes it and places the next character in the proper FIFO.

When a field attribute is placed in the Buffer Output Controller during display, it causes the controller to immediately put a character from the FIFO on the Character Code outputs ( $C_{0-6}$ ). The chosen Visual Attributes are also activated.
Since the FIFO is 16 characters long, no more than 16 field attribute characters may be used per line in this mode. If more are used, a bit in the status word is set and the first characters in the FIFO are written over and lost.

Note: Since the FIFO is 7 bits wide, the MSB of any characters put in it are stripped off. Therefore, a Visual Attribute or Special Code must not immediately follow a field attribute code. If this situation does occur, the Visual Attribute or Special Code will be treated as a normal display character.


Figure 24. Example of the Invisible Field Attribute Mode (Underline Attribute)

## Field and Character Attribute Interaction

Character Attribute Symbols are affected by the Reverse Video (RRV) and General Purpose ( $\mathrm{GPA}_{0-1}$ ) field attributes. They are not affected by Underline, Blink or Highlight field attributes; however, these characteristics can be programmed individually for Character Attribute Symbols.

## Cursor Timing

The cursor location is determined by a cursor row register and a character position register 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
4. a non-blinking reverse video block

The cursor blinking frequency is equal to the screen refresh frequency divided by 16.
If a non-blinking reverse video cursor appears in a nonblinking reverse video field, the cursor will appear as a normal video block.

If a non-blinking underline cursor appears in a non-blinking underline field, the cursor will not be visible.

## Light Pen Detection

A light pen consists of a micro switch and a tiny light sensor. When the light pen is pressed against the CRT screen, the micro switch enables the light sensor. When the raster sweep reaches the light sensor, it triggers the light pen output.
If the output of the light pen is presented to the 8275 LPEN input, the row and character position coordinates are stored in a pair of registers. These registers can be read on command. A bit in the status word is set, indicating that the light pen signal was detected. The LPEN input must be a 0 to 1 transition for proper operation.

Note: Due to internal and external delays, the character position coordinate will be off by at least three character positions. This has to be corrected in software.

## Device Programming

The 8275 has two programming registers, the Command Register (CREG) and the Parameter Register (PREG). It also has a Status Register (SREG). The Command Register can only be written into and the Status Registers can only be read from. They are addressed as follows:

| A $_{\mathbf{0}}$ | OPERATION | REGISTER |
| :---: | :---: | :---: |
| 0 | Read | PREG |
| 0 | Write | PREG |
| 1 | Read | SREG |
| 1 | Write | CREG |

The 8275 expects to receive a command and a sequence of 0 to 4 parameters, depending on the command. If the proper number of parameter bytes are not received before another command is given, a status flag is set, indicating an improper command.

## Instruction Set

The 8275 instruction set consists of 8 commands.

| COMMAND | NO. OF PARAMETER BYTES |
| :--- | :---: |
| Reset | 4 |
| Start Display | 0 |
| Stop Display | 0 |
| Read Light Pen | 2 |
| Load Cursor | 2 |
| Enable Interrupt | 0 |
| Disable Interrupt | 0 |
| Preset Counters | 0 |

In addition, the status of the 8275 (SREG) can be read by the CPU at any time.

1. Reset Command:

|  | OPERATION | $A_{0}$ | DESCRIPTION | MS |  |  | TA | B |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Reset Command |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Parameters | Write | 0 | Screen Comp Byte 1 |  | H | H | H | H | H |  | H |
|  | Write | 0 | Screen Comp Byte 2 |  | V | R | $R$ | R | R |  | R |
|  | Write | 0 | Screen Comp Byte 3 |  | U | U | U | L | L |  | L |
|  | Write | 0 | $\begin{gathered} \text { Screen Comp } \\ \text { Byte } 4 \\ \hline \end{gathered}$ | M | F | C | C | Z | Z | z | Z |

Action - After the reset command is written, DMA requests stop, 8275 interrupts are disabled, and the VSP output is used to blank the screen. HRTC and VRTC continue to run. HRTC and VRTC timing are random on power-up.

As parameters are written, the screen composition is defined.

| Parameter - S | Spaced Rows |
| :---: | :--- |
| $\mathbf{S}$ | FUNCTIONS |
| 0 | Normal Rows |
| 1 | Spaced Rows |



Parameter - VV Vertical Retrace Row Count

| $\mathbf{V}$ | $\mathbf{V}$ | NO. OF ROW COUNTS PER VRTC |
| :--- | :--- | :---: |
| 0 | 0 | 1 |
| 0 | 1 | 2 |
| 1 | 0 | 3 |
| 1 | 1 | 4 |

Parameter - RRRRRR Vertical Rows/Frame

| R | R | R | R | R | R | NO. OF ROWS/FRAME |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 | 1 | 2 |
| 0 | 0 | 0 | 0 | 1 | 0 | 3 |
|  |  |  |  |  |  | . |
|  |  |  |  |  |  | - |
|  |  |  |  |  |  | . |
| 1 | 1 | 1 | 1 | 1 | 1 | 64 |

Parameter - UUUU Underline Placement


Parameter - LLLL Number of Lines per Character Row

| $L$ | $L$ | $L$ | $L$ | NO. OF LINES/ROW |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 1 | 2 |
| 0 | 0 | 1 | 0 | 3 |
|  | . |  | . |  |
|  | . |  | . |  |
| 1 | 1 | 1 | 1 | . |


| Parameter - | Line Counter Mode |
| :---: | :---: |
| M | LINE COUNTER MODE |
| 0 | Mode 0 (Non-Offset) |
| 1 | Mode 1 (Offset by 1 Count) |


| Parameter - F | Field Attribute Mode |
| ---: | :---: |
| F | FIELD ATTRIBUTE MODE |
| 0 | Transparent |
| 1 | Non-Transparent |

Parameter - CC Cursor Format

| C | C | CURSOR FORMAT |
| :--- | :--- | :--- |
| 0 | 0 | Blinking reverse video block |
| 0 | 1 | Blinking underline |
| 1 | 0 | Nonblinking reverse video block |
| 1 | 1 | Nonblinking underling |

$\left.\begin{array}{c}\text { Parameter - ZZZZ }\end{array} \begin{array}{cccc|c}\text { Horizontal Retrace Count } \\ \text { z } & \text { z } & \text { z } & \text { z } & \text { NO. OF CHARACTER } \\ \text { COUNTS PER HRTC }\end{array}\right]$

Note: uuuu MSB determines blanking of top and bottom lines ( $1=$ blanked, $0=$ not blanked) .
2. Start Display Command:

|  | OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |  |  | LSB |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Start Display | 0 | 0 | 1 | S | S | S | B |

SSS BURST SPACE CODE

| $\mathbf{S}$ | $\mathbf{S}$ | $\mathbf{S}$ | NO. OF CHARACTER CLOCKS <br> BETWEEN DMA REQUESTS |
| :--- | :--- | :--- | :---: |
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 7 |
| 0 | 1 | 0 | 15 |
| 0 | 1 | 1 | 23 |
| 1 | 0 | 0 | 31 |
| 1 | 0 | 1 | 39 |
| 1 | 1 | 0 | 47 |
| 1 | 1 | 1 | 55 |


|  | B B | BURST COUNT CODE |
| :---: | :---: | :---: |
|  |  | NO. OF DMA CYCLES PER |
| B | B | BURST |
| 0 | 0 | 1 |
| 0 | 1 | 2 |
| 1 | 0 | 4 |
| 1 | 1 | 8 |

Action - 8275 interrupts are enabled, DMA requests begin, video is enabled, Interrupt Enable and Video Enable status flags are set.
3. Stop Display Command:

|  | OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |  |  |  | LSB |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Stop Display | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| No parameters |  |  |  |  |  |  |  |  |  |  |  |

Action - Disables video, interrupts remain enabled, HRTC and VRTC continue to run, Video Enable status flag is reset, and the "Start Display" command must be given to re-enable the display.
4. Read Light Pen Command

|  | OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |  | LSB |  |
| :--- | :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- |
| Command | Write | 1 | Read Light Pen | 0 | 1 | 1 | 0 | 0 | 0

Action - The 8275 is conditioned to supply the contents of the light pen position registers in the next two read cycles of the parameter register. Status flags are not affected.

Note: Software correction of light pen position is required.
5. Load Cursor Position:

|  | OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |
| :--- | :---: | :---: | :--- | :--- | :--- |
| Command | Write | 1 | Load Cursor | $1 \quad 0 \quad 0 \quad 0 \quad 0$ | 0 |

Action - The 8275 is conditioned to place the next two parameter bytes into the cursor position registers. Status flags not affected.
6. Enable Interrupt Command:

|  | OPERATION | A $_{0}$ | DESCRIPTION | MSB |  |  |  | LSB |  |  |  |
| :---: | :---: | :---: | :---: | :---: | ---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Enable Interrupt | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| No parameters |  |  |  |  |  |  |  |  |  |  |  |

Action - The interrupt enable status flag is set and interrupts are enabled.
7. Disable Interrupt Command:

|  | OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |  |  | LSB |  |  |
| ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Disable Interrupt | 1 | 1 | 0 | 0 | 0 | 0 | 0 |
| No parameters |  |  |  |  |  |  |  |  |  |  |

Action - Interrupts are disabled and the interrupt enable status flag is reset.

## 8. Preset Counters Command:

|  | OPERATION | A0 | DESCRIPTION | MSB |  |  |  | LSB |  |  |
| ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Preset Counters | 1 | 1 | 1 | 0 | 0 | 0 | 0 |

Action - The internal timing counters are preset, corresponding to a screen display position at the top left corner. Two character clocks are required for this operation. The counters will remain in this state until any other command is given.
This command is useful for system debug and synchronization of clustered CRT displays on a single CPU.

## Status Flags

|  | OPERATION | A $_{\mathbf{0}}$ | DESCRIPTION | MSB |
| :--- | :---: | :---: | :--- | :--- | ---: |
| Command | Read | 1 | Status Word | 0 IE IR LP IC VE OU FO |

IE - (Interrupt Enable) Set or reset by command. It enables vertical retrace interrupt. It is automatically set by a "Start Display" command and reset with the "Reset" command.
IR - (Interrupt Request) This flag is set at the beginning of display of the last row of the frame if the interrupt enable flag is set. It is reset after a status read operation.
LP - This flag is set when the light pen input (LPEN) is activated and the light pen registers have been loaded. This flag is automatically reset after a status read.

IC - (Improper Command) This flag is set when a command parameter string is too long of too short. The flag is automatically reset after a status read.

VE - (Video Enable) This flag indicates that video operation of the CRT is enabled. This flag is set on a "Start Display" command, and reset on a "Stop Display" or "Reset" command.

DU - (DMA Underrun) This flag is set whenever a data underrun occurs during DMA transfers. Upon detection of DU, the DMA operation is stopped and the screen is blanked until after the vertical retrace interval. This flag is reset after a status read.
FO - (FIFO Overrun) This flag is set whenever the FIFO is overrun. It is reset on a status read.

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

$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 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\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 \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 |  | 160 | mA |  |

## CAPACITANCE

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  | 20 | pF | Unmeasured pins returned to $\mathrm{V}_{\mathrm{SS}}$. |

Other Timing:

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CC}}$ | Character Code Output Delay |  | 150 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{HR}}$ | Horizontal Retrace Output Delay |  | 150 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{LC}}$ | Line Count Output Delay |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $t_{A T}$ | Control/Attribute Output Delay |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $t_{\text {VR }}$ | Vertical Retrace Output Delay |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $t_{\text {IR }}$ | IRQî from CCLK $\downarrow$ |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $t_{\text {RI }}$ | $1 \mathrm{RQ} \downarrow$ from Rd $\uparrow$ |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{KO}}$ | DRQ $\uparrow$ from CCLK $\downarrow$ |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| two | DRQ $\uparrow$ from WR $\uparrow$ |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| tra | DRQ $\downarrow$ from WR $\downarrow$ |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| tiR | DACK $\downarrow$ to WR $\downarrow$ | 0 |  | ns |  |
| $t_{\text {R }}$ | WR $\uparrow$ to DACK $\hat{1}$ | 0 |  | ns |  |
| $t_{\text {PR }}$ | LPEN Rise |  | 50 | ns |  |
| $\mathrm{tPH}^{\text {f }}$ | LPEN Hold | 100 |  | ns |  |

Note: Timing measurements are made at the following reference voltages: Output " 1 " $=2.0 \mathrm{~V}, ~ " 0$ " $=0.8 \mathrm{~V}$.

## WAVEFORMS


*CCLK is A multiple of the dot clock and an input to the 8275.

Figure 25. Typical Dot Level Timing


Figure 26. Line Timing


Figure 27. Row Timing


Figure 28. Frame Timing


Figure 29. Interrupt Timing


Figure 30. DMA Timing

## 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 \% ; G N D=0 \mathrm{~V}$

## Bus Parameters (Note 1)

## Read Cycle:

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {AR }}$ | Address Stable Before READ | 0 |  | ns |  |
| $t_{\text {RA }}$ | Address Hold Time for READ | 0 |  | ns |  |
| $t_{\text {RR }}$ | READ Pulse Width | 250 |  | ns |  |
| $t_{\text {RD }}$ | Data Delay from READ |  | 200 | ns | $C_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | READ to Data Floating | 20 | 100 | ns |  |

## Write Cycle:

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | ---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | Address Stable Before WRITE | 0 |  | ns |  |
| $t_{\text {WA }}$ | Address Hold Time for WRITE | 0 |  | ns |  |
| $t_{W W}$ | WRITE Pulse Width | 250 |  | ns |  |
| $t_{\text {DW }}$ | Data Setup Time for WRITE | 150 |  | ns |  |
| $t_{W D}$ | Data Hold Time for WRITE | 0 |  | ns |  |

## Clock Timing:

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | ---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CLK}}$ | Clock Period | 320 |  | ns |  |
| $\mathrm{t}_{\mathrm{KH}}$ | Clock High | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{KL}}$ | Clock Low | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{KR}}$ | Clock Rise | 5 | 30 | ns |  |
| $\mathrm{t}_{\mathrm{KF}}$ | Clock Fall | 5 | 30 | ns |  |

Note 1: AC timings measured at $\mathrm{V}_{\mathrm{OH}}=2.0, \mathrm{~V}_{\mathrm{OL}}=0.8$

## Write Timing



Clock Timing

## Read Timing



Input Waveforms (For A.C. Tests)


# 8278 <br> PROGRAMMABLE KEYBOARD INTERFACE 

## Simultaneous Keyboard and Display Operations

- Interface Signals for Contact and Capacitive Coupled Keyboards


## - 128-Key Scanning Logic

- 10.7 msec Matrix Scan Time for 128 Keys and 6 MHz Clock


## - 8-Character Keyboard FIFO

# - N-Key Rollover with Programmable Error Mode on Multiple New Closures 

## - 16-Character 7-Segment Display Interface

- Right or Left Entry Display RAM
- Depress/Release Mode Programmable
- Interrupt Output on Key Entry

The Intel ${ }^{\circledR} 8278$ is a general purpose programmable keyboard and display interface device designed for use with 8 -bit microprocessors such the MDS-80 ${ }^{\text {TM }}$ and MCS- $85^{\mathrm{TM}}$. The keyboard portion can provide a scanned interface to 128 -key contact or capacitive-coupled keyboards. The keys are fully debounced with N-key rollover and programmable error generation on multiple new key closures. Keyboard entries are stored in an 8 -character FIFO with overrun status indication when more than 8 characters are entered. Key entries set an interrupt request output to the master CPU.
The display portion of the 8278 provides a scanned display interface for LED, incandescent, and other popular display technologies. Both numeric displays and simple indicators may be used. The 8278 has a 16X4 display RAM which 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 autoincrement of the display RAM address.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | DATA BUS |
| :--- | :--- |
| $\overline{R D}, \overline{W R}$ | READ, WRITE STROBES |
| $\overline{C S}$ | CHIP SELECT |
| $\mathrm{A}_{0}$ | CONTROL/DATA SELECT |
| $\overline{\text { RESET }}$ | RESET INPUT |
| $\mathrm{X}_{1}, \mathrm{X}_{2}$ | FREQ. REFERENCE INPUT |
| SYNC | HIGH FREQUENCY OUTPUT |
|  | CLOCK |
| RL | KEYBOARD RETURN LINE |
| CLR | CLEAR ERROR |
| KCL | KEY CLOCK |
| $M_{6}-M_{0}$ | MATRIX SCAN LINES |
| $B_{3}-B_{0}$ | DISPLAY OUTPUTS |
| ERROR | ERROR SIGNAL |
| IRQ | INTERRUPT REQUEST |
| HYS | HYSTERESIS |
| $B P$ | TONE ENABLE |

BLOCK DIAGRAM


## PIN DESCRIPTION

The 8278 is packaged in a 40-pin DIP. The following is a brief functional description of each pin.

| Signal | Pin No. | Description |
| :--- | ---: | :--- | | $\mathrm{D}_{0}-\mathrm{D}_{7}$ |
| :--- |
| $\overline{\mathrm{WR}}$ |


| Signal | Pin No. | Description |
| :---: | :---: | :---: |
| ERROR | 24 | Error signal. This line is high whenever two new key closures are detected during a single scan or when too many characters are entered into the keyboard FIFO. It is reset by a system RESET pulse or by a " 1 " input on the CLR pin or by the CLEAR ERROR command. |
| CLR | 39 | Input used to clear an ERROR condition in the 8278. |
| BP | 21 | Tone enable output. This line is high for 10 ms following a valid key closure; it is set high and remains high during an ERROR condition. |
| VCC, VDD | 40,26 | +5 volt power input: $+5 \mathrm{~V} \pm 10 \%$. |
| GND | 20,7 | Signal ground. |

## PRINCIPLES OF OPERATION

The following is a description of the major elements of the 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{\mathrm{CS}}, \mathrm{A}_{0}, \overline{\mathrm{RD}}$, and $\overline{W R}$ lines to control data flow to and from the various internal registers and buffers (see Table 1). All data flow to and from the 8278 is enabled by $\overline{C S}$. The 8 -bits of information being transferred by the CPU is identified by $A_{0}$. A logic one means information is 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 Bus Buffer (DBB). The DBB register is a bi-directional 8-bit buffer register which connects the internal 8278 bus buffer register to the external bus. When the chip is not selected ( $\overline{C S}=1$ ) the DBB is in the high impedance state. The DBB acts as an input when ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}})=(1,0,0)$ and an output when $(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}})=(0,1,0)$.

| $\overline{\mathbf{C S}}$ | $\mathrm{AD}_{0}$ | $\overline{\text { WR }}$ | $\overline{\mathrm{RD}}$ | Condition |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | 0 | Read DBB Data |
| 0 | 1 | 1 | 0 | Read STATUS |
| 0 | 0 | 0 | 1 | Write Data to DBB |
| 0 | 1 | 0 | 1 | Write Command to DBB |
| 1 | X | X | X | Disable 8278 Bus is <br> High Impedance |

## Scan Counter

The scan counter provides the timing to scan the keyboard and display. The four MSB's ( $\mathrm{M}_{3}-\mathrm{M}_{6}$ ) scan the display digits and provide column scan to the keyboard via a 4 to 16 decoder. The three LSB's $\left(\mathrm{M}_{0}-\mathrm{M}_{2}\right)$ are used to multiplex the row return lines into the 8278.


Figure 1. System Configuration for Capacitive-Coupled Keyboard

## Keyboard Debounce and Control

The 8278 system configuration is shown in Figure 2. The rows of the matrix are scanned and the outputs are multiplexed by the 8278. When a key closure is detected, the debounce logic waits about 12 msec to check if the key remains closed. If it does, the address of the key in the matrix is transferred into a FIFO buffer.

## FIFO and FIFO Status

The 8278 contains an 8 X8 FIFO character buffer. Each new entry is written into a successive FIFO location and each is then read out in the order of entry. A FIFO status register keeps track of the number of characters in the

FIFO and whether it is full or empty. Too many reads or key entries will be recognized as an error. The status can be read by a $\overline{R D}$ with $\overline{C S}$ low and $A_{0}$ high. The status logic also provides a IRQ signal to the master processor whenever the FIFO is not empty.

## 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 4 -bit nibble 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. Data entry to the display can be set to either left or right entry.


Figure 2. System Configuration for Contact Keyboard

## 8278 COMMANDS

The 8278 operating mode is programmed by the master CPU using the $A_{0}, W R$, and $D_{0}-D_{7}$ inputs as shown below:


The master CPU presents the proper command on the $\mathrm{D}_{0-}$ $\mathrm{D}_{7}$ data lines with $\mathrm{A}_{0}=1$ and then sends a $\overline{W R}$ pulse. The command is latched by the 8278 on the rising edge of the $\overline{W R}$ and is decoded internally to set the proper operating mode.

## COMMAND SUMMARY

## Keyboard/Display Mode Set


where the mode set bits are defined as follows:
K - the keyboard mode select bit
0 - normal key entry mode
1 - special function mode: Entry on key closure and on key release
D - the display entry mode select bit
0 - left display entry
1 - right display entry
I - the interrupt request (IRQ) output enable bit.
0 - enable IRQ output
1 - disable IRQ output
$E$ - the error mode select bit
0 - error on multiple key depression
1 - no error on multiple key depression
N - the number of display digits select
$0-16$ display digits
1 - 8 display digits
NOTE: The default mode following a RESET input is all bits zero:


## Read FIFO Command

CODE


## Read Display Command

CODE


Where Al indicates Auto Increment ana A3 A ${ }_{3}$ is the address of the next display character to be read out

$$
\begin{array}{ll}
\mathrm{AI}=1 & \mathrm{AUTO} \text { increment } \\
\mathrm{AI}=0 & \text { no } A \cup T O \text { increment }
\end{array}
$$

## Write Display Command

CODE

| 1 | 0 | 0 | $A_{1}$ | $A_{3}$ | $A_{2}$ | $A_{1}$ | $A_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Where AI indicates Auto Increment and $A_{3}-A_{0}$ is the address of the next display character to be written.

## Clear/Blank Command



Where the command bits are defined as follows:
$C E=$ Clear ERROR
CF = Clear FIFO
CD = Clear Display RAM to all High
BD = Blank Display to all High (Display RAM unaffected)
UD = Unblank Display
The display is cleared and blanked following a Reset.

## 8278 Status Read

The status register in the 8278 can be read by the master CPU using the $A_{0}, \overline{R D}$, and $D_{0}-D_{7}$ inputs as shown below:


The 8278 places 8 -bits of status information on the $D_{0}-D_{7}$ lines following $\left(A_{0}, \overline{C S}, \overline{R D}\right)=1,0,0$ inputs from the master.


## Status Format

| $\mathrm{S}_{3}$ | $\mathrm{~S}_{2}$ | $\mathrm{~s}_{1}$ | $\mathrm{~s}_{0}$ | B | KE | IBF | OBF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |

Where the status bits are defined as follows:

```
OBF = Output Buffer Full Flag
IBF = Input Buffer Full Flag
\(K E=\) Keyboard Error Flag (multiple depression)
\(B=\) BUSY Flag
\(S_{3}-S_{0}=\) FIFO Status
```


## Status Description

The $\mathrm{S}_{3}-\mathrm{S}_{0}$ status bits indicate the number of entries ( 0 to 8 ) in the 8-level FIFO. A FIFO overrun will lock status at 1111. The overrun condition will prevent further key entries until cleared.
A multiple key closure error will set the KE flag and prevent further key entries until cleared.
The IBF and OBF flags signify the status of the 8278 data buffer registers used to transfer information (data, status or commands) to and from the master CPU.
The IBF flag is set when the master CPU writes Data or Commands to the 8278. The IBF flag is cleared by the 8278 during its response to the Data or Command.
The OBF flag is set when the 8278 has output data ready for the master CPU. This flag is cleared by a master CPU Data READ.
The Busy flag in the status register is used as a LOCKOUT signal to the master processor during response to any command or data write from the master.
The master must test the Busy flag before each read (during a sequence) to be sure that the 8278 is ready with valid DATA.
The ERROR and TONE outputs from the 8278 are set high for either type of error. Both types of error are cleared by the CLR input, by the CLEAR ERROR command, or by a reset. The FIFO and Display buffers are cleared independently of the Errors.
FIFO status is used to indicate the number of characters in the FIFO and to indicate whether an error has occurred. 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 character read will be the last one entered. FIFO status will remain at 0000 and the error condition will not be set.

## 8278 Data Read

The master CPU can read DATA from the 8278 FIFO or Display buffers by using the $A_{0}, \overline{R D}$, and $D_{0}-D_{7}$ inputs as follows:


The master sends a $\overline{R D}$ pulse with $\mathrm{A}_{0}=0$ and $\mathrm{CS}=0$ and the 8278 responds by outputing data on lines $\mathrm{D}_{0}-\mathrm{D}_{7}$. The data is strobed by the trailing edge of $\overline{R D}$.

## Data Read Sequence

Before reading data, the master $C R U$ must send a command to select FIFO or Display data. Following the command, the master must read STATUS and test the BUSY flag and the OBF flag to verify that the 8278 hias responded to the previous command. A typical DATA READ sequence is as follows:


After the first read following a Read Display or Read FIFO command, successive reads may occur as soon as OBF rises.

## 8278 Data Write

The master CPU can write DATA to the 8278 Display buffers by using the $A_{0}, \overline{W R}$ and $D_{0}-D_{7}$ inputs as follows:


The master CPU presents the Data on the $D_{0}-D_{7}$ lines with $\mathrm{A}_{0}=0$ and then sends a $\overline{W R}$ pulse. The data is latched by the 8278 on the rising edge of $\overline{W R}$.

## Data Write Sequence

Before writing data to the 8278 , the master CPU must first send a command to select the desired display entry mode and to specify the address of the next data byte. Following the commands, the master must read STATUS and test the BUSY flag (B) and IBF flag to verify that the 8278 has responded. A typical sequence is shown below:


## INTERFACE CONSIDERATIONS

## Scanned Keyboard Mode

With N-key rollover each key depression is treated independently from all others. When a key is depressed the debounce logic waits for a full scan of 128 keys and then checks to see if the key is still down. If it is, the key is entered into the FIFO.


Figure 3. Keyboard Timing

If two key closures occur during the same scan the ERROR output is set, the KE flag is set in the Status word, the TONE output is activated and IRQ is set, and no further inputs are accepted. This condition is cleared by a high signal on the CLEAR input or by a system RESET input or by the CLEAR ERROR command.

In the special function mode both the key closure and the key release cause an entry to the FIFO. The release is entered with the $M S B=1$.

Any key entry triggers the TONE output for 10 ms .
The $\overline{\mathrm{HYS}}$ and KCL outputs enable the analog multiplexer and detector to be synchronized for interface to capacitive coupled keyboards.


Figure 4. Key Entry and Error Timing

## Data Format

In the scanned keyboard mode, the code entered into the FIFO corresponds to the position or address of the switch in the keyboard. The MSB is relevant only for special function keys in which code " 0 " signifies closure and " 1 " signifies release. The next four bits are the column count which indicates which column the key was found in. The last three bits are from the row counter.

## KEY CODING

BIT

\[

\]

## Display

Display data is entered into a $16 \times 4$ display register and may be entered from the left, from the right or into specific locations in the display register. A new data character is put out on $B_{0}-B_{3}$ each time the $M_{6}-M_{3}$ lines change (i.e., once every 0.75 ms with a 6 MHz crystal). Data is blanked during the time the column select lines change by raising the display outputs. Output data is positive true.

## Left Entry

The left entry mode is the simplest display format in that each display position in the display corresponds to a byte (or nibble) in the Display RAM. Address 0 in the RAM is the left-most display character and address 15 is the rightmost display character. Entering characters from position zero causes the display to fill from the left. The 17th 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 efectronic 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. A Clear Display command should be given before display data is entered if the number of data characters is not equal to 16 (or 8) in this mode.


Figure 5. Display Timing

## 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 Left Entry - Auto Increment mode has no undesirable side effects and the result is predictable:

DISPLAY
1ST ENTRY


RAM


ENTER NEXT AT LOCATION 5 AUTO INCREMENT


In the Right Entry mode, Auto Incrementing and non Incrementing have the same effect as in the Left Entry except that the address sequence is interrupted:


ENTER NEXT AT LOCATION 5 AUTO INCREMENT


4TH ENTRY


Starting at an arbitrary location operates as shown below:


ENTER NEXT AT LOCATION 5 AUTO INCREMENT

1ST ENTRY


2ND ENTRY


8TH ENTRY

| 4 | 5 | 6 | 7 | 8 | 1 | 2 | 3 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |



Entry appears to be from the initial entry point.

## 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.5 Watt
*COMMENT: Stresses above those listed under Absolute Maximum Ratings" may cause permanent damage fo the device. This is a stress rating only and functronal 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

Commercial: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{Vcc}^{\mathrm{C}}=+5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Units | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage (All Inputs Except $X_{1}, X_{2}$ | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{1+1}$ | Input High Voltage (All Inputs Except $\mathrm{X}_{1}, \mathrm{X}_{2}$, $\overline{R E S E T}$ | 2.0 | Vcc | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | $\overline{\text { RESET }}$ High Voltage | 3.0 | Vcc | V |  |
| Vol1 | Output Low Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) |  | 0.45 | V | $\mathrm{IOL}=2.0 \mathrm{~mA}$ |
| VOL2 | Output Low Voltage (All Other Outputs) |  | 0.45 | V | $\mathrm{IOL}=1.6 \mathrm{~mA}$ |
| Voh1 | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  | V | $1 \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| VOH2 | Output High Voltage (All Other Outputs) | 2.4 |  | V | $\mathrm{IOH}=-50 \mu \mathrm{~A}$ |
| IIL | Input Leakage Current (All Inputs Except RESET) |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\text {cc }}$ |
| IOL | Output Leakage Current ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=V_{S S}+0.45 V \text { or } \\ & V_{I N}=V_{C C} \end{aligned}$ |
| IDD + ICC | Total Supply Current |  | 135 | mA | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| IDD | VDD Supply Current |  | 25 | mA | $\mathrm{VCC}=5.5 \mathrm{~V}$ |
| ILI | Low Input Source Current ( $\overline{\text { RESET }}$ ) |  | 0.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |

## 8278 CLOCK OPTIONS


$1-6 \mathrm{MHz}$
CRYSTAL

$40 \mu \mathrm{~h}-130 \mu \mathrm{~h}$ INDUCTOR


EXTERNAL CLOCK
A.C. CHARACTERISTICS
$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$; $\mathrm{VCC}=+5 \mathrm{~V} \pm 10 \%$; V SS $=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Units | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AC }}$ | Address ( $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ ) Setup to Control ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 0 |  | ns | $\mathrm{D}_{0}-\mathrm{D}_{7}, C_{L}=150 \mathrm{pF}$ |
| tca | Address Hold from Control | 0 |  | ns |  |
| tcc | Control Puise Width | 250 |  | ns |  |
| tow | Data in Setup to $\bar{W} R$ T.E. | 150 |  | ns |  |
| two | Data in Hold After WR T.E. | 0 |  | ns |  |
| trd | $\overline{\mathrm{RD}}$ L.E. to Data Out Valid |  | 150 | ns |  |
| tDF | $\overline{\mathrm{RD}}$ T.E. to Data Out Float | 10 | 100 | ns |  |
| tmCy | Matrix Cycle Time |  | 10.7 | ms | With 6MHz Crystal |
| trv | Recovery Time Between Reads and/or Writes | 1 |  | $\mu \mathrm{S}$ |  |

## WAVEFORMS

## Read Operation - Data Bus Buffer Register



Write Operation - Data Bus Buffer Register


## 8279/8279-5

 PROGRAMMABLE KEYBOARDIDISPLAY INTERFACE- MCS-85 ${ }^{\text {TM }}$ Compatible 8279 -5
- Simultaneous Keyboard Display Operations
- Scanned Keyboard Mode
- Scanned Sensor Mode
- Strobed Input Entry Mode
- 8-Character Keyboard FIFO


## - 2-Key Lockout or N-Key Rollover with Contact Debounce

Dual 8- or 16-Numerical Display
Single 16-Character Display

- Right or Left Entry 16-Byte Display RAM


## - Mode Programmable from CPU

- Programmable Scan Timing
- Interrupt Output on Key Entry

The Intel ${ }^{\oplus} 8279$ is a general purpose programmable keyboard and display I/O interface device designed for use with Intel ${ }^{\circledR}$ microprocessors. The keyboard portion can provide a scanned interface to a 64 -contact key matrix. 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, overrun 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 sumple indicators. The 8279 has $16 \times 8$ display RAM which can be organized into 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


LOGIC SYMBOL


## HARDWARE DESCRIPTION

The 8279 is packaged in a 40 pin DIP. The following is a functional description of each pin.

| No. Of Pins | Designatio |
| :---: | :---: |
| 8 | DB0-DB7 |
| 1 | CLK |
| 1 | RESET |
| 1 | $\overline{C S}$ |
| 1 | $\mathrm{A}_{0}$ |
| 2 | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ |
| 1 | IRQ |
| 2 | $\mathrm{V}_{\text {SS }}, \mathrm{V}_{\text {cc }}$ |
| 4 | SLo-SL3 |

8 RLo-RL7

## Function

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.
A high signal on this pin resets the 8279. After being reset the 8279 is placed in the following mode:

1) 168 -bit character display一left entry.
2) Encoded scan keyboard-2 key lockout.
Along with this the program clock prescaler is set to 31.
Chip Select. A low on this pin enables the interface functions to receive or transmit.
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.
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.
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.
Ground and power supply pins.
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).

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
$\left.\begin{array}{ll}\begin{array}{c}\text { No. Of } \\ \text { Pins }\end{array} & \begin{array}{l}\text { Designation }\end{array} \\ \hline \text { Function }\end{array} \begin{array}{l}\text { Keyboard modes. It has an } \\ \text { active internal pullup to keep it } \\ \text { high until a switch closure pulls } \\ \text { it low. }\end{array}\right\}$

## 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/C control section uses the $\overline{\mathrm{CS}}, \mathrm{A}_{0}, \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ 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 $\mathrm{A}_{0}$. A logic one means the information is a command or status. A logic zero means the information is data. $\overline{R D}$ and $\overline{W R}$ 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{\mathrm{CS}}=1$ ), the devices are in a high impedance state. The drivers input during $\overline{\mathrm{WR}} \bullet \overline{\mathrm{CS}}$ and output during $\overline{\mathrm{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}$.

## FUNCTIONAL DESCRIPTION

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 x 8 key keyboard) or decoded ( $4 \times 8$ 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 x 8 matrix switches) or decoded ( $4 \times 8$ matrix switches) scan fines. 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.
- Clock Prescaler
- 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.


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 N$ prescaler that can be programmed to yield an internal frequency of 100 kHz which 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.

## FIFOISensor 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 $\overline{\mathrm{RD}}$ with $\overline{\mathrm{CS}}$ low and $A_{0}$ 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



Where DD is the Display Mode and KKK is the Keyboard Mode.

| $\underline{D D}$ |  |  |
| :--- | :--- | :--- |
| 0 | 0 | 88 -bit character display - Left entry |
| 0 | 1 | 168 -bit character display - Left entry* |
| 1 | 0 | 88 -bit character display - Right entry |
| 1 | 1 | 168 -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

| 0 | 0 | 0 | Encoded Scan Keyboard - 2 Key Lockout* |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | Decoded Scan Keyboard - 2-Key Lockout |
| 0 | 1 | 0 | Encoded Scan Keyboard - N-Key Rollover |
| 0 | 1 | 1 | Decoded Scan Keyboard - N-Key Rollover |
| 1 | 0 | 0 | Encoded Scan Sensor Matrix |
| 1 | 0 | 1 | Decoded Scan Sensor Matrix |
| 1 | 1 | 0 | Strobed Input, Encoded Display Scan |
| 1 | 1 | 1 | Strobed Input, Decoded Display Scan |

## Program Clock

Code:


All timing and multiplexing signals for the 8279 are generated by an internal prescaler. This prescaler divides the external clock (pin 3) by a programmable integer. Bits PPPPP determine the value of this integer which ranges from 2 to 31 . Choosing a divisor that yields 100 kHz will give the specified scan and debounce times. For instance, if Pin 3 of the 8279 is being clocked by a 2 MHz signal, PPPPP should be set to 10100 to divide the clock by 20 to yield the proper 100 kHz operating frequency.

## Read FIFOISensor RAM

Code:


The CPU sets up the 8279 for a read of the FIFO/Sensor RAM by first writing this command. In the Scan Key-

[^25]board Mode, the Auto-Increment flag (AI) and the RAM address bits (AAA) are irrelevant. The 8279 will automatically drive the data bus for each subsequent read ( $A_{0}=0$ ) in the same sequence in which the data first entered the FIFO. All subsequent reads will be from the FIFO until another command is issued.

In the Sensor Matrix Mode, the RAM address bits AAA select one of the 8 rows of the Sensor RAM. If the AI flag is set $(A I=1)$, each successive read will be from the subsequent row of the sensor RAM.

## Read Display RAM

Code: | $\mathbf{0}$ | $\mathbf{1}$ | $\mathbf{1}$ | $\mathbf{A I}$ | $\mathbf{A}$ | $\mathbf{A}$ | $\mathbf{A}$ | $\mathbf{A}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The CPU sets up the 8279 for a read of the Display RAM by first writing this command. The address bits AAAA select one of the 16 rows of the Display RAM. If the AI flag is set $(A I=1)$, this row address will be incremented after each following read or write to the Display RAM. Since the same counter is used for both reading and writing, this command sets the next read or write address and the sense of the Auto-Increment mode for both operations.

## Write Display RAM

\section*{Code: $\quad$| $\mathbf{1}$ | $\mathbf{0}$ | $\mathbf{0}$ | $\mathbf{A I}$ | $\mathbf{A}$ | $\mathbf{A}$ | $\mathbf{A}$ | $\mathbf{A}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |}

The CPU sets up the 8279 for a write to the Display RAM by first writing this command. After writing the command with $A_{0}=1$, all subsequent writes with $A_{0}=0$ will be to the Display RAM. The addressing and AutoIncrement functions are identical to those for the Read Display RAM. However, this command does not affect the source of subsequent Data Reads; the CPU will read from whichever RAM (Display or FIFO/Sensor) which was last specified. If, indeed, the Display RAM was last specified, the Write Display RAM will, nevertheless, change the next Read location.

## Display Write Inhibit/Blanking

The IW Bits can be used to mask nibble $A$ and nibble $B$ in applications requiring separate 4-bit display ports. By setting the IW flag (IW=1) for one of the ports, the port becomes marked so that entries to the Display RAM from the CPU do not affect that port. Thus, if each nibble is input to a BCD decoder, the CPU may write a digit to the Display RAM without affecting the other digit being displayed. It is important to note that bit $\mathrm{B}_{0}$ corresponds to bit $\mathrm{D}_{0}$ on the CPU bus, and that bit $\mathrm{A}_{3}$ corresponds to bit $D_{7}$.

If the user wishes to blank the display, the BL flags are available for each nibble. The last Clear command issued determines the code to be used as a "blank." This code defaults to all zeros after a reset. Note that both BL flags must be set to blank a display formatted with a single 8-bit port.

## Clear

The $C_{D}$ bits are available in this command to clear all rows of the Display RAM to a selectable blanking code as follows:

| 1 | All Zeros $(X=$ Don't Care) |
| :--- | :--- |
| 1 | 0 |$\quad A B=\operatorname{Hex} 20(00100000)$

During the time the Display RAM is being cleared ( $\sim 160 \mu \mathrm{~s}$ ), it may not be written to. The most significant bit of the FIFO status word is set during this time. When the Display RAM becomes available again, it automatically resets.

If the $C_{F}$ bit is asserted ( $C_{F}=1$ ), the FIFO status is cleared and the interrupt output line is reset. Also, the Sensor RAM pointer is set to row 0.
$C_{A}$, the Clear All bit, has the combined effect of $C_{D}$ and $C_{F}$; it uses the $C_{D}$ clearing code on the Display RAM and also clears FIFO status. Furthermore, it resynchronizes the internal timing chain.

## 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{C S}$ and $\overline{R D}$ 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{\mathrm{CS}}$ and $\overline{\mathrm{WR}}$ 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 $\overline{\mathrm{WR}}$ occurs if Al set by the latest display command.

## INTERFACE CONSIDERATIONS

## 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. Other depressed keys are looked for during the next two scans. 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.

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

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

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

## 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 (non-inverted). 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.

\[

\]

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



RIGHT ENTRY MODE (AUTO INCREMENT)

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


2nd entry


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:


Enter next at Location 5 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 \＄et in the word to indicate that at least one sensor clossurer，chation is contained in the Sensor RAM．

In Special Error Mode the S／E bit is showing the enor and serves as an indication to whether a simulfariopus multiple closure error has occurred．


＊Do not drive the keyboard decoder with the MSB of the scan lines．

## 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 damaye to the device．This is a stress rating only and furetional ope－ tion of the device at these or any other conditians above those indicated in the operational sections of this specifi－ cation 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} s \mathrm{~S}=0 \mathrm{~V}$ ，Note 1

| Symbol | Parameter | Min． | Max． | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VILI | Input Low Voltage for Return Lines | －0．5 | 1.4 | V |  |
| $V_{\text {IL2 }}$ | Input Low Voltage for All Others | －0．5 | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage for Return Lines | 2.2 |  | V |  |
| $\mathrm{V}_{\text {IH2 }}$ | 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 |
| I／L1 | Input Current on Shift，Control and Return Lines |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & V_{\mathbb{I N}}=V_{C C} \\ & V_{I N}=0 V \end{aligned}$ |
| $I_{\text {IL2 }}$ | Input Leakage Current on All Others |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| Iof L | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ to 0 V |
| ICC | Power Supply Current |  | 120 | mA |  |

## Notes：

1． $8279, V_{C C}=+5 \mathrm{~V} \pm 5 \% ; 8279-5, V_{C C}=+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{IOH}^{2}=-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}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\text {out }}$ | Output Capacitance | 10 | 20 | pF | $\mathrm{V}_{\text {out }}=\mathrm{V}_{\mathrm{CC}}$ |

## A.C. CHARACTERISTICS

$T_{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. |  |
| ${ }_{t}$ AR | Address Stable Before $\overline{\text { READ }}$ | 50 |  | 0 |  | ns |
| $\mathrm{t}_{\text {RA }}$ | Address Hold Time for $\overline{\text { READ }}$ | 5 |  | 0 |  | ns |
| $t_{\text {RR }}$ | $\overline{\text { READ Pulse Width }}$ | 420 |  | 250 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}{ }^{[2]}$ | Data Delay from $\overline{\text { READ }}$ |  | 300 |  | 150 | ns |
| $t_{A D}{ }^{[2]}$ | Address to Data Valid |  | 450 |  | 250 | ns |
| ${ }^{\text {D }}$ F | $\overline{\text { READ }}$ to Data Floating | 10 | 100 | 10 | 100 | ns |
| $\mathrm{t}_{\text {RCY }}$ | Read Cycle Time | 1 |  | 1 |  | $\mu \mathrm{s}$ |

Write Cycle:

| Symbol | Parameter | 8279 |  | 8279-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {AW }}$ | Address Stable Before WRITE | 50 |  | 0 |  | ns |
| $t_{\text {WA }}$ | Address Hold Time for $\overline{\text { WRITE }}$ | 20 |  | 0 |  | ns |
| ${ }^{\text {tww }}$ | $\overline{\text { WRITE Pulse Width }}$ | 400 |  | 250 |  | ns |
| ${ }^{\text {t }}$ W | Data Set Up Time for $\overline{\text { WRITE }}$ | 300 |  | 150 |  | ns |
| ${ }^{\text {two }}$ | Data Hold Time for WRITE | 40 |  | 0 |  | ns |

Notes:

1. $8279, V_{C C}=+5 \mathrm{~V} \pm 5 \% ; 8279-5, V_{C C}=+5 \mathrm{~V} \pm 10 \%$.
2. $8279, C_{L}=100 p F ; 8279-5, C_{L}=150 p F$.

## Other Timings:

|  |  | 8279 |  | $8279-5$ |  |
| :---: | :--- | :--- | :--- | :--- | :---: |
| Symbol | Parameter | Min. $\quad$ Max. | Min. $\quad$ Max. | Unit |  |
| $\mathrm{t}_{\phi W}$ | Clock Pulse Width | 230 | 120 | nsec |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Clock Period | 500 | 320 | nsec |  |


| Keyboard Scan Time: | 5.1 msec | Digit-on Time: | $480 \mu \mathrm{sec}$ |
| :--- | :--- | :--- | :--- |
| Keyboard Debounce Time: | 10.3 msec | Blanking Time: | $160 \mu \mathrm{sec}$ |
| Key Scan Time: | $80 \mu \mathrm{sec}$ | Internal Clock Cycle: | $10 \mu \mathrm{sec}$ |
| Display Scan Time: | 10.3 msec |  |  |



Input Waveforms For A.C. Tests


## WAVEFORMS

## Read Operation



## Write Operation



## Clock Input



## SCAN WAVEFORMS



## DISPLAY WAVEFORMS



NOTE: SHOWN IS ENCODED SCAN LEFT ENTRY
$S_{2} \cdot S_{3}$ ARE NOT SHOWN BUT THEY ARE SIMPLY $S_{1}$ DIVIDED BY 2 AND 4

## GPIB TALKER/LISTENER

- Designed to Interface Microprocessors (e.g., 8080, 8085, 8086, 8048) to an IEEE Standard 488 Digital Interface Bus
- Programmable Data Transfer Rate
- Complete Source and Acceptor Handshake
- Complete Talker and Listener Functions with Extended Addressing
- Service Request, Parallel Poll, Device Clear, Device Trigger, Remote/Local Functions
- Selectable Interrupts
- On-Chip Primary and Secondary Address Recognition
- Automatic Handling of Addressing and Handshake Protocol
- Provision for Software Implementation of Additional Features
- 1-8 MHz Clock Range
- 16 Registers (8 Read, 8 Write), 2 for Data Transfer, the Rest for Interface Function Control, Status, etc.
- Directly Interfaces to External NonInverting Transceivers for Connection to the GPIB
- Provides Three Addressing Modes, Allowing the Chip to be Addressed Either as a Major or a Minor Talker/ Listener with Primary or Secondary Addressing
- DMA Handshake Provision Allows for Bus Transfers without CPU Intervention
- Trigger Output Pin
- On-Chip EOS (End of Sequence) Message Recognition Facilitates Handling of Multi-Byte Transfers

The 8291 GPIB Talker/Listener is a microprocessor-controlled chip designed to interface microprocessors (e.g., 8048, $8080,8085,8086$ ) to an IEEE Standard 488 Instrumentation Interface Bus. It implements all of the Standard's interface functions except for the controller.

## PIN CONFIGURATION

## 

BLOCK DIAGRAM


TO NON-INVERTING BUS TRANSCEIVERS

PIN DESCRIPTION

| Symbol | 1/0 | Pin No. | Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 1/0 | 12-19 | Data bus port, to be connected to microprocessor data bus. |
| $\mathrm{RSO}_{0}-\mathrm{RS}_{2}$ | 1 | 21-23 | Register select inputs, to be connected to three non-multiplexed microprocessor address bus lines. Select which of the 8 internal read (write) registers will be read from (written into) with the execution of $\overline{\mathrm{RD}}(\overline{\mathrm{WR}})$. |
| $\overline{C S}$ | I | 8 | Chip select. When low, enables reading from or writing into the register selected by RSo-RS2. |
| $\overline{\mathrm{RD}}$ | 1 | 9 | Read strobe. When low, selected register contents are read by the CPU. |
| $\overline{W R}$ | 1 | 10 | Write strobe. When low, data is written into the selected register. |
| INT ( $\overline{\text { INT }}$ ) | 0 | 11 | Interrupt request to the microprocessor, set high for request and cleared when the appropriate register is accessed by the CPU. May be software configured to be active low. |
| DMA REQ | 0 | 6 | DMA request, normally low, set high to indicate byte output or byte input, in DMA mode; reset by DMA ACK. |
| $\overline{\text { DMA ACK }}$ | 1 | \& | DMA acknowledge. When low, resets DMA REQ and selects data in/data out register for DMA data transfer (actual transfer done by $\overline{R D} / \overline{W R}$ pulse). |
| TRIG | 0 | 5 | Trigger output, normally low; generates a triggering pulse corresponding to the GET command. |
| CLOCK | 1 | 3 | External clock input, used for internal time delays generator. May be any speed in 1.8 MHz range. |
| RESET | 1 | 4 | Reset input. When high, forces the device into an "Idle" (initialization) mode. The device will remain at "Idle" until released by the microprocessor. |
| $\overline{\mathrm{DIO}}_{1}-\overline{\mathrm{DIO}}_{8}$ | 1/0 | 28-35 | 8-bit GPIB data port, used for bidirectional data byte transfer between 8291 and GPIB via noninverting external line transceivers. |
| $\overline{\text { DAV }}$ | $1 / 0$ | 36 | Data valid; GPIB handshake control line. Indicates the availability and validity of information on the DIO lines. |



Note: all signals on the 8291 pins are specified with positive logic. However, IEEE 488 specifies negative logic on its 16 signal lines.


## THE GENERAL PURPOSE INTERFACE BUS (GPIB)

The General Purpose Interface Bus (GPIB) is defined in the IEEE Standard 488-1975 "Digital Interface for Programmable Instrumentation." Although a knowledge of this standard is assumed, Figure 1 provides the bus structure for quick reference. Also, Tables 1 and 2 reference the interface state mnemonics and the interface messages respectively. Modified state diagrams for the 8291 are presented in Appendix A.

## GENERAL DESCRIPTION

The 8291 is a microprocessor controlled device designed to interface microprocessors e.g., 8048, 8080, 8085,8086 to the GPIB. It implements all of the interface functions defined in the IEEE 488 Standard. If an implementation of the Standard's Controller function is desired, it can be connected with an Intel ${ }^{\circledR} 8292$ to form a complete interface.

The 8291 handles communication between a microprocessor controlled device and the GPIB. Its capabilities include data transfer, handshake protocol, talker/listener addressing procedures, device clearing and triggering, service request, and both serial and parallel polling schemes. In most procedures, it does not disturb the microprocessor unless a byte is waiting on input or a byte sent on output (output buffer empty).

The 8291 architecture includes 16 registers. Eight of these registers may be written into by the microprocessor. The other eight registers may be read by the microprocessor. One each of these read and write registers is for direct data transfers. The rest of the write registers control the various features of the chip, while the rest of the read registers provide the microprocessor with a monitor of GPIB states, various bus conditions, and device conditions.


Figure 1. Interface Capabilities and Bus Structure.

## GPIB Addressing

Each device connected to the GPIB must have at least one address whereby the controller device in charge of the bus can configure it to talk, listen, or send status. An 8291 implementation of the GPIB offers the user three addressing modes from which the device can be initialized for each application. The first of these modes allows for the device to have two separate primary addresses. The
second mode allows the user to implement a single talker/listener with a two byte address (primary address + secondary address). The third mode again allows for two distinct addresses but in this instance, they can each have a two-byte address. However, this mode requires that the secondary addresses be passed to the microprocessor for verification. These three addressing schemes are described in more detail in the discussion of the Address registers.

TABLE 1.
IEEE 488 INTERFACE STATE MNEMONICS

| Mnemonic | State Represented |
| :--- | :--- |
| ACDS | Accept Data State |
| ACRS | Acceptor Ready State |
| AIDS | Acceptor Idle State |
| ANRS | Acceptor Not Ready State |
| APRS | Affirmative Poll Response State |
| AWNS | Acceptor Wait for New Cycle State |
| CACS | Controller Active State |
| CADS | Controller Addressed State |
| CAWS | Controller Active Wait State |
| CIDS | Controller Idle State |
| CPPS | Controller Parallel Poll State |
| CPWS | Controller Parallel Poll Wait State |
| CSBS | Controller Standby State |
| CSNS | Controller Service Not Requested State |
| CSRS | Controller Service Requested State |
| CSWS | Controller Synchronous Wait State |
| CTRS | Controller Transfer State |
| DCAS | Device Clear Active State |
| DCIS | Device Clear Idle State |
| DTAS | Device Trigger Active State |
| DTIS | Device Trigger Idle State |
| LACS | Listener Active State |
| LADS | Listener Addressed State |
| LIDS | Listener Idle State |
| LOCS | Local State |
| LPAS | Listener Primary Addressed State |
| LPIS | Listener Primary Idle State |
| LWLS | Local With Lockout State |
| NPRS | Negative Poll Response State |


| Mnemonic | State Represented |
| :--- | :--- |
| PACS | Parallel Poll Addressed to Configure State |
| PPAS | Parallel Poll Active State |
| PPIS | Parallel Poll Idle State |
| PPSS | Parallel Poll Standby State |
| PUCS | Parallel Poll Unaddressed to Configure State |
| REMS | Remote State |
| RWLS | Remote With Lockout State |
| SACS | System Control Active State |
| SDYS | Source Delay State |
| SGNS | Source Generate State |
| SIAS | System Control Interface Clear Active State |
| SIDS | Source Idle State |
| SIIS | System Control Interface Clear Idle State |
| SINS | System Control Interface Clear Not Active State |
| SIWS | Source Idle Wait State |
| SNAS | System Control Not Active State |
| SPAS | Serial Poll Active State |
| SPIS | Serial Poll Idle State |
| SPMS | Serial Poll Mode State |
| SRAS | System Control Remote Enable Active State |
| SRIS | System Control Remote Enable Idle State |
| SRNS | System Control Remote Enable Not Active State |
| SRQS | Service Request State |
| STRS | Source Transfer State |
| SWNS | Source Wait for New Cycle State |
| TACS | Talker Active State |
| TADS | Talker Addressed State |
| TIDS | Talker Idle State |
| TPIS | Talker Primary Idle State |

------ The Controller function is implemented on the Intel 8292.

TABLE 2.
IEEE 488 INTERFACE MESSAGE REFERENCE LIST

| Mnemonic | Message | Interface Function(s) |
| :---: | :---: | :---: |
| LOCAL MESSAGES RECEIVED (By Interface Functions) |  |  |
| * gts | go to standby | C |
| ist | individual status | PP |
| Ion | listen only | L, LE |
| lpe | local poll enable | PP |
| nba | new byte available | SH |
| pon | power on | SH,AH,T,TE,L,LE,SR,RL,PP,C |
| rdy | ready | AH |
| * rpp | request parallel poll | C |
| * rsc | request system control | C |
| rsv | request service | SR |
| rtl | return to local | RL |
| * sic | send interface clear | C |
| * sre | send remote enable | C |
| *tca | take control asynchronously | C |
| *tcs | take control synchronously | AH, C |
| ton | talk only | T, TE |
| REMOTE MESSAGES RECEIVED |  |  |
| ATN | Attention | SH,AH,T,TE,L,LE, PP, C |
| DAB | Data Byte | (Via L, LE) |
| DAC | Data Accepted | SH |
| DAV | Data Valid | AH |
| DCL | Device Clear | DC |
| END | End | (via L, LE) |
| GET | Group Execute Trigger | DT |
| GTL | Go to Local | RL |
| IDY | Identify | L,LE,PP |
| IFC | Interface Clear | T,TE,L,LE,C |
| LLO | Local Lockout | RL |
| MLA | My Listen Address | L,LE,RL,T,TE |
| MSA | My Secondary Address | TE,LE,RL |
| MTA | My Talk Address | T,TE,L,LE |
| OSA | Other Secondary Address | TE |
| OTA | Other Talk Address | T, TE |
| PCG | Primary Command Group | TE,LE,PP |
| $\dagger$ PPC | Parallel Poll Configure | PP |
| $\dagger$ (PPD) | Parallel Poll Disable | PP |
| $\dagger$ [PPE] | Parallel Poll Enable | PP |
| * PPRN | Parallel Poll Response N | (via C) |
| $\dagger$ PPU | Parallel Poll Unconfigure | PP |
| REN | Remote Enable | RL |
| RFD | Ready for Data | SH |
| RQS | Request Service | (via L, LE) |
| [SDC] | Select Device Clear | DC |
| SPD | Serial Poll Disable | T, TE |
| SPE | Serial Poll Enable | T, TE |
| * SQR | Service Request | (via C) |
| STB | Status Byte | (via L, LE) |
| *TCT or [TCT] | Take Control | C |
| UNL | Unlisten | L, LE |

[^26]TABLE 2. (Cont'd)
IEEE 488 INTERFACE MESSAGE REFERENCE LIST

**All Controller messages must be sent via Intel's 8292.

## 8291 Registers

A bit-by-bit map of the 16 registers on the 8291 is presented in Table 3. A more detailed explanation of each of these registers and their functions follows. The access of these registers by the microprocessor is accomplished by using the $\overline{C S}, \overline{R D}, \overline{W R}$, and $\mathrm{RS}_{0}-\mathrm{RS}_{2}$ pins.

| Register | $\overline{\text { CS }}$ | $\overline{\text { RD }}$ | $\overline{\text { WR }}$ | RSO-RS 2 |
| :---: | :---: | :---: | :---: | :---: |
| All Read Registers | 0 | 0 | 1 | CCC |
| All Write Registers | 0 | 1 | 0 | ccc |
| Don't Care | 1 | X | X | xxx |

TABLE 3. 8291 REGISTERS

|  | READ REGISTERS |  |  |  |  |  |  | REGISTER SELECT CODE |  |  | WRITE REGISTERS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  | RS2 | RS1 | RSO |  |  |  |  |  |  |  |  |
| D17 | DI6 | DI5 | DI4 | DI3 | DI2 | DI 1 | DIO | 0 | 0 | 0 | 007 | DO6 | D05 | D04 | DO3 | DO2 | D01 | DO0 |
| DATA IN |  |  |  |  |  |  |  |  |  |  | DATA OUT |  |  |  |  |  |  |  |
| CPT | APT | GET | END | DEC | ERR | BO | BI | 0 | 0 | 1 | CPT | APT | GET | END | DEC | ERR | BO | BI |
| INTERRUPT STATUS 1 |  |  |  |  |  |  |  |  |  |  | INTERRUPT MASK 1 |  |  |  |  |  |  |  |
| INT | SPAS | LLO | REM | SPASC | LLOC | REMC | ADSC | 0 | 1 | 0 | 0 | 0 | DMAO | DMAI | SPASC | LLOC | REMC | ADSC |
| INTERRUPT STATUS 2 |  |  |  |  |  |  |  |  |  |  | INTERRUPT MASK 2 |  |  |  |  |  |  |  |
| S8 | SROS | S6 | S5 | S4 | S3 | S2 | S1 | 0 | 1 | 1 | S8 | rsv | S6 | S5 | S4 | S3 | S2 | S1 |
| SERIAL POLL STATUS |  |  |  |  |  |  |  |  |  |  | SERIAL POLL MODE |  |  |  |  |  |  |  |
| ton | lon | EOI | LPAS | TPAS | LA | TA | MJMN | 1 | 0 | 0 | то | LO | 0 | 0 | 0 | 0 | ADM 1 | ADMO |
| ADDRESS STATUS |  |  |  |  |  |  |  |  |  |  | ADDRESS MODE |  |  |  |  |  |  |  |
| CPT7 | CPT6 | CPT5 | CPT4 | CPT3 | CPT2 | CPT1 | CPTO | 1 | 0 | 1 | CNT2 | CNT1 | CNTO | COM4 | COM3 | COM2 | COM1 | COMO |
| COMMAND PASS THROUGH |  |  |  |  |  |  |  |  |  |  | AUX MODE |  |  |  |  |  |  |  |
| X | DT0 | DLO | AD5-0 | AD4-0 | AD3-0 | AD2-0 | AD1-0 | 1 | 1 | 0 | ARS | DT | DL | AD5 | AD4 | AD3 | AD2 | AD1 |
| ADDRESS 0 |  |  |  |  |  |  |  |  |  |  | ADDRESS 0/1 |  |  |  |  |  |  |  |
| X | DT1 | DL1 | AD5-1 | AD4-1 | AD3-1 | AD2-1 | AD1-1 | 1 | 1 | 1 | EC7 | EC6 | EC5 | EC4 | EC3 | EC2 | EC1 | EC0 |
| ADDRESS 1 |  |  |  |  |  |  |  |  |  |  | EOS |  |  |  |  |  |  |  |

## Data Registers



## DATA-OUT REGISTER (OW)

The data-in register is used to move data from the GPIB to the microprocessor or to memory when the 8291 is
addressed to listen. Incoming information is separately latched by this register, and its contents are not destroyed by a write to the data-out register. The RFD (Ready for Data) message is held false until the byte is removed from the data in register, either by the microprocessor or by DMA. The 8291 then completes the handshake automatically. In RFD/DAV holdoff mode (see Auxiliary Register A), the handshake is not finished until a command is sent telling the 8291 to release the holdoff. In this way, the same byte may be read several times, or an over anxious talker may be held off until all available data has been processed.

When the 8291 is addressed to talk, it uses the data-out register to move data onto the GPIB. Upon a write to this register, the 8291 initiates and completes the handshake while sending the byte out over the bus. When the

RFD/DAV holdoff mode is in effect, data is held until the release command is issued. Also, a read of the data-in register does not destroy the information in the datarout register.

## Interrupt Registers



INTERRUPT STATUS 1 (1R)


INTERRUPT STATUS 2 (2R)

The 8291 can be configured to generate an interrupt to the microprocessor upon the occurrence of any of 12 conditions or events on the GPIB. Upon receipt of an interrupt, the microprocessor must read the Interrupt Status registers to determine which event has occurred, and then execute the appropriate service routine (if necessary). Each of the 12 interrupt status bits has a matching mask bit in the interrupt mask registers. These mask bits are used to select the events that will cause the INT pin to be asserted. Writing a logic " 1 " into any of these bits enables the corresponding interrupt status bits to


INTERRUPT MASK 1 (1W)


INTERRUPT MASK 2 (2W)
generate an interrupt. Bits in the Interrupt Status registers are set regardless of the states of the mask bits. The Interrupt Status registers are then cleared upon being read or when a local pon (power-on) message is executed. If an event occurs while one of the Interrupt Status registers is being read, the event is typically held until after its register is cleared and then placed in the register.
The mnemonics for each of the bits in these registers and a brief description of their respective functions appears in Table 4. This table also indicates how each of the interrupt bits is set.

TABLE 4. Interrupt Bits

| Indicates Undefined Commands | CPT | An undefined command has been received. |
| :---: | :---: | :---: |
| Set by (TPAS + LPAS)•SCG•ACDS•MODE 3 | APT | A secondary address must be passed through |
| Set by DTAS | GET | A group execute trigger has occurred. |
| Set by (EOS + EOI)•LACS | END | An EOS or EOI message has been received. |
| Set by DCAS | DEC | Device Clear Active State has occurred. |
| Set by TACS•nba•DAC•RFD | ERR | Interface error has occurred; no listeners are active. |
| TACS•(SWNS + SGNS) | BO | A byte has been output. |
| Set by LACS•ACDS | BI | A byte has been input. |


| Shows status of the INT pin The device has been enabled for a serial poll | INT | These are status only. They will not generate interrupts, nor do they have corresponding mask bits. |  |
| :---: | :---: | :---: | :---: |
|  | SPAS |  |  |
| The device is in local lock out state. <br> (LWLS+RWLS) | LLO |  |  |
| The device is in a remote state. <br> (REMS+RWLS) | REM |  |  |



*In ton (talk-only) and lon (listen-only) modes, no ADSC interrupt is generated.

The BO and BI interrupts enable the user to perform data transfer cycles. BO indicates that a byte has been sent to the GPIB and a new data byte may be written into the Data Out register. It is set by the occurrence of TACS • (SWNS +SGNS). Hence, it is reset when a data byte is written into the Data Out register, when ATN is asserted on the GPIB, or when the device stops being addressed to talk. Similarly, BI is set when an input byte is accepted into the 8291 and reset when the microprocessor reads the Data In register. BO and BI are also reset by pon (power-on local message) and by a read of the Interrupt Status 1 register. However, if it is so desired, data transfer cycles may be performed without reading the Interrupt Status 1 register if all interrupts except for BO or BI are masked; BO and BI will automatically reset after each byte is transferred.

If the 8291 is used without DMA, the BO and BI interrupts may be enabled through the DMA REQ pin. The DMAO and DMAI bits in the Interrupt Mask 2 register would be the corresponding mask bits for this feature. Thus, implementing this feature, with BO and BI masked from the INT pin, allows for servicing of these interrupts without reading the Interrupt Status registers.

The ERR bit is set to indicate the bus error condition where the 8291 is an active talker, tries sending a byte to the GPIB, but there are no active listeners (e.g., all devices on the GPIB are in AIDS). The logical equivalent of (nba TACS • DAC • RFD) will set this bit.

The DEC bit is set whenever DCAS has occurred. The user must define a known state to which all device functions will return in DCAS. Typically this state will be a power-on state. However, the state of the device functions at DCAS is at the designer's discretion. It should be noted that DCAS has no effect on the interface functions which are returned to a known state by the IFC (interface clear) message or the pon local message.

The End Interrupt bit may be used by the microprocessor to detect that a multi-byte transfer has been completed. The bit will be set when the 8291 is an active listener (LACS) and either EOS or EOI is received. EOS will generate an interrupt when the byte in the Data In register matches the byte in the EOS register. Otherwise the interrupt will be generated when a true input is detected at the EOI pin of the 8291.

The GET interrupt bit is used by the microprocessor to detect that DTAS has occurred. It is set by the 8291 when the GET message is received while it is addressed to listen. The TRIG output pin of the 8291 is also asserted when the GET message is received. Thus, the basic operation of the device may be started without involving the microprocessor.

The APT interrupt bit indicates to the processor that a secondary address is available in the CPT register for validation. This interrupt will only occur if Mode 3 addressing is in effect. (Refer to the section on addressing.) In Mode 2, secondary addresses will be recognized on the 8291. They will be ignored in Mode 1.

The CPT interrupt bit flags the occurrence of an undefined command and of all secondary commands following an undefined command. The Command pass through feature is enabled by the BO bit of Auxiliary register B.

$$
U D C=[U C G+A C G(T A D S \bullet \overline{P P C}
$$

+ LADS• $\overline{T C T})] \cdot$ undefined•BO
where:
ACG - Addressed Command Group
UCG - Universal Command Group
SCG - Secondary Command Group
Any message not decoded by the 8291 (not included in the state diagrams in Appendix B) becomes an undefined command. Note from the logic equation that any addressed command is automatically ignored when the 8291 is not addressed.
Undefined commands are read by the CPU from the Command Pass Through Register of the 8291. Until this register is read, the 8291 will hold off the handshake (only if the CPT feature is enabled).
An especially useful feature of the 8291 is its ability to generate interrupts from state transitions in the interface functions. In particular, the lower 4 bits of the Interrupt Status 2 register, if enabled by the corresponding mask bits, will cause an interrupt upon changes in the following states as defined in IEEE 488:

| Bit 0 | ADSC | change in LIDS or TIDS or MJMN |
| :--- | :--- | :--- |
| Bit 1 | RLC | change in LOCS or REMS |
| Bit 2 | LLOC | change in LWLS or RWLS |
| Bit 3 | SPASC | change in SPAS |

The upper 4 bits of the Interrupt Status 2 register are available to the processor as status bits. Thus, if one of the bits 1-3 generates an interrupt indicating a state change has taken place, the corresponding status bit (bits 5-7) may be read to determine what the new state is. To determine the nature of a change in addressed status (bit 0 ) the Address Status Register is available to be read. And finally, bit 7 monitors the state of the 8291 INT pin. Logically, it is an OR of all unmasked interrupt status bits. One should note that bits 4-7 of the Interrupt Status 2 Register do not generate interrupts, but are available only to be read as status bits by the processor.
Bits 4 and 5 (DMAI, DMAO) of the Interrupt Mask 2 Register are available to enable direct data transfers between memory and the GPIB, DMAI (DMA in) enables the DMA REQ (DMA request) pin of the 8291 to be asserted upon the occurrence of BI. Similarly, DMAO (DMA out) enables the DMA REQ pin to be asserted upon the occurrence of BO. One might note that the DMA REQ pin may be used as a second interrupt output pin, monitoring BI and/or BO and masked by DMAI and DMAO. One should note that the DMA REQ pin is not affected by a read of the Interrupt Status 1 Register. It is reset whenever a byte is written to the Data Out Register or read from the Data in Register.
To ensure that an interrupt status bit will not be cleared without being read, and will not remain uncleared after being read, the 8291 implements a special interrupt
handling procedures. When an unmasked interrupt bit is set in either of the Interrupt Status Registers, the input of the registers are blocked until the set bit is read and reset by the microprocessor. Thus, potential problems arise when interrupt status changes while the register is being blocked. However, the 8291 stores all new interrupts in a temporary register and transfers them to the appropriate interrupt Status Register after the interrupt
has been reset. In the Interrupt Status 1 Register and in ADSC bit, this transfer takes place only if the corresponding bits were read as zeroes. For the other status change bits in the Interrupt Status 2 Register," the transfer will always take place. However, even number of changes in these status bits during blocking time will cause no interrupt.

| S8 | rsv | S6 | S5 | S4 | S3 | S2 | S1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

SERIAL POLL MODE (3W)
talk. At this point, one byte of status is returned by the 8291 via the Serial Poll Mode Register.

The Serial Poll Status Register is available for reading the status byte in the Serial Poll Mode Register. The processor may check the status of a request for service by polling bit 6 of this register, which corresponds to SRQS (Service Request State). When a Serial Poll is conducted and the controller-in-charge reads the status byte, the SRQS bit is cleared. The SRQ line is tied to this bit, so that a request for service is terminated when the 8291's status byte is read. The rsv bit of the Serial Poll Mode Register must then be cleared by the microprocessor.

## Address Registers



The Address Mode Register is used to select one of the five modes of addressing available on the 8291. It determines the way in which the 8291 uses the information in the Address 0 and Address 1 registers:
-In Mode 1, the contents of the Address 0 Register constitute the "Major" talker/listener address while the Address 1 Register represents the "Minor" talker/listener address. In applications where only one address is needed, the major talker/listener is used, and the minor talker/listener should be disabled. Loading an addres via the Address $0 / 1$ Register into Address Registers 0 and 1 enables the major and minor talker/listener functions respectively.
-In Mode 2 the 8291 recognizes two sequential address bytes: a primary followed by a secondary. Both address bytes must be received in order to enable the device to talk or listen. In this manner, Mode 2 addressing implements the extended talker and listener functions as defined in IEEE 488.


To use Mode 2 addressing the primary address must be loaded into the Address 0 Register, and the Secondary address is placed in the Address 1 Register. With both primary and secondary addresses residing on chip, the 8291 can handle all addressing sequences without processor intervention.
-In Mode 3, the 8291 handles addressing just as it does in Mode 1, except that each Major or Minor primary address must be followed by a secondary address. All secondary addresses must be verified by the microprocessor when Mode 3 is used. When the 8291 is in TPAS or LPAS (talker/listener primary addresses state), and it does not recognize the byte on the DIO lines, an APT interrupt is generated (see section on Interrupt Registers) and the byte is available in the CPT (Command Pass-Through) Register. As part of its interrupt service routine, the microprocessor must read the CPT Register and write one of the following responses to the Auxiliary Mode Register:

1. 07 H implies a non-valid secondary address
2. OFH implies a valid secondary address

Setting the "ton" bit generates the local ton (talk-only) message and sets the 8291 to a talk-only mode. This mode allows the device to operate as a talker in an interface system without a controller.
Setting the "Ion" bit generates the local Ion (listen-only) message and sets the 8291 to a listen-only mode. This mode allows the device to operate as a listener in an interface system without a controller.

The mode of addressing implemented by the 8291 may be selected by writing one of the following bytes to the Address Mode Register:

| $\frac{1}{\text { Register Contents }}$ | Mode |
| :--- | :--- |
| 10000000 |  |
| 01000000 | Enable talk only mode (ton) |
| 11000000 | Thable listen only mode (Ion) |
| 00000001 | Mode 1, (Primary-Primary) |
| 00000010 | Mode 2 (Primary-Secondary) |
| 00000011 | Mode 3 (Primary/APT-Primary/APT) |

The Address Status Register contains information used by the microprocessor to handle its own addressing. This information includes status bits that monitor the address state of each talker/listener, "ton" and "lon" flags which indicate the talk only and listen only states, and an EOI bit which, when set, signifies that the END message came with the last data byte. LPAS and TPAS indicate that the listener or talker primary address has been received. The microprocessor can then use these bits when the secondary address is passed through to determine whether the 8291 is addressed to talk or listen. The LA (listener addressed) bit will be set when the 8291 is in LACS (Listener Active State) or in LADS (Listener Addressed State). Similarly, the TA (Talker Addressed bit will be set to indicate TACS or TADS, but also to indicate SPAS (Serial Poll Active State). The MJMN bit is used to determine whether the information in the other bits applies to the Major or Minor talker/listener. It is set to " 1 " when the Minor talker/listener is addressed. It should be noted that only one talker/listener may be active at any one time. Thus, the MJMN bit will indicate which, if either, of the talker/listeners is addressed or active.

The Address 0/1 Register is used for specifying the device's addresses according to the format selected in the Address Mode Register. Five bit addresses may be loaded into the Address 0 and Address 1 registers by writing into the Address 0/1 Register. The ARS bit is used to select which of these registers the other seven bits will be loaded into. The DT and DL bits may be used to disable the talker or listener function at the address signified by the other five bits. When Mode 1 addressing is used and only one primary address is desired, both the talker and the listener should be disabled at the Minor address.

As an example of how the Address 0/1 Register might be used, consider an example where two primary addresses are needed in the device. The Major primary address will be selectable only as a talker and the Minor primary address will be selectable only as a listener. This configuration of the 8291 is formed by the following sequence of writes by the microprocessor:

| Operation | $\overline{\mathbf{c s}}$ | RD | Wh | \% Data | AS2-RS0 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1. Select addressing Mode 1 | 0 | 1 | 0 | 00000001 | $100$ |
| 2. Load major address into Address 0 Register with listener function disabled. | 0 | 1 | 0 | 001AAAAA |  |
| 3. Load minor address into Address 1 Register with talker function disabled. | 0 | 1 | 0 | 110BBBBB | 110 |

At this point, the addresses AAAAA and BBBBB are stored in the Address 0 and Address 1 registers respectively, and are available to be read by the microprocessor. Thus, it is not necessary to store any address information elsewhere. Also, with the information stored in the Address 0 and Address 1 registers, processor intervention is not required to recognize addressing by the controller. Only in Mode 3, where secondary addresses are passed through, must the processor intervene in the addressing sequence.

## Command Pass Through Register

| CPT7 | CPT6 | CPT5 | CPT4 | CPT3 | CPT2 | CPT1 | CPT0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

COMMAND PASS THROUGH (5R)

The Command Pass Through Register is used to transfer undefined 8-bit remote message codes from the GPIB to the microprocessor. When the CPT feature is enabled (bit B0 in Auxiliary Register B), any message not decoded by the 8291 becomes an undefined command. When Mode 3 addressing is used secondary addresses are also passed through the CPT Register. In either case, the 8291 will holdoff the handshake until the microprocessor reads this register and issues the VSCMD auxiliary command.

The CPT and APT interrupts flag the availability of undefined commands and secondary addresses in the CPT Register. The details of these interrupts are explained in the section on Interrupt Registers.

An added feature of the 8291 is its ability to handle undefined secondary commands following undefined primaries. Thus, the number of available commands for user definition or future IEEE 488 definition is significantly increased; one undefined primary command followed by a sequence of as many as 32 secondary commands can be processed. However, it is recommended that users do not define their own commands since such definition would violate IEEE 488.

The recommended use of the 8291's undefined command capabilities is for a controller-configured Parallel Poll. The PPC message is an undefined primary command typically followed by PPE, an undefined secondary command. For details on this procedure, refer to the section on Parallel Poll Protocol.

## Auxiliary Mode Register



AUX MODE (5W)
CNTO-2:CONTROL BITS COMO-:COMMAND BITS

The Auxiliary Mode Register contains a three-bit control field and a five-bit command field. It is used for several purposes on the 8291:

1. To load "hidden" auxiliary registers on the 8291.
2. To issue commands from the microprocessor to the 8291.
3. To preset an internal counter used to generate T1, delay in the Source Handshake function, as defined in IEEE 488.

Table 4 summarizes how these tasks are performed with the Auxiliary Mode Register. Note that the three control bits determine how the five command bits are interpreted.

## TABLE 4

| CODE |  | COMMAND |
| :---: | :---: | :---: |
| $\begin{gathered} \hline \text { CONTROL } \\ \text { BITS } \\ \hline \end{gathered}$ | $\begin{gathered} \text { COMMAND } \\ \text { BITS } \\ \hline \end{gathered}$ |  |
| 000 | 0cccc | $\begin{aligned} & \text { Execute auxiliary command } \\ & \text { CCCC } \end{aligned}$ |
| 001 | OFFFF | Preset internal counter to match external clock frequency of FFFF MHZ (FFFF - binary representation of 1 to 8 MHz ) |
| 100 | DDDDD | Write DDDDD into auxiliary register A |
| 101 | ODDDD | Write DDDD into auxiliary register B |
| 011 | USP $\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{P}_{1}$ | Configure/unconfigure parallel poll $\mathrm{SP}_{3} \mathrm{P}_{2} \mathrm{P}_{1}$ as defined in Std. 488. (Configure if $U=0$, Unconfigure if $U=1$ ). This command is the local poll enable (lpe) message when $U=0$. |

## AUXILIARY COMMANDS

Auxiliary commands are executed by the 8291 whenever 0000 CCCC is written into the Auxiliary Mode Register, where CCCC is the 4-bit command code.

| 4-Bit Code | Description |
| :--- | :--- |
| 0000 | Immediate Execute pon - This command re- <br> sets the 8291 to a power up state (local pon <br> message as defined in IEEE 488). <br> The following conditions constitute the power <br> up state: <br> 1. All talkers and listeners are disabled. <br> 2. No interrupt status bits are set. |


| 4-Bit Code | Description |
| :--- | :--- |
|  | The 8291 is |

The 8291 is designed to power up in certain states as specified in the IEEE 488 state diagrams. Thus, the following states are in effect in the power up state: SIDS, AIDS, TIDS, LIDS, NPRS, LOCS, and PPIS.

The "0000" pon is an immediate execute command (a pon pulse). It is also used to release the "initialize" state generated by either an external reset pulse or the "0010" Chip Reset command.

Chip Reset (Initialize) - This command has the same effect as a pulse applied to the Reset pin. (Refer to the section on Reset Procedure.)

0011 Finish Handshake - This command finishes a handshake that was stopped because of a holdoff on RFD or DAV. (Refer to Auxiliary Register A.)
0100
Trigger - A "Group Execute Trigger" is forced by this command. It has the same effect as a GET command issued by the controller-in-charge of the GPIB, but does not cause a GET interrupt.
rtl ${ }^{1}$ - This command corresponds to the local rtl message as defined in IEEE 488. The 8291 will go to a local state if local lockout is not in effect.
Send EOI - The EOI line of the 8291 may be asserted with this command. The command causes EOI to go true with the next byte transmitted. The EOI line is then cleared upon completion of the handshake for that byte.
0111, 1111 Non-Valid/Valid Secondary Address or Command (VSCMD) - This command informs the 8291 that the secondary address received by the microprocessor was valid or invalid ( $0111 \rightarrow$ invalid, $1111 \rightarrow$ valid). If Mode 3 addressing is used, the processor must field each extended address and respond to it, or the GPIB will hang up. Note that the COM3 bit is the invalid/valid flag.
The valid (1111) command is also used to tell the 8291 to continue from the command-passthrough state (immediate execute command).
0001, 1001 Parallel Poll Flag (local "ist" message) - This command sets (1001) or clears (0001) the parallel poll flag. A " 1 " is sent over the assigned data line (PPR-Parallel Poll Response true) only if the parallel poll flag matches the sense bit from the lpe local message (or indirectly from the PPE message). For a more complete description of the Parallel Poll features and procedures refer to the section on Parallel Poll Protocol.

[^27]
## INTERNAL COUNTER

The internal counter determines the delay time allowed for the settling of data on the DIO lines. This delay time is defined as $T_{1}$ in IEEE 488 and appears in the Source Handshake state diagram between SDYS and STRS. As such, DAV is asserted $T_{1}$ after the DIO lines are driven. Consequently, $T_{1}$ is a major factor in determining the data transfer rate of the 8291 over the GPIB ( $\mathrm{T}_{1}=$ TWROV2-TWROI5).
When open-collector transceivers are used for connection to the GPIB, $\mathrm{T}_{1}$ is defined by IEEE 488 to be $2 \mu \mathrm{sec}$. By writing 0010FFFF into the Auxiliary Mode Register, the counter is preset to match a fc MHz clock input, where FFFF is the binary representation of $N_{F}\left(1 \leq N_{F} \leq 8\right.$, $\left.N_{F}=(F F F F)_{2}\right)$. When $N_{F}=f_{C}$, a $2 \mu \mathrm{sec} \mathrm{T}_{1}$ delay will be generated before each DAV asserted.
$T_{1(\mu \mathrm{sec})}=\frac{2 \mathrm{~N}_{\mathrm{F}}}{\overline{\mathrm{f}_{\mathrm{C}}}}+\mathrm{t}_{\mathrm{SYNC}}, 1 \leqslant \mathrm{~N}_{\mathrm{F}} \leqslant 8$
tSYNC is a synchronization error, greater than zero and smaller than the larger of T clock high and T clock low. (For a $50 \%$ duty cycle clock, tsync is less than half the clock cycle).

If it is necessary that $\mathrm{T}_{1}$ be different from $2 \mu \mathrm{sec}, \mathrm{N}_{\mathrm{F}}$ may be set to a value other than fc . In this manner, data transfer rates may be programmed for a given system. In small systems, for example, where transfer rates exceeding GPIB specifications are required, one may set $N_{F}<f_{c}$ and decrease $\mathrm{T}_{1}$.

When tri-state transceivers are used, IEEE 488 allows a higher transfer rate (lower $T_{1}$ ). Use of the 8291 with such transceivers is enabled by setting B2 in Auxiliary Register B.In this case, setting $N_{F}=f c$ causes a $T_{1}$ delay of $2 \mu \mathrm{sec}$ to be generated for the first byte transmitted - all subsequent bytes will have a delay of 500 nsec .
$T_{1}\left(\right.$ High Speed) $\mu \mathrm{sec}=\frac{\mathrm{N}_{\mathrm{F}}}{2 \mathrm{f}_{\mathrm{C}}}+\mathrm{tsYNC}$
Thus, setting $\mathrm{N}_{\mathrm{F}}=1$ using a 4 MHz clock will generate for a $50 \%$ duty cycle clock ( $t_{\text {SYNC }}<125$ nsec.):
$\mathrm{T}_{1}=\frac{1}{2.4}+0.125=0.250 \mu \mathrm{sec}=250 \mathrm{nsec}$

## AUXILIARY REGISTER A

Auxiliary Register A is a "hidden" 5-bit register which is used to enable some of the 8291 features. Whenever a $100 A_{4} A_{3} A_{2} A_{1} A_{0}$ byte is written into the Auxiliary Register, it is loaded with the data $A_{4} A_{3} A_{2} A_{1} A_{0}$. Setting the respective bits to " 1 " enables the following features:
Ao - RFD/DAV Holdoff on all Data: If the 8291 is listening, RFD will not be sent true until the "finish handshake" auxiliary command is issued by the microprocessor. If the 8291 is talking, DAV is not sent true until the "finish handshake" command is given. In both cases, the holdoff will be in effect for each data byte.
$A_{1}$ - RFD/DAV Holdoff on End: This feature enables the holdoff on EOI or EOS (if enabled). However, no holdoff will be in effect on any other data bytes.
$A_{2}$ - End on EOS Received: Wheneverthe byte in the Data In Register matches the byte in the EOSRegister the End interrupt bit will be set in the Interrupt Status:1/Registery $\mathrm{A}_{3}$ - Output EOI on EOS Sent: Any occurrence of data in the Data Out Register matching the EOS Register causes the EOI line to be sent true along with the data.
$A_{4}$ - EOS Binary Compare: Setting this bit causes the EOS Register to function as a full 8-bit word. When it is not set, the EOS Register is a 7-bit word (for ASCII characters).
If $\mathrm{A}_{0}=\mathrm{A}_{1}=1$, a special "continuous Acceptor Handshake cycling" mode is enabled. This mode should be used only in a controller system configuration, where both the 8291 and the 8292 are used. It provides a continuous cycling through the Acceptor Handshake state diagram, requiring no local messages from the microprocessor; the rdy local message is automatically generated when in ANRS. As such, the 8291 Acceptor Handshake serves as the controller Acceptor Handshake. Thus, the controller cycles through the Acceptor Handshake without delaying the data transfer in progress. When the tcs local message is executed, the 8291 is taken out of the "continuous AH cycling" mode, the GPIB hangs up in ANRS, and a BI interrupt is generated to indicate that control may be taken. A simpler procedure may be used when a "tcs on end of block" is executed; the 8291 may stay in "continuous AH cycling". Upon the end of a block (EOI or EOS received), a holdoff is generated, the GPIB hangs up in ANRS, and control may be taken.

## AUXILIARY REGISTER B

Auxiliary Register B is a "hidden" 4-bit register which is used to enable some of the features of the 8291. Whenever a $1010 \mathrm{~B}_{3} \mathrm{~B}_{2} \mathrm{~B}_{1} \mathrm{~B}_{0}$ is written into the Auxiliary Mode Register, it is loaded with the data $\mathrm{B}_{3} \mathrm{~B}_{2} \mathrm{~B}_{1} \mathrm{~B}_{0}$. Setting the respective bits to " 1 " enables the following features:

Bo - Enable Undefined Command Pass Through: This feature allows any commands not recognized by the 8291 to be handled in software. If enabled, this feature will cause the 8291 to holdoff the handshake when an undefined command is received. The microprocessor must then read the command from the Command Pass Through Register and send the VSCMD auxiliary command. Until the VSCMD command is sent, the handshake holdoff will be in effect.
$B_{1}$ - Send EOI in SPAS: This bit enables EOI to be sent with the status byte; EOI is sent true in Serial Poll Active State. Otherwise, EOI is sent false in SPAS.
$\mathrm{B}_{2}$ - Enable High Speed Data Transfer: This feature may be enabled when tri-state external transceivers are used. The data transfer rate is limited by $T_{1}$ (delay time generated in the Source Handshake function), which is defined according to the type of transceivers used. When the "High Speed" feature is enabled, $\mathrm{T}_{1}=2$ microseconds is generated for the first byte transmitted after each true to false transition of ATN. For all subsequent bytes, $T_{1}=500$ nanoseconds. Refer to the Internal Counter section for an explanation of $\mathrm{T}_{1}$ duration as a function of $\mathrm{B}_{2}$ and of clock frequency.
$B_{3}$ - Enable Active Low Interrupt: Setting this bit causes the polarity of the INT pin to be reversed, providing an output signal compatible with Intel's MCS-48 ${ }^{\text {TM }}$. Interrupt registers are not affected by this bit.

## PARALLEL POLL PROTOCOL

Writing a 011USP $\mathrm{UP}_{2} \mathrm{P}_{1}$ into the Auxiliary Mode Register will configure ( $\mathrm{U}=0$ ) or unconfigure ( $\mathrm{U}=1$ ) the 8291 for a parallel poll. When $U=0$, this command is the "Ipe" (local poll enable) local message as defined in IEEE 488. The " $S$ " bit is the sense in which the 8291 is configured; only if the Parallel Poll Flag ("ist" local message) matches this bit will the Parallel Poll Response, PPRN, be sent true. The bits $P_{3} P_{2} P_{1}$ specify which of the eight data lines PPRN will be sent over. Thus, once the 8291 has been configured for Parallel Poll, whenever it senses both EOI and ATN true, it will automatically compare its PP flag with the sense bit and send PPRN true or false according to the comparison.
If a $\mathrm{PP}_{2}{ }^{*}$ implementation is desired, the "lpe" and "ist" local messages are all that are needed. Typically, the user will configure the 8291 for Parallel Poll immediately after initialization. During normal operation the microprocessor will set or clear the Parallel Poll Flag (ist) according to the device's need for service. Consequently the 8291 will be set up to give the proper response to IDY (EOI • ATN) without directly involving the microprocessor.

If a PP1* implementation is desired, the undefined command features of the 8291 must be used. In PP1, the 8291 is indirectly configured for Parallel Poll by the active controller on the GPIB. The sequence at the 8291 being configured is as follows:

1. The PPC message is received true. Being an undefined command, it is loaded into the Command Pass Through Register, and a CPT interrupt is sent to the microprocessor. The handshake is automatically held off.
2. The microprocessor reads the CPT Register and sends VSCMD to the 8291, releasing the handshake.
3. Having received an undefined primary command, the 8291 is set up to receive an undefined secondary command, the PPE message. This message is also received into the CPT Register, the handshake is held off, and the CPT interrupt is generated.
4. The microprocessor reads the PPE message and decodes the $\mathrm{SP}_{3} \mathrm{P}_{2} \mathrm{P}_{1}$ information. It then sends the appropriate "Ipe" local message to the 8291. Finally, the microprocessor sends VSCMD and the handshake is released.
[^28]
## End of Sequence (EOS) Register

| EC7 | EC6 | EC5 | EC4 | EC3 | EC2 | EC1 | EC0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| EOS REGISTER |  |  |  |  |  |  |  |

The EOS Register and its features offer an alternative to the "Send EOI" auxiliary command. A seven or eight bit byte (ASCII or binary) may be placed in the register to flag the end of a block or read. The type of EOS byte to be used is selected in Auxiliary Register bit $\mathrm{A}_{4}$.

If the 8291 is a listener, and the "End on EOS Received" is enabled at bit $A_{2}$, then an End interrupt is generated in the Interrupt Status 1 Register whenever the byte in the DataIn Register matches the byte in the EOS Register.
If the 8291 is a talker, and the "Output EOI on EOS Sent" is enabled at bit $A_{3}$, then the EOI line is sent true with the next data byte whenever the contents of the Data Out Register match the EOS register.

## Reset Procedure

The 8291 is reset to an initialization state either by a pulse applied to its Reset pin, or by a reset auxiliary command 02 H written into the Auxiliary Command Register). The following conditions are caused by a reset pulse (or local reset command):

1. A "pon" local message as defined by IEEE 488 is held true until the initialization state is released.
2. The Interrupt Status Registers are cleared.
3. Auxiliary Registers A and B are cleared.
4. The Serial Poll Mode Register is cleared.
5. The Parallel Poll Flag is cleared.
6. The EOI bit in the Address Status Register is cleared.
7. $N_{F}$ in the Internal Counter is set to 8 MHz . This setting causes the longest possible $t_{1}$ delay to be generated in the Source Handshake ( $16 \mu \mathrm{sec}$ for 1 MHz clock).

The initiallization state is released by an "immediate execute pon" command $(00 \mathrm{H}$ written into the Auxiliary Command Register).
The suggested initialization sequence is:

1. Apply a reset pulse or send the reset auxiliary command.
2. Set the desired initial conditions by writing into the Interrupt Mask, Serial Poll Mode, Address Mode, Address 0/1, and EOS Registers. Auxiliary Registers A and $B$, and the internal counter should also be initialized.
3. Send the "immediate execute pon" auxiliary command to release the initialization state.
4. If a $\mathrm{PP}_{2}$ Parallel Poll implementation is to be used the "Ipe" local message may be sent, configuring the 8291 for a Parallel Poll Response on an assigned line. (Refer to the section on Parallel Poll Protocol.)

## Using DMA

The 8291 may be connected to the Intel 8257 DMA Controller for DMA operation. The DMA REQ pin of the 8291 requests a DMA byte transfer from the 8257 . It is set by BO or BI flip flops, masked by the DMAO and DMAI bits in the Interrupt Mask 2 Register. (After reading, the INT1 register BO and BI interrupts will be cleared but not BO and BI in DREQ equation.)

The DMA ACK pin is driven by the 8257 in response to the DMA request. When DMA ACK is true (active low) it sets CS $=$ RSO $=$ RS1 $=$ RS2 $=0$ such that the RD and WR signals sent by the 8257 refer to the Data In and Data Out Registers. Also, the DMA request line is reset by $\overline{D M A}$ ACK.

DMA input sequence:

1. A data byte is accepted from the GPIB by the 8291 .
2. A BI interrupt is generated and DMA REQ is set.
3. DMA ACK is asserted by the 8257 and DMA REQ is reset.
4. $\overline{\mathrm{RD}}$ is driven by the 8257 and the contents of the Data In Register are transferred to MCS bus.
5. The 8291 sends RFD true on the GPIB and proceeds with the Acceptor Handshake protocol.

DMA output sequence:

1. A BO interrupt is generated (indicating that the Data Out Register is empty) and DMA REQ is asserted.
2. $\overline{\text { DMA ACK }}$ is asserted by the 8257 and gMA REQ is reset.
3. $\overline{W R}$ is driven by the 8257 and a byte is transferred from the MCS bus into the Data Out Register.
4. The 8291 sends DAV true on the GPIB and proceeds with the Source Handshake protocol.
It should be noted that each time the device is addressed, the Address Status Register should be read, and the 8257 should be initialized accordingly. (Refer to the 8257 data sheet available in Intel's Peripheral Design Handbook.)

## System Configuration

## Microprocessor Bus Connection

The 8291 is $8080,8048,8085$ and 8086 compatible. The three address pins ( $\mathrm{RS}_{0}, \mathrm{RS}_{1}, \mathrm{RS}_{2}$ ) should be connected to the non-multiplexed address bus (for example: A8, A9, $\mathrm{A}_{10}$ ). In case of 8080, any address lines may be used.

## External Transceivers Connection

8291 IEEE bus pins are TTL compatible. For IEEE Std. bus connection, external transceivers are required. 8291 supplies Transmit/Receive control pins: T/R1 controls DIO $1_{1-8,}$ NRFD, NADC and DAV transceivers,T/R2 controls EOI transceiver. IFC, ATN, REN are always inputs and SRQ is always an output.

$$
\begin{aligned}
& \text { Logically, TR1 = TACS + SPAS + PPAS; } \\
& \text { TR2 = TACS + SPAS } .
\end{aligned}
$$

Refer to 8292 Data Sheet for 8291/8292 system configuration.

## DEVICE ELECTRICAL CHARACTERISTICS

## D.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2 | $\mathrm{V}_{\mathrm{cc}}+0.5$ | V |  |
| VOL | Output Low Voltage |  | 0.45 | V | IOL $=2 \mathrm{~mA}(4 \mathrm{~mA}$ for TR1 pin) |
| VOH | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}(-150 \mu \mathrm{~A}$ for SRQ pin $)$ |
| VOH-INT | Interrupt Output High Voltage | $\begin{aligned} & 2.4 \\ & 3.5 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}=-400 \mu \mathrm{~A} \\ & \mathrm{IOH}=-50 \mu \mathrm{~A} \end{aligned}$ |
| IIL | Input Leakage |  | 10 | $\mu \mathrm{A}$ | VIn $=0 \mathrm{~V}$ to VCC |
| ILOL | Output Leakage Current |  | -10 | $\mu \mathrm{A}$ | Vout $=0.45 \mathrm{~V}$ |
| ILOH | Output Leakage Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ |
| Icc | Vcc Supply Current |  | 180 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |

## A.C. CHARACTERISTICS

$V_{C C}=5 \mathrm{~V} \pm 10 \%$, Commercial: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Symbol | Parameter | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AR }}$ | Address Stable Before $\overline{\text { READ }}$ | 0 |  | nsec ${ }^{11]}$ |
| tra | Address Hold After $\overline{\text { READ }}$ | 0 |  | nsec ${ }^{11]}$ |
| trR | READ width | 250 |  | nsec ${ }^{\|2\|}$ |
| $t_{A D}$ | Address Stable to Data Valid |  | 250 | nsec ${ }^{11}$ |
| trd | $\overline{\mathrm{READ}}$ to Data Valid |  | 100 | nsec ${ }^{\|2\|}$ |
| trif | Data Float After $\overline{\text { READ }}$ | 0 | $60^{\|2\|}$ | nsec |
| $t_{\text {AW }}$ | Address Stable Before WRITE | 0 |  | nsec ${ }^{\text {\|1] }}$ |
| twa | Address Hold After WRITE | 0 |  |  |
| tww | WRITE Width | 250 |  | nsec ${ }^{[1]}$ |
| tow | Data Set Up Time to the Trailing Edge of WRITE | 150 |  | nsec ${ }^{11}$ |
| twD | Data Hold Time After WRITE | 0 |  | nsec ${ }^{[1]}$ |
| takRQ | $\widehat{\text { DACK } 1 \text { to DREQ. }}$ |  | 130 | nsec |
| tDKDA6 | DACK t to Up Data Valid |  | 200 | nsec |

## Notes:

1. 8080 System $C_{L \text { max }}=100 \mathrm{pF} ; C_{L \text { min }}=15 \mathrm{pF} ; 3 \mathrm{MHz}$ clock.
2. 8085 System $C_{L}=150 \mathrm{pF} ; 4 \mathrm{MHz}$ clock.

## READ

## WRITE



DMA


## GPIB TIMINGS ${ }^{[1]}$

| Symbol | Parameter | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: |
| TEOT13 | EOI! to TR1! | 90 | nsec | PPSS, $\overline{\text { ATN }}=0.45 \mathrm{~V}$ |
| TEODI6 | $\overline{\text { EOIt }}$ to $\overline{\text { DIO }}$ Valid | 130 | nsec | PPSS, $\overline{\text { ATN }}=0.45 \mathrm{~V}$ |
| TEOT12 | $\overline{\text { EOII }}$ to TR1! | 130 | nsec | PPSS, $\overline{\text { ATN }}=0.45 \mathrm{~V}$ |
| TATND4 | $\overline{\text { ATN }}$ t to $\overline{\mathrm{NDAC}}$. | 130 | nsec | TACS, AIDS |
| TATT14 | $\overline{\text { ATN }}$ to TR1! | 130 | nsec | TACS, AIDS |
| TATT24 | $\overline{\text { ATN }}$ to TR2! | 130 | nsec | TACS, AIDS |
| TDNVD3-C | $\overline{\text { DAV }}$ to $\overline{\text { NDAC }} 1$ | 350 | nsec | AH, CACS |
| TNDDV1 | $\overline{\text { NDAC } \dagger \text { to } \overline{\mathrm{DAV}} \text { 1 }}$ | 300 | nsec | SH, STRS |
| TNRDV2 |  | 300 | nsec | SH, T1 True |
| TNDDR1 | $\overline{\text { NDAC }}$ t to DREQ 1 | 350 | nsec | SH |
| TDVDR3 |  | 350 | nsec | AH, LACS, $\overline{\text { ATN }}=2.4 \mathrm{~V}$ |
| TDVND2-C | $\overline{\mathrm{DAV}}$ to $\overline{\mathrm{NDAC}}$. | 350 | nsec | AH,LACS |
| TDVNR1-C | $\overline{\text { DAV } 1 \text { to } \overline{\text { RRFD }} 1 .}$ | 350 | nsec | AH, LACS, rdy=True |
| TRDNR3 | $\overline{\mathrm{RD}} \downarrow$ to $\overline{\mathrm{NRFD}} \uparrow$ | 500 | nsec | AH, LACS |
| TWRDI5 | $\overline{\text { WR }}$ to $\overline{\text { DIO }}$ Valid | 200 | nsec | SH, TACS, RS $=0.4 \mathrm{~V}$ |
| TWRDV2 | $\overline{W R} \uparrow$ to $\overline{\mathrm{DAV}} \downarrow$ | 760 | nsec | $\overline{\mathrm{NRFD}}=2.4 \mathrm{~V}, \mathrm{RS}=0.4 \mathrm{~V}, \mathrm{SH},$ <br> TACS, High Speed Transfers Enabled, $\mathrm{N}_{\mathrm{F}}=\mathrm{f}_{\mathrm{C}}=8 \mathrm{MHz}$ |

Notes:

1. All GPIB timings are at the pins of the 8291 .

## Appendix A

## MODIFIED STATE DIAGRAMS

Figure A. 1 presents the interface function state diagrams. It is derived from IEEE Std. state diagrams, with the following changes:
A. Controller function omitted.
B. Addressing modes included in T,L state diagrams.

Note that in Mode 3, MSA, OSA are generated only after secondary address validity check by the microprocessor (APT interrupt).
C. All remote messages sent true in each state are indicated.
D. All remote multiline messages decoded are conditioned by ACDS. The multiplication by ACDS is not drawn to simplify the diagrams.
E. The symbol
indicates:

1. When event $X$ occurs, the function will return to state S .
2. X overrides any other transition condition in the function.

Statement 2 simplifies the diagram, avoiding the explicit use of $\bar{X}$ to condition all transitions from $S$ to other states.


Figure A.1. 8291 State Diagrams (Continued next page)


Figure A.1. 8291 State Diagrams (Continued next page)


Figure A.1. 8291 State Diagrams

## Appendix B

IEEE 488 TIME VALUES

| Description | Value |
| :--- | :--- |
| Settling Time for Multiline Messages | $\geq 2 \mu \mathrm{~s} \dagger$ |
| Response to ATN | $\leq 200 \mathrm{~ns}$ |
| Interface Message Accept Time + |  |
| Response to IFC or REN False | $>0 \delta$ |
| Response to ATN+EOI | $<100 \mu \mathrm{~s}$ |
| Parallel Poll Execution Time | $\leq 200 \mathrm{~ns}$ |
| Controller Delay to Allow Current Talker |  |
| to see ATN Message | $\geq 2 \mu \mathrm{~s}$ |
| Length of IFC or REN False | $\geq 500 \mathrm{~ns}$ |
| Delay for EOI** | $>100 \mu \mathrm{~s}$ |

* Time values specified by a lower case t indicate the maximum time allowed to make a state transition. Time values specified by an upper case $T$ indicate the minimum time that a function must remain in a state before exiting.
$\dagger$ If three-state drivers are used on the DIO, DAV, and EOI lines, $\mathrm{T}_{1}$ may be:

1. $\geq 1100 \mathrm{~ns}$
2. Or $\geq 700 \mathrm{~ns}$ if it is known that within the controller ATN is driven by a three-state driver.
3. Or $\geq 500$ ns for all subsequent bytes following the first sent after each false transition of ATN (the first byte must be sent in accordance with (1) or (2).
4. Or $\geq 350 \mathrm{~ns}$ for all subsequent bytes following the first sent after each false transition of ATN under conditions specified in Section 5.2 .3 and warning note. See IEEE Standard 488.

+ Time required for interface functions to accept, not necessarily respond to interface messages.
$\delta$ implementation independent.
** Delay required for EOI, NDAC, and NRFD signal lines to indicate valid states.
$\dagger \dagger \geq 600 \mathrm{~ns}$ for three-state drivers.


## Appendix C

THE THREE WIRE HANDSHAKE


Figure C.1. 3-Wire Handshake Timing.


FLOW DIAGRAM OUTLINES SEQUENCE OF EVENTS DURING TRANSFER OF DATA BYTE. MORE THAN ONE LISTENER AT A TIME CAN ACCEPT DATA BECAUSE OF LOGICAL AND CONNECTION OF NRFD AND NDAC LINES.

Figure C.2. Handshake Flowchart.

## Appendix D <br> FUNCTIONAL PARTITIONS



Figure D.1. Functional Partition Within a Device.

## 8292 <br> GPIB CONTROLLER

FEATURES:
Complete IEEE Standard 488 Controller Function.

- Interface Clear (IFC) Sending Capability Allows for Seizure of Control and/or Initialization of the Bus.

Responds to Service Requests (SRQ).

- Sends (REN), Allowing Instruments to Switch to Remote Control.
- Complete Implementation of Transfer Control Protocol.

Synchronous Control Seizure Prevents the Destruction of any Data Transmission in Progress.

Connects with the 8291 to Form a Complete IEEE Standard 488 Interface Talker/Listener/Controller.

The 8292 GPIB CONTROLLER is a microprocessor-controlled chip designed to connect with the 8291 GPIB TALKER/LISTENER to implement the full IEEE Standard 488 controller function, including transfer control protocol. The 8292 is a pre-programmed UPI-41ATM

PIN CONFIGURATION


8291, 8292 SYSTEM DIAGRAM


## PIN DESCRIPTION

Symbol IIO PinNo.

| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | $1 / O$ | $12-19$ | 8 bidirectional lines used for com- <br>  <br> munication between the central <br> processor and the 8292's data bus <br> buffers and status register. |
| :--- | :--- | :--- | :--- |

$\mathrm{A}_{0} \quad 1 \quad 9$ Address Line-Used to select between the data bus and the status register during read operations and to distinguish between data and commands written into the 8292 during write operations.

| $\overline{\mathrm{CS}} \quad 1$ | 6 | Chip Select Input-Used to select <br> the 8292 from other devices on the <br> common data bus. |
| :--- | :--- | :--- | :--- |

$\overline{\mathrm{RD}} \quad 1 \quad 8$ I/O write input which allows the master CPU to write to the 8292.
$\overline{W R} \quad 1 \quad 10 \quad 1 / O$ read input which allows the $\overline{\text { RESET }} 4$ master CPU to read from the 8292.
$\overline{\text { DAV }} 1 / 0$ known state during power on.
37 DAV Handshake Line-Used only during parallel poll, configures to force the 8291 to accept the parallel poll status bits.
$\overline{\text { ATNI }} \quad 1 \quad 22$ Attention In-Used by the 8292 to monitor the GPIB ATN control line. It is used during "take control synchronously" execution and during the transfer control procedure.
$\overline{\mathrm{CIC}} \quad 0 \quad 31$ Controller In Charge-Controls the $S / R$ input of the $S R Q$ bus transceiver. It can also be used to indicate that the 8292 is in charge of the bus.
$\overline{\text { EOI }} 1 / 0 \quad 34$ End Or Identify-One of the GPIB management lines, as defined by IEEE Std. 488-1975. Used with ATN as Identify Message during parallel poll.
$\overline{\mathrm{IFC}} \quad$ I/O 23 Interface Clear-One of the GPIB management lines, as defined by IEEE Std. 488-1975, places all devices in a known quiescent state.
SYC 122 System Controller-Monitors the system controller switch.
OBFI O 35 Output Buffer Full-Used as an interrupt to the central processor while the output buffer of the 8292 is full. The feature can be enabled and disabled by the interrupt mask register.
$\overline{\text { IBFI }} 036$ Input Buffer Not Full-Used to interrupt the central processor while the input buffer of the 8292 is empty. This feature is enabled and disabled by the interrupt mask register.
Symbol IIO Pin No. Function
$\overline{\text { ATNO }} \quad 0 \quad 29$ Attention Out-Controls the ATN control line of the bus through external logic for tcs (take control synchronously) purpose. (ATN is a GPIB control line, as defined by IEEE Std. 488-1975.)
$\overline{S R Q} \quad 1 \quad 21$ Service Request-One of the IEEE control lines. Sampled by the 8292 when it is controller in charge, if true-SPI interrupt to the monitor will be generated.
$\overline{R E N} \quad 0 \quad 38$ The Remote Enable bus signal selects remote or local control of the device on the bus. A GPIB bus management line, as defined by IEEE Std. 488-1975.
TCI O 32 Task Complete Interrupt-Interrupt to the control processor used to indicate that the task requested was completed by the 8292 and the information requested is ready in the data bus.
SPI O 33 Special Interrupt-Used as an interrupt on events not initiated by the central processor.
CLTH O 27 CLEAR LATCH Output-Used to clear the $\overline{\mathrm{FCR}}$ after recognized by the 8292. Usually low (except after hardware Reset), will be pulsed low when $\overline{\operatorname{FFR}}$ is recognized by the 8292.
$\overline{\mathrm{IFCR}} \quad \mathrm{I} 1$ IFC Received (latched)-The 8292 monitors the IFC Line (when not system controller) through this pin.
COUNT I 39 Count Input-When enabled by the proper command the internal counter will count external events through this pin. High to low transition will increment the internal counter by one. The pin is sampled once per three internal instruction cycles ( $7.5 \mu \mathrm{sec}$ when using 6 MHz XTAL). It can be used for byte counting when connected to NDAC line, or for block counting when connected to the EOI line.
$X_{1}, X_{2} \quad \mid \quad 2,3 \quad$ Inputs for a crystal, LC or an ex-
ternal timing signal to determine the internal oscillator frequency.
SYNC O 11 8041A instruction cycle synchronization signal; it is an output clock with a frequency of XTAL $\div 15$.
$V_{C C} \quad$ P.S. $40+5 \mathrm{~V}$ supply input.
$V_{\text {SS }} \quad$ P.S. 7,20 Circuit ground potential.
$\overline{R E N} \quad 0 \quad 38$ The Remote Enable bus signal

| SPI | $O$ | 33 |
| :--- | :--- | :--- |
| CLTH | 0 | 27 |




,








#### Abstract






-

## 8294 <br> DATA ENCRYPTION UNIT

## - Certified by National Bureau of Standards

## - 80 Byte/Sec Data Conversion Rate

## ■ 64-Bit Data Encryption Using 56-Bit Key

DMA Interface

## - 3 Interrupt Outputs to Aid in Loading and Unloading Data

7-Bit User Output Port
Single 5V $\pm \mathbf{1 0 \%}$ Power Supply

- Peripheral to MCS-86™, MCS-85 ${ }^{\text {TM }}$, MCS $80^{7 \mathrm{M}}$ and MCS-48 ${ }^{\text {TM }}$ Processors
- Implements Federal Information

Processing Data Encryption Standard
Encrypt and Decrypt Modes Available

## DESCRIPTION

The Intel® 8294 Data Encryption Unit (DEU) is a microprocessor peripheral device designed to encrypt and decrypt 64-bit blocks of data using the algorithm specified in the Federal Information Processing Data Encryption Standard. The DEU operates on 64-bit text words using a 56 -bit user-specified key to produce 64 -bit cipher words. The operation is reversible: if the cipher word is operated upon, the original text word is produced. The algorithm itself is permanently contained in the 8294; however, the 56 -bit key is user-defined and may be changed at any time.
The 56-bit key and 64-bit message data are transferred to and from the 8294 in 8 -bit bytes by way of the system data bus. A DMA interface and three interrupt outputs are available to minimize software overhead associated with data transfer. Also, by using the DMA interface two or more DEUs may be operated in parallel to achieve effective system conversion rates which are virtually any multiple of 80 bytes/second. The 8294 also has a 7 -bit TTL compatible output port for user-specified functions.
Because the 8294 implements the NBS encryption algorithm it can be used in a variety of Electronic Funds Transfer applications as well as other electronic banking and data handling applications where data musi be encrypted.


| Pin \# | Pin Name | 1/0 | Pin Description | Pin \# | Pin Name | 1/0 | Pin Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | NC | - | No connection. | 40 | $\mathrm{V}_{\mathrm{CC}}$ | - | +5 volt power inputw +5 V |
| 2 | X1 | 1 | Inputs for crystal, L-C or exter- |  |  |  | $\pm 10 \%$. |
| 3 | X2 |  | nal timing signal to determine internal oscillator frequency. | 39 38 | $\frac{\mathrm{NC}}{\mathrm{DACK}}$ | 1 | No connection. |
| 4 | $\overline{\text { RESET }}$ | 1 | A low signal to this pin resets the 8294. |  |  |  | signal from the 8257 DMA Controller acknowledging that the |
| 5 | NC | - | No connection. |  |  |  | requested DMA cycle has been granted. |
| 6 | $\overline{\mathrm{CS}}$ | 1 | A low signal to this pin enables reading and writing to the 8294. | 37 | DRQ | 0 | DMA request. Output signal to the 8257 DMA Controller |
| 7 | GND | - | This pin must be tied to ground. |  |  |  | requesting a DMA cycle. |
| 8 | $\overline{\mathrm{RD}}$ | I | An active low read strobe at this pin enables the CPU to read data and status from the internal DEU registers. | 38 | SRQ | 0 | Service Request. Interrupt to the CPU indicating that the 8294 is awaiting data or commands at the input buffer. |
| 9 | $\mathrm{A}_{0}$ | 1 | Address input used by the CPU to select DEU registers during read and write operations. | 35 | OAV | 0 | $\mathrm{SRQ}=1 \text { implies } \mathrm{IBF}=0$ <br> Output Available. Interrupt to the CPU indicating that the |
| 10 | $\overline{W R}$ | 1 | An active low write strobe at this pin enables the CPU to send data and commands to the DEU. | 34 | NC | - | 8294 has data or status available in its output buffer. $O A V=1$ implies $O B F=1$. <br> No connection. |
| 11 | SYNC | 0 | High frequency (Clock $\div 15$ ) output. Can be used as a strobe for external circuitry. | $\begin{aligned} & 33 \\ & 32 \\ & 31 \end{aligned}$ | $\begin{aligned} & \text { P6 } \\ & \text { P5 } \\ & \text { P4 } \end{aligned}$ | 0 | User output port lines. Output lines available to the user via a CPU command which can as- |
| 12 | $\mathrm{D}_{0}$ | 1/O | Three-state, bi-directional data | 30 | P3 |  | sert selected port lines. These |
| 13 | $\mathrm{D}_{1}$ |  | bus lines used to transfer data | 29 | P2 |  | lines have nothing to do with |
| 14 | $\mathrm{D}_{2}$ |  | between the CPU and the 8294. | 28 | P1 |  | the encryption function. At |
| 15 | $\mathrm{D}_{3}$ |  |  | 27 | P0 |  | power-on, each line is in a 1 |
| 16 | $\mathrm{D}_{4}$ |  |  |  |  |  |  |
| 17 | $D_{5}$ $D_{6}$ |  |  | 26 | $\mathrm{V}_{\text {DD }}$ | - | +5 V power input. ( $+5 \mathrm{~V} \pm 10 \%$ ) Low power standby pin. |
| 19 | $\mathrm{D}_{7}$ |  |  | 25 | NC | - | No connection. |
| 20 | GND | - | This pin must be tied to ground. | 24 | CCMP | 0 | Conversion Complete. Interrupt to the CPU indicating that the encryption/decryption of an 8 -byte block is complete. |
|  |  |  |  | 23 | NC | - | No connection. |
|  |  |  |  | 22 | NC | - | No connection. |
|  |  |  |  | 21 | NC | - | No connection. |

## BASIC FUNCTIONAL DESCRIPTION OPERATION

The data conversion sequence is as follows:

1. A Set Mode command is given, enabling the desired interrupt outputs.
2. An Enter New Key command is issued, followed by 8 data inputs which are retained by the DEU for encryption/decryption. Each byte must have odd parity.
3. An Encrypt Data or Decrypt Data command sets the DEU in the desired mode.
After this, data conversions are made by writing 8 data bytes and then reading back 8 converted data bytes. Any of the above commands may be issued between data conversions to change the basic operation of the DEU; e.g., a Decrypt Data command could be issued to change the DEU from encrypt mode to decrypt mode without changing either the key or the interrupt outputs enabled.

## INTERNAL DEU REGISTERS

Four internal registers are addressable by the master processor: 2 for input, and 2 for output. The following table describes how these registers are accessed.

| $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\overline{\mathbf{C S}}$ | $\mathbf{A}_{\mathbf{0}}$ | Register |
| :---: | :---: | :---: | :---: | :--- |
| 1 | 0 | 0 | 0 | Data input buffer |
| 0 | 1 | 0 | 0 | Data output buffer |
| 1 | 0 | 0 | 1 | Command input buffer |
| 0 | 1 | 0 | 1 | Status output buffer |
| X | X | 1 | X | Don't care |

The functions of each of these registers are described below.

Data Input Buffer - Data written to this register is interpreted in one of three ways, depending on the preceding command sequence.

1. Part of a key.
2. Data to be encrypted or decrypted.
3. A DMA block count.

Data Output Buffer - Data read from this register is the output of the encryption/decryption operation.

Command Input Buffer - Commands to the DEU are written into this register. (See command summary below.)

Status Output Buffer - DEU status is available in this register at all times. It is used by the processor for polldriven command and data transfer operations.

|  |  |  |  |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STATUS BIT: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| FUNCTION: | X | X | X | KPE | CF | DEC | IBF | OBF |
|  |  |  |  |  |  |  |  |  |

OBF Output Buffer Full; OBF = 1 indicates that output from the encryption/decryption function is available in the Data Output Buffer. It is reset when the data is read.

Input Buffer Full; A write to the Data Input Buffer or to the Command Input Buffer sets IBF=1. The DEU resets this flag when it has accepted the input byte. Nothing should be written when $I B F=1$.
DEC Decrypt; indicates whether the DEU is in an encrypt or a decrypt mode. DEC $=1$ implies the decrypt mode. DEC $=0$ implies the encrypt mode.

CF Completion Flag; This flag may be used to indicate any or all of three events in the data transfer protocol.

1. It may be used in lieu of a counter in the processor routine to flag the end of an 8byte transfer.
2. It must be used to indicate the validity of the KPE flag.
3. It may be used in lieu of the CCMP interrupt to indicate the completion of a DMA operation.
KPE Key Parity Error; After a new key has been entered, the DEU uses this flag in conjunction with the CF flag to indicate correct or incorrect parity.

## COMMAND SUMMARY

1 - Enter New Key
OP CODE:

| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| MSB | LSB |  |  |  |  |  |  |

This command is followed by 8 data byte inputs which are retained in the key buffer (RAM) to be used in encrypting and decrypting data. These data bytes must have odd parity represented by the LSB.

2 - Encrypt Data
op CODE:


This command puts the 8294 into the encrypt mode.

## 3 - Decrypt Data

OP CODE:


This command puts the 8294 into the decrypt mode.

4 - Set Mode
OP CODE:

where:
A is the OAV (Output Available) interrupt enable $B$ is the SRQ (Service Request) interrupt enable
C is the DMA (Direct Memory Access) transfer enable $D$ is the CCMP (Conversion Complete) interrupt enable

This command determines which interrupt outputs will be enabled. A " 1 " in bits A, B, or D will enable the OAV, SRQ, or CCMP interrupts respectively. A "1" in bit C will allow DMA transfers. When bit $C$ is set the OAV and SRQ interrupts should also be enabled (bits $A, B=1$ ). Following the command in which bit C , the DMA bit, is set, the 8294 will expect one data byte to specify the number of 8 -byte blocks to be converted using DMA.

\section*{5 - Write to Output Port <br> OP CODE <br> 

This command causes the 7 least significant bits of the command byte to be latched as output data on the 8294 output port. The initial output data is 1111111. Use of this port is independent of the encryption/decryption function.

## PROCESSOR/DEU INTERFACE PROTOCOL

## ENTERING A NEW KEY

The timing sequence for entering a new key is shown in Figure 1. A flowchart showing the CPU software to accommodate this sequence is given in Figure 2.


After the Enter New Key command is issued, 8 data bytes representing the new key are written to the data input buffer (most significant byte first). After the eighth byte is accepted by the DEU, CF goes true ( $C F=1$ ), The CF bit goes false again when KPE is valid. The CPU can then check the KPE flag. If KPE = 1 , a parity error has been detected and the DEU has not accepted the key. Each byte is checked for odd parity, where the parity bit is the LSB of each byte.

Since the CF bit is used in this protocol to indicate the validity of the KPE flag, it may not be used to flag the end of the 8 byte key entry. CF = 1 only as long as KPE is invalid. Therefore, the CPU might not detect that CF=1 and the key entry is complete before KPE becomes valid. Thus, a counter should be used, as in Figure 2, to flag the end of the new key entry. Then, CF is used to indicate a valid KPE flag.
$\qquad$


Figure 1. Entering a New Key

## ENCRYPTING OR DECRYPTING DATA

Figure 3 shows the timing sequence for encrypting or decrypting data. The CPU writes 8 data bytes to the DEU's data input buffer for encryption/decryption. CF then goes true ( $C F=1$ ) to indicate that the DEU has accepted the 8 -byte block. Thus, the CPU may test for $I B F=0$ and $C F=t$ to terminate the input mode, or it may use a software counter. When the encryption/decryption is complete, the CCMP and OAV interrupts are asserted and the OBF flag is set true (OBF = 1). OAV and OBF are set false again after each of the converted data bytes is read back by the CPU. The CCMP interrupt is set false, and remains false, after the first read. After 8 bytes have been read back by the CPU, CF goes false ( $C F=0$ ). Thus, the CPU may test for CF $=0$ to terminate the read mode. Also, the CCMP interrupt may be used to initiate a service routine which performs the next series of 8 data reads and 8 data writes.


Figure 3. Encrypting/Decrypting Data

Figure 4 offers two flowcharts outlining the alternative means of implementing the data conversion protocol. Either the CF flag or a software counter may be used to end the read and write modes.
$S R Q=1$ implies $\mathrm{IBF}=0, \mathrm{OAV}=1$ implies $\mathrm{OBF}=1$. This allows interrupt routines to do data transfers without checking status first. However, the OAV service routine must detect and flag the end of a data conversion.

USING SOFTWARE COUNTER


Figure 4. Data Conversion Flowcharts

## USING DMA

The timing sequence for data conversions using DMA is shown in Figure 5. This sequence can be better understood when considered in conjunction with the hardware DMA interface in Figure 6. Note that the use of the DMA feature requires 3 external AND gates and 2 DMA channels (one for input, one for output). Since the DEU has only one DMA request pin, the SRQ and OAV outputs are used in conjunction with two of the AND gates to create separate DMA request outputs for the 2 DMA channels. The third AND gate combines the two active-Iow $\overline{\text { DACK }}$ inputs.


Figure 5. DMA Sequence

DMARO IS FOR MEMORY TO DEU DATA TRANSFER DMAR1 IS FOR DEU TO MEMORY DATA TRANSFER USE OF CCMP IS OPTIONAL


Figure 6. DMA Interface

To initiate a DMA transfer, the GPU must first initialize the two DMA channels as shown in the flowetrart in Figure 7. It must then issue a Set Mode command to the DEU enabling the OAV, SRQ, and DMA outputs. The CCMP interrupt may be enabled or disabled, depending on whether that output is desired. Following the "Set Mode command, there must be a data byte giving the number of 8 -byte blocks of data ( $\mathrm{n}<256$ ) to be converted. The DEU then generates the required number of DMA requests to the 2 DMA channels with no further CPU intervention. When the requested number of blocks has been converted, the DEU will set CF and assert the CCMP interrupt (if enabled). CCMP then goes false again with the next write to the DEU (command or data). Upon completion of the conversion, the DMA mode is disabled and the DEU returns to the encrypt/decrypt mode. The enabled interrupt outputs, however, will remain enabled until another Set Mode command is issued.


Figure 7. DMA Flowchart

## SINGLE BYTE COMMANDS

Figure 8 shows the timing and protocol for single byte commands. Note that any of the commands is effective as a pacify command in that they may be entered at any time, except during a DMA conversion. The DEU is thus set to a known state. However, if a command is issued out of sequence, an additional protocol is required (Figure 9). The CPU must wait until the command is accepted ( $1 \mathrm{BF}=0$ ). A data read must then be issued to clear anything the preceding command sequence may have left in the Data Output Buffer. "筑 "








## CPUIDEU INTERFACES

Figures 10 through 13 Illustrate four interface configurations used in the CPUIDEU data transfers. In all cases SRQ will be true (if enabled) and IBF will be false when the DEU is ready to accept data or commands.


Figure 8. Single Byte Commands


Figure 9. Pacify Protocol


Figure 10. Polling Interface


Figure 11. Single Interrupt Interface


Figure 12. Dual Interrupt Interface


DMARO IS FOR MEMORY TO DEU DATA TRANSFER DMAR1 IS FOR DEU TO MEMORY DATA TRANSFER USE OF CCMP IS OPTIONAL
Figure 13. DMA Interface

## OSCILLATOR AND TIMING CIRCUITS

The 8294's internal timing generation is controlled by a self-contained oscillator and timing circuit. A choice of crystal, L-C or external clock can be used to derive the basic oscillator frequency.
The resident timing circuit consists of an oscillator, a state counter and a cycle counter as illustrated in Figure 14.


Figure 14. Oscillator Configuration

## OSCILLATOR

The on-board oscillator is a series resonant circuit with a frequency range of 1 to 6 MHz . Pins X1 and X2 are input and output (respectively) of a high gain amplifier stage. A crystal or inductor and capacitator connected between X1 and X2 provide the feedback and proper phase shift for oscillation. Recommended connections for crystal or L-C are shown in Figure 15.


Figure 15. Recommended Crystal and L-C Connections

A recommended range of inductance and capacitance combinations is given below:

$$
\begin{aligned}
& \mathrm{L}=130 \mu \mathrm{H} \text { corresponds to } 3 \mathrm{MHz} \\
& \mathrm{~L}=40 \mu \mathrm{H} \text { corresponds to } 5 \mathrm{MHz}
\end{aligned}
$$

An external clock signal can also be used as a frequency reference to the 8294; however, the levels are not compatible. The signal must be in the $1 \mathrm{MHz}-6 \mathrm{MHz}$ frequency range and must be connected to pins X 1 and X 2 by buffers with a suitable pull-up resistor to guarantee that a logic " 1 " is above 3.0 volts. Two recommended connections are shown in Figure 16.


Figure 16. Recommended Connections for External Clock Signal

## 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.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 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} T O 70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \% \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| VIL | Input Low Voltage (All Except $X_{1}, X_{2}$, RESET) | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H}_{1}}$ | Input High Voltage (All Except $\mathrm{X}_{1}, \mathrm{X}_{2}$ RESET) | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{H} 2}$ | Input High Voltage ( $\mathrm{X}_{1}, \mathrm{X}_{2}$ RESET) | 3.0 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$, Sync) |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage All Other Outputs |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| IIL | Input Leakage Current $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}, \overline{\mathrm{A}_{0}}$, |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{OZ}}$ | Output Leakage Current ( $\mathrm{D}_{0}-\mathrm{D}_{7}$, High $Z$ State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+0.45 \leqslant \mathrm{~V}_{1 \mathrm{~N}} \leqslant \mathrm{~V}_{\mathrm{CC}}$ |
| $I_{\text {DD }}$ | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 10 | 25 | mA |  |
| $I_{D D}+I_{C C}$ | Total Supply Current |  | 65 | 135 | mA |  |
| $\mathrm{l}_{\mathrm{LI} 1}$ | Low Input Load Current Pins 24, 27-38 |  |  | 0.4 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\text {L12 }}$ | Low Input Load Current RESET |  | . | 0.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |

A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ TO $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$

DBB READ

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A R}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RA}}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After $\overline{\mathrm{RD}} \uparrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\mathrm{RD}}$ Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{AD}}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ to Data Out Delay |  | 150 | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | $\overline{\mathrm{RD}} \downarrow$ to Data Out Delay |  | 150 | ns |  |
| $\mathrm{t}_{\mathrm{RDF}}$ | $\overline{\mathrm{RD}} \uparrow$ to Data Float Delay | 10 |  | ns |  |
|  | Recovery Time Between <br> Reads and/or Write | 1 | 100 | ns |  |
| $\mathrm{t}_{\mathrm{RV}}$ | Cycle Time |  | $\mu \mathrm{s}$ |  |  |
| $\mathrm{t}_{\mathrm{CY}}$ |  | 2.5 |  | $\mu \mathrm{~s}$ | 6 MHz Crystal |

DBB WRITE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {AW }}$ | $\overline{\mathrm{CS}}$, A $_{0}$ Setup to $\overline{\mathrm{WR}} \downarrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{WA}}$ | $\overline{\mathrm{CS}}$, A $_{0}$ Hold After $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{WW}}$ | $\overline{W R}$ Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{DW}}$ | Data Setup to $\overline{W R} \uparrow$ | 150 |  | ns |  |
| $\mathrm{t}_{\mathrm{WD}}$ | Data Hold to $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |

## DMA AND INTERRUPT TIMING

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{KC}}$ | $\overline{\text { DACK Setup to Control }}$ | 50 |  | ns |  |
| $\mathrm{t}_{\mathrm{CK}}$ | $\overline{\text { DACK Hold After Control }}$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{CR}}$ | Control L.E. to DRQ T.E. |  | 150 | ns |  |
| $\mathrm{t}_{\mathrm{CI}}$ | Control T.E. to <br> Interrupt T.E. |  | $\mathrm{t}_{\mathrm{CY}}+500$ | ns |  |

## A.C. TEST CONDITIONS

$$
D_{7}-D_{0} \text { Outputs } \quad C_{L}=150 \mathrm{pF}
$$

## WAVEFORMS

1. READ OPERATION - OUTPUT BUFFER REGISTER.

2. WRITE OPERATION - INPUT BUFFER REGISTER.


## DMA AND INTERRUPT TIMING



8295
DOT MATRIX PRINTER CONTROLLER

Interfaces Dot Matrix Printers to MCS－48 ${ }^{\text {TM }}$ ，MCS－80 ${ }^{\text {TM }}$ ，MCS－85 ${ }^{\text {TM }}$ Systems

## － 40 Character Buffer On Chip

－Serial or Parallel Communication with Host

## －DMA Transfer Capability

－Programmable Character Density（10 or 12 Chararcters／Inch）

Programmable Print Intensity
－Single or Double Width Printing
－Programmable Multiple Line Feeds
－ 3 Tabulations
－ 2 General Purpose Outputs

The Intel ${ }^{\circledR} 8295$ Dot Matrix Printer Controller provides an interface for microprocessors to the LRC 7040 Series dot matrix impact printers．It may also be used as an interface to other similar printers．

The chip may be used in a serial or parallel communication mode with the host processor．Furthermore，it provides internal buffering of up to 40 characters and contains a $7 \times 7$ matrix character generator accommodating 64 ASCII characters．

PIN
CONFIGURATION

| PFEEO | 1 － | 40 | $\mathrm{p}_{\mathrm{cc}}$ |
| :---: | :---: | :---: | :---: |
| $\times 10$ | 2 | 39 | 万home |
| $\mathrm{x}^{2}$ | 3 | 38 | JDACRISIN |
| AESET - | 4 | 37 | DDRO／CTS |
| NC－ | 5 | 36 | FIRa／EER |
| Cs | 6 | 35 | 口мот |
| GND | 7 | 34 | рттв |
| रD | 8 | 33 | $\square^{\overline{5}}$ |
| $\mathrm{v}_{\mathrm{cc}}$ | 9 | 32 | $\square 5_{6}$ |
| WR ${ }^{\text {a }}$ | 108295 | 31 | $\square \square_{5}$ |
| SYNC | $11 \quad 8295$ | 30 | $\square^{5}$ |
| $\mathrm{D}_{0}$ | 12 | 29 | $\square^{S_{3}}$ |
| $\mathrm{D}_{1} \mathrm{\square}$ | 13 | 28 | $\square^{5}$ |
| $\mathrm{D}_{2}$ | 14 | 27 | $\square^{5}$ |
| $\mathrm{O}_{3} \mathrm{C}$ | 15 | 26 | $\mathrm{p}^{\text {do }}$ |
| $\mathrm{D}_{4} \mathrm{C}$ | 16 | 25 | Jnc |
| $\mathrm{D}_{5}$ | 17 | 24 | $7 \mathrm{GP1}$ |
| $\mathrm{D}_{6}$ | 18 | 23 | －GP2 |
| $\mathrm{D}_{7} \mathrm{C}$ | 19 | 22 | 口TరF |
| GND | 20 | 21 | DPFM |

PIN NAMES

| PIN NAME | FUNCTION |
| :---: | :---: |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | data bus |
| ED，WR | READ，WRITE STROBES |
| CS | CHIP SELECT |
| RESET | RESET INPUT |
| $\mathrm{X}_{1}, \mathrm{X}_{2}$ | FREQUENCY REFERENCE INPUTS |
| SYNC | HIGH FREQUENCY OUTPUT |
| MOT，PFM | MAIN，PAPER FEED MOTOR DRIVES |
| DRQ，DACK | DMA REQUEST，ACKNOWLEDGE |
| SIN，CTS | SERIAL INPUT，CLEAR－TO－SEND |
| IROISER | INTERRUPT REQUEST，SERIAL GROUND |
| $\overline{\mathrm{S}_{1}-\mathrm{S}_{7}}$ | SOLENOID DRIVE OUTPUTS |
| PFEED | PAPER FEED INPUT |
| HOME，TOF | HOME，TOP．OF．FORM INPUTS |
| STB | SOLENOID STROBE OUTPUT |
| GP1，GP2 | GENERAL PURPOSE OUTPUTS |
| $\mathrm{V}_{\text {CC }}$ ，VDD．GND | ＋5V POWER，GND |

BLOCK DIAGRAM


## FUNCTIONAL DESCRIPTION

The 8295 interfaces microcomputers to the LRC 7040 Series dot matrix impact printers, and to other similar printers. It provides internal buffering of up to 40 characters. Printing begins automatically when the buffer is full or when a carriage return character is received.

Communication between the 8295 and the host processor can be implemented in either a serial or parallel
mode. The parallel mode allows for character transfers into the buffer via DMA cycles. The serial mode features selectable data rates from 110 to 4800 baud.
The 8295 also offers two general purpose output pins which can be set or cleared by the host processor. They can be used with various printers to implement such functions as ribbon color selection, enabling form release solenoid, and reverse document feed.

## COMMAND SUMMARY

| Hex Code |  |
| :---: | :--- |
| 00 | Description |
| 01 | Clear GP1. This command brings the GP1 <br> pin to a logic low state. After power on it is <br> automatically set high. |
| 02 | Clear GP2. Same as the above but for GP2. <br> Set GP1. Sets GP1 pin to a logic high state, <br> inverse of command 00. |
| 03 | Set GP2. Same as above but for GP2. In- <br> verse command 01. <br> Software Reset. This is a pacify command. <br> This command is not effective immediately <br> after commands requiring a parameter, as <br> the Reset command will be interpreted as a <br> parameter. |
| 04 | Print 10 characters/in. density. |
| 06 | Print 12 characters/in. density. |
| 07 | Print double width characters. This com- <br> mand prints characters at twice the normal <br> width, that is, at either 17 or 20 characters <br> per line. <br> Enable DMA mode; must be followed by two <br> bytes specifying the number of data charac- <br> ters to be fetched. Least significant byte ac- <br> cepted first. |
| 08 |  |

Hex Code

## Description

09 Tab character.
OA Line feed.
OB Multiple Line Feed; must be followed by a byte specifying the number of line feeds.
OC Top of Form. Enables the line feed output until the Top of Form input is activated.
OD Carriage Return. Signifies end of a line and enables the printer to start printing.

OE Set Tab \#1, followed by tab position byte.
OF Set Tab \#2, followed by tab position byte. Should be greater than Tab \#1.
10 Set Tab \#3, followed by tab position byte. Should be greater than Tab \#2.
Print Head Home on Right. On some printers the print head home position is on the right. This command would enable normal left to right printing with such printers.
12
Set Strobe Width; must be followed by strobe width selection byte. This command adjusts the duration of the strobe activation.

## CHARACTER SET



| Hex Code | Print Char. | Hex Code | Print Char. | Hex Code | Print Char. | Hex Code | Print Char. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 20 | space | 30 | 0 | 40 | @ | 50 | P |
| 21 | ! | 31 | 1 | 41 | A | 51 | Q |
| 22 | " | 32 | 2 | 42 | B | 52 | R |
| 23 | \# | 33 | 3 | 43 | C | 53 | S |
| 24 | \$ | 34 | 4 | 44 | D | 54 | T |
| 25 | \% | 35 | 5 | 45 | E | 55 | U |
| 26 | \& | 36 | 6 | 46 | F | 56 | V |
| 27 | , | 37 | 7 | 47 | G | 57 | W |
| 28 | $($ | 38 | 8 | 48 | H | 58 | X |
| 29 | ) | 39 | 9 | 49 | I | 59 | Y |
| 2A | * | 3A | : | 5A | $J$ | 5A | Z |
| 2B | + | 3B | ; | 4B | K | 5B | [ |
| 2 C | , | 3 C | $<$ | 4 C | L | 5C | 1 |
| 2D | - | 3D | = | 4D | M | 5D | ] |
| 2E | . | 3E | > | 4E | $N$ | 5E | $\uparrow$ |
| 2F | 1 | 4F | ? | 4F | 0 | 5F | - |


| Name | 1/0 | Pin \# | Description | Name | I/O | Pin \# | scription |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | I/O | 12-19 | Three-state bidirectional data | $\overline{\text { MOT }}$ | 0 | 35 | Main motor drive, active low. |
|  |  |  | bus buffer lines used to inter- | GP1, GP2 | 0 | 23,24 | General purpose output pins. |
|  |  |  | face the 8295 to the host processor in the parallel mode. In the serial mode $D_{0}-D_{2}$ sets up | $\mathrm{S}_{1}-\mathrm{S}_{7}$ | 0 | 27-33 | Solenoid drive outputs; active low. |
|  |  |  | the baud rate. | STB | 0 | 34 | Solenoid strobe output. Used |
| $\overline{W R}$ | 1 | 10 | Write input which enables the master CPU to write data and commands to the 8295 . In the serial mode this pin must be tied to ground. |  |  |  | to determine duration of solenoids activation. |
|  |  |  |  | $\overline{\text { TOF }}$ | 1 | 22 | Top of form input, used to sense top of form signal for type T printer, active low. |
| $\overline{\mathrm{RD}}$ | 1 | 8 | Read input which enables the master CPU to read data and status. In the serial mode this pin must be tied to $\mathrm{V}_{\mathrm{CC}}$. | IRQ/ $\overline{S E R}$ | 1/0 | 36 | In parallel mode it is an interrupt request input to the master CPU; in serial mode it should be strapped to ground. |
| $\overline{\mathrm{CS}}$ | 1 | 6 | Chip select input used to enable the $\overline{R D}$ and $\overline{W R}$ inputs except during DMA, active low. | DRQ/ $\overline{C T S}$ | 0 | 37 | In the parallel mode used as DMA request output pin to indicate to the 8257 that a DMA |
| RESET | 1 | 4 | Reset input, active low. After reset the 8295 will be set for 12 characters/inch single width |  |  |  | transfer is requested; in the serial mode used as clear-tosend signal. |
|  |  |  | printing, solenoid strobe at 320 msec. | $\begin{aligned} & \overline{\mathrm{DACK} /} \\ & \mathrm{SIN} \end{aligned}$ | $1 / 0$ | 38 | In the parallel mode used as DMA acknowledgement; in the |
| PFEED | 1 | 1 | Paper feed input switch. |  |  |  | serial mode, used as input for |
| HOME | 1 | 39 | Home input switch, used by the 8295 to detect that the print head is in the home position. | SYNC | 0 | 11 | Output signal which occurs once per instruction cycle ( 2.5 |
| $X_{1}, x_{2}$ | 1 | 2,3 | Inputs for a crystal to set internal oscillator frequency. For |  |  |  | $\mu \mathrm{sec}$ with 6 MHz crystal); can be used as a reference clock. |
|  |  |  | proper operation use 6 MHz | $\mathrm{V}_{\mathrm{CC}}$ | - | 9,40 | +5 V power supply |
|  |  |  | crystal. | $V_{\text {DD }}$ | - | 26 | +5 V low power standby sup- |
| PFM | 0 | 21 | Paper feed motor drive, active low. | GND | - | 20 | ply. <br> Circuit and supply ground. |



## Microcomputer Development Systems

## MICROCOMPUTER DEVELOPMENT SYSTEMS

## TABLE OF CONTENTS

MICROCOMPUTER DEVELOPMENT SYSTEMS
Model 210 Intellec ${ }^{\circledR}$ Series II Microcomputer Development System ..... 12-3
Model 220 Intellec ${ }^{\circledR}$ Series II Microcomputer Development System ..... 12-6
Model 230 Intellec ${ }^{\circledR}$ Series II Microcomputer Development System . ..... 12-10
Expansion Chassis Intellec ${ }^{\circledR}$ Series II Microcomputer Development System ..... 12-14
Model 770 Printer Intellec ${ }^{\circledR}$ Series II Microcomputer Development System ..... 12-16
Intellec Printer ..... 12-18
MCS-48 Diskette-Based Software Support Package ..... 12-20
PL/M-80 High Level Programming Language Intellec ${ }^{\circledR}$ Resident Compiler ..... 12-22
MDS-311 8086 Software Development Package. ..... 12-25
FORTRAN-80 8080/8085 ANS FORTRAN 77 Intellec Resident Compiler ..... 12-36
Basic-80 Extended ANS 1978 Basic Intellec ${ }^{\oplus}$ Resident Interpreter ..... 12-40
Intellec ${ }^{\circledR}$ Single/Double Density Flexible Disk System ..... 12-43
ISIS-II Diskette Operating System Microcomputer Development System ..... $12-47$
Intellec Prompt 48 MCS-48 Microcomputer Design Aid ..... 12-50
ICE-49 MCS-48 In-Circuit Emulator. ..... 12-56
ICE-80 8080 In-Circuit Emulator ..... 12-61
ICE-85 MCS-85 In-Circuit Emulator ..... 12-67
ICE-86 8086 In -Circuit Emulator ..... 12.71
EM1 8021 Emulation Board ..... 12.77
EM2 8022 Emulation Board ..... 12-80
UPP-103 Universal PROM Programmer ..... 12-83
SDK-85 MCS-85 System Design Kit. . ..... 12-85
SDK-86 MCS-86 System Design Kit . ..... 12-91
SDK-C86 MCS-86 System Design Kit Software and Cable Interface to Intellec® ${ }^{\circledR}$ Development System. ..... 12-97
Insite User's Program Library ..... 12-99
TEST AND INSTRUMENTATION SYSTEMS
$\mu$ Scope 820 Microprocessor System Console ..... 12-103
$\mu$ Scope Probe 8080A ..... 12-108
$\mu$ Scope Probe 8085 ..... 12-110
MICROCOMPUTER TRAINING PROGRAMS ..... 12-112

## intel

## MODEL 210 INTELLEC SERIES II MICROCOMPUTER DEVELOPMENT SYSTEM

Low cost development system for MCS-80, MCS-85, and MCS-48 microprocessor families

Compact four-slot chassis

Single LSI electronics board with CPU, 32 K bytes RAM memory, and 4 K bytes ROM memory

Self-test diagnostic capability

Eight-level nested, maskable priority interrupt system

Built-in interfaces for TTY, CRT, printer, high speed paper tape reader/punch and universal PROM programmer

Standard MULTIBUS with multiprocessor and DMA capabilities

ROM-based monitor, assembler, and editor

Compatible with standard Intellec/iSBC expansion modules

## Software compatible with previous Intellec systems

The Model 210 Intellec Series II Microcomputer Development System is a low cost, fully supported development system providing basic hardware and software support for development of products based around Intel's MCS-80 or MCS-85 microprocessor families. Through optional software, this development capability can be extended to products based on the MCS-48 family of microprocessors. Using the user supplied system console (TTY or equivalent), the product designer may enter and correct a program source code, assemble, and begin execution, all using the Model 210 ROM-resident editor/assembler. MCS-80 and MCS-85 debugging is accomplished by means of system monitor debug commands. Completed programs may be punched to paper tape for loading into the user's system or programmed into PROM using the optional Intellec UPP-103 Universal PROM Programmer.


## FUNCTIONAL DESCRIPTION

## Hardware Components

The Intellec Series II Model 210 is a compact, 4-inch table-top chassis with a 4-slot cardcage, power supply, and two printed circuit cards. The CPU, interrupt, I/O, and bus interface circuitry are all fashioned from Intel's high technology LSI components and located on one PC board. Known as the integrated processor board (IPB), it occupies the first slot in the cardcage. A second PC board (the parallel I/O board - PIO) containing additional I/O interface logic is mounted on the rear panel. The remaining 3 slots in the cardcage are available for system expansion. A simplified block diagram of the IPB is shown in Figure 1.

## System Components

The heart of the IPB is an Intel NMOS 8-bit microprocessor, the $8080 \mathrm{~A}-2$, running at 2.6 MHz .32 K bytes of RAM memory are provided on the board using Intel 16K RAMs. 4 K of ROM is provided, preprogrammed with system bootstrap "self-test" diagnostics, and the Intellec Series II System Monitor. The eight-level vectored priority interrupt system allows interrupts to be individually masked. Using Intel's versatile 8259 interrupt controller, the interrupt system may be user programmed to respond to individual needs.

## Input/Output

IPB Serial Channels - The I/O subsystem in the Model 210 consists of two parts. Two serial channels are provided directly on the IPB itself. Each channel is RS232 compatible and is capable of running asynchronously from 110 to 9600 baud or synchronously from 150 to 56K baud. One channel contains current loop adapters for teletype compatibility. Both channels are implemented using Intel's 8251 USART. They can be programmatically selected to perform a variety of I/O functions. Baud rate selection is accomplished programmatically through an Intel 8253 interval timer. The 8253 also serves as the real-time clock for the entire system. I/O activity is signaled to the system through a second 8259
interrupt controller, operating in a polled mode, nested to the primary 8259.

PIO Interface Logic - The second part of the I/O subsystem consists of the interface logic provided on the PIO board itself. Utilizing Intel's UPI-41 programmable peripheral controller, the PIO board provides device interfaces for standard Intellec peripherals, including a printer, high speed paper tape reader, high speed paper tape punch, and Universal PROM programmer. Communication between the IPB and PIO is maintained over a separate 8 -bit bidirectional data bus. Connectors for the four devices specified above, as well as the two serial channels, are mounted directly on the PIO.

## Control

User control is maintained through a front panel consisting of a power switch and indicator, reset/boot switch, run/halt light, and eight interrupt switches and indicators. The front-panel circuit board is attached directly to the IPB, allowing the eight interrupt switches to connect to the primary 8259, as well as to the Intellec Series II bus.

## MULTIBUS Capability

All Intellec Series II models implement the industrystandard MULTIBUS. MULTIBUS enables several bus masters, such as CPU and DMA devices, to share the bus and memory by operating at different priority levels. Resolution of bus exchanges is synchronized by a bus clock signal derived independently from processor clocks. Read/write transfers may take place at rates up to 5 MHz . The bus structure is suitable for use with any Intel microprocessor family.

## Software

All standard Model 210 software is ROM-based to eliminate costly delays of loading paper tape. The capabilities of the system monitor with its "self-test" diagnostics, text editor, and MCS-80/MCS-85 or MCS-48 ROM assemblers are described on pages 10-22 to 10-25 of this catalog.


Figure 1. Simplified Integrated Processor Board (IPB) Block Diagram for the Model 210 Intellec Series II Microcomputer Development System

## SPECIFICATIONS

## Host Processor (IPB)

8080A-2 based, operating at 2.600 MHz .
RAM - 32K, expandable to 64 K with iSBC 032 RAM board (system monitor occupies 62 K through 64 K )
ROM - 4K ( 2 K in monitor, 2K in boot/diagnostic), expandable with addition of 20 K auxiliary ROM board containing text editor and assembler
Bus - MULTIBUS, maximum transfer rate of 5 MHz
Clocks - Host processor, crystal controlled at 2.6 MHz , bus clock, crystal controlled at 9.8304 MHz

## Memory Access Time

RAM - 585 ns max
PROM - 450 ns max

## I/O Interfaces

2 serial I/O channels, RS232C, at 110-9600 baud (asynchronous) or $150-56 \mathrm{~K}$ baud (synchronous). Baud rates and serial format fully programmable using Intel 8251 USARTs. Serial channel 1 additionally provided with 20 mA current loop. Parallel I/O interfaces provided for paper tape punch, paper tape reader, printer, and UPP-103 Universal PROM Programmer.

## Interrupts

8-level, maskable, nested priority interrupt network initiated from front panel or user selected devices.

## Direct Memory Access (DMA)

Standard capability on MULTIBUS; implemented for user selected DMA devices through optional DMA module - maximum transfer rate of 2 MHz .

Physical Characteristics
Width - 17.37 in. ( 44.12 cm )
Height - 4.81 in. $(12.22 \mathrm{~cm})$
Depth - 19.13 in . $(48.59 \mathrm{~cm}$ )
Weight - $45 \mathrm{lb}(20.5 \mathrm{~kg})$

## Electrical Characteristics

DC Power Supply

| Volts <br> Supplied | Amps <br> Supplied | Typical <br> System Requirements |
| :---: | :---: | :---: |
| $+5 \pm 5 \%$ | 24 | 3.5 |
| $+12 \pm 5 \%$ | 2.0 | 0.1 |
| $-12 \pm 5 \%$ | 0.3 | 0.05 |
| $-10 \pm 5 \%$ | 1.0 | 0.1 |

AC Requirements
$50-60 \mathrm{~Hz}, 115 / 230 \mathrm{~V}$ AC

## Environmental Characteristics

Operating Temperature $-0^{\circ} \mathrm{C}$ to $35^{\circ} \mathrm{C}\left(95^{\circ} \mathrm{F}\right)$

## Equipment Supplied

Model 210 chassis
Integrated processor board (IPB)
Parallel I/O board (PIO)
ROM-resident system monitor
Auxiliary ROM board with MCS-80/MCS-85 assembler and text editor
PROM programming software (paper tape)
Assembler cross reference program (paper tape)

## Reference Manuals

9800558 - A Guide to Microcomputer Development Systems (SUPPLIED)
9800557 - Intellec Series II Model 210 User's Guide (SUPPLIED)
9800555 - Intellec Series II Hardware Interface Manual (SUPPLIED)
9800301 - 8080/8085 Assembly Language Programming Manual (SUPPLIED)
9800605 - Intellec Series II System Monitor Source Listing (SUPPLIED)
9800554 - Intellec Series II Schematic Drawings (SUPPLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

ORDERING INFORMATION

## Part Number Description

MDS-210
Intellec Series II Model 210 microcomputer development system.

# intel <br> MUDEL 220 INTELLEC SERIES II MICROCOMPUTER DEVELOPMENT SYSTEM 

Complete microcomputer development system in one package for MCS-80, MCS-85, and MCS-48 microprocessor families

Single LSI electronics board with CPU, 32K bytes RAM memory, and 4K bytes ROM memory

Self-test diagnostic capability

Eight-level nested, maskable priority interrupt system

Built-in interfaces for high speed paper tape reader/punch, printer, and universal PROM programmer

## Integral CRT with detachable upperl lower case typewriter-style full ASCII keyboard

Integral 250K-byte floppy disk with total storage capacity expandable to over 2M bytes

## Powerful ISIS-II Diskette Operating System with relocating macroassembler, linker, and locater

Standard MULTIBUS with multiprocessor and DMA capability

Compatible with standard Intellec/iSBC expansion modules

## Software compatible with previous

 Intellec systemsThe Model 220 Intellec Series II Microcomputer Development System is a complete microcomputer development system integrated into one compact package. It includes a CPU with 32K bytes of RAM memory, 4K bytes of ROM memory, a 2000-character CRT, detachable full ASCII keyboard with cursor controls and upper/lower case capability, and a 250K-byte floppy diskette drive. Powerful ISIS-II Diskette Operating System software allows the Model 220 to be used quickly and efficiently for assembling and debugging programs for Intel's MCS-80, MCS-85, or MCS-48 microprocessor families without the need for paper tape handling. ISIS-II performs all file handling operations for the user, leaving him free to concentrate on the details of his own application. When used in conjunction with an optional incircuit emulator (ICE) module, the Model 220 provides all the hardware and software development tools necessary for the rapid development of a microcomputer-based product.


## FUNCTIONAL DESCRIPTION

## Hardware Components

The Intellec Series II Model 220 is a packaged, highly integrated microcomputer development system consisting of a CRT chassis with a 6 -slot cardcage, power supply, fans, cables, single floppy diskette drive, and two printed circuit cards. A separate, full ASCII keyboard is connected with a cable.
CPU Cards - The master CPU card contains its own microprocessor, memory, I/O, interrupt, and bus interface circuitry, fashioned from intel's high-technology LSI components. Known as the integrated processor board (IPB), it occupies the first slot in the cardcage. A second, slave CPU card, is responsible for all remaining I/O control, including the CRT and keyboard interface and floppy disk control. This card, mounted on the rear panel, also contains its own microprocessor, RAM and ROM memory, and I/O interface, thus in effect creating a dual processor environment. Known as the I/O controller (IOC), the slave CPU card communicates with the IPB over an 8 -bit bidirectional data bus, thus leaving the remaining 5 slots in the cardcage available for system expansion. A block diagram of the IOC is shown in Figure 1.

## System Components

The heart of the IPB is an Intel NMOS 8-bit microprocessor, the $8080 \mathrm{~A}-2$, running at 2.6 MHz . 32K bytes of RAM memory are provided on the board using Intel 16K RAMs. 4 K of ROM is provided, preprogrammed with system bootstrap "self-test" diagnostics and the Intellec Series II System Monitor. The eight-level vectored priority interrupt system allows interrupts to be individually masked. Using Intel's versatile 8259 interrupt controller, the interrupt system may be user programmed to respond to individual needs.

## Input/Output

IBP Serial Channels - The I/O subsystem in the Model 220 consists of two parts: the IOC card and two serial channels on the IPB itself. Each serial channel is RS232 compatible and is capable of running asynchronously from 110 to 9600 baud or synchronously from 150 to 56K baud. Both may be connected to a user defined data set or data terminal. One channel contains current loop adapters. Both channels are implemented using Intel's 8251 USART. They can be programmatically selected to perform a variety of I/O functions. Baud rate selection is accomplished programmatically through an Intel 8253 interval timer. The 8253 also serves as a real-time clock for the entire system. 1/O activity through both serial channels is signaled to the system through a second 8259 interrupt controller, operating in a polled mode, nested to the primary 8259.

IOC Interface - The remainder of system I/O activity takes place in the IOC. The IOC provides interfaces for the CRT, keyboard, integral floppy disk and standard Intellec peripherals, including a printer, high speed paper tape reader/punch, and universal PROM programmer. The IOC contains its own independent microprocessor, also an 8080A-2. This CPU controls all I/O operations, as well as supervising communications with the IPB. 8 K bytes of ROM contain all I/O control firmware. 8 K bytes of ROM are used for CRT screen refresh storage and the floppy disk buffer. These do not occupy any space in Intellec Series II main memory since the IOC is a totally independent microcomputer subsystem.

Integral CRT Display - The CRT is a 12 -inch raster scan-type monitor with a $50 / 60 \mathrm{~Hz}$ vertical scan rate and 15.5 kHz horizontal scan rate. Controls are provided for brightness and contrast adjustments. The interface to the CRT is provided through an Intel 8275 single chip, programmable CRT controller. The master processor on


Figure 1. I/O Controller (IOC) Block Diagram for the Model 220 Intellec Series II Microcomputer Development System
the IPB transfers a character for display to the IOC, where it is stored in RAM. The CRT controller reads a line at a time into its line buffer through an Intel 8257 DMA controller and then feeds one character at a time to the character generator to produce the video signal. Timing for the CRT control is provided by an Intel 8253 interval timer. The screen display is formatted as 25 rows of 80 characters. The full set of ASCII characters are displayed, including lower-case alphas.
Keyboard - The keyboard interfaces directly to the IOC processor via an 8-bit data bus. The keyboard contains an Intel UPI-41 Universal Peripheral Interface, which scans the keyboard, encodes the characters, and buffers the characters to provide N-key rollover. The keyboard itself is a high quality typewriter-style keyboard containing the full ASCII character set. An upper/lower case switch allows the system to be used for document preparation. Cursor control keys are also provided.

## Floppy Disk Drive

The floppy disk drive is controlled by an Intel 8271 single chip, programmable floppy disk controller. It transfers data via an Intel 8257 DMA controller between an IOC RAM buffer and the diskette. The 8271 handles reading and writing of data, formatting diskettes, and reading status, all upon appropriate commands from the IOC microprocessor.

## Peripheral Interface

A UPI-41 Universal Peripheral Interface on the IOC board performs similar functions to the UPI-41 on the PIO board in the Model 210. It provides interface for other
standard Intellec peripherals, including a printer, high speed paper tape reader, high speed paper tape punch, and universal PROM programmer. Communication between the IPB and IOC is maintained over a separate, 8 -bit bidirectional data bus. Connectors for the devices named above, as well as the two serial channels, are mounted directly on the IOC itself.

## Control

User control is maintained through a front panel consisting of a power switch and indicator, reset/boot switch, run/halt light, and eight interrupt switches and indicators. the front-panel circuit board is attached directly to the IPB, allowing the eight interrupt switches to connect to the primary 8259, as well as to the Intellec Series II bus.

## MULTIBUS Capability

All Intellec Series II models implement the industrystandard MULTIBUS. MULTIBUS enables several bus masters, such as CPU and DMA devices, to share the bus and memory by operating at different priority levels. Resolution of bus exchanges is synchronized by a bus clock signal derived independently from processor clocks. Read/write transfers may take place at rates up to 5 MHz . The bus structure is suitable for use with any Intel microcomputer family.

## Expansion

The Model 220 may be expanded to 64 K of RAM and up to 2.25 M bytes of on-line diskette storage.

## SPECIFICATIONS

## Host Processor (IPB)

8080A-2 based, operating at 2.600 MHz .
RAM - 32 K , expandable to 64 K with iSBC 032 RAM boards (system monitor occupies 62 K through 64 K )
ROM - 4 K ( 2 K in monitor, 2 K in boot/diagnostic)
Bus - MULTIBUS, maximum transfer rate of 5 MHz
Clocks - Host processor, crystal controlled at 2.6 MHz , bus clock, crystal controlled at 9.8304 MHz

## I/O Interfaces

2 Serial I/O Channels, RS232C, at 110-9600 baud (asynchronous) or $150-56 \mathrm{~K}$ baud (synchronous). Baud rates and serial format fully programmable using Intel 8251 USARTs. Serial Channel 1 additionally provided with 20 mA current loop. Parallel I/O interfaces provided for paper tape punch, paper tape reader, printer, and UPP-103 Universal PROM Programmer.

## Interrupts

8-level, maskable, nested priority interrupt network initiated from front panel or user selected devices.

## Direct Memory Access (DMA)

Standard capability on MULTIBUS; implemented for user selected DMA devices through optional DMA module - maximum transfer rate of 2 MHz .

## Memory Access Time

RAM - 585 ns max
PROM - 450 ns max

## Diskette

Diskette System Capacity - 250K bytes (formatted)
Diskette System Transfer Rate - 160K bits/sec
Diskette System Access Time
Track-to-Track: 10 ms max
Average Random Positioning: 260 ms max
Rotational Speed: 360 rpm
Average Rotational Latency: 83 ms max
Recording Mode: FM
Physical Characteristics
Width - 17.37 in . ( 44.12 cm )
Height - $15.81 \mathrm{in} .(40.16 \mathrm{~cm})$
Depth - 19.13 in. ( 48.59 cm )
Weight - $86 \mathrm{lb}(39 \mathrm{~kg})$

Keyboard
Width - $17.37 \mathrm{in} .(44.12 \mathrm{~cm}$ )
Height - 3.0 in . $(7.62 \mathrm{~cm}$ )
Depth - $9.0 \mathrm{in} .(22.0 \mathrm{~cm})$
Weight - $6 \mathrm{lb}(3 \mathrm{~kg})$

## Electrical Characteristics

DC Power Supply

| Volts <br> Supplied | Amps <br> Supplied | Typical <br> System Requirements |
| :---: | :---: | :---: |
| $+5 \pm 5 \%$ | 30.0 | 7.5 |
| $+12 \pm 5 \%$ | 2.5 | 0.2 |
| $-12 \pm 5 \%$ | 0.3 | 0.05 |
| $-10 \pm 5 \%$ | 1.5 | 0.15 |
| $+15 \pm 5 \%$ | 1.5 | $1.3^{*}$ |
| $+24 \pm 5 \%$ | 1.7 | $1.2^{*}$ |

*Not available on bus.

## AC Requirements

$50-60 \mathrm{~Hz} .115 / 230 \mathrm{~V}$ AC

## Equipment Supplied

Model 220 chassis
Integrated processor board (IPB)
I/O controller board (IOC)
CRT and keyboard
250K-byte floppy disk drive
ROM resident system monitor
ISIS-II system diskette with MCS-80/MCS-85 macroassembler

## Reference Manuals

9800558 - A Guide to Microcomputer Development Systems (SUPPLIED)

9800559 - Intellec Series II Installation and Service Manual (SUPPLIED)

9800306 - ISIS-II System User's Guide (SUPPLIED)

9800556 - Intellec Series II Hardware Reference Manual (SUPPLIED)

9800555 - Intellec Series II Hardware Interface Manual (SUPPLIED)

9800301 - 8080/8085 Assembly Language Programming Manual (SUPPLIED)

9800605 - Intellec Series II System Monitor Source Listing (SUPPLIED)

9800554 - Intellec Series II Schematic Drawing (SUPPLIED)

Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

| Part Number | Description |
| :--- | :--- |
| MDS-220 | Intellec Series II Model 220 <br>  <br>  <br> microcomputer development system <br> $(110 \mathrm{~V} / 60 \mathrm{~Hz})$ |
| MDS-221 | Intellec Series II Model 220 <br>  <br>  <br>  <br> microcomputer development system <br> $(220 \mathrm{~V} / 50 \mathrm{~Hz})$ |

MODEL 230

## MICROCOMPUTER DEVELOPMENT SYSTEM

Complete microcomputer development center for Intel MCS-80, MCS-85, and MCS-48 microprocessor families

LSI electronics board with CPU, RAM, ROM, I/O, and interrupt circuitry

64K bytes RAM memory
Self-test diagnostic capability
Eight-level nested, maskable priority interrupt system

Built-in interfaces for high speed paper tape reader/punch, printer, and universal PROM programmer

Integral CRT with detachable upper/
lower case typewriter-style full ASCII keyboard

Powerful ISIS-II Diskette Operating System software with relocating macroassembler, linker, and locater

1 million bytes (expandable to 2.5M bytes) of diskette storage

Supports PL/M and FORTRAN high level languages

Standard MULTIBUS with multiprocessor and DMA capability

Compatible with standard Intellec/iSBC expansion modules

Software compatible with previous Intellec systems

The Model 230 Intellec Series II Microcomputer Development System is a complete center for the development of microcomputer-based products. It includes a CPU, 64 K bytes of RAM, 4 K bytes of ROM memory, a 2000-character CRT, a detachable full ASCII keyboard, and dual double density diskette drives providing over 1 million bytes of on-line data storage. Powerful ISIS-II Diskette Operating System software allows the Model 230 to be used quickly and efficiently for assembling and/or compiling and debugging programs for Intel's MCS-80, MCS-85, or MCS-48 microprocessor families without the need for handling paper tape. ISIS-II performs all file handling operations, leaving the user free to concentrate on the details of his own application. When used in conjunction with an optional in-circuit emulator (ICE) module, the Model 230 provides all the hardware and software development tools necessary for the rapid development of a microcomputer-based product.


## FUNCTIONAL DESCRIPTION

## Hardware Components

The Intellec Series II Model 230 is a packaged, highly integrated microcomputer development system consisting of a CRT chassis with a 6 -slot cardcage, power supply, fans, cables, and five printed circuit cards. A separate, full ASCII keyboard is connected with a cable. A second chassis contains two floppy disk drives capable of double-density operation along with a separate power supply, fans, and cables for connection to the main chassis. A block diagram of the Model 230 is shown in Figure 1.

CPU Cards - The master CPU card contains its own microprocessor, memory, I/O, interrupt and bus interface circuitry fashioned from Intel's high technology LSI components. Known as the integrated processor board (IPB), it occupies the first slot in the cardcage. A second slave CPU card is responsible for all remaining I/O control including the CRT and keyboard interface. This card, mounted on the rear panel, also contains its own microprocessor, RAM and ROM memory, and I/O interface logic, thus, in effect, creating a dual processor environment. Known as the I/O controller (IOC), the slave CPU
card communicates with the IPB over an 8 -bit bidirectional data bus.

Memory and Control Cards - In addition, 32K bytes of RAM (bringing the total to 64 K bytes) is located on a separate card in the main cardcage. Fabricated from Intel's 16K RAMs, the board also contains all necessary address decoding and refresh logic. Two additional boards in the cardcage are used to control the two double-density floppy disk drives.

Expansion - Two remaining slots in the cardcage are available for system expansion. Additional expansion of 4 slots can be achieved through the addition of an Intellec Series II expansion chassis.

## System Components

The heart of the IPB is an Intel NMOS 8-bit microprocessor, the $8080 \mathrm{~A}-2$, running at 2.6 MHz . 32 K bytes of RAM memory are provided on the board using Intel 16K RAMs. 4 K of ROM is provided, preprogrammed with system bootstrap "self-test" diagnostics and the Intellec Series II System Monitor. The eight-level vectored priority interrupt system allows interrupts to be individually masked. Using Intel's versatile 8259 interrupt controller, the interrupt system may be user programmed to respond to individual needs.


Figure 1. Intellec Series II Model 230 Microcomputer Development System Block Diagram

## Input/Output

IPB Serial Channels - The I/O subsystem in the Model 230 consists of two parts: the IOC card and two serial channels on the IPB itself. Each serial channel is RS232 compatible and is capable of running asynchronously from 110 to 9600 baud or synchronously from 150 to 56 K baud. Both may be connected to a user defined data set or terminal. One channel contains current loop adapters. Both channels are implemented using Intel's 8251 USART. They can be programmatically selected to perform a variety of I/O functions. Baud rate selection is accomplished progammatically through an Intel 8253 interval timer. The 8253 also serves as a real-time clock for the entire system. I/O activity through both serial channels is signaled to the system through a second 8259 interrupt controller, operating in a polled mode nested to the primary 8259.
IOC Interface - The remainder of system I/O activity takes place in the IOC. The IOC provides interface for the CRT, keyboard, and standard Intellec peripherals including printer, high speed paper tape reader/punch, and universal PROM programmer. The IOC contains its own independent microprocessor, also an 8080A-2. The CPU controls all I/O operations as well as supervising communications with the IPB. 8 K bytes of ROM contain all I/O control firmware. 8 K bytes of RAM are used for CRT screen refresh storage. These do not occupy space in Intellec Series II main memory since the IOC is a totally independent microcomputer subsystem.

## Integral CRT

Display - The CRT is a 12 -inch raster scan type monitor with a $50 / 60 \mathrm{~Hz}$ vertical scan rate and 15.5 kHz horizontal scan rate. Controls are provided for brightness and contrast adjustments. The interface to the CRT is provided through an Intel 8275 single chip programmable CRT controller. The master processor on the IPB transfers a character for display to the IOC, where it is stored in RAM. The CRT controller reads a line at a time into its line buffer through an Intel 8257 DMA controller and then feeds one character at a time to the character generator to produce the video signal. Timing for the CRT control is provided by an Intel 8253 interval timer. The screen display is formatted as 25 rows of 80 characters. The full set of ASCII characters are displayed, including lower case alphas.
Keyboard - The keyboard interfaces directly to the IOC processor via an 8-bit data bus. The keyboard contains an Intel UPI-41 Universal Peripheral Interface, which scans the keyboard, encodes the characters, and buffers the characters to provide N-key rollover. The keyboard itself is a high quality typewriter style keyboard containing the full ASCII character set. An upper/lower case switch allows the system to be used for document preparation. Cursor control keys are also provided.

## Peripheral Interface

A UPI-41 Universal Peripheral Interface on the IOC board performs similar functions to the UPI-41 on the PIO board in the Model 210. It provides interface for other standard Intellec peripherals including a printer, high speed paper tape reader, high speed paper tape punch,
and universal PROM programmer. Communication between the IPB and IOC is maintained over a separate 8 -bit bidirectional data bus. Connectors for the four devices named above, as well as the two serial channels, are mounted directly on the IOC itself.

## Control

User control is maintained through a front panel, consisting of a power switch and indicator, reset/boot switch, run/halt light, and eight interrupt switches and indicators. The front panel circuit board is attached directly to the IPB, allowing the eight interrupt switches to connect to the primary 8259, as well as to the Intellec Series II bus.

## Diskette System

The Intellec Series II double density diskette system provides direct access bulk storage, intelligent controller, and two diskette drives. Each drive provides $1 / 2 \mathrm{mil}$ lion bytes of storage with a data transfer rate of 500,000 bits/second. The controller is implemented with Intel's powerful Series 3000 Bipolar Microcomputer Set. The controller provides an interface to the Intellec Series II system bus, as well as supporting up to four diskette drives. The diskette system records all data in soft sector format. The diskette system is capable of performing seven different operations: recalibrate, seek, format track, write data, write deleted data, read data, and verify CRC.

Diskette Controller Boards - The diskette controller consists of two boards, the channel board and the interface board. These two PC boards reside in the Intellec Series II system chassis and constitute the diskette controller. The channel board receives, decodes and responds to channel commands from the 8080A-2 CPU in the Model 230. The interface board provides the diskette controller with a means of communication with the diskette drives and with the Intellec system bus. The interface board validates data during reads using a cyclic redundancy check (CRC) polynomial and generates CRC data during write operations. When the diskette controller requires access to Intellec system memory, the interface board requests and maintains DMA master control of the system bus, and generates the appropriate memory command. The interface board also acknowledges I/O commands as required by the Intellec bus. In addition to supporting a second set of double density drives, the diskette controller may co-reside with the Intel single density controller to allow up to 2.5 million bytes of on-line storage.

## MULTIBUS Capability

All Intellec Series II models implement the industry standard MULTIBUS. MULTIBUS enables several bus masters, such as CPU and DMA devices, to share the bus and memory by operating at different priority levels. Resolution of bus exchanges is synchronized by a bus clock signal derived independently from processor clocks. Read/write transfers may take place at rates up to 5 MHz . The bus structure is suitable for use with any Intel microcomputer family.

## SPECIFICATIONS

Host Processor (IPB)
RAM - 64K (system monitor occupies 62K through 64K)
ROM -4 K ( 2 K in monitor, 2 K in boot/diagnostic)
Diskette System Capacity (Basic Two Drives)

## Unformatted

Per Disk: 6.2 megabits
Per Track: 82.0 kilobits

## Formatted

Per Disk: 4.1 megabits
Per Track: 53.2 kilobits

## Diskette Performance

Diskette System Transfer Rate - 500 kilobits/sec
Diskette System Access Time
Track-to-Track: 10 ms
Head Settling Time: 10 ms
Average Random Positioning Time - 260 ms
Rotational Speed - 360 rpm
Average Rotational Latency - 83 ms
Recording Mode $-\mathrm{M}^{2} \mathrm{FM}$

## Physical Characteristics

Width - 17.37 in . $(44.12 \mathrm{~cm}$ )
Height - $15.81 \mathrm{in} .(40.16 \mathrm{~cm})$
Depth - 19.13 in. ( 48.59 cm )
Weight - $73 \mathrm{lb}(33 \mathrm{~kg})$
Keyboard
Width - 17.37 in. ( 44.12 cm )
Height - $3.0 \mathrm{in} .(7.62 \mathrm{~cm}$ )
Depth - 9.0 in. ( 22.86 cm )
Weight $-6 \mathrm{lb}(3 \mathrm{~kg})$
Dual Drive Chassis
Width - 16.88 in. ( 42.88 cm )
Height - $12.08 \mathrm{in} .(30.68 \mathrm{~cm})$
Depth - 19.0 in. ( 48.26 cm )
Weight - $64 \mathrm{lb}(29 \mathrm{~kg})$

## Electrical Characteristics

DC Power Supply

| Volts <br> Supplied | Amps <br> Supplied | Typical <br> System Requirements |
| :---: | :---: | :---: |
| $+5 \pm 5 \%$ | 30 | 14.25 |
| $+12 \pm 5 \%$ | 2.5 | 0.2 |
| $-12 \pm 5 \%$ | 0.3 | 0.05 |
| $-10 \pm 5 \%$ | 1.5 | 15 |
| $*+15 \pm 5 \%$ | 1.5 | 1.3 |
| $+24 \pm 5 \%$ | 1.7 |  |

*Not available on bus.

## Environmental Characteristics

Operating Temperature $-0^{\circ}$ to $35^{\circ} \mathrm{C}\left(95^{\circ} \mathrm{F}\right)$

## Equipment Supplied

Model 230 chassis
Integrated processor board (IPB)
I/O controller board (IOC)
32K RAM board
CRT and keyboard
Double density floppy disk controller (2 boards)
Dual drive floppy disk chassis and cables
2 floppy disk drives ( 512 K byte capacity each)
ROM-resident system monitor
ISIS-II system diskette with MCS-80/MCS-85 macroassembler

## Reference Manuals

9800558 - A Guide to Microcomputer Development Systems (SUPPLIED)
9800550 - Intellec Series II Installation and Service
Guide (SUPPLIED)
9800306 - ISIS-II System User's Guide (SUPPLIED)
9800556 - Intellec Series II Hardware Reference Manual (SUPPLIED)

9800555 - Intellec Series II Hardware Reference Manual (SUPPLIED)

9800301 - 8080/8085 Assembly Language Programming Manual (SUPPLIED)

9800292 - ISIS-II 8080/8085 Assembler Operator's Manual (SUPPLIED)

9800605 - Intellec Series II Systems Monitor Source Listing (SUPPLIED)

9800554 - Intellec Series II Schematic Drawings (SUPPLIED)

Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

## Part Number Description

MDS-230 Intellec Series II Model 230 microcomputer development system ( $110 \mathrm{~V} / 60 \mathrm{~Hz}$ )
MDS-231
Intellec Series II Model 230 microcomputer development system ( $220 \mathrm{~V} / 50 \mathrm{~Hz}$ )

## intel

## EXPANSION CHASSIS INTELLEC SERIES II MICROCOMPUTER DEVELOPMENT SYSTEM

Four expansion slots for Intellec Series II systems

Internal power supply

Snug fit beneath all Intellec Series II units

Cable connectable to main Intellec bus
Standard Intellec MULTIBUS with multiprocessor and DMA capability

Compatible with standard Intellec/iSBC expansion modules


#### Abstract

The Intellec Series II Expansion Chassis provides four expansion slots for use with Intellec Series II microcomputer development systems. With its own separate power supply, the expansion chassis may be fully loaded with any boards needed to expand a user's Intellec Series II system. With the addition of the expansion chassis, Intellec Series II Models 220 and 230 contain a total of ten slots, sufficient for any configuration Intellec Series II system. The Intellec Series II Expansion Chassis is a compact chassis with a four slot cardcage, power supply, fans, and cable assemblies. It is designed to fit under any Intellec Series II system, connect directly to the system bus through an opening in the top of the chassis, and provide additional slots for the system users. The power supply is linked directly to the main chassis power supply, allowing power to flow to both chassis when the main power is turned on.




## SPECIFICATIONS

Physical Characteristics
Width - 17.37 in. ( 44.12 cm )
Height $-4.81 \mathrm{in} .(17.22 \mathrm{~cm})$
Depth - $19.13 \mathrm{in} .(48.59 \mathrm{~cm})$
Weight - $42 \mathrm{lb} .(19 \mathrm{~kg})$

## Electrical Characteristics

## DC Power Supply

| Volts <br> Supplied | Amps <br> Supplied | System <br> Requirements |
| :---: | :---: | :---: |
| $+5 \pm 5 \%$ | 24 | None |
| $+12 \pm 5 \%$ | 2.0 | None |
| $-12 \pm 5 \%$ | 0.3 | None |
| $-10 \pm 5 \%$ | 1.0 | None |

AC Requirements $-50-60 \mathrm{~Hz}, 115 / 230 \mathrm{~V}$ AC

## Environmental Characteristics

Operating Temperature $-0^{\circ}$ to $35^{\circ} \mathrm{C}\left(95^{\circ} \mathrm{F}\right)$

## Equipment Supplied

Expansion chassis
Cables

## Reference Manuals

9800550 - Intellec Series II Installation and Service Guide (SUPPLIED)
9800554 - Intellec Series II Schematic Drawings (SUPPLIED)

Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

## Part Number Description

MDS-201
Intellec Series II
expansion chassis

## MODEL 770 PRINTER INTELLEC SERIES II MICROCOMPUTER DEVELOPMENT SYSTEM

Provides low cost, hard copy printer for CRT-based systems

Prints original plus four copies
Prints 60 characters per seconds (21-90 lines per minute)

Offers $5 \times 7$ dot matrix character format

Provides for rear or bottom tractor feed

Provides adjustable line width from 80
to 132 columns on $81 / 2$ inch line

The Intellec Series II Microcomputer Development System Model 770 Printer is a low cost, hard copy printer designed for use with CRT-based Intellec Series II and Intellec microcomputer development systems. Unidirectional printing at 60 characters per second makes the Model 770 an ideal printer for microcomputer-based system designers with small to medium printing requirements. The $81 / 2$-inch line width may be filled with 80 to 132 characters by varying the character size. The printer uses standard fanfold paper through a tractor-feed mechanism to produce an original and up to four copies. Paper can be fed from either the bottom or the rear of the printer for versatility in any lab environment.


## SPECIFICATIONS

## Printing Method

Impact, character-by-character printing, one line character buffer.

## Printing Rate

Characters - 60 cps
Full Lines - 21 @ 80 characters/line, 90 @ 20 characters/line

## Transmission Rate

Parallel - Up to $75,000 \mathrm{cps}$

## Character Structure

$5 \times 7$ dot matrix, 10 point type equivalent

## Code

USASCII - 64 characters printed

## Switch Controls

On-Off

## Indicators

Paper Out

## Format

80 to 132 characters per line, variable.
10 to 165 characters per inch, operator adjustable.
6 lines per inch.

## Paper Feed

Tractor Feed - 5.5 ips slew

## Paper

Standard sprocketed paper, $81 / 2$ in. to $91 / 2 \mathrm{in}$. paper width

## Number of Copies

Original plus up to four carbon copies

## Physical Characteristics

Width - 24.5 in . 62.2 cm )
Height - 7.0 in . $(17.8 \mathrm{~cm})$
Depth - 18.0 in. ( 45.7 cm )
Weight - $60 \mathrm{lb}(27 \mathrm{~kg})$

## Electrical Characteristics

$50-60 \mathrm{~Hz}, 110 / 230 \mathrm{~V}$ AC $\pm 10 \%$

## Environmental Characteristics

Temperature - Operating: $-40^{\circ}$ to $100^{\circ} \mathrm{F}\left(5^{\circ}\right.$ to $\left.40^{\circ} \mathrm{C}\right)$, Storage: $-40^{\circ}$ to $160^{\circ} \mathrm{F}\left(-40^{\circ}\right.$ to $\left.50^{\circ} \mathrm{C}\right)$
Humidity - Operating: 5\% to $90 \%$ (no condensation), Storage: 0\% to $95 \%$ (no condensation)

## ORDERING INFORMATION

| Part Number | Description |
| :--- | :--- |
| MDS- 770 | 60 CPS printer $(110 \mathrm{~V} / 60 \mathrm{~Hz})$ |
| MDS-771 | 60 CPS printer $(220 \mathrm{~V} / 50 \mathrm{~Hz})$ |

## INTELLEC PRINTER

## Provides listing of hard copy output at 55 lines per minute

Switch selectable to 80 or 132 characters per 81⁄2-inch line

Employs $5 \times 7$ dot matrix with standard 2-channel, vertical control format

## Prints up to four copies on standard $81 / 2$-inch fanfold paper

## Provides automatic on-off motor switch for quiet operation

## Provides optional finished metal stand and paper takeup tray

The Intellec Printer provides hard copy listings at 10 to 16 times the speed of a teleprinter. The automatic on-off motor control allows the user to maintain a low noise environment and yet send information to the printer from the Intellec system console without additional manipulation of line printer switches. The user may select a column width of 80 characters per line ( 10 characters per inch) or 132 characters per line ( 16.5 characters per inch) either manually or under program control. Top of page spacing capability is available under user programmable format control. The printer uses standard $81 / 2$-inch fanfold paper and can produce up to four carbon copies along with the original. Paper may be fed either from the bottom or from the rear of the printer for versatility in any lab environment.


## SPECIFICATIONS

## Printing Method

Impact, character-by-character printing, one line character buffer

## Printing Rate

Characters - 100 or 165 cps
Full Lines - 55 lines per minute ( 80 - or 132-character line)

## Transmission Rate

Parallel - Up to 75,000 characters per second

## Data Input

Parallel

## Character Structure

$5 \times 7$ dot matrix, 10-point type equivalent

## Code

USASCII - 64 characters printed

## Switch Controls

On/off
Select
Forms override
Normal/condensed top of form
Indicators
Paper out
Select

## Manual Controls

Form thickness
Paper advance knob

## Buffer

One line character buffer

## Format

80 or 132 characters maximum per line, 6 lines per inch

## Paper Feed

Sprocket fed, 4 I.P.S. slew, adjustable to $91 / 2$-in. width

## Paper

Standard sprocketed paper

## Number of Copies

Original and up to four carbon copies

## Warranty

The MDS-PRN is warranted against defects in materials and workmanship for a period of one (1) year on mechanical parts, 90 days on electrical parts, and 45 days on labor.

## Physical Characteristics

Width - $23.25 \mathrm{in} .(59.1 \mathrm{~cm}$ )
Height - $12.75 \mathrm{in} .(32.4 \mathrm{~cm})$
Depth - 18.75 in. ( 47.6 cm )
Weight - $66 \mathrm{lb}(30.2 \mathrm{~kg})$

## Electrical Characteristics

$115 \mathrm{~V} \mathrm{AC} \pm 10 \%, 60 \mathrm{~Hz}$ (or $230 \mathrm{~V} \mathrm{AC} \pm 10 \%, 50 \mathrm{~Hz}$ as option)

## Environmental Characteristics

Temperature $-40^{\circ}$ to $100^{\circ} \mathrm{F}$, operating; $-40^{\circ}$ to $160^{\circ} \mathrm{F}$, storage
Humidity $-5 \%$ to $90 \%$ (no condensation) operating; $0 \%$ to $95 \%$ (no condensation) storage

Optional Equipment
MDS-STD finished metal stand and paper tray
Reference Manuals
None

## ORDERING INFORMATION

Part No. Description
MDS-PRN Printer unit
MDS-STD Stand and paper tray

## Inted

## MCS-48 <br> DISKETTE-BASED SOFTWARE SUPPORT PACKAGE

Extends Intellec microcomputer development system to support MCS-48 development

MCS-48 assembler provides conditional assembly and macro capability

Takes advantage of powerful ISIS-II file handling and storage capabilities

Provides assembler output in standard Intel hex format

The MCS-48 Diskette-Based Software Support Package is provided with the Intel ISIS-II system diskette and contains both the MCS-48 assembler and the diskette version of the universal PROM mapper. The assembler translates symbolic 8048 assembly language instructions into the appropriate machine operation codes, and provides both conditional and macroassembler programming. Output may be loaded either to an ICE-48 module for debugging or into an Intellec microcomputer development system for 8748 PROM programming using the universal PROM programmer.


## FUNCTIONAL DESCRIPTION

The MCS-48, a software support assembler package, is provided with the ISIS-II system diskette and contains both the MCS-48 assembler and the diskette version of the universal PROM mapper. The MCS-48 assembler translates symbolic 8048 assembly language instructions into the appropriate machine operation codes. The ability to refer to program addresses with symbolic names eliminates the errors of hand translation and makes it easier to modify programs when adding or deleting instructions. Conditional assembly permits the programmer to specify which portions of the master source document should be included or deleted in variations on a basic system design, such as the code required to handle optional external devices. Macro capability allows the programmer use of a single label to define a routine. The MCS-48 assembler will assemble the code required by the reserved routine whenever the macro label is inserted in the text. Output from the assembler is in standard Intel hex format. It may be either loaded directly to an in-circuit emulator (ICE-48) module for integrated hardware/software debugging, or loaded into an Intellec development system for 8748 PROM programming using the universal PROM programmer. A sample assembly listing is shown in Table 1.

## SPECIFICATIONS

## Operating Environment

## Required Hardware

Intellec microcomputer development system
System console
Intellec diskette operating system
32K RAM (absoluteassembler)
48K RAM (macroassembler)
Optional Hardware
Universal PROM programmer

## Shipping Media

Diskette


Table 1. Sample MCS-48 Diskette-Based Assembly Listing

## Reference Manuals

9800255 - MCS-48/UPI-41 Assembly Language Programming Manual (SUPPLIED)
9800236 - Universal PROM Mapper Operator's Manual (SUPPLIED)
9800306 - ISIS-II User's Guide (SUPPLIED)

Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

Product Code Description<br>MDS-D48 Diskette-based assembler for MCS-48<br>family of microprocessors

# PL/M-80 <br> HIGH LEVEL PROGRAMMING LANGUAGE INTELLEC RESIDENT COMPILER 


#### Abstract

Provides resident operation on Intellec Microcomputer Development System and Intellec Series II microcomputer development systems


Produces relocatable and linkable object code

Speeds project completion with increased programmer productivity

Cuts software development and maintenance costs


#### Abstract

Improves product reliability with simplified language and consequent error reduction


## Eases enhancement as system capabilities expand

## Sophisticated code optimization reduces application memory requirements

The PL/M-80 High Level Programming Language Intellec Resident Compiler is an advanced, high level programming language for Intel 8080 and 8085 microprocessors, iSBC-80 OEM computer systems, and Intellec microcomputer development systems. PL/M has been substantially enhanced since its introduction in 1973 and has become one of the most effective and powerful microprocessor systems implementation tools available. It is easy to learn, facilitates rapid program development and debugging, and significantly reduces maintenance costs. PL/M is an algorithmic language in which program statements naturally express the algorithm to be programmed, thus freeing programmers to concentrate on system development rather than assembly language details (such as register allocation, meanings of assembler mnemonics, etc.). The PL/M compiler efficiently converts free-form PL/M programs into equivalent $8080 /$ 8085 instructions. Substantially fewer PL/M statements are necessary for a given application than would be using assembly language or machine code. Since PL/M programs are problem oriented and thus more compact, programming in PL/M results in a high degree of productivity during development efforts, resulting in significant cost reduction in software development and maintenance for the user.


## FUNCTIONAL DESCRIPTION

The PL/M compiler is an efficient multiphase compiler that accepts source programs, translates them into object code, and produces requested listings. After compilation, the object program may be first linked to other modules, then located to a specific area of memory, and finally executed. The diagram shown in Figure 1 illustrates a program development cycle where the program consists of three modules: PL/M, FORTRAN, and assembly language. A typical PL/M compiler procedure is shown in Table 1.

## Features

Major features of the Intel PL/M-80 compiler and programming language include:
Resident Operation - on Intellec microcomputer development systems eliminates the need for a large inhouse computer or costly timesharing system.
Object Code Generation - of relocatable and linkable object codes permits PL/M program development and debugging in small modules, which may be easily linked with other modules and/or library routines to form a complete application.

Extensive Code Optimization - including compile time arithmetic, constant subscript resolution, and common subexpression elimination, results in generation of short, efficient CPU instruction sequences.
Symbolic Debugging - fully supported in the PL/M compiler and ICE-85 in-circuit emulators.
Compile Time Options - includes general listing format commands, symbol table listing, cross reference listing, and "innerlist" of generated assembly language instructions.

Block Structure - aids in utilization of structured programming techniques

Access - provided by high level PL/M statements to hardware resources (interrupt systems, absolute addresses, CPU input/output ports).

Data Definition - enables complex data structures to be defined at a high level.

Re-entrant Procedures - may be specified as a user option.

## Benefits

PL/M is designed to be an efficient, cost-effective solution to the special requirements of microcomputer software development as illustrated by the following benefits of PL/M use:
Low Learning Effort - even for the novice programmer, because PL/M is easy to learn.

Earlier Project Completion - on critical projects, because PL/M substantially increases programmmer productivity while reducing program development time.
Lower Development Cost - because increased programmer productivity requiring less programming resources for a given function translates into lower software development costs.
Increased Reliability - because of PL/M's use of simple statements in the program algorithm, which are easier to correct and thus substantially reduce the risk of costly errors in systems that have already reached full production status.

Easier Enhancement and Maintenance - because programs written in PL/M are easier to read and easier to understand than assembly language, and thus are easier to enhance and maintain as system capabilities expand and future products are developed.


Figure 1. Program Development Cycle Block Diagram

Simpler Project Development - because the Intellec microcomputer development system with resident PL/M-80 is all that is needed for developing and debug-
ging software for 8080 and 8085 microcomputers, and the use of expensive (and remote) timesharing or large computers is consequently not required.

|  |  | ```$OBJECT(:F1:FACT.OB2) $DEBUG $XREF $TITLE('FACTORIAL GENERATOR - PROCEDURE') $PAGEWIDTH(80)``` |
| :---: | :---: | :---: |
| 1 |  | FACT: DO; |
| 2 | 1 | DECLARE NUMCH BYTE PUBLIC; |
| 3 | 1 | FACTORIAL: PROCEDURE (NUM,PTR) PUBLIC; |
| 4 | 2 | DECLARE NUM BYTE, PTR ADDRESS; |
| 5 | 2 | DECLARE DIGITS BASED PTR (161) BYTE; |
| 6 | 2 | DECLARE (I,C,M) BYTE; |
| 7 | 2 | $\mathrm{NUMCH}=1 ; \mathrm{DIGITS}(1)=1$; |
| 9 | 2 | DO M = 1 TO NUM; |
| 10 | 3 | $\mathrm{C}=0$; |
| 11 | 3 | DO I=1 TO NUMCH; |
| 12 | 4 | DIGITS(I) = DIGITS(I)* ${ }^{*}+\mathrm{C}$; |
| 13 | 4 | C = DIGITS(I)/10; |
| 14 | 4 | DIGITS(I) = DIGITS(I) - 10*C; |
| 15 | 4 | END; |
| 16 | 3 | IF $\mathrm{C}<>0$ THEN |
| 17 | 3 | DO; |
| 18 | 4 | NUMCH = NUMCH + 1; DIGITS(NUMCH) = C; |
| 20 | 4 | C = DIGITS(NUMCH)/10; |
| 21 | 4 | DIGITS(NUMCH) = DIGITS(NUMCH) - 10*C; |
| 22 | 4 | END |
|  |  | END; |
| 24 | 2 | END FACTORIAL; |
| 25 | 1 | END; |

Table 1. PL/M-80 Compiler Sample Factorial Generator Procedure

## SPECIFICATIONS

## Operating Environment

Required Hardware
Intellec microcomputer development system
65K bytes of memory
Dual diskette drives
System console - teletype
Optional Hardware
CRT as system console
Line printer
Required Software - ISIS-II diskette operating system

## Shipping Media

Diskette

## Reference Manuals

980026 - PL/M-80 Programming Manual (SUPPLIED)
9800300 - ISIS-II PLM-80 Compiler Operator's Manual (SUPPLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

## Product Code Description

MDS-PLM High level language compiler

MDS-311

## 8086 SOFTWARE DEVELOPMENT PACKAGE

## PL/M-86 high level programming language

ASM86 assembler for 8086 assembly language programming

## CONV86 converter for conversion of 8080/8085 assembly language source code to 8086 assembly language source code

## LINK86, LOC86 and QRL86 link and relocation utilities

## OH86 object-to-hexadecimal converter

 LIB86 library managerThe 8086 software development package provides a set of software development tools for the 8086 microprocessor and iSBC 86/12 single board computer. The package operates under the ISIS-II operating system on Intellec ${ }^{\circledR}$ Microcomputer Development Systems-Model 800 or Series II-thus minimizing requirements for additional hardware or training for Intel Microcomputer Development System users.

The package permits $8080 / 8085$ users to efficiently convert existing programs into 8086 object code from either 8080/8085 assembly language source code or PL/M-80 source code.

For the new Intel Microcomputer Development System user, the package operating on an Intellec Model 230 Microcomputer Development System provides total 8086 software development capability.


# PL/M-86 HIGH LEVEL PROGRAMMING LANGUAGE 

## Sophisticated new compiler design allows user to achieve maximum benefits of $\mathbf{8 0 8 6}$ capabilities <br> Language is upward compatible from PL/M-80, assuring MCS ${ }^{\text {TM }}$.80/85 design portability

## Supports 16-bit signed integer and 32-bit floating point arithmetic

## Produces relocatable and linkable object code

Supports full extended addressing features of the $\mathbf{8 0 8 6}$ microprocessor

Sophisticated code optimization assures efficient code generation and minimum application memory utilization


#### Abstract

Like its counterpart for MCS ${ }^{T M}-80 / 85$ program development, PLM-86 is an advanced structured high level programming language. PL/M-86 is a new compiler created specifically for performing software development for the Intel ${ }^{(0)} 8086$ Microprocessor. PL/M-86 has significant new capabilities over PL/M-80 that take advantage of the new facilities provided by the 8086 microprocessor, yet the PL/M-86 language remains downward compatible with PL/M-80. With the exception of interrupts, hardware flags, and time-critical code sequences, PL/M-80 programs may be recompiled under PL/M-86 with little or no conversion required. PL/M-86, like PL/M-80, is easy to learn, facilitates rapid program development, and reduces program maintenance costs. PL/M is a powerful, structured high level algorithmic language in which program statements can naturally express the program algorithm. This frees the programmer to concentrate on the system implementation without concern for burdensome details of assembly language programming (such as register allocation, meanings of assembler mnemonics, etc.).

The PL/M-86 compiler efficiently converts free-form PL/M language statements into equivalent 8086 machine instructions. Substantially fewer PLM statements are necessary for a given application that if it were programmed at the assembly language or machine code level.

Since PL/M programs are implementation problem oriented and more compact, use of PLM results in a high degree of engineering productivity during project development. This translates into significant reductions in initial software development and follow-on maintenance costs for the user.


## FEATURES

Major features of the Intel PL/M-86 compiler and programming language include:

## - Supports Five Data Types

- Byte: 8-bit unsigned number
- Word: 16-bit unsigned number
- Integer: 16-bit signed number
- Real: 32-bit floating point number
- Pointer: 16-bit or 32-bit memory address indicator
- Two Data Structuring Facilities
- Array: Indexed list of same type data elements
- Structure: Named collection of same or different type data elements
- Combinations of Each: Arrays of structures or structures of arrays


## - Block Structure

- Permits use of structured programming techniques
- Relocatable and Linkable Object Code
- Permits PL/M-86 programs to be developed and debugged in small modules. These modules can be easily linked with other modules and/or library routines to form a complete application system.
- Built-In String Handling Facilities
- Operates on byte strings or word strings
- Six Functions: MOVE, COMPARE, TRANSLATE, SEARCH, SKIP, and SET
- Automatic Support for $\mathbf{8 0 8 6}$ Extended Addressing
- Three compiler options offer a separate model of computation for programs from 128 K bytes to 1-Megabyte in size
- Language transparency for extended addressing
- Support for ICE-86 ${ }^{\text {TM }}$ and Symbolic Debugging
- Debug option for inclusion of symbol table in object modules for In-Circuit Emulation with symbolic debugging
- Numerous Compiler Options
- A host of 26 compiler options including:
- Conditional compilation
- Included file or copy facility
- Two levels of optimization
- Intra-module and inter-module cross reference
- Arbitrary placement of compiler and user files on any available combination of disk drives
- Reentrant and Interrupt Procedures
- May be specified as user options


## BENEFITS

PL/M-86 is designed to be an efficient, cost-effective solution to the special requirements of 8086 Microcomputer Software Development, as illustrated by the following benefits of PL/M-86 use:

- Low Learning Effort - PLM-86 is easy to learn and to use, even for the novice programmer.
- Earlier Project Completion - Critical projects are completed much earlier than otherwise possible because PL/M-86, a structured high-level language, increases programmer productivity.
- Lower Development Cost - Increases in programmer productivity translate immediately into lower software development costs because less programming resources are required for a given programmed function.
- Increased Reliability - PLM-86 is designed to aid in the development of reliable software (PL/M-86 programs are simple statements of the program algorithm). This substantially reduces the risk of costly correction of errors in systems that have already reached full production status, as the more simply stated the program is, the more likely it is to perform its intended function.
- Easier Enhancements and Maintenance - Programs written in PL/M tend to be self-documenting, thus easier to read and understand. This means it is easier to enhance and maintain PL/M programs as the system capabilities expand and future products are developed.
- Simpler Project Development - The Intellec ${ }^{\circledR}$ Development Systems offer a cost-effective hardware base for the development of 8086 designs. PL/M-86 and other elements of ISIS-II and the 8086 Software Development Package are all that is needed for development of software for the 8086 microcomputer and iSBC $86 / 12$ single board computer. This further reduces development time and costs because expensive (and remote) time sharing of large computers is not required. Present users of Intel Intellec ${ }^{\circledR}$ Development Systems can begin to develop 8086 designs without expensive hardware reinvestment or costly retraining.


## SAMPLE PROGRAM

STATISTICS: DO;
/*The procedure in this module computes the mean and variance of an array of data, $X$, of length $\mathrm{N}+1$, according to the method of Kahan and Parlett (University of California, Berkeley, Memo no. UCB/ERL M77/21.*/

STAT: PROCEDURE(X\$PTR,N,MEAN\$PTR,VARIANCE\$PTR) PUBLIC;
DECLARE (X\$PTR,MEAN\$PTR,VARIANCE\$PTR) POINTER, X BASED X\$PTR (1) REAL,
N INTEGER,
MEAN BASED MEAN\$PTR REAL,
VARIANCE BASED VARIANCE\$PTR REAL, (M,Q,DIFF) REAL, I INTEGER;
$M=X(0)$;
$\mathrm{Q}=0.0$;
DO I=1 TO N;
DIFF $=X(I)-M$;
$M=M+D I F F / F L O A T(I+1) ;$
$Q=Q+\operatorname{DIFF}^{*} \operatorname{DIFF}^{*} \operatorname{FLOAT}(I) / F L O A T(I+1) ;$
END;
MEAN $=M$;
VARIANCE $=$ Q/FLOAT $(N)$;
END STAT;
END STATISTICS;

## ASM86 ASSEMBLER

## A new assembler that encourages welldesigned and well-structured programs

Powerful "EQU" (equate) facility allows complex expressions to be represented as a single symbol


#### Abstract

ASM86 is highly mnemonic and compact, with most mnemonics representing several distinct machine instructions


## Enhanced data handling capabilities

Fully detailed set of error messages

The 8086 assembly language is "strongly typed". This means it performs extensive checks on the usage of variables and labels. The assembler uses the attributes which are derived explicitly when a variable or label is first declared, then makes sure that each use of a symbol in later instructions conforms to the usage defined for that symbol when it was declared.

Compared to earlier assemblers, ASM86 supports substantially improved flexibility in data definition and manipulation:

```
-RECORDS
-PROCEDURES
-ARRAYS
```

Its capabilities allow very sophisticated goals and significantly simplified coding to be achieved with a straightforward use of the language.

For example a data RECORD smaller than a word may be defined as a collection of named bit-fields and operators for manipulating these subfields are automatically defined when the record is declared. Bit-fields within a record may be referenced directly by name.

Powerful string manipulation instructions permit direct transfers to or from memory or the accumulator. They can be prefixed with a repeat operator for repetitive execution with a count-down and a condition test. These operations automatically decrement or increment the relevant indexes to memory, depending on the direction flag.

The assembler fully supports the 8086 addressing modes by providing for complex address expressions involving base and index registers and field offsets. A powerful EQU facility allows the use of simplified synonyms for complicated expressions which may occur throughout a module.

The 8086 assembly language includes approximately 100 instruction mnemonics. From these few mnemonics, the assembler can generate over 3,800 distinct machine instructions. These instructions are differentiated by the assembler's ability to evaluate the "TYPE" of the operands to the instruction and then generate the proper machine instruction. ASM86 will generate the shortest machine instruction possible given no forward referencing or given explicit information as to the characteristics of the forward referenced symbol.
ASM86 provides a detailed set of error messages which may appear both in the regular list file and the error print file. As a debugging feature, the list file may include a detailed listing of the user symbol table.
ASM86 allows the user power and flexibility, and is fully compatible with LINK86, LOC86, QRL86 and LIB86.The ASM86 operator's manual includes details on linking ASM86 programs with programs written in PL/M-86.
ASM86 implements directives which reflect the high level orientation of the 8086 architecture.
ASM86 assembles code significantly faster than ASM80 V2.0.

## CONV 86

## MCS-80/85 to MCS-86 ASSEMBLY LANGUAGE CONVERTER UTILITY PROGRAM

## Translates 8080/8085 Assembly Language Source Code to 8086 Assembly Language Source Code

 Provides a fast and accurate means toconvert $8080 / 8085$ programs to the 8086,
facilitating program portability.

## Automatically generates proper ASM-86 directives to set up a "virtual 8080" environment that is compatible with PL/M. 86 .

In support of Intel's commitment to software portability, CONV86 is offered as a tool to move 8080/8085 programs to the 8086. A comprehensive manual, "MCS-86 Assembly Language Converter Operating instructions for ISIS-II Users" (9800642), covers the entire conversion process. Detailed methodology of the conversion process is fully described therein.
CONV86 will accept as input an error-free 8080/8085 assembly-language source file and optional controls, and produce as output, optional PRINT and OUTPUT files.
The PRINT file is a formatted copy of the $8080 / 8085$ source and 8086 source file with embedded caution messages. The OUTPUT file is an 8086 source file.

CONV86 issues a caution message when it detects a potential problem in the converted 8086 code.
A transliteration of the $8080 / 8085$ programs occurs, with each $8080 / 8085$ construct mapped to its exact 8086 counterpart:

> -Registers
> -Condition flags
> -Instructions
> -Operands
> - Assembler directives
> -Assembler control lines

Because CONV86 is a transliteration process, there is the possibility of as much as a $15 \%-20 \%$ code expansion over the $8080 / 8085$ code. For compactness and efficiency it is recommended that critical portions of programs be re-coded in 8086 assembly language.
Also, as a consequence of the transliteration, some manual editing may be required for converting instruction sequences dependent on:
-instruction length, timing, or encoding
-interrupt processing
-PLIM parameter passing conventions $\}$
mechanical editing procedures
for these are suggested in the converter manual.

The set directive, macro definitions, macro calls, and conditional assembly directives are not supported by Version V1.0 of the 8086 Assembler. Appendix F of the MCS-86 Assembly Language Converter Operating Instructions for ISISII Users contains instructions for converting 8080/8085 programs containing these features, by using the macro expansion printed in the 8080/8085 assembler listing.
The accompanying diagram illustrates the flow of the conversion process. Initially, the abstract program may be represented in 8080/8085 or 8086 assembly language to execute on that respective target machine. The conversion process is porting a source destined for the $8080 / 8085$ to the 8086 via CONV86.


## LINK86

# Automatic generation of a summary map giving results of the LINK86 process 

Abbreviated control syntax

Relocatable modules may be merged into a single module suitable for inclusion in a library

Supports "incremental" linking


#### Abstract

LINK86 combines object modules specified in the LINK86 input list into a single output module. LINK86 combines segments from the input modules according to the order in which the modules are listed. Support for incremental linking is provided since an output module produced by LINK86 can be an input to another link. At each stage in the incremental linking process, unneeded public symbols may be purged. LINK86 will link any valid set of input modules without any controls. However, controls are available to control the output of diagnostic information in the LINK86 process and to control the content of the output module. LINK86 allows the user to create a large program as the combination of several smaller, separately compiled modules. After development and debugging of these component modules the user can link them together, locate them using LOC86, and enter final testing with much of the work accomplished.


## LOC86

## Automatic and independent relocation of segments. Segments may be relocated to best match users memory configuration

Extensive debug symbol manipulation, allowing line numbers, local symbols, and public symbols to be purged and listed selectively

Automatic generation of a summary map giving starting address, segment addresses and lengths, and debug symbols and their addresses
Extensive capability to manipulate the order and placement of segments in 8086 memory

## Abbreviated control syntax

Relocatability allows the programmer to code programs or sections of programs without having to know the final arrangement of the object code in memory.
LOC86 converts relative addresses in an input module to absolute addresses. LOC86 orders the segments in the input module and assigns absolute addresses to the segments. The sequence in which the segments in the input module are assigned absolute addresses is determined by their order in the input module and the controls supplied with the command.

LOC86 will relocate any valid input module without any controls. However, controls are available to control the output of diagnostic information in the LOC86 process, to control the content of the output module, or both.
The program you are developing will almost certainly use some mix of random access memory (RAM), read-only memory (ROM), and/or programmable read-only memory (PROM). Therefore, the location of your program affects both cost and performance in your application. The relocation feature allows you to develop your program on the Intellec development system and then simply relocate the object code to suit your application.

## QRL86

Combination linkage and relocation tool

Combines object modules and converts relative addresses to absolute addresses in a single step

QRL86 can be used for quick turnaround during development, whereas the extra capabilities of LINK86 and LOC86 may be needed to finalize the product at the end of development

QRL86 purges unsatisfied externals while LINK86 and LOC86 allow them to be kept for future processing

QRL86 provides $\mathbf{2 5 \%}$ faster turnaround than LINK86 and LOC86, but does not have as wide a range of controls:

- Incremental linking
- Selective purge of publics

QRL86 controls give the capability of changing the order and placement of segments in memory

[^29]
## OH86

OH86 command converts an 8086 absolute object module to symbolic hexadecimal format

Facilitates preparing a file for later loading by a symbolic hexadecimal loader, such as the iSBC Monitor or Universal PROM Mapper

Converts an absolute module to a more readable format that can be displayed on a CRT or printed for debugging

[^30][^31]
## LIB86

LIB86 is a library manager program which allows you to:

- Create specially formatted files to contain libraries of object modules
- Maintain these libraries by adding or deleting modules
- Print a listing of the modules and public symbols in a library file

Libraries can be used as input to QRL86 or LINK86 which will automatically link modules from the library that satisfy external references in the modules being linked

Libraries aid in the job of building programs. The library manager program, LIB86, creates and maintains files containing object modules. The operation of LIB86 is controlled by commands to indicate which operation LIB86 is to perform. The commands are:

CREATE - creates an empty library file
ADD - adds object modules to a library file
DELETE - deletes modules from a library file
LIST - lists the module directory of library files
EXIT - terminates the LIB86 program and returns control to ISIS-II


## SPECIFICATIONS

## Operating Environment

Required Hardware
Intellec ${ }^{\circledR}$ Microcomputer Development System

- MDS-800, MDS-888
- Series II

64K Bytes of RAM Memory
Dual Diskette Drives

- Single or Double* Density

System Console

- CRT or Hardcopy Interactive Device


## Optional Hardware

Universal PROM Programmer
Line Printer*
ICE-86 ${ }^{\text {TM * }}$

## Required Software

ISIS-II Diskette Operating System

- Single or Double* Density
*Recommended


## Documentation Package

PL/M-86 Programming Manual (9800466)
ISIS-II PL/M-86 Compiler Operator's Manual (9800478)
MCS ${ }^{\text {TM }}$ - 86 User's Manual (9800694)
MCS-86 Software Development Utilities Operating Instructions for ISIS-II Users (9800639)
MCS-86 Assembly Language Reference Manual (9800640)
MCS-86 Assembler Operating Instructions for ISIS-II Users (9800641)
MCS-86 Assembly Language Converter Operating Instructions for ISIS-II Users (9800642)
MCS-86 Absolute Object File Formats (9800821)
Universal PROM Programmer User's Manual (9800819A)

## Flexible Diskettes

- Single and Double* Density


## FORTRAN-80 8080/8085 ANS FORTRAN 77 INTELLEC® ${ }^{\text {RESIDENT COMPILER }}$

## Meets and exceeds ANS FORTRAN 77 Subset Language Specification

Supports Intel Floating Point Standard with either the floating point support library or the iSBC-310 High Speed Mathematics Board
Resident operation on Intellec ${ }^{\circledR}$
Microcomputer Development System and Intellec ${ }^{\circledR}$ Series II Microcomputer Development System
Supports full symbolic debugging with ICE-80 ${ }^{\text {TM }}$ and ICE-85 ${ }^{\text {TM }}$

## Produces relocatable and linkable object code compatible with resident PL/M-80 and 8080/8085 Macro Assembler

## Full FORTRAN 77 language I/O support or optional RMX-80 run-time library

## Well defined I/O interface for configuration with user-supplied drivers

## Sophisticated code optimization insures efficient program implementation

FORTRAN-80 is a computer industry-standard, high-level programming language and compiler that translates FORTRAN statements into relocatable object modules. When the object modules are linked together and located into absolute program modules, they are suitable for execution on Intel ${ }^{\circledR}$ 8080/8085 Microprocessors, iSBC-80 OEM Computer Systems, and Intellec ${ }^{\text {® }}$ Microcomputer Development Systems. FORTRAN-80 meets and exceeds the ANS FORTRAN 77 Language Subset Specification ${ }^{1}$. The compiler operates on the Intellec Microcomputer Development System under the ISIS-II Disk Operating Systems and produces efficient relocatable object modules that are compatible for linkage with PLM-80 and 8080/8085 Macro Assembler modules.
The ANS FORTRAN 77 language specification offers many powerful extensions to the FORTRAN language that are especially well suited to Intel ${ }^{\circledR}$ 8080/8085 Microprocessor software development. Because FORTRAN-80 conforms to the ANS FORTRAN 77 standard, the user is assured of compatibility with existing FORTRAN software that meets the standard as well as a guarantee of upward compatibility to other computer systems supporting an ANS FORTRAN 77 Compiler.
${ }^{1}$ ANSI X3J3/90


## FORTRAN-80 LANGUAGE FEATURES

Major ANS FORTRAN 77 features supported by the Intel ${ }^{\oplus}$ FORTRAN-80 Programming Language include:

- Structured Programming is supported with the IF ... THEN ... ELSE IF ... ELSE ... END IF constructs.
- CHARACTER data type permits alphanumeric data to be handled as strings rather than characters stored in array elements.
- Full I/O capabilities include:
- Sequential and Direct Access files
- Error handling facilities
- Formatted, Free-formatted, and Unformatted data representation
- Internal (in-memory) file units provide capability to format and reformat data in internal memory buffers
- List Directed Formatting
- Supports arrays of up to seven dimensions.
- Supports logical operators
.EQV. - Logical equivalence
.NEQV. - Logical nonequivalence
Major extensions to FORTRAN 77 in Intel FORTRAN- 80 include:
- Direct 8080/8085 port I/O supported by intrinsic subroutines.
- Binary and Hexadecimal integer constants.
- Well defined interface to FORTRAN-80 I/O statements (READ, OPEN, etc.), allowing easy use of user-supplied I/O drivers.
- User-defined INTEGER storage lengths of 1,2 or 4 bytes.
- User-defined LOGICAL storage lengths of 1,2 or 4 bytes.
- REAL STORAGE lengths of 4 bytes.
- Bitwise Boolean operations using logical operators on integer values.
- Hollerith data constants.
- Implicit extension of the length of an integer or logical expression to the length of the left-hand side in an assignment statement.
- A format descriptor to suppress carriage return on a terminal output device at the end of the record.


## FORTRAN-80 COMPILER FEATURES

- Supports multiple compilation units in single source file.
- Optional Assembly Language code listing.
- Comprehensive cross-reference, symbol attribute and error listing.
- Compiler controls and directives are compatible with other Intel language translators.
- Optional Reentrancy.
- User-defined default storage lengths.
- Optional FORTRAN 66 Do Loop semantics.
- Source files may be prepared in free format.
- The INCLUDE control permits specified source files to be combined into a compilation unit at compile time.
- Transparent interface for software and hardware floating point support, allowing either to be chosen at time of linking.


## FORTRAN-80 BENEFITS

FORTRAN-80 provides a means of developing application software for Intel ${ }^{(0}$ MCS-80/85 products in a familiar, widely accepted, and computer industrystandardized programming language. FORTRAN-80 will greatly enhance the user's ability to provide costeffective solutions to software development for Intel microprocessors as illustrated by the following:

- Completely Complementary to Existing Intel Software Design Tools - Object modules are linkable with new or existing Assembly Language and PL/M Modules.
- Incremental Runtime Library Support - Runtime overhead is limited only to facilities required by the program.
- Low Learning Effort - FORTRAN-80, like PL/M, is easy to learn and use. Existing FORTRAN software can be ported to FORTRAN-80, and programs developed in FORTRAN-80 can be run on any other computer with ANS FORTRAN 77.
- Earlier Project Completion - Critical projects are completed earlier than otherwise possible because FORTRAN-80 will substantially increase programmer productivity, and is complementary to PL/M Modules by providing comprehensive arithmetic, //O formatting, and data management support in the language.
- Lower Development Cost - Increases in programmer productivity translates into lower software development costs because less programming resources are required for a given function.
- Increased Reliability - The nature of high-level languages, including FORTAN-80, is that they lend themselves to simple statements of the program algorithm. This substantially reduces the risk of costly errors in systems that have already reached production status.
- Easier Enhancements and Maintenance - Like PL/M, program modules written in FORTRAN-8C are easier to read and understand than assembly language. This means it is easier to enhance and maintain FORTRAN-80 programs as system capabilities expand and future products are developed.
- Comprehensive, Yet Simple Project Development - The Intellec Microcomputer Development System, with the 8080/8085 Macro Assembler, PL/M-80 and FORTRAN-80 is the most comprehensive software design facility available for the intel MCS-80/85 Microprocessor family. This reduces development time and cost because expensive (and remote) timesharing or large computers are not required.


## SAMPLE FORTRAN-80 SOURCE PROGRAM

## LISTING

```
* ** THIS PROGRAM IS AN EXAMPLE OF ISIS-II FORTRAN-80 THAT
* ** CONVERTS TEMPERATURE BETWEEN CELSIUS AND FARENHEIT
    PROGRAM CONVRT
    CHARACTER*1 CHOICE, SCALE
    PRINT 100
    ** ENTER CONVERSION SCALE (C OR F)
    PRINT 200
    READ (5,300) SCALE
        IF (SCALE .EQ. 'C')
    + THEN
        PRINT 400
        ** ENTER THE NUMBER OF DEGREES FARENHEIT
            READ (5,*) DEGF
            DEGC = 5./9.*(DEGF-32)
            ** PRINT THE ANSWER
            WRITE (6,500) DEGF,DEGC
            ** RUN AGAIN?
            PRINT 600
            READ (5,300) CHOICE
                IF (CHOICE .EQ. 'Y')
                THEN
                    GOTO 10
            ELSE IF (CHOICE .EQ. 'N')
                    THEN
                            CALL EXIT
                ELSE
                                    GOTO 20
                END IF
        ELSE IF (SCALE .EQ. 'F')
    + THEN
            ** CONVERT FROM FARENHEIT TO CELSIUS
            PRINT 700
            READ (5,*) DEGC
            DEGF = 9./5.*DEGC+32.
            ** PRINT THE ANSWER
            WRITE (6,800) DEGC,DEGF
            GOTO 20
        ELSE
            ** NOT A valid ENTRY FOR THE SCALE
            WRITE (6,900) SCALE
            GOTO 10
        END IF
100 FORMAT(' TEMPERATURE CONVERSION PROGRAM',//,
    +' TYPE C FOR FARENHEIT TO CELSIUS OR',/,
    +' TYPE F FOR CELSIUS TO FARENHEIT',//)
        FORMAT(/,' CONVERSION? ',$)
        FORMAT(A1)
    FORMAT(/,'ENTER DEGREES FARENHEIT: ',$)
    FORMAT(/,F7.2, DEGREES FARENHEIT = ',F7.2,' DEGREES CELSIUS·)
    FORMAT(/,' AGAIN (Y OR N)? ',$)
    FORMAT(/,' ENTER DEGREES CELSIUS: ',$)
    FORMAT(/,F7.2,' DEGREES CELSIUS = ',F7.2,' DEGREES FARENHEIT',/)
    FORMAT(/,1H ,A1,' NOT A VALID CHOICE - TRY AGAIN!',/)
    END
```

The FORTRAN-80 Compiler is an efficient, multiphase compiler that accepts source programs, translates them into relocatable object code, and produces requested listings. After compilation, the object program may be linked to other modules, located to a specific area of memory, then executed. The diagram shown below illustrates a program development cycle where the program consists of modules created by FORTRAN-80, PL/M-80 and the $8080 / 8085$ Macro Assembler.


## SPECIFICATIONS

## OPERATING ENVIRONMENT

Required Hardware:
Intellec ${ }^{\circledR}$ Microcomputer Development System

- MDS-800, MDS-888
- Series II Model 220, Model 230

64 K bytes of RAM memory
Dual diskette drives

- Single or Double Density

System console

- CRT or hardcopy interactive device

Optional Hardware:
Line Printer
ICE-80 ${ }^{\text {TM }}$, ICE- $85^{\text {TM }}$

Required Software:
ISIS-II Diskette Operating System

- Single or Double Density

Optional Software:
iSBC-801 FORTRAN-80 Run-Time Software Package for RMX-80

## DOCUMENTATION PACKAGE

FORTRAN-80 Programming Manual (9800481)
ISIS-II FORTRAN-80 Compiler Operator's Manual (9800480)

FORTRAN-80 Programming Reference Card (9800547)
SHIPPING MEDIA
Flexible Diskettes

- Single and Double Density

[^32]
## BASIC-80 <br> EXTENDED ANS 1978 BASIC INTELLEC ${ }^{\circledR}$ RESIDENT INTERPRETER

Meets ANS 1978 standard for minimal BASIC and adds many powerful extensions

Operates under the ISIS-II operating system on Intellec and Intellec Series-II Microcomputer Development Systems

## Full sequential and random disk file I/O with ISIS-II

Applications range from prototyping microcomputer software to inexpensive engineering and management problem solving on the Intellec systems

Supports the Intel floating point standard and provides integer and string data types

Can call user subroutines written in FORTRAN-80, PL/M-80, and 8080/85 macro assembler that are resident in the Intellec memory

Easily learned language and interactive environment combine to provide a flexible and powerful facility for developing programs to run on the Intellec Microcomputer Development Systems

BASIC is an industry standard, high-level programming language which is designed to be easily learned and used by novices and experienced programmers alike. The interpreter provides an interactive environment which allows fast and easy program development, testing, and debugging. BASIC is widely used for problem solving in engineering and management; extensive software exists for business applications such as order entry, accounts receivable, accounts payable, and inventory control, and engineering applications such as numeric and statistical analysis.

Intel's BASIC-80 meets the standards of ANS 1978 BASIC and extends them to take advantage of the software development capabilities of the Intellec Microcomputer Development Systems. The matching of these resources with the ease of programming in BASIC-80 provides a very effective tool for both microprocessor systems development and inexpensive applications programming and problem solving on the Intellec systems.


## BASIC-80 LANGUAGE FEATURES

Standard ANS 78 BASIC features, all supported by BASIC-80, include:

- String and numeric constants, variables, and arrays.
- FOR...TO...STEP... NEXT statements for loop execution.
- IF ... THEN statements for conditional execution.
- ON . . . GOTO statements for computed branching.
- GOSUB/RETURN subroutine calls and returns.
- Built in scientific functions:

| ABS | RND | TAN |
| :--- | :--- | :--- |
| EXP | SGN | COS |
| INT | SQR | SIN |
| LOG | ATN |  |

- User defined single statement functions.

Major extensions to ANS 78 BASIC which BASIC-80 provides include:

- Support for the Intel single and double precision floating point standard.
- Disk file I/O, supporting both random access and sequential access files.
- Direct read and write to CPU I/O ports through the INP and OUT functions.
- Direct memory read and write through the PEEK and POKE functions.
- Calls to user-supplied external subroutines, which may have been written in FORTRAN-80, PLM-80, or 8080/8085 Assembly Language and have been located at absolute memory locations using the ISIS-II facilities.
- User directed error trapping and handling functions.
- Program execution trace command.
- Formatted print statement with the PRINT USING function.
- ELSE clause for IF . . . THEN statements.
- Matrices with up to 110 dimensions.
- Extensive string manipulation functions.
- Boolean operators.
- Type conversion functions-integer, floating point, and character.


## BENEFITS OF BASIC-80

- Added Value to the Intellec Systems-with BASIC-80 the Intellec Microcomputer Development Systems can be effectively used in many engineering and management applications.
- Inexpensive and Accessible Computational Facilitythe ease of use and flexibility inherent in BASIC-80 and its interpretive environment fit well with the "at hand" computational resources of the Intellec systems. The combination is a particularly useful tool for obtaining fast and accurate results.
- Easy to Learn-the language is designed to be easily understood and learned. Results are obtained faster and people who may benefit from using the system can do so easily.
- Aid in Microcomputer Software Design-microcomputer software can be prototyped in BASIC-80 to inexpensively develop and test program logic.
- Complemented by Existing Software-subroutines written in PLM-80, FORTRAN-80, and ASM 8080/85 can be called from BASIC-80 programs.
- Easy to Enhance and Maintain-BASIC-80, being straightforward and easily understood, provides for programs that are easy to maintain and modify in the future.


## SPECIFICATIONS

## Operating Environment

## Required Hardware:

Intellec Microcomputer Development System

- MDS-800, MDS-888
- Series-II Model 220, Model 230

48 K bytes of RAM memory
Diskette drive

- Single or double density

System console

- CRT or hard copy interactive device


## Optional Hardware:

Line printer
Additional diskette drive

## Required Software:

ISIS-II Diskette Operating System

- Single or double density


## Documentation Package:

Basic-80 Reference Manual (9800758A)
Basic-80 Programming Reference Card (9800774)

## Shipping Media:

Flexible diskettes

- Single and double density


## EXAMPLE BASIC-80 PROGRAM

```
list
l0 PRINT "THIS PROGRAv CALCULATES THE MEAN AND STANDARD"
20 PRINT " DEVIATION OF INPUT DATA"
30 S=\emptyset:V=\emptyset
4\emptyset INPUT "NUMBER OF VALUES";N
50 FOR I=l TO N
60 INPUT A(I)
70 S=S+A(I)
80 NEXT
90 S=S/N
100 REM CALCULATION OF VARIANCE
110 FOR I=1 TO N
120 V = V+(A(I) -S )}\mp@subsup{}{}{\prime}2/\textrm{N
130 NEXT
140 SD=SQR(V)
150 PRINT "MEAN=";S
160 PRINT "STANDARD DEVIATION IS=";SD
Ok
run
THIS PROGRAM CALCULATES THE MEAN AND STANDARD
        DEVIATION OF INPUT DATA
NUMBER OF VALUES? }
? 34.7
? 32.9
? 38.2
? 35
? 37.6
? 40.9
MEAN= 36.55
STANDARD DEVIATION IS= 2.642442
Ok
```


## ORDERING INFORMATION

## Product Code Description

MDS-320
ISIS-II BASIC-80
Disk-Based Interpreter

INTELLEC® ${ }^{\circledR}$ SINGLE/DOUBLE DENSITY FLEXIBLE DISK SYSTEM

Flexible Disk system providing high speed Input/Output and data storage for Intellec Microcomputer Development Systems

Available in both single density and double density systems

Data recorded on single density flexible disk is in IBM soft-sectored format which allows $1 / 4$ million byte data capacity with up to 200 files per flexible disk

Data recorded on double density flexible disk is in soft-sectored format which allows $1 / 2$ million byte data capacity with up to 200 files per flexible disk

Associated software supports up to four double density drives and two single density drives, providing up to 2.5 Megabytes of storage in one system

Dynamic allocation and deallocation of flexible disk sectors for variable length files

[^33]

## HARDWARE

The Intellec ${ }^{\circledR}$ flexible disk system provides direct access bulk storage, intelligent controller, and two flexible disk drives. Each single density drive provides $1 / 4$ million bytes of storage with a data transfer rate of 250,000 bits/second. The double density drive provides $1 / 2$ million bytes of storage with a data transfer rate of $500,000 \mathrm{bits} /$ second. The controllers are implemented with Intel's powerful Series 3000 Bipolar Microcomputer Set. The controllers provide interface to the Intellec System bus. Each single density controller will support two drives. Each double density controller will support up to four drives. The flexible disk system records all data in soft sector format.
The single/double density flexible disk controllers each consists of two boards, the Channel Board and the Interface Board. These two printed circuit boards reside in the Intellec System chassis. The boards are shown in the photograph, and are described in more detail in the following paragraphs.


SINGLE/DOUBLE DENSITY CHANNEL BOARD


DOUBLE DENSITY INTERFACE BOARD (SINGLE DENSITY INTERFACE BOARD is Similar to the one shown Above)

## CHANNEL BOARD

The Channel Board is the primary control module within the flexible disk system. The Channel Board receives, decodes, and responds to channel commands from the Central Processor Unit (CPU) in the Intellec system. The Channel Board can access a block of Intellec system memory to determine the particular flexible disk operations to be performed and fetch the parameters required for the successful completion of the specified operation.
The control functions of the Channel Board have been achieved with an 8-bit microprogrammed processor, designed with Intel's Series 3000 Bipolar Microcom-
puter Set. This 8 -bit processor includes four 3002 Central Processing Elements (2-bit slice per CPE), a 3001 Microprogram Control Unit, and $512 \times 32$ bits of 3604 programmable-read-only-memory (PROM) which stores the microprogram. It is the execution of the microprogram by the microcomputer set which actually effects the control capability of the Channel Board.

This board is the same for either single or double density drives, except that the Series 3000 microcode is different.

## INTERFACE BOARD

The Interface Board provides the flexible disk controller with a means of communication with the flexible disk drives, as well as with the Intellec system bus. Under control of the microprogram being executed on the Channel Board, the Interface Board generates those signals which cause the read/write head on the selected drive to be loaded (i.e., to come in contact with the flexible disk platter), cause the head to move to the proper track and verify successful operation. The Interface Board accepts the data being read off the flexible disk, interprets synchronizing bit patterns, checks the validity of the data using a cyclic redundancy check (CRC) polynomial, and then transfers the data to the Channel Board.
During write operations, the Interface Board outputs the data and clock bits to the selected drive at the proper times, and generates the CRC characters which are then appended to the data.
When the flexible disk controller requires access to Intellec system memory, the Interface Board requests the DMA master control of the system bus, and generates the appropriate memory command. The Interface Board also acknowledges I/O commands as required by the Intellec bus.

The Flexible Disk System is capable of performing seven different operations: recalibrate, seek, format track, write data, write deleted data, read data, and verify CRC.

The channel board is different for single and double density drives, due to the different recording techniques used. The single density controller boards support one set of dual single density drives. The double density controller boards support up to two sets of dual double density drives (four drives total).
The double density controller may co-reside with the Intel single density controller to allow conversion of single density flexible disk to double density format, and provide up to 2.5 M bytes of storage.

## FLEXIBLE DISK DRIVE MODULES

Each flexible disk drive consists of read/write and control electronics, drive mechanisms, read/write head, track positioning mechanism, and the removable flexible disk platter. These components interact to perform the following functions:

- Interpret and generate control signals
- Move read/write head to selected track
- Read and write data


## FLEXIBLE DISK SYSTEM

## ASSOCIATED SOFTWARE - INTEL SYSTEMS IMPLEMENTATION SUPERVISOR (ISIS-II)

The Flexible Disk Drive System is to be used in conjunction with the ISIS-II Operating System. ISIS-II provides total file management capabilities, file editing,

## ISIS-II OPERATIONAL ENVIRONMENTAL

 ISIS-II32K bytes RAM memory
48K bytes when using Assembler Macro feature
64 K bytes when using PLM or Fortran
System Console
Single or Double density Flexible Disk Drive
HARDWARE SPECIFICATIONS
MEDIA

Single Density
Flexible Disk

One Recording Surface IBM Soft Sector Format 77 Tracks/Diskette 26 Sectors/Track
128 Bytes/Sector

Double Density
Double Density Specified Flexible Disk
One Recording Surface
Soft Sector Format
77 Tracks/Diskette
52 Sectors/Track
128 Bytes/Sector

## PHYSICAL CHARACTERISTICS <br> CHASSIS AND DRIVES

Mounting:
Height:
Width:
Depth:
Weight:
Table-Top or Standard 19" Retma Cabinet

## ELECTRICAL CHARACTERISTICS

## CHASSIS

DC Power Supplies
Supplied Internal to the Cabinet
AC Power Requirements
3 -wire input with center conductor (earth ground) tied to chassis
Single-phase, 115 VAC; 60 Hz ; 1.2 Amp Maximum (For a Typical Unit)
230 VAC; 50 Hz ; 0.7 Amp Maximum (For a Typical Unit)
FLEXIBLE DISK OPERATING SYSTEM CONTROLLER
DC Power Requirements (All power supplied by Intellec Development System)

CHANNEL BOARD

Single Density
5V @ 3.75A (typ), 5A (max)
5 V @ 3.75A (typ), 5A (max)
INTERFACE BOARD
Single Density
5V @ 1.5A (typ), 2.5A (max)

Double Density
5V @ 1.5A (typ), 2.5A (max) -10V @ 0.1A (typ), 0.2 A (max)
library management, run-time supports, and utility management.
ISIS-II provides automatic implementation of random access disk files. Up to 200 files may be stored on each $1 / 4$ million byte flexible disk for single density system or on each $1 / 2$ million byte flexible disk for double density system. For more information, see the ISIS-II data specification sheet.

## FLEXIBLE DISK DRIVE PERFORMANCE SPECIFICATION

|  | Single <br> Density | Double Density |
| :---: | :---: | :---: |
| Capacity (Unformatted): |  |  |
| Per Disk | 3.1 megabits | 6.2 megabits |
| Per Track | 41 kilobits | 82 kilobits |
| Capacity (Formatted): |  |  |
| Per Disk | 2.05 M bits | 4.10 megabits |
| Per Track | 26.6K bits | 53.2 kilobits |
| Data Transfer Rate | 250 kilobits/ sec | 500 kilobits sec |
| Access Time: |  |  |
| Track-to-Track | 10 ms | 10 ms |
| Head Settling Time | 10 ms | 10 ms |
| Average Random |  |  |
| Positioning Time | 260 ms | 260 ms |
| Rotational Speed | 360 rpm | 360 rpm |
| Average Latency | 83 ms | 83 ms |
| Recording Mode | Frequency | $M^{2} \mathrm{FM}$ |
|  | Modulation |  |

## ENVIRONMENTAL CHARACTERISTICS MEDIA <br> Temperature: <br> Operating: $\quad 15.6^{\circ} \mathrm{C}$ to $51.7^{\circ} \mathrm{C}$ <br> Non-Operating: $5^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}$ <br> Humidity: <br> Operating: $\quad 8$ to $80 \%$ (Wet bulb $29.4^{\circ} \mathrm{C}$ ) <br> Non-Operating: 8 to $90 \%$

DRIVES AND CHASSIS
Temperature:
Operating: $\quad 10^{\circ} \mathrm{C}$ to $38^{\circ} \mathrm{C}$
Non-Operating: $\quad-35^{\circ} \mathrm{C}$ to $65^{\circ} \mathrm{C}$
Humidity:
Operating: $\quad 20 \%$ to $80 \%$ (Wet bulb $26.7^{\circ} \mathrm{C}$ )
Non-Operating: $5 \%$ to $95 \%$
CONTROLLER BOARDS

Operating: $\quad 0$ to $55^{\circ} \mathrm{C}$
Non-Operating: $\quad-55^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
Humidity:
Operating: Up to $95 \%$ relative humidity without condensation
Non-Operating: All conditions without condensation of water or frost

## EQUIPMENT SUPPLIED

SINGLE DENSITY
Cabinet, Power Supplies, Line Cord, Two Drives
Single Density FDC Channel Board
Single Density FDC Interface Board
Dual Auxiliary Board Connector
Flexible Disk Controller Cable
Flexible Disk Peripheral Cable
Hardware Reference Manual
Reference Schematics
ISIS-II Single Density System Disk
ISIS-II System User's Guide

## DOUBLE DENSITY

Cabinet, Power Supplies, Line Cord, Two Drives Double Density FDC Channel Board Double Density FDC Interface Board Dual Auxiliary Board Connector Flexible Disk Controller Cable Flexible Disk Peripheral Cable Hardware Reference Manual Reference Schematics ISIS-II Double Density System Disk ISIS-II System User's Guide

## OPTIONAL EQUIPMENT

| MDS-640 | Rack Mount Kit |
| :--- | :--- |
| MDS-BLD | 10 Blank Flexible Disks |
| MDS-DDR | Second Drive Cabinet with two additional <br> drives |

## ORDERING INFORMATION

## Description

Flexible Disk drive unit with two drives, single density drive controller, software, and cables. Flexible Disk drive unit with two drives, double density drive controller, software, and cables.
Add-on drive unit with two drives and double density cable, without controller and software. Can be used with double density controller.

ISIS-II

## DISKETTE OPERATING SYSTEM MICROCOMPUTER DEVELOPMENT SYSTEM

Supports up to four double density drives and two single density drives, providing up to 2.5 megabytes of storage in one system with up to 200 files per diskette

Relocating MCS-80/MCS-85 macroassembler contains extended macro and conditional assembly capability

Command file facility allows console commands to be submitted from diskette file

Diskette operating system functions callable from user programs

Diskette system text editor provides string search, substitution, insertions, and deletion commands

Supports resident, high level programming languages, PL/M and FORTRAN

Provides dynamic allocation and deallocation of diskette sectors for variable length files

Linker automatically combines separately assembled or compiled programs into single relocatable module

Library manager creates and updates program libraries

Supports all standard Intellec peripherals

Provides access to all Intellec monitor facilities

The ISIS-II Microcomputer Development System Diskette Operating System is a sophisticated, general purpose, high speed data handler and file manipulation system. It provides the ability to edit, assemble, compile, link, relocate, execute, and debug programs, and performs all user file management tasks. The ISIS-II operating system resides on the system diskette and supports a broad range of user oriented design aid software. Total file management and input editing features greatly reduce software development time. The ISIS-II relocating macroassembler, linker, object locator, and library manager may be loaded from the diskette in seconds. All passes of the assembler may be executed without the need for user intervention. Object code and listings may be directed to any output device, or stored as diskette files. Powerful system console commands are provided in an easy to use context. Monitor mode may be entered by a special prefix to any sytem command or program call.


## FUNCTIONAL DESCRIPTION

The ISIS-II operating system resides on the system diskette and supports a broad range of user oriented design aid software. Total file management and input editing features greatly reduce software development time. The ISIS-II relocating macroassembler, linker, object locator, and library manager may be loaded from the diskette in seconds. All passes of the assembler may be executed without the need for user intervention. Object code and listings may be directed to any output device, or stored as diskette files. A diagram of the ISIS-II system program development flow is shown in Figure 1.

## ISIS-II Files

A file is a user defined collection of information of variable length. ISIS-II also treats each of the standard Intellec system peripherals as files through preassignment of unique file names to each device. In this manner data may be copied from one device to another (i.e., tape reader to tape punch) using the same command required to copy one diskette data file to another. ISIS-II provides automatic implementation of random access disk files. Each file is identified by a user chosen name unique on its diskette. Up to 200 files may be stored on each diskette.

## ISIS-II System Commands

ISIS-II system commands are designed to provide the user with a powerful, easy to use program and file manipulation capability. Several commands have the capability of operating on several files at once via the wildcard file naming convention. As an example, the command DELETE $\star$.OBJ deletes all files in the diskette directory with the suffix .OBJ. A summary of ISIS-II system commands is presented in Table 1.

Call Capability - The delete, rename, and attribute assignment commands, along with a set of file I/O routines, are callable from user written programs. This allows the user to open, close, read, and write diskette files, access standard peripheral devices, write error messages, and load other programs via simple program call statements.

| Command | Operation |
| :--- | :--- |
| Initialize <br> disk <br> Attribute <br> assignment | Initializes a diskette for use by the sys- <br> tem. Requires only one disk drive. |
| Assigns specified attributes to a file, |  |
| such as write-protect. |  |
| Delete | Creates copies of existing diskette <br> files or transfers files from one device <br> to another. <br> Removes a file from the diskette, <br> thereby freeing space for allocation of <br> other files. <br> Lists name, size, and attributes of files <br> from a specified diskette directory. <br> Allows diskette files to be renamed. |
| Rename | Initializes a diskette for use by the sys- <br> tem. (Use with two or more drives.) <br> Loads a specified program from a disk- |
| Format into memory and then transfers |  |
| control to the Intellec monitor for exe- |  |
| cution and or debugging. |  |
| Provides capability for executing a |  |
| series of ISIS-II commands previously |  |
| written to a diskette file. |  |

Table 1. ISIS-II System Commands


Figure 1. Program Development Flow Using ISIS-II Disk Operating System

## ISIS-II Text Editor

The ISIS-II text editor is a comprehensive tool for assembly language, PL/M, and FORTRAN program entry and correction for Intel microcomputers. Its command set allows either entire lines of text or individual characters to be manipulated within a line.

Program Entry - Programs may be entered from the console keyboard or may be loaded directly. 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

Utility Commands - 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

Storage - The contents of the workspace are stored on diskette and can be immediately accessed by ISIS-II commands or other programs, such as the ISIS-II MCS-80/MCS-85 macroassembler.

## ISIS-II MCS-80/MCS-85 Relocating Macroassembler

Address Translation - The ISIS-II MCS-80/MCS-85 macroassembler translates assembly language mnemonics into relocatable and/or absolute object code modules. 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. Extended macro capability eliminates the need to rewrite similar sections of code repeatedly, and thus simplifies program documentation. Conditional assembly permits the assembler to include or delete sections of code that may vary from system to system, such as the code required to handle optional external devices. Additionally, the user is allowed complete freedom in assigning the location of code, data, and stack segments.
List File - The ISIS-II Assembler accepts diskette file input and produces a relocatable object file with corresponding symbol table and assembly listing file, including any error messages. A cross reference listing is also
optionally produced. The list file may then be examined from the system console or copied to a specified list device.
Object File - The relocatable object file generated by the assembler may be combined with other object programs residing on the diskette to form a single relocatable object module or it can be converted to an absolute form for subsequent loading and execution.

## ISIS-II Linker

The ISIS-II linker provides the capability to combine the outputs of several independently compiled or assembled object modules (files) into a single relocatable object module. The linker automatically resolves all external program and data references during the linking process. Object modules produced from previous link operations may be easily linked to a new module. ISIS-II also provides facilities to ease the generation of overlays. An optional link map showing the contents and lengths of each segment in the output module can be requested. All unsatisfied external references are also listed. If requested by the user, the ISIS-II linker can search a specified set of program libraries for routines to be included in the output module.

## ISIS-II Object Locator

The ISIS-II locate program takes output from either the resident FORTRAN or PLM compilers, the macroassembler, or the linker and transforms that output from relocatable format to an absolute format which may then be loaded via the standard ISIS-II loader, or loaded into an appropriate in-circuit emulator (ICE) module. During the locate process, code, data, and stack segments may be separately relocated, allowing code to be put in areas to be subsequently specified as ROM, while data and the stack are directed to RAM addresses. A locate map showing absolute addresses for each code and data segment and a symbol table dump listing symbols, attributes, and absolute address may also be requested.

## ISIS-II Library Manager

The ISIS-II Library Manager program provides for the creation and maintenance of a program library containing Intel-provided and user-written programs and subroutines. These library routines may be linked to a program using the ISIS-II linker. Several libraries, each containing its own set of routines, may be created.

## ORDERING INFORMATION

## INTELLEC PROMPT 48 <br> MCS-48 MICROCOMPUTER DESIGN AID

Complete low cost design aid and EPROM programmer for revolutionary MCS-48 single component computers

Simplifies microcomputing, allowing user to enter, run, debug, and save machine language programs with calculator-like ease

Utilizes two removable 8-bit MCS-48 CPUs

- 8748 CPU with erasable, reprogrammable on-chip program memory
- 8035 CPU with off-chip program memory

1K-byte erasable, reprogrammable onchip (8748), expandable program memory, 1K-byte RAM in PROMPT system

64 bytes RAM on-chip, expandable register memory

256 bytes expandable RAM data memory in PROMPT system

## 27 on-chip TTL compatible expandable I/O lines

On-chip clock, internal timerlevent counter, two vectored interrupts, eight level stack control

## Single + 5V DC system power requirement

Integral keyboard and displays (no teletypewriter or CRT terminal required)

Extensive PROMPT 48 monitor, allowing system I/O, bus, and memory expansion

Includes comprehensive design library

The Intellec Prompt 48 MCS-48 Microcomputer Design Aid is a low cost, fully-assembled design aid for the revolutionary 8748 single component microcomputer. PROMPT 48 simplifies the programming of MCS-48 systems - programs may 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 48's panel connector allows easy access to I/O ports and system bus. Thus users can expand program memory beyond the 1 K bytes provided internally.


## FUNCTIONAL DESCRIPTION

"PROMPT" stands for PROgraMming Tool. It is a programmer for 8748 EPROMs, and a versatile aid for debugging MCS-48 programs. Programs can be entered via its integral panel keyboard, programming socket, or serial channel. Almost any terminal can be interfaced to the serial channel, including a teletypewriter, CRT, or an Intellec microcomputer development system. Intellec PROMPT 48 simplifies the programming of MCS-48 systems. Like the 8748 it is radically new, highly integrated, and expandable. Like the MCS-48 family, it is low cost, and ideal for small applications and programs. It is a design aid, not a development system with sophisticated software and peripherals.

## MCS-48 Processors

PROMPT 48 comes complete with two of Intel's revolutionary MCS-48 processors: an $8748-4$ Single Component 8 -Bit Microcomputer and and 8035-4 Single Component 8 -Bit Microcomputer. Advances in n-channel MOS technology allow intel, for the first time to integrate into one 40-pin component all computer functions:
8-bit CPU
$1 \mathrm{~K} \times 8$-bit EPROM/ROM program memory
$64 \times 8$-bit RAM data memory
27 input/output lines
8 -bit timer/event counter
Performance - More than 90 instructions - each one or two cycles - make the single chip MCS-48 equal in performance to most multi-chip microprocessors. The MCS-48 is an efficient controller and arithmetic processor, with extensive bit handling, binary, and BCD arithmetic instructions. These are encoded for minimum program length; $70 \%$ are single byte operation codes, and none is more than two bytes.
Flexibility - Three interchangeable, pin-compatible devices offer flexibility and low cost in development and production, as follows:
8748 - with user-programmable and erasable EPROM program memory for prototype and pre-productions systems.
8048 - with factory-programmed mask ROM memory for low-cost, high volume production.
8035 - without program memory, for use with external program memories.
Circuitry - Each MCS-48 processor operates on a single +5 V supply, with internal oscillator and clock driver, and circuitry for interrupts and resets. Extra circuitry is in the 8048 ROM processor to allow low power standby operation. The $64 \times 8$ RAM data memory can be independently powered.

Compatlblilty - For systems requiring additional compatibility, the MCS-48 can be expanded with the new 8243 I/O expander, 8155 I/O and 256-byte RAM, 8755 I/O and 2K-byte EPROM, or 8355 I/O and 2K ROM devices. MCS-48 processors readily interface to MCS-80/85 peripherals and standard memories.

## Memory Capacity

PROMPT 48 is a complete, fully assembled and powered microcomputer system including program memory, data memory, I/O, and system monitor beyond that available on MCS-48 single component computers. 1 K bytes of PROMPT system RAM serve as "writable program memory" - a ROM simulator for the program memory on each MCS-48 computer. 256 bytes of PROMPT system RAM serve as "external data memory," beyond the 64 register bytes on each MCS-48 computer. Users may further expand program or data memory via the panel I/O ports and bus connector.

## Programming

Programs written first in assembly language, are entered in machine language and debugged with calculator-like ease on the large, informative display and keyboard panel. Most MCS-48 operations can be specified with only two keystrokes. Once entered, routines can be exercised one instruction (single step) or many instructions at a time. The principal MCS-48 register - the accumulator - is displayed while single stepping. Programs can be executed in real time (GO NO BREAK) or with as many as eight different breakpoints (GO WITH BREAK).

## Control

PROMPT 48 can be fully controlled either by the panel keyboard and displays, or remotely by a serial channel. Thus a teletypewriter or CRT can be used but neither is required.

## Access

The PROMPT panel I/O ports and bus connector allow easy access to all MCS-48 pins except those reserved for control by the PROMPT system, namely EA external access, SS single step, and X1, X2 clock inputs.

## Optional Expansion

PROMPT 48 may be expanded beyond the resources on both the MCS-48 single component computer and the PROMPT system. External program and data memory may be interfaced and input/out ports added with the 8243 //O expander.

## FEATURES

## Single Component Computer

The 8748 is the first microcomputer fully integrated on one component. All elements of a computing system are provided, including CPU, RAM, I/O, timer, interrupts, and erasable, reprogrammable nonvolatile program memory.

## Programming Socket

PROMPT's programming socket programs this revolutionary "smart PROM"-the 8748-in a highly reliable, convenient manner. A fail-safe interlock ensures the device is properly inserted before applying programming pulses. Each location may be individually programmed, one byte at a time. A read-before-write programming algorithm prevents device damage by inadvertently programming unerased memory.

## MCS-48 Processors

The execution socket accepts either an 8035 or an 8748 MCS-48 processor. Both are supplied with each PROMPT 48, and either can serve as heart of the PROMPT system. There are no processors within the PROMPT 48 mainframe, which instead contains monitor ROM and RAM, user RAM, peripherals, drivers, and sophisticated control circuitry. Once a processor is seated in the execution socket and power is applied, the PROMPT system comes to life. Various access modes may be selected such as program execution from PROMPT system RAM, or from on-chip PROM. Thus programs may first be executed from PROMPT RAM with the 8035 processor. When debugging is complete, the 8035 (execution socket) processor can program the 8748 (programming socket) processor. Finally, a programmed 8748 processor may be exercised by itself from the execution socket. The execution socket processor runs either monitor or user programs.

## System Monitor

The system reset command initializes the PROMPT system and enters the monitor. The monitor interrupt command exits a user program gracefully, preserving system status and entering the monitor. The user interrupt command causes an interrupt only if the PROMPT system is running a user program. A comprehensive system monitor resides in four 1 K -byte read only memories. It drives the PROMPT keyboard and displays and responds to commands and functions. The top 16 bytes of on-chip program memory must be used by the PROMPT system to switch between monitor and user programs. It requires one level of the MCS-48 eight-level stack.

## Commands

PROMPT 48's commands are grouped and color-coded to simplify access to the 8748's separate program and data memory. Registers, data memory, or program memory, may be examined and modified with the examine and modify commands. Then either the next or previous register and memory locations may be accessed with one keystroke. Programs may be exercised in three modes. The go no break (GO NO BREAK) runs in real time. The go with break (GO WITH BREAK) mode is not
real time - after each instruction the MCS-48 program counter is compared against pending breakpoints. If no break is encountered, execution resumes. The go single step (GO SINGLE STEP) mode exercises one instruction at a time. Commands are like sentences, with parameters separated by NEXT. Each command ends with (1) EXECUTE/END. In addition to the PROMPT basic commands, thirteen functions simplify programming. Each is started merely by pressing a hex data/function key and entering parameters as required, as shown in Table 1.


## Cable Interface

An optional cable, PROMPT-SER, directly connects the PROMPT system to virtually any terminal via a rear access slot.


| Key | Function | Operation |
| :---: | :---: | :---: |
| 2 | Port 2 map | Allows specification of direction of each pin on port 2. Port 2 is multiplexed to address external program memory and expand I/O. Thus it must be buffered; the P2 map command establishes the direction of buffering. |
| 3 | Program EPROM | Programs 8748 EPROMs. |
| 4 | Byte search (with optional mask) | Sweeps through register, data, or program memory searching for byte matches. Starting and ending memory addresses are specified. |
| 5 | Word search (with optional mask) | Sweeps through register, data, or program memory searching for word matches. Starting and ending memory addresses are specified. |
| 6 | Hex calculator | Computes hexadecimal sums and differences. |
| 7 | 8748 program for debug | Similar to program EPROM, but ensures that the top of program memory contains monitor re-entry code for debugging. |
| 8 | Compare | Verifies any portions of EPROM program memory against PROMPT memory. |
| 9 | Move memory | Allows blocks of register, data, or program memory to be moved. |
| (A) | Access | Specifies one of six access modes for PROMPT 48. For example EPROM, PROMPT RAM, or external program memory, and a variety of input/output options may be selected. |
| B | Breakpoint | Allows any or all of the eight breakpoints to be set and cleared. |
| C | Clear | Clears portions of register, data, or program memory. |
| D | Dump | Dumps register, data, or program memory to PROMPT's serial channel: for example, a teletypewriter paper tape punch. |
| E | Enter | Enters (reads) register, data, or program memory from PROMPT's serial channel. |
| F | Fetch | Fetches programs from EPROM to PROMPT RAM. |

Table 1. PROMPT 48 Commands and Functions

## Access

Easy access to the pins of the executing processor is provided via the I/O ports and bus connector. Only the EA external access, SS single step, and X1, X2 clock inputs are reserved for the PROMPT system.

## Expansion

Program or data memory may be expanded beyond that provided on-chip or in the PROMPT system. I/O ports may be expanded, as with the 8243 , or peripheral controllers may be memory-mapped. The I/O ports and Bus connector allows the execution socket processor to be directly interfaced to prototype systems, yet be controlled from the PROMPT panel.

## Control

The command/function group panel keyboard and displays completely control PROMPT 48-a teletypewriter or CRT terminal is not needed. A hyphen prompting character appears whenever a command or function can be entered. Addresses and data are shown whenever examining registers and memory. Parameters for commands and functions are also shown.

## Documentation

The PROMPT 48 manual includes chapters for the reader with little or no programming experience. Topics treated range from number systems to microcomputer hardware design. A novel, unifying set of tutorial diagrams - MICROMAPS - 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 application notes, make the Intellec PROMPT 48 ideal for the newcomer to microcomputing.

## SPECIFICATIONS

## Timing

Basic Instruction - $2.5 \mu \mathrm{~s}$
Cycle Time $-\mathrm{t}_{\mathrm{CY}}=2.5 \mu \mathrm{~s}$
Clock - $6 \mathrm{MHz} \pm 0.1 \%$

## Memory Bytes

The 8748 contains 64 bytes of register memory, no external data memory, and 1024 bytes of RAM program memory. The PROMPT system provides 256 bytes of external data memory, and 1024 bytes of RAM program memory. PROMPT RAM program memory can be used in place of the on-chip EPROM program memory; thus programs less than 1024 bytes may be designed. For larger programs additional memory can be directly interfaced to the MCS-48 bus via the PROMPT panel I/O ports and bus connector.

## Memory Configuration

| Memory | Maximum | On Chip | In PROMPT 48 |
| :--- | :---: | :---: | :---: |
| Register | 64 | 64 | 0 |
| Data | 3328 | 0 | 256 |
| Program | 4096 | 1024 EPROM | 1024 RAM |

## I/O Ports

All MCS-48 I/O ports are accessible on the PROMPT panel connector.

Bus - A true bidirectional 8-bit port with associated strobes. If the bidirectional feature is not needed, bus can serve as either a statically latched output port or a non-latching input port. Input and output lines cannot be mixed.

Ports 1 and 2 - Data written to these 8-bit ports is latched and remains unchanged until written. As inputs these lines are not latching. The lines of ports 1 and 2 are called quasibidirectional. A special output structure allows each line of port 1 and half of port 2 to serve as an input, an output, or both. Any mix of input, output, and both lines is allowed.
T0, T1, and INT - Three pins that can serve as inputs. T0 can be designated as a clock output. Input/output can be expanded via the PROMPT panel connector with a special I/O expander (8243) or standard peripherals.

## Reset and Interrupts

Reset - initializes the PROMPT system and enters the monitor.
Monitor Interrupt - exits a user program gracefully, preserving system status and entering the monitor.

User Interrupt - causes an interrupt only if the PROMPT system is running a user program.

The processor traps to location $3_{16}$. The MCS-48 timer/event counter is not used by the PROMPT system and is available to the user. Either timer flag or interrupt will signal when overflow has occurred. The timer interrupt can be used only in the go-no-break (real time) mode.

## EPROM Programming

PROMPT 48 provides a programming socket to directly program 8748s. Programs are loaded into the PROMPT RAM program memory via keyboard. EPROM, teletypewriter, or other serial interface. A fail-safe interlock ensures programming pulses are applied only if the device is properly inserted. Inadvertant reprogramming is prevented by a read-before-write programming algorithm. Each location may be individually programmed, one byte at a time.

## Panel I/O Ports and Bus Connectors

All MCS-48 pins, except five, are accessible on the I/O ports and bus connector. The five reserved for PROMPT system control are EA external access, SS single step, X1, X2 crystal inputs, and 5V. Due to internal buffering of the MCS-48 bus, access times will be negligibly degraded by the PROMPT system. Since MCS-48 processors do not communicate internal address gate status, bus data must be driven out if neither PSEN nor RD is asserted.

## System Devices

Both user programs and the PROMPT monitor enjoy access to system devices: serial I/O, panel displays, and keyboard. These are memory-mapped to program memory addresses beyond 2 K .

Serial I/O - The serial I/O port (data $820_{16}$, control $821_{16}$ ) is defined by software and jumpers for 110 baud, 20 mA current loop, but can easily be jumpered for other baud rates and RS232C levels. Asynchronous or synchronous transmission, data format, control characters, and parity can be programmed.
Panel Displays - Eight display ports (data 810-817 ${ }_{16}$ ) allow each of the panel displays to be written from user programs. Data written on a display device will time out after a fixed interval. Displays must be refreshed on a polled or interrupt-driven basis. User programs can call software drivers which provide this capability.

Keyboard - Software is used to debounce the panel keyboard (data $810_{16}$ ). The monitor's input routines (see Software Drivers) provide this debouncing and can be called from user programs.

## Commands

Single step $\left.\begin{array}{l}\text { WIth break } \\ \text { No break }\end{array}\right\}$ Go
Examine/modify $\left\{\begin{array}{l}\text { Register } \\ \text { Data } \\ \text { Program }\end{array}\right\}$ Memory
Open previous/clear/entry $\square$ Next $\square$ Execute/End

## Functions

(2) Port 2 map

3 Program EPROM (8748)
4 Search (R, D or P)* memory for 1 byte, optional mask
5. Search (R, D or P) memory for 2 bytes, optional mask
6 Hexadecimal calculator + , -
[7 8748 program EPROM for debug
[8] Compare EPROM with memory
[9] Move memory (R, D or P)
(A) Access
(B) Breakpoint
[C Clear memory (R, D or P)
(D) Dump memory (R, D or P)

E Enter (read) memory (R, D or P)
E Fetch EPROM program memory

Note

* $R, D$, or $P$ is register, data, or program.


## Software Drivers

Panel Keyboard In - KBIN, KDBIN
Panel Display Out - DGS6, DGOUT, HXOUT, BLK, REFS, ENREF
Serial Channel - CI, CO, RI, PO, CSTS

## Connectors

Serial I/O - 3M 3462-0001 Flat Crimp/AMP 88106-1 Flat Crimp/ TI H312113 Solder/AMP 1-583485-5 Solder.

Panel I/O Ports and Bus Connector - 3M 3425 Flat Crimp. A complete cable set including wirewrap header for prototyping is included with each PROMPT.

## Equipment Supplied

PROMPT 48 mainframe with two MCS-48 processors (8748, 8035), display/keyboard, EPROM programmer, power supply, cabinet, and ROM-based monitor.
110 V AC power cable
110 or 220 V AC
Fuse
Panel I/O ports
Bus connector cable set

## Physical Characteristics

Helght - 5.3 in . $(13.5 \mathrm{~cm}$ ) max
Width - $17 \mathrm{in} .(43.2 \mathrm{~cm})$
Depth - 17 in. ( 43.2 cm ) max
Welght - $21 \mathrm{lb} .(9.6 \mathrm{~kg})$

## Electrical Characteristics

Pc" er Requirements - either 115 or 230 V AC ( $\pm 10 \%$ ) may be switch selected on the mainframe. 1.8 amps max current (at 125 V AC ).
Frequency $-47-63 \mathrm{~Hz}$

## Environmental Characteristics

Operating Temperature $-0^{\circ} \mathrm{C}$ to $+40^{\circ} \mathrm{C}$
Non-Operating Temperature $-20^{\circ} \mathrm{C}$ to $+65^{\circ} \mathrm{C}$

## Reference Manuals

9800402 - Intellec PROMPT 48 User's Manual (SUPPLIED)
9800270 - MCS-48 User's Manual (SUPPLIED)
9800255 - MCS-48 and UPI-41 Assembly Language Programming Manual (SUPPLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

Part Number Description
PROMPT-48 or Intellec PROMPT 48 MCS-48 micro-PROMPT-48-220V computer design aid. Complete with two MCS-48 processors (8748 and 8305), EPROM programmer, integral keyboard, displays, and system monitor in ROM.

PROMPT-SER Serial cable for connecting PROMPT to TTY, CRT


#### Abstract

Extends Intellec microcomputer development system debug power to user configured system via external cable and 40-pin plug, replacing system MCS-48 device


## Emulates user system MCS-48 device in real time

## Shares static RAM memory with user system for program debug

## Provides hardware comparators for user designated break conditions

Eliminates need for extraneous debugging tools residing in user system

Collects bus, register, and MCS-48 status information on instructions emulated

Provides capability to examine and alter MCS-48 registers, memory, and flag values, and to examine pin and port values

## Integrates hardware and software efforts early to save development time


#### Abstract

The ICE-49 MCS-48 In-Circuit Emulator module is an Intellec-resident module that interfaces with any MCS-48 system. The MCS-48 family consists of the $8049,8048,8748,8039,8035$, and 8021 microcomputers. The ICE-49 module interfaces with an MCS-48 system through a cable terminating in an MCS-48 pin-compatible plug which replaces the MCS-48 device in the sytem. With the ICE-49 plug in place, the designer has the capability to execute the system in real time while collecting up to 255 instruction cycles of real-time trace data. In addition, he can single step the system program to monitor more closely the program logic during execution. Static RAM memory is available through the ICE-49 module to emulate MCS-48 program and data memory. The designer can display and alter the contents of data and replacement RAM control memory, internal MCS-48 registers and flags and I/O ports. Powerful debug capability is extended into the MCS-48 system while ICE-49 debug hardware and software remain inside the Intellec system. Symbolic reference capability allows the designer to use meaningful symbols rather than absolute values when examining and modifying memory, registers, flags, and I/O ports in this system.


[^34]

## FUNCTIONAL DESCRIPTION

## Debug Capability Inside User System

The ICE-49 module provides the user with the ability to debug a full prototype or production system without introducing extraneous hardware or software test tools. The module connects to the user system through the socket provided for the MCS-48 device in the user system. Intellec memory is used for the execution of the ICE-49 software. The Intellec console and file handling capabilities provide the designer with the ability to communicate with the ICE-49 module and display information on the operation of the prototype system. The ICE-49 module block diagram is shown in Figure 1.

## Batch Testing

In conjunction with the ISIS-II diskette operating system, the ICE-49 module can run extensive system diagnostics without operator intervention. The designer or test engineer can define a complete diagnostic exercise, which is stored in a file on the diskette. When activated with an ISIS-II submit command, this file can instruct the ICE-49 module to execute the diagnostic routine and store the results in another file on the diskette. Results are available to the designer at his convenience. In this way, routine diagnostics and long term testing may be done without tying up valuable manpower.

## Integrated Hardware/Software Development

The user prototype need consist of no more than an MCS-48 socket and timing logic to begin integration of software and hardware development efforts. Through the ICE-49 module mapping capabilities, Intellec system resources can be accessed to replace prototype memory. Hardware designs can be tested using the system software to drive the final product. Thus, the system integration phase, which can be costly when attempting to mesh completed hardware and software products, becomes a convenient two-way debug tool when begun early in the design cycle.

## Real-Time Trace

The ICE-49 module captures trace information while the designer is executing programs in real time. The instructions executed, program counter, port values for bus 0 , port 1 and port 2, and the values of selected MCS-48 status lines are stored for the last 255 instruction cycles executed. When retrieved for display, code is disassembled for user convenience. This provides data for determining how the user system was reacting prior to emulation break, and is available whether the break was user initiated or the result of an error condition. For more detailed information on the actions of internal registers, flags, or other system operations, the user may operate in single or multiple step sequences tailored to system debug needs.


Figure 1. ICE-49 Module Block Diagram

## Memory Mapping

The 8049, 8748 and 8048 contain internal program and data memory. Both program and data memory can be expanded using external memory devices.
Internal Memory - When the MCS-48 microcomputer is replaced by the ICE-49 socket in a system, the ICE-49 module supplies static RAM memory as a replacement for the internal microcomputer memory. The ICE-49 module has enough RAM memory available to emulate up to the total 4 K control memory capability of the system. The ICE-49 module also provides for up to 320 bytes of data memory.
External Memory - The ICE-49 module separates replacement control memory into sixteen 256-byte blocks. Replacement external data memory consists of one 256 -byte block. Each block of memory can be defined separately as supplied by the user system or supplied by the ICE-49 module. The user may assign ICE-49 equivalent memory to take the place of external memory not yet supplied in his system.

## Symbolic Debugging

ICE-49 software provides symbolic definition of all MCS-48 registers, flags, and selected MCS-48 pins. Symbolically defined pseudo registers provide access to the sense of MCS-48 flip flops which enable time, counter, interrupt, and flag-0/flag-1 options. In addition, the user may reference locations in program and data memory, or their contents, symbolically. The user symbol table generated along with the object file during a program assembly may be loaded to Intellec memory for access during emulation. The user is encouraged to add to this symbol table any additional symbolic values for memory addresses, constants, or variables he may find useful during system debugging. Symbols may be substituted for numeric values in any of the ICE-49 commands. Symbolic reference is a great advantage to the system designer. He is no longer burdened with the need to recall or look up those addresses of key locations in his program that can change with each assembly. Meaningful symbols from his source program may be used instead. For example, the command:

## GO FROM .START TILL XDATA. RSLT WRITTEN

begins execution of the program at the address referenced by the label START in the designers assembly program. A breakpoint is set to occur the first time the microprocessor writes to the external data memory location referenced by RSLT. The designer does not have to be concerned with the physical locations of START and RSLT. The ICE-49 software driver supplies them automatically from information stored in the symbol table.

## Hardware

The ICE-49 module is a microcomputer system utilizing Intel's 8049 or 8048/8748 microcomputer as its nucleus. The 8049 provides the 8049,8039 emulation characteristics. The 8048/8748 provides the 8748/8648/8035/8021 emulation characteristics. The ICE-49 module uses an

Intel 8080 to communicate with the Intellec host processor via a common memory space. The 8080 also controls an internal ICE-49 bus for intramodule communication. ICE-49 hardware consists of two PC boards, the controller board, and the emulator board, all of which reside in the Intellec chassis. A cable interfaces the ICE-49 boards to the MCS-48 system. The cable terminates in a MCS-48 pin compatible plug which replaces any MCS-48 device in the user system. The ICE-49 module block diagram is shown in Figure 1.

## Real-Time Trace

Trace Buffer - While the ICE-49 module is executing the user program, it is monitoring port, program counter, data, and status lines. Values for each instruction cycle executed are stored in a $255 \times 44$ real-time RAM trace buffer. A resetable timer resident on the controller board counts instruction cycles.

## Controller Board

The ICE-49 module talks to the Intellec system as a peripheral device. The controller board receives commands from the Intellec system and responds through the parameter block. Three 15-bit hardware breakpoint registers are available for loading by the user. While in emulation mode, a hardware comparator is constantly monitoring address and status lines for a match to terminate an emulation. The breakpoint registers provide a signal when a match is detected. The user may disable the emulation break capability and use the signal to synchronize other debug tools. The controller board returns real-time trace data, MCS-48 register, flag, and pin values, and ICE-49 status information, to a control block in the Intellec system when emulation is terminated. This information is available to the user through the ICE-49 interrogation commands. Error conditions, when present, are automatically displayed on the Intellec system console. The controller board also contains static RAM memory, which can be used to emulate MCS-48 program and data memory in real time. 4 K of memory is available in sixteen 256 -byte pages to emulate MCS-48 PROM or PROM program memory. A 256byte page of data memory is available to access in place of MCS-48 external data memory. The controller board address map directs the ICE-49 module to access either replacement ICE-49 memory or actual user system external memory in 256 -byte segments based on information provided by the user.

## Emulator Board

The emulator board contains the 8049* and peripheral logic required to emulate the MCS-48 device in the user system. A software selectable 6 MHz or 3 MHz clock drives the emulated MCS-48 device. This clock can be disabled and replaced with a user supplied TTL clock in the user system.

[^35]
## 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 MCS-48 device.

## Software

The ICE-49 software driver is a RAM-based program which provides the user with an easy to use command language (see Table 1, Table 2, and Table 3) for defining breakpoints, initiating real-time emulation or single step operation, and interrogating and altering user system status recorded during emulation. The ICE-49 command language contains a broad range of modifiers to provide the user with maximum flexibility in defining the operation to be performed. The ICE-49 software driver is available on diskette and operates in 32 K of Intellec RAM memory.

| Command | Operation |
| :--- | :--- |
| Enable | Activates breakpoint and display regis- <br> ters for use with go and step com- <br> mands. <br> Initiates real-time emulation and allows <br> user to specify breakpoints and data <br> retrieval. <br> StepInitiates emulation in single instruction <br> increments. Each step is followed by <br> register dump. User may optionally <br> tailor other diagnostic activity to his <br> needs. <br> Emulates user system interrupt. |

Table 1. ICE-49 Emulation Commands

| Command | Operation |
| :---: | :--- |
| Display | Prints contents of memory, MCS-48 <br> device registers, I/O ports, flags, pins, <br> real-time trace data, symbol table, or <br> other diagnostic data on list device. <br> Change <br> Alters contents of memory, register, <br> output port, or flag. Sets or alters break- <br> points and display registers. |
| Map | Defines memory status. <br> Base <br> Suffix |
| Establishes mode of display for output <br> data. <br> Establishes mode of display input data. |  |

Table 2. ICE-49 Interrogation Commands

| Command | Operation |
| :--- | :--- |
| Load | Fetches user symbol table and object <br> code from input device. <br> Sends user symbol table and object <br> code to output device. <br> Define <br> Enters symbol name and value to user <br> symbol table. <br> Moves block of memory data to another <br> area of memory. |
| List | Defines list device. <br> Returns program control to ISIS-II. <br> Eonverts expression to equivalent <br> values in binary, octal, decimal, and <br> hex. <br> Evaluate |
| Remove | Deles symbols from symbol table. <br> Reinitializes ICE-49 hardware. |
| Reset |  |

Table 3. ICE-49 Utility Commands

## SPECIFICATIONS

## ICE-49 Operating Environment

## Required Hardware

Intellec microcomputer development system
System console
intellec diskette operating system
ICE-49 Module

## Required Software

System monitor
ISIS-II

## Equipment Supplied

Printed circuit boards (control board, emulator board) Interface cables and buffer module ICE-49 software, diskette-based version (single density or double density)
8048 with internal monitor program

## System Clock

Crystal controlled 6.0 MHz internal, 3.0 MHz internal or user supplied TTL external: software selectable.

Physical Characteristics
Width - 12.00 in . $(30.48 \mathrm{~cm})$
Height $-6.75 \mathrm{in} .(17.15 \mathrm{~cm})$
Depth - $0.50 \mathrm{in} .(1.27 \mathrm{~cm})$
Weight $-8.00 \mathrm{lb} .(3.64 \mathrm{~kg})$

## Electrical Characteristics

DC Power Requirements
$V_{C C}=+5 \mathrm{~V} \pm 5 \%$
$\mathrm{I}_{\mathrm{CC}}=10 \mathrm{~A}$ max; 7.0A typ
$V_{D D}=+12 V \pm 5 \%$
$I_{D D}=79 \mathrm{~mA}$ max; 45 mA typ
$V_{B B}=-10 \mathrm{~V} \pm 5 \%$
$I_{B B}=20 \mathrm{~mA}$ max

Input Impedance - @ ICE-49 user socket pins:
$V_{I L}=0.8 \mathrm{~V}$ (max), $I_{I L}=-1.6 \mathrm{~mA}$,
$V_{1 H}=2.0 \mathrm{~V}(\mathrm{~min}), I_{1 \mathrm{H}}=40 \mu \mathrm{~A}$
For Bus:
$V_{I L}=0.8 \mathrm{~V}(\max ), I_{I L}=-250 \mu \mathrm{~A}$
$V_{I H}=2.0 \mathrm{~V}(\mathrm{~min}), I_{\mathrm{IH}}=20 \mu \mathrm{~A}$
Output Impedance - @ ICE-49 user socket pins:
P1, P2:
$\mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}($ max $), \mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$
$\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{CC}}$ (10K pullup)
For Bus:
$\mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}$ (max), $\mathrm{l}_{\mathrm{OL}}=25 \mathrm{~mA}$
$\mathrm{V}_{\mathrm{OH}}=3.65 \mathrm{~V}(\mathrm{~min}), \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$
Others:
$\mathrm{V}_{\mathrm{OL}}=0.5 \mathrm{~V}$ (max), $\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA}$
$\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}(\max ), \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$

## Environmental Characteristics

Operating Temperature $-0^{\circ} \mathrm{C}$ to $40^{\circ} \mathrm{C}$, Roon Temperature)
Operating Humidity - Up to $95 \%$ relative humidity without condensation

## Reference Manuals

9800632 - ICE-49 Operator's Manual (SUPPLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

## Part Number Description

MDS-49-ICE $\quad 8049,8048,8039,8748,8035,8021$
CPU in-circuit emulator. Cable assembly and interactive diskette software included
MDS-498 Assembled kit to upgrade ICE-48 to ICE-49 capability. ICE-49 emulator board, 8049/8048 CPU components with internal monitor program, ICE-49 firmware and diskette software included.

ICE-80 8080 IN-CIRCUIT EMULATOR

Connects Intellec system to user configured system via an external cable and 40-pin plug, replacing the user system 8080

Allows real-time ( 2 MHz ) emulation of user system 8080

Shares Intellec RAM, ROM, and PROM memory and Intellec I/O facilities with user system

Checks for up to three hardware and four software break conditions

Offers full symbolic debugging capabilities

Eliminates need for extraneous debugging tools residing in 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 ICE-80 8080 In-Circuit Emulator is an Intellec resident module designed to interface with any user configured 8080 system. With ICE-80 as a replacement for a prototype system 8080, the designer may emulate the system's 8080 in real time, single step the system's program, and substitute Intellec memory and I/O for user system equivalents. Powerful Intellec debug functions are extended into the user system. For the first time the designer may examine and modify his system with symbolic references instead of absolute values.


## FUNCTIONAL DESCRIPTION

## Integrated Hardware/Software Development

Use of the ICE-80 module enables the system integration phase, which can be so costly and frustrating when attempting to mesh completed hardware and software products, to become a convenient two-way debug tool when begun early in the design cycle. 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. With the ICE-80 mapping capabilities, system resources may be accessed for missing prototype hardware. Hardware designs may be tested using system software to drive the final product. A functional block diagram of the ICE-80 module is shown in Figure 1.

## Symbolic Debugging Capability

ICE-80 provides for user-defined symbolic references to program memory addresses and data. Symbols may be substituted for numeric values in any of the ICE-80 commands. The user is thus relieved from looking up addresses of variables or program subroutines.
Symbol Table - The user symbol table generated along with the object file during a PL/M compilation or a MAC80 or resident assembly, is loaded to memory along with the user program to be emulated. The user may add to this symbol table any additional symbolic values for memory addresses, constants, or variables found useful
during system debugging. By referring to symbolic memory addresses, the user may be assured of examining, changing, or breaking at the intended location.
Symbolic Reference - 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 RAM address occupied by user memory.

## Debug Capability Inside User System

ICE-80 provides for user debugging of full prototype or production systems 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 (See Figure 2). Intellec memory is used for the execution of the ICE-80 software, while I/O provides the user with the ability to communicate with ICE-80 and receive information on the generation of the user system. A sample ICE-80 debug session is shown in Figure 3.

## I/O Mapping and Memory

Memory and I/O for the user system may be resident in the user system or "borrowed" from the Intellec system through ICE-80's mapping capability.


Figure 1. Functional Block Diagram of ICE-80 Module


Figure 2. ICE-80 Module Installed in User System
Memory Blocking - 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 may be defined independently. The user may assign system equivalents to take the place of devices not yet designed for the user system during prototyping. In addition, memory or I/O may be accessed in place of user system devices during prototype or production checkout.

Error Messages - The user may also designate a block of memory or I/O as nonexistent. ICE-80 issues error messages when memory or I/O designated as nonexisting is accessed by the user program.

## 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 the ICE-80 is a microcomputer system utilizing Intel's 8080 microprocessor as its nucleus. This system communicates with the Intellec 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 system also communicate through a control block resident in the Intellec 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 chassis - and a 6 -foot cable interfacing to the user system. The trace and processor boards communicate with the system on the 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 system as a peripheral device. It receives 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 high-speed bipolar memory.
Breakpoint - 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 to terminate an emulation. A user probe is also available for attachment to any user signal. When this signal goes true a break condition is recognized.
Interrogation - The trace board signals the processor board when a command to ICE-80 or break condition has been detected. The ICE-80 CPU then sends data stored on the trace board to the control block in 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.
Timing - The processor board contains an internal clock generator to provide 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.
On/Off Control - The processor board turns on an emulation when ICE-80 has received a run command from the system. 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.
Status Storage - 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

8. Exit returns control to the MDS monitor.

Figure 3. Sample ICE-80 Debug Session
on the Intellec or user bus by consulting the address map. The processor board allows the ICE-80 CPU to gain access to the bus as a master to "borrow" Intellec 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 Intellec 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 that 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 a RAM-based program providing easy to use English language commands for defining breakpoints, initiating emulation, and interrogating and altering the user system status recorded during emulation. ICE-80 commands are con-
figured with a broad range of modifiers to provide the user with maximum flexibility in describing the operation to be performed. Listings of emulation commands, interrogation commands, and utility commands are provided in Table 1, Table 2, and Table 3, respectively.

| Command | Operation |
| :--- | :--- |
| Base | Establishes mode of display for output <br> data. |
| Display | Prints contents of memory, 8080 regis- <br> ters, input ports, 8080 flags, 8080 pins, <br> snap data, symbol table, or other diag- <br> nostic data on list device. May also be <br> used for base-to-base conversion, or for <br> addition or subtraction in any base. |
| Change | Alters contents of memory, register, out- <br> put port, or 8080 flag. <br> Defines memory and I/O status. <br> Looks through memory range for speci- <br> fied value. |

Table 2. ICE-80 Interrogation Commands

| Command | Operation |
| :--- | :--- |
| Load | Fetches user symbol table and object <br> code from input device. <br> Sends user symbol table and object code <br> to output device. <br> Enters symbol name and value to user <br> symbol table. |
| Fill | Fills memory range with specified value. <br> Moves block of memory data to another <br> area of memory. <br> Enables/disables user CPU 1/4 second |
| Timeout | wait state timeout. <br> Defines list device (diskette-based ver- <br> sion only). <br> Returns program control to monitor. |

Table 3. ICE-80 Utility Commands

## SPECIFICATIONS

## Paper Tape-Based ICE80SD <br> Operating Environment

## Required Hardware

Intellec system
System console
Reader device
Punch device
ICE-80
Required Software
System monitor

## Diskette-Based ICE80SD

## Operating Environment

## Required Hardware

Intellec system
32K bytes RAM memory
System console
ISIS MOS floppy disk drive
ICE-80
Required Software
System monitor
ISIS-II Diskette Operating System

## System Clock

Crystal controlled $2.185 \mathrm{MHz} \pm 0.01 \%$. May be replaced by user clock through jumper selection.

## Connectors <br> Edge Connector — CDC VPB01E32A00A1

## Physical Characteristics

Width - 12.00 in. ( 30.48 cm )
Height - 6.75 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 Requirements
$V_{C C}=+5 \mathrm{~V}, \pm 5 \%$
$I_{C C}=9.81 \mathrm{~A}$ max; 6.90A typ
$V_{D D}=+12 \mathrm{~V}, \pm 5 \%$
$\mathrm{I}_{\mathrm{DD}}=79 \mathrm{~mA}$ max; 45 mA typ
$V_{B B}=-9 V, \pm 5 \%$
$\mathrm{I}_{\mathrm{BB}}=1 \mathrm{~mA}$ max; $1 \mu \mathrm{~A}$ typ

## Environmental Characteristics

Operating Temperature $-0^{\circ} \mathrm{C}$ to $40^{\circ} \mathrm{C}$
Operating Humidity - Up to $95 \%$ relative humidity without condensation

## Equipment Supplied

Printed circuit modules (2) Interface cables and buffer board ICE-80 software driver, paper tape version
(ICE-80 software driver, diskette-based version is supplied with diskette operating systems)

## Reference Manuals

9800185 - ICE-80 Operator's Manual (SUPPLIED)
9800556 - Intellec Series II Hardware Reference Manual (SUPPLIED)
9800554 - Intellec Series II Schematic Drawings (SUPPLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

Part Number Description<br>MDS-80-ICE $\quad 8080$ CPU in-circuit emulator, cable assembly and interactive software included

## ICE-85 MCS-85 IN-CIRCUIT EMULATOR

Connects the Intellec system resources to the user configured system via a 40-pin adaptor plug

## Executes user system software in real time

## Shares Intellec memory and I/O facilities with user system

Provides 1023 states of 8085 trace data plus 18 additional logic signals via external trace module

Offers full symbolic debugging capability for both assembly language and Intel's high level compiler language, PL/M-80

Displays trace data from user's 8085 in assembler mnemonics and allows personality groupings of data sampled by external 18-channel trace module

Extends ICE capabilities to prototype system peripheral circuitry by allowing user to execute peripheral chip analysis routines

Provides ability to examine and alter MCS-85 registers, memory, flag values, interrupt bits, and I/O ports


#### Abstract

The ICE-85 MCS-85 In-Circuit Emulator is an Intellec resident module designed to interface with any user configured 8085 system. In addition, an external trace module provides access to user system peripheral circuitry via a user configured DIP clip for peripheral ICs or may be attached to as many as 18 separate prototype signal nodes via individual probe clips. Using the ICE-85 module, the designer may execute prototype software in real time or single step mode and may substitute Intellec system memory and I/O for their user system equivalents. ICE capability may be extended to the remaining user system peripheral circuitry by allowing the user to create and execute a library of user defined peripheral chip analyzer routines. All user access to the prototype system software may be done symbolically by assigning names to program locations and data, I/O ports, and groups of external trace signals. For the first time, inciruit emulation extends beyond a user prototype CPU to the entire user system, allowing in-system emulation.




## SYMBOLIC DEBUGGING CAPABILITY

ICE-85 allows the user to make symbolic references to I/O ports, memory addresses and data in his program. Symbols and $\mathrm{PL} / \mathrm{M}$ statement number may be substituted for numeric values in any of the ICE-85 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-80 compilation or by the ISIS-II 8080/8085 Macro Assembler is loaded into the Intellec ${ }^{\circledR}$ System 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 symbol memory addresses, the user can examine, change or break at the intended location.
ICE-85 provides symbolic definition of all 8085 registers, interrupt bits and flags. The following symbolic references are also provided for user convenience: TIMER, the loworder 16 bits of a register containing the number of 2 MHz clock pulses elapsed during emulation; HTIMER, the highorder 16 bits of the timer counter; PPC, the address of the last instruction emulated; BUFFERSIZE, the number of frames of valid trace data (between 0 and 1022).

## PERSONALITY GROUPED DISPLAYS

Trace data in the 1023 by 42 -channel real-time trace memory buffer is displayed in easy to read format. The user has the option to specify trace data displays in actual 8085 assembler instruction mnemonics. The data collected from the External Trace Module can be grouped and symbolically named according to user specifications and displayed in the appropriate number base designation. Simple ICE-85 commands allow the user to select any portion of the 42 K bit trace buffer for immediate display.

## MEMORY AND I/O MAPPING

Memory and I/O for the user system can be resident in the user system or "borrowed" from the Intellec ${ }^{\circledR}$ System through ICE-85's mapping capability.

ICE-85 separates user memory into 32 2K blocks. Each block of memory can be defined independently. The user may assign Intellec ${ }^{\circledR}$ System equivalents to take the place of devices not yet designed for the user system during prototyping. In addition, Intellec ${ }^{\circledR}$ System memory or I/O can be accessed in place of suspect user system devices during prototyping or production checkout.
The user can also designate a block of memory or I/O as nonexistent. ICE-85 issues error messages when memory or I/O designated as nonexistent is accessed by the user program.

## INTEGRATED HARDWARE/SOFTWARE DEVELOPMENT

The user prototype need consist of no more than an 8085 CPU socket and a user bus to begin integration of software and hardware development efforts. Through ICE-85 mapping capabilities, Intellec ${ }^{\circledR}$ System 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 when attempting to mesh completed hardware and software products, becomes a convenient two-way debug tool when begun early in the design cycle.


## TYPICAL ICE INTERROGATION AND UTILITY COMMANDS

DISPLAY/ Display/Changes the values of symbols and CHANGE the contents of 8085 registers, pseudoregisters, status flags, interrupt bits, I/O ports and memory.
EVALU- Displays the value of an expression in the ATE binary, octal, decimal or hexadecimal.
SEARCH Searches user memory between locations in a user program for specified contents.
CALL Emulates a procedure starting at a specified memory address in user memory.
ICALL Executes a user-supplied procedure starting at a specified memory address in the Intellec ${ }^{\circledR}$ System memory.
EXECUTE Saves emulated program registers and emulates a user-supplied subroutine to access peripheral chips in the user's system.

## REAL TIME TRACE

ICE-85 captures valuable trace information from the emulating CPU and the External Trace Module while the user is executing programs in real time. The 8085 status, the user memory or port addressed, the data read or written, the serial data lines and data from 18 external signals, is stored for the last 1023 machine states executed ( 511 machine cycles). 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 multi-step sequences tailored to system debug needs.


## EMULATION CONTROLS AND COMMANDS

GROUP Defines into a symbolically named group, a channel or combination of channels from the 8085 Microcprocessor and/or the External Trace Module.
GO Initiates real-time emulation and controls emulation break conditions.
STEP Initiates emulation in single instruction steps. User may specify the type and amount of information displayed following each step, and define conditions under which stepping should continue.
PRINT Prints the user-specified portion of the trace memory to the selected list device.

## EXTERNAL TRACE MODULE

TTL level signals from 18 points in the user system may be synchronously sampled by the External Trace Module and collected in ICE-85's trace buffer. The signals can be collected from a single peripheral chip via the supplied 40-pin DIP clip or may be placed by the user on up to 18 separate signal nodes using the supplied 18 individual probe clips. These signals are included in the 42 -channel breakpoint comparisons and clock qualifiers. Also, data from these 18 channels may be displayed in each to read, user-defined groupings.

## SYNCHRONOUS OPERATION WITH OTHER DESIGN AIDS

ICE-85 can be synchronized with other Intellec ${ }^{\circledR}$ design aids by means of two external synchronization lines. These lines are used to enable and disable ICE-85 trace data collection and to cause break conditions based on an external signal which may not be included in the ICE-85 breakpoint registers. In addition, ICE-85 can generate signals on these lines which may be used to control other design aids.

## BREAK REGISTERS/TRACE MEMORY

ICE-85 has two breakpoint registers which are used to break emulation, and two trace qualifier registers which are used to control the collection of trace data during emulation. Each register is 42 entries wide, one entry for each channel and each entry can take any one of the three values 0,1 or "don't care".
The trace buffer, also 42 entries wide, collects data sampled from 248085 processor channels and 18 external channels sampled by the External Trace Module. The signals collected from the 8085 include address lines, data lines, status lines and serial input and output lines. The 18 channels extending from the External Trace Module synchronously sample and collect into the trace buffer any user-specified TTL compatible signal from the rest of the prototype system. "Break" and "trace qualification" may therefore occur as a result of a match of any combination of up to 42 channels of CPU and external circuitry signals.


Figure 1. Functional Block Diagram of ICE-85 Module

## SPECIFICATIONS

## ICE-85 Operating Environment

## Required Hardware

Intellec microcomputer development system System console Intellec diskette operating system ICE-85 module
Required Software
System monitor
ISIS-II

## Emulation Clock

User's system clock or ICE-85 adaptor socket (6.144 MHz crystal)

Physical Characteristics
Width - 12.00 in. ( 30.48 cm )
Height $-6.75 \mathrm{in} .(17.15 \mathrm{~cm})$
Depth - $0.50 \mathrm{in} .(1.27 \mathrm{~cm})$
Packaged Weight - $6.00 \mathrm{lb}(2.73 \mathrm{~kg})$
Electrical Characteristics
DC Power Requirements
$V_{C C}=+5 \mathrm{~V} \pm 5 \%$
$I_{C C}=12 \mathrm{~A}$ max; 10A typ
$V_{D D}=+12 \mathrm{~V} \pm 5 \%$
$\mathrm{I}_{\mathrm{DD}}=80 \mathrm{~mA}$ max; 60 mA typ
$V_{B B}=-10 V \pm 5 \%$
$\mathrm{I}_{\mathrm{BB}}=30 \mathrm{~mA}$ max; $10 \mu \mathrm{~A}$ typ

## Environmental Characteristics

Operating Temperature $-0^{\circ}$ to $40^{\circ} \mathrm{C}$
Operating Humidity - Up to $95 \%$ relative humidity without condensation.

## Equipment Supplied

18-channel external trace module
Printed circuit boards (2)
Interface cable and emulation buffer module
ICE-85 software, diskette-based version

## Reference Manuals

9800463 - ICE-85 Operator's Manual (SUPPLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

Part Number Description<br>MDS-85-ICE $\quad 8085$ CPU in-circuit emulator and 18-channel external trace module

ICE-86 ${ }^{\text {TM }}$
8086 IN-CIRCUIT EMULATOR

## Hardware in-circuit emulation

## Full symbolic debugging

Breakpoints to halt emulation on a wide variety of conditions

Comprehensive trace of program execution, both conditional and unconditional

## Disassembly of trace or memory from object code into assembler mnemonics

## 2K bytes of high speed ICE-86 mapped memory

## Software debugging with or without user system

## Handles full 1 megabyte addressability of 8086

## Compound commands

## Command macros

The ICE-86 module provides In-Circuit Emulation for the 8086 microprocessor and the iSBC $86 / 12$ Single Board Computer. It includes three circuit boards which reside in Intellec Microcomputer Development Systems. A cable and buffer box connect the Intellec system to the user system by replacing the user's 8086 . Powerful Intellec debug functions are thus extended into the user system. Using the ICE-86 module, the designer can execute prototype software in continuous or single-step mode and can substitute blocks of Intellec system memory for user equivalents. Breakpoints allow the user to stop emulation on user-specified conditions, and the trace capability gives a detailed history of the program execution prior to the break. All user access to the prototype system software may be done symbolically by referring to the source program variables and labels.


## INTEGRATED HARDWARE/SOFTWARE DEVELOPMENT

The ICE-86 emulator allows hardware and software development to proceed interactively. This is more effective than the traditional method of independent hardware and software development followed by system integration. With the ICE-86 module, prototype hardware can be added to the system as it is designed. Software and hardware testing occurs while the product is being developed.

Conceptually, the ICE-86 emulator assists three stages of development:

1. It can be operated without being connected to the user's system, so ICE-86 debugging capabilities can be used to facilitate program development before any of the user's hardware is available.
2. Integration of software and hardware can begin when any functional element of the user system hardware is connected to the 8086 socket. Through ICE-86 mapping capabilities, Intellec memory, ICE memory, or diskette memory can be substituted for missing prototype memory. Time-critical program modules are debugged before hardware implementation by using the 2 K -bytes of high-speed ICE-resident memory. As each section of the user's hardware is completed, it is added to the prototype. Thus each section of the hardware and software is "system" tested as it becomes available.
3. When the user's prototype is complete, it is tested with the final version of the user system software. The ICE-86 module is then used for real time emulation of the 8086 to debug the system as a completed unit.

Thus the ICE-86 module provides the user with the ability to debug a prototype or production system at any stage in its development without introducing extraneous hardware or software test tools.

## SYMBOLIC DEBUGGING

Symbols and PL/M statement numbers may be substituted for numeric values in any of the ICE- 8600 m mands. This allows the user to make symbolic refer ences to I/O ports, memory addresses, and data in the user program. Thus the user need not remember the addresses of variables or program subroutines.

Symbols can be used to reference variables, procedures, program labels, and source statements. A variable can be displayed or changed by referring to it by name rather than by its absolute location in memory. Using symbols for statement labels, program labels, and procedure names simplifies both tracing and breakpoint setting. Disassembly of a section of code from either trace or program memory into its assembly mnemonics is readily accomplished.

Furthermore, each symbol may have associated with it one of the data types BYTE, WORD, INTEGER, SINTEGER (for short, 8-bit integer) or POINTER. Thus the user need not remember the type of a source program variable when examining or modifying it. For example, the command "!VAR" displays the value in memory of variable VAR in a format appropriate to its type, while the command "!VAR = !VAR + 1" increments the value of the variable.

The user symbol table generated along with the object file during a PL/M-86 compilation or an ASM-86 assembly is loaded into 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.

The ICE-86 module provides access through symbolic definition to all of the 8086 registers and flags. The READY, NMI, TEST, HOLD, RESET, INTR, and MN/MX pins of the 8086 can also be read. Symbolic references to key ICE-86 emulation information are also provided.


Figure 1. ICE-86 Block Diagram


A typical ICE-86 development configuration. It is based on an MDS-230 Development System, which also includes an MDS-DDS Double Density Diskette Operating System and an MDS-201 Expansion Chassis (which holds the ICE-86 emulator). The ICE-86 module is shown connected to a user prototype system, in this case, an SDK-86.

## MACROS AND COMPOUND COMMANDS

The ICE-86 module provides a programmable diagnostic facility which allows the user to tailor its operation using macro commands and compound commands.

A macro is a set of ICE-86 commands which is given a single name. Thus, a sequence of commands which is executed frequently may be invoked simply by typing in a single command. The user first defines the macro by entering the entire sequence of commands which he wants to execute. He then names the macro and stores it for future use. He executes the macro by typing its name and passing up to ten parameters to the commands in the macro. Macros may be saved on a disk file for use in subsequent debugging sessions.
Compound commands provide conditional execution of commands(IF), and execution of commands until a condition is met or until they have been executed a specified number of times (COUNT, REPEAT).

Compound commands and macros may be nested any number of times.

## MEMORY MAPPING

Memory for the user system can be resident in the user system or "borrowed" from the Intellec System through ICE-86's mapping capability.

The ICE-86 emulator allows the memory which is addressed by the 8086 to be mapped in 1K-byte blocks to:

1. Physical memory in the user's system,
2. Either of two 1 K -byte blocks of ICE-86 high speed memory,
3. Intellec memory,
4. A random-access diskette file.

The user can also designate a block of memory as nonexistent. The ICE-86 module issues an error message when any such "guarded" memory is addressed by the user program.

| Command | Description |
| :--- | :--- |
| GO | Initializes emulation and allows the <br> user to specify the starting point <br> and breakpoints. Example: <br> GO FROM .START TILL .DELAY <br> EXECUTED <br> where START and DELAY are state- <br> ment labels. <br> STEP <br> Allows the user to single-step <br> through the program. |

Table 1. Summary of ICE-86 Emulation Commands

## OPERATION MODES

The ICE-86 software is a RAM-based program that provides the user with easy-to-use commands for initiating emulation, defining breakpoints, controlling trace data collection, and displaying and controlling system parameters. ICE-86 commands are configured with a broad range of modifiers which provide the user with maximum flexibility in describing the operation to be performed.

## Emulation

Emulation commands to the ICE-86 emulator control the process of setting up, running and halting an emulation of the user's 8086 . Breakpoints and tracepoints enable ICE-86 to halt emulation and provide a detailed trace of execution in any part of the user's program. A summary of the emulation commands is shown in Table 1.

Breakpoints - The ICE-86 module has two breakpoint registers that allow the user to halt emulation when a specified condition is met. The breakpoint registers may be set up for execution or non-execution breaking. An execution breakpoint consists of a single address which causes a break whenever the 8086 executes from its queue an instruction byte which was obtained from
the address. A non-execution breakpoint causes an emulation break when a specified condition other than an instruction execution occurs. A non-execution breakpoint condition, using one or both breakpoint registers, may be specified by any one of or a combination of:

1. A set of address values. Break on a set of address values has three valuable features:
a. Break on a single address.
b. The ability to set any number of breakpoints within a limited range ( 1024 bytes maximum) of memory.
c. The ability to break in an unlimited range. Execution is halted on any memory access to an address greater than (or less than) any 20-bit breakpoint address.
2. A particular status of the 8086 bus (one or more of: memory or I/O read or write, instruction fetch, halt, or interrupt acknowledge).
3. A set of data values (features comparable to break on a set of address values, explained in point one).
4. A segment register (break occurs when the register is used in an effective address calculation).
An external breakpoint match output for user access is provided on the buffer box. This allows synchronization of other test equipment when a break occurs.

Tracepoints - The ICE-86 module has two tracepoint registers which establish match conditions to conditionally start and stop trace collection. The trace information is gathered at least twice per bus cycle, first when the address signals are valid and second when the data signals are valid. If the 8086 execution queue is otherwise active, additional frames of trace are collected.

Each trace frame contains the 20 address/data lines and detailed information on the status of the 8086. The trace memory can store 1,023 frames, or an average of about 300 bus cycles, providing ample data for determining how the 8086 was reacting prior to emulation break. The trace memory contains the last 1,023 frames of trace data collected, even if this spans several separate emulations. The user has the option of displaying each frame of the trace data or displaying by instruction in actual ASM-86 Assembler mnemonics. Unless the user chooses to disable trace, the trace information is always available after an emulation.

## Interrogation and Utility

Interrogation and utility commands give the user convenient access to detailed information about the user program and the state of the 8086 that is useful in debugging hardware and software. Changes can be made in both memory and the 8086 registers, flags, input pins, and I/O ports. Commands are also provided for various utility operations such as loading and saving program files, defining symbols and macros, displaying trace data, setting up the memory map, and returning control to ISIS-II. A summary of the basic interrogation and utility commands is shown in Table 2.

Memory/Register Commands
Display or change the contents of:

- Memory
- 8086 Registers
- 8086 Status flags
- 8086 Input pins
- 8086 I/O ports
- ICE-86 Pseudo-Registers (e.g. emulation timer)

Memory Mapping Commands
Display, declare, set, or reset the ICE-86 memory mapping. Symbol Manipulation Commands

Display any or all symbols, program modules, and program line numbers and their associated values (locations in memory).

Set the domain (choose the particular program module) for the line numbers.

Define new symbols as they are needed in debugging.
Remove any or all symbols, modules, and program statements.

Change the value of any symbol.
TYPE
Assign or change the type of any symbol in the symbol table. ASM

Disassemble user program memory into ASM-86 Assembler mnemonics.

PRINT
Display the specified portion of the trace memory. LOAD

Fetch user symbol table and object code from the input file. SAVE

Send user symbol table and object code to the output file. LIST

Send a copy of all output (including prompts, input line echos, and error messages) to the chosen output device (e.g. disk, printer) as well as the console.
EVALUATE
Display the value of an expression in binary, octal, decimal, hexadecimal, and ASCII.

SUFFIXIBASE
Establish the default base for numeric values in input text/output display (binary, octal, decimal, or hexadecimal).
CLOCK
Select the internal (ICE-86 provided, for stand-alone mode only) or an external (user-provided) system clock.
RWTIMEOUT
Allows the user to time out READ/WRITE command signals based on the time taken by the 8086 to access Intellec memory or diskette memory.

## ENABLE/DISABLE RDY

Enable or disable logical AND of ICE-86 Ready with the user Ready signal for accessing Intellec memory, ICE memory, or diskette memory.

Table 2. Summary of Basic ICE-86 Interrogation and Utility Commands

## DIFFERENCES BETWEEN ICE-86 <br> EMULATION AND THE 8086 MICROPROCESSOR

The ICE-86 module emulates the actual operation of the 8086 microprocessor with the following exceptions:

- The ICE-86 module will not respond to a user system NMI or RESET signal when it is out of emulation.
- Trap is ignored in single step mode and on the first instruction step of an emulation.
- The MIN/MAX line, which chooses the "minimum" or "maximum" configuration of the 8086, must not change dynamically in the user system.
- In the "minimum" mode, the user HOLD signal must remain active until HLDA is output by the ICE-86 emulator.
- The $\overline{R Q} / \overline{\mathrm{GT}}$ lines in the "maximum" configuration are not supported.

The speed of run emulation by the ICE- 86 module depends on where the user has mapped his memory. As the user prototype progresses to include memory, emulation becomes real time.

| Memory Mapped To | Estimated Speed |
| :---: | :---: |
| User System | $100 \%$ of real time*, up to 4 MHz clock |
| ICE | 2 wait states per 8086-controlled bus cycle |
| Intellec | Approximately $0.02 \%$ of real time at 4 MHz clock |
| Diskette | ** |
| * $100 \%$ of real time is emulation at the user system clock rate with no wait states. <br> **The emulation speed from diskette is comparable to Intellec memory, but emulation must wait when a new page is accessed on the diskette. |  |
|  |  |

## DC CHARACTERISTICS OF 1CE- 86 USER CABLE

1. Output Low Voltages $\left[\mathrm{V}_{\mathrm{OL}}(\mathrm{Max})=0.4 \mathrm{~V}\right]$

AD0-AD15

( $24 \mathrm{~mA} @ 0.5 \mathrm{~V}$ )
A16/S3-A19/S7, $\overline{\mathrm{BHE}} / \mathrm{S} 7, \overline{\mathrm{RD}}$,
8 mA LOCK, QS0, QS1, $\overline{\mathrm{SO}}, \overline{\mathrm{S} 1, ~ \overline{S 2}}$, ( $16 \mathrm{~mA} @ 0.5 \mathrm{~V}$ ) $\overline{W R}, \mathrm{M} / \overline{\mathrm{IO}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{DEN}}, \mathrm{ALE}$, INTA

| HLDA | 7 mA |
| :--- | ---: |
| MATCH0 OR MATCH1 <br> buffer box) | 16 mA |

2. Output High Voltages $\left[\mathrm{V}_{\mathrm{OH}}(\mathrm{Min})=2.4 \mathrm{~V}\right]$

$$
\underline{\mathrm{IOH}}^{(\mathrm{Min})}
$$

AD0-AD15 -3 mA
A16/S3-A19/S7, $\overline{B H E} / \mathrm{S} 7, \overline{\mathrm{RD}}, \quad-2.6 \mathrm{~mA}$ $\overline{\text { LOCK }}, \mathrm{QS} 0, \mathrm{QS} 1, \overline{\mathrm{S0}}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 2}$, $\overline{W R}, \mathrm{M} / \overline{\mathrm{O}}, \mathrm{DT} / \overline{\mathrm{R}}, \overline{\mathrm{DEN}}, \mathrm{ALE}$, $\overline{\text { INTA }}$

| HLDA | -3.0 mA |
| :--- | :--- |
| MATCH0 OR MATCH1 <br> buffer box) | -0.8 mA |,

3. Input Low Voltages $\left[\mathrm{V}_{\mathrm{IL}}(\mathrm{Max})=0.8 \mathrm{~V}\right.$ ]

| (VIL | IIL (Max) |
| :---: | :---: |
| AD0.AD15 | -0.2 mA |
| NMI, CLK | $-0.4 \mathrm{~mA}$ |
| READY | -0.8 mA |
| INTR, HOLD, $\overline{\text { TEST, RESET }}$ | $-1.4 \mathrm{~mA}$ |
| $\mathrm{MN} / \overline{\mathrm{MX}}$ ( $0.1 \mu \mathrm{f}$ to GND) | -3.3 mA |

4. Input High Voltages $\left[\mathrm{V}_{\mathrm{IH}}(\mathrm{Min})=2.0 \mathrm{~V}\right]$

|  | $\frac{\mathbf{I}_{\mathbf{I H}}(\text { Max })}{}$ |
| :--- | :---: |
| AD0-AD15 | $20 \mu \mathrm{~A}$ |
| NMI, CLK | $20 \mu \mathrm{~A}$ |
| READY | -0.4 mA |
| INTR, HOLD, TEST, RESET | -1.1 mA |
| MN/MX $(0.1 \mu \mathrm{~F}$ to GND $)$ |  |

5. $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$ are pulled up to +5 V through a 5.6 K ohm resistor. No current is taken from user circuit at $V_{C C}$ pin.

## SPECIFICATIONS

## ICE-86 Operating Environment

## Required Hardware

Intellec microcomputer development system with:

1. Three adjacent slots for the ICE-86 module. (Series II requires MDS-201 Expansion Chassis).
2. 64 K bytes of Intellec memory. If user prototype program memory is desired, additional memory above the basic 64 K is required.
System console
Intellec diskette operating system
ICE-86 module

## Required Software

System monitor
ISIS-II, version 3.4 or subsequent
ICE-86 software

## Equipment Supplied

Printed circuit boards (3)
Interface cable and emulation buffer module Operator's manual
ICE-86 software, diskette-based

## Emulation Clock

User system clock up to 4 MHz or $2 \mathrm{MHz} \mid C E-86$ infernal clock in stand-alone mode

## Physical Characteristics

## Printed Circuit Boards

Width: 12.00 in ( 30.48 cm )
Height: 6.75 in ( 17.15 cm )
Depth: 0.50 in ( 1.27 cm )
Packaged Weight: $9.00 \mathrm{lb}(4.10 \mathrm{~kg})$

## Electrical Characteristics

## DC Power

$V_{C C}=+5 \mathrm{~V}+5 \%-4 \%$
$I_{C C}=15 \mathrm{~A}$ maximum; 11A typical
$V_{D D}=+12 \mathrm{~V} \pm 5 \%$
$\mathrm{I}_{\mathrm{DD}}=120 \mathrm{~mA}$ maximum; 80 mA typical
$V_{B B}=-10 \mathrm{~V} \pm 5 \%$ or $-12 \mathrm{~V} \pm 5 \%$ (optional)
$I_{B B}=15 \mathrm{~mA}$ maximum; 12 mA typical

## Environmental Characteristics

Operating Temperature: $0^{\circ}$ to $40^{\circ} \mathrm{C}$
Operating Humidity: Up to $95 \%$ relative humidity without condensation.

ORDERING INFORMATION

## Part Number Description

MDS-86-ICE $\quad 8086$ CPU in-circuit emulator

## EM1

8021 EMULATION BOARD

## EPROM functional equivalent of 8021 single component 8 -bit microcomputer

## Based on 8748 - user programmablel erasable EPROM 8-bit computer

## Operates with ICE-49 ${ }^{\text {TM }}$ to provide full in-circuit debugging of 8021 prototype system

Connects to prototype system through 8021 pin compatible plug

On-card 3.0 MHz or external TTL driven clock

Portable 4" $\times \mathbf{7 " ~}^{\prime \prime}$ microcomputer circuit assembly

The MDS-EM1 emulator board is a ready-to-use $4^{\prime \prime} \times 7^{\prime \prime}$ microcomputer circuit assembly that emulates the Intel 8021 microcomputer. A 12 -inch flat-cable assembly connects the board to the 8021 socket in a prototype system. The board is designed so that it can be mounted either as a stand-alone unit or within the prototype assembly.
The 8021 microcomputer has $1 \mathrm{~K} \times 8$ mask programmable ROM program memory and $64 \times 8$ RAM data memory. The EM1 is controlled by an Intel 8748, with 1K of EPROM program memory and a 64-byte data memory. The EPROM can be programmed and erased repeatedly during hardware and software development. The EM1 has several ancillary circuits that perform the following functions which are specific to the 8021:

Zero crossing detector
Crystal controlled clock/buffer
Port 0 simulator
For prototype debugging, the 8748 can be removed from its socket and replaced with a cable to an Intel ICE-49. When used with the EM1, ICE-49 emulates the 8021 in real time, or single steps the 8021 program at the user's command. A full range of capabilities for examining and modifying 8021 memory and status are supplied through ICE-49.


## HARDWARE

The EM1 emulation board uses the 8748 to perform the emulation.

## PO Simulator

Port 0 of the 8021 is a quasi-bidirectional* port. The P0 simulator converts the data bus of the 8748 into a quasibidirectional port.

## Crystal Control Clock Buffer

The EM1 allows the user to select an on-board oscillator or a TTL clock driven from the 8021 user's prototype system via a Cambion Suitcase jumper.

| Jumper | Position | State |
| :---: | :---: | :---: |
| W1 | A-B | On-Board |
|  | C-D | External |
|  |  | TTL Clock |

*A bidirectional port which serves as an input port, output port, or both, even though outputs are statically latched.

## Zero Cross Detection Simulator

The zero cross detection simulator enables the 8748's T1 input to detect zero-crossings. The circuitry provides a high level signal on a positive crossing and a low level signal on a negative crossing of zero to the T1 input of the 8748.

## Reset Buffer

The 8021 resets on a logic HIGH level signal. However, the 8748 resets on a logic LOW level, thus an inverter is provided on the MDS-EM1 to make the two chips compatible.

## Optional Pull Ups

Resistors are provided to simulate the optional pull-up resistors on T 1 input and port 0 of the 8021. A removable resistor pack is used on port 0 . The T1 input pull up can be installed by soldering in a 50 K resistor.

## SOFTWARE

When emulating the 8021 with EM1 the user must observe the 8021 instruction set.


## SPECIFICATIONS

## Operating Environment

Stand-Alone Required Hardware
EM1 emulation board
In-Circuit Emulation Required Hardware
EM1 emulation board
Intellec Microcomputer Development System configured to support ICE-49

## Equipment Supplied

EM1 printed circuit board
$12^{\prime \prime}$ long flat cable terminating in 28 -pin plug, pin compatible with 8021
EM1 Operator's Manual

## System Clock

Crystal controlled 3.0 MHz on board or user supplied TTL external clock: hardware jumper selectable

## Physical Characteristics

Width: 7.0 in . ( 17.78 cm )
Height: 4.0 in . $(10.16 \mathrm{~cm})$
Depth: $0.75 \mathrm{in} .(1.91 \mathrm{~cm})$
Weight: <1.0 lb ( 0.45 kg )

## Electrical Characteristics

DC Power
$V_{C C}=5 \mathrm{~V} \pm 5 \%$
$\mathrm{I}_{\mathrm{CC}}=300 \mathrm{~mA}$ (max)

## Environmental Characteristics

Operating Temperature $-0^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}$
Operating Humidity—Up to $95 \%$ relative humidity without condensation

## ORDERING INFORMATION

## Part Number Description

MDS-EM1 8021 Emulation Board

## intel

## EM2 <br> 8022 EMULATION BOARD

Portable 4.25" $\times 2.75^{\prime \prime}$ microcomputer circuit assembly

Connects directly into prototype system through Intel ${ }^{\circledR}$ 8022* pin compatible socket

Provides Intel ${ }^{\circledR}$ 8755A $-2 \mathrm{~K} \times 8$ EPROM

EPROM functional and electrical equivalent of Intel 8022 - single component 8 -bit computer

The EM2 emulator board is a ready-to-use $4.2^{\prime \prime} \times 2.75^{\prime \prime}$ microcomputer circuit assembly that emulates the Intel ${ }^{\circledR} 8022$ single chip microcomputer. The emulator board is designed to plug directly into the 8022 socket. No interfacing and interconnection cables are necessary. Power is obtained from the user's system.
The EM2 emulator board provides the user a full EPROM functional and electrical equivalent of the 8022 single component 8-bit microcomputer.

The EM2 emulator board consists of an Inte ${ }^{\circledR 3} 8022$ emulator chip and an Intel ${ }^{\circledR}$ 8755A, providing the EM2 emulator board with a $2 \mathrm{~K} \times 8$ EPROM program memory which can be programmed and erased repeatedly during hardware and software development.

The 8022E emulator chip is a modified version of the 8022 intended for use in design support systems. Instead of using resident ROM memory as the 8022, the 8022E uses an external 2K EPROM 8755A memory for program storage, allowing easy program modification.
*See Intel ${ }^{\circledR} 8022$ Data Sheet.



## PIN DESCRIPTION

Designation

Pin \#
Function
$V_{\text {SS }} \quad 20$ Circuit GND potential.
$V_{C C} \quad 40+5 \mathrm{~V}$ circuit power supply.
PROG 37 Output strobe for Intel ${ }^{\circledR} 8243$ I/O expander.

P00-P07 10-17 8-bit open-drain port with comparator

Port 0
$V_{\text {TH }} 9 \quad$ Port 0 threshold reference pin.
P10-P17 25-32 8-bit quasi-bidirectional port.
Port 1
P20-P27 33-36 8-bit quasi-bidirectional port.
Port 2 38-39 P20-P23 also serve as a 4-bit I/O ex-1-2 pander for Intel ${ }^{\circledR} 8243$.

TO 8 Interrupt input and input pin testable using the conditional transfer instructions JTO and JNTO. Initiates an interrupt following a low level input if interrupt is enabled. Interrupt is disabled after a reset.
T1 19 Input pin testable using the JT1 and JNT1 conditional transfer instructions. Can be designated the timerlevent counter input using the STRT CNT instruction. Also serves as the zero-cross detection input to allow zero-crossover sensing of slowly moving AC inputs. Optional pull-up resistor may be added via ROM mask selection.

Desig-
nation Pin \# Function

RESET 24 Input used to initialize the processor by clearing status flip-flops and setting the program counter to zero.
$\mathrm{AV}_{\mathrm{SS}} 7$ A/D converter GND potential. Also establishes the lower limit of the conversion range.
$\mathrm{AV}_{\mathrm{CC}} 3 \mathrm{~A} / \mathrm{D}+5 \mathrm{~V}$ power supply.

SUBST 21 Substrate pin used with a bypass capacitor to stabilize the substrate voltage and improve A/D accuracy.
$V_{\text {AREF }} 4$ A/D converter reference voltage. Establishes the upper limit of the conversion range.

ANO,
AN1

ALE 18 Address Latch Enable. Signal occurring once every 30 input input clocks (once every single cycle instruction), used as an output clock.

XTAL1 22 One side of crystal, inductor, or resistor input for internal oscillator. Also input for external frequency source. (Not TTL compatible.)

XTAL2 23 Other side of timing control element. This pin is not connected when an external frequency source is used.

## On the EM2 Board:

The Intel ${ }^{\circledR}$ 8755A EPROM can be programmed using any of the modules listed in Table 1.

| Module | Description |
| :---: | :--- |
| UPP-103 | Universal PROM Programmer. <br> Requires UPP-955, which in- <br> cludes 8755A Personality Card <br> with 40-pin adapter socket. <br> PROMPT-48 <br> Intellec® MCS-48 Microcom- <br> puter Design Aid. Requires <br> PROMPT-475 Programming <br> Adapter. <br> Intellec® 8080/8085 Microcom- <br> PROMPT-80/85 <br> puter Design Aid. Requires <br> PROMPT-975 Programming <br> Adapter. |

Table 1. 8755A Proramming Module

The 8755A EPROM is erased when exposed fo light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). Sunlight and certain fluorescent lamps have wavelengths in the $3000 \AA$ to $4000 \AA$ range. If the $8755 A$ is to be exposed to sunlight or room fluorescent lighting for extended periods, then opaque labels should be placed over the window to prevent unintentional erasure.

The recommended erasure procedure is exposure to ultraviolet light which has a wavelength of $2537 \AA$. The integrated dose (UV intensity multiplied by exposure time) for erasure should be a minimum of 15 W -sec/cm. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with a $12,000 \mu$ W/em ${ }^{2}$ power rating. Place the 8755A within one inch of the lamp during erasure. Some lamps include a filter which should be removed before erasure.

## SPECIFICATIONS

## Operating Environment <br> Intel ${ }^{\circledR}$ 8755A EPROM Programming

UPP-103
PROMPT-48
PROMPT-80/85

## Intellec Microcomputer Development System

## Software

8048 Assembler
ISIS-II Diskette Operating System
Equipment Supplied
EM2 Printed Circuit Board
EM2 Reference Manual

## Physical Characteristics

Width: 2.75 in. ( 6.98 cm )
Height: $4.25 \mathrm{in} .(10.79 \mathrm{~cm})$
Depth: $1.5 \mathrm{in} .(3.81 \mathrm{~cm})$
Weight: $0.5 \mathrm{lb}(0.23 \mathrm{~kg})$

## Electrical Characteristics

## DC Power

$V_{C C}=5 \mathrm{~V} \pm 5 \%$
$\mathrm{I}_{\mathrm{CC}}=300 \mathrm{~mA}$ (maximum)

## Environmental Characteristics

Operating Temperature -0 to $55^{\circ} \mathrm{C}$
Operating Humidity - Up to $95 \%$ relative humidity without condensation

## ORDERING INFORMATION

Part Number Description<br>MDS-EM2 8022 Emulation Board

## intel

*Replaces UPP.101, UPP. 102 Universal PROM Programmers

Intellec development system peripheral for PROM programming and verification

Provides personality cards for programming all Intel PROM families

Provides zero insertion force sockets for both 16 -pin and 24 -pin PROMs

Universal PROM mapper software provides powerful data manipulation and programming commands

Provides flexible power source for system logic and programming pulse generation

Holds two personality cards to facilitate programming operations using several PROM types

The UPP-103 Universal PROM Programmer is an Intellec system peripheral capable of programming and verifying the following Intel programmable ROMs (PROMs): 1702A, 2704, 2708, 2716, 3601, 8702A, 8704, and 8708. In addition, the UPP-103 programs the PROM memory portions of the 8748 microcomputer and the 8755 PROM and I/O chip. Programming and verification operations are initiated from the Intellec development system console and are controlled by the universal PROM mapper (UPM) program.


## FUNCTIONAL DESCRIPTION

## Universal PROM Programmer

The basic Universal PROM Programmer (UPP) consists of a controller module, two personality card sockets, a front panel, power supplies, a chassis, and an Intellec development system interconnection cable. An Intel 4040-based intelligent controller monitors the commands from the Intellec System and controls the data transfer interface between the selected PROM personality card and the Intellec memory. A unique personality card contains the appropriate pulse generation functions for each Intel PROM family. Programming and verifying any Intel PROM may be accomplished by selecting and plugging in the appropriate personality card. The front panel contains a power-on switch and indicator, a reset switch, and two zero-force insertion sockets (one 16 -pin and one 24 -pin or two 24 -pin). A central power supply provides power for system logic and for PROM programming pulse generation. The Universal PROM Programmer may be used as a table top unit or mounted in a standard 19 -inch RETMA cabinet.

## Universal PROM Mapper

The Universal PROM Mapper (UPM) is the software program used to control data transfer between paper tape
or diskette files and a PROM plugged into the Universal PROM Programmer. It uses Intellec system memory for intermediate storage. The UPM transfers data in 8-bit HEX, BNPF, or binary object format between paper tape or diskette files and the Intellec system memory. While the data is in Intellec system memory, it can be displayed and changed. In addition, word length, bit position, and data sense can be adjusted as required for the PROM to be programmed. PROMs may also be duplicated or altered by copying the PROM contents into the Intellec system memory. Easy to use program and compare commands give the user complete control over programming and verification operations. The UPM eliminates the need for a variety of personalized PROM programming routines because it contains the programming algorithms for all Intel PROM families.

## Optional Versions

There are two versions of the UPM: one that runs under the Intellec system monitor (paper tape system), and one that runs under ISIS-II, the Intellec diskette operating system (diskette-based system). The paper tape version is included with the Universal PROM Programmer. The diskette-based version of the UPM is available on all ISIS-II system diskettes.

## SPECIFICATIONS

## Hardware Interface

Data - Two 8-bit unidirectional buses
Commands - 3 write commands, 2 read commands, one initiate command

## Physical Characteristics

Width - $6 \mathrm{in} .(14.7 \mathrm{~cm})$
Height - $7 \mathrm{in} .(17.2 \mathrm{~cm})$
Depth - $17 \mathrm{in} .(41.7 \mathrm{~cm})$
Weight - $18 \mathrm{lb}(8.2 \mathrm{~kg})$

## Electrical Characteristics

AC Power Requirements $-50-60 \mathrm{~Hz} ; 115 / 230 \mathrm{~V}$ AC: 80 W
Environmental Characteristics
Operating Temperature $-0^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}$

## Optional Equipment

Personality Cards
UPP-361: 3601 personality card
UPP-816: 2716 personality card
UPP-832: 2732 personality card
UPP-848: 8748 personality card with 40-pin adaptor socket
UPP-855: 8755 personality card with 40 -pin adaptor socket
UPP-865: 3602, 3622, 3602A, 3622A, 3621, 3604, 3624,

3604A, 3624A, 3604AL, 36046-6, 3605, 3625, 3608, 3628
UPP-872: 8702A/1702A personality card
UPP-878: 8708/8704/2708/2704 personality card

## PROM Programming Sockets

UPP-501: 16-pin/24-pin socket pair
UPP-502: 24-pin/24-pin socket pair
UPP-562: Socket adaptor for 3621, 3602, 3622, 3602A, 3622A
UPP-555: Socket adaptor for 3604AL, 36046-6, 3608, 3628
UPP-566: Socket adaptor for 3605,3625

## Equipment Supplied <br> Cabinet

Power supplies
4040 intelligent controller module
Specified zero insertion force socket pair
Intellec development system interface cable
Universal PROM Mapper program (paper tape version -disk-based version available on ISIS-II diskettes)

## Reference Manuals

9800133 - Universal PROM Programmer Hardware Reference Manual (SUPPLIED)
9800554 - Intellec Series II Schematics Drawings
(SUPPLIED)
9800819 - Universal PROM Programmer User's Manual (SUPPLIED)

## ORDERING INFORMATION

## Part Number Description

UPP-103 Universal PROM programmer with
16-pin/24-pin socket pair and
24-pin/24-pin socket pair

## intel

 MCS-85 SYSTEM DESIGN KITComplete single board microcomputer system including CPU, memory, and I/O

Easy to assemble, low cost, kit form
Extensive system monitor software in
ROM

Interactive LED display and keyboard

Large wire-wrap area for custom interfaces

Popular 8080A instruction set
Interfaces directly with TTY
High performance 3 MHz 8085A CPU (1.3 $\mu$ s instruction cycle)

## Comprehensive design library included

The SDK-85 MCS-85 System Design Kit is a complete single board microcomputer system in kit form. It contains all components required to complete construction of the kit, including LED display, keyboard, resistors, caps, crystal, and miscellaneous hardware. Included is a preprogrammed ROM containing a system monitor for general software utilities and system diagnostics. The complete kit includes a 6-digit LED display and a $24-k e y$ keyboard for a direct insertion, examination, and execution of a user's program. In addition, it can be directly interfaced with a teletype terminal. The SDK-85 is an inexpensive, high performance prototype system that has designed-in flexibility for simple interface to the user's application.


## FUNCTIONAL DESCRIPTION

The SDK-85 is a complete 8085A microcomputer system on a single board, in kit form. It contains all necessary components to build a useful, functional system. Such items as resistors, capacitors, and sockets are included. Assembly time varies from three to five hours, depending on the skill of the user. The SDK-85 functional block diagram is shown in Figure 1.

## 8085A Processor

The SDK-85 is designed around Intel's 8085A microprocessor. The Intel 8085A is a new generation, complete 8 -bit parallel central processing unit (CPU). Its instruction set is $100 \%$ software upward compatible with the 8080A microprocessor, and it is designed to improve the present 8080A's performance by higher system speed. Its high level of system integration allows a minimum system of three IC's: 8085A (CPU), 8156 (RAM), and 8355/8755 (ROM/PROM). A block diagram of the 8085A microprocessor is shown in Figure 2.

System Integration - The 8085A incorporates all of the features that the 8224 (clock generator) and 8228 (system controller) provided for the 8080 A , thereby offering a high level of system integration.

Addressing - The 8085A uses a multiplexed data bus. The 16 -bit address is split between the 8 -bit address bus and the 8 -bit address/data bus. The on-chip address latches of 8155/8156/8355/8755 memory products allows a direct interface with the 8085A.

## System Monitor

A compact but powerful system monitor is supplied with the SDK-85 to provide general software utilities and system diagnostics. It comes in a pre-programmed ROM.

## Communications Interface

The SDK-85 communicates with the outside world through either the on-board LED display/keyboard combination, or the user's TTY terminal (jumper selectable).


Figure 1. SDK-85 System Design Kit Functional Block Diagram


Figure 2. 8085A Microprocessor Block Diagram

Both memory and I/O can be easily expanded by simply soldering in additional devices in locations provided for this purpose. A large area of the board ( 45 sq . in.) is laid out as general purpose wire-wrap for the user's custom interfaces.

## Assembly

Only a few simple tools are required for assembly; soldering iron, cutters, screwdriver, etc. The SDK-85 user's manual contains step-by-step instructions for easy assembly without mistakes. Once construction is complete, the user connects his kit to a power supply and the SDK-85 is ready to go. The monitor starts immediately upon power-on or reset.

| Command | Operation |
| :--- | :--- |
| Reset | Starts monitor. <br> Go <br> Allows user to execute user pro- <br> gram. <br> Allows user to execute user pro- <br> gram one instruction at a time- <br> useful for debugging. <br> Substitute memory <br> Allows user to examine and <br> modify memory locations. <br> Allows user to examine and <br> modify 8085A's register con- <br> tents. |
| Vector interrupt | Serves as user interrupt button. |

Table 1. Keyboard Monitor Commands.

Commands - Keyboard monitor commands and teletype monitor commands are provided in Table 1 and Table 2, respectively.

| Command | Operation |
| :---: | :--- |
| Display memory | Displays multiple memory loca- <br> tions. <br> Substitute memory <br> Allows user to examine and <br> modify memory locations one <br> at a time. <br> Insert instructions <br> Allows user to store multiple <br> bytes in memory. <br> Allows user to move blocks of <br> data in memory. <br> Allows user to examine and <br> modify the 8085A's register <br> contents. <br> Allows user to execute user <br> programs. |
| Go | Gxamine register |

Table 2. Teletype Monitor Commands

## Documentation

In addition to detailed information on using the monitors, the SDK-85 user's manual provides circuit diagrams, a monitor listing, and a description of how the system works. The complete design library for the SDK-85 is shown in Figure 3 and listed in the Specifications section under Reference Manuals.


Figure 3. SDK-85 Design Library

## 8085A INSTRUCTION SET

Table 3 contains a summary of processor instructions used for the 8085A microprocessor.

| Mnemonic | Description | Instruction Code ${ }^{2}$ |  |  |  |  |  |  |  |  |  | Clock ${ }^{3}$ Cycles | Mnemonic ${ }^{1}$ | Description | Instruction Code ${ }^{2}$ |  |  |  |  |  |  |  | Clock ${ }^{3}$ <br> Cycles |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $D_{7} D_{6} \quad D_{5} D_{4} \quad D_{3} D_{2} D_{1} D_{0}$ |  |  |  |  |  |  |  |  |  |  |  |  | $\mathrm{D}_{7}$ |  | $\mathrm{D}_{5}$ |  |  |  |  | $\mathrm{D}_{0}$ |  |
| MOVE, LOAD, AND STORE |  |  |  |  |  |  |  |  |  |  |  |  | LXI SP | Load immediate stack pointer | 0 |  | 1 |  | 0 | 0 |  | 1 | 10 |
| MOVr1r2 | Move register to register Move register to memory | 0 |  | D |  | D |  | S | $\begin{aligned} & \mathrm{s} \\ & \mathrm{~s} \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| MOV M.r |  | 0 | 1 |  | 1 | 1 | 0 | S |  |  |  | 7 | INX SP DCX SP | Increment stack pointer |  |  | 1 | 1 | 0 | 0 | 11 |  | 6 |
| MOV r.M | Move memory to register | 0 | 1 |  | D | D | D | 1 | 1 |  | 0 | 7 |  | Decrement stack | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 6 |
| MVI r | Move immediate register | 0 | 0 |  | D | D | D | 1 | 1 |  | 0 | 7 |  |  |  |  |  |  |  |  |  |  |  |
| MVI M | Move immediate memory | 0 | 0 |  | 1 | 1 | 0 | 1 | 1 |  | 0 | 10 | JUMP |  |  |  |  |  |  |  |  |  |  |
| LXIB | Load immediate register Pair B \& C | 0 | 0 |  | 0 | 0 | 0 | 0 | 0 |  | 1 | 10 | JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | $10$ |
|  |  |  |  |  |  |  |  |  |  |  |  |  | JC | Jump on carry | 1 | 1 | $0$ | 1 | $1$ | 0 | $1$ | $0$ | $7 / 10$ |
| LXI D | Load immediate register Pair D \& E | 0 | 0 |  | 0 | 1 | 0 | 0 | 0 |  |  | 10 | JNC | Jump on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| LXIH | Load immediate register | 0 | 0 |  | 1 | 0 | 0 | 0 | 0 |  | 1 | 10 | JZ | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 7110 |
|  | Pair H\&L |  |  |  |  |  |  |  |  |  |  |  | JNZ | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| StaX B | Store A indirect | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  | 0 | 7 | JP | Jump on positive | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 7/10 |
| STAX D | Store A indirect | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |  | 0 | 7 | JM | Jump on minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 7/10 |
| LDAX B | Load A indirect | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |  | 0 | 7 | JPE | Jump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 7/10 |
| LDAX D | Load A indirect | 0 | 0 |  | 0 | 1 | 1 | 0 | 1 |  | 0 | 7 | JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 7/10 |
| STA | Store A direct | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 |  | 0 | 13 | PCHL | H\&L to program | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 6 |
| LDA | Load A direct | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 |  | 0 | 13 |  |  |  |  |  |  |  |  |  |  |  |
| SHLD | Store H \& L direct | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 |  | 0 | 16 | CALL |  |  |  |  |  |  |  |  |  |  |
| LHLD | Load H\& L direct | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |  | 0 | 16 | CALL | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 18 |
| XCHG | Exchange D \& E, H \& L registers | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |  | 1 | 4 | CC | Call on carry | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 9/18 |
| STACK OPS |  |  |  |  |  |  |  |  |  |  |  |  | CNC | Call on no carry | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 9/18 |
|  |  | 1 |  | 0 |  |  |  |  |  |  |  |  | Cz | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| PUSH 8 | on stack | 1 | 1 |  |  | 0 | 0 | 1 | 0 |  |  | 12 | CNZ | Call on no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 9/18 |
| PUSH D | Push register pair D \& E on stack | 1 | 1 | 0 | - | 1 | 0 | 1 | 0 | 1 | 1 | 12 |  | Call on positive | 1 |  | 1 |  | 0 | 1 | 0 | 0 | $9 / 18$ $9 / 18$ |
| PUSH H | Push register pair H \& L | 1 | 1 | 1 | 10 | 0 | 0 | 1 | 0 |  |  |  |  | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 9/1 |
| PUSH | on stack | 1 | 1 | 1 |  | 0 | 0 | 1 | 0 |  |  | 12 | CPE | Call on parity even | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 9/18 |
| PUSH PSW | Push A and flags on stack | 1 | 1 | 1 |  | 1 | 0 | 1 | 0 | 1 |  | 12 | RETURN | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 9/18 |
| POP B | Pop register pair B \& C off stack | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  | 10 | RET | Return | 1 |  | $0$ |  | 1 |  |  | 1 | $10$ |
| POP D | Pop register pair D \& E off stack | 1 | 1 | 0 | - | 1 | 0 | 0 | 0 | 1 |  | 10 | RNC | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| POP H | Pop register pair H \& L off stack | 1 | 1 | 1 | 10 | 0 | 0 | 0 | 0 |  |  | 10 | RZ RNZ | Return on zero Return on no zero | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | $6 / 12$ $6 / 12$ |
| POP PSW | Pop $A$ and flags off stack | 1 | 1 | 1 |  | 1 |  |  | 0 |  |  | 10 | $\begin{aligned} & \text { RP } \\ & \text { RM } \end{aligned}$ | Return on positive Return on minus | 1 | 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 1 | 0 | 0 | 0 | $\begin{aligned} & 6 / 12 \\ & 6 / 12 \end{aligned}$ |
| XTHL | Exchange top of stack H\&L | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |  |  | 16 |  |  |  |  |  |  |  |  |  |  |  |
| SPHL | H\& L to stack pointer | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |  | 6 |  |  |  |  |  |  |  |  |  |  |  |



Table 3. Summary of 8085A Processor Instructions

## SPECIFICATIONS

Central Processor
CPU - 8085A
Instruction Cycle - $1.3 \mu \mathrm{~s}$
Tcy - 330 ns

## Memory

ROM - 2 K bytes (expandable to 4 K bytes) 8355/8755A
RAM - 256 bytes (expandable to 512 bytes) 8155

## Addressing

ROM - 0000-07FF (expendable to OFFF with an additional 8355/8755A)
RAM - 2000-20FF ( $2800-28 \mathrm{FF}$ available with an additional 8155)

## Note

The wire-wrap area of the SDK-85 PC board may be used for additional custom memory expansion up to the 64 K -byte addressing limit of the 8085A.

## Input/Output

Parallel - 38 lines (expandable to 76 lines)
Serial - Through SID/SOD ports of 8085A. Software generated baud rate.
Baud Rate - 110

## Interfaces

Bus - All signals TTL compatible
Parallel I/O - All signals TTL compatible
Serial I/O - 20 mA current loop TTY

## Note

By populating the buffer area of the board, the user has access to all bus signals that enable him to design custom system expansions into the kit's wire-wrap area.

## Interrupts

Three Levels
(RST 7.5) - Keyboard interrupt
(RST 6.5) - TTL input
(INTR) - TTL input

## DMA

Hold Request - Jumper selectable. TTL compatible input.

## Software

System Monitor - Pre-programmed 8755A or 8355 ROM
Addresses - 0000-07FF
Monitor I/O - Keyboard/display or TTY (serial I/O)

## Physical Characteristics

Width - $12.0 \mathrm{in} .(30.5 \mathrm{~cm})$
Height - $10 \mathrm{in} .(25.4 \mathrm{~cm})$
Depth - $0.50 \mathrm{in} .(1.27 \mathrm{~cm})$
Weight - approx. 12 oz

## Electrical Characteristics

DC Power Requirement (power supply not included in kit)

| Voltage | Current |
| :---: | :---: |
| $\mathrm{V}_{\text {CC }} 5 \mathrm{~V} \pm 5 \%$ | 1.3 A |
| $\mathrm{~V}_{\text {TTY }}-10 \mathrm{~V} \pm 10 \%$ | 0.3 A |
|  | ( $\mathrm{V}_{\text {TTY }}$ required only if teletype <br> is connected) |

## Environmental Characteristics <br> Operating Temperature $-0.55^{\circ} \mathrm{C}$

Reference Manuals
9800451 - SDK-85 User's Manual (SUPPLIED)
9800366 - MCS-85 User's Manual (SUPPLIED)
9800301 - 8080/8085 Assembly Language Programming Manual (SUPPLIED)
8085/8080 Assembly Language Reference Card (SUP. PLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

## Part Number Description

SDK-85
MCS-85 system design kit

## SDK-86 <br> MCS-86 SYSTEM DESIGN KIT

## Complete single board microcomputer system including CPU, memory, and I/O

## Easy to assemble kit form

## High performance 8086 16-bit CPU

## Interfaces directly with TTY or CRT

## Interactive LED display and keyboard

Wire wrap area for custom interfaces

## Extensive system monitor software in ROM

Comprehensive design library included

The SDK-86 MCS-86 System Design Kit is a complete single board 8086 microcomputer system in kit form. It contains all necessary components to complete construction of the kit, including LED display, keyboard, resistors, caps, crystal, and miscellaneous hardware. Included are preprogrammed ROMs containing a system monitor for general software utilities and system diagnostics. The complete kit includes an 8-digit LED display and a mnemonic 24-key keyboard for direct insertion, examination, and execution of a user's program. In addition, it can be directly interfaced with a teletype terminal, CRT terminal, or the serial port of an Intellec system. The SDK-86 is a high performance prototype system with designed-in flexibility for simple interface to the user's application.


## FUNCTIONAL DESCRIPTION

The SDK-86 is a complete MCS-86 microcomputer system on a single board, in kit form. It contains all necessary components to build a useful, functional system. Such items as resistors, caps, and sockets are included. Assembly time varies from 4 to 10 hours, depending on the skill of the user. The SDK-86 functional block diagram is shown in Figure 1.

## 8086 Processor

The SDK-86 is designed around Intel's 8086 microprocessor. The Intel 8086 is a new generation, high performance microprocessor implemented in N -channel, depletion load, silicon gate technology (HMOS), and packaged in a 40-pin CerDIP package. The processor features attributes of both 8 -bit and 16 -bit microprocessors in that it addresses memory as a sequence of 8 -bit bytes, but has a 16 -bit wide physical path to memory for high performance. Additional features of the 8086 include the following:

- Direct addressing capability to one megabyte of memory
- Assembly language compatibility with 8080/8085
- 14 word $\times 16$-bit register set with symmetrical operations
- 24 operand addressing modes
- Bit, byte, word, and block operations
- 8 and 16 -byte signed and unsigned arithmetic in binary or decimal mode, including multiply and divide
- 5 MHz clock rate
- MULTIBUS compatible system interface

A block diagram of the 8086 microprocessor is shown in Figure 2.

## System Monitor

A compact but powerful system monitor is supplied with the SDK-86 to provide general software utilities and system diagnostics. It comes in preprogrammed read only memories (ROMs).

## Communications Interface

The SDK-86 communicates with the outside world through either the on-board light emitting diode (LED) display/keyboard combination or the user's TTY or CRT terminal (jumper selectable), or by means of a special mode in which an Intellec development system transports finished programs to and from the SDK-86. Memory may be easily expanded by simply soldering in additional devices in locations provided for this purpose. A large area of the board (22 square inches) is laid out as general purpose wire-wrap for the user's custom interfaces.

## Assembly

Only a few simple tools are required for assembly: soldering iron, cutters, screwdriver, etc. The SDK-86 assembly manual contains step-by-step instructions for easy assembly with a minimum of mistakes. Once construction is complete, the user connects his kit to a power supply and the SDK-86 is ready to go. The monitor starts immediately upon power-on or reset.
Commands - Keyboard mode commands, serial port commands, and Intellec slave mode commands are summarized in Table 1, Table 2, and Table 3, respectively. The SDK-86 keyboard is shown in Figure 3.


Figure 1. SDK-86 System Design Kit Functional Block Diagram


Figure 2. 8086 Microprocessor Block Diagram


Figure 3. SDK-86 Keyboard

## Documentation

In addition to detailed information on using the monitors, the SDK-86 user's manual provides circuit diagrams, a monitor listing, and a description of how the system works. The complete design library for the SDK-86 is shown in Figure 4 and listed in the Specifications section under Reference Manuals.


Figure 4. SDK-86 Design Library

| Command | Operation |
| :--- | :--- |
| $\begin{array}{l}\text { Reset } \\ \text { Go }\end{array}$ | $\begin{array}{l}\text { Starts monitor. } \\ \text { Allows user to execute user pro- } \\ \text { gram, and causes it to halt at prede- } \\ \text { termined program stop. Useful for } \\ \text { debugging. } \\ \text { Allows user to execute user pro- } \\ \text { gram one instruction at a time. Use- } \\ \text { ful for debugging. }\end{array}$ |
| Substitute | $\begin{array}{l}\text { Allows user to examine and modify } \\ \text { memory locations in byte or word } \\ \text { memory } \\ \text { Exade. } \\ \text { Allows user to examine and modify } \\ \text { 8086 register contents. } \\ \text { Allows user to relocate program } \\ \text { and data portions in memory. } \\ \text { Alock move }\end{array}$ |
| Input or output |  |
| Allows direct control of SDK-86 I/O |  |$\}$

Table 1. Keyboard Mode Commands

| Command | Operation |
| :--- | :--- |
| Dump memory | Allows user to print or display large <br> blocks of memory information in <br> hex format than amount visible on <br> terminal's CRT display. |
| Start/continue |  |
| display | Allows user to display blocks of <br> memory information larger than <br> amount visible on terminal's CRT <br> display. |
| Punch/read | Allows user to transmit finished <br> programs into and out of SDK-86 via <br> TTY paper tape punch. |

Table 2. Serial Mode Commands

| Command | Operation |
| :--- | :--- |
| Up/download | Allows user to transport finished pro- <br> grams between Intellec and SDK-86, <br> using special Intellec utility program. |
| Note <br> The Intellec slave mode utilizes all the keyboard mode commands <br> and serial mode commands (listed in Tables 1 and 2, respectively), as <br> well as the up/download slave mode command, via the console of <br> the Intellect development system, using the SDK-C86 product. |  |

Table 3. Intellec Slave Mode Commands

## 8086 INSTRUCTION SET

Table 4 contains a summary of processor instructions used for the 8086 microprocessor.



Table 4. $\mathbf{8 0 8 6}$ Instruction Set Summary

## SPECIFICATIONS

## Central Processor

CPU - 8086-4
Note
May be operated at 2.5 MHz or 5 MHz , jumper selectable, for use with 8086.

## Memory

ROM - 8K bytes 2316/2716
RAM - 2K bytes (expandable to 4 K bytes) 2142

## Addressing

ROM - FE000-FFFFF
RAM - 0-7FF (800-FFF available with additional 2142's)

## Note

The wire-wrap area of the SDK-86 PC board may be used for additional custom memory expansion.

## Input/Output

Parallel - 48 lines (two 8255A's)
Serial - RS232 or current loop (8251A)
Baud Rate - selectable from 110 to 4800 baud

## Interfaces

Bus - All signals TTL compatible
Parallel I/O - All signals TTL compatible
Serial IIO - 20 mA current loop TTY or RS232
Note
The user has access to all bus signals which enable him to design custom system expansions into the kit's wire-wrap area.

Interrupts (256 vectored)
Maskable Non-maskable TRAP

## DMA

Hold Request - Jumper selectable. TTL compatible input.

## Software

System Monitor - Preprogrammed 2716 or 2316 ROMs
Addresses - FE000-FFFFF
Monitor I/O — Keyboard/display or TTY or CRT (serial I/O)

## Physical Characteristics

Width - 13.5 in . $(34.3 \mathrm{~cm})$
Height - $12 \mathrm{in} .(30.5 \mathrm{~cm})$
Depth - $1.75 \mathrm{in} .(4.45 \mathrm{~cm}$ )
Weight - approx. $24 \mathrm{oz} .(3.3 \mathrm{~kg}$ )

## Electrical Characteristics

DC Power Requirement
(Power supply not included in kit)

| Voltage | Current |
| :---: | :---: |
| $V_{C C} 5 \mathrm{~V} \pm 5 \%$ | 3.5 A |
| $V_{T T Y}-12 \mathrm{~V} \pm 10 \%$ | 0.3 A |
|  | (VTTY required only if teletype is connected) |

## Environmental Characteristics

Operating Temperature $-0-50^{\circ} \mathrm{C}$

## Reference Manuals

9800697A - SDK-86 MCS-86 System Design Kit Assembly Manual
9800722 - MCS-86 User's Manual
9800640A - 8086 Assembly Language Programming Manual
8086 Assembly Language Reference Card
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

## Part Number Description

SDK-86 MCS-86 system design kit

SDK-C86

## MCS-86"' SYSTEM DESIGN KIT SOFTWARE AND CABLE INTERFACE TO INTELLEC ${ }^{*}$ DEVELOPMENT SYSTEM

- Provides the Software and Hardware Communications Link Between an Intellec ${ }^{\circledR}$ Development System and the SDK-86
- Intellec ${ }^{\circledR}$ System Files can be Accessed and Down loaded to the SDK-86 Resident Memory
- Data in SDK-86 Memory can be Uploaded and Saved in Intellec ${ }^{\circledR}$ System Files
- Enhances and Extends the Power and Usefulness of the SDK-86
- Allows the SDK-86 to Become an Execution Vehicle for ISIS-II Developed 8086 Object Code Using the MDS-311 Software Cross Development Package
- All SDK-86 Serial Port Mode Commands Become Available at Console of the Intellec ${ }^{\circledR}$ System

The SDK-C86 product provides the software and hardware link for using the SDK-86 monitor in conjunction with an Intellec ${ }^{\circledR}$ Development System while adding features of data transfer between SDK-86 memory and Intellec ${ }^{\circledR}$ System files. The user may enter programs and data into the SDK-86 and then save them on a diskette. Also, programs and data may be created on the Intellec ${ }^{\circledR}$ System using the MDS-311 cross development software package, then loaded into the SDK-86 for testing and checkout. This provides a real time execution environment of the SDK-86 as a peripheral to the Intellec ${ }^{\text {® }}$ System.


## HARDWARE

There are two serial ports on the Intellec ${ }^{\circledR}$ System back panel, TTY and CRT. Assuming that one of the ports is used for the Intellec ${ }^{\circledR}$ console, the SDK-C86 cable can plug into the unused port. The SDK-86 is jumper selectable to accept either the CRT (RS232) or TTY ( 20 mA current loop) signals.

The edge connector on the SDK-86 has the MULTIBUS ${ }^{\text {TM }}$ form factor. No signals are connected to the fingers except the power supply traces. Therefore, the SDK-86 can plug directly into the Intellec ${ }^{\circledR}$ motherboard to obtain power while using the SDK-C86 cable as the communication link.

## SOFTWARE

Two programs must be invoked to operate in the SDK-86 slave mode. One program runs on the SDK-86, and another runs in any ISIS-II environment that includes a diskette drive.

The serial I/O monitor is installed on the SDK-86 and operates as though it was talking to a terminal. The software in the Intellec ${ }^{\circledR}$ allows the Intellec ${ }^{\circledR}$, with a console device, to behave as if it were a terminal to the SDK-86.
The SDK-C86 software program in the Intellec reads the console input device, then passes the character to the SDK-86 through the serial port. It also receives the characters from the SDK-86 and displays them at the console output device. Besides the basic transfer function, this program also recognizes and performs the Upload and Download functions.

## COMMAND MODES

- Transparent: In this mode, the SDK-C86 software passes all characters through without any processing. All the commands of the SDK-86 monitor (except paper tape commands) are available and will function in exactly the same manner as if the terminal were attached directly to the serial port of the SDK-86.
- Upload/Download: In this mode the SDK-C86 software, in the Intellec ${ }^{\circledR}$, recognizes the mnemonic for Upload or Download from the terminal. It "translates" the Download command to an R (Read hexadecimal tape) command and the Upload command to a W (Write hexadecimal tape). The R and W commands are then passed on to the SDK-86 monitor. Using these paper tape commands allows for a checksummed transfer of data between the Intellec ${ }^{\circledR}$ and the SDK-86 memory.


## COMMAND SUMMARY

- Reset - starts the SDK-86 monitor.
- Execute with Breakpoint (G) - Allows you to execute a user program and cause it to halt at a predetermined program step - useful for debugging.
- Single Step (N) - allows you to execute a user program one instruction at a time - useful for debugging.
- Substitute Memory (S, SW) - allows you to examine and modify memory locations in byte or word mode.
- Examine Register ( $\mathbf{X}$ ) - allows you to examine and modify the 8086's register contents.
- Block Move (M) - allows you to relocate program and data portions in memory.
- Input or Output (I, IW, O, OW) - allows direct control of the SDK-86's I/O facilities in byte or word mode.
- Display Memory (D) - allows you to print or display large blocks of memory information in HEX format.
- Load (L) - allows you to load hex format object files into SDK-86 memory from an Intellec.
- Transfer (T) - allows you to save contents of SDK-86 memory in a hex format object file in the Intellec.


SDK-86/Intellec ${ }^{\text {® }}$ Slave Mode Configuration

# INSITE ${ }^{\text {TM }}$ USER'S PROGRAM LIBRARY 

Programs for 8008, 8048, 8080, 8085 and 8086 processors

## Updates of new programs sent bi-monthly Diskettes, paper tapes, and listings available for library programs

Hundreds of programs
For each accepted program submittal, Insite will provide either a one-year free membership, five free paper tapes, or free program diskette

Insite ${ }^{T M}$, Intel's Software Index and Technology Exchange, is a collection of programs, subroutines, procedures, and macros written by users of Intel's $8008,8048,8080,8085$ and 8086 microcomputers, iSBC- 80 OEM computer systems, and Intellec ${ }^{\text {® }}$ development systems. Thanks to customer contributions to Insite ${ }^{T M}$, Intel is able to make these programs available to all users of Intel microcomputers. By taking advantage of the availability of these general-purpose routines, the microcomputer design engineer and programmer can save many hours of programming and debugging time. The library of programs also serves as a good learning tool for those unfamiliar with Intel assembly language or PLM-80 and FORTRAN-80, Intel's high-level languages for the 8008, 8080 and 8085 microcomputers.


## INSITE PROGRAM LIBRARY MANUAL

Each member will be sent the Program Library Manual consisting of an abstract for each program indicating the function of the routine, required hardware and software, and memory requirements, plus the source listings that are five pages and under.

User's Library members will be updated bi-monthly with abstracts of new programs submitted to Insite $e^{\text {TM }}$ during the subscription period. Please refer to the Intel OEM Price List or contact the nearest Regional Sales Office for yearly subscription fee.

## PROGRAM LIBRARY SERVICES

PAPER TAPES, DISKETTES OR SOURCE LISTINGS are available for every program in Insite $e^{T M}$. Diskettes are available on single or double density.

## MEMBERSHIP

Membership in Insite ${ }^{T M}$ is available on an annual basis. Intel customers may become members through an accepted program contribution or membership fee. New members should use the membership form on the back of this data sheet.

## PROGRAM SUBMITTAL

Programs submitted for our review must follow the guidelines listed below:

1. Programs must be written in a standard Intel Assembly Language or PL/M-80. These languages are documented in the following manuals:
a. 8008/MCS-8 Assembly Programming Manual \#98019B
b. $8080 / 8085$ Assembly Language Programming Manual \#98-301C
c. $8080 / 8085$ Floating-Point Arithmetic Library User's Manual \#98-452B
d. PL/M-80 Programming Manual \#98-268B
e. MCS-48 and UPI-41 Assembly Language Manual \#98-255C
f. FORTRAN-80 Programming Manual \#98-481A
g. 8086 Assembly Language Reference Manual \#98640A
h. PL/M-86 Programming Manual \#98-466A
2. A source listing of the program must be included. This must be the output listing of a compile or assembly. All accepted programs must be capable of compilation or assembly by Intel standard compilers or assemblers. No consideration will be given to partial programs or duplication of existing programs.
3. A test program which assures the validity of the contributed program must be included. This must show the correct operation of the program.
4. A source paper tape or diskette of the contributed program is required. This will be used for the reproduction of tapes for other members.

Complete the Submittal Form as follows: (please type or print)

1. Processor (check appropriate box).
2. Program Title: Name and brief description of program function.
3. Function: Detailed description of operations performed by the program. Attach additional pages if necessary.

## 4. Required Hardware:

For example: TTY or Ports 0 and 1
Interrupt Circuitry
I/O Interface
Machine line and configuration for cross products
5. Required Software:

For example: TTY Driver Floating Point Package
Support software required for cross products
6. Input Parameters: Description of register values, memory areas or values accepted from input ports.
7. Output Results: Values to be expected in registers, memory areas or on output ports.
8. Program Details: (for resident products only)
a. Register modified
b. RAM required (bytes)
c. ROM required (bytes)
d. Maximum subroutine nesting level

## 9. Assembler/Compiler Used:

For example: PL/M-80
Intellec® MDS Macro Assembler
FORTRAN-80
10. Programmer, Company and Address.

3－Byte Positive Fractional Multiply
5 Level（BARDOT）to 8 Level（ASCII）Paper Tape Conversion
8－Bit Multiply and Divide
8 －Bit Random Number Generator
$12 \times 12$ Multıply
16－Bit CRC for Polynomial X16＋X12＋X5＋1
16－Bit Division－16－Bit Result
16－Bit Division－16－Bit Result
16－Bit Multiply－16－Bit Result
16－Bit Multiply－16－Bit Result
16－Bit Multiply－32－Bit Result
16－Bit Random Number Generator
16－Bit Square Root Routine
32－Bit Binary to BCD Conversion，Leading Zero Blanking
32－Bit Divide Subroutine
2708 PROM Programmer for Intellec 8／MOD 80
4040 Cross Assembler for Inteliec 8／MOD 80 and MDS－800
8008 Cross Assembler for 8085－MACRO Defini－ tion－M8008．SRC
8008 Cross Inverse Assembler for HP 2100
8008 Disassembler
8008 MACRO Assembler Version 2.0
8008 MACRO Definition Set for Assembly on PDP－11
8048 BCD Multiply
8048－DIV－Division Routine
8048 －Seven Segment Display Interface Sub－ routines－SCAN
8048 TUNE GENERATOR
8080 CPU Exercise Routine
8080 Cross Assembler for Tektronix 4051
8080 Disassembler
8080 Disassembler
8080 Double Precision ARC Tangent
8080 Floating Point $A^{b}$
8080 Floating Point Extended Math Package
8080 Floating Point with BCD Conversion Routine
8080 Idle Analyzer for Approximatıng CPU Utilization
8080 I／O System Status Display
8080 Least Squares Quadratic Fitting Routine
8080 MACRO Assembler 4.1
8080 RAM Memory Test
8080 Symbol Table Dump
8085 Cross Assembler for the DEC PDP8 and PDP11
9600 Initialize CRT and UART for Baud
Absorbance Calculation
AID Converter Routine
ADCCP Remainder Routine
Adaptive Game Program
Algebraic Compare Subroutine
Align Program－Intermediate Pass Between PLM／Pass 1 \＆ 2
Analog／Digital Polling Routıne
AP29＂USING THE 8085 SERIAL I／O LINES＂
APL Graphic Display on a $5 \times 7$ Dot Matrix
Approximating Routine
Arctan 2 Subroutine
ARRAY ADDRESSING SUBROUTINE AND CALLING MACRO
ASCII Display
ASCII to EBCDIC and EBCDIC to ASCII Con－ verters
ASCII String to Intel Floating Point
Assembler Oriented Centronics 306 Line Printer Handler and Error Only Assembler
Bandit Static Display
Banner Print and Punch
BASIC CPU State Vector Maintenance
Basic Digital Panel Meter Call
BASIC Interpreter
BASIC／M Translator and Interpreter BCD to BIN Conversion Routine
BCD tolfrom Binary Conversion
BCD Input and Direct Conversion to Binary Routıne
BCD Multiplication
BCD Sum for 8008
BCD Up／Down Counter
BIN to BCD Conversion Routıne
Binary to BCD Subroutine
Binary to HEX Routine
Binary Loader for MDS
Binary Multiplication－24－Bit

Binary Search
Binary Search Routine
Binary Tape Program
BINDECBIN－Binary tolfrom BCD
BINLB－ 8080 System Loader
BIORIM
Blackjack
\＄BLPT
BOOT－Bootstrap Loading and Program Patch－ ing
Calculate a Calendar
Calendar Subroutine
Card Reader Driver，Hollerith to ASCII Conver－ sion
Character Interpreted Memory Dump
CLI
Clock Subroutine
Compare
COMPARE Files
Compare Object Code Tape with Memory
Control Data Output
Controller for Hewlett－Packard 9871A Printer
Conversion of Scientific to Easily Readable Notation
Crap＇s
CRECH－Cyclic Redundancy Check
Cross Assembler ASM08
Cross Assembler for NOVA 1200
cross Assembler for NOVA 1220，IBM 360／40 and CDC 3000
Cross Assembler for PDP－11
Cross Assembler for PDP－11
Cross Assembler for Varian Data Machıne
Cross Reference for PAS80 PASCAL Programs －XREF80
CRTBZ－GET
Cut and Paste Editor（PLM）
Cyclic Redundancy Character Generator
Cyclic Redundancy Check
Cyclic Redundancy Check for Data String of $2^{16}$ Bytes
Data Array Move
Data General to Intellec MDS Diskette Trans－ port Package
Data I／O PROM Processor
＂DATCON B1＂Analog to Digital Conversion

## Program

Decrement H and L Regsiters
Delete Comments
Diagnostic 1003 －Memory Validity Check
Digital to Analog Conversion for Eight Outputs
Disable Hold－Screen Mode
Disassembler
Disk Dump Routine for ICOM F DOS－11／MOD 80 Floppy DOS
Diskette Recovery Program，Recovery 1
Display
Double Precision Integer Arithmetic Package
Double Precision Multiply
Driver for Tektronix 4010 Grafic Screen
DTMHEX
Elementary Function Package
Enable Hold－Screen Mode
ERLIST
Examin
EXEC
Factorial of a Decimal Number
Fast Floating Point Square Root Routine
FAST \＆SLOW
FDUMP
Field
Fixed and Floating Point Arithmetic Routines
Fixed Point CHEBYSHEV Sine and Cosine for PLM Users
Flag Processing Routine
Floating Point Conversion Routine
Floating Point Decimal and HEX Format Con－ version
Floating Point Format Conversion Package
Floating Point Interpreter
Floating Point Math Package
Floating Point Package for Intel 8008 and 8080 Microprocessors
Foating Point Procedures
Floating Point Square Root
Floating Point Utility Programs for Use with FPAL．LIB
Fly Reader Driver
Format

Format Intel Data
Gambol
Game of Life
Gamma Function Subroutine
Generalized Stepper Motor Drive Program
GLANCE
GRAPH
Gray to Binary Conversion
Handier for Tally PTP
Hang
Hazeltine 2000 CRT Function Driver
Hewlett－Packard Calculator to MDS800 I／O Con－
trol Program－HPIO
HEX Convert－Convert Intel HEX to Prolog HEX File Converter
Hex to ASCII Conversion
HEX to Decimal Conversion
HEX Format Paper Tape Dump for SDK
HEX Tape Loader for SDK
High Speed Paper Tape Reader with Stepper Motor Control
Histogram
18080 Cross Assembler for Intel 8080／8085 Microprocessors
IBM Selectric Input Program
IBM Selectric Output Program
ICE－80 Disassembler
I－Command－Insert Data in HEX Form from TTY into RAM
Input／Output Commands for MDS
Insert Tab Characters for Spaces
Intel Format HEX Data File Load／Read
Intellec 8 MOD 80 Monitor
Inteliec 8／MOD 80 －Silent 700 Interface
Intellec MDS Diagnostic Confidence Test Ver－ sion 1.1
Intellec MDS Monitor Version 2.0
Intellec 8 Text Editor
Interfacing the MDS and HP 2644
Interrupt Driven Clock Routine
Interrupt Handler（Re－Entrant）
interrupt Service Routine
INVERT Data in RAM
I／O Routine for TI Silent 700 Terminal
IO Simulation MACROS
I／O Test Program for SBC 80／20－IOTEST
Join
Julian Data Routine
K，Program Trap and Dump Routine
Kalah
Keyboard Scanner
Kill the Rotating Bit
Lander
Lerr
Legible Paper Tape
Lewthwaite＇s Game
Linear System（Gauss Elimination）－LISY
LISP INTERPRETER
List
List Device Program
List SCR
List 1 －High Speed List Program for Intellec 8
List／Print／Type＂List SRC＂on Diskette
LLLUChernack Basic Interpreter
LOAD
Log Base 2
LSORT
MACRO Assembler for DG NOVA
Main Routine DDUMP（Diskette DUMP Routines）
Mastermind
Mastermind 8080
＂Mastermind 8080＂for SBC 80／10
Match
Match Game
Maze
Maze
MBCD N1 $\times$ N2 Bytes Decimal Multiply Subrou－ tine
MDS Back to Back Data Transfer
Memory Compare
Memory Diagnostic Program
Memory Dump
Memory Test for the 8080
Memory Test Program
$\mu$ Scope 820 Test Instrument，iSBC 80／10 Diag－ nostic Program
MINITH－RMX Minimal Terminal Handler
Model 101 Centronics Printer Handler
Mon256－256－Byte PROM Monitor

## INSITETM USER'S LIBRARY PARTIAL PROGRAM INDEX (Continued)

Monitor for iSBC 80/05 or 80/04 - MON805
Monitor for ISBC 80/10 or 80/10A - MON810 Monitor for ISBC 80/20 or 80/20-4 - MON820 Morse Code Generator
MSAVEIMLOAD Utilities for MDS-800 with DOS MULDIV Multi-Precision Pack for 8080
Natural Logarithm
N -Byte Binary Multiplicaiton and Leading Zero Blanking

## Nim

Nim
Non-Encoded Keyboard Subroutine
Nova Cross Assembler - Intel 8080
Numbers
Octal Code Conversion for PDP-11
Octal Debugging Program (ODT) for the MCS-80 Computer
Octal PROM Programming
OCTHEX
Online, Upload, Download
Optimized Ultra Fast Floating Point Package
Output Message Generator
P2708 PROM Programming Routine
Page Break for Tektronix 4010 I/O Graphics Terminal
Page Listing Program
Paper Tape Leader I.D
Paper Tape Reformatter for SDK
Pass - Parameter Passing Routine
PDP. 11 Binary File to Intel HEX File Converter
PDP. 11 Program Load to HEX, Dump, \& Verify
PILOT-80 ISIS-II Version 2.0
PLM 80 Pass 3
PUM Floating Point Interface
PLM Histogram Procedure and Random Number Generator
Print
Print Program for G.E. Terminet-1200 Printer
Print Out Source File on Floppy Disk
Print Text for SBC 80/10
Program Test Load
PROM Programmer for Intellec 8
Prompt Pong
Proportional Power Control Image Builder
Punch Binary Tape
Punch Test or TTY Reader/Punch Test
Quicksort Procedures
RAM Check
RAM Test Program
Random Number Generator - RINGEN

RANDOM\$BITS
React
Read and Interrupt Modifications for Intellec $8 /$ MOD 80
Read/Write Routines for Interchange Tapes
Reader Test
Real Time Clock Service Routine
Real Time Executive
Real Time Monitor
RECOVR
Relative Jump Routine
Relocatable FMath and XMath, 8085 Floating Point Package
RIA80
RMSTF - Integration Routine
RMX/80-based Keyboard Input Handler Subrou-
un 0
Sample Automatic Test Equipment
Save/Restore CPU State on an Interrupt
SBC Communicator
SBC 80P Real Time Clack
SBC 80/10 8255 Test
SBC 80/10 Interactive Monitor
SBC 80/10 Port I/O Exerciser
SBC 310 Floating Point System for Use with SBC 80/20
SCAN
SCAN - 8048 - Seven Segment Display inter-
face Subroutines
SDK-80 Keyboard Monitor
SDK-80 Paper Tape Punch Routine
SDK80 TRAP
SDK PROM Programmer
Sequential Pascal Compler
Serial PROM Programmer
Sets Horizontal Tabs on Terminet
Shellsorting Routine
$\sin X, \cos X$ Subroutine
Slot Machine
SMAL:Symbolic Microcontroller Assembly Language
SMPY16: 16-Bit 2's Complement Signed Multiplication
Snap Dump 8080
Software Stack Routines for 8008
Source Paper Tape to Magnetic Cassette
SQRTF - Calculates 8 -Bit Root of 16 -Bit Num-
Stage2

Statement Counter
STEP
String Manipulation Package
Structured Assembler for 8080
Subroutine DMULT (Decimal Multiplication)
Subroutine Log - Common Logarithms
Subroutine SORT
Symbol Cross-Reference
Symbol Table
Symbol Table Dump for Intellec 8/MOD 0
Symbol Table List Routine
Tabs
Tally - Use Tally 2200 Line Printer in Assembly
Stage of Programming
Tally R2050 HSPTR Driver
Tape Duplicator
Tape Labeler for MDS
Teleprocessing Buffer Routine
Terminal Editor
Terminet 300
Terminet 1200
Text Editor, Enhanced
Text Storage Program
Thermocouple Linearization (Type J)
Thumbwheel SBC 80/10 Test Program
Tic-Tac-Toe
Tic-Tac-Toe - 3 Dimensional
Time Sharing Communications
TIMIT - Interrupt Driven Real Time Clock Rou-
tine
T.I. Silent 700 Interface - Intellec MDS
T.I. Silent 700 SBC 80 Monitor interface

TRACE - Program Trace and Debugger
Trace \& Register Print Out
Trace Routine
TRACE Version 7.0
TTY Binary Dump Routine
TTY Binary Load Routine
TYY Diagnostic
Type
Type
Type K.T.C. Linearizer
Utility Macros for 8080
VDU Darts
Video Driver
Wipe
Word Game, The
WRMIN-RMX Minimal Terminal Output

I am interested in becoming a member of Insite ${ }^{T M}$
Enclosed is $\square$ Check $\square$ Money Order $\square$ Purchase Order* $\square$ Program Submittal
NAME:
COMPANY: $\qquad$
SHIP TO: $\qquad$

## SEND TO NEAREST LOCATION:

North America
Intel Corporation
User's Library 6-321
Microcomputer Systems
3065 Bowers Avenue
Santa Clara, California
95051
Ph. 408-987-8080

## Europe

Intel International Corp. S.A.
User's Library
Rue du Moulin a Papier 51
Boite 1
B-1160 Brussels, Belgium
Ph. 02-660-3010

## Orient

Intel Japan K.K.
User's Library
Flowerhill-Shinmachi, East Bldg.
1-23-9 Shinmachi, Setagaya-ku
Tokyo 154, Japan
Ph. 813-426-9261 (PME \& FSE)
813-426-9267 (CS \& Fin.)

## $\mu$ SCOPE 820 MICROPROCESSOR SYSTEM CONSOLE

Gives complete control over microprocessor, including single step, run-withdisplay, or run-real-time capability

Provides a 32-bit hardware breakpoint with bit masking and a 256-word trace memory

## Executes diagnostic routines from $\mu$ Scope 820 console overlay memory

## Provides an interface to microcomputer systems for troubleshooting system problems

Monitors, displays, and alters register, memory, and I/O values for system under test

Executes instrument resident software patch routines even when microcomputer system is ROM-based

## Is a stand-alone, self-contained, rugged portable unit

## Human engineered with easy to read 9 -segment hexadecimal displays and extensive operator prompting

## Designed to support many different microprocessors

Has built-in, self-test operation

Intel's new $\mu$ SCOPE 820 Microprocessor System Console provides equipment manufacturers with a portable microcomputer system designed to expedite troubleshooting and maintenance of other microcomputer systems. The unit can control and examine system operations. Diagnostics can be automated by EPROM (erasable, programmable read only memories) or ROMs into the socket at the upper left of the keyboard display panel. The $\mu$ Scope 820 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 plugged into the microprocessor socket. Each personality probe is unique to each microprocessor type. The instrument features many different operating and controi modes, allowing the operator to carry out a number of functional checks on the microcomputer system under test (SUT). Although the unit has been specifically designed to ease the task of microcomputer system checkout 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 commands keys, visual prompting, and simplified data entry sequences all ease the checkout 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 keyboard.


## FEATURES

## 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 may be issued without impacting other operational parameters or diagnostic sequences previously established.

## 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 may be accomplished simply by depressing the exam next or exam last keys.

## Overlay Memory



A unique feature of the unit is the ability to map its memory onto the SUT memory space. Using the overlay memory allows the operator to insert patch, exercise, or diagnostic subroutines at any location or point of execution in the SUT program. The subroutine may either be entered via the front panel hexadecimal keypad or via the front panel's ROM/PROM socket. By using the unit's overlay memory, the operator may quickly set up the SUT to execute special maintenance or troubleshooting programs to permit rapid evaluation of system operation.

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




## Address, Data, and Control Entry

The address, data, and control variable entry into the instrument is accomplished via the conveniently located hexadecimal keypad. For selection of the information to be displayed or modified the operator enters the hexadecimal value of the desired address, I/O port number, or label assigned to each of the registers. Once this entry is made, the operator can then elect to either continue data entry if modification is desired or press the end execute key if examination only is desired. For all data entry sequences potentially requiring multiple value entry, the $\mu$ Scope 820 Microprocessor System Console provides operator prompting to indicate the specific information expected.

## Value Display/Select

The value displays provide clear and easy to use information. 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, and 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 eleven dedicated examine keys. Further, the information is either displayed statically or is con-


All 8-bit values can be displayed in binary format on the instrument. The binary display operates in parallel with the hexadecimal display and 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 may alter the value by means of further hex keypad entries or by changing the binary state of any of the data bits via the eight binary data switches.

## Front Panel

The front panel of the $\mu$ Scope 820 Microprocessor System Console has been designed to be rugged and
durable as well as easy to use and understand. A plastic overlay employing 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.

## 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 subroutine select (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 AC 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 available today. This is accomplished 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 4 -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.

## FUNCTIONAL DESCRIPTION <br> CPU Control

User selectable commands permit one of four possible CPU operating modes:
Run Real Time - User's CPU runs at full speed set by user clock. No wait states or cycle stealing are required.
Run with Display - User's CPU runs at full speed, except that 10 times/sec the instrument halts user's CPU temporarily to acquire display data. Worse case throughput is $95 \%$ of real time operation.
Halt - User CPU halted at next opcode fetch. DMA activity is permitted during halt.
Single Step - User CPU executes one instruction then halts.

## Breakpoint Control

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 are controlled by the breakpoint enable/disable switch except for trace recording and the sync trigger output. The sync output is a negative true TTL output occurring whenever a breakpoint match occurs.

## Trace Memory

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 may initiate a panel freeze to temporarily stop all trace data recording, and allow display
of previously recorded data without halting the user CPU.

## Overlay Memory

The $\mu$ Scope 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 Entry

All single and double byte items may be entered via the front panel hexadecimal keypad. In addition, all single byte items may be optionally entered via eight binary input keys.

## 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 have been incorporated into the instrument to facilitate the selfchecking 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.


## SPECIFICATIONS

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

## Connection

Four external connections to the $\mu$ Scope 820 Microprocessor System Console are provided:
1.2 m ( $\mathbf{4} \mathbf{f t}$ ), 50 conductor flat cable - for connection to the microprocessor probe
20-pin board edge connector - for the probe personality PROM
24-pin zero force insertion sockets - for overlay EPROM/ROM
Recessed pin - for breakpoint sync output

## Breakpoint

Pulse Width - 180 ns typ
Output High - 2.5 V min, -1.2 mA
Output Low - 0.5V max, 24.0 mA

## Physical Characteristics

Width - 18-7/8 in. ( 479 mm )
Length - 15-1/2 in. (394 mm)

Height (top closed) - 6-5/8 in. (168 mm)
Height (top removed) - 4-5/8 in. ( 117 mm )
Weight - $20 \mathrm{lb}(9.1 \mathrm{~kg})$

## Electrical Characteristics

Voltage - 100, 120, 220, $240-10 \%+5 \%, 110 \mathrm{~V}$ AC max Frequency - $48-63 \mathrm{~Hz}$

## Environmental Characteristics

Operating Temperature $-0^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}\left(32^{\circ} \mathrm{F}\right.$ to $\left.130^{\circ} \mathrm{F}\right)$
Storage Temperature $-40^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}\left(-40^{\circ} \mathrm{F}\right.$ to $167^{\circ} \mathrm{F}$ )
Humidity - $95 \% \mathrm{RH}, 15^{\circ} \mathrm{C}$ to $40^{\circ} \mathrm{C}\left(59^{\circ} \mathrm{F}\right.$ to $\left.104^{\circ} \mathrm{F}\right)$ noncondensing

## Accessories Supplied

Two keys
One fuse for $220 / 240 \mathrm{~V}$ operation
One 2.3m ( 7.5 ft ) power cord

## Reference Manuals

9800526A - $\mu$ Scope 820 Operator's Handbook (SUPPLIED)

Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION

## Part Number Description

USC-820 Microprocessor system console

## $\mu$ SCOPE PROBE 8080A

## Provides interconnection for 8080A microprocessor-based systems to $\mu$ Scope 820 Microprocessor System Console

Provides complete control over system under test (SUT), yet causes minimal interference with SUT operation

Comes complete with cable, buffer box, personality ROM, and $\mu$ Scope 820 system console overlay

Fits securely in console carrying case during transit

Provides complete protection for plug pins during transit

Connects via 4 -foot cable to $\mu$ Scope 820 console

Has user system interconnect cable with integral ground plane for low noise operation

Operates over broad range of environ-
mental conditions

The $\mu$ Scope Probe 8080A provides the $\mu$ Scope Microprocessor System 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 ground 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 four feet from the system console.


## SPECIFICATIONS

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

## $\mu$ Scope 820 Console Interconnect

The probe interconnection to the $\mu$ Scope 820 console is accomplished via a 4 -foot ( 1.2 m ) flat cable. 50 -pin mating connectors plug into a board edge conector 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 16 -inch ( 406 mm ) 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 -pin socket provided on the probe buffer box.

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

## Accessories Supplied

One $\mu$ Scope 820 system console overlay
One personality ROM
One hardware reference manual

## Physical Characteristics

Probe Buffer Box
Height: $0.75 \mathrm{in} .(19 \mathrm{~mm})$
Length: 7.25 in . ( 184 mm )
Width: 3.75 in . $(95 \mathrm{~mm}$ )

## User System Interconnect Cable

Width: $2^{11 / 4} \mathrm{in}$. ( 57 mm )
Length: $16 \mathrm{in} .(406 \mathrm{~mm})$ flat cable
$\mu$ Scope 820 Console Personality ROM PC Card
Height: $3 / 4 \mathrm{in}$. $(19 \mathrm{~mm}$ )
Width: $2^{1 / 1 / 4} \mathrm{in}$. $(57 \mathrm{~mm}$ )
Length: $3^{1 ⁄ / 4} \mathrm{in} .(83 \mathrm{~mm})$

## Electrical Characteristics

All DC specifications are in addition to user system parameters. All capacitance values include cables and connectors.

Non-Intercepted Signals

| $\varnothing 1, \varnothing 2$ | $\pm 10 \mu \mathrm{~A}$ max; 55 pF typ |
| :--- | :--- |
| $\mathrm{A}_{15}-\mathrm{A}_{0}, \mathrm{D}_{7}-\mathrm{D}_{0}$ | $-0.25 \mathrm{~mA} \max @ 0.45 \mathrm{~V} ; 30 \mu \mathrm{~A} \max$ |
|  | $@ 5.25 \mathrm{~V} ; 49 \mathrm{pF}$ typ |
| +12 V Supply | $15 \mu \mathrm{~A}$ max |
| WAIT | 35 pF typ (capacitance loading only) |

Intercepted Signals

| Outputs to User System |  |
| :---: | :---: |
| SYNC <br> HOLDA, INTE, DBIN, and $\overline{W R}$ | $20 \mathrm{~mA} \min @ 0.5 \mathrm{~V} ;-1 \mathrm{~mA} \min @$ 2.7 V ; 40 pF typ <br> 4 mA min @ 0.4 V ; -0.2 mA min @ 2.7 V ; 40 pF typ |
| Inputs from User System |  |
| INT, READY, RESET HOLD | $\begin{aligned} & 40 \mu \mathrm{~A} \max @ 2.7 \mathrm{~V} ;-0.72 \mathrm{~mA} \max @ \\ & 0.4 \mathrm{~V} ; 50 \mathrm{pF} \text { typ } \\ & 60 \mu \mathrm{~A} \text { max @ } 2.7 \mathrm{~V} ;-1.08 \mathrm{~mA} \text { max @ } \\ & 0.4 \mathrm{~V} ; 50 \mathrm{pF} \text { typ } \end{aligned}$ |

Power Requirements - Power supplied by $\mu$ Scope 820 Microprocessor System Console.

## Environmental Characteristics

Operating Temperature $-0^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}\left(32^{\circ} \mathrm{F}\right.$ to $\left.130^{\circ} \mathrm{F}\right)$
Storage Temperature $-40^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}\left(-40^{\circ} \mathrm{F}\right.$ to $167^{\circ} \mathrm{F}$ )
Humidity - $95 \% \mathrm{RH}, 15^{\circ} \mathrm{C}$ to $40^{\circ} \mathrm{C}\left(59^{\circ} \mathrm{F}\right.$ to $\left.104^{\circ} \mathrm{F}\right)$ noncondensing

## Reference Manuals

9800526 - $\mu$ Scope 820 Operator's Manual (SUPPLIED)
Reference manuals are shipped with each product only if designated SUPPLIED (see above). Manuals may be ordered from any Intel sales representative, distributor office or from Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

## ORDERING INFORMATION <br> Part Number Description <br> PRB-80 8080A interface probe

## $\mu$ SCOPE $^{\text {T }}$ PROBE 8085

Provides interconnection for both 8085 and 8085A Microprocessor-based Systems to the $\mu$ Scope $^{\text {TM }}$ Microprocessor System Console
Comes complete with cable, buffer box, personality ROM, and $\mu$ Scope system console overlay
Has user system interconnect cable with integral ground plane for low noise operation
Increases diagnostic capability via four user positioned external inputs

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 8085 provides the $\mu$ Scope Console with the ability to interact with 8085 and 8085A Microcomputer-based systems. The purpose of the probe is to interface the $\mu$ Scope 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 8085, 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 4 feet from the system console.
The probe can be reconfigured to test either 8085 or 8085 A microprocessor-based systems. The user can operate the microprocessor from either the system under test crystal or one adjacent to the probe 8085 CPU socket. User control of the probe interaction with CPU control signals insures maximum compatibility with the system under test. Test and diagnostic capability is increased by integrating four external inputs into the probe 8085.


## GENERAL

## $\mu$ SCOPE CONSOLE INTERCONNECT

The probe interconnection to the $\mu$ Scope Console is accomplished via a 1.2 m ( 4 ft .) flat cable. 50 -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 200 mm ( 8 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 8085 socket and the 8085 itself is plugged into the 40-pin socket provided on the probe buffer box.

## $\mu$ SCOPE CONSOLE CONFIGURATION

Several features of the $\mu$ Scope Console are directly determined by the probe being used with it. The features that are determined by the 8085 interface probe are:

- Single Registers: A, B, C, D, E, H, L
- Double Registers: BC, DE, HL, PC, SP
- CPU States: Flags, CPU pins, Interrupt Masks, and Interrupt States
- Trace/Breakpoint Word Size: 32 bits with 16 bits of address, 8 bits of data and 8 bits of CPU status
- 4 external inputs included in the 8 bits of CPU status for examining, recording in trace memory, and transferring control


## ELECTRICAL SPECIFICATIONS

All DC specifications are in addition to user system parameters. All capacitance values include cables and connectors.

## Non-Intercepted Signals

| $\mathrm{x} 1, \mathrm{x} 2$, reset out | 16 pF typical |
| :--- | :--- |
| $\mathrm{AD}_{0}-\mathrm{AD}_{7}, \mathrm{~A}_{8}-\mathrm{A}_{15}$ | $-0.25 \mathrm{~mA} \max @ 0.45 \mathrm{~V} ; 10 \mu \mathrm{~A}$ max |
|  | $@ 5.25 \mathrm{~V} ; 26 \mathrm{pF}$ typical |
| SID | $40 \mu \mathrm{~A} \max @ 2.7 \mathrm{~V} ;-0.6 \mathrm{~mA}$ max |
|  | $@ 0.4 \mathrm{~V} ; 20 \mathrm{pF}$ typical |
| SOD | $20 \mu \mathrm{~A} \max @ 2.7 \mathrm{~V} ;-0.4 \mathrm{~mA}$ max @ |
|  | $0.4 \mathrm{~V} ; 20 \mathrm{pF}$ typical |

## Intercepted Signals

Output to user system:

| ALE | 19 mA max @ 0.5 volt; - $900 \mu \mathrm{~A} \max @$ 2.7 volt |
| :---: | :---: |
| CLK | 2 mA max @ 0.64 volt; $-400 \mu \mathrm{~A}$ max @ 2.6 volt |
| SSO, SSI | 8 mA max @ 0.5 volt; $-400 \mu \mathrm{~A} \max @$ 2.7 volt |
| RD, WR, $10 / \bar{M}$ | 24 mA max @ 0.5 volt; -2.6 mA max @ 2.4 volt |

INTA

HLDA
21 mA max @ 0.5 volt; -3.6 mA max @ 2.4 volt

6 mA max @ 0.5 volt; $-350 \mu \mathrm{~A}$ max @ 2.7 volt

All Output Signals have capacitance of 20pF typical.
Inputs from user system:


External Inputs:

$$
\begin{aligned}
\text { XI0, XI1, XI2, XI3 } & -0.25 \mathrm{~mA} \max @ 0.45 \mathrm{~V} ; 10 \mu \mathrm{~A} \max @ \\
& 5.25 \mathrm{~V} ; 2.4 \mathrm{~V} \text { min Input High Voltage; } \\
& 0.85 \mathrm{~V} \text { max Input Low Voltage }
\end{aligned}
$$

## CONNECTIONS

Three external connections to the probe are provided:

- 50-pin flat cable connector on buffer box
- 40-pin zero insertion force socket for the 8085 SUT CPU
- 40-pin low profile replaceable IC DIP connector for connection to SUT


## CHARACTERISTICS

## PHYSICAL CHARACTERISTICS

Probe Buffer Box:

| Height: | $22 \mathrm{~mm}(7 / 8 \mathrm{in})$. |
| :--- | ---: |
| Length: | $208 \mathrm{~mm}(8-1 / 4 \mathrm{in})$. |
| Width: | $116 \mathrm{~mm}(4-5 / 8 \mathrm{in})$. |

User System Interconnect Cable:
Width: $\quad 57 \mathrm{~mm}(2-1 / 4 \mathrm{in}$.)
Length: 200 mm ( 8 in .) flat cable
$\mu$ Scope Console Personality ROM PC Card:
Height: 19 mm ( $3 / 4 \mathrm{in}$.)
Width: $\quad 57 \mathrm{~mm}(2-1 / 4 \mathrm{in}$.
Length: $\quad 86 \mathrm{~mm}(3-1 / 4 \mathrm{in}$.)

## POWER REQUIREMENTS

Power supplied by $\mu$ Scope Microprocessor System Console.

## ENVIRONMENTAL CONDITIONS

Operating Temperature: $0^{\circ}$ to $50^{\circ} \mathrm{C}\left(32^{\circ}\right.$ to $\left.122^{\circ} \mathrm{F}\right)$ Storage Temperature: $-40^{\circ}$ 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 Probe 8085 overlay for the $\mu$ Scope System Console One Personality ROM

One Operator's Manual
Four Test Probes for the External Inputs

## ORDERING INFORMATION

Part Number Description
PRB-85 8085 Interface Probe

## MICROCOMPUTER TRAINING PROGRAMS

## INTRODUCTION

Intel provides complete training for all its system related products. Courses are given regularly at Intel's training centers located in Santa Clara, California; Boston, Massachusetts; and Chicago, Illinois. These training centers are staffed by highly trained and experienced instructors. This section describes the overall program for microcomputer training and provides outlines for the following courses offered by Intel.

## TABLE OF CONTENTS

Microcomputer Training Programs ..... 14-3
INTRODUCTORY LEVEL
Introduction to Microcomputers. ..... 14-4
Microcomputer Concepts (2 days). ..... 14-5
Development System Operations (3 days). ..... 14-5
INTERMEDIATE LEVEL
MCS-80/85 System. ..... 14-6
PL/M-80 Language/Software Design. ..... 14-7
MCS-86 System. ..... 14-8
PL/M-86 Language/Software Design. ..... 14-9
MCS-48 System ..... 14-10
ADVANCED LEVEL
RMX/80 System. ..... 14-11
Advanced MCS-86 Assembly Language. ..... 14-12
iSBC Design Project ..... 14-12

## intel

## MICROCOMPUTER TRAINING PROGRAMS

Courses presented at training centers and customer facilities

## Training center locations

- Boston
- Chicago
- Santa Clara

Scheduled on a continuing basis throughout the year

## Evening workshops

On-site courses tuned to customer requirements

## System demonstration

Hands-on laboratory sessions reinforce lecture

## Training center classes limited to 15 attendees

Intellec microcomputer development systems with in-circuit emulators used in laboratory

Microcomputers are being used in hundreds of applications from simple controllers to complex data processing systems. To enable users to bring microcomputers into their applications, Intel offers a selection of workshops designed to provide users with the tools for making optimum use of Intel microcomputers in system development.


## INTRODUCTION TO MICROCOMPUTERS

This workshop offers five days of lectures, questions and answers, practical learning, and hands-on training with your own microcomputer. You'll learn the fundamentals and general uses of microprocessors, and the basics of microcomputer-based design. The best learning will come from using and programming an operating SDK-85 System Design Kit (described below). When the training session is completed, an SDK-85 kit is yours to keep.

Attendees: One who has limited programming and design experience, and does not need to learn about development systems. A background in electronics is helpful but not necessary. (Maximum attendance is 20.)

Day 1<br>Introduction to Microcomputers<br>Computer Ogranization<br>Instruction Execution<br>Lab-Using Microcomputers<br>Day 2<br>Elementary Programming Microcomputer Interfacing<br>Lab-Audio Oscillator Using Digital Techniques<br>Day 3<br>Computer Arithmetic<br>Conditional Jumps<br>Stacks and Subroutines<br>\section*{Push/Pop}<br>Lab-Using Monitor Routine<br>Day 4<br>Interrupts<br>Computer Kit Hardware<br>Memory Systems<br>Decimal Arithmetic<br>Lab-A Digital Clock<br>Day 5<br>Introduction to Single Chip Microcomputers<br>Introduction to High Level Langnuages<br>Introduction to 16-Bit Microcomputers<br>Survey of Programming Aids

## Microcomputer Concepts Workshop

The student will learn microcomputer terminology, run a microcomputer program, and gain insight in the development process and selecting the most appropriate microcomputer for an application.

Attendees: Project leaders, managers, administrative staff, or non-technical personnel who need a better understanding of microcomputer fundamental concepts.

|  |  |
| :--- | :--- |
| Day 1 | Day 2 |
| Introduction | Review |
| Terminology | Single Chip Design Example |
| SDK-85-Microcomputer Experiment | iSBC Design Example |
| iSBC Demonstration | Hardware/Software Tradeoffs |
| Development System Laboratory |  |

Table 2. Microcomputer Concepts Workshop Course Outline

## Development System Operations Workshop

This lab-intensive workshop teaches the student how to operate the Intellec Microcomputer Development System and the ISIS (Intel Systems Implementation Supervisor) disk operating system. Laboratory operations include editing data files, assembling and compiling programs, using relocation and linkage facilities, and identifying the correct documentation. This is not a programming course.

Attendees: A programmer who will be using the Intellec MDS. In addition, the technician, programmer-aid, or clerk who needs to operate the Intellec MDS can benefit from this course.

|  |  |
| :--- | :--- |
| Day 1 | Day 3 |
| Introduction | Review |
| System Installation, |  |
| Interconnections, Power-Up | Link/Locate |
| Utility Commands-COPY, | Diagnostic Programs |
| DELETE, RENAME, | BASIC-80 |
| DIR, ATTRIB |  |
| Day 2 |  |
| Review |  |
| Edit-Build and Modify a File Manuals |  |
| Compile |  |
| Assemble |  |

Table 3. Development System Operations Workshop Course Outline

## COURSE DESCRIPTIONS

## MCS-80/85 System Workshop

This workshop will prepare the student to design and develop a system using Intel 8080/8085 microprocessors by means of lectures, demonstrations, and laboratory "hands-on" experience with the Intellec Microcom-
puter Development System and an in-circuit emulator. The course outline for this workshop is presented in Table 4.

Prerequisites: A knowledge of binary and hexadecimal number systems and basic logic functions is recommended.

## Day 1

Introduction
a. Microprocessor System

1. Function
2. Organization
3. Programming
b. Central Processor Overview
4. Functional Sections
5. Programming Model
6. Execution Sequence

Assembly Language Instructions
a. Input/Output
b. Register/Memory Reference
c. Arithmetic, Logical, Rotates

Input/Output Techniques
a. Programmed $1 / O$
b. Interrupt I/O
c. Direct Memory Access

Programmed Input/Output
a. Status Request
b. Command
c. Data Transfer

Development System
a. Function
b. System Monitor
c. Disk Operating System

Debugging With the System Monitor
a. Break Points
b. Examine Registers

Laboratory
a. Using the System Monitor
b. Program Instruction Sequences
c. Debugging and Break Points

Day 2
Basic CPU Timing
a. Instruction Fetch
b. Bus Structure
c. Read/Write Timing

Subroutines
a. Invocation
b. Stack Memory
c. Parameters

Interrupt System
a. Description
b. RST Instruction
c. Service Subroutines

Disk Operating System Modules
a. Macro Assembler
b. Text Editor
c. File Utility Commands

## Laboratory

a. Using the Disk Operating System
b. Program Assembly and Execution

Day 3
Programming Techniques
a. Branch Tables
b. Direct Load/Store Instructions
c. Special Purpose Instructions

## 8085 Timing

a. Ready/Wait
b. DMA/Hold

8085 Interrupts
a. RST 5.5, 6.5, 7.5
b. Trap
c. RIM, SIM

8080 vs. 8085
a. 8080 Chip Set

1. $8228 / 8238$ System Controller
2. 8224 Clock Generator
b. 8080 Bus Structure
c. 8080 Instruction Timing

Memory Interfacing
a. RAM/ROM/PROM Address

Decoding
b. 8708 PROM/8185 RAM

## Laboratory

a. Program Design Using

Development System
b. Program DEBUG Under Disk Operating System

## Day 4

8085 CPU Set
a. 8085 Bus Structure
b. $8355 / 8755$ ROM/EPROM and I/O
c. 8155 RAM/Timer and I/O

I/O Design
a. Memory-mapped
b. 8255 Parallel Interface
c. 8251 Serial Interface

In-Circuit Emulator
a. Prototype Development
b. Resource Sharing
c. Mapping Commands
d. Utility Commands
e. Debug Commands
f. Emulation Syntax

## Laboratory

a. Use of the $\operatorname{In}$-Circuit Emulator for System Debugging

## Day 5

Relocation and Linkage
a. ISIS-II LINK and LOCATE Commands
b. Relocatable Libraries
c. Parameter Passing
d. System Design

## Macros

Single Board Computers
a. Use as a System Component
b. Parallel I/O Options
c. Serial I/O Options
d. Interrupt System
e. Family Boards

## PL/M-80 Language/Software Design Workshop

This workshop will prepare the student for designing, developing, and debugging modular PLM-80 programs, by means of lectures, demonstrations, and laboratory "hands-on" experience with the Intellec Microcomputer

Development System and an in-circuit emulator. The course outline for this workshop is presented in Table 5.
Prerequisites: A knowledge of binary and hexadecimal number systems and basic logic functions is required. To attain maximum benefit from course presentation, some background in logic design and computer programming is recommended.

Day 1
Introduction
a. Preview of Course
b. Overview of PL/M, Linking and Relocation
c. Why use a High Level Language

Definitions
Symbols, Identifiers, Reserved
Words, Comments, Data Elements,
Expressions, Statements,
Declarations

## Data Elements

Variables, Subscripted Variables, Data Type, Constants
Operators, Operations and Priorities
Arithmetic and Boolean
Evaluating Expressions

## Statements

Redefine, Basic, Conditional
Assignment
a. Implement a Given Algorithm in PL/M
Day 2
ISIS-II Disc Operating System
a. Components of System

ISIS-II File Structure
a. System Files
b. User Files
c. Device Files
d. Directory and File Attributes

ISIS-II Commands
a. CUSPS-Commonly Used System Programs
b. Directory and Attribute Commands
c. Rename and Delete Commands
d. Creating System and

User Discs
ISIS-II Editor
a. Definition of Terminology
b. Invoking the Editor
c. Editor Commands
d. Editing Existing Files

ISIS.II PL/M 80 Compiler
a. Invoking PL/M
b. Compiler Options

ISIS.II Locate
a. Invoking Locate

Laboratory
a. Introduction to ISIS-II Disc Operating System
b. Creating a PL/M Source File
c. Compiling a PL/M Program
d. Locating and Executing a PL/M Program

## Day 3

Review

## Procedures

a. Declaration
b. Invocation

## c. Program Construction

Data References
a. Based Variables
b. Variable Equivalencing

## Blocks

a. Concept and Use
b. Scope of Declarations

Predeclared Procedures
a. TIME, MOVE, LENGTH, LAST and

SIZE Procedures
b. Type Transfers
c. Shifts and Rotates

The Memory Array and STACKPTR Variables
Laboratory
a. Compile and Locate Program
b. Execute Program

Day 4
Review
Modular Implementation
a. Compilation Modules
b. Modular Programming

ISIS-II Link
a. Invoking Link
b. Link Options
c. Assembly Object Modules

In-Circuit Emulator
a. Definition
b. System Overview

1. Memory and I/O Mapping
2. Breakpoint Capability
3. Dynamic Tracing
4. Control Block

In-Circuit Emulator Software Driver
a. Modes
b. Commands

System Debugging Examples
System Demonstration
Laboratory
a. Locate
b. Load and Emulate Using

In-Circuit Emulator
Day 5
Review
Interrupt Procedures
Reentrant Procedures
ISIS-II Librarian
a. Creating a Library
b. Managing a Library

1. Adding Modules
2. Deleting Modules

ISIS-II System Interfaces
a. System Library

Discussion of Selected Programs
Laboratory
a. Create a Library
b. Link Object to a Library

## MICROCOMPUTER TRAINING PROGRAMS

## MCS-86 System Workshop

This workshop will prepare the student to develop assembly language programs and design systems based on the Intel 8086 microprocessor through the use of lecture, demonstration, and laboratory "hands-on" experi-
ence with the SDK-86 and the Intellec Microcomputer Development System. The course outline for this workshop is presented in Table 6.

Prerequisites: The student has programmed a computer in assembly language and, preferably, is familiar with the 8080/8085 microprocessor.


Table 6. MCS-86 System Workshop Course Outline

## PL/M-86 Language/Software Design Workshop

This workshop will prepare the student for designing, developing, and debugging modular PL/M-86 programs using lecture, demonstration, and laboratory "handson" experience with the Intellec Microcomputer Devel-
opment System. The course outline for this workshop is presented in Table 7.

Prerequisites: A knowledge of binary and hexadecimal number systems and basic logic functions is required. To attain maximum benefit from course presentation, some background in logic design and computer programming is recommended.

Day 1
Introduction
a. Preview of course
b. Overview of PLM, linking and relocation
c. Why use a high level language

## Definitions

a. Symbols, identifiers, reserved words, comments, data elements, expressions, statements, declarations

## Data Elements

a. Variables, subscripted variables, constants

## Data Types

a. Logical, integer, real

Operators, Operations and Priorities
a. Arithmetic and boolean

Evaluating Expressions

## Statements

a. Redefine, basic, conditional

## Assignment

a. Implement a given algorithm in PL/M

Day 2
ISIS-II Disk Operating System
a. Components of system

ISIS-II File Structure
a. System files
b. User files
c. Device files
d. Directory and file attributes

## ISIS-II Commands

a. CUSPS - Commonly Used Sys. tem Programs
b. Directory and attribute commands
c. Rename and delete commands
d. Creating system and user disks

ISIS-II Editor
a. Definition of terminology
b. Invoking the editor
c. Editor commands
d. Editing existing files

## ISIS-II PL/M-86 Compiler

a. Invoking PLM
b. Compiler options

ISIS.II LOC-86
a. Invoking LOC-86

## Laboratory

a. Introduction to ISIS-II disk operating system
b. Creating a PL/M source file
c. Compiling a PLM program
d. Locating and executing a PL/M program
Day 3
Review

## Procedures

a. Declaration
b. Invocation
c. Program construction

## Data References

a. Based variables
b. Variable equivalencing
c. Pointer type

## Statement Labels

## Unconditional Transfers

## Blocks

a. Concept and use
b. Scope of declarations
c. Modular compilation
d. Modular program

ISIS-II LINK-86
a. Invoking LINK-86
b. Link options
c. Assembly object modules

## Laboratory

a. Compile program modules
b. Link and locate modules
c. Execute program

## Day 4

## Review

ISIS-II LIB-86
a. Creating a library
b. Managing a library

1. Adding modules
2. Deleting modules

## String Operations

a. Move bytes or words
b. Compare bytes or words
c. Find bytes or words
d. Skip bytes or words

The LOCKSET Procedure
a. Excluding mutual access

## Laboratory

a. Create a library
b. Link object to a library
c. Locate

Day 5
Review
Interrupt Procedures
Reentrant Procedures
Predeclared Procedues
a. TIME, MOVE, LENGTH, LAST and SIZE procedures
b. Type transfers
c. Shifts and rotates

The Memory Array and STACKPTR Variables
Discussion of Selected Programs

## Laboratory

a. Execution and debugging of selected programs

## MCS-48 System Workshop

This workshop will prepare the student to design and develop a system using the Intel 8049 microprocessor, by means of lectures, demonstrations, and laboratory "hands-on" experience with the Intellec Microcomputer Development System, the PROMPT-48, and an in-circuit
emulator. The course outline for this workshop is presented in Table 8.

Prerequisites: A knowledge of binary and hexadecimal number systems and basic logic functions is required. To attain maximum benefit from course presentation, some background in logic design or computer programming is recommended.

Day 1
Orientation
Introduction
a. Microprocessor System

1. Function
2. Organization
3. Programming
b. 8048 Overview
4. Functional Sections
5. Programming Model
6. Execution Sequence

Assembly Language Instructions
a. I/O Instructions
b. Data Move Instructions
c. Increment/Decrement Instructions
d. Branch Instructions
e. Worksession No. 1
f. Accumulator Group Instructions

1. ADD/ADDC
2. Logicals

PROMPT-48
a. Function
b. Operation

Laboratory Exercise
a. Program Entry and Execution Using PROMPT-48
Day 2
Assembly Language Instructions
a. Accumulator Group Instructions

1. Flags
2. Rotates
b. Specials (XCH, DA, SWAP)
c. Worksession No. 2
d. Subroutines
3. Invocation
4. Stack Operation
e. Interrupt System
5. Description
6. Service Subroutines
7. Multiple Source Systems

Development System
a. Function
b. Disk Operating System

Text Editor and Macro Assembler
a. Function
b. Operation

Laboratory Exercise
a. Bootstrap Procedures
b. Create, Edit, and Assemble Source Program
c. Execute Program

Day 3
System Timing
a. Basic Timing and Timer
b. Bus Timing for Peripheral Devices

Peripherals and Design
a. Expanding Memory

1. Program Memory (1, 2K ROMs)
2. Data Memory (RAMs)
b. Expanding Ports (8243)
3. Device Characteristics
4. Software Control of Ports
c. Combination Chips
5. 8155 RAM and I/O Chip
6. 8355,8755 ROM and I/O Chip
d. Peripheral Interfacing (Parallel)
7. 8255 Parallel I/O
8. 8279 Keyboard and Display Interface
-Keyboard Scanning
Techniques
-Display Refresh
Laboratory Exercise
a. Edit and Assemble Using DOS
b. Execute Using PROMPT-48

Day 4
Peripherals and Design
a. Peripheral Interfacing (Serial)

1. Transmission Formats
2. Asynchronous Operation
3. RS232C Interface

In-Circuit Emulator
a. Prototype Development
b. Resource Sharing
c. Commands

1. Mapping
2. Utility
3. Interrogation
4. Emulation

Laboratory Exercise
a. Use of the In-Circuit Emulator for System Debugging

Day 5
8048 Family
a. 8049
b. 8041

1. 8041/8048 Difference
2. 8041 Slave/Master Protocol
c. 8021
d. 8022

Analog Interfacing
a. Successive Approximation A/D
b. A/D, DIA Chips
c. A/D Design

Laboratory

## RMX/80 Real-Time Multi-Tasking Executive System Workshop

This workshop will cover the concepts of multi-tasking, i.e., what a task is, concurrency of tasks, asynchronous events, priorities and scheduling, resource sharing, interrupts, and inter-task communication. Also included will be discussions on sytem design, writing tasks,
system generation, and debugging. The course outline for this workshop is presented in Table 9.

Prerequisites: Prior attendance at the PL/M-80 language/software design workshop. This may be satisfied with an equivalent knowledge of PL/M-80 language and compiler, ISIS-II utility facilities, ISIS-II relocation facilities, and modular systems programming.


## Advanced MCS-86 Assembly Language Workshop

This workshop will prepare the student to program the 8086 components in assembly language. The design and programming of large systems, use of Link, Locate, and Library, Input/Output controllers, and ICE-86 are included. This advanced course reviews material presented in the intermediate level MCS-86 System Workshop, and then proceeds to investigate these more advanced topics.

Prerequisite: MCS-86 System Workshop.
Length: 5 days

TOPICS INCLUDE:
Review of Instruction Set
Assembler Directives
Segmentation
Programming of Input/Output Controllers

ICE-86
Reentrant Coding Interrupt Structures PL/M-86 Linkage iSBC 86/12

Table 10. Advanced MCS-86 Assembly Language Workshop Course Outline

## iSBC Design Project

The class is divided into teams and implements a project from given specifications. The system is built using several iSBC boards and is tested under ICE-85 (In-Circuit Emulator). The use of multiple processors is explored, and modular software development is emphasized.

Attendee: System designer or programmer and a graduate of an Intel workshop who wants more laboratory experience with the ICE-85 development tool, or who wants to design with iSBC boards. (Maximum attendance is 12.)

Prerequisite: MCS-80/85 System or PL/M-80 Language/Software Design Workshops.
Length: 5 days

## TOPICS INCLUDE:

iSBC Board Line Review
Multibus Operation and Interfacing
Design Specifications
Project Team Organizations
Module Development
Module Documentation

## Software Integration

ICE-85 Operation
Semaphores and Multiprocessor Communication
System Integration, Link/Locate
System Testing and Evaluation

Table 11. iSBC Design Project Course Outline

## REGISTRATION AND ADDITIONAL INFORMATION

Contact MCSD Training at Intel Corporation, Santa Clara, California 95051, (408) 987-8003 or your local Intel sales office.


## Industrial Grade Products

## INTEL INDUSTRIAL GRADE PRODUCTS

Intel's industrial grade components are designed for extended operating temperature ranges ( $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ ). They have been designed for reliable operation in severe industrial environments, and are fully tested and burned-in before delivery.

This section offers preliminary data sheets which include functional description, pin-out description and block diagram.

For copies of complete data sheets when available, contact Intel literature department, M/S 4-903, 3065 Bowers Avenue, Santa Clara, CA 95051

## TABLE OF CONTENTS

$121141024 \times 4$-Bit Static RAM ..... 13-3
12708/I8708 8K UV Erasable PROM . ..... 13-4
I2716 16K(2K $\times 8$ ) UV Erasable PROM ..... 13-5
18048/I8648/I8748/I8035 Single Component 8-Bit Microcomputer ..... 13-6
18155/I8156 2048-Bit Static MOS RAM With I/O Ports and Timer ..... 13-7
18212 8-Bit Input/Output Port ..... 13-8
18216/8226 4-Bit Parallel Bidirectional Bus Driver ..... 13-9
18243 MCS-48 Input/Output Expander ..... 13-10
18251 Programmable Communication Interface ..... 13-11
18255A Programmable Peripheral Interface ..... 13-12
18259 Programmable Interrupt Controller ..... 13-13
18279 Programmable Keyboard/Display Interface ..... 13-14
18355 16,384-Bit ROM With I/O ..... 13-15
18755A-8 16,384-Bit EPROM With I/O ..... 13-16

|  | $2114-3$ | 2114 | 2114 L 3 | 2114 L |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 300 | 450 | 300 | 450 |
| Max. Power Dissipation (mw) | 575 | 575 | 410 | 410 |

\author{

- High Density 18 Pin Package <br> ■ Identical Cycle and Access Times <br> - Single +5V Supply <br> - No Clock or Timing Strobe Required <br> - Completely Static Memory
}
■ Directly TTL Compatible: All Inputs and Outputs
- Common Data Input and Output Using Three-State Outputs
- Industrial Temperature Range $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ I2114 is a 4096 -bit statıc 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 12114 is designed for memory applications where high performance, low cost, large bit storage, and simple interfacing are important design objectives. The 12114 is placed in an 18-pin package for the highest possible density. It is directly TTL compatible in ali espects inputs, outputs, and a single +5 V supply. A separate Chip Select ( $\overline{\mathrm{CS}}$ ) lead allows easy selection of an individual package when outputs are OR-tied.

## PIN CONFIGURATION

LOGIC SYMBOL


PIN NAMES

| $A_{0}-A_{9}$ | ADDRESS INPUTS | $V_{C C}$ POWER ( +5 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


# I2708/I8708* <br> INDUSTRIAL GRADE 8K UV ERASABLE PROM 

|  | Max. Power | Max. Access | Organization |
| :---: | :---: | :---: | :---: |
| I 2708 | 800 mW | 450 ns | $1 \mathrm{~K} \times 8$ |

## - Industrial Grade Temperature <br> Range: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

- Fast Access Time - 450 ns Max

Static - No Clocks Required

- Data Inputs and Outputs TTL Compatible during both Read and Program Modes


## Three-State Outputs - OR-Tie Capability

The Intel ${ }^{\circledR}$ Industrial Grade I2708 is a 8192-bit ultraviolet light erasable and electrically reprogrammable EPROM, ideally suited where fast turnaround and pattern experimentation are important requirements. All data inputs and outputs are TTL compatible during both the read and program modes. The outputs are three-state, allowing direct interface with common system bus structures. The I2708 is fabricated with the N -channel silicon gate FAMOS technology and is available in a 24 -pin dual in-line package.


PIN NAMES

| $A_{0} \cdot A_{9}$ | ADDRESS INPUTS |
| :--- | :--- |
| $O_{1} \cdot O_{8}$ | DATA OUTPUTS/INPUTS |
| $\overline{C S} / W E$ | CHIP SELECTWRITE ENABLE INPUT |

$\mathrm{O}_{1} \cdot \mathrm{O}_{8}$ DATA OUTPUTS/INPUTS
CS/WE


PIN CONNECTION DURING READ OR PROGRAM

|  | PIN NUMBER |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | $\begin{gathered} \text { DATA I/O } \\ 9.11, \\ 13.17 \\ \hline \end{gathered}$ | ADDRESS <br> INPUTS <br> 1.8, <br> 22, 23 | $\begin{gathered} v_{\mathrm{ss}} \\ 12 \end{gathered}$ | $\begin{gathered} \text { PROGRAM } \\ 18 \\ \hline \end{gathered}$ | $\begin{gathered} V_{D D} \\ 19 \end{gathered}$ | $\begin{gathered} \overline{\mathrm{CS}} / \mathrm{WE} \\ 20 \\ \hline \end{gathered}$ | $\begin{gathered} V_{B B} \\ 21 \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{V}_{\mathrm{cc}} \\ \hline \end{gathered}$ |
| READ | Dout | AIN | GND | GND | +12 | $\mathrm{V}_{\text {IL }}$ | -5 | +5 |
| DESELECT | HIGH IMPEDANCE | DON'T CARE | GND | GND | +12 | $\mathrm{V}_{\mathrm{IH}}$ | -5 | +5 |
| PROGRAM | $\mathrm{DIN}^{\text {IN }}$ | $A_{\text {IN }}$ | GND | $\begin{gathered} \hline \text { PUISED } \\ 26 \mathrm{~V} \end{gathered}$ | +12 | $\mathrm{V}_{\text {IHW }}$ | -5 | +5 |

Fast Access Time: 450 ns Max

- Industrial Grade Temperature
Range: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- Single +5V Power Supply
- Low Power Dissipation
- 603 mW Max. Active Power
- 165 mW Max. Standby Power


## - Simple Programming Requirements Single Location Programming Programs with One 50 ms Pulse

- Inputs and Outputs TTL Compatible during Read and Program


## - Completely Static

The Intel ${ }^{\oplus}$ Industrial Grade I2716 is a 16,384 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The I2716 operates from a single 5-volt power supply, has a static standby mode, and features fast single address location programming. It makes designing with EPROMs faster, easier and more economical.

The I2716, with its single 5 -volt supply and with an access time of 450 ns max, is ideal for use with the newer high performance industrial grade +5 V microprocessors such as Intel's I8085 and I8086. The I2716 is also the first EPROM with a static standby mode which reduces the power dissipation without increasing access time. The maximum active power dissipation is 603 mW while the maximum standby power dissipation is only 165 mW , a $75 \%$ savings.

The I2716 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. Program any location at any time-either individually, sequentially or at random, with the I2716's single address location programming. Total programming time for all 16,384 bits is only 100 seconds.

PIN CONFIGURATION
12716


PIN NAMES

| $A_{0}-A_{10}$ | ADDRESSES |
| :--- | :--- |
| $\overline{C E / P G M}$ | CHIP ENABLE/PROGRAM |
| $\overline{O E}$ | OUTPUT ENABLE |
| $O_{0}-O_{1}$ | OUTPUTS |

MODE SELECTION

|  | $\overline{C E} /$ PGM <br> (18) | $\begin{gathered} \overline{O E} \\ (20) \end{gathered}$ | $V_{\text {PP }}$ <br> (21) | $v_{c c}$ (24) | OUTPUTS $(9.11,13.17)$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | +5 | DOUT |
| Standby | $V_{\text {IH }}$ | Don't Care | +5 | +5 | High $Z$ |
| Program | Pulsed $V_{\text {IL }}$ to $V_{\text {IH }}$ | $V_{\text {IH }}$ | +25 | +5 | DIN |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +25 | +5 | DOUT |
| Program Inhibit | $V_{\text {IL }}$ | $V_{\text {IH }}$ | +25 | +5 | High 2 |

BLOCK DIAGRAM


## intel

# INDUSTRIAL TEMPERATURE RANGE SINGLE COMPONENT 8-BIT MICROCOMPUTER 

18048/I8648/I8748/I8035

- 8048 Mask Programmable ROM
- 8648 One-Time Factory Programmable EPROM
- 8748 User Programmable/Erasable EPROM
- 8035/8035L External ROM or EPROM
- $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operation
- 8-Bit CPU, ROM, RAM, I/O in Single Package
- Interchangeable ROM and EPROM Versions
- Single 5V Supply
- $2.5 \mu \mathrm{sec}$ and $5.0 \mu \mathrm{sec}$ Cycle Versions: All instructions 1 or 2 Cycles
- Over 90 Instructions: 70\% Single Byte
- $1 \mathrm{~K} \times 8$ ROM/EPROM
$64 \times 8$ RAM


## 27 I/O LINES

- Interval Timer/Event Counter
- Easily Expandable Memory and I/O

Compatible with 8080/8085 Series Peripherals
Single Level Interrupt

The Intel ${ }^{\circledR} 8048 / 8648 / 8748 / 8035$ is a totally self-sufficient 8 -bit parallel computer fabricated on a single silicon chip using Intel's N -channel silicon gate MOS process.
The 8048 contains a $1 \mathrm{~K} \times 8$ program memory, a $64 \times 8$ RAM data memory, 27 I/O lines, and an 8 -bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability, the 8048 can be expanded using standard memories and MCS- $80^{T M} / \mathrm{MCS}-85^{T M}$ peripherals. The 8035 is the equivalent of an 8048 without program memory. The 8035L has the RAM power-down mode of the 8048 while the 8035 does not. The 8648 is a one-time programmable (at the factory) 8748 which can be ordered as the first 25 pieces of a new 8048 ROM order. The substitution of 8648 's for 8048 's allows for very fast turnaround for initial code verification and evaluation units.
To reduce development problems to a minimum and provide maximum flexibility, three interchangeable pin-compatible versions of this single component microcomputer exist: the 8748 with user-programmable and erasable EPROM program memory for prototype and preproduction systems, the 8048 with factory-programmed mask ROM program memory for low cost, high volume production, and the 8035 without program memory for use with external program memories.
This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The 8048 has extensive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from an instruction set consisting mostly of single byte instructions and no instructions over 2 bytes in length.

PIN CONFIGURATION


LOGIC SYMBOL


BLOCK DIAGRAM


DATA MEMORY


27
I/O LINES

## I8155/I8156 2048 BIT STATIC MOS RAM WITH I/O PORTS AND TIMER

Industrial Temperature Range<br>$\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$<br>256 Word x 8 Bits<br>Single $+5 V$ Power Supply<br>Completely Static Operation<br>Internal Address Latch

The 18155 and 18156 are RAM and I/O chips to be used in the MCS- $85^{\text {TM }}$ microcomputer system. The RAM portion is designed with 2048 static cells organized as $256 \times 8$. They have a maximum access time of 400 ns to permit use with no wait states in 18085A 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 depending on timer mode.


## I8212 <br> 8-BIT INPUT/OUTPUT PORT

3.65V Output High Voltage for Direct Interface to 8008, 8080A, or 8085A CPU

- Asynchronous Register Clear
- Replaces Buffers, Latches and Multiplexers in Microcomputer Systems
$\square-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Temp Range

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.
Note: The specifications for the 3212 are identical with those for the 8212.


## I8216/8226 <br> 4 BIT PARALLEL BIDIRECTIONAL BUS DRIVER

- Data Bus Buffer Driver for 8080 CPU
- Low Input Load Current - . 25 mA Maximum
- High Output Drive Capability for Driving System Data Bus
- 3.65V Output High Voltage for Direct Interface to $\mathbf{8 0 8 0}$ CPU
- Three State Outputs
- Reduces System Package Count
- $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Temp Range

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 mA lol 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} \cdot \mathrm{DB}_{3}$ | DATA BUS <br> BI-DIRECTIONAL |
| :--- | :--- |
| $\mathrm{DI}_{0} \cdot \mathrm{DI}_{3}$ | DATA INPUT |
| $\mathrm{DO}_{0} \cdot \mathrm{DO}_{3}$ | DATA OUTPUT |
| $\overline{\text { DIEN }}$ | DATA IN ENABLE <br> DIRECTIEN CONTROL |
| $\overline{\mathrm{C}}$ | CHIP SELECT |

CHIP SELECT

LOGIC DIAGRAM
8216

$$
8216
$$



LOGIC DIAGRAM 8226


# I8243 <br> MCS-48™ ${ }^{\text {T }}$ INPUT/OUTPUT EXPANDER 

\author{

- $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Operation <br> - Low Cost <br> - Simple Interface to MCS-48 ${ }^{\text {™ }}$ Microcomputers <br> - Four 4-Bit I/O Ports <br> - AND and OR Directly to Ports
}

The Intel 8243 is an input/output expander designed specifically to provide a low cost means of I/O expansion for the MES-48 ${ }^{\text {T" }}$ family of single chip microcomputers. Fabricated in 5 volts NMOS, the 8243 combines low cost, single supply voltage and high drive current capability.
The 8243 consists of four 4-bit bidirectional static I/O ports and one 4-bit port which serves as an interface to the MCS-48 microcomputers. The 4-bit interface requires that only 4 I/O lines of the 8048 be used for I/O expansion, and also allows multiple 8243's to be added to the same bus.

The I/O ports of the 8243 serve as a direct extension of the resident I/O facilities of the MCS-48 microcomputers and are accessed by their own MOV, ANL, and ORL instructions.

## PIN CONFIGURATION

BLOCK DIAGRAM


- 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.
- Industrial Grade Temperature Range $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$


## Full Duplex, Double Buffered, Transmitter and Receiver

## Error Detection - Parity, Overrun and Framing

## 28-Pin DIP Package

## - All Inputs and Outputs are TTL Compatible

Single +5V Supply

. Single TTL Clock

The Intel ${ }^{\circledR}$ I8251 is a Universal Synchronous/Asynchronous Receiver/Transmitter (USART), designed for data communications with Intel's new high performance family of microprocessors such as the 8085. The I8251 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


PIN NAMES

| D/ $D_{0}$ | Data Bus (8 bits) |
| :--- | :--- |
| $C / D$ | Control or Data is to be Written or Read |
| $\overline{R D}$ | Read Data Conimand |
| $\overline{W R}$ | Write Data or Control Command |
| $\overline{C S}$ | Chip Enable |
| $C L K$ | Clock Pulse (TTL) |
| RESET | Reset |
| $\overline{T \times C}$ | Transmitter Clock |
| $T \times D$ | Transmitter Data |
| $\overline{R \times C}$ | Receiver Clock |
| $R \times D$ | Receiver Data |
| $R \times R D Y$ | Receiver Ready (has character for 8080) |
| $T \times R D Y$ | Transmitter Ready (ready for char from 8080) |

BLOCK DIAGRAM


## I8255A PROGRAMMABLE PERIPHERAL INTERFACE

\author{

- Extended Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}$ ) <br> - 24 Programmable I/O Pins <br> - Completely TTL Compatible <br> - Improved Timing Characteristics
}
- Direct Bit Set/Reset Capability Easing Control Application Interface

\author{

- 40-Pin Dual In-Line Package
}


#### Abstract

The Inte $I^{\circledR}$ 8255A is a general purpose programmable I/O device designed for use with Intel ${ }^{\circledR}$ microprocessors. It has 24 I/O pins which may be individually programmed in 2 groups of 12 and used in 3 major modes of operation. In the first mode (MODE 0), each group of 12 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 4 pins, 3 are used for hand- shaking and interrupt control signals. The third mode of operation (MODE 2 ) is a bidirectional bus mode which uses 8 shaking and interrupt control signals. The third mode of operation (MODE 2) is a bidirectional bus mode which uses 8 lines for a bidirectional bus, and 5 lines, borrowing one from the other group, for handshaking.


8255A BLOCK DIAGRAM


PIN CONFIGURATION


| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| RESET | RESET INPUT |
| $\overline{C S}$ | CHIP SELECT |
| $\overline{\text { RD }}$ | READ INPUT |
| $\overline{\text { WR }}$ | WRITE INPUT |
| AO, AI | PORT ADDRESS |
| PA7-PAO | PORT A (BIT) |
| PB7-PB0 | PORT B (BIT) |
| PC7-PCO | PORT C (BIT) |
| VCC | +5 VOLTS |
| GND | SVOLTS |

## PIN NAMES

- . -

\author{

- Reduces System Package Count <br> - Improved DC Driving Capability
}
- MCS-86 ${ }^{\text {TM }}$ Compatible
- MCS-80/85 ${ }^{\text {TM }}$ Compatible
- Eight-Level Priority Controller
- Expandable to 64 Levels
- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single +5V Supply (No Clocks)
- $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ Temp. Range

The Intel 8259 Programmable interrupt Controller handles up to eight vectored priority interrupts for the CPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry. It is packaged in a 28 -pin 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 |
| CAS2-CASO | CASCADE LINES |
| SP/EN | SLAVE PROGRAM INPUT/ENABLE |
| INT | INTERRUPT OUTPUT |
| $\overline{I N T A}$ | INTERRUPT ACKNOWLEDGE INPUT |
| IRO-IRT | INTERRUPT REQUEST INPUTS |

BLOCK DIAGRAM


# I8279 <br> PROGRAMMABLE KEYBOARDIDISPLAY INTERFACE 

－Extended Temperature Range
$\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

## Simultaneous Keyboard Display Operations

－Scanned Keyboard Mode
－Scanned Sensor Mode
－Strobed Input Entry Mode
－8－Character Keyboard FIFO

## 2－Key Lockout or N－Key Rollover with Contact Debounce

－Dual 8－or 16－Numerical Display
－Single 16－Character Display
－Right or Left Entry 16－Byte Display
－Mode Programmable from CPU
－Programmable Scan Timing
－Interrupt Output on Key Entry

The Intel ${ }^{\circledR} 8279$ is a general purpose programmable keyboard and display I／O interface device designed for use with Intel ${ }^{\circledR}$ microprocessors．The keyboard portion can provide a scanned interface to a 64 －contact key matrix．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，overrun 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 $16 \times 8$ display RAM which can be organized into 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

| $\mathrm{RL}_{2} \square_{1}$ | 1 | 40 | $\mathrm{v}_{\text {cc }}$ |
| :---: | :---: | :---: | :---: |
| $\mathrm{RL}_{3} \mathrm{C}$ | 2 | 39 | $\square^{R} L_{1}$ |
| CLK | 3 | 38 | －RLo |
| IRO－ | 4 | 37 | 万cntl／stb |
| $\mathrm{RL}_{4} \mathrm{C}$ | 5 | 36 | Shift |
| RL5 | 6 | 35 | $\mathrm{SL}_{3}$ |
| $\mathrm{RL}_{6} \mathrm{C}$ | 7 | 34 | $\mathrm{SL}_{2}$ |
| RL， | 8 | 33 | SL |
| reset | ${ }^{18} 88279$ | 32 | $\mathrm{Q}^{\mathrm{sL}}$ |
| $\overline{\text { 人̇D }}$ | $10{ }^{18279}$ | 31 | －out $\mathrm{B}_{0}$ |
| WR | 11 | 30 | Dout $\mathrm{B}_{1}$ |
| $\mathrm{DB}_{0}$－ | 12 | 29 | Pout $\mathrm{B}_{2}$ |
| D8， | 13 | 28 | Dout $\mathrm{B}_{3}$ |
| $\mathrm{DB}_{2}$ | 14 | 27 | pout $A_{0}$ |
| $\mathrm{DB}_{3} \mathrm{C}$ | 15 | 26 | gout $A_{1}$ |
| $\mathrm{DB}_{4} \mathrm{H}$ | 16 | 25 | pọit $A_{2}$ |
| $\mathrm{DB}_{5} \mathrm{C}$ | 17 | 24 | Dout $A_{3}$ |
| $\mathrm{DB}_{6} \mathrm{C}$ | 18 | 23 | 口 $\square^{80}$ |
| $\mathrm{DB}_{7}$ | 19 | 22 | ］cs |
| $\mathrm{vss}^{4}$ | 20 | 21 | $\square^{\prime}$ |

PIN NAMES

| $\mathrm{DB}_{07}$ | L，O | DATA BUS（BI DIRECTIONAL） |
| :---: | :---: | :---: |
| CLK | 1 | CLOCK INPUT |
| RESET | 1 | RESET INPUT |
| CS | 1 | CHIP SELECT |
| \％${ }^{\circ}$ | 1 | READ INPUT |
| WA | 1 | WRITE INPUT |
| $\mathrm{A}_{0}$ | 1 | BUFFER ADDRESS |
| IRO | 0 | INTERRUPT REOUEST OUTPUT |
| $\mathrm{SL}_{03}$ | 0 | SCAN LINES |
| RL07 | 1 | RETURN LINES |
| SHIFT | 1 | SHIFT INPUT |
| CNTL／STB | 1 | CONTROL／STROBE INPUT |
| OUT $A_{0,3}$ | 0 | DISPLAY（A）OUTPUTS |
| OUT $\mathrm{B}_{03}$ | 0 | DISPLAY（B）OUTPUTS |
| B0 | 0 | BLANK DISPLAY OUTPUT |

LOGIC SYMBOL


## intel

## 18355* <br> 16,384-BIT ROM WITH I/O <br> *Directly Compatible with I8085A CPU

- Industrial Temperature Range
$\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- 2048 Words $\times 8$ Bits
- Single +5V Power Supply


## - 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 Intel ${ }^{(8)} 8355$ is a ROM and I/O chip to be used in the MCS-85"u microcomputer system. The ROM portion is organized as 2048 words by 8 bits. It has a maximum access time of 400 ns to permit use with no wait states in the I8085A CPU.

The I/O portion consists of 2 general purpose I/O ports. Each I/O port has 8 port lines, and each I/O port line is indivdually programmable as input or output.

PIN CONFIGURATION


BLOCK DIAGRAM


I8755A-8
16,384-BIT EPROM WITH I/O

- Directly Compatible with I8085A CPU
- Industrial Temperature Range
$\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- 2048 Words $\times 8$ Bits
- Single +5V Power Supply ( $\mathbf{V c c}_{\text {cc }}$
- 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 Intel® 8755A is an erasable and electrically reprogrammable ROM (EPROM) and I/O chip to be used in the MCS-85 ${ }^{\text {mu }}$ microcomputer system. The EPROM portion is organized as 2048 words by 8 bits. It has a maximum access time of 750 ns to permit use with one wait state in a 3 MHz 8085A system.
The I/O portion consists of 2 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.



## INTEL MILITARY PRODUCTS

In 1977, Intel qualified the first military microprocessor to MIL-M-38510. The JAN version of the industry standard 8080A is listed in QPL, Part I as M38510/42001BQB.

Intel also offers an extensive family of selected microprocessor and memory components for military/hi-rel applications. All standard military products are screened to full Level B requirements of MIL-STD-883B, Method 5004. Additionally, complete lot conformance testing is performed in accordance with MIL-STD-883B, Method 5005.

## TABLE OF CONTENTS

M1702A ..... $14-4$
M2114 ..... $14-6$
M2115A, M2125A ..... 14-10
M2147 ..... 14-15
M2708 ..... 14-21
M2716 ..... 14-27
M3604A, M3624A ..... 14-32
M3625A ..... $14-34$
M3636 ..... 14-37
M5101-4, M5101L-4 ..... $14-40$
M8080A ..... $14-43$
M8212 ..... $14-48$
M8214 ..... $14-53$
M8216/M8226 ..... $14-56$
M8224 ..... 14-59
M8228 ..... 14-63
M8251 ..... $14-68$
M8255A ..... 14-71
M8085A ..... $14-74$
M8155 ..... $14-87$
M8257 ..... 14-98
M8259 ..... 14-105
M8048/M8748/M8035 ..... 14-110

## MILITARY PRODUCT REQUIREMENTS

| General Requirements | MIL-M-38510 Requirements | JAN (Level B) | $\begin{gathered} 883 \\ \text { (Level B) } \end{gathered}$ |
| :---: | :---: | :---: | :---: |
| CERTIFICATION <br> A. Product Assurance Program Plan <br> B. Manufacturer's Certification | Para. 3.4.1.2 <br> Para. 3.4.1.2.1 | $X$ $X$ | N/A N/A |
| DEVICE QUALIFICATION | Para. 4.4 | X | N/A |
| TRACEABILITY | Para. 3.4.6 | X | N/A |
| COUNTRY OF MANUFACTURE | Para. 3.2.1 | X | N/A |
| Screening Test Requirements | Screening Per Method 5004 of MIL-STD-883 |  |  |
| INTERNAL VISUAL | 2010, Cond. B | 100\% | 100\% |
| STABILIZATION BAKE | 1008, Cond. C <br> (24 Hrs. @ $150^{\circ} \mathrm{C}$ ) | 100\% | 100\% |
| TEMPERATURE CYCLING | 1010, Cond. C (10 cycles $\left.-65^{\circ} \mathrm{C} \text { to }+150^{\circ} \mathrm{C}\right)$ | 100\% | 100\% |
| CONSTANT ACCELERATION | 2001, Cond. D or E As Applicable | 100\% | 100\% |
| SEAL (HERMETICITY) <br> A. Fine <br> B. Gross | 1014 <br> Cond. B ( $5 \times 10$ atm-cc/sec) <br> Cond. C | 100\% | 100\% |
| PRE BURN-IN ELECTRICAL | Per Applicable Device Specification | 100\% | 100\% |
| BURN-IN | 1015, Cond. C or F <br> ( 160 Hrs. @ $125^{\circ} \mathrm{C}$ ) | 100\% | 100\% |
| FINAL ELECTRICAL TESTS <br> A. Static (@ $25^{\circ} \mathrm{C}$, Min and Max Rated Temp) <br> B. Dynamic and Functional (@ $25^{\circ} \mathrm{C}$ ) | Per Applicable Device Specification Per Applicable Device Specification | $100 \%$ $100 \%$ | $100 \%$ $100 \%$ |
| EXTERNAL VISUAL | 2009 | 100\% | 100\% |
| Quality Conformance Inspection Tests | Per MIL-STD-883, Method 5005 | JAN (Level B) | $\begin{gathered} 883 \\ \text { (Level B) } \end{gathered}$ |
| GROUP A Electrical Tests | Per Applicable Device Specification. Table I, Subgroups as Required | Every Inspection Lot | Every Inspection Lot |
| GROUP B Package Function and Mechanical Tests | Per Table llb, Subgroups 1-3 | Every 6 <br> Weeks | Every 6 Weeks |
| GROUP C Die Related Tests | Per Table III, Subgroups 1 and 2 | Every 12 <br> Weeks | Every 12 <br> Weeks |
| GROUP D <br> Package Related Tests | Per Table IV, Subgroups 1-5 | Every 6 Months | Every 6 Months |

M1702A

## 2K (256 $\times 8$ ) UV ERASABLE PROM

$-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ OPERATION
■ Fast Access Time: Max. 850ns

- Completely Static
- Inputs and Outputs DTL and TTL Compatible
- All 2048 Bits Factory Tested Prior to Shipment
- Three-State Output
- 24 Pin Dip

The Intel ${ }^{\circledR}$ M1702A is a 256 -word by 8 -bit ultraviolet light erasable and electrically reprogrammable EPROM which is specified over the $-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ temperature range. The M1702A has a transparent lid which allows the user to expose the M1702A to UV light to erase the bit pattern. A new pattern can then be written into the device.

| PIN CONFIGURATION | ABSOLUTE MAXIMUM RATINGS* |
| :---: | :---: |
|  | Ambient Temperature Under Bias .... $-65^{\circ} \mathrm{C}$ to $110^{\circ} \mathrm{C}$ |
|  | Storage Temperature . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
|  | Soldering Temperature of Leads ( 10 sec ) . . . . . . . $+300^{\circ} \mathrm{C}$ |
| ${ }^{A_{0}}-3 \quad 22-v_{\text {cc }}$ | Power Dissipation . . . . . . . . . . . . . . . . . . . 2 Watts |
| - Dataout , - (lsb) ${ }^{29}$ - ${ }^{\text {a }}$ | Read Operatıon: Input Voltages and Supply |
| - Data out $2=5$ | Voltages with respect to $\mathrm{V}_{\mathrm{CC}}$. . . . . . . . +0.5 V to -20 V |
| -data out 3-6 $619-a_{5}$ | Program Operation: Input Voltages and Supply |
| -data out $4-$, $18 .-A_{6}$ | Voltages with respect to $\mathrm{V}_{\mathrm{CC}} \ldots . . . . . . . . . . . . ~-48 V ~$ |
| -data out 5 -a may |  |
| - data out 6 - | *COMMENT |
| - oata out r- 10 15 $-v_{\text {bb }}$ | Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a |
| - oata out e- 11 lmsb ) ${ }^{14}$ | stress rating only and functional operation of the device at |
| $\mathrm{vcc}_{\text {ct }} 12 \times 13-$ Program | these or at any other condition above those indicated in |
| -this pin is the data input lead during programming | the operational sections of this specification is not implied. |
| refer to the tuoza data sheet for pin connections during read ano program | Exposure to Absolute Maxımum Rating conditions for extended periods may affect device reliability. |

## D.C. AND OPERATING CHARACTERISTICS <br> $T_{A}=-55^{\circ} \mathrm{C}$ to $100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=-9 \mathrm{~V} \pm 10 \%$,

 READ OPERATION| Symbol | Test | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LI}}$ | Address and Chip Select Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.0 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}, \overline{\mathrm{CS}}=\mathrm{V}_{1 \mathrm{H} 2}$ |
| $\mathrm{IDD1}^{\text {[1] }}$ | Power Supply Current |  | 35 | 50 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IH} 2}, \mathrm{I}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \text {, Continuous } \end{aligned}$ |
| IDD2 | Power Supply Current |  | 32 | 46 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=0.0 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \text { Continuous } \end{aligned}$ |
| IDD3 | Power Supply Current |  | 38 | 65 | mA | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{1 \mathrm{H} 2}, \mathrm{IOL}=0.0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text {, Continuous } \end{aligned}$ |
| $\mathrm{I}_{\text {cF }}$ | Output Clamp Current |  | 8 | 11 | mA | $\begin{aligned} & V_{\text {OUT }}=-1.0 \mathrm{~V}, \\ & T_{A}=-55^{\circ} \mathrm{C} \text {, Continuous } \end{aligned}$ |
| $\mathrm{I}_{\text {GG }}$ | Gate Supply Current |  |  | 10 | $\mu \mathrm{A}$ |  |
| $V_{\text {IL } 1}$ | Input Low Voltage for TTL Interface | -1 |  | 0.65 | V |  |
| $V_{\text {IL2 }}$ | Input Low Voltage for MOS Interface | $\mathrm{V}_{\mathrm{DD}}$ |  | $\mathrm{V}_{\mathrm{CC}}{ }^{-6}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Address Input High Voltage | $\mathrm{V}_{\mathrm{Cc}}-2$ |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | Chip Select Input High Voltage | $\mathrm{V}_{C C}-1.5$ |  | $\mathrm{V}_{C C}+0.3$ | V |  |
| lOL | Output Sink Current | 1.6 | 4 |  | mA | $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}$ |
| IOH | Output Source Current | -2.0 |  |  | mA | $\mathrm{V}_{\text {OUT }}=0.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | -3 | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 3.5 | 4.5 |  | V | $\mathrm{IOH}=-200 \mu \mathrm{~A}$ |

Note 1. Typical values are at nominal voltages and $T_{A}=25^{\circ} \mathrm{C}$.

## A.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=-9 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{GG}}=-9 \mathrm{~V} \pm 10 \%$ unless otherwise noted.

| Symbol | Test | Limits | Unit |
| :---: | :---: | :---: | :---: |
|  |  | Min. Max. |  |
| Freq. | Repetition Rate | 1.2 | MHz |
| $\mathrm{tOH}^{\text {H }}$ | Previous Read Data Valid | 0.1 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to Output Delay | 0.85 | $\mu \mathrm{s}$ |
| ${ }^{\text {t }}$ Cs | Chip Select Delay | 0.5 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{CO}}$ | Output Delay From CS | 0.35 | $\mu \mathrm{s}$ |
| tob | Output Deselect | 0.3 | $\mu \mathrm{s}$ |

CAPACITANCE * $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| SYMBOL | TEST | TYPICAL | MAXIMUM | UNIT | CONDITIONS |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 8 | 15 | pF | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ <br> $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 10 | 15 | pF | AII <br> unused pins <br> $\mathrm{V}_{\mathrm{OUT}}$ <br> $\mathrm{V}_{\mathrm{GG}}$ <br> $=V_{\mathrm{CC}}$ | | are at A.C. |
| :--- |
| ground |

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

## SWITCHING CHARACTERISTICS

## Conditions of Test:

Input pulse amplitudes: 0 to $4 \mathrm{~V} ; \mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}} \leq 50 \mathrm{~ns}$ Output load is 1 TTL gate; measurements made at output of TTL gate ( $\mathrm{t}_{\mathrm{PD}} \leqslant 15 \mathrm{~ns}$ ), $\mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$
A) READ OPERATION


## ERASING AND PROGRAMMING PROCEDURE

The erasing and programming procedure of the M1702A is the same as the $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} 1702 \mathrm{~A}$. The procedure is described in the Data Catalog PROM/ROM Programming Instructions section.
B) DESELECTION OF DATA OUTPUT IN OR-TIE OPERATION


# M2114 <br> $1024 \times 4$ BIT STATIC RAM 

|  | $2114-3$ | 2114 | 2114 L3 | 2114 L |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 300 | 450 | 300 | 450 |
| Max. Power Dissipation (mw) | 575 | 575 | 410 | 410 |

## ■ High Density 18 Pin Package

- Identical Cycle and Access Times
- 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 OutputsMilitary Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel ${ }^{®}$ M2114 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 M2114 is designed for memory applications where high performance, low cost, large bit storage, and simple interfacing are important design objectives. The M2114 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{\mathrm{CS}}$ ) lead allows easy selection of andividual package when outputs are OR-tied.

PIN CONFIGURATION


LOGIC SYMBOL


## PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{9}$ | ADDRESS INPUTS | $V_{\text {CC }}$ POWER $(+5 \mathrm{~V})$ |
| :--- | :--- | :--- |
| $\overline{W E}$ | WRITE ENABLE | GND GROUND |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |  |
| $\mathrm{I} / \mathrm{O}_{1}-\mathrm{I} / \mathrm{O}_{4}$ | DATA INPUT/OUTPUT |  |

BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\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
D.C. Output Current . . . . . . . . . . . . . . . . . . . . . 5mA
*COMMENT: Stresses above those iisted under" "Absolute Maximum Ratings" may cause permanemt damage to the device. This is a stress rating only and functionat 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. AND OPERATING CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{C}}=5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

| SYMBOL | PARAMETER | M2114, M2114-3 |  |  | M2114L3, M2114L3 |  |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ.[1] | Max. | Min. | Typ.[1] | Max. |  |  |
| $I_{\text {LI }}$ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0$ to 5.5 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} & V_{I N}=5.5 \mathrm{~V}, \quad I_{I / O}=0 \mathrm{~mA}, \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | Power Supply Current |  |  | 105 |  |  | 75 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V} \quad \mathrm{I}_{\mathrm{I} / \mathrm{O}}=0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=-55^{\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.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.0 | -1.4 |  | -1.0 | -1.4 |  | mA | $\mathrm{VOH}=2.4 \mathrm{~V}$ |
| $\mathrm{IOS}^{[2]}$ | Output Short Circuit Current |  |  | 40 |  |  | 40 | mA |  |

NOTE: 1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $V_{C 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 |
| :--- | :--- | :---: | :---: | :--- |
| $C_{1 / O}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{1 / \mathrm{O}}=\mathrm{OV}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{\mathrm{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.0 Volt
Input Rise and Fall Times ..... 10 nsec
Input and Output Timing Levels ..... 1.5 Volts
Output Load ..... 1 TTL Gate and $C_{L}=100 \mathrm{pF}$

TEST NOTE: This circuit employs a self starting oscillator and a charge pump which require a certain amount of time after POWER ON to start functioning properly. This M2114 circuit is conservatively specified as requiring $500 \mu \mathrm{sec}$ after $\mathrm{V}_{\mathrm{CC}}$ reaches its specified limits (4.50V).
A.C. CHARACTERISTICS $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

READ CYCLE ${ }^{[1]}$

| SYMBOL | PARAMETER | M2114, M2114L |  | M2114-3, M2114L3 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle Time | 450 |  | 300 |  | ns |
| $t_{A}$ | Access Time |  | 450 |  | 300 | ns |
| $\mathrm{t}_{\mathrm{co}}$ | Chip Selection to Output Valid |  | 120 |  | 100 | ns |
| $\mathrm{t}_{\mathrm{CX}}$ | Chip Selection to Output Active | 20 |  | 20 |  | ns |
| toto | Output 3-state from Deselection |  | 100 |  | 80 | ns |
| $\mathrm{t}_{\mathrm{OHA}}$ | Output Hold from Address Change | 50 |  | 50 |  | ns |

## WRITE CYCLE [2]

| SYMBOL | PARAMETER | M2114, M2114L |  | M2114-3, M2114L3 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {wc }}$ | Write Cycle Time | 450 |  | 300 |  | ns |
| $t_{w}$ | Write Time | 200 |  | 150 |  | ns |
| $t_{\text {WR }}$ | Write Release Time | 0 |  | 0 |  | ns |
| totw | Output 3-state from Write |  | 100 |  | 80 | ns |
| $\mathrm{t}_{\text {DW }}$ | Data to Write Time Overlap | 200 |  | 150 |  | ns |
| $t_{\text {DH }}$ | Data Hold From Write Time | 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)}$


NOTES:
(3) $\overline{W E}$ is high for a Read Cycle.
(4) If the $\overline{C S}$ low transition occurs simultaneously with the $\overline{W E}$ low transition, the output buffers remain in a high impedance state.
(5) $\overline{W E}$ must be high during all address transitions.

## WRITE CYCLE



TYPICAL D.C. AND A.C. CHARACTERISTICS


NORMALIZED ACCESS TIME VS. OUTPUT LOAD CAPACITANCE


OUTPUT SOURCE CURRENT
VS. OUTPUT VOLTAGE


NORMALIZED POWER SUPPLY CURRENT
VS. AMBIENT TEMPERATURE


NORMALIZED ACCESS TIME VS AMBIENT TEMPERATURE


OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE

$V_{\mathrm{OL}}(\mathrm{V})$

|  | M2115AL, M2125AL | M2115A, M2125A |
| :---: | :---: | :---: |
| Max. TAA (ns) | 75 | 55 |
| Max. ICC (mA) | 75 | 125 |

HMOS Technology<br>■ Low Operating Power Dissipation 413mW (M2115AL, M2125AL)<br>- Fast Access Time Over $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ - 55ns Maximum (M2115A, M2125A)<br>■ Single 5V Supply with $\pm 10 \%$ Tolerance

TTL Inputs and Output<br>- Uncommitted Collector (M2115A, M2115AL) and Three State (M2125A, M2125AL) Output<br>■ Non-Inverting Data Output<br>Hermetic 16 Pin Dual In-Line Package

The Intel® M2115A and M2125A families are fully static, random access memories (RAMs) organized as 1024 words by 1 bit, which operate over a $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ ambient temperature range. Both open collector (M2115A) and three-state (M2125A) outputs are available. The M2115A and M2125A use fully DC stable (static) circuitry throughout in both the array and the decoding, and, therefore, require no clocks or refreshing to operate. The data is read out nondestructively and has the same polarity as the input data.
The M2115AL and M2125AL are ideal for high-performance systems where speed and power dissipation are significant design considerations. They have a maximum access time of 75 ns , while power dissipation is only 413 mW maximum. The M2115A and M2125A at 55 ns maximum should be considered for applications in which speed is a primary design objective.
The devices are directly TTL compatible in all respects: inputs, outputs and a single +5 V supply. A separate chip select lead allows easy selection of an individual package when outputs are OR-tied.
PIN CONFIGURATION

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+135^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output or Supply Voltages. . . . . . . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . . . . . . . . -0.5 V to +6 V
D.C. Output Current . . . . . . . . . . . . . . . . . . . . . 20 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 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 ${ }^{[1,2]}$

$\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| Symbol | Test | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {OL1 }}$ | M2115A, M2115AL Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | M2125A, M2125AL Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.1 |  |  | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.8 | V |  |
| $\mathrm{I}_{\text {IL }}$ | Input Low Current |  | -0.1 | -40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max., $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{IH}}$ | Input High Current |  | 0.1 | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max., $\mathrm{V}_{\text {IN }}=4.5 \mathrm{~V}$ |
| $\mathrm{I}_{\text {CEX }}$ | M2115A, M2115AL Output Leakage Current |  | 0.1 | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max., $\mathrm{V}_{\text {OUT }}=4.5 \mathrm{~V}$ |
| $\mid I \mathrm{OFF}$ \| | M2125A, M2125AL Output Leakage Current (High Z) |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max},. \mathrm{~V}_{\text {OUT }}=0.5 \mathrm{~V} / 2.4 \mathrm{~V}$ |
| $\mathrm{IOS}^{[3]}$ | M2125A, M2125AL Current Short Circuit to Ground |  |  | -100 | mA | $V_{C C}=$ Max . |
| $\mathrm{V}_{\mathrm{OH}}$ | M2115A, M2115AL Output High Voltage | 2.4 |  |  | V | $\mathrm{l}_{\mathrm{OH}}=-3.2 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | M2115AL, M2125AL Power Supply Current |  | 60 | 75 | mA | All Inputs Grounded, Output Open |
| $\mathrm{I}_{\mathrm{CC} 2}$ | M2115A, M2125A Power Supply Current |  | 100 | 125 | mA | All Inputs Grounded, Output Open |

## NOTES:

1. The operating ambient temperature ranges are guaranteed with transverse air flow exceeding 400 linear feet per minute.

Typical thermal resistance values of the package at maximum temperature are:

$$
\begin{aligned}
& \theta_{\mathrm{JA}}\left(@ 400 \mathrm{fPM} \text { air flow) }=45^{\circ} \mathrm{C} / \mathrm{W}\right. \\
& \theta_{\mathrm{JA}}(\text { still air })=60^{\circ} \mathrm{C} / \mathrm{W} \\
& \theta_{\mathrm{JC}}=25^{\circ} \mathrm{C} / \mathrm{W}
\end{aligned}
$$

2. Typical limits are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$ and maximum loading.
3. Duration of short circuit current should not exceed 1 second.

## M2115AL, M2115A, M2125AL, M2125A

M2115AL, M2115A A.C. CHARACTERISTICS ${ }^{[1,2]} \quad \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
READ CYCLE

| Symbol | Test | M2115AL Limits |  |  | M2115A Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ | Max. |  |
| ${ }^{\text {t }}$ ACS | Chip Select Time | 5 |  | 45 | 5 |  | 45 | ns |
| $\mathrm{t}_{\text {RCS }}$ | Chip Select Recovery Time |  |  | 50 |  |  | 35 | ns |
| ${ }^{\text {t }}$ A ${ }^{\text {d }}$ | Address Access Time |  | 40 | 75 |  | 35 | 55 | ns |
| tOH | Previous Read Data Valid After Change of Address | 10 |  |  | 10 |  |  | ns |

## WRITE CYCLE

| Symbol | Test | Min. | Typ. | Max. | Min. | Typ. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {WS }}$ | Write Enable Time |  |  | 45 |  |  | 35 | ns |
| $t_{\text {WR }}$ | Write Recovery Time | 0 |  | 50 | 0 |  | 35 | ns |
| $t_{\text {W }}$ | Write Pulse Width | 55 | 10 |  | 40 | 10 |  | ns |
| $t_{\text {WSD }}$ | Data Setup Time Prior to Write | 5 | -5 |  | 5 | -5 |  | ns |
| $t_{\text {WHD }}$ | Data Hold Time After Write | 5 | 0 |  | 5 | 0 |  | ns |
| $t_{\text {WSA }}$ | Address Setup Time | 15 | 0 |  | 5 | 0 |  | ns |
| $t_{\text {WHA }}$ | Address Hold Time | 5 | 0 |  | 5 | 0 |  | ns |
| $t_{\text {WSCS }}$ | Chip Select Setup Time | 5 | 0 |  | 5 | 0 |  | ns |
| $t_{\text {WHCS }}$ | Chip Select Hold Time | 5 | 0 |  | 5 | 0 |  | ns |

## A.C. TEST CONDITIONS



READ CYCLE

PROPAGATION DELAY FROM CHIP SELECT


## WRITE CYCLE


(ALL ABOVE MEASUREMENTS REFERENCED TO 1.5 V )

M2125AL, M2125A A.C. CHARACTERISTICS ${ }^{[1,2]} \quad V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ READ Cycle

| Symbol | Test | M2125AL Limits |  |  | M2125A Limits |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $\mathrm{t}_{\text {Acs }}$ | Chip Select Time | 5 |  | 45 | 5 |  | 45 | ns |
| tzrcs | Chip Select to HIGH Z |  |  | 50 |  |  | 35 | ns |
| $\mathrm{t}_{\mathrm{AA}}$ | Address Access Time |  | 40 | 75 |  | 25 | 55 | ns |
| $\mathrm{toH}^{\text {l }}$ | Previous Read Data Valid After Change of Address | 10 |  |  | 10 |  |  | ns |

WRITE CYCLE

| Symbol | Test | Min. | Typ. | Max. | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tzws | Write Enable to HIGH Z |  |  | 45 |  |  | 35 | ns |
| ${ }^{\text {twR }}$ | Write Recovery Time | 0 |  | 50 | 0 |  | 35 | ns |
| tw | Write Pulse Width | 55 | 10 |  | 40 | 10 |  | ns |
| twSD | Data Setup Time Prior to Write | 5 | -5 |  | 5 | -5 |  | ns |
| ${ }^{\text {t Whi }}$ | Data Hold Time After Write | 5 | 0 |  | 5 | 0 |  | ns |
| twSA | Address Setup Time | 15 | 0 |  | 5 | 0 |  | ns |
| twha | Address Hold Time | 5 | 0 |  | 5 | 0 |  | ns |
| ${ }^{\text {twscs }}$ | Chip Select Setup Time | 5 | 0 |  | 5 | 0 |  | ns |
| $\mathrm{t}_{\text {WHCS }}$ | Chip Select Hold Time | 5 | 0 |  | 5 | 0 |  | ns |

## A.C. TEST CONDITIONS



READ CYCLE


PROPAGATION DELAY FROM CHIP SELECT


WRITE CYCLE


M2125AL, M2125A WRITE ENABLE TO HIGH Z DELAY


LOAD 1


## M2125AL, M2125A PROPAGATION DELAY FROM CHIP SELECT TO HIGH Z


(All t ZXXX parameters are measured at a delta of 0.5 V from the logic level and using Load 1.)

CAPACITANCE* $V_{C C}=5 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Test | M2115AL, M2115A <br> Limits |  | M2125AL, M2125A <br> Limits | Units | Test Conditions |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. | Typ. |  |  |  |
| $\mathrm{C}_{1}$ | Input Capacitance | 3 | 5 | 3 | 5 | pF | All Inputs = OV, Output Open |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance | 5 | 8 | 5 | 8 | pF | CS $=5 \mathrm{~V}$, All other inputs $=0 \mathrm{~V}$, <br> Output Open |

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

## TYPICAL CHARACTERISTICS



ICC vs. TEMPERATURE


ICC vs. Vcc

ACCESS TIME vs. TEMPERATURE

# M2147 4096 X 1 BIT STATIC RAM 

|  | M2147 |
| :--- | :---: |
| Max. Access Time (ns) | 85 |
| Max. Active Current (mA) | 180 |
| Max. Standby Current (mA) | 30 |

- HMOS Technology
- Completely Static Memory - No Clock or Timing Strobe Required
Equal Access and Cycle Times
■ Single +5 V Supply
■ $\pm \mathbf{1 0 \%}$ Power Supply Tolerance


## - Automatic Power-Down

■ High Density 18-Pin Package
■ Directly TTL Compatible - All Inputs and Outputs

- Separate Data Input and Output
- Three-State Output

Full Military Temperature Range

The Intel® M2147 is a 4096-bit static Random Access Memory organized as 4096 words by 1 -bit using HMOS, a highperformance MOS technology. It uses a uniquely innovative design approach which provides the ease-of-use features associated with non-clocked static memories and the reduced standby power dissipation associated with clocked static memories. To the military user this means low standby power dissipation without the need for clocks, address setup and hold times, nor reduced data rates due to cycle times that are longer than access times.
$\overline{\mathrm{CS}}$ controls the power-down feature. In less than a cycle time after $\overline{\mathrm{CS}}$ goes high - deselecting the M2147- the part automatically reduces its power requirements and remains in this low power standby mode as long as $\overline{\mathrm{CS}}$ remains high. This device feature results in system power savings as great as $85 \%$ in larger systems, where the majority of devices are deselected.

The M2147 is placed in an 18-pin package configured with the industry standard pinout. It is directly TTL compatible in all respects: inputs, outputs, and a single +5 V supply. The data is read out nondestructively and has the same polarity as the input data. A data input and a separate three-state output are used.

PIN CONFIGURATION


PIN NAMES

| $A_{0}-A_{11}$ | ADDRESS INPUTS | $V_{C C}$ POWER $(+5 \mathrm{~V})$ |
| :--- | :--- | :--- | :--- |
| $\overline{W E}$ | WRITE ENABLE | GND GROUND |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |  |
| $\mathrm{D}_{1 N}$ | DATA INPUT |  |
| DOUT | DATA OUTPUT |  |

TRUTH TABLE

| $\overline{\mathrm{CS}}$ | $\overline{\text { WE }}$ | MODE | OUTPUT | POWER |
| :---: | :---: | :---: | :---: | :---: |
| H | X | NOT SELECTED | HIGH Z | STANDBY |
| L | L | WRITE | HIGH Z | ACTIVE |
| L | H | READ | DOUT | ACTIVE |

LOGIC SYMBOL


ABSOLUTE MAXIMUM RATINGS*
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 . ........................ -1.5 V to +7 V
Power Dissipation .................................... 1.2 W
D.C. Output Current .............................. 20 mA
*COMMENT. Stresses above those listed under hapisolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operas tion of the device at these or any other conditions above those indicated in the operational sections of this specifi; cation is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS ${ }^{[1]}$

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise specified

| Symbol | Parameter | Min. | M2147 <br> Typ. | Max. | Unit | Test Conditionsp |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ILI | Input Load Current (All Input Pins) |  | 0.01 | 10 | $\mu \mathrm{A}$ | $V_{C C}=M A X ., V_{\text {IN }}=G N D$ to $V_{C C}$ |
| \|lool | Output Leakage Current |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{I H}, V_{C C}=M a x ., \\ & V_{O U T}=G N D \text { to } 4.5 \mathrm{~V} \end{aligned}$ |
| Icc | Operating Current |  | 120 | 160 | mA | $\mathrm{V}_{\mathrm{CC}}=\text { Max., } \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$ <br> Outputs Open |
|  |  |  |  | 180 | mA |  |
| ISB | Standby Current |  | 18 | 30 | mA | VCC $=$ Min. to Max., $\overline{\mathrm{CS}}=\mathrm{V}_{1 H}$ |
| IPO ${ }^{[3]}$ | Peak Power On Current |  | 35 | 70 | mA | $\mathrm{V}_{\mathrm{CC}}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{Cc}}$ Min., $\overline{\mathrm{CS}}=$ Lower of $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{IH}}$ Min. |
| VIL | Input Low Voltage | -1.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | 6.0 | V |  |
| VOL | Output Low Voltage |  |  | 0.45 | V | $\mathrm{IOL}=5 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-1.0 \mathrm{~mA}$ |
| $1 \mathrm{~s}{ }^{[4]}$ | Output Short Circuit Current | -150 |  | 150 | mA | VOUT $=$ GND to VCC |

Notes:

1. The operating ambient temperature range is guaranteed with transverse air flow exceeding 400 linear feet per minute.
2. Typical limits are at $\mathrm{V}_{C C}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, and specified loading.
3. ICC exceeds ISB maximum during power on, as shown in Graph 7. A pull-up resistor to VCC on the $\overline{C S}$ input is required to keep the device deselected; otherwise, power-on current approaches Icc active.
4. Duration not to exceed 30 seconds.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.5 Volts |
| :--- | ---: |
| Input Rise and Fall Times <br> Input and Output Timing Reference <br> Levels | 10 nsec |
| Output Load | 1.5 Volts |



Figure 1. Output Load

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}^{[5]}$

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

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

## A.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, V_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise specified

## READ CYCLE

| Symbol | Parameter | M2147 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $t_{\text {RC }}$ | Read Cycle Time | 85 |  | ns |  |
| $t_{A A}$ | Address Access Time |  | 85 | ns |  |
| $t_{\text {ACS }}$ | Chip Select Access Time |  | 85 | ns | Note 1 |
| $\mathrm{taCS}^{\text {a }}$ | Chip Select Access Time |  | 100 | ns | Note 2 |
| tor | Output Hold from Address Change | 5 |  | ns |  |
| tLz | Chip Selection to Output in Low Z | 10 |  | ns |  |
| $t_{H z}$ | Chip Deselection to Output in High $Z$ | 0 | 40 | ns |  |
| tpu | Chip Selection to Power Up Time | 0 |  | ns |  |
| tPD | Chip Deselection to Power Down Time |  | 30 | ns |  |

## WAVEFORMS

READ CYCLE NO. $1^{[3,4]}$


READ CYCLE NO. $2{ }^{[3,5]}$


Notes 1 Chip deselected for greater than 55 ns prior to selection.
2. Chip deselected for a finite time that is less than 55 ns prior to selection. (If the deselect time is Ons, the chip is by definition selected and access occurs accordıng to Read Cycle No. 1)
$3 \overline{W E}$ is high for Read Cycles.
4. Device is continuously selected, $\overline{C S}=V_{I L}$.
5. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.

## A.C. CHARACTERISTICS (Continued)

## WRITE CYCLE

| Symbol | Parameter | M2147 |  | Unit | Test Conditions | [ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |  |
| twc | Write Cycle Time | 85 |  | ns |  |  |
| tow | Chip Selection to End of Write | 70 |  | ns |  |  |
| $t_{\text {AW }}$ | Address Valid to End of Write | 70 |  | ns |  |  |
| $t_{\text {AS }}$ | Address Setup Time | 0 |  | ns |  |  |
| twp | Write Pulse Width | 55 |  | ns |  |  |
| twr | Write Recovery Time | 15 |  | ns |  |  |
| tow | Data Valid to End of Write | 35 |  | ns |  |  |
| to | Data Hold Time | 10 |  | ns |  |  |
| twz | Write Enabled to Output in High Z | 0 | 50 | ns |  |  |
| tow | Output Active from End of Write | 0 |  | ns |  |  |

## WAVEFORMS

WRITE CYCLE \#1 ( $\overline{W E}$ CONTROLLED)


WRITE CYCLE \#2 ( $\overline{C S}$ CONTROLLED)


Note: 1. If $\overline{C S}$ goes high simultaneously with $\overline{\mathrm{WE}}$ high, the output remains in a high impedance state.

## TYPICAL D.C. AND A.C. CHARACTERISTICS

GRAPH 1 SUPPLY CURRENT VS. SUPPLY VOLTAGE


GRAPH 4
NORMALIZED ACCESS TIME
VS. SUPPLY VOLTAGE


GRAPH 7
TYPICAL POWER-ON CURRENT VS. POWER SUPPLY VOLTAGE


GRAPH 2
SUPPLY CURRENT VS. AMBIENT TEMPERATURE


GRAPH 5
NORMALIZED ACCESS TIME VS. AMBIENT TEMPERATURE


GRAPH 8 ACCESS TIME CHANGE VS. INPUT VOLTAGE


OUTPUT SOURCE CURBE KMTYS



GRAPH 6
OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE


GRAPH 9
ACCESS TIME CHANGE VS. OUTPUT LOADING


## DEVICE DESCRIPTION

The M2147 is produced with HMOS, a new highperiormance MOS technology which incorporates onchip substrate bias generation combined with device scaling to achieve high-performance. The speed-power product of this process has been measured at 1 pj , approximately four times better than previous MOS processes.

This process, combined with new design ideas, gives the M2147 its unique features. High speed, low power and ease-of-use have been obtained in a single part. The lowpower feature is controlled with the Chip Select input, which is not a clock and does not have to be cycled. Multiple read or write operations are possible during a single select period. Access times are equal to cycle times, resulting in a data rate of 11.8 MHz . This is considerably higher performance than for clocked static designs.
Whenever the M2147 is deselected, it automatically reduces its power requirements to a fraction of the active power, as shown in Figure 1. This is achieved by switching off the power to unnecessary portions of the internal peripheral circuitry. This feature adds up to significant system power savings. The average power per device declines as system size grows because a continually higher portion of the memory is deselected. Device power dissipation asymptotically approaches the standby power level, as shown in Figure 2.


FIGURE 1. $\mathrm{i}_{\mathrm{CC}}$ WAVEFORM.


FIGURE 2. AVERAGE DEVICE DISSIPATION VS. MEMORY SIZE.

There is no functional constraint on the amount of time the M2147 is deselected. However, there is a relationship between deselect time and Chip Select access time. With no compensation, the automatic power switch would cause an increase in Chip Select access time, since some time is lost in repowering the device upon selection. A feature of the M2147 design is its ability to compensate for this loss. The amount of compensation is a function of deselect time, as shown in Figure 3. For short deselect times, Chip Select access time becomes slower than address access time, since full compensation typically requires 40 ns . For longer deselect times, Chip Select access time actually becomes faster than address access time because the compensation more than offsets the time lost in powering up. The spec accounts for this characteristic by specifying two Chip Select access times, $t_{A C S 1}$ and $t_{A C S 2}$.


FIGURE 3. $t_{\text {ACs }}$ VS. DESELECT TIME.
The power switching characteristic of the M2147 requires more careful decoupling than would be required of a constant power device. It is recommended that a $0.1 \mu \mathrm{~F}$ to $0.3 \mu \mathrm{~F}$ ceramic capacitor be used on every other device, with a $22 \mu \mathrm{~F}$ to $47 \mu \mathrm{~F}$ bulk electrolytic decoupler every 16 devices. The actual values to be used will depend on board layout, trace widths and duty cycle. Power supply gridding is recommended for PC board layout. A very satisfactory grid can be developed on a two-layer board with vertical traces on one side and horizontal traces on the other, as shown in Figure 4.


FIGURE 4. PC LAYOUT.
Terminations are recommended on input signal lines to the M2147 devices. In high speed systems, fast drivers can cause significant reflections when driving the high impedance inputs of the M2147. Terminations may be required to match the impedance of the line to the driver. The type of termination used depends on designer preference and may be parallel resistive or resistivecapacitive. The latter reduces terminator power dissipation.

M2708

## 8K (1K x 8) UV ERASABLE PROM

## - Extended Temperature Range: $-55^{\circ} \mathrm{C}$ to $100^{\circ} \mathrm{C}$

- Fast Programming: Typ. 100 sec . For All 8K Bits
- Low Power During Programming
- Access Time: 450 ns Max.
- Standard Power Supplies:
$+12 \mathrm{~V},+5 \mathrm{~V},-5 \mathrm{~V}$
- Static: No Clocks Required
- Inputs and Outputs TTL Compatible During Both Read and Program Modes
- Three-State Output: OR-Tie Capability
- Hermetic Package: 24 Pin DIP

The Intel M2708 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 M2708 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 devices.
The M2708 is fabricated with the time proven N -channel silicon gate technology.

PIN CONFIGURATION


PIN NAMES

| $A_{0} \cdot A_{9}$ | ADDRESS INPUTS |
| :--- | :--- |
| $O_{1} \cdot O_{8}$ | DATA OUTPUTS |
| CS/WE | CHIP SELECT/WRITE ENABLE INPUT |

BLOCK DIAGRAM


PIN CONNECTION DURING READ OR PROGRAM

|  | PIN NUMBER |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE | $\begin{gathered} \text { DATA I/O } \\ 9.11, \\ 13-17 \end{gathered}$ | ADDRESS INPUTS 1.8, 22, 23 | $\begin{gathered} \\ \mathrm{v}_{\mathrm{ss}} \\ 12 \end{gathered}$ | PROGRAM 18 | $\begin{gathered} \mathrm{V}_{\mathrm{DD}} \\ 19 \end{gathered}$ | $\begin{gathered} \overline{\mathrm{CS}} / \mathrm{WE} \\ 20 \end{gathered}$ | $\begin{gathered} V_{B B} \\ 21 \end{gathered}$ | $\mathrm{v}_{\mathrm{cc}}$ |
| READ | Dout | AIN | GND | GND | +12 | $\mathrm{V}_{\mathrm{IL}}$ | -5 | +5 |
| DESELECT | HIGH IMPEDANCE | DON'T CARE | GND | GND | +12 | $\mathrm{V}_{\mathrm{IH}}$ | -5 | +5 |
| PROGRAM | $\mathrm{DiN}_{\text {IN }}$ | $A_{\text {IN }}$ | GND | PULSED $\mathrm{V}_{\text {IHP }}$ | +12 | $\mathrm{V}_{\text {IHW }}$ | -5 | +5 |

## Absolute Maximum Ratings *

Temperature Under Bias
Storage Temperature $-65^{\circ} \mathrm{C}$ to $110^{\circ} \mathrm{C}$
. $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$


All Input or Output Voltages With Respect
to $V_{B B}$ During Read
+15 V to -0.3 V
$\overline{\mathrm{CS}} /$ WE Input With Respect to $V_{\mathrm{BB}}$
During Programming
+20 V to -0.3 V
Program Input With Respect to $V_{B B}$. . . . . . . . . . . . . . . +35 V to -0 3V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.8W
*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 thits 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}=-55^{\circ} \mathrm{C}$ to $100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}{ }^{[1]}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Min. | Typ. ${ }^{[2]}$ | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LI}}$ | Address and Chip Select Input Sink Current |  | 1 | 10 | $\mu \mathrm{~A}$ |

NOTES: 1. $V_{B B}$ must be applied prior to $V_{C C}$ and $V_{D D} . V_{B B}$ must also be the last power supply switched off.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. The total power dissipation of the $2704 / 2708$ is specified at 750 mW . It is not calculated by summing the various currents (IDD, ${ }^{\prime} \mathrm{CC}$, and $\mathrm{I}_{\mathrm{BB}}$ ) multiplied by their respective voltages since current paths exist between the various power supplies and $\mathrm{V}_{\mathrm{SS}}$. The $I_{D D}, I_{C C}$, and $I_{B B}$ currents should be used to determine power supply capacity only.

## Typical D.C. Characteristics

Idd CURRENT VS. TEMPERATURE


ICC CURRENT VS. TEMPERATURE


## A.C. Characteristics

$T_{A}=-55^{\circ} \mathrm{C}$ to $100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \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, |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to Output Delay |  | 280 | 450 | ns |
| ${ }^{\text {t }} \mathrm{CO}$ | Chip Select to Output Delay |  | 60 | 120 | ns |
| ${ }_{\text {t }}{ }_{\text {b }}$ | Chip De-Select to Output Float | 0 |  | 120 | ns |
| $\mathrm{t}_{\mathrm{OH}}$ | Address to Output Hold | 0 |  |  | ns |

Capacitance ${ }^{[1]} \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 1. This parameter is sampled and not $100 \%$ tested.

## A.C. TEST CONDITIONS:

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$ Input Rise and Fall Times: $\leqslant 20$ ns 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 iviz/U8 are sucn mat 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 $\begin{gathered}\text { range. }\end{gathered}$ Data show that constant exposure to room level fluorescent lighting could erase the typical M2708 in approximately 3 years, while it would take approximatley 1 week to cause erasure when exposed to direct sunlight. If the M2708 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 M2708 window to prevent unintentional erasure.
inc uuv.............. ........:
PROM/ROM Programming Instructions section) for the M2708 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 $1200 \mu \mathrm{~W} / \mathrm{cm}^{2}$ power rating. The M2708 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.

## I. ERASING PROCEDURE

The M2708 is erased by exposure to high intensity short wave ultraviolet light at a wavelength of $2537 \AA$. The recommended thtegrated dose (i.e., UV intensity $x$ exposure time) is $10 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$. An example of an ultraviolet source which can erase the M 2708 in 30 minutes is the Model S52 short wave ultraviolet lamp. The lamp should be used without short wave filters and the PROM , should be placed about one inch away from the lamp tubes.
Two manufacturers of the S52 are Ultra-Violet Products, Inc. (San Gabriel, Calif.) and Product Specialities, Inc. (Issaquah, , the Washington).

To prevent damage to the device, it is recommended that no more ultraviolet light exposure be used than that necessary to erase the M2708.

## II. PROGRAMMING INSTRUCTIONS

Initially, and after each erasure, all bits of the M2708 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 $\overline{\mathrm{CS}} / \mathrm{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 ( $\mathrm{O}_{1}-\mathrm{O}_{8}$ ). 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 (tpW) according to $N \times t_{\text {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\left(\mathrm{t}_{\mathrm{PW}}=1 \mathrm{~ms}\right)$ to greater than 1000 (tpW $=0.1 \mathrm{~ms}$ ). There must be N successive loops through 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 $\overline{\mathrm{CS}} / \mathrm{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 ( $I_{\text {IPL }}$ ) when $\overline{C S} / W E$ is at $V_{\text {IHW }}(12 \mathrm{~V})$ and the program pulse is at $V_{\text {ILP }}$.

Programming Examples (Using $\mathbf{N} \times \mathrm{t}_{\mathrm{PW}} \geqslant 100 \mathrm{~ms}$ )
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.

## 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_{L I}$ | Address and $\overline{\mathrm{CS}} / \mathrm{WE}$ Input Sink Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.25 \mathrm{~V}$ |
| IIPL | Program Pulse Source Current |  |  | 3 | mA |  |
| IIPH | Program Pulse Sink Current |  |  | 20 | mA |  |
| IDD | $V_{\text {DD }}$ Supply Current |  | 45 | 55 | mA | Worst Case Supply Currents: <br> All Inputs High $\overline{\mathrm{CS}} / \mathrm{WE}=5 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $I_{\text {cc }}$ | $V_{\text {CC }}$ Supply Current |  | 5 | 8 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}$ | $\mathrm{V}_{\text {BB }}$ Supply Current |  | 30 | 35 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Level (except Program) | $\mathrm{V}_{\text {SS }}$ |  | 0.65 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Level for all Addresses and Data | 3.0 |  | $\mathrm{V}_{C C}+1$ | V |  |
| $\mathrm{V}_{\text {IHW }}$ | $\overline{\text { CS/WE Input High Level }}$ | 11.4 |  | 12.6 | V | Referenced to $\mathrm{V}_{\mathrm{SS}}$ |
| $\mathrm{V}_{\text {IHP }}$ | Program Pulse High Level | 25 |  | 27 | V | Referenced to $\mathrm{V}_{\text {SS }}$ |
| VILP | Program Pulse Low Level | $\mathrm{V}_{\text {SS }}$ |  | 1 | V | $V_{\text {IHP }}-V_{\text {ILP }}=25 \mathrm{~V} \mathrm{~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}_{\text {AH }}$ | Address Hold Time | 1 |  |  | $\mu \mathrm{~s}$ |
| $\mathrm{t}_{\mathrm{CH}}$ | $\overline{\text { 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.

## Programming Waveforms



NOTE 1. THE CS/WE 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.

## Packaging Information

## 24 LEAD HERMETIC DUAL IN-LINE PACKAGE



# M2716 <br> $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ UV ERASABLE PROM 

## Extended Temperature Range $-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ Operation

Single +5V Power Supply

## - Single Programming Requirements <br> - Single Location Programming <br> - Programs with One 50 ms Pulse

\author{

- Static Standby Mode <br> - Low Power Dissipation of 165 mW max. standby power <br> - Fast Access Time; 450 ns max. <br> - Inputs and Outputs TTL Compatible during Read and Program
}

The Intel ${ }^{\circledR}$ M2716 is a 16,384 -bit ultraviolet erasable and electrically programmable read only memory (EPROM) specified over the $-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ temperature range. The M 2716 operates from a single +5 V 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.

The M2716 has a static standby mode which reduces the power dissipation without increasing access time. The active power dissipation is reduced by over $60 \%$ in the standby power mode.

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

PIN CONFIGURATION


PIN NAMES

| $A_{0}-A_{10}$ | ADDRESSES |
| :--- | :--- |
| $\overline{\mathrm{CE}} / \mathrm{PGM}$ | CHIP ENABLE/PROGRAM |
| $\overline{\mathrm{OE}}$ | OUTPUT ENABLE |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | OUTPUTS |

MODE SELECTION

|  | $\overline{\mathrm{CE}} / \mathrm{PGM}$ <br> (18) | $\begin{gathered} \overline{O E} \\ (20) \end{gathered}$ | $V_{\text {PP }}$ <br> (21) | $\begin{aligned} & V_{C C} \\ & (24) \end{aligned}$ | OUTPUTS <br> (9-11, 13-17) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | +5 | Dout |
| Standby | $V_{\text {IH }}$ | Don't Care | +5 | +5 | High $Z$ |
| Program | Pulsed $\mathrm{V}_{\text {IL }}$ to $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | DIN |
| Program Verify | $V_{\text {IL }}$ | $\mathrm{V}_{1} \mathrm{~L}$ | +25 | +5 | DOUT |
| - | ' | U... | +75 | +5 | Hiah $Z$ |

BLOCK DIAGRAM


## PROGRAMMING

The programming specifications are described in the Data Catalog PROM/ROM Programming Instructions Section

## Absolute Maximum Ratings*

| Temperature Under Bias | $-65^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| All Input or Output Voltages with Respect to Ground. $\qquad$ | $+6 \mathrm{~V} \text { to }-0.3 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{Pp}}$ Supply Voltage with Respect to Ground During Program | $+26.5 \mathrm{~V} \text { to }-0.3 \mathrm{~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}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}{ }^{[1,2]}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{P}}{ }^{[2]}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ [3] | Max. |  |  |
| $\mathrm{I}_{\mathrm{L}}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.50 \mathrm{~V}$ |
| Lo | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.50 \mathrm{~V}$ |
| $\mathrm{IPP}^{\text {[ }}{ }^{[2]}$ | $V_{\text {pp }}$ Current |  |  | 5 | mA | $\mathrm{V}_{\mathrm{PP}}=5.50 \mathrm{~V}$ |
| $\mathrm{ICCl}^{[2]}$ | $\mathrm{V}_{\mathrm{CC}}$ Current (Standby) |  | 10 | 30 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}, \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{ICCl}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Active) |  | 57 | 115 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V |  |
| $\mathrm{V}_{\text {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{IOH}=-400 \mu \mathrm{~A}$ |

NOTES: 1. $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{\text {PP }}$.
2. $\mathrm{V}_{\mathrm{PP}}$ may be connected directly to $\mathrm{V}_{\mathrm{CC}}$ except during programming. The supply current would then be the sum ofl CC and ${ }^{\mathrm{I} P P 1}$.
3. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. This parameter is only sampled and is not $100 \%$ tested.

## Typical Characteristics



A.C. Characteristics
$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}{ }^{[1,2]}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{PP}}{ }^{[2]}=\mathrm{V}_{\mathrm{CC}}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| ${ }^{\text {t }}$ ACC | Address to Output Delay |  |  | 450 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{t} \mathrm{CE}$ | $\overline{\mathrm{CE}}$ to Output Delay |  |  | 450 | ns | $\overline{O E}=V_{\text {IL }}$ |
| ${ }^{\text {t OE }}$ | Output Enable to Output Delay |  |  | 150 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{t}$ DF | Output Enable High to Output Float | 0 |  | 130 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\mathrm{t}} \mathrm{OH}$ | Output Hold From Addresses, $\overline{\text { CE }}$ or $\overline{O E}$ Whichever Occurred First | 0 |  |  | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |

Capacitance ${ }^{[4]} \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}$ |

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

## A.C. Waveforms ${ }^{[5]}$



NOTES: 1. $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{p p}$.
2. $V_{P P}$ may be connected directly to $V_{C C}$ except during programming. The supply current would then be the sum of $I_{C C}$ and $I_{P P 1}$.
3. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. This parameter is only sampled and is not $100 \%$ tested.
5. All times shown in parentheses are minimum and are nsec unless otherwise specified.
6. $\overline{\mathrm{OE}}$ may be delayed up to $\mathrm{t}_{\mathrm{ACC}}-$ to $_{\mathrm{OE}}$ after the falling edge of $\overline{\mathrm{CE}}$ without impact on tacc.
7. t $t_{D F}$ is specified from $\overline{O E}$ or $\overline{C E}$, whichever occurs first.

## TYPICAL 16K EPROM SYSTEM



- This scheme accomplished by using $\overline{\mathrm{CE}}$ as the primary decode. $\overline{\mathrm{OE}}$ is now controlled by previously unused signal. RD now controls data on and off the bus by way of $\overline{\mathrm{OE}}$.
- The use of a PROM as a decoder allows for:
a) Compatibility with upward (and downward) memory expansion.
b) Easy assignment of ROM memory modules, compatible with PUM modular software concepts.


## 8K, 16K, 32K, 64K 5V EPROM/ROM FAMILY PRINTED CIRCUIT BOARD LAYOUT



## ERASURE CHARACTERISTICS

The erasure characteristics of the M2716 are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms ( $\AA$ ). It should be noted that sunlight and certain types of fluorescent lamps have wavelengths in the $3000-4000 \AA$ range. Data show that constant exposure to room level fluorescent lighting could erase the typical device in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the M2716 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 M2716 window to prevent unintentional erasure.

The recommended erasure procedure (see Data Catalog PROM/ROM Programming Instruction Section) for the M2716 is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms ( $\AA$ ). The integrated dose (i.e., UV intensity $\times$ 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 device should be placed within 1 inch of the lamp tubes during erasure. Some lamps have a filter on their tubes which should be removed before erasure.

## DEVICE OPERATION

The five modes of operation of the M2716 are listed in Table 1. It should be noted that all inputs for the five 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 two modes.

## MODE SELECTION

| MODE PINS | $\overline{C E} / P G M$ <br> (18) | $\begin{gathered} \overrightarrow{O E} \\ (20) \end{gathered}$ | $V_{p p}$ <br> (21) | vcc <br> (24) | $\begin{aligned} & \text { OUTPUTS } \\ & (9.11,13-17) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | VIL | +5 | +5 | DOUT |
| Standby | $V_{\text {IH }}$ | Don't Care | +5 | +5 | High $Z$ |
| Program | Pulsed $V_{\text {IL }}$ to $V_{\text {IH }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | DIN |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +25 | +5 | Dout |
| Program Inhibit | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | +25 | +5 | High Z |

## READ MODE

The M2716 has two control functions, both of which must be logically satisfied in order to obtain dat at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{\mathrm{OE}}$ ) is the output control and should be used to gate data to the output pins, independent of device selection. Assuming that addresses are stable, address access time ( $t_{A C C}$ ) is equal to the delay from $\overline{\mathrm{CE}}$ to output ( $\mathrm{t}_{\mathrm{CE}}$ ). Data is available at the outputs $150 \mathrm{~ns}\left(\mathrm{t}_{\mathrm{OE}}\right)$ after the falling edge of $\overline{O E}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $t_{A C C}{ }^{-t_{O E}}$.

## STANDBY MODE

The M2716 has a standby mode which reduces the active power dissipation by $75 \%$, from 633 mW to 165 mW . The M2716 is placed in the standby mode by applying a TTL high special to the CE input. When in standby mode, the outputs are in a high impedance state, independent of the OE input.

## OUTPUT OR-TIEING

Because M2716's are usually used in larger memory arrays, Intel has provided a 2 line control function that accommodates this use of multiple memory connections. The two line control function allows for
a) the lowest possible memory power dissipation, and, b) complete assurance that output bus contention will not occur.

To most efficiently use these two control lines, it is recommended that $\overline{C E}$ (pin 18) be decoded and used as the primary device selecting function, while $\overline{O E}$ (pin 20 ) be made a common connection to all devices in the array and connected to the READ line from the system control bus. This assures that all deselected memory devices are in their low power standby mode and that the output pins are only active when data is desired from a particular memory device.

## PROGRAMMING

Initially, and after each erasure, all bits of the M27.16 are in the "1" state. Data is introduced by selectively "pro. gramming " 0 's" into the desired bit locations. Although only " 0 's" wil 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 M2716 is in the programming mode when the $V_{P P}$ power supply is at 25 V and $\overline{\mathrm{OE}}$ is at $\mathrm{V}_{1 \mathrm{H}}$. The data to be programmed is applied 8 bits in parallel to the data output pins. The levels required for the address and data inputs are TTL.

When the address and data are stable, a 50 msec , active high, TTL program pulse is applied to the $\overline{C E}$ input. A program pulse must be applied at each address location to be programmed. You can progam any location at any time - either individually, sequentially, or at random. The program pulse has a maximum wit)dth of 55 msec . The M2716 must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.

Programming of multiple M2716's in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled M2716's may be connected together when they are programmed with the same data. A high level TTL pulse applied to the $\overline{\mathrm{CE}}$ input programs the paralleled M2716's.

## PROGRAM INHIBIT

Programming of multiple M2716's in parallel with different data is also easily accomplished. Except for $\overline{\mathrm{CE}}$, all like units (including $\overline{\mathrm{OE}}$ ) of the parallel M2716's may be common. A TTL level program pulse applied to a M2716's $\overline{C E}$ input with $V_{P P}$ at 25 V will program that M2716. A low level $\overline{\mathrm{CE}}$ input inhibits the other M2716 from being programmed.

## PROGRAM VERIFY

A verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed with $V_{P p}$ at 25 V . Except during programming and program verify, $\mathrm{V}_{\mathrm{PP}}$ must be at ${ }^{〔} 5 \mathrm{~V}$.

## DEVICE RELIABILITY

The M2716 is built on a proven 2 layer polysilicon NMOS technology. Extensive testing and monitoring has allowed us to achieve failure rates equal to other memory devices. For detailed failure rate predictions and reliability data, request Intel 2716 Reliability Report.

\author{

- Military Temperature Range: <br> $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ <br> Fast Access Time - 90nsec Maximum <br> - Open Collector (M3604A) or Three-State (M3624A) Outputs
}

The M3604A and M3624A are military temperature range PROMs organized as 512 words by 8 bits. They are manufactured with all outputs high and logic output low levels can be electrically programmed in selected bit locations. The M3604A and M3624A, except for programming, have the same electrical specifications and are direct replacements to their predecessors, the M3604 and M3624.


## - Four Chip Select Inputs for Easy Memory Expansion

- Polycrystalline Silicon Fuse for
Higher Reliability
- Standard Packaging - 24 Pin Hermetic Dual In-Line Lead Configuration


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias
$-65^{\circ} \mathrm{C}$ to +135 C Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ Output or Supply Voltages -0.5 V to 7 Volts All Input Voltages -1.6 V to 5.6 V Output Currents . . . . . . . . . . . . . . . . . . . . . . . 100 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.
D.C. CHARACTERISTICS $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. | Unit |  |
| $I_{\text {fa }}$ | Address Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=$ Max, $\mathrm{V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {FS }}$ | Chip Select Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=$ Max, $\mathrm{V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RA }}$ | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\mathrm{A}}=$ Max |
| $I_{\text {RS }}$ | Chip Select Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max, $\mathrm{V}_{\mathrm{S}}=$ Max |
| $\mathrm{V}_{\text {CA }}$ | Address Input Clamp Voltage |  | -0.9 | -1.5 | V | $V_{C C}=\operatorname{Min}, I_{A}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{CS}}$ | Chip Select Input Clamp Voltage |  | -0.9 | -1.5 | V | $V_{C C}=\operatorname{Min}, I_{S}=-10 \mathrm{~mA}$ |
| VOL | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Min}, \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| ICEX | Output Leakage Current |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max, $\mathrm{V}_{\text {CE }}=$ Max |
| ${ }^{\text {ICC1 }}$ | Power Supply Current (M3604A) |  |  | 190 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC} 1}=\mathrm{Max}, \mathrm{~V}_{\mathrm{AO}} \rightarrow \mathrm{~V}_{\mathrm{AB}}=0 \mathrm{~V}, \\ & \mathrm{CS}_{1}=\mathrm{CS}_{2}=0 \mathrm{~V}, \mathrm{CS}_{3}=\mathrm{CS}_{4}=5.5 \mathrm{~V} \end{aligned}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.8 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{1 H}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$ |

M3624A ONLY

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $I_{\mathrm{O}} \mathrm{I}$ | Output Leakage for High <br> Impedance Stage |  |  | 100 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{O}}=\mathrm{Max}$ or 0.45 V, <br> $\mathrm{~V}_{\mathrm{CC}}=\mathrm{Max}, \overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=2.4 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{SC}}{ }^{[2]}$ | Output Short Circuit Current | -20 | -25 | -80 | mA | $\mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V}$ |

NOTES: 1. Typical values are at $25^{\circ} \mathrm{C}$ and at nominal voltage.
2. Unmeasured outputs are open during this test.

## A．C．CHARACTERISTICS $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | LIMITS |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP．${ }^{[1]}$ | MAX． |  |  |
| $\begin{aligned} & \mathrm{t}_{\mathrm{A}++}, \mathrm{t}_{\mathrm{A}--} \\ & \mathrm{t}_{\mathrm{A}+-}, \mathrm{t}_{\mathrm{A}-+} \end{aligned}$ | Address to Output Delay | 60 | 90 | ns | $\begin{aligned} & \overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=\mathrm{V}_{1 \mathrm{~L}} \text { and } \\ & \mathrm{CS}_{3}=\mathrm{CS}_{4}=\mathrm{V}_{1 \mathrm{H}} \text { to } \end{aligned}$ |
| ${ }_{\text {t }}+$＋ | Chip Select to Output Delay | 20 | 45 | ns | Select the PROM |
| ts－－ | Chip Select to Output Delay | 20 | 45 | ns |  |

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

| SYMBOL | PARAMETER | LIMITS |  | UNIT | TEST CONDITIONS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP． | MAX． |  |  |  |
| CINA | Address Input Capacitance | 4 | 10 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{1 N}=2.5 \mathrm{~V}$ |
| $C_{\text {INS }}$ | Chip－Select Input Capacitance | 6 | 10 | pF | $V_{C C}=5 \mathrm{~V}$ | $V_{1 N}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 7 | 15 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

NOTES：1．Typical values are at $25^{\circ} \mathrm{C}$ and nominal voltage．
2．This parameter is only periodically sampled and is not $100 \%$ tested．

## SWITCHING CHARACTERISTICS

## Conditions of Test：

Input puise amplitudes－ 2.5 V
Input pulse rise and fall times of
5 nanoseconds between 1 volt and 2 volts
Speed measurements are made at 1.5 volt levels
Output loading is 10 mA and 30 pF
Frequency of test -2.5 MHz

10 mA TEST LOAD


## WAVEFORMS

ADDRESS TO OUTPUT DELAY


## M3625A <br> 4K (1K x 4) PROM

- $\pm 10 \%$ Power Supply Tolerance
- Fast Access Time: 60 ns Maximum

Lower Power Dissipation: 0.14 mW/Bit Typically

## Simple Memory Expansion Two Chip Select Inputs

- Three-State Outputs
- Polycrystalline Silicon Fuse for Higher Reliability
Hermetic 18-Pin DIP

The Intel ${ }^{\circledR}$ M3625A is a high density, 4096 -bit bipolar PROM organized as 1024 words by 4 bits. The 1024 by 4 organization gives ideal word or bit modularity for memory array expansion. The M3625A is fully specified over the $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ temperature range with $\pm 10 \%$ power supply variation.
The M3625A is packaged in an 18 -pin dual-in-line hermetic package with 300 milli-inch centers. Thus, twice the bit density can be achieved in the same memory board areas as 512 by 8 -bit PROMs in 24 -pin packages.
The highly reliable polycrystalline silicon fuse technology is used in the manufacturing of the M3625A. All outputs are initially a logical high and logic low levels can be electrically programmed in selected bit locations.


## PROGRAMMING

The programming' specifications are described in the Data Catalog PROM/ROM Programming Instructions.

## Absolute Maximum Ratings*

| Temperature Under Bias | $-65^{\circ} \mathrm{C}$ to $+135^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature . | $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ |
| Output or Supply Voltages | -0.5 V to 7V |
| All Input Voltages | -1V 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 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 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$, unless otherwise specified.

| Symbol | Parameter | Limits |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. | Unit |  |
| $\mathrm{I}_{\text {FA }}$ | Address Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {FS }}$ | Chip Select Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $I_{\text {RA }}$ | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RS }}$ | Chip Select Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.5 \mathrm{~V}$ |
| 1 OL | Output Leakage for High Impedance Stage |  |  | 40 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V} \text { or } 0.45 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{CS}_{1}=\overline{\mathrm{CS}_{2}}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{\text {[2] }}$ | Output Short Circuit Current | -20 | -35 | -80 | mA | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{CA}}$ | Address Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{A}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {cs }}$ | Chip Select Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{\text {CC }}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{S}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $l_{\text {cc }}$ | Power Supply Current |  | 110 | 140 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{AO}} \rightarrow \mathrm{~V}_{\mathrm{A} 9}=0 \mathrm{~V}, \\ & \mathrm{CS}_{1}=\mathrm{CS}_{2}=\mathrm{V}_{\mathrm{IH}} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.
A.C. Characteristics: $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$.

| Symbol | Parameter | Max. <br> Limits | Unit | Conditions |
| :---: | :---: | :---: | :---: | :--- |
| $t_{A++}, t_{A--}$ <br> $t_{A+-}, t_{A-+}$ | Address to Output Delay | 60 | ns | $\overline{\mathrm{CS}_{1}}=\overline{\mathrm{CS}_{2}}=\mathrm{V}_{\mathrm{IL}}$ <br> to select the |
| $\mathrm{t}_{\mathrm{s}++}$ | Chip Select to Output Delay | 35 | ns | PROM. |
| $\mathrm{t}_{\mathrm{S}--}$ | Chip Select to Output Delay | 35 | ns |  |

Capacitance ${ }^{\prime} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$.

| Symbol | Parameter | Limits |  | Unit | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |  |  |  |
| $\mathrm{Cina}^{\text {IN }}$ | Address Input Capacitance | 3 | 8 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {INS }}$ | Chip Select Input Capacitance | 4 | 8 | pF | $\mathrm{V}_{\text {CC }}=5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{IN}}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUt }}$ | Output Capacitance | 5 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

NOTES:

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

## Switching Characteristics

## Conditions of Test:

Input pulse amplitudes - 2.5 V
Input pulse rise and fall times of 5 nanoseconds between 1 V and 2 V
Speed measurements are made at 1.5 V levels
Output loading - 10 mA and 30 pF
Frequency of test -2.5 MHz
10 mA TEST LOAD


## Waveforms

## ADDRESS TO OUTPUT DELAY



CHIP SELECT TO OUTPUT DELAY


## M3636

## $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ BIPOLAR PROM

- $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Operation
- Fast Access Time: 80 ns Maximum
- Low Power Dissipation: $0.05 \mathrm{~mW} / \mathrm{Bit}$ Typically
- Three Chips Select Input for Easy
Memory Expansion
- Pin Compatible to 8K PROMs
- Three-State Outputs
- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability

The Intel ${ }^{\circledR}$ M3636 is a fully decoded 16,384 bit PROM organized as 2048 words by 8 bits. The worst case access time of 80 ns is specified over the $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range and $5 \% \mathrm{~V}_{\mathrm{CC}}$ power supply tolerances. There are three chip selects provided to facilitate expansion into larger PROM arrays. The PROMs use the Schottky clamped TTL technology with polycrystalline silicon fuses. All outputs are initially high and logic low levels can be electrically programmed in selected bit locations.

Prior to the 16,384 bit M3636, the highest density bipolar PROM available was 8196 bits. The high density of the M3636 now easily doubles the capacity without an increase in area on existing designs currently using 1024 by 8-bit PROMs. There is also little, if any, penalty in power since the power/bit is approximately one-half that of 8 K PROMs. The M3636 is packaged in a hermetic 24 -pin dual in-line package.


## PROGRAMMING

The programming specifications are described in the PROMIROM Programming section of the Data Catalogue.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature. . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$
Output or Supply Voltages . . . . . . . . . . . -0.5 V to 7 Volts
All Input Voltages. . . . . . . . . . . . . . . . . . . . . . . - 1V to 5.5 V
Output Currents . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 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.

## D.C. CHARACTERISTICS

All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ unless otherwise specified

| Symbol | Parameter | Limits |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. | Unit |  |
| $\mathrm{I}_{\text {FA }}$ | Address Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {FS }}$ | Chip Select Input Load Current |  | -0.05 | -0.25 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\text {RA }}$ | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{RS}}$ | Chip Select Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.25 \mathrm{~V}$ |
| $1 \mathrm{O} \mid$ | Output Leakage for High Impedance State |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=5.25 \mathrm{~V} \text { or } 0.45 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{CS}_{1}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{[1]}$ | Output Short Circuit Current | -20 | -35 | -80 | mA | $\mathrm{V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {CA }}$ | Address Input Clamp Voltage |  | $-0.9$ | -1.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{A}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{CS}}$ | Chip Select Input Clamp Voltage |  | -0.9 | -1.5 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{S}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | 3.0 |  | V | $\mathrm{l}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 150 | 185 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

Notes:

1. Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.
A.C. CHARACTERISTICS $V_{C C}= \pm 5 \pm 5 \%, T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX. LIMITS | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\text {A }}$ | Address to Output Delay | 80 | ns | $\begin{gathered} \overline{\mathrm{CS}}_{1}=\mathrm{V}_{1 \mathrm{~L}} \\ \text { and } \mathrm{CS}_{2}=\mathrm{CS}_{3}=\mathrm{V}_{1 \mathrm{H}} \end{gathered}$to select the PROM. |
| $t_{\text {EN }}$ | Output Enable Time | 50 | ns |  |
| $\mathrm{t}_{\text {DIS }}$ | Output Disable Time | 50 | ns |  |

CAPACITANCE ${ }^{(1)} \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$

| SYMBOL | PARAMETER | TYP. LIMITS |  | UNIT | TEST CONDITIONS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. |  |  |  |
| $C_{\text {INA }}$ | Address Input Capacitance | 4 | 10 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| Cins | Chip-Select Input Capacitance | 6 | 10 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{1 \mathrm{~N}}=2.5 \mathrm{~V}$ |
| Cout | Output Capacitance | 7 | 12 | pF | $V_{C C}=5 \mathrm{~V}$ | $\mathrm{V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

NOTE 1: This parameter is only periodically sampled and is not $100 \%$ tested.

## SWITCHING CHARACTERISTICS

## Conditions of Test:

Input pulse amplitudes - 2.5 V Input pulse rise and fall times of

5 nanoseconds between 1 volt and 2 volts
Speed measurements are made at 1.5 volt levels
Output loading is 10 mA and 30 pF
Frequency of test -2.5 MHz


## WAVEFORMS

ADDRESS TO OUTPUT DELAY


CHIP SELECT TO OUTPUT DELAY


M5101-4, M5101L-4<br>256 x 4 BIT STATIC CMOS RAM<br>- Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$<br>- Ultra Low Standby Current: 200nA/Bit<br>- Fast Access Time - 800ns<br>- Single +5V Power Supply<br>- CE2 Controls Unconditional Standby Mode<br>- Three-State Output

The Intel ${ }^{\circledR} \mathrm{M} 5101$ 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.


## D.C. AND OPERATING CHARACTERISTICS FOR M5101-4, M5101L-4

$\mathrm{T}_{\mathrm{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{LI}}{ }^{[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{CE} 1}=2.2 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\text {LOL }}{ }^{[2]}$ | Output Low Leakage |  |  | 2 | $\mu \mathrm{A}$ | $\overline{\mathrm{CE1}}=2.2 \mathrm{~V}, \mathrm{~V}_{\text {OUT }}=0.0 \mathrm{~V}$ |
| ${ }^{\text {ccel }}$ | Operating Current |  | 11 | 25 | mA | $V_{I N}=V_{C C} \text { Except } \overline{C E 1} \leqslant 0.01 \mathrm{~V}$ Outputs Open |
| $\mathrm{ICC2}$ | Operating Current |  | 20 | 32 | mA | $\mathrm{V}_{\mathrm{IN}}=2.2 \mathrm{~V}$ Except $\overline{\mathrm{CE} 1} \leqslant 0.5 \mathrm{~V}$ Outputs Open |
| $I_{\text {CCL }}{ }^{[2]}$ | Standby Current |  | 2 | 200 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0 \text { to } V_{C C} \text {, Except } \\ & C E 2 \leqslant 0.2 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage | -0.3 |  | 0.5 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | $\mathrm{V}_{\mathrm{cc}}-2.0$ |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output "Low" Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output "High" Voltage | $\mathrm{V}_{\mathrm{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 CCL.

## M5101-4, M5101L-4

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}$ | " ${ }^{4}$ |
| I CCDR | 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 $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. ${ }^{t} 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}_{C C}=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{CO1}$ | Chip Enable ( $\overline{\mathrm{CE}} 1$ ) to Output |  |  | 700 | ns |  |
| ${ }^{\text {t }} \mathrm{CO} 2$ | Chip Enable (CE2) to Output |  |  | 850 | ns |  |
| tod | Output Disable To Output |  |  | 350 | ns |  |
| ${ }_{\text {t }}{ }^{\text {b }}$ | 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 {w }}$ | Write Cycle | 800 |  |  | ns | (See below) |
| $\mathrm{t}_{\text {AW }}$ | Write Delay | 150 |  |  | ns |  |
| ${ }^{\text {t }}$ W ${ }_{\text {W }}$ | Chip Enable ( $\overline{\mathrm{CE}} 1)$ To Write | 550 |  |  | ns |  |
| ${ }^{\text {t }}$ W 2 | Chip Enable (CE2) To Write | 550 |  |  | ns |  |
| $t_{\text {DW }}$ | Data Setup | 400 |  |  | ns |  |
| ${ }^{\text {t }}$ H | Data Hold | 100 |  |  | ns |  |
| twp | Write Pulse | 400 |  |  | ns |  |
| $t_{\text {WR }}$ | Write Recovery | su |  |  | 113 |  |
| ${ }^{\text {t }}$ D | Output Disable Setup | 150 |  |  | ns |  |



CAPACITANCE ${ }^{[3]} \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_{I N}=0 V$ | 4 | 8 |
| $C_{\text {OUT }}$ | Output Capacitance $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



## 8-BIT N-CHANNEL MIRCOPROCESSOR

The M8080A is functionally compatible with the Intel ${ }^{(8)} 8080$.

- Fully 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
- 6 General Purpose Registers and an Accumulator


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

16-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 68 -bit general purpose working registers and an accumulator. The 6 general purpose registers may be addressed individually or in pairs providing both single and double precision operators. Arithmetic and logical instructions set or reset 4 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 6 general purpose registers. The 16 -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 bidirectional 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 OR-tying these busses with other controlling device for (DMA) direct memory access or multiprocessor operation.


## 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 M8080A. 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 M8080A instruction set.

The following special instruction group completes the M8080A 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 M8080A is stored in the form of 8-bit binary integers. All data transfers to the system data bus will be in the same format.

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

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}{|lllllllll}
\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}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |$\quad$ OP CODERAND

Three Byte Instructions

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

## TYPICAL INSTRUCTIONS

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

Immediate mode or I/O instructions

Jump, call or direct load and store instructions

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

## 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 +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
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . 1.7W
*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}_{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.

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {ILC }}$ | Clock Input Low Voltage | $\mathrm{V}_{S S}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V | $\int \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}_{S S}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | 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{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 | Operation <br> $\mathrm{T}_{\mathrm{CY}}=.48 \mu \mathrm{sec}$ |
| $\mathrm{I}_{\text {CC ( }}(\mathrm{VV}$ ) | 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}} \\ & \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 {che }}$ | 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}$ |  |
| $I_{\text {FL }}$ | Address and Data Bus Leakage During HOLD |  |  | $\begin{array}{r} +10 \\ -100 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\text {ADDR/DATA }}=\mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\text {ADDR/DATA }}=\mathrm{V}_{\mathrm{SS}}+0.45 \mathrm{~V} \end{aligned}$ |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} \quad \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~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}_{\text {IN }}$ | Input Capacitance | 6 | 10 | pf | Unmeasured Pins <br> Returned to $V_{\text {SS }}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 10 | 20 | pf | Reter |

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


AMBIENT TEMPERATURE ( ${ }^{\circ} \mathrm{C}$ )
Figure 1. Typical Supply Current vs. Temperature, Normalized[3]

$V_{\text {IN }}$
Figure 2. Data Bus Characteristic During DBIN

## A.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{D D}=+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}_{\mathrm{SS}}=0 \mathrm{~V}$, Unless Otherwise Noted:

| Symbol | Parameter | Min. | Max. | Unit | Test Condition ${ }_{\text {des }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CY}}{ }^{\text {[3] }}$ | Clock Period | 0.48 | 2.0 | $\mu \mathrm{sec}$ | $\int-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 |  |
| ${ }^{\text {t }} 1$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  | nsec |  |
| ${ }^{\text {t }}$ 2 | Delay $\phi_{2}$ to $\phi_{1}$ | 80 |  | nsec |  |
| $t_{\text {D }}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 80 |  | nsec |  |
| $\mathrm{t}_{\mathrm{DA}}$ [2] | Address Output Delay From $\phi_{2}$ |  | 200 | nsec |  |
| $\mathrm{t}_{\mathrm{DD}}[2]$ | Data Output Delay From $\phi_{2}$ |  | 220 | nsec |  |
| ${ }^{\text {DC }}{ }^{[2]}$ | Signal Output Delay From $\phi_{1}$, or $\phi_{2}$ (SYNC, 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 |  | ${ }^{\text {t }}$ DF | nsec |  |
| ${ }^{\text {t }}$ S1 | Data Setup Time During $\phi_{1}$ and DBIN | 30 |  | nsec |  |

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


## 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}=0 \mathrm{~V}$, Unless Otherwise Noted. m . m

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{D S 2}$ | Data Setup Time to $\phi_{2}$ During DBIN | 130 |  | nsec |  |
| $\mathrm{t}_{\mathrm{DH}}[1]$ | Data Hold Time From $\phi_{2}$ During DBIN | $[1]$ |  | nsec |  |


| $t_{1 E}[2]$ | INTE Output Delay From $\phi_{2}$ |  | 200 | 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_{C Y}=t_{D 3}+t_{r \phi 2}+t_{\phi 2}+t_{f \phi 2}+t_{D 2}+t_{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}_{\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 $\mathrm{C}_{\mathrm{L}} \neq \mathrm{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{CSPEC}$.
5. ${ }^{t} A W=2 t^{t} Y^{-t} \mathrm{t}_{3}-\mathrm{t}_{\mathrm{r} \phi} 2-140 \mathrm{nsec}$.

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$.
8. $\mathrm{t}_{\mathrm{HF}}=\mathrm{t}_{\mathrm{D} 3}+\mathrm{t}_{\mathrm{r} \phi 2}-50 \mathrm{~ns}$.
9. ${ }^{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 T_{3}$. Both tDS1 and tDS2 must be satisfied.

1. Ready signal must be stable for this period during $T_{2}$ or $T_{W}$. (Must be externally synchronized.)
2. 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.)
4. This timing diagram shows timing relationships only; it does not represent any specific machine cycle.

## M8212 <br> 8-BIT INPUT/OUTPUT PORT

## Fully Parallel 8-Bit Data Register and Buffer

## Service Request Flip-Flop for Interrupt

 Generation■ Low Input Load Current 0.25mA Max

- 3-State Outputs
- Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- 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 Intel ${ }^{\circledR}$ M8212/M3212 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.
*Note: The specifications for the M3212 are identical with those for the M8212.

PIN CONFIGURATION


PIN NAMES

| $D_{1} \cdot D I_{8}$ | DATA IN |
| :--- | :--- |
| $D O_{1} \cdot D O_{8}$ | DATA OUT |
| $\bar{D} S_{1} \cdot D S_{2}$ | DEVICE SELECT |
| $M D$ | MODE |
| $S T B$ | STROBE |
| $\overline{N T}$ | INTERRUPT (ACTIVE LOW) |
| $\overline{\mathrm{CLT}}$ | CLEAR (ACTIVE LOW) |



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 or Supply Voltages .... -0.5 to +7 Volts
All Input Voltages . . . . . . . . . . . . 1.0 to 5.5 Volts
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.

## 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 <br> STB, DS $2, C R, \mathrm{DI}_{1}-\mathrm{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 STB, DS, CR, DI 1 -DI 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}$ | $V_{R}=V_{C C}$ |
| $\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}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | . 80 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output "Low" Voltage |  |  | . 45 | V | $\mathrm{lat}_{\mathrm{L}}=10 \mathrm{~mA}$ |
| VOH | Output "High" Voltage | 3.5 | 4.0 |  | V | $\mathrm{I}_{\mathrm{OH}}=-.5 \mathrm{~mA}$ |
| los | 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 ${ }^{\text {Na** }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tpw | Pulse Width | 40 |  | ns |  |
| ${ }_{\text {tPD }}$ | Data To Output Delay |  | 30 | ns | NOTE 1 |
| twe | Write Enable To Output Delay |  | 50 | ns | NOTE 1 |
| ${ }^{\text {t SET }}$ | Data Setup Time | 20 |  | ns |  |
| $\mathrm{t}_{\mathrm{H}}$ | Data Hold Time | 30 |  | ns |  |
| $t_{R}$ | Reset To Output Delay |  | 55 | ns | NOTE 1 |
| ts | Set To Output Delay |  | 35 | ns | NOTE 1 |
| ${ }_{\text {t }}$ | Output Enable/Disable Time |  | 50 | ns | NOTE $1 \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |
| ${ }^{\text {t }}$ C | Clear To Output Delay |  | 55 | ns | NOTE 1 |

CAPACITANCE $F=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Test | LIMITS |  |
| :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |
| $\mathrm{CiN}_{\text {I }}$ | $\overline{\mathrm{DS}}, \mathrm{MD}$ Input Capacitance | 9 pF | 15 pF |
| $\mathrm{CIN}^{\text {I }}$ | $\mathrm{DS}_{2}, \overline{\mathrm{CLR}}, \mathrm{STB}, \mathrm{DI}_{1}-\mathrm{DI}_{8}$ Input Capacitance | 5 pF | 10 pF |
| Cout | DO,-DO88 Output Capacitance | 8 pF | 15 pF |

## SWITCHING CHARACTERISTICS

## Conditions of Test

Test Load


NOTE 1:

| TEST | $\mathbf{C}_{\mathrm{L}}$ | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :--- | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{PD}}, \mathrm{t}_{\text {WE }}, \mathrm{t}_{\mathbf{R}}, \mathrm{t}_{\mathrm{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

st8

$\overline{\mathrm{DS}} \mathrm{S}_{1} \cdot \mathrm{DS}_{2}$

INT


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


M8214
PRIORITY INTERRUPT CONTROL UNIT

## 8 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}$

■ +10\% Power Supply Tolerance

The Intel ${ }^{\circledR}$ M8214 is an 8 -level priority interrupt control unit (PICU) designed to simplify interrupt-driven microcomputer systems.
The PICU can accept 8 requesting levels; determine the highest priority, compare this priority to a software controlled current status register and issue and 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 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 interruptdriven microcomputer systems.

PIN CONFIGURATION


PIN NAMES

| INPUTS |  |
| :---: | :---: |
| $\overline{\mathbf{R}_{0} \cdot \mathbf{R}_{7}}$ | Request levels (ry highest priority) |
| $\overline{\mathrm{B}_{0}-\mathrm{B}_{2}}$ | CURRENT STATUS |
| $\overline{\text { SGS }}$ | STATUS GROUP SELECT |
| ECS | ENABLE CURRENT STATUS |
| INTE | INTERRUPT ENABLE |
| $\overline{\text { CLX }}$ | CLOCK (INT F.F) |
| ELR | ENABLE LEVEL READ |
| ETLG | ENABLE THIS LEVEL GROUP |
| OUTPUTS |  |
| $\frac{\overline{A_{0} \cdot A_{2}}}{\frac{N T T}{}}$ | REQUEST LEVELS INTERRUPT (ACT LOW) OPEN COLLECTOR |
| ENLG | ENABLE NEXT LEVEL GROUP |

LOGIC DIAGRAM


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

## D.C. AND OPERATING CHARACTERISTICS

$\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}^{\prime}=-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}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $V_{R}=5.5 \mathrm{~V}$ |
| $V_{\text {IL }}$ | Input LOW Voltage: | all inputs |  |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input HIGH Voltage: | all inputs | 2.0 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  |  | 90 | 130 | mA | See Note 2. |
| $\mathrm{V}_{\mathrm{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}$ |
| Ios | Short Circuit Output Current: ENLG output |  | -15 | -35 | -55 | mA | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| ICEX | Output Leakage Current: $\overline{\mathrm{INT}}, \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 $\mathrm{T}_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=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.

| Symbol | Parameter | Limits |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min． | Typ．${ }^{\text {1］}}$ | Max． |  |
| ${ }_{\text {t }}^{\text {c }}$ Y | $\overline{\text { CLK }}$ Cycle Time | 85 |  |  | ns |
| $t_{\text {PW }}$ | $\overline{\text { CLK }}$ ，$\overline{\text { ECS }}, \overline{\text { INT }}$ Pulse Width | 25 | 15 |  | ns |
| $\mathrm{t}_{\text {ISS }}$ | INTE Setup Time to CLK | 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 CLK | 20 | 10 |  | ns |
| $\mathrm{t}_{\text {ECCS }}{ }^{[2]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{\text { CLK }}$ | 85 | 25 |  | ns |
| $\mathrm{tECCH}^{[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 |
| $\mathrm{t}_{\mathrm{ECRH}}{ }^{[3]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{C L K}$ | 0 |  |  |  |
| $\mathrm{tECSS}^{[2]}$ |  | 85 | 70 |  | ns |
| $\mathrm{t}_{\mathrm{ECSH}}{ }^{[2]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{\text { CLK }}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {DCS }}{ }^{[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{\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{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to $\overline{\text { CLK }}$ | 100 | 55 |  | ns |
| $\mathrm{t}_{\mathrm{RCH}}{ }^{[3]}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Hold Time After $\overline{\mathrm{CLK}}$ | 0 |  |  | ns |
| $\mathrm{t}_{1 \mathrm{CS}}$ |  | 55 | 35 |  | ns |
| ${ }^{\text {t }}$ Cl | $\overline{\text { CLK }}$ to INT Propagation Delay |  | 15 | 30 | ns |
| $\mathrm{t}_{\text {RIS }}{ }^{\text {［4］}}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to $\overline{\text { INT }}$ | 10 | 0 |  | ns |
| $\mathrm{t}_{\text {RIH }}{ }^{[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{A_{0}} \cdot \overline{A_{2}}$ Propagation Delay |  | 80 | 100 | ns |
| $t_{\text {ELA }}$ | $\overline{E L R}$ to $\overline{A_{0}} \cdot \overline{A_{2}}$ Propagation Delay |  | 40 | 55 | ns |
| $t_{\text {ECA }}$ | $\overline{\text { 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 |
| $t_{\text {REN }}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ to ENLG Propagation Delay |  | 45 | 70 | ns |
| $t_{\text {ETEN }}$ | ETLG to ENLG Propagation Delay |  | 20 | 30 | ns |
| $t_{\text {ECRN }}$ | $\overline{\text { ECS }}$ to ENLG Propagation Delay |  | 85 | 110 | ns |
| $\mathrm{t}_{\text {ECSN }}$ | ECS to ENLG Propagation Delay |  | ここ | ここ | $\because$ |

## CAPACITANCE

| Symbol | Parameter | Limits |  |  | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  | Input Capacitance | Min． | Typ．${ }^{[1]}$ | Max |  |
|  | Output Capacitance Except ENLG（Pin 14） |  | 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}$

# M8216/M8226 <br> 4-BIT PARALLEL BIDIRECTIONAL BUS DRIVER 

Data Bus Buffer Driver for $\mathbf{8 0 8 0}$ CPU<br>■ Low Input Load Current: 0.25mA Maximum<br>High Output Drive Capability for Driving System Data Bus<br>16-Pin Dual In-Line Package

3.40V Output High Voltage for Direct Interface to $\mathbf{8 0 8 0}$ CPU

3-State Outputs
Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
$\pm 10 \%$ Power Supply Tolerance

The M8216/M8226 is a 4-bit bidirectional bus driver/receiver. All inputs are low power TTL compatible. For driving MOS, the DO outputs provide a high 3.40 V VOH, and for high capacitance terminated bus structures, the DB outputs provide a high 50 mA lol capability. A non-inverting (M8216) and an inverting (M8226) are available to meet a wide variety of applications for buffering in microcomputer systems.

PIN CONFIGURATION


PIN NAMES

| $\mathrm{DB}_{0} \cdot \mathrm{DB}_{3}$ | DATA BUS <br> BI-DIRECTIONAL |
| :--- | :--- |
| $\mathrm{DI}_{0} \cdot \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
M8216


LOGIC DIAGRAM
M8226

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 ..... 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 operà 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. AND OPERATING 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 | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{IF}_{1}$ | Input Load Current $\overline{\text { DIEN, }} \overline{\text { CS }}$ |  | -0.15 | -. 5 | mA | $V_{F}=0.45$ |
| IF2 | Input Load Current All Other Inputs |  | -0.08 | -. 25 | mA | $V_{F}=0.45$ |
| $\mathrm{IR}_{1}$ | Input Leakage Current $\overline{\text { DIEN, }}$ CS |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| IR2 | Input Leakage Current DI Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| $V_{C}$ | Input Forward Voltage Clamp |  |  | -1.2 | V | IC $=-5 \mathrm{~mA}$ |
| VIL | Input "Low" Voltage M8216 |  |  | . 95 | V | $\mathrm{V}_{C C}=5 \mathrm{~V}$ |
| VIL | Input "Low" Voltage M8226 |  |  | . 90 | V | $\mathrm{VCC}=5 \mathrm{~V}$ |
| VIH | Input "High" Voltage | 2.0 |  |  | V | $V_{C C}=5 \mathrm{~V}$ |
| $\mid \mathrm{lo}$ \| | Output Leakage Current DO <br> (3-State) DB |  |  | $\begin{gathered} 20 \\ 100 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ |
| Icc | Power Supply Current M8216 |  | 95 | 130 | mA |  |
| Icc | Power Supply Current M8226 |  | 85 | 120 | mA |  |
| Vol1 | Output "Low" Voltage |  | 0.3 | . 45 | V | DO Outputs IOL $=15 \mathrm{~mA}$ <br> DB Outputs $\mathrm{IOL}=25 \mathrm{~mA}$ |
| Vol2 | Output "Low" Voltage |  | 0.5 | . 6 | V | DB Outputs $\mathrm{IOL}=45 \mathrm{~mA}$ |
| VOH | Output "High" Voltage | 3.4 | 3.8 |  | V | DO Outputs $\mathrm{IOH}=-.5 \mathrm{~mA}$ |
| VOH2 | Output "High" Voltage | 2.4 | 3.0 |  | V | $\begin{aligned} & \text { DO Outputs IOH }=-2 \mathrm{~mA} \\ & \text { DB Outputs IOH }=-5.0 \mathrm{~mA} \end{aligned}$ |
| Ios | Output Short Circuit Current | $\begin{aligned} & -15 \\ & -v u \end{aligned}$ | -35 -5 | $\begin{aligned} & -65 \\ & 100 \\ & \hline \end{aligned}$ | mA | DO Outputs $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ <br> no nutnite Van $=5 \mathrm{nV}$ |

NOTE: $T_{\text {ypical }}$ values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.

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 | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ.[1] | Max. |  |  |
| TPD1 | Input to Output Delay DO Outputs |  | 15 | 25 | ns | (NOTE 2) |
| TPD2 | Input to Output Delay DB Outputs M8216 |  | 19 | 33 | ns | (NOTE 2) |
| TPD2 | Input to Output Delay DB Outputs M8226 |  | 16 | 25 | ns | (NOTE 2) |
| TE | Output Enable Time M8216 |  | 42 | 75 | ns | (NOTE 2) |
| TE | Output Enable Time M8226 |  | 36 | 62 | ns | (NOTE 2) |
| TD | Output Disable Time M8216 |  | 16 | 40 | ns | (NOTE 2) |
| TD | Output Disable Time M8226 |  | 16 | 38 | 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. ${ }^{[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: $\quad 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.

| TEST | $\mathrm{C}_{\mathrm{L}}$ | $\mathrm{R}_{1}$ | $\mathrm{R}_{2}$ |
| :---: | :---: | :---: | :---: |
| TPD1 | 30 pF | 30082 | $600 \Omega$ |
| $\mathrm{T}_{\text {PD2 }}$ | 300pF | $90 \Omega$ | 180S2 |
| $T_{E,}$ ( $D O, E N A B L E \uparrow$ ) | 30pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| $\mathrm{T}_{\mathrm{E},}(\mathrm{DO}, \mathrm{ENABLE} \downarrow)$ | 30 pF | $300 \Omega$ | $600 \Omega 2$ |
| $T_{E},(D B, E N A B L E \uparrow)$ | 300 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| $T_{E, ~(~}^{\text {PB, }}$ ENABLE $\downarrow$ ) | 300pF | $90 \Omega$ | 18052 |
| T ${ }_{\text {D }}$ ( DO, DISABLE $\uparrow$ ) | 5pF | $300 \Omega$ | $600 \Omega$ |
| T ${ }_{\text {D }}$ ( $D$ O, DISABLE $\downarrow$ ) | 5pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| TD, (DB, DISABLE $\uparrow$ ) | 5pF | $90 \Omega$ | $180 \Omega$ |
| TD, (DB, DISABLE ${ }^{\text {l }}$ ) | 5pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

# M8224 <br> CLOCK GENERATOR AND DRIVER FOR 8080A CPU 

\author{

- Single Chip Clock Generator/Driver for M8080A CPU <br> Power-Up Reset for CPU <br> - Ready Synchronizing Flip-Flop <br> - Advanced Status Strobe <br> - Fully Military Temperature Range <br> $-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 Intel ${ }^{\circledR}$ 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 trobe, and synchronization of ready.
The M8224 provides the designer with a significant reduction of packages used to generate clocks and timing for M8080A.



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> $O_{2}$ |


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

## 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}_{\text {CC }}$ | -0.5 V to +7V |
| Supply Voltage, VDD | -0.5 V to +13.5 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

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $I_{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 Clamp Voltage |  |  | -1.2 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | . 8 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage $\overline{\text { RESIN }}$ All Other Inputs | $\begin{aligned} & 2.6 \\ & 2.0 \end{aligned}$ |  |  | V |  |
| $\mathrm{V}_{\mathrm{IH}}-\mathrm{V}_{\mathrm{IL}}$ | $\overline{\text { RESIN }}$ Input Hysteresis | . 25 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | $\begin{array}{r} \text { Output "Low" Voltage OSC, } \\ \phi 2 \text { (TTL) } \\ \text { All Other Outputs } \end{array}$ |  |  | $.45$ $.45$ | V <br> V | $\begin{aligned} \mathrm{IOL} & =10 \mathrm{~mA} \\ \mathrm{IOL}^{2} & =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} & 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}$ |
| bos ${ }^{[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}$ |
| ICC | 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 $-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

$V_{C C}=+5.0 \pm 10 \% ; V_{D D}=+12.0 \mathrm{~V} \pm 10 \% ; T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  | Units | Test <br> Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{t}_{\phi 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 |  |  |  |  |
| $t_{\text {D2 }}$ | $\phi_{2}$ to $\phi_{1}$ Delay | $\frac{2 \mathrm{tcy}}{9}-25 \mathrm{~ns}$ |  |  |  |  |
| $t_{\text {D }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | $\frac{2 \mathrm{tcy}}{9}$ |  | $\frac{2 t c y}{9}+40 n s$ |  |  |
| $\mathrm{t}_{\mathrm{R}}$ | $\phi_{1}$ and $\phi_{2}$ R ise Time |  |  | 25 |  |  |
| $\mathrm{t}_{\mathrm{F}}$ | $\phi_{1}$ and $\phi_{2}$ Fall Time |  |  | 25 |  |  |
| ${ }^{\text {t }}$ ¢ 2 | $\phi_{2}$ to $\phi_{2}$ (TTL) Delay | -5 |  | +15 | ns | $\begin{aligned} & \phi_{2} \mathrm{TTL}, \mathrm{CL}=30 \mathrm{pF} \\ & \mathrm{R}_{1}=300 \Omega \\ & \mathrm{R}_{2}=600 \Omega \\ & \hline \end{aligned}$ |
| $t_{\text {DSS }}$ | $\phi_{2}$ to STSTB Delay | $\frac{6 t c y}{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 \mathrm{~ns}$ |  |  |  |  |
| ${ }^{\text {t DRS }}$ | RDYIN Setup Time to Status Strobe | $50 \mathrm{~ns}-\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| ${ }^{\text {t }}$ DRH | RDYIN Hold Time After STSTB | $\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| ${ }^{\text {t }}$ R | READY or RESET to $\phi_{2}$ Delay | $\frac{4 \text { tcy }}{9}-25 n s$ |  |  |  | $\begin{aligned} & \mathrm{CL}=10 \mathrm{pF} \\ & \mathrm{R}_{1}=2 \mathrm{~K} \\ & \mathrm{R}_{2}=4 \mathrm{~K} \end{aligned}$ |
| ${ }_{\text {t }}^{\text {cle }}$ | CLK Period |  | $\frac{\text { tcy }}{9}$ |  |  |  |
| $\mathrm{f}_{\text {max }}$ | Maximum Oscillating Frequency | 27 |  |  | MHz |  |
| $\mathrm{C}_{\text {in }}$ | Input Capacitance |  |  | 8 | pF | $\begin{aligned} & V_{C C}=+5.0 \mathrm{~V} \\ & \mathrm{~V}=\mathrm{=}=+10 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{BIAS}}=2.5 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |


 All other signals measured at 1.5 V .

## Example:

## A.C. CHARACTERISTICS ( $\mathrm{For}_{\mathrm{t}}^{\mathrm{CY}}=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 |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |

M8228

## SYSTEM CONTROLLER AND BUS DRIVER FOR M8080A CPU

- Single Chip System Control for
MCS-80

\author{

- Built-In Bidirectional 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
■ Full Military Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

- $\pm 10 \%$ Power Supply Tolerance

The Inte ${ }^{\circledR}$ 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 bidirectional 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.
$\qquad$

PIN CONFIGURATION


BLOCK DIAGRAM


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 ENABLE INPUT |
| MEMR | MEMORY READ | $\overline{\text { STSTB }}$ | STATUS STROBE (FROM 8224) |
| MEMW | MEMORY WRITE | $\mathrm{V}_{\text {cc }}$ | +5V |
| DBIN | DBIN (FROM 8080) | GND | 0 VOLTS |

## 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, VCC . . . . . . . . . . |
| -0.5 V to +7 V |
| Input Voltage . . . . . . . . . . . . . . . |
| O -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 speciffication 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, 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}$ |  |
| $\mathrm{I}_{\mathrm{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}$ |
| ICC | Power Supply Current |  | 210 | mA |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage, $D_{0}-D_{7}$ |  | . 5 | V | $\mathrm{I}_{\mathrm{OL}}=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}=-10 \mu \mathrm{~A}$ |
|  | All Other Outputs | 2.4 |  | V | $\mathrm{IOH}=-1 \mathrm{~mA}$ |
| Ios | Short Circuit Current, All Outputs | 15 | 90 | mA | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| Io (Off) | Off State Output Current, <br> 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 | INTA Current |  | 5 | mA | (See Figure 1) |

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.

|  |  | Limits |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Symbol | Parameter | 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: $\mathrm{V}_{\mathrm{BI}} \mathrm{AS}=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}$.



Figure 1. INTA Test Circuit (for RST 7)
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 \%$.

| Symbol | Parameter | Limits |  | Units | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tpW | Width of Status Strobe | 25 |  | ns |  |
| ${ }_{\text {t }}$ S | Setup Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 8 |  | ns |  |
| ${ }_{\text {t }}^{\text {S }}$ H | Hold Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 5 |  | ns |  |
| ${ }_{\text {t }}^{\text {D }}$ | Delay from $\overline{\text { STSTB }}$ to any Control Signal | 20 | 75 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\text {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}$ |
| $\mathrm{t}_{\mathrm{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 }}$ D | 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 | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $t_{H D}$ | HLDA to Read Status Outputs |  | < 0 | $\cdots$ | $\bar{v}_{L}$ - iovr. ${ }^{\text {- }}$ |
| $t_{\text {DS }}$ | Setup Time, System Bus Inputs to HLDA | 10 |  | ns |  |
| ${ }_{\text {t }}$ H | Hold Time, System Bus Inputs to HLDA | 20 |  | ns |  |



Figure 2. M8080A CPU Interface


Figure 3. Status Word Chart


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 .

# PROGRAMMABLE COMMUNICATION INTERFACE 

## - Synchronous and Asynchronous Operation

\author{

- Synchronous: <br> 5-8 Bit Characters Internal or External Character Synchronization <br> Automatic Sync Insertion <br> - Asynchronous: <br> 5-8 Bit Characters <br> Clock Rate - 1,16 or 64 Times Baud Rate <br> Break Character Generation <br> 1, $11 / 2$, or 2 Stop Bits <br> False Start Bit Detection
}

\author{

- Baud Rate - DC to 56k Baud (Sync Mode) DC to 8.1k Baud (Async Mode) <br> - Full Duplex, Double Buffered, Transmitter and Receiver <br> - Error Detection - Parity, Overrun, and Framing <br> - Fully Compatible with 8080 CPU <br> - All Inputs and Outputs Are TTL Compatible <br> - Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ <br> - $\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, T×EMPT. The chip is constructed using $N$-channel silicon gate technology.

PIN CONFIGURATION


M8251 BLOCK DIAGRAM



| Pin Name | Pin Function |
| :--- | :--- |
| $D_{7} D_{0}$ | Data Bus (8 bits) |
| $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 Enabie |
| $C L K$ | Clock Pulse (TTL) |
| $R E S E T$ | Reset |
| $\overline{T \times C}$ | Transmitter Clock |
| $T \times D$ | Transmitter Data |
| $\overline{R \times C}$ | Receiver Clock |
| $R \times D$ | Receiver Data |
| $R \times R D Y$ | Receiver Ready (has character for 8080) |
| $T \times R D Y$ | Transmitter Ready (ready for char from 8080) |


| Pin Name | Pin Function |
| :--- | :--- |
| $\overline{\mathrm{DSR}}$ | Data Set Ready |
| $\overline{\mathrm{DTR}}$ | Data Terminal Ready |
| SYNDET | Sync Detect |
| $\overline{\mathrm{RTS}}$ | Request to Send Data |
| $\overline{\mathrm{CTS}}$ | Clear to Send Data |
| TXE | Transmitter Empty |
| VCC | +5 Volt Supply |
| GND | Ground |

## 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 maximurn 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 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {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

$\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}_{1 N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / 0}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to GND. |

## TEST LOAD CIRCUIT:



Figure 1.

$\triangle$ CAPACITANCE (pF)

## A.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \% ; \quad G N D=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{t} \mathrm{CY}$ | 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 |  |
| ${ }^{\text {twR }}$ | WRITE Pulse Width | 400 |  |  | ns |  |
| $t_{\text {DS }}$ | Data Set-Up Time for WRITE | 200 |  |  | ns |  |
| ${ }^{t_{\text {DH }}}$ | Data Hold Time for WRITE | 40 |  |  | ns |  |
| ${ }^{\text {taw }}$ | Address Stable before $\overline{\text { WRITE }}$ | 20 |  |  | ns | ' |
| twA | Address Hold Time for WRITE | 20 |  |  | ns |  |
| $t_{\text {RD }}$ | READ Pulse Width | 430 |  |  | ns |  |
| $t_{\text {DD }}$ | Data Delay from READ |  |  | 350 | ns |  |
| ${ }^{\text {t }}$ DF | $\overline{\text { READ }}$ to Data Floating [3] | 25 |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=15 \mathrm{pF}$ to 100 p |
| ${ }^{t_{A R}}$ | Address (CE, C/ $\overline{\mathrm{D}}$ ) Stable before $\overline{\mathrm{READ}}$ | 50 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{RA}}$ | Address (CE, C/D) Hold Time for $\overline{\text { READ }}$ | 5 |  |  | ns |  |
| ${ }^{\text {t }}$ DTx | TxD Delay from Falling Edge of TxC |  |  | 1 | $\mu \mathrm{s}$ |  |
| ${ }_{\text {t }}^{\text {SR } \times}$ | Rx Data Set-Up Time to Sampling Pulse | 2 |  |  | $\mu \mathrm{s}$ |  |
| $t_{\text {HRx }}$ | R× Data Hold Time to Sampling Pulse | 2 |  |  | $\mu \mathrm{s}$ |  |
| ${ }_{\mathrm{f}}^{\mathrm{T} \times}$ [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} \times 1]}$ | Receiver 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}$ |  |
| ${ }^{t}{ }_{\text {T }}$ | T×RDY Delay from Center of Data Bit |  |  | 16 | CLK Perıod |  |
| $\mathrm{t}_{\mathrm{Rx}}$ | RxRDY Delay from Center of Data Bit | 15 |  | 20 | CLK Period |  |
| $t_{\text {IS }}$ | Internal Syndet Delay from Center of Data Bit | 20 |  | 25 | CLK Period |  |
| $\mathrm{t}_{\mathrm{ES}}$ | External Syndet Set-Up Time before Falling Edge of RxC |  |  | 16 | CLK Periorl |  |

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{x}}$ or $\mathrm{t}_{\mathrm{R}_{\mathrm{x}}}=4.5 \mathrm{t}_{\mathrm{C}} \mathrm{Y}$
For SYNC Mode, $\mathrm{t}_{\mathrm{T}}$ or $\mathrm{t}_{\mathrm{R}_{\mathrm{x}} \geqslant 30{ }^{\mathrm{t}} \mathrm{CY},}$
2. AC timings are measured at $\mathrm{VOH}=2.0 \mathrm{~V}, \mathrm{VOL}_{\mathrm{OL}}=0.8 \mathrm{~V}$, and load circuit of $\mathrm{F}_{\text {igure }} 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.


## M8255A PROGRAMMABLE PERIPHERAL INTERFACE

## 24 Programmable I/O PIns

## - Completely TTL Compatible

- Fully Compatible with MCS-80 ${ }^{\text {TM }}$
Microprocessor Family

\author{

- Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
}
- Direct Bit Set/Reset Capability Easing Control Application Interface
- 40-Pin Dual In-Line Package
- Reduces System Package Count
- $\pm \mathbf{1 0 \%}$ Power Supply Tolerance

The Intel ${ }^{\circledR}$ 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 2 groups of 12 and used in 3 major modes of operation. In the first mode (MODE 0), each group of 12 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 4 pins, 3 are used for handshaking and interrupt control signals. The third mode of operation (MODE 2 ) is a bidirectional bus mode which uses 8 lines for a bidirectional bus, and 5 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{\text { AD }}$ | READ INPUT |
| $\overline{W R}$ | WRITE INPUT |
| A0, A1 | PORT ADDRESS |
| PA7-PAO | PORT A (BIT) |
| PB7-PB0 | PORT B (BIT) |
| PC7-PC0 | PORT C (BIT) |
| $V_{\text {cc }}$ | +5 VOLTS |
| GND | 9 VOLTS |

M8255A 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 histed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functionat operation of the device at these or any other conditions above those indicated in the operational sections of this speciffy cation 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 \mathrm{~V} \pm 10 \% ; \mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{I L}$ | 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}}$ (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}}$ (DB) | Output High Voltage (Data Bus) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ (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{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.

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 | 8255A |  | UNIT |
| :---: | :---: | :---: | :---: | :---: |
|  |  | MIN. | MAX. |  |
| $\mathrm{t}_{\text {AR }}$ | Address Stable Before READ | 0 |  | ns |
| $t_{\text {RA }}$ | Address Stable After READ | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | READ Pulse Width | 300 |  | ns |
| $t_{\text {RD }}$ | Data Valid From READ ${ }^{1]}$ |  | 250 | ns |
| $\mathrm{t}_{\mathrm{DF}}$ | Data Float After READ | 10 | 150 | ns |
| $\mathrm{t}_{\mathrm{R} V}$ | Time Between READs and/or WRITEs | 850 |  | ns |
| $\mathrm{t}_{\text {AW }}$ | Address Stable Before WRITE | 0 |  | ns |
| twa | Address Stable After WRITE | 20 |  | ns |
| ${ }^{\text {tw }}$ w | WRITE Pulse Width | 400 |  | ns |
| $t_{\text {DW }}$ | Data Valid to WRITE (T.E.) | 100 |  | ns |
| ${ }^{\text {tw }}$ | Data Valid After WRITE | 30 |  | ns |
| ${ }^{\text {t }}$ WB | WR = 1 to Output ${ }^{\|1\|}$ |  | 350 | ns |
| $\mathrm{t}_{\mathrm{IR}}$ | Peripheral Data Before RD | 0 |  | ns |
| $\mathrm{t}_{\mathrm{HR}}$ | Peripheral Data After RD | 0 |  | ns |
| ${ }^{\text {A AK }}$ | ACK Pulse Width | 300 |  | ns |
| ${ }_{\text {t }}^{\text {S }}$ | STB Pulse Width | 500 |  | ns |
| $t_{\text {PS }}$ | Per. Data Before T.E. of STB | 0 |  | ns |


| $\mathrm{t}_{\text {PH }}$ | Per. Data After T.E. of STB | 180 |  | ns |
| :---: | :--- | :--- | :--- | :--- |
| $\mathrm{t}_{\text {AD }}$ | ACK $=0$ to Output ${ }^{11 \mid}$ |  | 300 | ns |
| $\mathrm{t}_{\text {KD }}$ | ACK $=1$ to Output Float | 20 | 250 | ns |
| $\mathrm{t}_{\text {WOB }}$ | WR $=1$ to OBF $=0^{\|1\|}$ |  | 650 | ns |
| $\mathrm{t}_{\text {AOB }}$ | ACK $=0$ to OBF $=1^{\|1\|}$ |  | 350 | ns |
| $\mathrm{t}_{\text {SIB }}$ | STB $=0$ to IBF $=1^{\|1\|}$ |  | 300 | ns |
| $\mathrm{t}_{\text {RIB }}$ | RD $=1$ to IBF $=0^{\|1\|}$ |  | 300 | ns |
| $\mathrm{t}_{\text {RIT }}$ | RD $=0$ to INTR $=0^{\|1\|}$ |  | 400 | ns |
| $\mathrm{t}_{\text {SIT }}$ | STB $=1$ to INTR $=1^{\|1\|}$ |  | 300 | ns |
| $\mathrm{t}_{\text {AIT }}$ | ACK $=1$ to INTR $=1^{\|1\|}$ |  | 350 | ns |
| $\mathrm{t}_{\text {WIT }}$ | WR $=0$ to INTR $=0^{\|1\|}$ |  | 850 | ns |

Notes:

1. Test condition: $8255 \mathrm{~A}: \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
2. Period of Reset pulse must be at least $50 \mu \mathrm{~F}$ during or after power on. Subsequent Reset pulse can be 500 ns min.

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}_{I / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to GND |

Figure 31. Test Load Circuit


Figure 32. MODE 2 (Bidirectional)

# M8085A <br> 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, LC or RC Network)
- On-Chip System Controller; Advanced Cycle Status Information Available for Large System Control
- Four Vectored Interrupt Inputs (One is non-Maskable) Plus an 8080Acompatible interrupt

Serial In/Serial Out Port

- Decimal, Binary and Double Precision Arithmetic

Direct Addressing Capability to 64k
Bytes of Memory

The Intel® M8085A is a 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 8080A's performance by higher system speed.
The M8085A incorporates all of the features that the 8224 (clock generator) and 8228 (system controller) provided for the 8080A, thereby offering a high level of system integration.

The M8085A uses a multiplexed data bus. The address is split between the 8-bit address bus and the 8-bit data bus.


Figure 1. M8085A CPU Functional Block Diagram.


Figure 2. M8085A Pinout Diagram

## M8085A FUNCTIONAL PIN DESCRIPTION

The following describes the function of each pin:

| Symbol | Function |
| :---: | :---: |
| $\mathbf{A}_{8}-\mathbf{A}_{15}$ <br> (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 and during RESET. |
| AD ${ }_{0-7}$ <br> (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 (T state) of a machine cycle. It then becomes the data bus during the second and third clock cycles. |
| ALE (Output) | Address Latch Enable: It occurs during the first clock state of a machine cycle 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. The falling edge of ALt can also de usea to strobe the status information. ALE is never 3-stated. |
| $\mathbf{S}_{0}, \mathbf{S}_{1} \text {, and } 10 / \bar{M}$ |  |
| (Output) | $\underline{10 / \bar{M}} \quad \underline{\mathbf{S}_{1}} \quad \underline{\mathbf{S}_{0}}$ Status |
|  | $0 \quad 0 \quad 1$ Memory write |
|  | 010 Memory read |
|  | $1011 / O$ write |
|  | 110 l/O read |
|  | 011 Opcode fetch |
|  | 111 Interrupt Acknowledge |
|  | * 00 Halt |
|  | * X X Hold |
|  | * X X Reset |
|  | * $=3$-state (high impedance) |
|  | X $=$ unspecified |

$\mathrm{A}_{8}-\mathrm{A}_{15}$
(Output, 3-state)

AD ${ }_{0-7}$ (Input/Output, 3-state)

ALE
(Output)
$\mathbf{S}_{0}, \mathbf{S}_{1}$, and $10 / \bar{M}$
(Output)

Machine cycle status:

## INTR

## M8085A FUNCTIONAL PIN DESCRIPTION (Continued)


(Output)

RST 5.5
RST 6.5
RST 7.5
(Inputs)

TRAP (Input)

RESET IN (Input)

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

RESTART INTERRUPTS: These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted.
The priority of these interrupts is ordered as shown in Table 1. These interrupts have a higher priority than INTR. In addition, they may be individually masked out using the SIM instruction.
Trap interrupt is a nonmaskable RESTART interrupt. It is recognized at the same time as INTR or RST 5.5-7.5 It is unaffected by any mask or Interrupt Enable. It has the highest priority of any interrupt. (See Table 1.)
Sets the Program Counter to zero and resets the Interrupt Enable and HLDA flip-flops. The data and address buses and the control lines are 3 -stated during RESET and because of the asynchronous nature of RESET, the processor's internal registers and flags may be altered by RESET with unpredictable results. RESET IN is a

| Symbol | Function <br> Schmitt-triggered input, allowing <br> connection to an R-C network for <br> power-on RESET delay. The cpu is <br> held in the reset condition as long as |
| :--- | :--- |
| RESET IN is applied. |  |

TABLE 1. INTERRUPT PRIORITY, RESTART ADDRESS, AND SENSITIVITY

| Name | Priority | Address Branched To (1) <br> When Interrupt Occurs | Type Trigger |
| :---: | :---: | :---: | :--- |
| TRAP | 1 | 24 H | Rising edge AND high level until sampled. |
| RST 7.5 | 2 | 3 CH | Rising edge (latched). |
| RST 6.5 | 3 | 34 H | High level until sampled. |
| RST 5.5 | 4 | 2 CH | High level until sampled. |
| INTR | 5 | See Note (2). | High level until sampled. |

NOTES:
(1) The processor pushes the PC on the stack before branching to the indicated address.
(2) The address branched to depends on the instruction provided to the cpu when the interrupt is acknowledged.

## FUNCTIONAL DESCRIPTION

The M8085A 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 8080A's performance with higher system speed. Also it is designed to fit into a minimum system of three IC's: The CPU (8085A), a RAM/IO (8156), and a ROM or EPROM/IO chip (8355 or 8755A).
The M8085A has twelve addressable 8-bit registers. Four of them can function only as two 16-bit register pairs. Six others can be used interchangeably as 8-bit registers or as 16-bit register pairs. The M8085A register set is as follows:

| Mnemonic | Register | Contents |
| :---: | :---: | :---: |
| ACC or A | Accumulator | 8 bits |
| PC | Program Counter | 16-bit address |
| BC, DE, HL | General-Purpose Registers; data pointer ( HL ) | 8 bits $\times 6$ or 16 bits $\times 3$ |
| SP | Stack Pointer | 16-bit address |
| Flags or $F$ | Flag Register | 5 flags (8-bits |

The M8085A 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 T state (clock cycle) of a machine cycle the low order address is sent out on the Address/Data bus. These lower 8 bits may be latched externally by the Address Latch Enable signal (ALE). During the rest of the machine cycle the data bus is used for memory or I/O data.
The M8085A provides $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{S}_{0}, \mathrm{~S}_{1}$, and $\mathrm{IO} / \bar{M}$ signals for bus control. An Interrupt Acknowledge signal (INTA) is also provided. HOLD, READY, and all Interrupts are synchronized with the processor's internal clock. The M8085A also provides Serial Input Data (SID) and Serial Output Data (SOD) lines for simple serial interface.
In addition to these features, the M8085A has three maskable, vector interrupt pins and one nonmaskable TRAP interrupt.

## INTERRUPT AND SERIAL I/O

The M8085A has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP. INTR is identical in function たthononn init conh nf tho throo RFCTART innuts 5.5 6.5 , and 7.5 , has a programmable mask. TRAP is also a RESTART interrupt but it is nonmaskable.
The three maskable interrupts cause the internal execution of RESTART (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 RESTART vector independent of the state of the interrupt enable or masks. (See Table 1.)
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. (See Section 2.2.7.) The RST 7.5 request flip-flop remains
set until the request is servicedrain it meset automatically. This flip-flop may also be neset by usifg the SIM instruction or by issuing a RESET IN to the M8085A The RST 7.5 internal flip-flop will be set by a pllse 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 RESETIN. (See SIM, Chapter 4.)

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 an RST 7.5 routine if the interrupts are re-enabled before the end of the RST 7.5 routine.
The TRAP interrupt is useful for catastrophic events 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 remain high until it is acknowledged. It will not be recognized again until it goes low, then high again. This avoids any false triggering due to noise or logic glitches. Figure 3 illustrates the TRAP interrupt request circuitry within the M8085A. 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.


## Figure 3. TRAP and RESET IN Circuit

The TRAP interrupt is special in that it disables interrupts, but preserves the previous interrupt enable status. Performing the first RIM instruction following a TRAP interrupt allows you to determine whether interrupts were enabled or disabled prior to the TRAP. All subsequent RIM instructions provide current interrupt enable status. Performing a RIM instruction following INTR, or RST 5.5-7.5 will provide current Interrupt Enable status, revealing that Interrupts are disabled. See the description of the RIM instruction in Chapter 4.

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 M8085A has a multiplexed Data Bus. ALE is used as a strobe to sample the lower 8-bits of address on the Data Bus. Figure 4 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction). 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.

There are seven possible types of machine cycles. Which of these seven takes place is defined by the status of the three status lines ( $I O / \bar{M}, S_{1}, S_{0}$ ) and the three control signals ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{NTA}}$ ). (See Table 2.) The status lines can be used as advanced controls (for device selection, for example), since they become active at the $\mathrm{T}_{1}$ state, at the outset of each machine cycle. Control lines $\overline{R D}$ and $\overline{W R}$ become active later, at the time when the transfer of data is to take place, so are used as command lines.

A machine cycle normally consists of three T states, with the exception of OPCODE FETCH, which normally has either four or six T states (unless WAIT or HOLD states are forced by the receipt of READY or HOLD inputs). Any T state must be one of ten possible states, shown in Table 3.

TABLE 2. M8085A MACHINE CYCLE CHART


TABLE 3. M8085A MACHINE STATE CHART

| Machine State | Status \& Buses |  |  |  | Control |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | S1,S0 | 10/M | $A_{8}-A_{15}$ | $A D_{0}-A D_{7}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | INTA | ALE |
| T1 | X | $x$ | X | X | 1 | 1 | $1^{*}$ |
| $\mathrm{T}_{2}$ | $x$ | $x$ | $x$ | X | $x$ | x | 0 |
| TWAIT | $x$ | $x$ | $x$ | x | $x$ | $x$ | 0 |
| $\mathrm{T}_{3}$ | X | $x$ | $x$ | x | x | X | 0 |
| $\mathrm{T}_{4}$ | 1 | 0 - | $x$ | TS | 1 | 1 | 0 |
| $\mathrm{T}_{5}$ | 1 | $0{ }^{+}$ | $x$ | TS | 1 | 1 | 0 |
| $\mathrm{T}_{6}$ | 1 | 0 + | $x$ | TS | 1 | 1 | 0 |
| Treset | x | TS | TS | TS | TS | 1 | 0 |
| THALT | 0 | TS | TS | TS | TS | 1 | 0 |
| THOLD | X | TS | TS | TS | TS | 1 | 0 |
| $0=$ Logic '0" 0 " $T$ S $=$ High Impedance |  |  |  |  |  |  |  |
| $1=$ Logic " 1 " |  | $\mathrm{X}=$ Un | specified |  |  |  |  |



Figure 4. M8085A Basic System Timing

TABLE 4. 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 Ground . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation
1.5 Watt

## *COMMENT

Stresses above those listed under "Absolute Maximum Ratings" maycatuse permanent damage to the device. This is a stress rating only and functiomal 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 maxımum ratıng conditions for extended periods may affect device reliability.

TABLE 4. D.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{VSS}=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.2 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | 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}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 200 | mA |  |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{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}_{\text {IHR }}$ | Input High Level, RESET | 2.4 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{HY}}$ | Hysteresis, RESET | 0.25 |  | V |  |

TABLE 5. A.C. CHARACTERISTICS
$T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$

| Symbol | Parameter | M8085A ${ }^{[2]}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| tcyc | CLK Cycle Period | 320 | 2000 | ns |
| $\mathrm{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 |
| tXKR | $X_{1}$ Rising to CLK Rising | 30 | 120 | ns |
| tXKF | $\mathrm{X}_{1}$ Rising to CLK Falling | 30 | 150 | ns |
| $t_{\text {AC }}$ | A8-15 Valid to Leading Edge of Control ${ }^{[1]}$ | 270 |  | ns |
| $t_{\text {ACL }}$ | A0-7 Valid to Leading Edge of Control | 240 |  | ns |
| $t_{A D}$ | A0-15 Valid to Valid Data In |  | 575 | ns |
| $t_{\text {AFR }}$ | Address Float After Leading Edge of $\overline{R E A D}$ (INTA) |  | 0 | ns |
| $t_{\text {AL }}$ | A8-15 Valid Before Trailing Edge of ALE ${ }^{[1]}$ | 115 |  | ns |
| $t_{\text {ALL }}$ | A0-7 Valid Before Trailing Edge of ALE | 90 |  | ns |
| tary | READY Valid from Address Valid |  | 220 | ns |
| tca | Address (A8-A15) Valid After Control | 120 |  | ns |
| tcc | Width of Control Low ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{INTA}}$ ) Edge of ALE | 400 |  | ns |
| tcl | Trailing Edge of Control to Leading Edge of ALE | 50 |  | ns |
| tow | Data Valid to Trailing Edge of $\overline{\text { WRITE }}$ | 420 |  | ns |
| thabe | HLDA to Bus Enable |  | 210 | ns |
| thabf | Bus Float After HLDA |  | 210 | ns |
| thack | HLDA Valid to TRailing Edge of CLK | 110 |  | ns |
| thin | HOLD Hold Time | 0 |  | ns |
| thDS | HOLD Setup Time to Trailing Edge of CLK | 170 |  | ns |
| tinh | INTR Hold Time | 0 |  | ns |
| tins | INTR, RST, and TRAP Setup Time to Falling Edge of CLK | 160 |  | ns |
| tla | Address Hold Time After ALE | 100 |  | ns |
| tLC | Trailing Edge of ALE to Leading Edge of Control | 130 |  | ns |
| tLCK | ALE Low During CLK High | 100 |  | ns |
| tLDR | ALE to Valid Data During Read |  | 460 | ns |
| tLDW | ALE to Valid Data During Write |  | 200 | ns |
| tLL | ALE Width | 140 |  | ns |
| tLRY | ALE to READY Stable |  | 110 | ns |

TABLE 5. A.C. CHARACTERISTICS (Cont.)

| Symbol | Parameter | M8085A ${ }^{[2]}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| traE | Trailing Edge of $\overline{\text { READ }}$ to Re-Enabling of Address | 150 |  | ns |
| trd | $\overline{\text { READ ( }}$ ( INTA) to Valid Data |  | 300 | ns |
| trv | Control Trailing Edge to Leading Edge of Next Control | 400 |  | ns |
| $t_{\text {RDH }}$ | Data Hold Time After $\overline{\mathrm{READ}} \overline{\text { INTA }}^{\text {[7] }}$ | 0 |  | ns |
| $t_{\text {RYM }}$ | READY Hold Time | 0 |  | ns |
| trys | READY Setup Time to Leading Edge of CLK | 110 |  | ns |
| two | Data Valid After Trailing Edge of WRITE | 100 |  | ns |
| twDL | LEADING Edge of WRITE to Data Valid |  | 40 | ns |

## Notes:

1. $A_{8}-A_{15}$ address Specs apply to $I O / \bar{M}, S_{0}$, and $S_{1}$ except $A_{8}-A_{15}$ are undefined during $T_{4}-T_{6}$ of OF cycle whereas $I O / \bar{M}, S_{0}$, and $\mathrm{S}_{1}$ are stable.
2. Test conditions: tcyc $=320 \mathrm{~ns} ; \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
3. For all output timing where $\mathrm{C}_{L}=150 \mathrm{pF}$ use the following correction factors:
$25 \mathrm{pF} \leq \mathrm{CL}_{\mathrm{L}}<150 \mathrm{pF}:-0.10 \mathrm{~ns} / \mathrm{pF}$
$150 \mathrm{pF}<\mathrm{C}_{\mathrm{L}} \leq 300 \mathrm{pF}:+0.30 \mathrm{~ns} / \mathrm{pF}$
4. Output timings are measured with purely capacitive load.
5. All timings are measured at output voltage $\mathrm{V}_{\mathrm{L}}=0.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}=2.0 \mathrm{~V}$, and 1.5 V with 20 ns rise and fall time on inputs.
6. To calculate timing specifications at other values of tcyc use Table 6.
7. Data hold time is guaranteed under all loading conditions.

TABLE 6. BUS TIMING SPECIFICATION AS A Tcyc DEPENDENT
M8085A

| ${ }_{\text {t }}$ AL | - | (1/2) T-45 | MIN |
| :---: | :---: | :---: | :---: |
| ${ }_{\text {L }}^{\text {LA }}$ | - | (1/2) T-60 | MIN |
| ${ }_{\text {t }}^{\text {LL }}$ | - | (1/2) T-20 | MIN |
| $\mathrm{t}_{\text {LCK }}$ | - | (1/2) T-60 | MIN |
| ${ }_{\text {t }}^{\text {L }}$ C | - | (1/2) T-30 | MIN |
| ${ }^{\text {A }}$ AD | - | $(5 / 2+N) T-225$ | MAX |
| $\mathrm{t}_{\text {RD }}$ | - | $(3 / 2+N) T-180$ | MAX |
| $t_{\text {RAE }}$ | - | (1/2) T-10 | MIN |
| ${ }^{t} \mathrm{CA}$ | - | (1/2) T-40 | MIN |
| ${ }_{\text {DW }}$ | - | $(3 / 2+N) T-60$ | MIN |
| ${ }^{\text {w }}$ ( | - | (1/2) T-60 | MIN |
| ${ }^{t} \mathrm{CC}$ | - | $(3 / 2+N) T-80$ | MIN |
| ${ }^{\mathrm{t}} \mathrm{CL}$ | - | (1/2) T-110 | MIN |
| ${ }^{\text {t }}$ ARY | - | (3/2) T-260 | MAX |
| ${ }^{\text {t }}$ HACK | - | (1/2) T-50 | MIN |
| ${ }^{\text {t }}$ HABF | - | $(1 / 2) T+50$ | MAX |
| ${ }^{\text {t }}$ HABE | - | (1/2) T + 50 | MAX |
| ${ }^{t} A C$ | - | (2/2) T-50 | MIN |
| ${ }_{1}$ | - | (1/2) T-80 | MIN |
| $\mathrm{t}_{2}$ | - | (1/2) T-40 | MIN |
| ${ }_{\text {t }}^{\text {RV }}$ | - | (3/2) T-80 | MIN |
| ${ }^{\text {t LDR }}$ | - | (4/2) T-180 | MAX |

NOTE: $\quad N$ is equal to the total WAIT states.
$T={ }^{t} \mathrm{CYC}$.


Figure 5. Clock Timing Waveform

Read Operation


Write Operation


Read operation with Wait Cycle (Typical) - same READY timing applies to WRITE operation.


Figure 6. M8085A Bus Timing, With and Without Wait

## Hold Operation



Figure 7. M8085A Hold Timing


Figure 8. M8085A Interrupt and Hold Timing

TABLE 7. INSTRUCTION SET SUMMARY

|  |  | Instruction Code[1] Clock\|2] |  |  |  |  |  |  |  |  | Mnemonic | Description | Instruction Codet) |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Description | 07 | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{O}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{O}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | Cycles |  |  | 07 | $0_{6}$ |  | $\mathrm{O}_{4}$ | $\mathrm{D}_{3}$ |  |  |  | Cyoles: |
| MOVE. LOAD. AND STORE |  |  |  |  |  |  |  |  |  |  | CPE | Call 011 parity even | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | $9 \% 18$ |
| MOV $11 \mathrm{r}_{2}$ | Move register to register | 0 | 1 | D | D | 0 | S | S | S | 4 | CPO | Call on parity odd | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 9/18 |
| MOV M.r | Move register to memory | 0 | 1 | 1 | 1 | 0 | S | S | S | 7 | RETURN |  |  |  |  |  |  |  |  |  |  |
| MOV r M | Move memory to register | 0 | 1 | D | 0 | 0 | 1 | 1 | 0 | 7 | RET | Return | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| MVI r | Move immediate register | 0 | 0 | D | 0 | 0 | 1 | 1 | 0 | 7 | RC | Return on carry | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| MVI M | Move immediate memory | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 10 | RNC | Return on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 6/12 |
| LXIB | Load immediate register | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 10 | RZ | Return on zero | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 6/12 |
|  | Pair B \& C |  |  |  |  |  |  |  |  |  | RNZ | Return on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 6/12 |
| LXI D | Load immediate register Pair D \& E | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 10 | RPRM | Return on positive | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 6/12 |
|  |  |  |  |  |  |  |  |  |  |  |  | Return on minus | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 6/12 |
| LXIH | Load immediate register Pair H \& L | 0 | 0 | 1 | 0 | 0 | 0 |  | 1 | 10 | $\begin{aligned} & \text { RPE } \\ & \text { RPO } \end{aligned}$ | Return on parity even Return on parity odd | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | $6 / 12$ $6 / 12$ |
| LXI SP | Load immediate stack pointer | 0 | 0 |  |  |  |  | 0 | 1 | 10 |  |  | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 6/12 |
|  |  | 0 | 0 | 1 | 1 | 0 |  | 00 |  |  | RESTART |  |  |  |  |  |  |  |  |  |  |
| STAX B | Store A indirect | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 7 | RST | Restart | 1 | 1 | A | A | A | 1 | 1 | 1 | 12 |
| STAX D | Store A indirect | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 7 | INPUT/OUTPUT |  |  |  |  |  |  |  |  |  |  |
| LDAX B | Load A indirect | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 7 | IN | Input | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 10 |
| LDAX 0 | Load A indirect | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 7 | OUT | Output | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 10 |
| STA | Store A direct | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 13 | INCREMENT AND DECREMENT |  |  |  |  |  |  |  |  |  |  |
| LOA | Load A direct | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | 13 | INR r | Increment register | 0 | 0 | D | D | D | 1 | 0 | 0 | 4 |
| SHLD | Store H \& L direct | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 16 | DCR r | Decrement register | 0 | 0 | D | D | D | 1 | 0 | 1 | 4 |
| LHLD | Load H \& L direct | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 16 | INR M | Increment memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 0 | 10 |
| XCHG | Exchange D \& E H \& L | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 4 | DCR M | Decrement memory | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | 10 |
|  | Registers |  |  |  |  |  |  |  |  |  | INX B | Increment B \& C | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 6 |
| STACK OPS |  |  |  |  |  |  |  |  |  |  |  | registers |  |  |  |  |  |  |  |  |  |
| PUSH B | Push register Pair B \& C on stack | 1 | 1 | 0 | 00 | 01 |  | 10 | 01 | 12 | INX 0 | Increment D \& E registers | 0 | 0 | 0 | 1 | 0 | 0 | 1 |  | 6 |
| PUSH D | Push register Pair D \& E on stack | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 12 | INXH | increment H\&L registers | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 6 |
| PUSH H | Push register Pair H \& L on stack | 1 | 1 | 1 | 0 | 01 |  |  | 1 | 12 | $\begin{aligned} & \text { INX SP } \\ & \text { DCX B } \end{aligned}$ | Increment stack pointer Decrement B \& C | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 6 |
|  |  |  |  |  |  |  |  | 0 |  |  |  |  | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 6 |
| PUSH PSW | Push A and Flags on stack | 1 | 1 | 1 | 10 | 0 | 1 | 0 | 1 | 12 | $\begin{aligned} & O C \times D \\ & D C \times H \end{aligned}$ | Decrement D \& E | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 6 |
|  |  |  |  | 0 | 0 | 0 |  |  |  |  |  |  |  | 0 | 1 | 0 | $1$ | 0 | 1 |  | 6 |
| POP B | Coff stack | 1 | 1 |  |  |  | 00 | 01 | 1 | 10 | DCX SP | Decrement stack pointer |  | 0 | 1 | 1 |  | 01 |  | 1 | 6 |
| POP D | Pop register Pair D \& E off stack | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 10 | ADD |  |  |  |  |  |  |  |  |  |  |
| POP H | Pop register Pair H \& L off stack | 1 | 1 | 1 | 0 | 00 | 00 |  | 1 | 10 | $A D C \cdot$ | Add register to A <br> Add register to A |  | 0 | 0 | 0 | 1 | S | S | S | 4 |
|  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  | S | S | S |  |
| POP PSW | Pop A and Flags off stack | 1 | 1 | 1 | 10 | 0 | 00 |  | 1 | 10 | ADD M | with carry Add memory to $A$ | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 7 |
| XTHL | Exchange top of stack H\&L <br> $H \& L$ to stack pointer | 1 | 1 | 1 | 0 | 00 |  | 1 | 1 | 16 | ADC M | Add memory to $A$ with carry | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| SPHL |  | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 6 | ADI | Add immediate to A | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | $i$ |
| JUMP |  |  |  |  |  |  |  |  |  |  | ACl | Add immediate to A with carry | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 7 |
| JMP | Jump unconditional | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 10 | DAD B | Add B \& C to H \& L | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 10 |
| $\therefore$ | - .-.... | + | 1 | $n$ | 1 | 1 | $n$ | 1 | $n$ | 7/10 | nan $n$ | जnत 0 eftn Hel | $n$ | $\bigcirc$ | $\bigcirc$ | 1 | 1 | 0 | 0 | 1 | 10 |
| JNC | Jump on no carry | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 7/10 | DAD H | Add $H \& L$ to $H \& L$ | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 10 |
| JZ | Jump on zero | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 7/10 | DAD SP | Add stack pointer to | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 10 |
| JNZ | Jump on no zero | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 7/10 |  | H\& L |  |  |  |  |  |  |  |  |  |
| JP | Jump on positive | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 7/10 | SUBTRACT |  |  |  |  |  |  |  |  |  |  |
| JM | Jump on minus | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 7/10 | SUB r | Subtract register | 1 | 0 | 0 | 1 | 0 | S | S | S | 4 |
| JPE | Jump on parity even | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 7/10 |  | from A |  |  |  |  |  |  |  |  |  |
| JPO | Jump on parity odd | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 7/10 | SBB r | Subtract register from A with borrow | 1 | 0 | 0 | 1 | 1 | S | S | S | 4 |
| PCHL | H\&L to program counter | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 6 | SUB M | A with borrow <br> Subtiact memory from A | 1 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| CALL |  |  |  |  |  |  |  |  |  |  | SBB M |  | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| CALL | Call unconditional | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | 18 | SBB M | A with borrow | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |  |
| CC | Call on carry | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | 9/18 | SUI | Subtract immediate | 1 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 7 |
| CNC | Call on no carry | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 9/18 |  | from A |  |  |  |  |  |  |  |  |  |
| CZ | Call on zero | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 9/18 | SBI | Subtract immediate | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 7 |
| CNZ | Call on no zero | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 9/18 |  | from A with borrow |  |  |  |  |  |  |  |  |  |
| CP | Call on positive | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 9/18 | LOGICAL |  |  |  |  |  |  |  |  |  |  |
| CM | Call on minus | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 9/18 | ANA I | And register with A | 1 | 0 | 1 | 0 | 0 | S | S | S | 4 |

## TABLE 7. INSTRUCTION SUMMARY (Cont.)

| Mnemonic |  | Instruction Code[1] |  |  |  |  |  |  |  |  |  | Mnemonic | Description | Instruction Codetil |  |  |  |  |  |  |  | Clock\|2| Cycles. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Description | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{O}_{2}$ | D |  | 0 | Cycles |  |  | 07 | $\mathrm{O}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{O}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{O}_{2}$ | $\mathrm{O}_{1}$ | $\mathrm{D}_{0}$ |  |
| XRA r | Exclusive Or register with A | 1 | 0 | 1 | 0 | 1 | S | S |  | S | 4 | RAL | Rotate A left through carry | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 4. |
| ORA r | Or register with A | 1 | 0 | 1 | 1 | 0 | S | S |  | S | 4 | RAR | Rotate A ught through | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 4 |
| CMP r | Compare register with A | 1 | 0 | 1 | 1 | 1 | S | S |  | S | 4 |  | carry |  |  |  |  |  |  |  |  |  |
| ANA M | And memory with A | 1 | 0 | 1 | 0 | 0 | 1 | 1 |  | 0 | 7 | SPECIALS |  |  |  |  |  |  |  |  |  |  |
| XRA M | Exclusive Or memory | 1 | 0 | 1 | 0 | 1 | 1 |  |  | 0 | 7 | CMA | Complement A | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 4 |
|  | with A |  |  |  |  |  |  |  |  |  |  | STC | Set carry | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 4 |
| ORA M | Or memory with A | 1 | 0 | 1 | 1 | 0 | 1 | 1 |  | 0 | 7 | CMC | Complement carry | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 4 |
| CMP M | Compare memory with A | 1 | 0 | 1 | 1 | 1 | 1 | 1 |  | 0 | 7 | DAA | Decimal adjust A | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 4 |
| ANi | And immediate with A | 1 | 1 | 1 | 0 | 0 | 1 | 1 |  | 0 | 7 | CONTROL |  |  |  |  |  |  |  |  |  |  |
| XRI | Exclusive Or immedıate with A | 1 | 1 | 1 | 0 | 1 | 1 | 1 |  | 0 | 7 | EI | Enable Interrupts | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 4 |
| ORI | Or immediate with A | 1 | 1 | 1 | 1 | 0 | 1 | 1 |  | 0 | 7 | DI | Disable Interrupt | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 4 |
| CPI | Compare immediate | 1 | 1 | 1 | 1 | 1 | 1 |  |  | 0 | 7 | NOP | No-operation | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 4 |
|  | with A |  |  |  |  |  |  |  |  |  |  | HLT | Halt | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 5 |
| ROTATE |  |  |  |  |  |  |  |  |  |  |  | NEW M80 | A INSTRUCTIONS |  |  |  |  |  |  |  |  |  |
| RLC | Rotate A left | 0 | 0 | 0 | 0 | 0 | 1 | 1 |  |  | 4 | RIM | Read Interrupt Mask | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 4 |
| RRC | Rotate A right | 0 | 0 | 0 | 0 | 1 | 1 | 1 |  | 1 | 4 | SIM | Set Interrupt Mask | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 4 |

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 cy'cles dependent on condition flags
-All mnemonics copyright © Intel Corporation 1977

## intel

M8155

## 2048 BIT STATIC MOS RAM WITH I/O PORTS AND TIMER

Military Temperature Range Operation ( $-55^{\circ} \mathrm{C}$ TO $+125^{\circ} \mathrm{C}$ )<br>- 256 Word x 8 Bits<br>- Single +5 V Power Supply<br>- Completely Static Operation<br>■ Internal Address Latch

## 2 Programmable 8 Bit I/O Ports <br> - 1 Programmable 6-Bit I/O Port <br> Programmable 14-Bit Binary Counter/ Timer <br> Multiplexed Address and Data Bus <br> 40 Pin DIP

The M8155 is a RAM and I/O chip to be used in the MCS-85 ${ }^{\text {TM }}$ microcomputer system. The RAM portion is designed with 2048 static cells organized as $256 \times 8$. It has a maximum access time of 400 ns to permit use with no wait states in the 8085A 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 depending on timer mode.

PIN CONFIGURATION


BLOCK DIAGRAM


## M8155 PIN FUNCTIONS

## Symbol

RESET
(input)

AD0-7 (input)
(input)
$\overline{\mathrm{RD}}$
(input)
$\overline{C E} \quad$ Chip Enable: On the M8155, this pin is
Function
Pulse provided by the 8085A to initialize the system (connect to 8085A RESET OUT). 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 two 8085A clock cycle times.

3-state Address/Data lines that interface with the CPU lower 8-bit Address/Data Bus. The 8-bit address is latched into the address latch inside the M8155 on the falling edge of ALE. The address can be either for the memory section or the I/O section depending on the $10 / \bar{M}$ input. The 8bit data is either written into the chip or read from the chip, depending on the $\overline{W R}$ or $\overline{R D}$ input signal $\overline{\mathrm{CE}}$ and is ACTIVE LOW.

Read control: Input low on this line with the Chip Enable active enables and $A D D_{0-7}$ buffers. If $1 O / \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 or command/ status registers will be read to the AD bus.

Write control: Input low on this line with the Chip Enable active causes the data on the Address/Data bus to be written to the RAM or I/O ports and command/status register depending on $10 / \bar{M}$.

## Symbol

ALE
(input)
$10 / \bar{M}$
(input)
PA0-7(8)
(input/output)

PB0-7(8)
(input/output)

PC0-5(6) (input/output)

TIMER IN
(input)
TIMER OUT
(output)
$V_{c c}$
Vss

## Function

Address Latch Enable: This conttol signal latches both the address onthe $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.
Selects memory if Iow and I/O and command/status registers if high.
These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the command register.
These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the command register.

These 6 pins can function as either input port, output port, or as control signals for PA and PB. Programming is done through the command register. When $\mathrm{PC}_{0-5}$ are used as control signals, they will provide the following:
PC 0 - A INTR (Port A Interrupt)
$\mathrm{PC}_{1}$ - ABF (Port A Buffer Full)
$\mathrm{PC}_{2}-\overline{\mathrm{A} S T B}$ (Port A Strobe)
$\mathrm{PC}_{3}-\mathrm{B}$ INTR (Port B Interrupt)
$\mathrm{PC}_{4}-\overline{\mathrm{B} \mathrm{BF}}$ (Port B Buffer Full)
$\mathrm{PC}_{5}$ - B STB (Port B Strobe)
Input to the counter-timer.

Timer output. This output can be either a square wave or a pulse depending on the timer mode.
+5 volt supply.
Ground Reference.

## DESCRIPTION

The M8155 contains the following:

- $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 timer-counter

The $10 / \bar{M}$ (IO/Memory Select) pin selects either the five registers (Command, Status, $\mathrm{PA}_{0-7}, \mathrm{~PB}_{0-7}, \mathrm{PC}_{0-5}$ ) or the memory (RAM) portion. (See Figure 1.1
The 8-bit address on the Address/Data lines, Chip Enable input CE or $\overline{C E}$, and $I O / \bar{M}$ are all latched on-chip at the falling edge of ALE


Figure 1. M8155 Internal Registers

## PROGRAMMING OF THE COMMAND REGISTER

The command register consists of eight latches. 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 command register contents can be altered at any time by using the I/O address XXXXX000 during a WRITE operation with the Chip Enable active and $10 / \bar{M}=1$. The meaning of each bit of the command byte is defined in Figure 2. The contents of the command register may never be read.


Figure 2. Command Register Bit Assignment

## READING THE STATUS REGISTER

The status register consists of seven latches; oneforeach 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 $1 / O$ section can be polled by reading the Status Register (Address XXXXX000). Status word format is shown in Figure 3. Note that you may never write to the status register since the command register shares the same 1/O address and the command register is selected when a write to that address is issued.


Figure 3. Status Register Bit Assignment

## INPUT/OUTPUT SECTION

The I/O section of the M8155 consists of five registers: (See Figure 4.)

- Command/Status Register (C/S) - Both registers are assigned the address XXXXX000. The C/S address serves the dual purpose.
When the C/S registers are 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 becomes available on the $\mathrm{AD}_{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 PA0-7. The address of this register is XXXXX001.
- PB Register - This register functions the same as PA Register. The I/O pins assigned are $\mathrm{PB}_{0-7}$. The address of this register is 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 PA and PB 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 M8155 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:

| CONTROL | INPUT MODE | OUTPUT MODE |
| :---: | :---: | :---: |
| BF | Low | Low |
| INTR | Low | High |
| STB | Input Control | Input Control |


| I/O ADDRESS ${ }^{+}$ |  |  |  |  |  |  |  | SELECTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A7 | A6 | A5 | A4 | A3 | A2 | A1 | AO |  |
| $x$ | $x$ | $x$ | $x$ | $x$ | 0 | 0 | 0 | Interval Command/Status Regıster |
| $x$ | $x$ | $x$ | $x$ | $x$ | 0 | 0 | 1 | General Purpose I/O Port A |
| $x$ | $x$ | $x$ | $x$ | $x$ | 0 | 1 | 0 | General Purpose I/O Port B |
| X | $x$ | $x$ | $x$ | $x$ | 0 | 1 | 1 | Port C - General Purpose 1,O or Control |
| $x$ | $x$ | $x$ | $x$ | X | 1 | 0 | 0 | Low-Order 8 bits of Timer Count |
| X | X | X | $x$ | X | 1 | 0 | 1 | High 6 bits of Timer Count and 2 bits of Timer Mode |

X: Don't Care.
$\dagger$ : I/O Address must be qualified by $\overline{\mathrm{CE}}=0($ M8155 ) and $10 / \bar{M}=1$ in order to select the appropriate register.

Figure 4. I/O Port and Timer Addressing Scheme

Figure 5 shows how I/O PORTS A and B are structured within the M8155:


Figure 5. M8155 Port Functions

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

Note in the diagram that when the $1 / 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.
The outputs of the M8155 are "glitch-free" meaning that you can write a " 1 " to a bit position that was previously" 1 " and the level at the output pin will not change.
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 M8155 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.

Figure 6 shows how the M8155 I/O ports might be configured in a typical MCS-85 system.


Figure 6. Example: Command Register $=00111001$

## TIMER SECTION

The timer is a 14 -bit down-counter that counts the TIMER IN 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. (See Figure 4).
To program the timer, the COUNT LENGTH REG is loaded first, one byte at a time, by selecting the timer addresses. Bits 0-13 of the high order count register will specify the length of the next count and bits 14-15 of the high order register will specify the timer output mode (see Figure 7). The value loaded into the count length register can have any value from 2 H through $3 F F H$ in Bits 0-13.


LSB OF CNT LENGTH
Figure 7. Timer Format
There are four modes to choose from: M2 and M1 define the timer mode, as shown in Figure 9.


Figure 8. Timer Modes
Bits 6-7 (TM $M_{2}$ and $T M_{1}$ ) of command register contents are used to start and stop the counter. There are four commands to choose from:

| TM 2 | TM1 |  |
| :---: | :---: | :--- |
| 0 | 0 | NOP - Do not affect counter operation. |
| 0 | 1 | STOP - NOP if timer has not started; <br> stop counting if the timer is running. |
| 1 | 0 | STOP AFTER TC - Stop immediately <br> after present TC is reached (NOP if timer <br> has not started) |
| 1 | 1 | START - Load mode and CNT length <br> and start immediately after loading (if <br> timer is not presently running). If timer <br> is running, start the new mode and CNT <br> length immediately after present TC is <br> reached. |

NOP - Do not affect counter operation. stop counting if the timer is running. is running, start the new mode and CNT reached.

Note that while the counter is counting, you may foad a new count and mode into the count length registers. Before the new count and mode will be used by the counter, you must issue a START command to the counter. This applies even though you may only want to change the count and use the previous mode.

In case of an odd-numbered count, the first half-cycle of the squarewave output, which is high, is one count longer than the second (low) half-cycle, as shown in Figure 9.


NOTE: 5 AND 4 REFER TO THE NUMBER OF CLOCKS IN THAT TIME PERIOD

Figure 9. Asymmetrical Square-Wave Output Resulting from Count of 9

The counter in the M8155 is not initialized to any particular mode or count when hardware RESET occurs, but RESET does stop the counting. Therefore, counting cannot begin following RESET until a START command is issued via the C/S register.
Please note that the timer circuit on the M8155 chip is designed to be a square-wave timer, not an event counter. To achieve this, it counts down by twos twice in completing one cycle. Thus, its registers do not contain values directly representing the number of TIMER IN pulses received. You cannot load an initial value of 1 into the count register and cause the timer to operate, as its terminal count value is 10 (binary) or 2 (decimal). (For the detection of single pulses, it is suggested that one of the hardware interrupt pins on the 8085A be used.) After the timer has started counting down, the values residing in the count registers can be used to calculate the actual number of TIMER IN pulses required to complete the timer cycle if desired. To obtain the remaining count, perform the following operations in order:

1. Stop the count
2. Read in the 16-bit value from the count length registers
3. Reset the upper two mode bits
4. Reset the carry and rotate right one position all 16 bits through carry
5. If carry is set, add $1 / 2$ of the full original count ( $1 / 2$ full count -1 if full count is odd).

Note: If you started with an odd count and you read the count length register before the third count pulse occurs, you will not be able to discern whether one or two counts has occurred. Regardless of this, the M8155 always counts out the right number of pulses in generating the TIMER OUT waveforms.

## 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}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.5 V to +7 V |
| Power Dissipation |  |

*COMMENT: Stresses above those fisted under Masolute Maximum Ratings" may cause permanent "damage to the device. This is a stress rating only and functional operamu 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}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| 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}_{\mathrm{CC}}+0.5$ | 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{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\text {IL }}$ | Input Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ to 0V |
| $\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 |  |
| $\mathrm{I}_{\text {IL }}$ (CE) | Chip Enable Leakage <br> M8155 |  | +100 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ to 0V |

A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

|  |  | M8155 |  |  |
| :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | MIN. | MAX. | UNITS |
| ${ }_{\text {t }}{ }_{\text {L }}$ | Address to Latch Set Up Time | 50 |  | ns |
| $t_{\text {LA }}$ | Address Hold Time after Latch | 80 |  | ns |
| ${ }_{\text {t }}$ C | Latch to READ/WRITE Control | 100 |  | ns |
| $t_{\text {RD }}$ | Valid Data Out Delay from READ Control |  | 170 | ns |
| ${ }^{t} A D$ | Address Stable to Data Out Valid |  | 400 | ns |
| $t_{\text {LL }}$ | Latch Enable Width | 100 |  | ns |
| $t_{\text {RDF }}$ | Data Bus Float After READ | 0 | 100 | ns |
| ${ }^{\text {t }} \mathrm{CL}$ | READ/WRITE Control to Latch Enable | 20 |  | ns |
| ${ }^{\text {t }}$ C | READNRRITE Control Width | 250 |  | ns |
| ${ }_{\text {t }}$ D | Data In to WRITE Set Up Time | 150 |  | ns |
| two | Data In Hold Time After WRITE | 0 |  | ns |
| $t_{\text {R } V}$ | Recovery Time Between Controls | 300 |  | ns |
| $t_{\text {WP }}$ | WRITE to Port Output |  | 400 | ns |
| $t_{\text {PR }}$ | Port Input Setup Time | 70 |  | ns |
| $t_{\text {R }} \mathrm{P}$ | Port Input Hold Time | 50 |  | ns |
| ${ }_{\text {t }}^{\text {SBF }}$ | Strobe to Buffer Full |  | 400 | ns |
| ${ }_{\text {tSS }}$ | Strobe Width | 200 |  | ns |
| $t_{\text {Rbe }}$ | READ to Buffer Empty |  | 400 | ns |
| ${ }_{\text {t }}^{\text {I }}$ | Strobe to INTR On |  | 400 | ns |
| ${ }^{\text {troi }}$ | READ to INTR Off |  | 400 | ns |
| $\mathrm{t}_{\text {PSS }}$ | Port Setup Time to Strobe Strobe | 50 |  | ns |
| $t_{\text {PHS }}$ | Port Hold Time After Strobe | 120 |  | ns |
| ${ }^{\text {t }}$ SBE | Strobe to Buffer Empty |  | 400 | ns |
| twbF | WRITE to Buffer Full |  | 400 | ns |
| $t_{W I}$ | WRITE to INTR Off |  | 400 | ns |
| ${ }^{\text {t }}$ L | TIMER-IN to TIMER-OUT Low |  | 400 | ns |
| ${ }_{\text {t }}{ }^{\text {H }}$ | TIMER-IN to $\overline{\text { TIMER-OUT High }}$ |  | 400 | ns |
| $\mathrm{t}_{\text {RDE }}$ | Data Bus Enable from READ Control | 10 |  | ns |
| $\mathrm{t}_{1}$ | TIMER-IN Low Time | 80 |  | ns |
| $\mathrm{t}_{2}$ | TIMER-IN High Time | 120 |  | ns |

## WAVEFORMS

## a. Read Cycle


b. Write Cycle


Figure 10. M8155 Read/Write Timing Diagrams
a. Strobed Input Mode

b. Strobed Output Mode


Figure 11. Strobed I/O Timing
a. Basic Input Mode

b. Basic Output Mode

*DATA BUS TIMING IS SHOWN IN FIGURE 7.

Figure 12. Basic I/O Timing Wavefore


NOTE 1: THE TIMER OUTPUT IS PERIODIC IF IN AN AUTOMATIC RELOAD MODE ( $M_{1}$ MODE BIT $=1$ )

Figure 13. Timer Output Waveform Countdown from 5 to 1

\author{

- Full Military Temp. Range $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ <br> - 4-Channel DMA Controller <br> - Priority DMA Request Logic <br> - Channel Inhibit Logic
}

\author{

- Terminal Count and Modulo 128 Outputs <br> - Single TTL Clock <br> - Single +5V Supply <br> - Auto Load Mode
}

The Intel ${ }^{\circledR}$ M8257 is a 4-channel direct memory access (DMA) controller. It is specifically designed to simplify the transfer of data at high speeds for the Intel ${ }^{\circledR}$ 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 in accomplished via the CPU's hold function. The M8257 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. The M8257 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

| $D_{7}-D_{0}$ | DATA BUS |
| :--- | :--- |
| $A_{7}-A_{0}$ | ADDRESS BUS |
| $\overline{\overline{/ O R}}$ | I/O READ |
| $\overline{\overline{/ O W}}$ | I/O WRITE |
| $\overline{M E M R}$ | MEMORY READ |
| $\overline{M E M W}$ | MEMORY WRITE |
| CLK | CLOCK INPUT |
| RESET | RESET INPUT |
| READY | READY |
| HRQ | HOLD REQUEST <br> (TO 8080A) |
| HLDA | HOLD ACKNOWLEDGE <br> (FROM 8080A) |




PIN NAMES

| AEN | ADDRESS ENABLE |
| :---: | :---: |
| ADSTB | ADDRESS STROBE |
| TC | TERMINAL COUNT |
| MARK | MODULO 128 MARK |
| $\mathrm{DRO}_{3} \cdot \mathrm{DRG}_{0}$ | DMA REQUEST INPUT |
| $\overline{\text { DACK }}_{3} \overline{\text { DACK }}_{0}$ | DMA ACKNOWLEDGE OUT |
| $\overline{\text { cs }}$ | CHIP SELECT |
| Vcc | +5 VOLTS |
| GND | GROUND |

BLOCK DIAGRAM


# M8257 <br> PROGRAMMABLE DMA CONTROLLER 

## 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 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 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 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | MAX. | UNIT | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | Volts |  |
| $\mathrm{V}_{1} \mathrm{H}$ | Input High Voltage | 2.2 | $\mathrm{V}_{\mathrm{CC}}+.5$ | Volts |  |
| $V_{\text {OL }}$ | Output Low Voltage |  | 0.45 | Volts | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 | V cc | Volts | $\mathrm{l}_{\mathrm{OH}}=-150 \mu \mathrm{~A} \text { for } A B \text {, }$ <br> DB and AEN $\mathrm{l}_{\mathrm{OH}}=-80 \mu \mathrm{~A} \text { for others }$ |
| $\mathrm{V}_{\mathrm{HH}}$ | HRQ Output High Voltage | 3.3 | $V_{\text {cc }}$ | Volts | $\mathrm{IOH}=-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}_{\mathrm{CC}}$ to 0 V |
| lofl | Output Leakage During Float |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ to 0 V |

## CAPACITANCE

$T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}$

| SYMBOL | PARAMETER | MIN. | TYP. | MAX. | UNIT | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $C_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $C_{I / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins <br> returned to GND |

## A.C. CHARACTERISTICS: PERIPHERAL (SLAVE) MODE

$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$; GND $=0 \mathrm{~V}$ (Note 1 ).

## 8080 Bus Parameters

Read Cycle:

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $T_{A R}$ | Adr or $\overline{\mathrm{CS}} \downarrow$ Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | ns |  |
| $\mathrm{~T}_{\mathrm{RA}}$ | Adr or $\overline{\mathrm{CS}} \uparrow$ Hold from $\overline{\mathrm{RD}} \uparrow$ | 0 |  | ns |  |
| $\mathrm{~T}_{\text {RD }}$ | Data Access from $\overline{\mathrm{RD}} \downarrow$ | 0 | 300 | ns | (Note 2) |
| $\mathrm{T}_{\mathrm{DF}}$ | $\mathrm{DB} \rightarrow$ Float Delay from $\overline{\mathrm{RD}} \uparrow$ | 20 | 150 | ns |  |
| $\mathrm{~T}_{\mathrm{RR}}$ | $\overline{\mathrm{RD}}$ Width | 250 |  | ns |  |

## Write Cycle:

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $T_{\text {AW }}$ | Adr Setup to $\overline{W R} \downarrow$ | 20 |  | ns |  |
| $T_{\text {WA }}$ | Adr Hold from $\overline{\mathrm{WR}} \uparrow$ | 35 |  | ns |  |
| $T_{\text {DW }}$ | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 200 |  | ns |  |
| $T_{\text {WD }}$ | Data Hold from $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| $\mathrm{~T}_{\text {WW }}$ | $\overline{\mathrm{WR}}$ Width | 175 |  | ns |  |

## Other Timing:

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $T_{\text {RSTW }}$ | Reset Pulse Width | 300 |  | ns |  |
| $\mathrm{~T}_{\text {RSTD }}$ | Power Supply $\uparrow\left(\mathrm{V}_{\mathrm{CC}}\right)$ Setup to Reset $\downarrow$ | 500 |  | $\mu \mathrm{~s}$ |  |
| $\mathrm{~T}_{\mathrm{r}}$ | Signal Rise Time |  | 20 | ns |  |
| $\mathrm{~T}_{\mathrm{f}}$ | Signal Fall Time |  | 20 | ns |  |
| $\mathrm{~T}_{\text {RSTS }}$ | Reset to First I/OWR | 2 |  | $\mathrm{t}_{\mathrm{CY}}$ |  |

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. M 8257 : $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, 8257-5: \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.

## M8257 PERIPHERAL MODE TIMING DIAGRAMS



Read Timing:


Input Waveform for A.C. Tests:


## A.C. CHARACTERISTICS: DMA (MASTER) MODE

$\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}$

## Timing Requirements

| Symbol | Parameter | Min. | Max. | Unit : |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{CY}}$ | Cycle Time (Period) | 0.320 | 4 | $\mu \mathrm{S}$ |
| $\mathrm{T}_{\theta}$ | Clock Active (High) | 120 | .$^{.8} \mathrm{~T}_{C Y}$ | ns |
| $\mathrm{T}_{\mathrm{QS}}$ | DRQ^ Setup to $\theta \downarrow$ (SI, S4) | 120 |  | ns |
| $\mathrm{T}_{\text {QH }}$ | DRQ $\downarrow$ Hold from HLDA介 ${ }^{[4]}$ | 0 |  | ns |
| $\mathrm{T}_{\mathrm{HS}}$ | HLDA $\uparrow$ or $\downarrow$ Setup to $\theta \downarrow$ (SI, S4) | 100 |  | ns |
| $\mathrm{T}_{\text {RS }}$ | READY Setup Time to $\theta \uparrow(\mathrm{S} 3, \mathrm{Sw}$ ) | 30 |  | ns |
| $\mathrm{T}_{\text {RH }}$ | READY Hold Time from $\theta \uparrow$ ( $33, \mathrm{Sw}$ ) | 20 |  | ns |

Note: 4. Tracking Parameter.

## Tracking Parameters

Signals labeled as Tracking Parameters (footnotes 4.7 under A.C. Specifications) are signals that follow similar paths through the silicon die. The propagation speed of these signals varies in the manufacturing process but the relationship between all these parameters is constant. The variation is less than or equal to 50 ns .
Suppose the following timing equation is being evaluated,

$$
T_{A(M I N)}+T_{B(M A X)} \leq 150 \mathrm{~ns}
$$

and only minimum specifications exist for $T_{A}$ and $T_{B}$. If $T_{A(M I N)}$ is used, and if $T_{A}$ and $T_{B}$ are tracking parameters, $\mathrm{T}_{\mathrm{B}(\mathrm{MAX})}$ can be taken as $\mathrm{T}_{\mathrm{B}(\mathrm{MIN})}+50 \mathrm{~ns}$.

$$
T_{A(M I N)}+\left(T_{B(M I N)^{*}}+50 \mathrm{~ns}\right) \leq 150 \mathrm{~ns}
$$

${ }^{*}$ if $T_{A}$ and $T_{B}$ are tracking parameters

## A.C. CHARACTERISTICS: DMA (MASTER) MODE

$\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}$

## Timing Responses

| Symbol | Parameter | Min. | Max. | Unit. |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{DQ}}$ | HRQ̂ or $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI}, \mathrm{S} 4)$ (measured at 2.0 V ) ${ }^{[1]}$ |  | 180 | ns |
| $\mathrm{T}_{\text {DQ1 }}$ | HRQ^ or $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI}, \mathrm{S} 4)$ (measured at 3.3 V ) ${ }^{[3]}$ |  | 270 | ns |
| $\mathrm{T}_{\text {AEL }}$ | AEN $\uparrow$ Delay from $\theta \downarrow(\mathrm{S} 1)^{[1]}$ |  | 300 | ns |
| $\mathrm{T}_{\text {AET }}$ | AEN $\downarrow$ Delay from $\theta \uparrow(\mathrm{SI})^{[1]}$ |  | 200 | ns |
| $\mathrm{T}_{\text {AEA }}$ | $\operatorname{Adr}(\mathrm{AB})($ Active $)$ Delay from AEN $\uparrow(\mathrm{S} 1)^{[4]}$ | 20 |  | ns |
| $\mathrm{T}_{\text {FAAB }}$ | $\operatorname{Adr}(\mathrm{AB})($ Active $)$ Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 270 | ns |
| $\mathrm{T}_{\text {AFAB }}$ | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Float) Delay from $\theta \uparrow(\mathrm{SI})^{[2]}$ |  | 200 | ns |
| $\mathrm{T}_{\text {ASM }}$ | Adr(AB)(Stable) Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 250 | ns |
| $\mathrm{T}_{\text {AH }}$ | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Stable) Hold from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ | $\mathrm{T}_{\text {ASM }}-50$ |  | ns |
| $\mathrm{T}_{\text {AHR }}$ | Adr(AB)(Valid) Hold from $\overline{\mathrm{Rd} \uparrow}(\mathrm{S} 1, \mathrm{SI})^{[4]}$ | 60 |  | ns |
| $\mathrm{T}_{\text {AHW }}$ | Adr(AB)(Valid) Hold from $\overline{\mathrm{Wr}} \uparrow(\mathrm{S} 1, \mathrm{SI})^{[4]}$ | 300 |  | ns |
| $\mathrm{T}_{\text {FADB }}$ | Adr(DB)(Active) Delay from $\theta^{\uparrow}(\mathrm{S} 1)^{[2]}$ |  | 300 | ns |
| $\mathrm{T}_{\text {AFDB }}$ | Adr(DB)(Float) Delay from $\theta \uparrow(\mathrm{S} 2)^{[2]}$ | $\mathrm{T}_{\text {STT }}+20$ | 250 | ns |
| $\mathrm{T}_{\text {ASS }}$ | Adr(DB) Setup to AdrStbl(S1-S2) ${ }^{[4]}$ | 100 |  | ns |
| $\mathrm{T}_{\text {AHS }}$ | Adr(DB)(Valid) Hold from AdrStbl(S2) ${ }^{[4]}$ | 50 |  | ns |
| $\mathrm{T}_{\text {STL }}$ | AdrStb $\uparrow$ Delay from $\theta \uparrow(\mathrm{S} 1)^{[1]}$ |  | 200 | ns |
| $\mathrm{T}_{\text {STT }}$ | AdrStb $\downarrow$ Delay from $\theta \uparrow(\mathrm{S} 2)^{[1]}$ |  | 160 | ns |
| $\mathrm{T}_{\text {SW }}$ | AdrStb Width (S1-S2) ${ }^{[4]}$ | $\mathrm{T}_{\mathrm{CY}}-100$ |  | ns |
| $\mathrm{T}_{\text {ASC }}$ | $\overline{\mathrm{Rd}} \downarrow$ or $\overline{\mathrm{Wr}}\left(\right.$ Ext) $\downarrow$ Delay from AdrStb $\downarrow$ (S2) ${ }^{[4]}$ | 70 |  | ns |
| $\mathrm{T}_{\text {DBC }}$ | $\overline{\mathrm{Rd}} \downarrow$ or $\overline{\mathrm{Wr}}(\mathrm{Ext}) \downarrow$ Delay from $\operatorname{Adr}(\mathrm{DB})$ (Float)(S2) ${ }^{[4]}$ | 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(S 4)^{[1,5]}$ |  | 270 | ns |
| $\mathrm{T}_{\mathrm{DCL}}$ | $\overline{\mathrm{Rd}} \downarrow$ or $\overline{\mathrm{Wr}}(E x t) \downarrow$ Delay from $\theta \uparrow(\mathrm{S} 2)$ and $\overline{W r} \downarrow$ Delay from $\theta^{\uparrow}(\mathrm{S} 3)^{[2,6]}$ |  | 250 | ns |
| $\mathrm{T}_{\mathrm{DCT}}$ | $\overline{\mathrm{Rd}} \uparrow$ Delay from $\theta \downarrow(\mathrm{S} 1, \mathrm{SI})$ and $\overline{W r \uparrow}$ Delay from $\theta \uparrow(S 4)^{[2,7]}$ |  | 200 | ns |
| $\mathrm{T}_{\text {FAC }}$ | $\overline{\mathrm{Rd}}$ or $\overline{\mathrm{Wr}}$ (Active) from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 300 | ns |
| $\mathrm{T}_{\text {AFC }}$ | $\overline{\mathrm{Rd}}$ or $\overline{\mathrm{Wr}}$ (Float) from $\theta \uparrow(\mathrm{SI})^{[2]}$ |  | 170 | ns |
| $\mathrm{T}_{\text {RWM }}$ | $\overline{\mathrm{Rd}}$ Width (S2-S1 or SI) ${ }^{[4]}$ | $2 \mathrm{~T}_{\mathrm{CY}}+\mathrm{T}_{\theta}-50$ |  | ns |
| TWWM |  | $\mathrm{T}_{\mathrm{CY}}-50$ |  | ns |
| TWWME | $\overline{\mathrm{Wr}}$ (Ext) Width (S2-S4) ${ }^{[4]}$ | $2 \mathrm{~T}_{C Y}-50$ |  | ns |

Notes: 1. $L$ oad $=1 \mathrm{TTL}$. 2. $\mathrm{Load}=1 \mathrm{TTL}+50 \mathrm{pF}$. 3. $\mathrm{Load}=1 \mathrm{TTL}+\left(R_{L}=3.3 \mathrm{~K}\right), \mathrm{V}_{\mathrm{OH}}=3.3 \mathrm{~V}$. 4. Tracking Parameter.
5. $\Delta T_{A K}<50 \mathrm{~ns}$. 6. $\Delta \mathrm{T}_{\mathrm{DCL}}<50 \mathrm{~ns}$. 7. $\Delta \mathrm{T}_{\mathrm{DCT}}<50 \mathrm{~ns}$.

## DMA MODE WAVEFORMS

CONSECUTIVE CYCLES AND BURST MODE SEQUENCE


Figure 12. Consecutive Cycles and Burst Mode Sequence


Figure 13. Control Override Sequence


Figure 14. Not Ready Sequence

## M8259 <br> PROGRAMMABLE INTERRUPT CONTROLLER

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

## Eight Level Priority Controller

Expandable to 64 Levels

- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single + 5V Supply (No Clocks)


## 28-Pin Dual-In-Line Package

- Fully Compatible with Intel CPUs

The M8259 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 M8259 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



DIN NAMES

| $D_{7}-D_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| $\overline{R D}$ | READ INPUT |
| $\overline{W R}$ | WRITE INPUT |
| $A_{0}$ | COMMAND SELECT ADDRESS |
| $\overline{C S}$ | CHIP SELECT |
| CAS1-CASO | CASCADE LINES |
| $\overline{S P}$ | SLAVE PROGRAM INPUT |
| INT | INTERRUPT OUTPUT |
| $\overline{\text { INTA }}$ | INTERRUPT ACKNOWLEDGE INPUT |
| IRO-IRT | INTERRUPT REQUEST INPUTS |

BLOCK DIAGRAM



## WAVEFORMS

## READ TIMING



WRITE TIMING


## OTHER TIMING



NOTE: INTERR!JPT REQUEST MUST REMAIN "HIGH" (AT LEAST) UNTIL LEADING EDGE OF FIRST INTA.
A.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}$

BUS PARAMETERS
Read

| Symbol | Parameter | Min. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{AR}}$ | $\overline{\mathrm{CS}} / \mathrm{A}_{0}$ Stable Before $\overline{\mathrm{RD}}$ or $\overline{\mathrm{NTA}}$ | 50 |  | ns |
| $\mathrm{t}_{\mathrm{RA}}$ | $\overline{\mathrm{CS}} / \mathrm{A}_{0}$ Stable After $\overline{\mathrm{RD}}$ or $\overline{\mathrm{INTA}}$ | 5 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\mathrm{RD}}$ Pulse Width | 420 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Valid From $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}[1]$ |  | 360 | ns |
| $\mathrm{t}_{\mathrm{DF}}$ | Data Float After $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}$ | 20 | 200 | ns |

Write

| Symbol | Parameter | Min. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| $t_{A W}$ | $A_{0}$ Stable Before $\overline{W R}$ | 50 |  | ns |
| $t_{W A}$ | $A_{0}$ Stable After $\overline{W R}$ | 20 |  | ns |
| $t_{W W}$ | $\overline{W R}$ Pulse Width | 420 |  | ns |
| $t_{D W}$ | Data Valid to $\overline{W R}(T . E)$. | 300 | ns |  |
| $t_{W D}$ | Data Valid After $\overline{W R}$ | 40 |  | ns |

Other Timings

| Symbol | Parameter | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{IW}}$ | Width of Interrupt Request Pulse | 100 |  | ns |
| $\mathrm{t}_{\mathrm{INT}}$ | INT $\uparrow$ After IR $\uparrow$ | 400 |  | ns |
| $\mathrm{t}_{\mathrm{IC}}$ | Cascade Line Stable After INTA $\uparrow$ | 400 |  | ns |

Note 1: $C_{L}=100 \mathrm{pF}$.

## INPUT WAVEFORMS FOR A.C. TESTS



## 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 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 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 $T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | $-0.5$ | 0.8 | V |  |
| $\mathrm{V}_{\text {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{V}_{\text {OH-INT }}$ | Interrupt Output High Voltage | $\begin{aligned} & 2.4 \\ & 3.5 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{LL}\left(1 \mathrm{R}_{0-7}\right)}$ | Input Leakage Current for $\mathrm{IR}_{0-7}$ |  | $\begin{gathered} -300 \\ 10 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| IIL | Input Leakage Current for Other Inputs |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\text {OFL }}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}$ to $\mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{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}_{I \mathrm{~N}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{I / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $\mathrm{V}_{\mathrm{SS}}$ |

Read Status/Poll Mode


# *8048 Mask Programmable ROM <br> *8748 User Programmable/Erasable EPROM *8035 External ROM or EPROM 

$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Operation (M8048/M8035L)

- $-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ Operation (M8748/M8035)
- 8-Bit CPU, ROM, RAM, I/O in Single Package
- Interchangeable ROM and EPROM Versions
- Single 5V Supply
- $2.5 \mu \mathrm{sec}$ and $5.0 \mu \mathrm{sec}$ Cycle Versions All Instructions 1 or 2 Cycles.

■ Over 90 Instructions: 70\% Single Byte

- 1K x 8 ROM/EPROM
$64 \times 8$ RAM
27 I/O Lines
- Interval Timer/Event Counter
- Easily Expandable Memory and I/O
- Compatible with $8080 / 8085$ Series Peripherals
- Single Level Interrupt

The Intel® M8048/M8748/M8035/M8035L is a totally self-sufficient 8-bit parallel computer fabricated on a single silicon chip using Intel's N -channel silicon gate MOS process.
The M8048 contains a $1 \mathrm{~K} \times 8$ program memory, a $64 \times 8$ RAM data memory, 27 I/O lines, and an 8-bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability, the M8048 can be expanded using standard memories and MCS-80 ${ }^{\text {TM }} / \mathrm{MCS}-85^{\text {TM }}$ peripherals. The M8035 is the equivalent of an M8048 without program memory. The M8035L has the RAM power down mode of the M8048 while the M8035 does not. To reduce development problems to a minimum and provide maximum flexibility, three interchangeable pin-compatible* versions of this single component microcomputer exist: the M8748 with user-programmable and erasable EPROM program memory for prototype and preproduction systems, the M8048 with factory-programmed mask ROM program memory for low cost, high volume production, and the M8035 without program memory for use with external program memories.
This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The M8048 has extensive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of programı memory results from an instruction set consisting mostly of single byte instructions and no instructions over 2 bytes in length.

PIN CONFIGURATION


LOGIC SYMBOL


BLOCK DIAGRAM


## CRYSTAL OSCILLATOR MODE



CRYSTAL SERIES RESISTANCE SHOULD BE $<75 \Omega$ AT $6 \mathrm{MHz},<180 \Omega$ AT 3.6 MHz

DRIVING FROM EXTERNAL SOUBCE


BOTH X1 AND X2 SHOULD BE DRIVEN.
RESISTORS TO VCC APE NEEDED TO ENSURE $V_{I H}=3.8 \mathrm{~V}$ IF TTL. CIRCUITRY IS USED. THE MINIMUM HIGH AND THE MINIMUM LOW TIMES ARE 45\%.

## LC OSCILLATOR MODE



EACH C SHOULD BE APPROXIMATELY 20 pF, INCLUDING STRAY CAPACITANCE

## PROGRAMMING, VERIFYING, AND ERASING THE 8748 EPROM

## Programming Verification

In brief, the programming process consists of: activating the program mode, applying an address, latching the address, applying data, and applying a programming pulse. Each word is programmed completely before moving on to the next and is followed by a verification step. The follow-
 tion of their functions:

| Pin | Function |
| :--- | :--- |
| XTAL 1 | Clock Input (1 to 6MHz) |
| $\overline{\text { Reset }}$ | Initialization and Address Latching |
| Test 0 | Selection of Program or Verify Mode |
| EA | Activation of Program/Verify Modes |
| BUS | Address and Data Input |
|  | Data Output During Verify |
| P20-1 | Address Input |
| VDD | Programming Power Supply |
| PROG | Program Pulse Input |

WARNING:
An attempt to program a missocketed 8748 will result in severe damage to the part. An indication of a properly socketed part is the appearance of the ALE clock output. The lack of this clock may be used to disable the programmer.

The Program/Verify sequence is:

1. $\quad V_{D D}=5 \mathrm{v}$, Clock applied or internal oscillator operating, RESET $=0 \mathrm{v}$, TEST $0=5 \mathrm{v}, \mathrm{EA}=5 \mathrm{v}$, BUS and PROG floating.
2. Insert 8748 in programming socket
3. ItSI U=UV (select program moae)
4. $E A=23 V$ (activate program mode)
5. Address applied to BUS and P20-1
6. $\overline{\mathrm{RESET}}=5 \mathrm{v}$ (latch address)
7. Data applied to BUS
8. $V_{D D}=25 v$ (programming power)
9. $\mathrm{PROG}=0 \mathrm{v}$ followed by one 50 ms pulse to 23 V
10. $V_{D D}=5 v$
11. TEST $0=5 v$ (verify mode)
12. Read and verify data on BUS
13. TEST $0=0 v$
14. $\overline{\operatorname{RESET}}=0 \mathrm{v}$ and repeat from step 5
15. Programmer should be at conditions of step 1 when 8748 is removed from socket.

## AC TIMING SPECIFICATION FOR PROGRAMMING

$T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, V_{D D}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| taw | Address Setup Time to $\overline{\text { RESET }} 1$ | 4tcy |  |  |  |
| twa | Address Hold Time After RESET 1 | 4tcy |  |  |  |
| tow | Data in Setup Time to PROG 1 | 4tcy |  |  |  |
| two | Data in Hold Time After PROG ! | 4tcy |  |  |  |
| tPH | RESET Hold Time to Verify | 4tcy |  |  |  |
| tvodw | VDD | 4tcy |  |  |  |
| tVODH | Vod Hold Time After PROG ! | 0 |  |  |  |
| tpw | Program Pulse Width | 50 | 60 | mS |  |
| tTw | Test 0 Setup Time for Program Mode | 4tcy |  |  |  |
| twT | Test 0 Hold Time After Program Mode | 4 tcy |  |  |  |
| too | Test 0 to Data Out Delay |  | 4tcy |  |  |
| tww | $\overline{\text { RESET }}$ Pulse Width to Latch Address | 4 tcy |  |  |  |
| $t_{r}, \mathrm{tf}_{\text {f }}$ | VDD and PROG Rise and Fall Times | 0.5 | 2.0 | $\mu \mathrm{S}$ |  |
| tcr | CPU Operation Cycle Time | 5.0 |  | $\mu \mathrm{S}$ |  |
| tre | $\overline{R E S E T}$ Setup Time Before EA 4. | 4tcy |  |  |  |

Note: If Test 0 is high too can be triggered by $\overline{\operatorname{RESET}} \uparrow \mathrm{f}$.

DC SPECIFICATION FOR PROGRAMMING
$T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{VCC}=5 \mathrm{~V} \pm 5 \%, \mathrm{VDD}=25 \mathrm{~V} \pm 1 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VDOH | VDD Program Voltage High Level | 24.0 | 26.0 | V |  |
| VDDL | VDD Voltage Low Level | 4.75 | 5.25 | V |  |
| VPH | PROG Program Voltage High Level | 21.5 | 24.5 | V |  |
| $V_{\text {PL }}$ | PROG Voltage Low Level |  | 0.2 | V |  |
| VEAH | EA Program or Verify Voltage High Level | 21.5 | 24.5 | V | 8748 |
| $\mathrm{V}_{\text {EAH } 1}$ | EA1 Verify Voltage High Level | 11.4 | 12.6 | V | 8048 |
| VEAL | EA Voltage Low Level |  | 5.25 | V |  |
| IDD | VDD High Voltage Supply Current |  | 30.0 | mA |  |
| Iprog | PROG High Voltage Supply Current |  | 16.0 | mA |  |
| IEA | EA High Voltage Supply Current |  | 1.0 | mA |  |

## WAVEFORMS FOR PROGRAMMING

COMBINATION PROGRAM/VERIFY MODE (EPROM'S ONLY)


## VERIFY MODE (ROM/EPROM)



## NOTES:

1. PROG MUST FLOAT IF EA IS LOW (i.e., $\neq 23 \mathrm{~V}$ ), OR IF TO $=5 \mathrm{~V}$ FOR THE 8748. FOR THE

8048 PROG MUST ALWAYS FLOAT.
2. $X_{1}$ AND $X_{2}$ DRIVEN BY 3 MHz CLOCK WILL GIVE $5 \mu \mathrm{sec} \mathrm{t}_{\mathrm{C} Y}$. THIS IS ACCEPTABLE FOR ALL PARTS.

The 8748 EPROM can be programmed by either of two Intel products:

1. PROMPT-48 Microcomputer Design Aid, or
2. Universal PROM Programmer (UPP Series)
peripheral of the Intellec ${ }^{( }$Development System with a UPP-848 Personality Card.

## INSTRUCTION SET

|  | Mnemonic | Description | Bytes | Cycle |
| :---: | :---: | :---: | :---: | :---: |
|  | ADD A, R | Add register to A | 1 | 1 |
|  | ADD A, @R | Add data memory to A | 1 | 1 |
|  | ADD A, \#data | Add immediate to A | 2 | 2 |
|  | ADDC A, R | Add register with carry | 1 | 1 |
|  | ADDC A, @R | Add data memory with carry | 1 | 1 |
|  | ADDC A, \#data | Add immediate with carry | 2 | 2 |
|  | ANL A, R | And register to $A$ | 1 | 1 |
|  | ANL A, @R | And data memory to $A$ | 1 | 1 |
|  | ANL A, \#data | And immediate to $A$ | 2 | 2 |
|  | ORL A, R | Or register to A | 1 | 1 |
|  | ORL A, @R | Or data memory to $A$ | 1 | 1 |
|  | ORL A. \#data | Or immediate to $A$ | 2 | 2 |
|  | XRL A, R | Exclusive or register to $A$ | 1 | 1 |
|  | XRL A, @R | Exclusive or data memory to $A$ | 1 | 1 |
|  | XRL A. \#data | Exclusive or immediate to $A$ | 2 | 2 |
|  | INC A | Increment A | 1 | 1 |
|  | DEC A | Decrement A | 1 | 1 |
|  | CLR A | Clear A | 1 | 1 |
|  | CPL A | Complement A | 1 | 1 |
|  | DA A | Decimal adjust $A$ | 1 | 1 |
|  | SWAP A | Swap nibbles of $A$ | 1 | 1 |
|  | RL A | Rotate A left | 1 | 1 |
|  | RLC A | Rotate A left through carry | 1 | 1 |
|  | RR A | Rotate A right | 1 | 1 |
|  | RRC A | Rotate A right through carry | 1 | 1 |
| $\begin{aligned} & \overline{3} \\ & \frac{a}{3} \\ & 0 \\ & \vdots \\ & \vec{Z} \\ & \underline{ } \end{aligned}$ | IN A, P | Input port to A | 1 | 2 |
|  | OUTL P, A | Output A to port | 1 | 2 |
|  | ANL. P. \#data | And immediate to port | 2 | 2 |
|  | ORL P. \#data | Or immediate to port | 2 | 2 |
|  | INS A, BUS | Input BUS to A | 1 | 2 |
|  | OUTL BUS, A | Output A to BUS | 1 | 2 |
|  | ANL BUS, \#data | And immediate to BUS | 2 | 2 |
|  | ORL BUS, \#data | Or immediate to BUS | 2 | 2 |
|  | MOVD A, P | Input expander port to $A$ | 1 | 2 |
|  | MOVD P, A | Output A to expander port | 1 | 2 |
|  | ANLD P, A | And $A$ to expander port | 1 | 2 |
|  | ORLD P, A | Or A to expander port | 1 | 2 |
|  | INC R | Increment register | 1 | 1 |
|  | INC@R | Increment data memory | 1 | 1 |
|  | DEC R | Decrement register | 1 | 1 |
|  | JMP addr | Jump unconditional | 2 | 2 |
|  | JMPP@A | Jump indirect | 1 | 2 |
|  | DJNZ R, addr | Decrement register and skip | 2 | 2 |
|  | JC addr | Jump on carry $=1$ | 2 | 2 |
|  | JNC addr | Jump on carry $=0$ | 2 | 2 |
|  | JZ addr | Jump on A zero | 2 | 2 |
|  | JNZ addr | Jump on A not zero | 2 | 2 |
|  | JTO addr | Jump on TO $=1$ | 2 | 2 |
|  | JNT0 addr | Jump on T0 $=0$ | 2 | 2 |
|  | JT1 addr | Jump on $\mathrm{T} 1=1$ | 2 | 2 |
|  | JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
|  | JFO addr | Jump on FO=1 | 2 | 2 |
|  | JF1 addr | Jump on F1 $=1$ | 2 | 2 |
|  | JTF addr | Jump on timer flag | 2 | 2 |
|  | JNI addr | Jump on $\overline{\mathbb{N T}}=0$ | 2 | 2 |
|  | JBb addr | Jump on accumulator bit | 2 | 2 |


|  | Mnemonic | Description | Bytes Cycles |  |
| :---: | :---: | :---: | :---: | :---: |
| 릋흘号 |  |  |  |  |
|  | CALL | Jump to subroutine | 2 | 2 |
|  | RET | Return | 1 | 2 |
|  | RETR | Return and restore status | 1 | 2 |
| $\begin{aligned} & \text { © } \\ & \text { © } \\ & \hline \mathbf{\pi} \end{aligned}$ | CLR C | Clear carry | 1 | 1 |
|  | CPL C | Complement carry | 1 | 1 |
|  | CLR FO | Clear flag 0 | 1 | 1 |
|  | CPL F0 | Complement flag 0 | 1 | 1 |
|  | CLR F1 | Clear flag 1 | 1 | 1 |
|  | CPL F1 | Complement flag 1 | 1 | 1 |
|  | MOV A, R | Move register to $A$ | 1 | 1 |
|  | MOV A, @R | Move data memory to a | 1 | 1 |
|  | MOV A, \#data | Move immediate to $A$ | 2 | 2 |
|  | MOV R, A | Move A to register | 1 | 1 |
|  | MOV @R, A | Move A to data memory | 1 | 1 |
|  | MOV R, \#data | Move immediate to register | 2 | 2 |
|  | MOV @R, \#data | Move immediate to data memory | 2 | 2 |
|  | MOV A, PSW | Move PSW to A | 1 | 1 |
|  | MOV PSW, A | Move A to PSW | 1 | 1 |
|  | XCH A, R | Exchange $A$ and register | 1 | 1 |
|  | XCHA, @R | Exchange $A$ and data memory | 1 | 1 |
|  | XCHD A, @R | Exchange nibble of $A$ and register | 1 | 1 |
|  | MOVX A, @R | Move external data memory to $A$ | 1 | 2 |
|  | MOVX@R, A | Move A to external data memory | 1 | 2 |
|  | MOVP A, @A | Move to A from current page | 1 | 2 |
|  | MOVP3 A, @A | Move to $A$ from page 3 | 1 | 2 |
|  | MOV A, T | Read timer/counter | 1 | 1 |
|  | MOV T, A | Load timer/counter | 1 | 1 |
|  | STRT T | Start timer | 1 | 1 |
|  | STRT CNT | Start counter | 1 | 1 |
|  | STOP TCNT | Stop timer/counter | 1 | 1 |
|  | EN TCNTI | Enable timer/counter interrupt | 1 | 1 |
|  | DIS TCNTI | Disable timer/counter interrupt | 1 | 1 |
|  | EN I | Enable external interrupt | 1 | 1 |
|  | DIS I | Disable external interrupt | 1 | 1 |
|  | SEL RBO | Select register bank 0 | 1 | 1 |
|  | SEL RB1 | Select register bank 1 | 1 | 1 |
|  | SEL MB0 | Select memory bank 0 | 1 | 1 |
|  | SEL MB1 | Select memory bank 1 | 1 | 1 |
|  | ENTO CLK | Enable clock output on T0 | 1 | 1 |
|  | NOP | No operation | 1 | 1 |

PIN DESCRIPTION

| Designation | Pin \# | Function |
| :---: | :---: | :---: |
| Vss | 20 | Circuit GND potential |
| VDD | 26 | Programming power supply; +25V during program, +5 V during operation for both ROM and PROM. Low power standby pin in 8048 and 8035L. |
| Vcc | 40 | Main power supply; +5 V during operation and programming. |
| PROG | 25 | Program pulse ( +23 V ) input pin during 8748 programming. <br> Output strobe for 8243 I/O expander. |
| P10-P17 <br> Port 1 P20-P27 | 27-34 21-24 | 8-bit quasi-bidirectional port. <br> 8-bit quasi-bidirectional port. |
| Port 2 | 35-38 | P20-P23 contain the four high order program counter bits during an external program memory fetch and serve as a 4-bit 1/O expander bus for 8243. |
| $\begin{aligned} & \mathrm{DB}_{0}-\mathrm{DB}_{7} \\ & \text { BUS } \end{aligned}$ | 12-19 | True bidirectional port which can be written or read synchronously using the $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ strobes. The port can also be statically latched. <br> Contains the 8 low order program counter bits during an external program memory fetch, and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM data store instruction, under control of ALE, $\overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$. |
| T0 | 1 | Input pin testable using the conditional transfer instructions JTO and JNTO. TO can be designated as a clock output using ENTO CLK instruction. TO is also used during programming. |
| T1 | 39 | Input pin testable using the JT1, designated the timer/counter input using the STRT CNT instruction. |


| Designation | Pin\# | Function |
| :---: | :---: | :---: |
| $\overline{\overline{\text { INT }}}$ | 6 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. Also testable with conditional jump instruction. (Active low) |
| $\overline{\mathrm{RD}}$ | 8 | Output strobe activated during a BUS read. Can be used to enable data onto the bus from an external device. |
|  |  | Used as a read strobe to external data memory. (Active low) |
| RESET | 4 | Input which is used to initialize the processor. Also used during PROM programming verification, and power down. (Active low) (Non TTL VIH) |
| $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) |
|  |  | Used as write strobe to external data memory. |
| ALE | 11 | Address latch enable. This signal occurs once during each cycle and is useful as a clock output. |
|  |  | The negative edge of ALE strobes address into external data and program memory. |
| $\overline{\text { PSEN }}$ | 9 | Program store enable. This output occurs only during a fetch to external program memory. (Active low) |
| $\overline{\text { SS }}$ | 5 | Single step input can be used in junction with ALE to "single step" the processor through each instruction. (Active low) |
| EA | 7 | External access input which forces all program memory fetches to reference external memory. Useful for emulation and debug, and essential for testing and program verification. (Active high) |
| XTAL1 | 2 | One side of crystal input for internal oscillator. Also input tor external source. (Non TTL VIH) |
| XTAL2 | 3 | Other side of crystal input. |

## A.C. CHARACTERISTICS (PORT 2 TIMING)

$T_{A}=-55^{\circ} \mathrm{C}$ to $\left(100^{\circ} \mathrm{C} 8748 / 8035 / 125^{\circ} \mathrm{C} 8048 / 8035 \mathrm{~L}\right), \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| tCP | Port Control Setup Before Falling <br> Edge of PROG | 115 |  | ns |  |
| tPC | Port Control Hold After Falling <br> Edge of $\overline{\text { PROG }}$ | 65 |  | ns |  |
| tPR | PROG to Time P2 Input Must Be Valid |  | 860 | ns |  |
| tPF | Input Data Hold Time | 0 | 160 | ns |  |
| tDP | Output Data Setup Time | 230 |  | ns |  |
| tPD | Output Data Hold Time | 25 |  | ns |  |
| tPP | $\overline{\text { PROG Pulse Width }}$ | 920 |  | ns |  |
| tPL | Port 2 I/O Data Setup | 300 |  | ns |  |
| tLP | Port 2 I/O Data Hold | 120 |  | ns |  |

PORT 2 TIMING


## ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature Under Bias |  |
| :---: | :---: |
| 8748/8035 | $-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ |
| 8048/8035L | $-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 Ground | $-0.5 \text { to +7V }$ |
| ower Dissipatio | 1.5 Wat |

*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.AND OPERATING CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $\left(100^{\circ} \mathrm{C} 8748 / 8035 / 125^{\circ} \mathrm{C} 8048 / 8035 \mathrm{~L}\right), \mathrm{V}_{C C}=\mathrm{V}_{D D}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage <br> (All Except RESET, X1, X2) | -. 5 |  | . 7 | V |  |
| $\mathrm{V}_{\text {IL } 1}$ | Input Low Voltage (RESET, X1, X2) | -. 5 |  | . 5 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage <br> (All Except XTAL1, XTAL 2, $\overline{\text { RESET }}$ ) | 2.3 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{H} 1}$ | Input High Voltage ( $\overline{\mathrm{RESET}}, \mathrm{X} 1, \mathrm{X} 2)$ | 3.8 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage <br> (BUS, $\overline{R D}, \overline{W R}, \overline{\text { PSEN }}, \mathrm{ALE})$ |  |  | . 45 | V | $\mathrm{IOL}=1.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage (All Other Outputs) |  |  | . 45 | V | $\mathrm{IOL}=0.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-240 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | $\mathrm{IOH}=-50 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | $\mathrm{IOH}=-30 \mu \mathrm{~A}$ |
| $I_{L I}$ | Input Leakage Current (T1, $\overline{\mathrm{NT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\text {LI } 1}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{\mathrm{SS}}$ ) |  |  | -700 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| $I_{\text {LO }}$ | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}$ Supply Current |  | 10 | 25 | mA |  |
| $\mathrm{I}_{\mathrm{DD}}+\mathrm{I}_{\mathrm{CC}}$ | Total Supply Current |  | 80 | 155 | mA |  |

BUS
P1, P2



VoL

## WAVEFORMS

Instruction Fetch From External Program Memory


Write to External Data Memory


Read From External Data Memory


Input and Output Waveforms for A.C. Tests


## A.C. CHARACTERISTICS

$T_{A}=-55^{\circ} \mathrm{C}$ to $\left(100^{\circ} \mathrm{C} 8748 / 8035 / 125^{\circ} \mathrm{C} 8048 / 8035 \mathrm{~L}\right), \mathrm{V}_{C C}=\mathrm{V}_{D D}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$

| Symbol | Parameter | $\begin{gathered} 8048 \\ 8648 \text { (Note 2) } \\ 8748 / 8035 / 8035 \mathrm{~L} \end{gathered}$ |  | $\begin{aligned} & 8748 \\ & 8035 \end{aligned}$ |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\text {LL }}$ | ALE Pulse Width | 200 |  | 300 |  | ns |  |
| $\mathrm{t}_{\text {AL }}$ | Address Setup to ALE | 120 |  | 120 |  | ns |  |
| $t_{\text {LA }}$ | Address Hold from ALE | 80 |  | 80 |  | ns |  |
| ${ }^{\text {t }}$ C | Control Pulse Width ( $\overline{\text { PSEN }}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 400 |  | 600 |  | ns |  |
| ${ }^{\text {d }}$ W | Data Setup before $\overline{W R}$ | 420 |  | 600 |  | ns |  |
| twd | Data Hold After $\overline{W R}$ | 80 |  | 120 |  | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ |
| ${ }^{\text {t }} \mathrm{CY}$ | Cycle Time | 2.5 | 15.0 | 4.17 | 15.0 | $\mu \mathrm{s}$ | $\begin{aligned} & \text { (3.6 MHz } \\ & \text { XTAL 8748/8035) } \end{aligned}$ |
| $\mathrm{t}_{\mathrm{DR}}$ | Data Hold | 0 | 200 | 0 | 200 | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | $\overline{\text { PSEN, }}, \overline{\mathrm{RD}}$ to Data In |  | 400 |  | 600 | ns |  |
| $\mathrm{t}_{\text {AW }}$ | Address Setup to $\overline{W R}$ | 230 |  | 260 |  | ns |  |
| $t_{\text {AD }}$ | Address Setup to Data In |  | 600 |  | 900 | ns |  |
| ${ }^{\text {t }}$ AFC | Address Float to $\overline{\mathrm{RD}}, \overline{\text { PSEN }}$ | -40 |  | -60 |  | ns |  |
| $t_{\text {CA }}$ | Control Pulse to ALE | 10 |  | 10 |  | ns |  |

[^36]
## intel

INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, CA 95051 • (408) 987-8080


[^0]:    *For specifications contact Intel Literature Department, 3065 Bowers Avenue, Santa Clara, California 95051.

[^1]:    *Field application location
    These representatives do not offer Intel Components, only boards and systems.

[^2]:    *All 8101A-4 specs are identical to the 2101A-4 specs.

[^3]:    NOTES:

    1. TYPICAL TRANSFER FUNCTION OF THE RECEIVE FILTER AS A SEPARATE COMPONENT.
    2. TYPICAL TRANSFER FUNCTION OF THE RECEIVE FILTER DRIVEN BY THE SAMPLE AND HOLD OUTPUT OF THE INTEL 2910 AND 2911 CODECS. THE COMBINED FILTER/CODEC
[^4]:    *See July, 1978 MCS-48 User's Manual for opcodes.

[^5]:    Note 1: Control outputs: $C_{L}=80 \mathrm{pF}$ BUS Outputs: $\quad C_{L}=150 \mathrm{pF}$
    ${ }^{\mathrm{t}} \mathrm{CY}=2.5 \mu \mathrm{~s}$ for standard parts
    $=4.17 \mu \mathrm{~s}$ for -8 parts
    ${ }^{*} V_{C C}$ and $V_{D D}$ for $8748-8$ and 8035.8 are $\pm 5 \%$.

[^6]:    *For maximum performance use 8155-2/8156-2, 8185-2, and 8355-2 with the high performance 8085A-2 CPU.

[^7]:    ${ }^{[1]}{ }_{\mathrm{t}_{1}}$ MIN $\geq{ }^{\mathrm{t}_{\text {SO }}}$
    ${ }^{121}$ If the INTERRUPT is not used, all states have the same output delay, ${ }^{\text {t }}$, 1 .

[^8]:    $V_{S S} \quad$ Ground Reference.
    $V_{D D}+12 \pm 5 \%$ Volts.
    VCC $\quad+5 \pm 5 \%$ Volts.
    $V_{B B} \quad-5 \pm 5 \%$ Volts (substrate bias).
    $\phi_{1}, \phi_{2} \quad 2$ externally supplied clock phases. (non TTL compatible)

[^9]:    *For 109.1 ( $64 x$ ) Baud rate divide 1200 Baud Frequency ( 76.8 KH ) by 11.

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

[^11]:    *: $8155 / 8155-2=\overline{C E}, 8156 / 8156-2=C E$

[^12]:    * $A_{0}-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: TCSTOP, EW: EXTENDED WRITE, RP: ROTATING PRIORITY, EN3-ENO: CHANNELENABLE MASK, UP: UPDATE FLAG, TC3-TCO: TERMINAL COUNT STATUS BITS.

[^13]:    - Note: Master/Slave in ICW4 is only used in the buffered mode.

[^14]:    (1) Wcs enses syoueme onty

[^15]:    NOTES: 1. ALL SIGNALS SWITCH BETWEEN $V_{O H}$ AND $V_{\text {OI }}$ UNLESS OTHERWISE SPECIFIED
    2. RDY IS SAMPLED NEAR THE END OF T T TW TO DETERMINE IE IF TW MACHINES STATES ARE TO BE INSERTED
    3. FOLLOWING A WRITE CYCLE THE LOCAL BUS IS FLOATED BY THE 8086 ONLY WHEN THE 8086 ENTERS A "HOLD ACKNOWLEDGE" STATE
    3. TWO INTA CYCLES RUN BACK-TO-BACK. THE 8088 LOCAL ADDRIDATA BUS IS FLOATING DURING THE SECOND INTA CYCLE

    SIGNALS AT 8284 ARE SHOWN FOR REFERENCE ONLY
    6. ALL TIMING MEASUREMENTS ARE MADE AT 1.5 V UNLESS OTHERWISE NOTED.

[^16]:    *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.

[^17]:    Note: 1. B Outputs $-\mathrm{I}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF} \quad$ A Outputs $-\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

[^18]:    *If an 8085 clock output is to drive an $8253-5$ clock input, it must be reduced to 2 MHz or less.

[^19]:    Write Data

[^20]:    *Note the two ready bits are zero latching. Therefore, to clear the drive not ready condition, assuming the drive is ready, and to detect it via software, one must issue this command twice.

[^21]:    *Bits 0 and 1 are initialized to zero.

[^22]:    Pointer $=$ sector length $-\left((\text { Register } 14 \mathrm{H})^{*} 128+(\right.$ Register 13 H$\left.)\right)$

[^23]:    1. All timing measurements are made at the reference voltages unless otherwise specified: Input " 1 " at 2.0 V , " 0 " at 0.8 V

    Output " 1 " at 2.0V, " 0 " at 0.8 V
    2. $t_{A D}, t_{R D}, t_{A C}$, and $t_{C A}$ are not concurrent specs.
    3. Standard Floppy: $\mathrm{t}_{\mathrm{C}}=250 \mathrm{~ns} \pm 0.4 \% \quad$ Mini-Floppy: $\mathrm{t}_{\mathrm{C}}=500 \mathrm{~ns} \pm 0.4 \%$

[^24]:    *Character Attribute Code 1011 is not recommended for normal operation. Since none of the attribute outputs are active, the character Generator will not be disabled, and an indeterminate character will be generated.

[^25]:    *Default after reset.

[^26]:    *These messages are handled only by Intel's 8292.
    $\dagger$ Undefined commands which may be passed to the microprocessor.

[^27]:    1. Subsequently the 8291 will include "set rtl" and "clear rtl" commands.
[^28]:    *As defined in IEEE Standard 488.

[^29]:    QRL86 combines object modules and converts relative addresses to absolute addresses in a single step. The segment is the fundamental unit with which linkage and relocation functions work. First, segments are combined, then absolute addresses are assigned to segments. Addresses that are referenced relative to the beginning of a segment are translated to absolute memory address references.
    The modules to be combined are specified in a list in the QRL86 command. In general, QRL86 will link and locate any set of valid input modules without any controls. However, controls are available for you to modify the manner in which QRL86 links and locates and to control the output of information in the process.

[^30]:    The OH86 command converts an 8086 absolute object module to the hexadecimal format. This conversion may be necessary to format a module for later loading by a hexadecimal loader such as the iSBC $86 / 12$ monitor or Univeral Prom Mapper. The conversion may also be made to put the module in a more readable format that can be displayed or printed.

[^31]:    The module to be converted must be in absolute format; the output from the QRL86 and LOC86 is in absolute format.

[^32]:    ORDERING INFORMATION
    PRODUCT CODE DESCRIPTION
    MDS-301
    FORTRAN-80 Compiler for Intellec
    Microcomputer Development
    Systems

[^33]:    The Intellec ${ }^{\oplus}$ Flexible Disk System is a sophisticated, general purpose, bulk storage peripheral for use with the Intellec Microcomputer Development System. The use of a flexible disk operating system significantly reduces program development time. The software system known as ISIS-II (Intel System Implementation Supervisor), provides the ability to edit, assemble, compile, link, relocate, execute and debug programs, and performs all file management tasks for the user.

[^34]:    *EM1 emulator board is also required.

[^35]:    *Use 8048 with internal monitor program when emulating 8748/8048/ 8035/8021.

[^36]:    Note 1: Control outputs: $C_{\mathrm{L}}=80 \mathrm{pF} \quad \mathrm{t}_{\mathrm{CY}}=2.5 \mu \mathrm{~s}$ for $8048 / 8035 \mathrm{~L}$ BUS Outputs: $\quad C_{L}=150 \mathrm{pF} \quad 4.17 \mu$ s for $8748 / 8035$

