## Component Data Catalog



## intel

## COMPONENT DATA CATALOG

Intel Corporation makes no warranty for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

The following are trademarks of Intel Corporation and may only be used to identify Intel Products:
BXP, CREDIT, i, ICE, $\mathrm{iCS}, \mathrm{i}_{\mathrm{m}}$, iMMX, Insite, Intel, int ${ }_{\mathrm{e}} \mathrm{I}$, Intelevision, Intellec, iOSP, iRMX, iSBC, iSBX, Library Manager, MCS, Megachassis, Micromainframe, Micromap, Multimodule, Plug-A-Bubble, PROMPT, RMX/80, System 2000 and UPI.

MDS is an ordering code only and is not used as a product name or trademark. MDS ${ }^{\circledR}$ is a registered trademark of Mohawk Data Sciences Corporation.
*MULTIBUS is a patented Intel bus.
Additional copies of this manual or other Intel literature may be obtained from:
Intel Corporation
Literature Department SV3-3
3065 Bowers Avenue
Santa Clara, CA 95051

## Table of Contents

Alphanumeric Index ..... v
CHAPTER 1
Random Access Memory
2114A, $1024 \times 4$-Bit Static RAM ..... 1-1
2115A, 2125A Family, High Speed $1 \mathrm{~K} \times$ 1-Bit Static RAM ..... 1-5
2115H, 2125H Family, High Speed 1K x 1-Bit Static RAM ..... 1-10
2118 Family 16,384 x 1-Bit Dynamic RAM ..... 1-15
2128 2K x 8 Static RAM ..... 1-26
2141, $4096 \times 1$-Bit Static RAM ..... 1-30
2142, $1024 \times 4$-Bit Static RAM ..... 1-36
2147A, 1K x 4 Static RAM ..... 1-40
2147H High Speed $4096 \times 1$-Bit Static RAM ..... 1-44
$2148 \mathrm{H}, 1024 \times 4$-Bit Static RAM ..... 1-48
$2149 \mathrm{H}, 1024 \times 4$-Bit Static RAM ..... 1-52
2164 Family 65,536 x 1-Bit Dynamic RAM ..... 1-56
2164-25, 65,536 x 1-Bit Dynamic RAM ..... 1-64
2167 High Speed 16,384 x 1-Bit Static RAM ..... 1-72
2186/7, $8192 \times 8$-Bit Integrated RAM ..... 1-77
8148, $4096 \times 8$-Bit Integrated RAM ..... 1-76
CHAPTER 2
Read Only Memory and Memory Support
2716, 16K (2K x 8) UV Erasable PROM ..... 2-1
2732A, 32K (4K x 8) UV Erasable PROM ..... 2-9
2764, (8K x 8) UV Erasable PROM ..... 2-16
27128, (16K x 8) UV Erasable PROM ..... 2-22
2815, 16K (2K x 8) Electrically Erasable PROM ..... 2-23
2816, 16K ( $2 \mathrm{~K} \times 8$ ) Electrically Erasable PROM ..... 2-36
2817, 16K ( $2 \mathrm{~K} \times 8$ ) Electrically Erasable PROM ..... 2-49
3628A, 8 K (1K x 8) Bipolar PROM ..... 2-50
3632, 32K (4K x 8) Bipolar PROM ..... 2-53
3636B, 16K (2K x 8) Bipolar PROM ..... 2-56
82S181/82HS181, 8K (1K x 8) Bipolar PROM ..... 2-59
82S191/82HS191, 16K (2K x 8) Bipolar PROM ..... 2-62
82S321/82HS321, 32K (4K x 8) Bipolar PROM ..... 2-65
Bipolar PROM Programming ..... 2-68
Bipolar PROM Cross Reference ..... 2-71
CHAPTER 3
Magnetics
BPK70, 1 Mbit Bubble Storage Subsystem ..... 3-1
BPK72 Bubble Storage Prototype Kit ..... 3-3
7110, 1 Megabit Bubble Memory Family ..... 3-5
7220-1 Bubble Memory Controller ..... 3-11
7230 Current Pulse Generator for Bubble Memories ..... 3-26
7242 Dual Formatter/Sense Amplifier for Bubble Memories ..... 3-30
7250 Coil Pre-Driver for Bubble Memories ..... 3-40
7254 Quad VMOS Drive Transistors for Bubble Memories ..... 3-44
CHAPTER 4Telephony and Signal Processing
2910A PCM Codec- $\mu$ Law, 8-Bit Companded A/D and D/A Converter ..... 4-1
2911A PCM Codec-A Law, 8-Bit Companded A/D and D/A Converter ..... 4-16
2912A PCM Transmit/Receive Filter ..... 4-30
2913/2914 Combined Single Chip ..... 4-42
2921 ..... 4-60
CHAPTER 5
Automotive
P80A48H/P80A35HL HMOS Single Component 8-Bit Microcomputer ..... 5-1
P80A49H/P80A39HL HMOS Single Component 8-Bit Microcomputer ..... 5-17
P80A48L HMOS Single Component 8-Bit Microcomputer ..... 5-9
CHAPTER 6
MCS-48 ${ }^{\text {TM }}$ Microprocessors
8020H HMOS Single-Component 8-Bit Microcomputer ..... 6-1
8021 Single Component 8 -Bit Microcomputer ..... 6-7
8021H HMOS Single Component 8 -Bit Microcomputer ..... 6-8
8022 Single Component 8-Bit Microcomputer with On-Chip A/D Converter ..... 6-17
8022H High Performance Single Component 8-Bit Microcomputer with On-Chip A/D Converter ..... 6-23
8031/8051/8751 Single-Component 8-Bit Microcomputer ..... 6-24
8048H/8048H-1/8035HL/8035HL-1 HMOS Single Component 8-Bit Microcomputer ..... 6-39
80C48/80C35 CHMOS Single-Component 8-Bit Microcomputer ..... 6-46
8748H/8035H HMOS Single-Chip EPROM Microcomputer ..... 6-53
8049H/8049HL HMOS Single-Component 8-Bit Microprocessor ..... 6-62
80C49/80C39 CHMOS Single-Component 8-Bit Microcomputer ..... 6-69
8749H/8749H-8/8739H/8739H-B ..... 6-76
8243 MCS-48 Input/Output Expander ..... 6-85
8050H/8040H HMOS Single Component 8-Bit Microcomputer ..... 6-91
CHAPTER 7
MCS-80/85 ${ }^{\text {TM }}$ Microprocessors
8080A/8080A-1/8080A-2, 8-Bit N-Channel Microprocessor ..... 7-1
8085AH/8085AH-2 Single Chip 8-Bit HMOS Microprocessors ..... 7-10
8085A/8085A-2 Single Chip 8-Bit N-Channel Microprocessors ..... 7-26
$8155 \mathrm{H} / 8156 \mathrm{H} / 8155 \mathrm{H}-2 / 8156 \mathrm{H}-2,2048$ Bit Static HMOS RAM with I/O Ports and Timer ..... 7-30
8155/8156/8155-2/8156-2, 2048 Bit Static MOS RAM with I/O Ports and Timer ..... 7-42
8185/8185-2, $1024 \times 8$-Bit Static RAM for MCS-85 ..... 7-45
8205 High Speed 1 Out of 8 Binary Decoder ..... 7-50
8212 8-Bit Input/Output Port ..... 7-55
8216/8226, 4-Bit Parallel Bidirectional Bus Driver ..... 7-63
8218/8219 Bipolar Microcomputer Bus Controllers for MCS-80 and MCS-85 Families ..... 7-68
8224 Clock Generator and Driver for 8080A CPU ..... 7-79
8228/8238 System Controller and Bus Driver for 8080A CPU ..... 7-84
8237A/8237A-5 High Performance Programmable DMA Controller ..... 7-88
8257/8257-5 Programmable DMA Controller ..... 7-103
8259A/8259A-2/8259A-8 Programmable Interrupt Controller ..... 7-120
8355/8355-2, 16,384-Bit ROM with I/O ..... 7-138
8755A/8755A-2, 16,384-Bit EPROM with I/O ..... 7-146
CHAPTER 8
IAPX 86, 88 Microprocessors
iAPX 86/10 16-Bit HMOS Microprocessor ..... 8-1
iAPX 88/10 8-Bit HMOS Microprocessor ..... 8-25
8089 8/16-Bit HMOS I/O Processor ..... 8-52
iAPX 86/20, 88/20, 8-Bit HMOS Numeric Data Processor ..... 8-66
iAPX 86/30, iAPX 88/30 Operating System Processors ..... 8-86
8282/8283 Octal Latch ..... 8-108
8284A Clock Generator and Driver for iAPX 86/10, iAPX 88/10 8089 Processors ..... 8-113
8286/〔287 Octal Bus Transceiver ..... 8-121
8288 Bus Controller for iAPX 86/10, iAPX 88/10 8089 Processors ..... 8-126
8289 Bus Arbiter ..... 8-133
CHAPTER 9
Micropncessor Peripherals
Slave Processors
8041AH/8041AH-2/8641A/8741A Universal Peripheral Interface 8-Bit Microcomputer ..... 9-1
8042/8742 Universal Peripheral Interface 8-Bit Microcomputer ..... 9-14
8231^ Arithmetic Processing Unit ..... 9-27
8232 Floating Point Processing Unit ..... 9-37
8294 Data Encryption Unit ..... 9-49
8295 Dot Matrix Printer Controller ..... 9-60
Memory Controllers 8202A Dynamic RAM Controller ..... 9-69
820364K Dynamic RAM Controller ..... 9-83
8206 Error Detection and Correction Unit ..... 9-98
8271,8271-6 Programmable Floppy Disk Controller ..... 9-117
8272 Single/Double Density Floppy Disk Controller ..... 9-146
Data Communications
8251A Programmable Communications Interface ..... 9-165
8256 Multifunction Universal Asynchronous Receiver-Transmitter (MUART) ..... 9-182
8273, 8273-4, 8273-8 Programmable HDLC/SDLC Protocol Controller ..... 9-191
8274 Multi-Protocol Serial Controller ..... 9-216
8291A GPIB Talker/Listener ..... 9-251
8292 GPIB Controller ..... 9-280
8293 GPIB Transceiver ..... 9-295
Controllers
8253/8253-5 Programmable Interval Timer ..... 9-307
8254 Programmable Interval Timer ..... 9-318
8255A/8255A-5 Programmable Peripheral Interface ..... 9-333
8275 Programmable CRT Controller ..... 9-354
8276 Small System CRT Controller ..... 9-378
8279/8279-5 Programmable Keyboard/Display Interface ..... 9-395
CHAPTER 10
iAPX 432 MICROMAINFRAME ${ }^{\text {TM }}$
iAPX 43201/43202/43203 VLSI Micromainframe System ..... 10-1
iAPX 43201, 43202 VLSI General Data Processor ..... 10-3
iAPX 43203 VLSI Interface Processor ..... 10-34
CHAPTER 11
Industrial Grade Products
I2114A, $1024 \times 4$-Bit Static RAM ..... 11-1
I2118 Family 16,384 x 1-Bit Dynamic RAM ..... 11-4
12716 Industrial Grade 16K (2K x 8) UV Erasable PROM ..... 11-9
18022 Single Component 8-Bit Microcomputer with On-Chip A/D Converter ..... 11-13
18031/8051 Single Component 8-Bit Microcomputer ..... 11-16
18048H New High Performance HMOS Single Component 8-Bit Microcomputer ..... 11-17
18049H/8039H New High Performance Single Component 8-Bit Microcomputer ..... 11-20
18085AH Single Chip 8-Bit N-Channel Microprocessor ..... 11-23
Industrial iAPX 86/10 16-Bit HMOS Microprocessor ..... 11-27
I8155/6H, 2048 Bit Static MOS RAM with I/O Ports and Timer ..... 11-37
18185, $1024 \times 8$-Bit Static RAM for MCS-85 ..... 11-40
18212, 8-Bit Input/Output Port ..... 11-45
18216/8226, 4-Bit Parallel Bidirectional Bus Driver ..... 11-48
I8259A Programmable Interrupt Controller ..... 11-51
18282/8283 Octal Latch ..... 11-57
18284 Clock Generator and Driver for iAPX 86, 88 Processors ..... 11-61
18286/8287 Octal Bus Transceiver ..... 11-65
18288 Bus Controller for iAPX 86, 88 Processors ..... 11-70
18289 Bus Arbiter ..... 11-75
I8355, 16,384-Bit ROM with I/O ..... 11-79
I8755A, 16,384-Bit EPROM with I/O ..... 11-82
CHAPTER 12
Military Grade Products
Introduction ..... 12-1
M2114A, $1024 \times 4$-Bit Static RAM ..... 12-4
M2118 Family 16,384 x 1-Bit Dynamic RAM ..... 12-8
M2147H High Speed $4096 \times 1$-Bit Static RAM ..... 12-13
M2148H High Speed $1024 \times 4$-Bit Static RAM ..... 12-17
M2167 ..... 12-21
M2716/M2716M, 16K (2K x 8) UV Erasable PROM ..... 12-25
M2732, 32K (4K x 8) UV Erasable PROM ..... 12-28
M2764 ..... 12-29
M2816, 16K (2K x 8) Electrically Erasable PROM ..... 12-33
M3632 ..... 12-38
M3636, 16K (2K x 8) Bipolar PROM ..... 12-39
M8048/M8748/M8035L Single Component 8-Bit Microcomputer ..... 12-42
M8080A, 8-Bit N-Channel Microprocessor ..... 12-48
M8085AH Single Chip 8-Bit N-Channel Microprocessor ..... 12-53
Military iAPX 86/10, 16-Bit HMOS Microprocessor ..... 12-58
M8155H, 2048-Bit Static MOS RAM with I/O Ports and Timer ..... 12-67
M8185, $1024 \times 8$-Bit Static RAM for MCS-85 ..... 12-70
M8212, 8-Bit Input/Output Port ..... 12-72
M8214 Priority Interrupt Control Unit ..... 12-76
M8216/M8226, 4-Bit Parallel Bidirectional Bus Driver ..... 12-79
M8224 Clock Generator and Driver for 8080A CPU ..... 12-82
M8228 System Controller and Bus Driver for M8080A CPU ..... 12-87
M8231A Arithmetic Processing Unit ..... 12-92
M8243 MCS-48 Input/Output Expander ..... 12-95
M8251A Programmable Communication Interface ..... 12-98
M8253 Programmable Interval Timer ..... 12-102
M8255A Programmable Peripheral Interface ..... 12-106
M8257 Programmable DMA Controller ..... 12-112
M8259A Programmable Interrupt Controller ..... 12-116
M8282/8283 Octal Latch ..... 12-119
M8284 Clock Generator and Driver for Military iAPX 86 ..... 12-122
M8286/8287 Octal Bus Transceiver ..... 12-125
M8288 Bus Controller for Military iAPX 86 ..... 12-128
M8289 Bus Arbiter ..... 12-133
M8741A Universal Peripheral Interface 8-Bit Microcomputer ..... 12-136
M8755A, 16,384-Bit EPROM with I/O ..... 12-140
CHAPTER 13
Quality Assurance ..... 13-1
CHAPTER 14
General Information
Ordering Information ..... 14-1
Packaging Information ..... 14-2
Microcomputer Workshops ..... 14-11
Product Service ..... 14-14

## Alphanumeric Index

2114A, $102 \times 4$-Bit Static RAM ..... 1-1
I2114A, $104 \times 4$-Bit Static RAM ..... 11-1
M2114A, $124 \times 4$-Bit Static RAM ..... 12-4
2115A, 215A Family, High Speed 1K x 1-Bit Static RAM ..... 1-5
2115H, 215H Family, High Speed 1K x 1-Bit Static RAM ..... 1-10
2118 Fami 16,384 x 1-Bit Dynamic RAM ..... 1-15
12118 Famly 16,384 x 1-Bit Dynamic RAM ..... 11-4
M2118 Fanily 16,384 x 1-Bit Dynamic RAM ..... 12-8
2128 2K x 3 Static RAM ..... 1-26
2141, 4091x 1-Bit Static RAM ..... 1-30
2142, 102، x 4-Bit Static RAM ..... 1-36
2147A, 1 Kx 4 Static RAM ..... $1-40$
2147H Hiç Speed $4096 \times 1$-Bit Static RAM ..... 1-44
M2147H Hgh Speed $4096 \times 1$-Bit Static RAM ..... 12-13
$2148 \mathrm{H}, 104 \times 4$-Bit Static RAM ..... 1-48
M2148H High Speed $1024 \times 4$-Bit Static RAM ..... 12-17
2149H, $104 \times 4$-Bit Static RAM ..... 1-52
2164 Famly 65,536 x 1-Bit Dynamic RAM ..... 1-56
2164-25, 6,536 x 1-Bit Dynamic RAM ..... 1-64
2167 Higr Speed 16,384 x 1-Bit Static RAM ..... 1-72
M2167 ..... 12-21
2186/7, $892 \times 8$-Bit Integrated RAM ..... 1-77
27128, (10K x 8) UV Erasable PROM ..... 2-22
2716, 16K(2K x 8) UV Erasable PROM ..... 2-1
I2716 Indıstrial Grade 16K (2K x 8) UV Erasable PROM ..... 11-9
M2716/M:716M, 16K (2K x 8) UV Erasable PROM ..... 12-25
2732A, 3K (4K x 8) UV Erasable PROM ..... 2-9
M2732, 3؛K (4K x 8) UV Erasable PROM ..... 12-28
2764, (8Kx 8) UV Erasable PROM ..... 2-16
M2764 ..... 12-29
2815, 16K (2K x 8) Electrically Erasable PROM ..... 2-23
2816, 16K (2K x 8) Electrically Erasable PROM ..... 2-36
M2816, 16K (2K x 8) Electrically Erasable PROM ..... 12-33
2817, 16K ( $2 \mathrm{~K} \times 8$ ) Electrically Erasable PROM ..... 2-49
2910A PCM Codec - $\mu$ Law, 8-Bit Companded A/D and D/A Converter ..... 4-1
2911A PCM Codec - A Law, 8-Bit Companded A/D and D/A Converter ..... 4-16
2912A PCM Transmit/Receive Filter ..... 4-30
2913/2914 Combined Single Chip ..... 4-42
2921 ..... 4-60
3628A, 8K (1K x 8) Bipolar PROM ..... 2-50
3632, 32K (4K x 8) Bipolar PROM ..... 2-53
M3632 ..... 12-38
3636B, 16K (2K x 8) Bipolar PROM ..... 2-56
M3636, 16K (2K x 8) Bipolar PROM ..... 12-39
iAPX 43201/43202/43203 VLSI Micromainframe System ..... 10-1
iAPX 43201, 43202 VLSI General Data Processor ..... 10-3
iAPX 43203 VLSI Interface Processor ..... 10-34
7110, 1 Negabit Bubble Memory Family ..... 3-5
7220-1 Bubble Memory Controller ..... 3-11
7230 Current Pulse Generator for Bubble Memories ..... 3-26
7242 Dual Formatter/Sense Amplifier for Bubble Memories ..... 3-30
7250 Coil Pre-Driver for Bubble Memories ..... 3-40
7254 Quad VMOS Drive Transistors for Bubble Memories ..... 3-44
8020H HMOS Single-Component 8-Bit Microcomputer ..... 6-1
8021 Single Component 8-Bit Microcomputer ..... 6-7
8021H HMOS Single-Component 8-Bit Microcomputer ..... 6-8
8022 Single Component 8-Bit Microcomputer with On-Chip A/D Converter ..... 6-17
8022H High Performance Single Component 8-Bit Microcomputer with On-Chip A/D Converter ..... 6-23
18022 Single Component 8-Bit Microcomputer with On-Chip A/D Converter ..... 11-13
8031/8051/8751 Single Component 8-Bit Microcomputer ..... 6-24
18031/8051 Single Component 8-Bit Microcomputer ..... 11-16
8041 AH/8041AH-2/8641A/8741A Universal Peripheral Interface 8-Bit Microcomputer ..... 9-1
8042/8742 Universal Peripheral Interface 8-Bit Microcomputer ..... 9-14
80C48/80C35 CHMOS Single-Component 8-Bit Microcomputer ..... 6-46
8048H/8048H-1/8035HL/8035HL-1 HMOS Single Component 8-Bit Microcomputer ..... 6-39
18048H New High Performance HMOS Single Component 8-Bit Microcomputer ..... 11-17
M8048/M8748/M8035L Single Component 8-Bit Microcomputer ..... 12-42
P80A48H/P80A35HL HMOS Single Component 8-Bit Microcomputer ..... 5-1
P80A48L HMOS Single Component 8-Bit Microcomputer ..... 5-17
80C49/80C39 CHMOS Single-Component 8-Bit Microcomputer ..... 6-69
8049H/8049HL HMOS Single Component 8-Bit Microprocessor ..... 6-62
18049H/8039H New High Performance Single Component 8-Bit Microcomputer ..... 11-20
P80A49H/P80A39HL HMOS Single Component 8-Bit Microcomputer ..... 5-9
8050H/8040H HMOS Single Component 8-Bit Microcomputer ..... 6-91
8080A/8080A-1/8080A-2, 8-Bit N-Channel Microprocesser ..... 7-1
M8080A, 8-Bit N-Channel Microprocessor ..... 12-48
8085A/8085A-2 Single Chip 8-Bit N-Channel Microprocessors ..... 7-26
8085AH/8085AH-2 Single Chip 8-Bit HMOS Microprocessors ..... 7-10
I8085AH Single Chip 8-Bit N-Channel Microprocessor ..... 11-23
M8085AH Single Chip 8-Bit N-Channel Microprocessor ..... 12-53
iAPX 86/10 16-Bit HMOS Microprocessor ..... 8-1
Industrial iAPX 86/10 16-Bit HMOS Microprocessor ..... 11-27
iAPX 86/20, 88/20 8-Bit HMOS Numeric Data Processor ..... 8-66
iAPX 86/30, iAPX 88/30 Operating System Processors ..... 8-86
iAPX 88/10 8-Bit HMOS Microprocessor ..... 8-25
8089 8/16-Bit HMOS I/O Processor ..... 8-52
8148, $4096 \times 8$-Bit Integrated RAM ..... 1-76
8155/8156/8155-2/8156-2, 2048 Bit Static MOS RAM with I/O Ports and Timer ..... 7-42
$8155 \mathrm{H} / 8156 \mathrm{H} / 8155 \mathrm{H}-2 / 8156 \mathrm{H}-2,2048$ Bit Static HMOS RAM with I/O Ports and Timer ..... 7-30
18155/6H, 2048 Bit Static MOS RAM with I/O Ports and Timer ..... 11-37
M8155H, 2048-Bit Static MOS RAM with I/O Ports and Timer ..... 12-67
8185/8185-2, $1024 \times 8$-Bit Static RAM for MCS-85 ..... 7-45
18185, $1024 \times 8$-Bit Static RAM for MCS-85 ..... 11-40
M8185, $1024 \times 8$-Bit Static RAM for MCS-85 ..... 12-70
8202A Dynamic RAM Controller ..... 9-69
8203 64K Dynamic RAM Controller ..... 9-83
8205 High Speed 1 Out of 8 Binary Decoder ..... 7-50
8206 Error Detection and Correction Unit ..... 9-98
8212 8-Bit Input/Output Port ..... 7-55
18212, 8-Bit Input/Output Port ..... 11-45
M8212, 8-Bit Input/Output Port ..... 12-72
M8214 Priority Interrupt Control Unit ..... 12-76
8216/8226, 4-Bit Parallel Bidirectional Bus Driver ..... 7-63
18216/8226, 4-Bit Parallel Bidirectional Bus Driver ..... 11-48
82S181/82HS181, 8K (1K x 8) Bipolar PROM ..... 2-59
82S191/82HS191, 16K (2K x 8) Bipolar PROM ..... 2-62
82S321/82HS321, 32K (4K x 8) Bipolar PROM ..... 2-65
M8216/M8226, 4-Bit Parallel Bidirectional Bus Driver ..... 12-79
8218/8219 Bipolar Microcomputer Bus Controllers for MCS-80 and MCS-85 Families ..... 7-68
8224 Clock Generator and Driver for 8080A CPU ..... 7-79
M8224 Clock Generator and Driver for 8080A CPU ..... $12-82$
8228/8238 System Controller and Bus Driver for 8080A CPU ..... 7-84
M8228 System Controller and Bus Driver for M8080A CPU ..... 12-87
8231A Arithmetic Processing Unit ..... 9-27
M8231A Arithmetic Processing Unit ..... 12-92
8232 Floating Point Processing Unit ..... 9-37
8237A/8237A-5 High Performance Programmable DMA Controller ..... 7-88
8243 MCS-48 Input/Output Expander ..... 6-85
M8243 MCS-48 Input/Output Expander ..... 12-95
8251A Programmable Communication Interface ..... 9-165
M8251A Programmable Communication Interface ..... 12-98
8253/8253-5 Programmable Interval Timer ..... 9-307
M8253 Programmable Interval Timer ..... 12-102
8254 Programmable Interval Timer ..... 9-318
8255A/8255A-5 Programmable Peripheral Interface ..... 9-333
M8255A Programmable Peripheral Interface ..... 12-106
8256 Multifunction Universal Asynchronous Receiver-Transmitter (MUART) ..... 9-182
8257/8257-5 Programmable DMA Controller ..... 7-103
M8257 Programmable DMA Controller ..... 12-112
8259A/8259A-2/8259A-8 Programmable Interrupt Controller ..... 7-120
18259A Programmable Interrupt Controller ..... 11-51
M8259A Programmable Interrupt Controller ..... 12-116
8271/8271-6 Programmable Floppy Disk Controller ..... 9-117
8272 Single/Double Density Floppy Disk Controller ..... 9-146
8273, 8273-4, 8273-8 Programmable HDLC/SDLC Protocol Controller ..... 9-191
8274 Multi-Protocol Serial Controller ..... 9-216
8275 Programmable CRT Controller ..... 9-354
8276 Small System CRT Controller ..... 9-378
8279/8279-5 Programmable Keyboard/Display Interface ..... 9-395
8282/8283 Octal Latch ..... 8-108
18282/8283 Octal Latch ..... 11-57
M8282/8283 Octal Latch ..... 12-119
8284A Clock Generator and Driver for iAPX 86/10, iAPX 88/10 8089 Processors ..... 8-113
18284 Clock Generator and Driver for iAPX 86, 88 Processors ..... 11-61
M8284 Clock Generator and Driver for Military iAPX 86 ..... 12-122
8286/8287 Octal Bus Transceiver ..... 8-121
18286/8287 Octal Bus Transceiver ..... 11-65
M8286/8287 Octal Bus Transceiver ..... 12-125
8288 Bus Controller for iAPX 86/10, iAPX 88/10 8089 Processors ..... 8-126
18288 Bus Controller for iAPX 86, 88 Processors ..... 11-70
M8288 Bus Controller for Military iAPX 86 ..... 12-128
8289 Bus Arbiter ..... 8-133
18289 Bus Arbiter ..... 11-75
M8289 Bus Arbiter ..... 12-133
8291 A GPIB Talker/Listener ..... 9-251
8292 GPIB Controller ..... 9-280
8293 GPIB Transceiver ..... 9-295
8294 Data Encryption Unit ..... 9-49
8295 Dot Matrix Printer Controller ..... 9-60
8355/8355-2, 16,384-Bit ROM with I/O ..... 7-138
I8355, 16,384-Bit ROM with I/O ..... 11-79
M8741A Universal Peripheral Interface 8-Bit Microcomputer ..... 12-136
8748H/8035H HMOS Single-Chip EPROM Microcomputer ..... 6-53
8749H/8749H-8/8739H/8739H-B ..... 6-76
8755A/8755A-2, 16,384-Bit EPROM with I/O ..... 7-146
18755A, 16,384-Bit EPROM with I/O ..... 11-82
M8755A, 16,384-Bit EPROM with I/O ..... 12-140
Bipolar PROM Cross Reference ..... 2-71
Bipolar PROM Programming ..... 2-68
BPK70, 1 Mbit Bubble Storage Subsystem ..... 3-1
BPK72 Bubble Storage Prototype Kit ..... 3-3

## Random Access Memory

# 2114A <br> 1024 X 4 BIT STATIC RAM 

|  | 2114AL-1 | 2114AL-2 | $2114 \mathrm{AL}-3$ | $2114 \mathrm{AL}-4$ | $2114 \mathrm{~A}-4$ | 2114A-5 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 100 | 120 | 150 | 200 | 200 | 250 |
| Max. Current (mA) | 40 | 40 | 40 | 40 | 70 | 70 |

## - HMOS Technology

- Low Power, High Speed
- Identical Cycle and Access Times
- Single +5 V Supply $\pm \mathbf{1 0 \%}$
- High Density 18 Pin Package
- Completely Static Memory - No Clock or Timing Strobe Required
- Directly TTL Compatible: All Inputs and Outputs
- Common Data Input and Output Using Three-State Outputs
2114 Upgrade

The Intel* 2114A is a 4096-bit static Random Access Memory organized as 1024 words by 4 -bits using HMOS, a high performance MOS technology. It uses fully DC stable (static) circuitry throughout, in both the array and the decoding, therefore it requires no clocks or refreshing to operate. Data access is particularly simple since address setup times are not required. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided.

The 2114A is designed for memory applications where the high performance and high reliability of HMOS, low cost, large bit storage, and simple interfacing are important design objectives. The 2114A is placed in an 18-pin package for the highest possible density.

It is directly TTL compatible in all respects: inputs, outputs, and a single +5 V supply. A separate Chip Select ( $\overline{\mathrm{CS}}$ ) lead allows easy selection of an individual package when outputs are or-tied.

| $A_{0}-A_{9}$ | ADDRESS INPUTS | $V_{\text {CC }}$ POWER $(+5 \mathrm{~V})$ |
| :--- | :--- | :--- |
| WE | WRITE ENABLE | GND GROUND |
| $\overline{\text { CS }}$ | CHIP SELECT |  |
| $1 / \mathrm{O}_{1}-1 / \mathrm{O}_{4}$ | DATA INPUT/OUTPUT |  |



[^0]
## ABSOLUTE MAXIMUM RATINGS*

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure 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 | 2114AL-1/L-2/L-3/L-4 |  |  | 2114A-4/-5 |  |  |  | $8$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{11]}$ | Max. | Min. | Typ. ${ }^{11]}$ | Max. | UNIT | CONDITIONS |
| $\left\|I_{\text {LI }}\right\|$ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0$ to 5.5 V |
| IL LO | I/O Leakage Current |  | $\therefore$; | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{1 H} \\ & V_{1 / O}=G N D \text { to } V C C \end{aligned}$ |
| ICC | Power Supply Current |  | 25 | 40 |  | 50 | 70 | mA | $\begin{aligned} & V_{C C}=\max , I_{I / O}=0 \mathrm{~mA}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C} \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -3.0 |  | 0.8 | -3.0 |  | 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 | 9.0 |  | 2.1 | 9.0 |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| IOH | Output High Current | -1.0 | -2.5 |  | -1.0 | -2.5 | $\therefore$ | 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}_{\propto 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 |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{1 / \mathrm{O}}=\mathrm{OV}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ |

NOTE: This parameter is periodically sampled and not $100 \%$ tested.
A.C. CONDITIONS OF TEST
Input Pulse Levels0.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}$

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

|  |  | 2114AL-1 |  | 2114AL-2 |  | 2114AL-3 |  | 2114A-4/L-4 |  | 2114A-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle Time | 100 |  | 120 |  | 150 |  | 200 |  | 250 |  | ns |
| $t_{\text {A }}$ | Access Time |  | 100 |  | 120 |  | 150 |  | 200 |  | 250 | ns |
| tco | Chip Selection to Output Valid |  | 70 |  | 70 |  | 70 |  | 70 |  | 85 | ns |
| tcx | Chip Selection to Output Active | 10 |  | 10 |  | 10 |  | 10 |  | 10 |  | ns |
| tото | Output 3-state from Deselection |  | 30 |  | 35 |  | 40 |  | 50 |  | 60 | ns |
| tora | Output Hold from Address Change | 15 |  | 15 |  | 15 |  | 15 |  | 15 |  | ns |

WRITE CYCLE [2]

|  |  | 2114AL-1 |  | 2114AL-2 |  | 2114AL-3 |  | 2114A-4/L-4 |  | 2114A-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL | PARAMETER | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| twc | Write Cycle Time | 100 |  | 120 |  | 150 |  | 200 |  | 250 |  | ns |
| tw | Write Time | 75 |  | 75 |  | 90 |  | 120 |  | 135 |  | ns |
| twe | Write Release Time | 0 |  | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| torw | Output 3-state from Write |  | 30 |  | 35 |  | 40 |  | 50 |  | 60 | ns |
| tow | Data to Write Time Overlap | 70 |  | 70 |  | 90 |  | 120 |  | 135 |  | ns |
| toh | Data Hold from Write Time | 0 |  | 0 |  | 0 |  | 0 |  | 0 |  | ns |

NOTES:

1. A Read occurs during the overlap of a low $\overline{C S}$ and a high $\overline{W E}$.
2. A Write occurs during the overlap of a low $\overline{C S}$ and a low $\overline{W E} . t_{W}$ is measured from the latter of $\overline{C S}$ or $\overline{W E}$ going low to the earlier of $\overline{C S}$ or $\overline{W E}$ going high.

## WAVEFORMS

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


NOTES:
3. $\overline{W E}$ is high for a Read Cycle.
4. If the $\overline{\mathrm{CS}}$ low transition occurs simultaneously with the $\overline{\mathrm{WE}}$ 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

$\mathrm{V}_{\mathrm{OH}}(\mathrm{V})$

NORMALIZED ACCESS TIME VS. AMBIENT TEMPERATURE


NORMALIZED POWER SUPPLY CURRENT VS. AMBIENT TEMPERATURE


OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE

$V_{\mathrm{OL}}(\mathrm{V})$

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

|  | 2115AL, 2125AL | 2115A, 2125A | 2115AL-2, 2125AL-2 | 2115A-2, 2125A-2 |
| :---: | :---: | :---: | :---: | :---: |
| Max. $\mathrm{T}_{\mathrm{AA}}(\mathrm{ns})$ | 45 | 45 | 70 | 70 |
| Max. $\mathrm{I}_{\mathrm{CC}}(\mathrm{mA})$ | 75 | 125 | 75 | 125 |

## - Pin Compatible To 93415A (2115A) And 93425A (2125A) <br> - 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}$ 2115A and 2125A families are high-speed, 1024 words by 1 bit random access memories. Both open collector ( $2115 A$ ) and three-state output (2125A) are available. The 2115 A and 2125 A 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 $2115 \mathrm{~A} / 2125 \mathrm{~A}$ and the 2115A-2/2125A-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 Intel's N-channel MOS Silicon Gate Technology.


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


#### 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 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]}$
$V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$

| Symbol | Test | Min. | Typ. | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {OL1 }}$ | 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 | $\because$ |
| $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}$ |
| $\mathrm{I}_{\mathrm{IH}}$ | Input High Current |  | 0.1 | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=\mathrm{Max} ., \mathrm{V}_{\text {IN }}=4.5 \mathrm{~V}$ |
| $\left\|I_{\text {Cex }}\right\|$ | 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\|l_{\text {OFF }}\right\|$ | 2125A Family Output Current (High Z) |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=$ Max., $\mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V} / 2.4 \mathrm{~V}$ |
| $\mathrm{IOS}^{[3]}$ | 2125A Family Current Short Circuit to Ground |  |  | -100 | mA | $V_{C C}=$ Max . |
| V 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 }^{\text {CO }} 2115 \mathrm{AL}, 2115 \mathrm{AL}-2,2125 \mathrm{AL}, \\ & \quad 2125 \mathrm{AL}-2 \\ & \hline \mathrm{ICC}_{2}: 2115 \mathrm{~A}, 2115 \mathrm{~A}-2,2125 \mathrm{~A}, 2125 \mathrm{~A}-2 \end{aligned}$ |  | 60 100 | 75 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 and a two minute warm-up. Typical thermal resistance values of the package at maximum temperature are:

$$
\begin{aligned}
& \theta \mathrm{JA}\left(@ 400 \text { fPM 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}, \mathrm{~T}_{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]} \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, T_{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}{lll}5 & 15 & 30\end{array}$ | $\begin{array}{lll}5 & 15 & 30\end{array}$ | 5. 1530 | $\begin{array}{lll}5 & 15 & 40\end{array}$ | ns |
| $t_{\text {RCS }}$ | Chip Select Fiecovery Time | $10 \quad 30$ | $10 \quad 30$ | $10 \quad 30$ | $10 \quad 40$ | ns |
| ${ }^{\prime}{ }_{\text {A }}$ A | Address Access Time | $30 \quad 45$ | 3045 | 4070 | 4070 | 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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tws | Write Enable Time | $10 \quad 25$ | 1030 | $10 \quad 25$ | 1040 |  |
| tWR | Write Recovery Time | $0 \quad 25$ | 030 | 025 | $0 \quad 45$ | ns |
| tw | Write Pulse Width | $30 \quad 20$ | $30 \quad 10$ | 3015 | $50 \quad 15$ | ns |
| twSD | Data Set-Up Time Prior to Write | $0-5$ | 5 -5 | 0 -5 | $5-5$ | ns |
| $t_{\text {WHD }}$ | Data Hold Time After Write | 50 | 50 | 50 | 50 | ns |
| twSA | Address Set-Up Time | 50 | 5 0 | 50 | 150 | ns |
| $t_{\text {WHA }}$ | Address Hold Time | 50 | 50 | 50 | 50 | ns |
| twscs | 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


(ALL ABOVE MEASUREMENTS REFERENCED TO 1.5V)

## 2115A, 2125A FAMILY

2125 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 }}$ ACS | Chip Select Time | $\begin{array}{lll}5 & 15 & 30\end{array}$ | $5 \quad 15 \quad 30$ | $5 \quad 15 \quad 30$ | $\begin{array}{lll}5 & 15 & 40\end{array}$ | ns |
| $t_{\text {zRCS }}$ | Chip Select to HIGH Z | $10 \quad 30$ | 1030. | $10 \quad 30$ | $10 \quad 40$ | ns |
| ${ }^{\text {t }}$ A ${ }^{\text {a }}$ | Address Access Time | $30 \quad 45$ | $30 \quad 45$ | 4070 | 4070 | 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 | $10 \quad 25$ | 1030 | 1025 | $10 \quad 40$ | ns |
| $t_{\text {WR }}$ | Write Recovery Time | $0 \quad 25$ | $0 \quad 30$ | 0 0 25 | $0 \quad 45$ | ns |
| $\mathrm{t}_{\mathrm{w}}$ | Write Pulse Width | $30 \quad 20$ | $30 \quad 10$ | $30 \quad 10$ | $50 \quad 15$ | ns |
| tWSD | Data Set-Up Time Prior to Write | $0-5$ | $5 \quad-5$ | $0-5$ | $5-5$ | ns |
| ${ }^{\text {W WHD }}$ | Data Hold Time After Write | 5 0 | 50 | 50 | 50 | ns |
| twSA | Address Set-Up Time | 50 | 50 | 50 | 150 | ns |
| ${ }^{\text {twha }}$ | Address Hold Time | 50 | 50 | 50 | 50 | ns |
| ${ }^{\text {twscs }}$ | Chip Select Set-Up Time | 50 | 50 | 50 | 50 | ns |
| twhCs | Chip Select Hold Time | 50 | 50 | 50 | 50 | ns |

## A.C. TEST CONDITIONS



## 2125A FAMILY WRITE ENABLE TO HIGH Z DELAY



LOAD 1


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


(ALL ' $Z \times 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 | 2115A Family LIMITS |  | 2125A Family LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. | TYP. | MAX. |  |  |
| $C_{1}$ | Input Capacitance | 3 | 5 | 3 | 5 | pF | All Inputs $=0 \mathrm{~V}$, Output Open |
| $\mathrm{C}_{0}$ | Output Capacitance | 5 | 8 | 5 | 8 | pF | $\overline{\mathbf{C S}}=5 \mathrm{~V}$, All Other Inputs $=0 \mathrm{~V}$, 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

|  | $2125 \mathrm{H}-1$ | $2115 \mathrm{H}-2,2125 \mathrm{H}-2$ | $2115 \mathrm{H} \cdot 3,2125 \mathrm{H}-3$ | $2115 \mathrm{H} \cdot 4,2125 \mathrm{H}-4$ |
| :---: | :---: | :---: | :---: | :---: |
| Max. $\mathrm{T}_{\mathrm{AA}}(\mathrm{ns})$ | 20 | 25 | 30 | 35 |
| Max. $\mathrm{I}_{\mathbf{c c}}(\mathrm{mA})$ | 150 | 125 | 100 | 125 |

## - HMOS II Technology

- Pin Compatible to 93415A (2115H) and 93425A (2125H)
- 16mA Output Sink Current

■ Low Operating Power Dissipation Max. $0.53 \mathrm{~mW} /$ Bit (2115H-3, 2125H-3)

- TTL Inputs and Outputs
- Single +5V Supply

■ Uncommitted Collector (2115H) and Three-State (2125H) Output

- Standard 16-Pin Dual In-Line Package

The Intel® 2115 H and 2125 H families are high speed, 1024 words by 1 -bit random access memories fabricated with HMOSII, Intel's advanced N-channel MOS silicon gate technology. Both open collector ( 2115 H ) and three-state output $(2125 \mathrm{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.
HMOS II's advanced technology allows the production of the industry's fastest, low power, 1K static RAMs - offering access times as low as 20 ns .
HMOS $\Pi$ allows the production of the $2115 \mathrm{H} / 2125 \mathrm{H}$ families, fully compatible with the 1 K Bipolar RAMs yet offering substantial reductions in power dissipation. The power dissipations of 525 mW maximum and 656 mW maximum compared to 814 mW maximum offer reductions of $19 \%$ and $36 \%$ respectively.
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.

LOGIC SYMBOL


PIN NAMES

| CS | CHIP SELECT |
| :--- | :--- |
| $A_{0}$ TO Ag | ADDRESS INPUTS |
| $\overline{W E}$ | WRITE ENABLE |
| $D_{\text {IN }}$ | DATA INPUT |
| $D_{\text {OUT }}$ | DATA OUTPUT |

BLOCK DIAGRAM


TRUTH TABLE

| INPUTS |  |  | OUTPUT 2115H FAMILY | OUTPUT 2125H FAMILY | MODE |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | WE | DIN | Dout | Dout |  |
| H | X | X | HIGH $Z$ | HIGH 2 | NOT SELECTED |
| L | 1 | L | HIGH 2 | HIGH $Z$ | WRITE "0" ? |
| $L$ | 1 | H | HIGH 2 | HIGH 2 | WRITE "1"- |
| L | H | X | Dout | Dout | READ |

## 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 . . . . . . . . . . . . . . . . . -1.5 V to +7 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]}$

$V_{C C}=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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Vou | 2115H/25H Family Output Low Voltage |  |  | 0.45 | $v$ | $\mathrm{loL}=16 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.1 |  |  | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.8 | V |  |
| ILI | Input Low Current |  | -0.1 | -40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{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}$ |
| $\left\|I_{\text {cex }}\right\|$ | 2115H Family Output Leakage Current |  | 0.1 | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {cc }}=\mathrm{Max}^{\text {., }} \mathrm{V}_{\text {OUt }}=4.5 \mathrm{~V}$ |
| \|loffl | 2125H Family Output Current (High Z) |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {cc }}=\mathrm{Max}^{\text {., }} \mathrm{V}_{\text {OUT }}=0.5 \mathrm{~V} / 2.4 \mathrm{~V}$ |
| los | 2125H Family Current Short Circuit to Ground |  | 125 | 200 | mA | $\mathrm{V}_{\mathrm{cc}}=\mathrm{Max}$. |
| $\mathrm{V}_{\mathrm{OH}}$ | Family Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-5.2 \mathrm{~mA}$ |
| lcc | Power Supply Current: $\mathrm{I}_{\mathrm{cc}_{1}:}: 2125 \mathrm{H}-1$ |  | 80 | 150 | mA | All Inputs Grounded, Output Open |
|  | $\text { Icc: } \begin{aligned} & 2115 \mathrm{H}-2 / 2125 \mathrm{H}-2 \\ & 2115 \mathrm{H}-4 / 2125 \mathrm{H}-4 \end{aligned}$ |  | 80 | 125 | mA |  |
|  | $I_{\text {ccas: }} \mathbf{2 1 1 5 H - 3 / 2 1 2 5 H - 3}$ |  | 80 | 100 | mA |  |

NOTES:

1. The operating ambient temperature ranges are 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 maximum loading.

2115H FAMILY A.C. CHARACTERISTICS
$V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$
READ CYCLE

| Symbol | Test | 2115H-2 Limits Min. Max. | 2115H-3 Limits Min. Max. | 2115H-4 Limits Min. Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {Acs }}$ | Chip Select Time | 15 | 20 | 20 | ns |
| $t_{\text {RCS }}$ [1] | Chip Select Recovery Time | 20 | 20 | 20 | ns |
| $t_{\text {AA }}$ | Address Access Time | 25 | 30 | 35 | ns |
| tor [1] | Previous Read Data Valid After Change of Address | 0 | 0 | 0 | ns |

## WRITE CYCLE


[1] These specifications are guaranteed by design and not production tested.

## A.C. TEST CONDITIONS





## READ CYCLE



## WRITE CYCLE



2125H FAMILY A.C. CHARACTERISTICS $\quad V_{C C}=5 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$
READ CyCle

| Symbol | Test | 2125H-1 Limits | 2125H-2 Limits | 2125H-3 Limits | 2125H-4 Limits | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. Max. | Min. Max. |  |
| $t_{\text {ACS }}$ | Chip Select Tirrie | 15 | 15 | 20 | 20 | ns |
| $t_{\text {zrcs }}$ [1] | Chip Select to HIGH Z | 20 | 20 | 20 | 20 | ns |
| ${ }^{t}$ AA | Address Access Time | 20 | 25 | 30 | 35 | ns |
| $\mathrm{toher}^{\text {[1] }}$ | Previous Piead Data Valid After Change of Address | 0 | 0 | 0 | 0 | ns |

## WRITE CYCLE

| Symbol | Test | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {ZWS }}$ [1] | Write Enable to HIGH Z |  | 15 |  | 15 |  | 20 |  | 20 | ns |
| twr | Write Recovery Time | 0 | 15 | 0 | 15 | 0 | 20 | 0 | 20 | ns |
| tw | Write Pulse Width | 15 |  | 20 |  | 20 |  | 25 |  | ns |
| twSD | Data Set-Up Time Prior to Write | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| twhD | Data Hold Time After Write | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| twSA | Address Set-Up Time | 5 |  | 5 |  | 5 |  | 5 |  | ns |
| twha [1] | Address Hold Time | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| twscs | Chip Select Set-Up Time | 5 |  | 5 |  | 5 |  | 5 |  | ns |
| $\mathrm{t}_{\text {WHCS }}$ | Chip Select Hold Time | 0 |  | 0 |  | 5 |  | 5 |  | ns |

[1] These specifications are guaranteed by design and not production tested.

## A.C. TEST CONDITIONS




## READ CYCLE



PROPAGATION DELAY FROM CHIP SELECT


WRITE CYCLE


## 2125H FAMILY WRITE ENABLE TO HIGH Z DELAY



LOAD 1


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


(ALL ${ }^{2}$ ZXXX PARAMETERS ARE MEASURED AT A DELTA OF 0.5V FROM THE LOGIC LEVEL AND USING LOAD 1.)

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

| SYMBOL | TEST | 2115H Family LIMITS |  | 2125H Family LIMITS |  | UNITS | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TYP. | MAX. | TYP. | MAX. |  |  |
| $\mathrm{C}_{1}$ | Input Capacitance | 3 | 5 | 3 | 5 | pF | All Inputs = OV, Output Open |
| $\mathrm{C}_{0}$ | Output Capacitance | 5 | 8 | 5 | 8 | pF | $\overline{\mathbf{C S}}=5 \mathrm{~V}$, All Other Inputs $=0 \mathrm{~V}$, Output Open |

[^1]
# 2118 FAMILY <br> 16,384 x 1 BIT DYNAMIC RAM 

|  | $2118-10$ | $2118-12$ | $2118-15$ |
| :--- | :---: | :---: | :---: |
| Maximum Access Time (ns) | 100 | 120 | 150 |
| Read, Write Cycle (ns) | 235 | 270 | 320 |
| Read-Modify-Write Cycle (ns) | 285 | 320 | 410 |

■ Single +5V Supply, $\pm 10 \%$ Tolerance

- HMOS Technology

■ Low Power: 150 mW Max. Operating 11 mW Max. Standby

## Low VDD Current Transients

All Inputs, Including Clocks, TTL Compatible

## CAS Controlled Output is Three-State, TTL Compatible

RAS Only Refresh

- 128 Refresh Cycles Required Every 2ms
- Page Mode and Hidden Refresh Capability
- Allows Negative Overshoot $V_{\text {IL }} \min =-2 V$

The Intel® 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 (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{\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 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{R A S}-$ only refresh cycles, hidden refresh cycles, or normal read or write cycles on the 128 address combinations of $A_{0}$ through $\mathrm{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.

PIN
CONFIGURATION
LOGIC SYMBOL


| $A_{0}-A_{6}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{\text { CAS }}$ | COLUMN ADDRESS STROBE |
| $D_{\text {IN }}$ | DATA IN |
| DOUT | DATA OUT |
| $\overline{\text { WE }}$ | WRITE ENABLE |
| $\overline{\text { RAS }}$ | ROW ADDRESS STROBE |
| $V_{\text {DD }}$ | POWER $+5 \mathrm{~V})$ |
| $V_{S S}$ | GROUND |

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 Relative to Vss | 7.5 V |
| Data Out Current | 50mA |
| Power Dissipation | 1.0 |

*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]}$

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

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[2]}$ | 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 {DD }}$ |  |
| \|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.2 | 2 | mA | $\overline{\text { CAS }}$ and $\overline{\text { RAS }}$ at $\mathrm{V}_{\mathrm{IH}}$ |  |
| IDD2 | VDD Supply Current, Operating |  | 23 | 27 | mA | 2118-10, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
|  |  |  | 21 | 25 | mA | 2118-12, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
|  |  |  | 19 | 23 | mA | 2118-15, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
| IDD3 | VDD Supply Current; $\overline{\text { RAS-Only }}$ Cycle |  | 16 | 18 | mA | 2118-10, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
|  |  |  | 14 | 16 | mA | 2118-12, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
|  |  |  | 12 | 14 | mA | 2118-15, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
| IDD5 | Vdo Supply Current, Standby, Output Enabled |  | 2 | 4 | mA | $\overline{\text { CAS }}$ at VIL, $\overline{\text { RAS }}$ at $V_{\text {IH }}$ | 3 |
| $V_{\text {IL }}$ | Input Low Voltage (all inputs) | -2.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (all inputs) | 2.4 |  | 7.0 | V |  |  |
| VOL | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ |  |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-5 \mathrm{~mA}$ |  |

NOTES:

1. All voltages referenced to $V_{S s}$.
2. Typical values are for $T A=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. $I_{D D}$ is dependent on output loading when the device output is selected. Specified $I_{D D}$ MAX is measured with the output open.

CAPACITANCE ${ }^{[1]}$
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

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

NOTES:
I. 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 ${ }^{[1,2,3]}$

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

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

| Symbol | Parameter | 2118-10 |  | 2118-12 |  | 2118-15 |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| trac | Access Time From $\overline{\mathrm{RAS}}$ |  | 100 |  | 120 |  | 150 | ns | 4,5 |
| tcac | Access Time From $\overline{\mathrm{CAS}}$ |  | 55 |  | 65 |  | 80 | ns | 4,5,6 |
| tref | Time Between Refresh |  | 2 |  | 2 |  | 2 | ms |  |
| trp | $\overline{\text { RAS }}$ Precharge Time | 110 |  | 120 |  | 135 |  | ns |  |
| ICPN | $\overline{\text { CAS }}$ Precharge Time(non-pagecycles) | 50 |  | 55 |  | 70 |  | ns |  |
| tcre | $\overline{\overline{C A S}}$ to $\overline{\text { RAS }}$ Precharge Time | 0 |  | 0 |  | 0 |  | ns |  |
| trco | $\overline{\mathrm{RAS}}$ to CAS Delay Time | 25 | 45 | 25 | 55 | 25 | 70 | ns | 7 |
| trsh | $\overline{\text { RAS }}$ Hold Time | 70 |  | 85 |  | 105 |  | ns |  |
| tcs ${ }^{\text {H}}$ | $\overline{\text { CAS }}$ Hold Time | 100 |  | 120 |  | 165 |  | ns |  |
| tasR | Row Address Set-Up Time | 0 |  | 0 |  | 0 |  | ns |  |
| trah | Row Address Hold Time | 15 |  | 15 |  | 15 |  | ns |  |
| tasc | Column Address Set-Up Time | 0 |  | 0 |  | 0 |  | ns |  |
| tCAH | Column Address Hold Time | 15 |  | 15 |  | 20 |  | ns |  |
| $t_{\text {AR }}$ | Column Address Hold Time, to $\overline{\text { RAS }}$ | 60 |  | 70 |  | 90 |  | ns |  |
| $t$ | Transition Time (Rise and Fall) | 3 | 50 | 3 | 50 | 3 | 50 | ns | 8 |
| toff | Output Buffer Turn Off Delay | 0 | 45 | 0 | 50 | 0 | 60 | ns |  |
| READ AND REFRESH CYCLES |  |  |  |  |  |  |  |  |  |
| trc | Random Read Cycle Time | 235 |  | 270 |  | 320 |  | ns |  |
| tras | $\overline{\text { RAS }}$ Pulse Width | 115 | 10000 | 140 | 10000 | 175 | 10000 | ns |  |
| tcas | $\overline{\text { CAS }}$ Pulse Width | 55 | 10000 | 65 | 10000 | 95 | 10000 | ns |  |
| tracs | Read Command Set-Up Time | 0 |  | 0 |  | 0 |  | ns |  |
| $t_{\text {RCH }}$ | Read Command Hold Time | 0 |  | 0 |  | 0 |  | ns |  |

## WRITE CYCLE

| trc | Random Write Cycle Time | 235 |  | 270 |  | 320 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tras | $\overline{\text { RAS }}$ Puise Width | 115 | 10000 | 140 | 10000 | 175 | 10000 | ns |  |
| tcas | $\overline{\text { CAS }}$ Pulse Width | 55 | 10000 | 65 | 10000 | 95 | 10000 | ns |  |
| twcs | Write Command Set-Up Time | 0 |  | 0 |  | 0 |  | ns | 9 |
| twCH | Write Command Hold Time | 25 |  | 30 |  | 45 |  | ns |  |
| twCR | Write Command Hold Time, to RAS | 70 |  | 85 |  | 115 |  | ns |  |
| twp | Write Command Pulse Width | 25 |  | 30 |  | 50 |  | ns |  |
| trwL | Write Command to $\overline{\text { RAS }}$ Lead Time | 60 |  | 65 |  | 110 |  | ns |  |
| tCWL | Write Command to $\overline{\text { CAS }}$ Lead Time | 45 |  | 50 |  | 100 |  | ns |  |
| tos | Data-In Set-Up Time | 0 |  | 0 |  | 0 |  | ns |  |
| toh | Data-In Hold Time | 25 |  | 30 |  | 45 |  | ns |  |
| tDHR | Data-In Hold Time, to $\overline{\text { RAS }}$ | 70 |  | 85 |  | 115 |  | ns |  |

READ-MODIFY-WRITE CYCLE

| trwc | Read-Modify-Write Cycle Time | 285 | 320 | 410 | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| traw | RMW Cycle $\overline{\text { RAS }}$ Pulse Width | 16510000 | 19010000 | 26510000 | ns |  |
| tcrw | RMW Cycle $\overline{\text { CAS }}$ Pulse Width | 10510000 | $120 \quad 10000$ | $\begin{array}{ll}185 & 10000\end{array}$ | ns |  |
| trwD | $\overline{\text { RAS }}$ to $\overline{\text { WE }}$ Delay | 100 | 120 | 150 | ns | 9 |
| tcwo | $\overline{\mathrm{CAS}}$ to WE Delay | 55 | 65 | 80 | ns | 9 |

## NOTES:

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{\text { AAS }}$ 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}^{-}=5 \mathrm{~ns}$
 (max.) then trac will increase by the amount that trcD exceeds thco (max.).
4. Load $=2 \mathrm{TTL}$ loads and 100 pF
5. Assumes trco $\geq$ trco (max.)
6. trCD $_{\text {(max. }}$ ) is specified as a reference point only: if thCD is less than trCD (max.) access time is trac. If trCD is greater than trCD (max.) access time is trcd + tcac.
7. $\mathrm{It}^{2}$ is measured between $\mathrm{V}_{\mathrm{IH}}$ (min.) and $\mathrm{V}_{\mathrm{IL}}$ (max.)
8. 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 tcwn $\geq$ tcwo (min.) and trwo $\geq$ tRwD (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



NOTES: 1,2. $V_{I H}$ 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$ ILo
6. $t_{D S}$ AND TDH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. trCH 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 (ı.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH $\overline{R A S}$ ).

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE



RAS-ONLY REFRESH CYCLE


HIDDEN REFRESH CYCLE
(For Hidden Refresh Operation order 2118-10 S6445, 2118-12 S6446 or 2118-15 S6447)


NOTES: 1,2. $V_{I H \text { MIN }}$ AND $V_{\text {IL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS.
3,4. $V_{O H}$ MIN AND $V_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF D DUT.
5. toff IS MEASURED TO IOUT \& llol.
6. tDS AND tDH ARE REFERENCED TO CAS OR $\overline{W E}$, WHICHEVER OCCURS LAST
7. trCH IS REFERENCED TO THE TRAILING EDGE OF CAS OR RAS, WHICHEVER OCCURS FIRST.
8. 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).

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

$\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=5 \mathrm{~V} \pm 10 \%$, V SS $=0 \mathrm{~V}$, unless otherwise noted.
(For Page Mode Operation order 2118-10 S6329, 2118-12 S6330 or 2118-15 S6331)

| Symbol | Parameter | $\begin{gathered} 2118-10 \\ S 6329 \\ \hline \end{gathered}$ |  | $\begin{gathered} 2118-12 \\ S 6330 \end{gathered}$ |  | $\begin{gathered} 2118-15 \\ 56331 \end{gathered}$ |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| tPC | Page Mode Read or Write Cycle | 125 |  | 145 |  | 190 |  | ns |  |
| tPCM | Page Mode Read Modify Write Cycle | 175 | * | 200 |  | 280 |  | ns |  |
| $t_{\text {c }}$ | $\overline{\text { CAS }}$ Precharge Time, Page Cycle | 60 |  | 70 |  | 85 |  | ns |  |
| trPM | $\overline{\text { RAS }}$ Pulse Width, Page Mode | 115 | 10000 | 140 | 10000 | 175 | 10000 | ns |  |
| tcas | $\overline{\text { CAS Pulse Width }}$ | 55 | 10000 | 65 | 10000 | 95 | 10000 | ns |  |
| IDD4 | VDD Supply Current Page Mode, Minimum tpC, Minimum tcas |  | 20 | . | - 17 |  | 15 | mA |  |

## WAVEFORMS

## PAGE MODE READ CYCLE



NOTES: 1,2. $V_{I H}$ 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 : 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}^{2}=5$ ns.
9. SEE THE TYPICAL CHARACTERISTICS SECTION FOR VALUES OF THIS PARAMETER 9. SEE THE TYPICAL CHARACTERISTI
UNDER ALTERNATE CONDITIONS.
10. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\text { RAS/CAS 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., 2118-10 S6329 WILL OPERATE AS A 2118-10).

PAGE MODE


PAGE MODE READ-MODIFY-WRITE CYCLE


NOTES: 1,2. $V_{I H}$ 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$ |hol.
6. tDS AND tDH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST
7. trCH IS REFERENCED TO THE TRAILING EDGE OF $\overline{C A S}$ OR RAS, WHICHEVER OCCURS FIRST
8. t CRP $^{2}$ REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A CAS-
8. tcRP REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY
ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## TYPICAL SUPPLY CURRENT WAVEFORMS

$\overline{\mathbf{R A S}} / \overline{\mathbf{C A S}}$



RAS ONLY REFRESH



LONG $\overline{\text { RAS }} / \overline{\text { CAS }}$



Typical power supply waveforms vs. time are shown for the $\overline{\text { RAS }} / \overline{\mathrm{CAS}}$ timings of Read/Write, Read/Write (Long $\overline{\mathrm{RAS}} / \overline{\mathrm{CAS}})$, and $\overline{\mathrm{RAS}}$-only refresh cycles. I DD current transients at the $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ edges require adequate decoupling of these supplies.

The effects of cycle time, $\mathrm{V}_{\mathrm{DD}}$ supply voltage and ambient
temperature on the IDD current are shown in graphs included in the Typical Characteristics Section. Each family of curves for $I_{D D 1}, I_{D D 2}$, and $I_{D D 3}$ is related by a common point at $V_{D D}=5.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, $V_{D D}$ and $T_{A}$ can be determined by combining the effects of the appropriate family of curves.

## TYPICAL CHARACTERISTICS

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


GRAPH 4
TYPICAL STANDBY CURRENT IDD1 VS. AMBIENT TEMPERATURE


GRAPH 7
TYPICAL OPERATING CURRENT IDD2 VS. AMBIENT TEMPERATURE


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


GRAPH 5
TYPICAL OPERATING CURRENT $I_{D D 2}$ VS. $\mathrm{t}_{\mathrm{RC}}$


GRAPH 8
TYPICAL RAS ONLY REFRESH CURRENT
$I_{D D 3}$ VS. $t_{R C}$


GRAPH 3
TYPICAL STANDBY CURRENT IDD1 $^{\text {VS. }}$ DD


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


GRAPH 9
TYPICAL $\overline{R A S}$ ONLY REFRESH CYCLE $I_{D D 3}$ VS. VDD


## TYPICAL CHARACTERISTICS



## DEVICE DESCRIPTION

The Intel® 2118 is produced with HMOS, a high performance MOS technology which incorporates on chip substrate bias generation. This process, combined with new circuit design concepts, allows the 2118 to operate from a single +5 V power supply, eliminating the +12 V and -5 V requirements. Pins 1 and 9 are not connected, which allows P.C.B. layout for future higher density memory generations.

The 2118 is functionally compatible with the industry standard 16 -pin 16 K dynamic RAMs, except for the power supply requirements. Replacing the +12 V supply with a +5 V supply and eliminating the -5 V bias altogether, allows simple upgrade both in power and performance. To achieve total speed performance upgrade, however, the timing ciruitry must be modified to accommodate the higher performance.

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

$$
\text { 1. } t_{A C C}=t_{R A C} \quad O R \quad \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, $t_{R C D}$, are system dependent timing
parameters. For example, substituting the device parameters of the 2118-3 yields:

$$
\begin{aligned}
& \text { 3. } t_{A C C}=t_{R A C}=100 \mathrm{nsec} \text { for } 25 \mathrm{nsec} \leq t_{R C D} \leq 45 \mathrm{nsec} \\
& \text { OR }
\end{aligned}
$$

4. $t_{A C C}=t_{R C D}+t_{C A C}=t_{R C D}+55 \mathrm{nsec}$ for $t_{R C D}>45 \mathrm{nsec}$ Note that if $25 \mathrm{nsec} \leq \mathrm{t}_{\mathrm{RCD}} \leq 45 \mathrm{nsec}$ device access time is determined by equation 3 and is equal to trac. If $t_{R C D}>$ 45 nsec access time is determined by equation 4 . This 20nsec 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{\text { CAS }}$.

## REFRESH CYCLES

Each of the 128 rows of the 2118 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. 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{\text { RAS }}-$ only refresh cycle maintains the DOut in the high
impedance state with a typical power reduction of 30\% over a Read or Write cycle.

## $\overline{\text { RAS }} / \overline{\text { CAS TIMING }}$

$\overline{\mathrm{RAS}}$ and $\overline{\mathrm{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 bringing $\overline{\mathrm{RAS}}$ and/or 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 2118 Data Output (DOUT), which has three-state capability, is controlled by $\overline{C A S}$. During $\overline{\text { CAS }}$ high state ( $\overline{C A S}$ at $V_{(H)}$ ) the output is in the high impedance state. The following table summarizes the DOUT state for various types of cycles.

Intel 2118 Data Output Operation for Various Types of Cycles
\(\left.$$
\begin{array}{l|l}\text { Type of Cycle } & \text { Dout State } \\
\hline \text { Read Cycle } & \begin{array}{l}\text { Data From Addressed } \\
\text { Memory Cell }\end{array} \\
\text { Early Write Cycle } & \mathrm{HI}-\mathrm{Z} \\
\overline{\text { RAS-Only Refresh Cycle }} \begin{array}{l}\mathrm{HI}-\mathrm{Z} \\
\overline{\text { CAS-Only Cycle }}\end{array}
$$ \& \mathrm{HI}-\mathrm{Z} <br>
Read/Modify/Write Cycle \& Data From Addressed <br>

Memory Cell\end{array}\right\}\)| Indeterminate |
| :--- |

## HIDDEN REFRESH

An optional feature of the 2118 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 ( $t_{\text {RP }}$ ), executing a " $\overline{R A S}-O n l y$ " refresh cycle, but with $\overline{C A S}$ held low (see Figure 1.)


Figure 1. Hidden Refresh Cycle.

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

## POWER ON

After the application of the $V_{D D}$ supply, or after extended periods of bias (greater than 2 ms ) without clocks, the device must perform a minimum of eight (8) initialization cycles (any combination of cycles containing a $\overline{\mathrm{RAS}}$ clock such as $\overline{\text { RAS }}$-only refresh) prior to normal operation.

The $V_{D D}$ current (IDD) requirement of the 2118 during power on is, however, dependent upon the input levels of $\overline{R A S}$ and CAS. If the input levels of these clocks are at $\mathrm{V}_{1 H}$ or $V_{D D}$, whichever is lower, the $I_{D D}$ requirement per device is $I_{D D 1}$ (IDD standby). If the input levels for these clocks are lower than $V_{I H}$ or $V_{D D}$ the $I_{D D}$ requirement will be greater than IDD1, as shown in Figure 2.


Figure 2. Typical $I_{D D}$ VS $V_{D D}$ during power up.

For large systems, this current requirement for IDD could be substantially more than that for which the system has been designed. A system which has been designed, assuming the majority of devices to be operating in the refresh/standby mode, may produce sufficient IDD loading such that the power supply may current limit. To assure that the system will not experience such loading during power on, a pullup resistor for each clock input to $V_{D D}$ to maintain the non-selected current level (IDD1) for the power supply is recommended.

## 2128 <br> $2048 \times 8$-BIT STATIC RAM

|  | $2128-15$ | $2128-20$ |
| :---: | :---: | :---: |
| Max. Access Time (ns) | 150 | 200 |
| Max. Active Current (mA) | 120 | 120 |
| Max. Standby Current (mA) | 30 | 30 |

## Fully Static Operation; No Clocks, Refresh or Latches

## - EPROM Compatible Pinout

## - Industry Standard 24-Pin Package

## - Two Line Control, $\overline{\text { CE }}$ Controls PowerDown, $\overline{\text { OE Controls Output Buffers - }}$ Eliminates Bus Contention

## - 150 ns Maximum Access Time

- Auto Power-Down

The Intel $2 \mathrm{~K} \times 8$ is a 16,384 -bit static RAM organized as 2048 words by 8 bits. It employs fully static circuitry which eliminates the need for clocks, refresh, or address setup and hold times. The auto powerdown feature cuts power consumption when the device is disabled.

The 24-pin industry standard pinout allows easy upgrades to $4 \mathrm{~K} \times 8$ static RAMs and compatibility to the $27324 \mathrm{~K} \times 8$ and $27648 \mathrm{~K} \times 8$ EPROMs in 28 -pin sites. The two line control simplifies decoding and eliminates any possibility of bus contention.

## TRUTH TABLE

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

## PIN NAMES

| $A_{0}-A_{11}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | CHIP ENABLE |
| $\overline{\mathrm{OE}}$ | OUTPUT ENABLE |
| $\overline{\mathrm{WE}}$ | WRITE ENABLE |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | DATA INPUTIOUTPUT |
| $\mathrm{V}_{\mathrm{CC}}$ | POWER $(+5 \mathrm{~V})$ |
| GND | GROUND |

LOGIC SYMBOL $2 \mathrm{~K} \times 8$ SRAM


COMPATIBLE PINOUTS

| EPROM | SRAM |  |  |
| :---: | :---: | :---: | :---: |
| $8 \mathrm{~K} \times 8$ | $8 \mathrm{~K} \times 8$ | $4 \mathrm{~K} \times 8$ | $2 \mathrm{~K} \times 8$ |
| $\mathrm{V}_{\mathrm{pp}}$ | NC | NC |  |
| $A_{12}$ | $A_{12}$ | NC |  |
| $A_{7}$ | $A_{7}$ | $\mathrm{A}_{7}$ | $A_{7}$ |
| $\mathrm{A}_{6}$ | $\mathrm{A}_{6}$ | $\mathrm{A}_{6}$ | $\mathrm{A}_{6}$ |
| $A_{5}$ | $\mathrm{A}_{5}$ | $A_{5}$ | $A_{5}$ |
| $\mathrm{A}_{4}$ | $\mathrm{A}_{4}$ | $A_{4}$ | $A_{4}$ |
| $A_{3}$ | $A^{\prime}$ | $A_{3}$ | $\mathrm{A}_{3}$ |
| $A_{2}$ | $\mathrm{A}_{2}$ | $A_{2}$ | $\mathrm{A}_{2}$ |
| $A_{1}$ | $A_{1}$ | $A_{1}$ | $A_{1}$ |
| $A_{0}$ | $\mathrm{A}_{0}$ | $A_{0}$ | $\mathrm{A}_{0}$ |
| $\mathrm{D}_{0}$ | $\mathrm{D}_{0}$ | $\mathrm{D}_{0}$ | $D_{0}$ |
| $\mathrm{D}_{1}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{1}$ |
| $\mathrm{D}_{2}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{2}$ |
| GND | GND | GND | GND |



| SRAM |  |  | EPROM |
| :---: | :---: | :---: | :---: |
| $2 \mathrm{~K} \times 8$ | 4K $\times 8$ | $8 \mathrm{~K} \times 8$ | $8 \mathrm{~K} \times 8$ |
|  | $V_{\text {cc }}$ | $\mathrm{V}_{\text {cc }}$ | Vcc |
|  | WE | WE | PGM |
| $\mathrm{V}_{\text {cc }}$ | NC | NC | NC |
| $\mathrm{A}_{B}$ | $\mathrm{A}_{8}$ | $\mathrm{A}_{8}$ | $A_{8}$ |
| $A_{9}$ | $\mathrm{A}_{9}$ | $\mathrm{A}_{9}$ | $\mathrm{A}_{9}$ |
| WE | $A_{11}$ | $A_{11}$ | $A_{11}$ |
| $\overline{\mathbf{O E}}$ | $\overline{\mathbf{O E}}$ | $\overline{\mathbf{O E}}$ | $\overline{\mathbf{O E}}$ |
| $A_{10}$ | $\mathrm{A}_{10}$ | $A_{10}$ | $\mathrm{A}_{10}$ |
| $\overline{\mathbf{C E}}$ | $\overline{\mathbf{C E}}$ | $\overline{C E}$ | CE |
| $\mathrm{D}_{7}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{7}$ |
| $\mathrm{D}_{6}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{6}$ |
| $\mathrm{D}_{5}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{5}$ |
| $\mathrm{D}_{4}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{4}$ |
| $\mathrm{D}_{3}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{3}$ |

[^2]
## 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 | -3.5 V to +7 V |
| Power Dissipation. | .1.0W |
| D.C. Output Current | . 10 mA |


#### Abstract

*NOTICE: 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 10 \%$, unless otherwise noted.

| Symbol | Parameter | 2128-15/20 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ Max. |  |  |
| $I_{L I}$ | Input Load Current (All Input Pins) |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.5 V |
| $\mid \mathrm{l}$ LO\| | Leakage Current |  | 10 | $\mu \mathrm{A}$ | $\overline{\mathrm{CE}}=\mathrm{V}_{1 \mathrm{H}}, \mathrm{V}_{\mathrm{D}}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $I_{C C}$ | Power Supply Current (Active) |  | 120 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{Max}_{.,} \mathrm{I}_{1 / 0}=0 \mu \mathrm{~A}, \\ & \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}, \mathrm{CE}=\mathrm{V}_{\mathrm{IL}} \end{aligned}$ |
| $I_{\text {SB }}$ | Power Supply Current (Standby) |  | 30 | mA | $\begin{aligned} & V_{C C}=M a x ., I_{1 / O}=0 \mathrm{~mA}, \\ & T_{A}=0^{\circ} \mathrm{C}, \overline{\mathrm{CE}}=\mathrm{V}_{1 \mathrm{H}} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $-3.0$ | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | 6.0 | V |  |
| loL | Output Low Current | 4.0 |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| $\mathrm{IOH}^{\text {O}}$ | Output High Current | 2.0 |  | mA | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |

## A.C. CONDITIONS OF TEST



Load B. (FOR HIGH IMPEDANCE MEASUREMENTS ONLY)

## CAPACITANCE

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

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

NOTE:
This parameter is periodically 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 \%$
READ CYCLE

| Symbol | Parameter |  | 2128-15 |  | 2128-20 |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle Time | 150 | - | 200 | - | ns |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address Access Time | - | 150 | - | 200 | ns |
| $\mathrm{t}_{\mathrm{CE}}$ | Chip Select Access Time | - | 150 | - | 200 | ns |
| $\mathrm{t}_{\mathrm{OE}}$ | Output Enable Time | - | 50 | - | 65 | ns |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold Time from Address Change, $\overline{\mathrm{CE}}, \overline{\mathrm{OE}}$ | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\mathrm{CLZ}}$ | Output in Low Z from $\overline{\mathrm{CE}}$ | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\mathrm{CHZ}}$ | Output in High Z from $\overline{\mathrm{CE}}$ | - | 50 | - | 65 | ns |
| $\mathrm{t}_{\mathrm{OLZ}}$ | Output in Low Z from $\overline{\mathrm{OE}}$ |  | - | - | 0 | - |
| $\mathrm{t}_{\mathrm{OHZ}}$ | Output in High Z from $\overline{\mathrm{OE}}$ | ns |  |  |  |  |

## TIMING WAVEFORMS

## READ CYCLE



NOTE: READ CYCLE

1. WE is high for Read Cycle.

## A.C. CHARACTERISTICS (Continued)

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

| Symbol | Parameter | 2128-15 |  | 2128-20 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {wc }}$ | Write Cycle Time | 150 | - | 200 | - | ns |
| ${ }^{\text {c }}$ W | Chip Selection to End of Write | 150 | - | 200 | - | ns |
| $t_{\text {AS }}$ | Address Setup Time | 0 | - | 0 | - | ns |
| $t_{\text {WP }}$ | Write Pulse Width | 75 | - | 100 | - | ns |
| ${ }^{\text {t }}{ }_{\text {AW }}$ | Address Valid to End of Write | 150 | - | 200 | - | ns |
| $t_{\text {WR }}$ | Write Recovery Time | 0 | - | 0 . | - | ns |
| $t_{\text {DS }}$ | Data Setup Time | 50 | - | 65 | - | ns |
| $t_{\text {DH }}$ | Data Hold Time | 0 | - | 0 | - | ns |
| $\mathrm{twiz}^{[3]}$ | Output in Low Z from $\overline{\text { WE }}$ High | 0 | - | 0 | - | ns |
| ${ }^{\text {twhz }}$ | Output in High Z from WE Low | - | 50 | - | 65 | ns |

## WRITE CYCLE



NOTES: WRITE CYCLE

1. Write may be terminated by either $\overline{\mathrm{CE}}$ or $\overline{\mathrm{WE}}$.
2. Output in High $\mathbf{Z}$ will occur from $\overline{W E}$ low or $\overline{\mathrm{OE}}$ high or $\overline{\mathrm{CE}}$ high, whichever is first.
3. If $\overline{O E}$ is high, $\mathrm{t}_{\text {WIZ }}$ is invalid - $\mathrm{D}_{\text {OUT }}$ remains in the high impedance state.

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

## - Directly TTL Compatible - All Inputs and Output

- Separate Data Input and Output
- Three-State Output

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


LOGIC SYMBOL

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{\text { CS }}$ | $\overline{\text { WE }}$ | MODE | OUTPUT | POWER |
| :---: | :---: | :---: | :---: | :---: |
| H | X | NOT SELECTED | HIGHZ | STANDBY |
| L | L | WRITE | HIGHZ | 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 ................................ 20mA
```

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

|  | Parameter | 2141-2/-3 |  |  | 2141-4/-5 |  |  | 2141L-3/L-4/L-5 |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Typ. ${ }^{[1]}$ | Max. | Min. | Typ. ${ }^{[1]}$ | Max. | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $\left\|I_{\text {LI }}\right\|$ | Input Load Current (All Input Pins) |  | 0.01 | 10 |  | 0.01 | 10 |  | 0.01 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max., $\mathrm{V}_{\mathrm{IN}}=$ GND to $V_{c c}$ |
| \|licol | Output Leakage Current |  | 0.1 | 10 |  | 0.1 | 10 |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{\text {IH }}, V_{C C}=\text { Max., } \\ & \text { VOUT }=\text { GND to } 4.5 \mathrm{~V} \end{aligned}$ |
| Icc | Operating Current |  | 45 | 70 |  | 40 | 55 |  | 30 | 40 | mA | $\text { VCC }=\text { Max., } \overline{C S}=V_{I L},$ <br> 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 $\mathrm{V}_{\mathrm{IH}}$ Min. |
| VIL | Input Low Voltage | -1.0 |  | 0.8 | -1.0 |  | 0.8 | -1.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | 6.0 | $2.0{ }^{\circ}$ |  | 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}$ |
| V OH | Output High Voltage | 2.4 |  |  | 2.4 |  |  | 2.4 |  |  | V | $1 \mathrm{OH}=-4.0 \mathrm{~mA}$ |
| $10{ }^{[3]}$ | Output Short Circuit Current | -120 |  | 120 | -120 |  | 120 | -120 |  | 120 | mA | Vout=GND to Vcc |

Notes: 1. Typical limits are at $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{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 <br> Input Rise and Fall Times <br> Input and Output Timing Reference <br> Levels | GND to 3.5 Volts |
| :--- | :---: |
| Output Load | 10 nsec |

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

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

| Symbol | Parameter | Max. | Unit | Conditions |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ |
| COUT | Output Capacitance | 6 | pF | $\mathrm{V}_{\text {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}, V_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.
READ 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. |  |
| thc | Read Cycle Time | 120 |  | 150 |  | 200 |  | 250 | \% | ns |
| $t_{\text {AA }}$ | Address Access Time |  | 120 |  | 150 |  | 200 |  | 250 | ns |
| tacsi ${ }^{[1]}$ | Chip Select Access Time |  | 120 |  | 150 |  | 200 |  | 250 | ns |
| tacs2 ${ }^{[2]}$ | Chip Select Access Time |  | 130 |  | 160 |  | 200 |  | 250 | ns |
| tor | Output Hold from Address Change | 10 |  | 10 |  | 10 |  | 10 |  | ns |
| tLz ${ }^{[3]}$ | Chip Selection to Output in Low $\mathbf{Z}$ | 30 |  | 30 |  | 30 |  | 30 |  | ns |
| $\mathrm{thz}^{(3)}$ | Chip Deselection to Output in High Z | 0 | 60 | 0 | 60 | 0 | 60 | 0 | 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 $0 n s$, 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 tLz 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{C S}=V_{I L}$
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{VCC}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

## WRITE CYCLE

| Symbol | Parameter | $\begin{aligned} & 2141-2 \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & 2141-3 / \text { L-3 } \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & \text { 2141-4/L-4 } \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & \text { 2141-5/L-5 } \\ & \text { Min. Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 | 1070 | 1080 | 1080 | 1080 | ns |
| tow | Output Active from End of Write | 5 | 5 | 5 | 5 | ns |

## WAVEFORMS

## WRITE CYCLE \#1 (WE 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 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


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


FIGURE 3. $t_{\text {ACS }}$ 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 \times 4$ BIT STATIC RAM

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

- High Density 20 Pin Package
- Access Time Selections From 200-450ns
- Identical Cycle and Access Times
- Low Operating Power Dissipation $.1 \mathrm{~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.

PIN CONFIGURATION
LOGIC SYMBOL


PIN NAMES

| $A_{0}-A_{9}$ | ADDRESS INPUTS | OD | OUTPUT DISABLE |
| :--- | :--- | :--- | :--- |
| WE | WAITE ENABLE | VCC | POWER ( +5 V ) |
| CS $_{1}, \mathrm{CS}_{2}$ | CHIP SELECT | GND | GROUNO |
| $1 / \mathrm{O}_{1}-1 / \mathrm{O}_{4}$ | DATA INPUT/OUTPUT |  |  |

BLOCK DIAGRAM


## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias |  |
| :---: | :---: |
| Storage Temperature | C to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.5 V to +7 V |
| Power Dissipation | 1.0 W |
| D.C. Output Current | 10 mA |

*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of the 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 |  |  | 2142L3, 2142L. |  |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\left\|I_{L I}\right\|$ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V |
| \|lol | 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}$ |
| ICC1 | 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}$ |
| ${ }^{\text {I CC2 }}$ | 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}$ |
| $\mathrm{los}^{[2]}$ | Output Short Circuit Current |  |  | 60 |  |  | 60 | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CG }}$ to GND |

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}}=\mathbf{2 5}{ }^{\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.4 Volt
Input Rise and Fall Times . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . }10\mathrm{ nsec
Input and Output Timing Levels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.5 Volts
```

Output Load . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 TTL Gate and CL $=100$ 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$ <br> Min. Max. | 2142-3, 2142L3 | 2142, 2142L | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. Max. | Min. Max. |  |
| $\mathrm{t}_{\mathrm{R}}$ | Read Cycle Time | 200 | 300 | 450 | ns |
| ${ }_{t}$ | 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 |
| $\mathrm{t}_{\mathrm{CO}}$ | Chip Selection to Output Valid | 70 | 100 | 120 | ns |
| ${ }_{\text {t }} \mathrm{Cx}$ | Chip Selection to Output Active | 20 | 20 | 20 | ns |
| totD | Output 3-state from Disable | 60 | 80 | 100 | ns |
| toha | Output Hold from Address Change | 50 | 50 | 50 | ns |

WRITE CYCLE [2]

|  | PARAMETER | 2142-2 |  | 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 |
| $\mathrm{t}_{\text {OtD }}$ | Output 3-state from Disable |  | 60 |  | 80 |  | 100 | ns |
| tDW | 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{\overline{C S}}$ 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. 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


OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE


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

|  | $2147 \mathrm{~A}-3$ | $2147 \mathrm{AL}-3$ | 2147 A | 2147 AL |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 55 | 55 | 70 | 70 |
| Max. Active Current (mA) | 50 | 35 | 50 | 35 |
| Max. Standby Current (mA) | 20 | 12 | 20 | 10 |

- Pinout and Functionally Compatible with the Industry Standard 2147H and the 6147
- Low Power Operation - 275 mW Maximum
- Lower Input/Output Leakage Current
- 0.8-2.0V Output Timing Reference Level
- Automatic Power Down Mode
- High Density 18-Pin Plastic/Cerdip Package
- Advanced HMOS-II Technology
- Directly TTL Compatible-All Inputs and Outputs
- Improved Output Current Drive
- Three-State Output for Bus Interface

The Intel 2147 A is a 4096 words by 1 bit static RAM designed for low power dissipation of 275 mW maximum. The 2147A is fully compatible with the industry standard 2147 H and is fabricated on Advanced HMOS-II, an evolution of HMOS-II technology - a production proven process for high reliability, high performance, and high storage density.
The 2147A is fully static which results in reduced overhead costs by elimination of refresh clocking circuitry and by simplification of timing requirements. When deselected, the 2147A automatically changes into a low power standby mode and maintains this state until the chip select signal, CS, is low.
Accordingly, the 2147A is suitable for use in applications such as instrumentation, telecommunications, caches, writeable control store, fast buffer memories and large memory systems in which a majority of units are deselected.
The 2147A is placed in an 18 pin plastic or cerdip package and 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
$A_{0} \square 1$
$A_{1} \square 2$
$A_{2} \square$
$A_{3} \square V_{C C}$
$A_{4} \square 5$

LOGIC SYMBOL


PIN NAMES

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

TRUTH TABLE

| CS | WE | MODE | OUTPUT | POWER |
| :---: | :---: | :---: | :---: | :---: |
| $H$ | $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 . . . . . . . . . . . . -3.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 ${ }^{[1]}$

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

| Symbol | Parameter | $\mathrm{Min}^{2}$ | 147A.3 <br> Typ. Max. | $\begin{array}{\|c\|} 2 \\ \text { Min. } \end{array}$ | 47AL-3 <br> Typ. Max. | Min. | $\begin{aligned} & \text { 2147A } \\ & \text { Typ. } \end{aligned}$ | Max. | Min. | $\begin{aligned} & \text { 2147AL } \\ & \text { Typ. } \end{aligned}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\left\|L_{\text {LI }}\right\|$ | Input Load Current (All Input Pins) |  | 1 |  | 1 |  |  | 1 |  |  | 1 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=\text { Max. } \\ & V_{\text {IN }}=\text { GND to } V_{C C} \end{aligned}$ |
| \|low | Output Leakage Current |  | 10 |  | 10 |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{1 H}, V_{C C}=\text { Max., } \\ & V_{\text {OUT }}=G N D \text { to } 4.5 \mathrm{~V} \end{aligned}$ |
| $I_{\text {cc }}$ | Operating Current |  | 50 |  | 35 |  |  | 50 |  |  | 35 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { Max. } \\ & \mathrm{CS}=\mathrm{V}_{\mathrm{IL}}, \\ & \text { Outputs Open } \end{aligned}$ |
| $\mathrm{I}_{\text {SB }}$ | Standby Current |  | 20 |  | 12 |  |  | 20 |  |  | 10 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { Min. to Max., } \\ & \mathrm{CS}=\mathrm{V}_{\mathrm{IH}} \end{aligned}$ |
| $\mathrm{IPO}^{[3]}$ | Peak Power-On Current |  | 18 |  | 18 |  |  | 18 |  |  | 18 | mA | $\begin{aligned} & V_{C C}=G N D \text { to } V_{C C} \text { Min., } \\ & C S=\text { Lower of } V_{C C} \text { or } V_{I H} \text { Min. } \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -3.0 | 0.8 | -3.0 | 0.8 | -3.0 |  | 0.8 | -3.0 |  | 0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 | 6.0 | 2.0 | 6.0 | 2.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.4 |  | 0.4 |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=12 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | 2.4 |  | 2.4 |  |  | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-8 \mathrm{~mA}$ |
| $\mid \mathrm{IOS}{ }^{[4]}$ | Output Short Circuit Current |  | 275 |  | 275 |  |  | 275 |  |  | 275 | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ to $\mathrm{V}_{\text {CC }}$ |

## NOTES:

1. The operating ambient temperature range is guaranteed with transverse air flow exceeding 400 linear feet per minute. Typical thermal resistance values of the package at maximum temperatures are

$$
\begin{aligned}
& \theta_{J A}\left(@ 400 \mathrm{f}_{\mathrm{PM}} \text { air flow }\right)=40^{\circ} \cdot \mathrm{C} / \mathrm{W} \\
& \theta_{J A}(\mathrm{still} \text { air })=70^{\circ} \mathrm{C} / \mathrm{W} \\
& \theta_{J C}=25^{\circ} \mathrm{C} / \mathrm{W}
\end{aligned}
$$

2. Typical limits are at $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, and specified loading.
3. A pull-up resistor to $\mathrm{V}_{\mathrm{CC}}$ on the CS input is required to keep the device deselected; otherwise, power-on current approaches Icc active.
4. Duration not to exceed 1 sec .

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | ---: |
| Input Rise and Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | $0.8-2.0 \mathrm{~V}$ |
| Output Load | See Figure 1 |

CAPACITANCE ${ }^{[5]}\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| 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 }}=\mathrm{OV}$ |

## NOTE:

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


Figure 1. Output Load


Figure 2. Output Load for $t_{H Z}, t_{L Z}, t_{w Z}$, tow

## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.) <br> Read Cycle

| Symbol | Parameter | $\begin{gathered} \text { 2147A-3, } 2147 A L-3 \\ \text { Min. Max. } \end{gathered}$ | $\begin{aligned} & \text { 2147A, } 2147 \mathrm{AL} \\ & \text { Min. Max. } \end{aligned}$ | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $t_{R C}{ }^{[1]}$ | Read Cycle Time | 55 | 70 | ns |
| $t_{A A}$ | Address Access Time | 55 | 70 | ns |
| $\mathrm{t}_{\text {ACS } 1}{ }^{[8]}$ | Chip Select Access Time | 55 | 70 | ns |
| . $\mathrm{taCS2}^{[9]}$ | Chip Select Access Time | 65 | 80 | ns |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from Address Change | 5 | 5 | ns |
| $t_{17}{ }^{[2,3,7]}$ | Chip Selection to Output in Low Z | 10 | 10 | ns |
| $t_{H Z}{ }^{[2,3,7]}$ | Chip Deselection to Output in High Z | 030 | $0 \quad 40$ | ns |
| $t_{\text {PU }}$ | Chip Selection to Power Up Time | 0 | 0 | ns |
| $t_{\text {PD }}$ | Chip Deselection to Power Down Time | 20 | 30 | ns |

## WAVEFORMS

Read Cycle No. $1^{[4,5]}$


Read Cycle No. 2 ${ }^{[4,6]}$


## NOTES:

1. All Read Cycle timings are referenced from the last valid address to the first transitioning address.
2. 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.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2.
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.
7. This parameter is sampled and not $100 \%$ tested.
8. Chip deselected for greater than 55 ns prior to selection.
9. Chip deselected for a finite time that is less than 55 ns prior to selection. (If the deselect time is 0 ns , the chip is by definition selected and access occurs according to Read Cycle No. 1. Applies to 2147A, 2147AL, 2147A-3, and 2147AL-3.

## A.C. CHARACTERISTICS (Continued) <br> Write Cycle

| Symbol | Parameter | $\begin{aligned} & \text { 2147A-3, } 2147 \mathrm{AL}-3 \\ & \text { Min. Max. } \end{aligned}$ | $\text { 2147A, } 2147 \text { AL }$ Min. Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $t_{w c}{ }^{[2]}$ | Write Cycle Time | 55 | 70 | ns |
| $\mathrm{t}_{\mathrm{CW}}$ | 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 |
| $t_{\text {wp }}$ | Write Pulse Width | 35 | 40 | ns |
| $t_{\text {WR }}$ | Write Recovery Time | 10 | 15 | ns |
| $t_{\text {DW }}$ | Data Valid to End of Write | 25 | 30 | ns |
| $t_{\text {DH }}$ | Data Hold Time | 10 | 10 | ns |
| $t_{W z}{ }^{[3]}$ | Write Enabled to Output in High Z | 025 | 035 | ns |
| $\mathrm{t}_{0}{ }^{[3]}$ | Output Active from End of Write | 0 | 0 | ns |

## WAVEFORMS <br> Write Cycle No. 1 (WE CONTROLLED) ${ }^{4]}$

Write Cycle No. 2 ( $\overline{C S}$ CONTROLLED) ${ }^{[4]}$

## NOTES:



1. If $\overline{\mathrm{CS}}$ goes high simultaneously with $\overline{\mathrm{WE}}$ high, the output remains in a high impedance state.
2. All Write Cycle timings are referenced from the last valid address to the first transitioning address.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2 .
4. $\overline{\mathrm{CS}}$ or $\overline{\mathrm{WE}}$ must be high during address transitions.

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

|  | $2147 \mathrm{H}-1$ | $2147 \mathrm{H}-2$ | $2147 \mathrm{H}-3$ | $2147 \mathrm{HL}-3$ | 2147 H | 2147 HL |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 35 | 45 | 55 | 55 | 70 | 70 |
| Max. Active Current (mA) | 180 | 180 | 180 | 125 | 160 | 140 |
| Max. Standby Current (mA) | 30 | 30 | 30 | 15 | 20 | 10 |

- Pinout, Function, and Power Compatible to Industry Standard 2147
- HMOS II Technology
- Completely Static Memory-No Clock or Timing Strobe Required
- Equal Access and Cycle Times
- Single +5V Supply
- 0.8-2.0V Output Timing Reference Levels
- Direct Performance Upgrade for 2147
- Automatic Power-Down
- High Density 18-Pin Package
- Directly TTL Compatible-AlI Inputs and Output
- Separate Data Input and Output
- Three-State Output

The Intel ${ }^{\circledR} 2147 \mathrm{H}$ is a 4096 -bit static Random Access Memory organized as 4096 words by 1 -bit using HMOS-II, Intel's next generation 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{C S}$ controls the power-down feature. In less than a cycle time after $\overline{\mathrm{CS}}$ goes high-deselecting the 2147H -the part automatically reduces its power requirements and remains in this low power standby mode as long as $\overline{C S}$ 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 2147 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.


## 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 | 3.5 V to +7 V |
| Power Dissipation | 1.2W |
| D.C. Output Curren | 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 ${ }^{[1]}$

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

| Symbol | Parameter | $\text { 2147H-1, 2, } 3$ |  |  | 2147HL-3 |  |  | 2147H |  |  | 2147HL |  |  | Unit | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current (All Input Pins) |  | 0.01 | 10 |  | 0.01 | 10 |  | 0.01 | . 10 |  | 0.01 | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \left.V_{C C}=M a\right) \\ & V_{I N}=G N D \end{aligned}$ | $\circ V_{C C}$ |
| \|lol | Output Leakage Current |  | 0.1 | 50 |  | 0.1 | 50 |  | 0.1 | 50 |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{1 H}, \\ & V_{\text {OUT }}=G N \end{aligned}$ | $\begin{aligned} & C C=M a x ., \\ & D \text { to } 4.5 \mathrm{~V} \end{aligned}$ |
| ICC | Operating Current |  | 120 | 170 |  |  | 115 |  | 100 | 150 |  | 100 | 135 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\text { Max., } \\ & \mathrm{CS}=\mathrm{V}_{1 \mathrm{~L}} \\ & \text { Outputs Open } \end{aligned}$ |
|  |  |  |  | 180 |  |  | 125 |  |  | 160 |  |  | 140 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |  |
| $\mathrm{I}_{\text {SB }}$ | Standby Current |  | 18 | 30 |  | 6 | 15 |  | 12 | 20 |  | 7 | 10 | mA | $\begin{aligned} & V_{C C}=\text { Min. to Max., } \\ & C S=V_{I H} \end{aligned}$ |  |
| $\mathrm{IPO}^{[3]}$ | Peak Power-On Current |  | 35 | 70 |  | 25 | 50 |  | 25 | 50 |  | 15 | 30 | mA | $\begin{aligned} & V_{C C}=G N D \text { to } V_{C C} \text { Min., } \\ & C S=\text { Lower of } V_{C C} \text { or } V_{T H} \text { Min. } \end{aligned}$ |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -3.0 |  | 0.8 | -3.0 |  | 0.8 | -3.0 |  | 0.8 | -3.0 |  | 0.8 | V |  |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 |  | 6.0 | 2.0 |  | 6.0 | 2.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 |  |  | 0.4 |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{l}_{0 \mathrm{~L}}=8 \mathrm{~mA}$ |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | 2.4 |  |  | 2.4 |  |  | 2.4 |  |  | V | $1 \mathrm{IOH}^{2}=-4.0$ | mA |

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. A pull-up resistor to $\mathrm{V}_{\mathrm{CC}}$ on the CS input is required to keep the device deselected; otherwise, power-on current approaches $\mathrm{I}_{\mathrm{CC}}$ active.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | ---: |
| Input Rise and Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Level (2147H-1) | 1.5 V |
| Output Timing Reference Levels |  |
| (2147H, H-2, H-3, HL, HL-3) | $0.8-2.0 \mathrm{~V}$ |
| Output Load | See Figure 1 |

CAPACITANCE ${ }^{[4]}$ $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right.$ )

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

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


Figure 1. Output Load


Figure 2. Output Load for $t_{H Z}, t_{L Z}, t_{W Z}$, tow
A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.)

Read Cycle

| Symbol | Parameter | $2147 \mathrm{H}-1$ <br> Min. Max. | $2147 \mathrm{H}-2$ <br> Min. Max. | $\begin{array}{\|c\|} \hline 2147 \mathrm{H}-3, \\ \text { HL-3 } \\ \text { Min. Max. } \\ \hline \end{array}$ | $\begin{aligned} & \hline 2147 \mathrm{H}, \\ & 2147 \mathrm{HL} \end{aligned}$ <br> Min. Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {RC }}{ }^{[1]}$ | Read Cycle Time | 35 | 45 | 55 | 70 | ns |
| $t_{\text {AA }}$ | Address Access Time | 35 | 45 | 55 | 70 | ns |
| $t_{A C S 1}{ }^{[8]}$ | Chip Select Access Time | 35 | 45 | 55 | 70 | ns |
| $\mathrm{t}_{\text {ACS } 2}{ }^{[9]}$ | Chip Select Access Time | 35 | 45 | 65 | 80 | ns |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from Address Change | 5 | 5 | 5 | 5 | ns |
| $\mathrm{t}_{\mathrm{L}} \mathrm{z}^{[2,3,7]}$ | Chip Selection to Output in Low Z | 5 | 5 | 10 | 10 | ns |
| $\mathrm{t}_{\mathrm{Hz}}{ }^{[2,3,7]}$ | Chip Deselection to Output in High Z | $0 \quad 30$ | 030 | 030 | 040 | ns |
| tpu | Chip Selection to Power Up Time | 0 | 0 | 0 | 0 | ns |
| $t_{\text {PD }}$ | Chip Deselection to Power Down Time | 20 | 20 | 20 | 30 | ns |

## WAVEFORMS

Read Cycle No. $1^{[4,5]}$


Read Cycle No. $2^{[4,6]}$


NOTES:

1. All Read Cycle timings are referenced from the last valid address to the first transitioning address.
2. 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.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2.
4. $\overline{\mathrm{WE}}$ is high for Read Cycles.
5. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{LL}}$.
6. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
7. This parameter is sampled and not $100 \%$ tested.
8. Chip deselected for greater than 55 ns prior to selection.
9. Chip deselected for a finite time that is less than 55 ns prior to selection. If the deselect time is 0 ns , the chip is by definition selected and access occurs according to Read Cycle No. 1. Applies to $2147 \mathrm{H}, 2147 \mathrm{HL}, 2147 \mathrm{H}-3$, and $2147 \mathrm{HL}-3$.

## A.C. CHARACTERISTICS (Continued) <br> Write Cycle

| Symbol | Parameter | $2147 \mathrm{H} \cdot 1$ <br> Min. Max. | $2147 \mathrm{H}-2$ <br> Min. Max. | $\begin{array}{\|c\|} \hline 2147 \mathrm{H}-3, \\ \text { HL-3 } \\ \text { Min. Max. } \end{array}$ | $\begin{array}{\|c\|} \hline 2147 \mathrm{H}, \\ 2147 \mathrm{HL} \\ \text { Min. Max. } \end{array}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{twc}^{\text {[2] }}$ | Write Cycle Time | 35 | 45 | 55 | 70 | ns |
| $\mathrm{t}_{\mathrm{CW}}$ | Chip Selection to End of Write | 35 | 45 | 45 | 55 | ns |
| $t_{\text {AW }}$ | Address Valid to End of Write | 35 | 45 | 45 | 55 | ns |
| $t_{\text {AS }}$ | Address Setup Time | 0 | 0 | 0 | 0 | ns |
| $t_{\text {WP }}$ | Write Pulse Width | 20 | 25 | 25 | 40 | ns |
| $t_{\text {WR }}$ | Write Recovery Time | 0 | 0 | 10 | 15 | ns |
| $t_{\text {DW }}$ | Data Valid to End of Write | 20 | 25 | 25 | 30 | ns |
| $t_{\text {DH }}$ | Data Hold Time | 10 | 10 | 10 | 10 | ns |
| $\mathrm{twz}^{[3]}$ | Write Enabled to Output in High Z | 020 | $0 \quad 25$ | 025 | $0 \quad 35$ | ns |
| tow ${ }^{[3]}$ | Output Active from End of Write | 0 | 0 | 0 | 0 | ns |

## WAVEFORMS

Write Cycle No. 1 (WE CONTROLLED) ${ }^{[4]}$

## Write Cycle No. 2

 ( $\overline{\text { CS }}$ CONTROLLED) ${ }^{[4]}$
## NOTES:



1. If $\overline{C S}$ goes high simultaneously with $\overline{W E}$ high, the output remains in a high impedance state.
2. All Write Cycle timings are referenced from the last valid address to the first transitioning address:
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2 .
4. $\overline{\mathrm{CS}}$ or $\overline{\mathrm{WE}}$ must be high during address transitions.

## $1024 \times 4$ BIT STATIC RAM

|  | $2148 \mathrm{H}-2$ | $2148 \mathrm{H}-3$ | 2148 H | $2148 \mathrm{HL}-3$ | 2148 HL |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 45 | 55 | 70 | 55 | 70 |
| Max. Active Current (mA) | 180 | 180 | 180 | 125 | 125 |
| Max. Standby Current (mA) | 30 | 30 | 30 | 20 | 20 |

## - Automatic Power-Down

- Industry Standard 2114A and 2148 Pinout
- HMOS II Technology

■ Functionally Compatible to the 2148

- Completely Static Memory - No Clock or Timing Strobe Required

Equal Access and Cycle Times

- High Density 18-Pin Package
- Common Data Input and Output
- Three-State Output

Single +5V Supply
Fast Chip Select Access 2149H Available

The Intel ${ }^{\circledR} 2148 \mathrm{H}$ is a 4096 -bit static Random Access Memory organized as 1024 words by 4 bits using HMOS II, 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 - disabling the 2148 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 disabled. A non-power-down companion, the 2149 H , is available to provide a fast chip select access time for speed critical applications.

The 2148 H is assembled 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.
PIN CONFIGURATION LOGIC SYMBOL

PIN NAMES

|  | PIN NAMES |
| :--- | :--- |
| $A_{0}-A_{0}$ | ADDRESS INPUTS |
| WE | WRITE ENABLE |
| $C S$ | CHIP SELECT |
| UO |  |
| $V_{1}-$ UO $_{4}$ | DATA INPUTIOUTPUT |
| $V_{\text {CC }}$ | POWER $(+5 V$ |
| QND | GROUND |

TRUTH TABLE

| $\overline{\text { cs }}$ | WE | MODE | 110 | Power |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & H \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \hline X \\ & L \\ & H \\ & \hline \end{aligned}$ | NOT SELECTED WRTIE READ |  | STANDBY Active active |

Figure 1. Pin Configuration, Logic Symbol, Pin Names and Truth Table

Figure 2. 2148H Block Diagram

## ABSOLUTE MAXIMUM RATINGS*

|  |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |

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


## D.C. AND OPERATING CHARACTERISTICS ${ }^{[1]}$

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

| Symbol | Parameter | 2148H-2/H-3/HL-3 |  |  | 2148HLHL-3 |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\|1 \mathrm{LI}\|$ | Input Load Current (All Input Pins) |  | 0.01 | 10 |  | 0.01 | 10 | $\mu \mathrm{A}$ | $V_{C C}=$ max, $V_{\text {IN }}=$ GND to $V_{C C}$ |
| $\mid \mathrm{l}$ Lo\| | Output Leakage Current |  | 0.1 | 50 |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{\text {IH }}, V_{C C}=\max , \\ & V_{\text {OUT }}=G N D \text { to } 4.5 \mathrm{~V} \end{aligned}$ |
| Icc | Operating Current |  | 120 | 180 |  | 90 | 125 | mA | $\begin{aligned} & V_{c c}=\max , \overline{\mathrm{CS}}=V_{\mathrm{IL}} . \\ & \text { Outputs Open } \end{aligned}$ |
| Isb | Standby Current |  | 15 | 30 |  | 10 | 20 | mA | $V_{C C}=\min$ to $\max , \overline{\mathrm{CS}}=\mathrm{V}_{1 \mathrm{H}}$ |
| IPO ${ }^{(3)}$ | Peak Power-On Current |  | 25 | 50 |  | 15 | 30 | mA | $\begin{aligned} & V_{C C}=G N D \text { to } V_{C C} \min , \\ & C S=\text { Lower of } V_{C C} \text { or } V_{I H} \min \end{aligned}$ |
| VIL | Input Low Voltage | $-3.0$ |  | 0.8 | $-3.0$ |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.1 |  | 6.0 | 2.1 |  | 6.0 | V |  |
| Vol | Output Low Voltage |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{lOL}=8 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | 2.4 |  | . | V | $\mathrm{IOH}^{\text {O }}=-4.0 \mathrm{~mA}$ |
| los | Output Short Circuit Current |  | $\pm 250$ | $\pm 275$ |  | $\pm 250$ | $\pm 275$ | mA | Vout $=$ GND to VCC |

## Notes:

1. The operating ambient temperature range is guaranteed with transverse air flow exceeding 400 linear feet per minute. Typical thermal resistance values of the package at maximum temperatures are:

$$
\begin{aligned}
& \theta_{J A} \text { (@ } 400 \text { fPM air flow) }=40^{\circ} \mathrm{C} / \mathrm{W} \\
& \theta_{\mathrm{JA}}(\text { still air })=70^{\circ} \mathrm{C} / \mathrm{W} \\
& \theta_{\mathrm{JC}}=25^{\circ} \mathrm{C} / \mathrm{W}
\end{aligned}
$$

2. Typical limits are at $\mathrm{V}_{\mathrm{Cc}}=5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$, and Load A .
3. A pull-up resistor to $V C c$ on the $\overline{C S}$ input is required to keep the device deselected during power-on. Otherwise, power-on current approaches Icc active.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 Volts |
| :--- | ---: |
| Input Rise and Fall Times | 5 nsec |
| Input and Output Timing <br> Reference Levels | 1.5 Volts |
| Output Load | See Load A. |

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

| Symbol | Parameter | Max. | Unit | Conditions |
| :---: | :---: | :---: | :---: | :--- |
| $C_{\text {IN }}$ | Address/Control Capacitance | 5 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ |
| $\mathrm{C}_{\text {IO }}$ | Input/Output Capacitance | 7 | pF | $\mathrm{V}_{\text {OUT }}=\mathrm{OV}$ |

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 | $\begin{gathered} 2148 \mathrm{H}-2 \\ \text { Min. } \quad \text { Max. } \end{gathered}$ | $\begin{aligned} & \text { 2148H-3/HL-3 } \\ & \text { Min. Max. } \end{aligned}$ | 2148H/HL Min. Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {RC }}$ | Read Cycle Time | 45 | 55 | 70 | ns |  |
| $t_{\text {AA }}$ | Address Access Time | 45 | 55 | 70 | ns |  |
| $\mathrm{t}_{\text {ACS1 }}$ | Chip Select Access Time | 45 | 55 | 70 | ns | Note 1 |
| $\mathrm{t}_{\text {ACS2 }}$ | Chip Select Access Time | 55 | 65 | 80 | ns | Note 2 |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from Address Change | 5 | 5 | 5 | ns |  |
| $\mathrm{t}_{17}$ | Chip Selection Output in Low Z | 20 | 20 | 20 | ns | Note 6 |
| $\mathrm{t}_{\mathrm{Hz}}$ | Chip Deselection to Output in High $\mathbf{Z}$ | $0 \quad 20$ | 020 | $0 \quad 20$ | ns | Note 6 |
| $t_{\text {pu }}$ | Chip Selection to Power Up Time | 0 | 0 | 0 | ns |  |
| $\mathrm{t}_{\text {PD }}$ | Chip Deselection to Power Down Time | 30 | 30 | 30 | ns |  |

## WAVEFORMS

READ CYCLE NO. $1^{13.4}$


READ CYCLE NO. $2^{(3.51}$


Notes:

1. Chip deselected for greater than 55 ns prior to $\overline{\mathrm{CS}}$ transition low.
2. Chip deselected for a finite time that is less than 55 ns prior to $\overline{C S}$ transition low. (If the deselect time is 0 ns , the chip is by definition selected and access occurs according to Read Cycle No. 1.)
3. $\overline{W E}$ is high for Read Cycles
4. Device is continuously selected, $\overline{C S}=V_{1 L}$
5. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
6. Transition is measured $\pm 500 \mathrm{mV}$ from high impedance voltage with Load B. This parameter is sampled and not $100 \%$ tested.

## A.C. CHARACTERISTICS (Continued)

## WRITE CYCLE

| Symbol | Parameter | $\begin{aligned} & 2148 \mathrm{H}-2 \\ & \text { Min. Max. } \end{aligned}$ | $\begin{aligned} & \text { 2148H-3/HL-3 } \\ & \text { Min. Max. } \end{aligned}$ | 2148H/HL Min. Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {wc }}$ | Write Cycle Time | 45 | 55 | 70 | ns |  |
| $\mathrm{t}_{\mathrm{CW}}$ | Chip Selection to End of Write | 40 | 50 | 65 | ns |  |
| $t_{\text {AW }}$ | Address Valid to End of Write | 40 | 50 | 65 | ns |  |
| $t_{\text {AS }}$ | Address Setup Time | 0 | 0 | 0 | ns |  |
| $t_{\text {WP }}$ | Write Pulse Width | 35 | 40 | 50 | ns |  |
| ${ }^{\text {twr }}$ | Write Recovery Time | 5 | 5 | 5 | ns |  |
| $t_{\text {DW }}$ | Data Valid to End of Write | 20 | 20 | 25 | ns |  |
| $t_{\text {DH }}$ | Data Hold Time | 0 | 0 | 0 | ns |  |
| $t_{\text {wz }}$ | Write Enabled to Output in High Z | $0 \quad 15$ | $0 \quad 20$ | 025 | ns | Note 2 |
| tow | Output Active from End of Write | 0 | 0 | 0 | ns | Note 2 |

## WAVEFORMS

WRITE CYCLE No. 1 (WE CONTROLLED)


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


Notes: 1. If $\overline{C S}$ goes high simultaneously with $\overline{W E}$ high, the output remains in a high impedance state.
2. Transition is measured $\pm 500 \mathrm{mV}$ from high impedance voltage with Load B . This parameter is sampled and not 100\% tested.

2149H
$1024 \times 4$ BIT STATIC RAM

|  | $2149 \mathrm{H}-2$ | $2149 \mathrm{H}-3$ | 2149 H | $2149 \mathrm{HL}-3$ | 2149 HL |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Max. Address Access Time (ns) | 45 | 55 | 70 | 55 | 70 |
| Max. Chip Select Access Time (ns) | 20 | 25 | 30 | 25 | 30 |
| Max. Active Current (mA) | 180 | 180 | 180 | 125 | 125 |

## - Fast Chip Select Access Time-20ns Maximum

- HMOS II Technology
- Equal Access and Cycle Times
- Completely Static Memory-No Clock or Timing Strobe Required
- High Density 18-Pin Package
- Common Data Input and Output
- Three-State Output
- Single +5V Supply
- Automatic Power-Down 2148H Available

The Intel ${ }^{\circledR}$ 2149H is a 4096 -bit static Random Access Memory organized as 1024 words by 4 bits using HMOS II, a high performance MOS technology. It provides a maximum chip select access time as low as 20 ns instead of an automatic power-down feature. This fast chip select access time feature increases system throughput. An automatic power-down companion, the 2148 H , is available for power critical applications.

The 2149 H is assembled 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.


Figure 1. 2149H Block Diagram

PIN NAMES

|  | PIN NAMES |
| :--- | :--- |
| $\frac{A_{0}-A_{9}}{W E}$ | ADDRESS INPUTS |
| $\overline{C S}$ | WRITE ENABLE |
| $I / O_{1}-I / O_{4}$ | CHIP SELECT |
| $V_{\text {CC }}$ | POWER INPUTIOUTPUT |
| GND | GROUND |


| TRUTH TABLE |  |  |  |
| :---: | :---: | :---: | :---: |
| $\overline{C S}$ | $\overline{\text { WE }}$ | MODE | NO |
| $H$ | $X$ | NOT SELECTED | HIGH:Z |
| L | L | WRITE | $D_{\text {IN }}$ |
| L | $H$ | READ | DOUT |

Figure 2. 2149H Pin Diagram

## ABSOLUTE MAXIMUM RATINGS*



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


## D.C. AND OPERATING CHARACTERISTICS" ${ }^{\prime \prime}$

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

|  | Parameter | 2149H/H-2/H-3 |  |  | 2149HL/HL-3 |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | $T y p^{(2)}$ | Max. | Min. | $\operatorname{Typ}^{(2)}$ | Max. |  |  |
| $\mid \mathrm{ILI}$ | Input Load Current (All Input Pins) |  | 0.01 | 10 |  | 0.01 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {CC }}=\max , \mathrm{V}_{\text {IN }}=$ GND to $\mathrm{V}_{\text {cc }}$ |
| \|lıo| | Output Leakage Current |  | 0.1 | 50 |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{1 H}, V_{\text {cc }}=\max , \\ & V_{\text {OUT }}=G N D \text { to } 4.5 \mathrm{~V} \end{aligned}$ |
| Icc | Operating Current |  | 120 | 180 |  | 90 | 125 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=\max , \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}, \\ & \text { Outputs Open } \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -3.0 |  | 0.8 | -3.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |
| Vol | Output Low Voltage |  |  | 0.4 |  |  | 0.4 | V | $\mathrm{IOL}=8 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | 2.4 |  |  | V | $\mathrm{IOH}^{\text {a }}$ - -4.0 mA |
| los | Output Short Circuit Current |  | $\pm 150$ | $\pm 200$ |  | $\pm 150$ | $\pm 200$ | mA | Vout $=$ GND to Vcc |

## Notes:

1. The operating ambient temperature range is guaranteed with transverse air flow exceeding 400 linear feet per minute. Typical thermal resistance values of the package at maximum temperatures are:

$$
\begin{aligned}
& \theta_{J A} \text { (@ } 400 \text { fPM air flow) }=40^{\circ} \mathrm{C} / \mathrm{W} \\
& \theta_{\text {JA }}(\text { still air })=70^{\circ} \mathrm{C} / \mathrm{W} \\
& \theta_{J C}=25^{\circ} \mathrm{C} / \mathrm{W}
\end{aligned}
$$

2. Typical limits are at $V_{C c}=5 V, T_{A}=+25^{\circ} \mathrm{C}$, and Load $A$.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 Volts |
| :--- | ---: |
| Input Rise and Fall Times | 5 nsec |
| Input and Output Timing | $\ldots \ldots$. |
| Reference Levels | 1.5 Volts |
| Output Load | See Load A. |

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

| Symbol | Parameter | Max. | Unit | Conditions |
| :---: | :--- | :---: | :---: | :--- |
| CIN | Address/Control Capacitance | 5 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{OV}$ |
| CIo $^{\prime}$ | Input/Output Capacitance | 7 | pF | $\mathrm{V}_{\text {out }}=\mathrm{OV}$ |



Load B.

Note 3. 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 | 2149H-2 |  | 2149H-3/HL-3 |  | 2149H/HL |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| trc | Read Cycle Time | 45 |  | 55 |  | 70 |  | ns |  |
| $t_{\text {A }}$ | Address Access Time |  | 45 |  | 55 |  | 70 | ns |  |
| tacs | Chip Select Access Time |  | 20 |  | 25 |  | 30 | ns |  |
| tor | Output Hold from Address Change | 5 |  | 5 |  | 5 |  | ns |  |
| tLz | Chip Selection Output in Low $\mathbf{Z}$ | 5 |  | 5 |  | 5 |  | ns | Note 3, 4 |
| thz | Chip Deselection to Output in High Z | 0 | 15 | 0 | 15 | 0 | 15 | ns | Note 3, 4 |

## WAVEFORMS

READ CYCLE No. $1^{(1,2)}$


READ CYCLE No. $2^{(3)}$


## Notes:

1. $\overline{W E}$ is high for Read Cycles.
2. Device is continuously selected, $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$.
3. At any given temperature and voltage condition, $t_{H z}$ max. is less than $t_{L z} \mathrm{~min}$. both for a given device and from device to device.
4. Transition is measured $\pm 500 \mathrm{mV}$ from high impedance voltage with Load B . This parameter is sampled and not $100 \%$ tested.

## A.C. CHARACTERISTICS (continued)

WRITE CYCLE

| Symbol | Parameter | 2149H-2 |  | 2149H-3/HL-3 |  | 2149H/HL |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| twc | Write Cycle Time | 45 |  | 55 |  | 70 |  | ns |  |
| tcw | Chip Selection to End of Write | 40 |  | 50 |  | . 65 |  | ns |  |
| taw | Address Valid to End of Write | 40 |  | 50 |  | 65 |  | ns |  |
| tas | Address Setup Time | 0 |  | 0 |  | 0 |  | ns |  |
| twp | Write Pulse Width | $\because 35$ |  | 40 |  | 50 |  | ns |  |
| twr | Write Recovery Time | 5 |  | 5 |  | 5 |  | ns |  |
| tow | Data Valid to End of Write | 20 |  | 20 |  | 25 |  | ns |  |
| ${ }_{\text {toh }}$ | Data Hold Time | 0 |  | 0 |  | 0 |  | ns |  |
| twz | Write Enabled to Output in High $\mathbf{Z}$ | 0 | 15 | 0 | 20 | 0 | 25 | ns | Note 2 |
| tow | Output Active from End of Write | 0 |  | 0 |  | 0 |  | ns | Note 2 |

## WAVEFORMS

## WRITE CYCLE No. 1 (WE CONTROLLED)



WRITE CYCLE No. 2 (ㄷ्S CONTROLLED)


## Notes:

1. If $\overline{C S}$ goes high simultaneously with $\overline{W E}$ high, the output remains in a high impedance state.
2. Transition is measured $\pm 500 \mathrm{mV}$ from high impedance voltage with Load $B$. This parameter is sampled and not $100 \%$ tested.

2164 FAMILY
$65,536 \times 1$ BIT DYNAMIC RAM

|  | $2164-15$ | $2164-20$ |
| :--- | :---: | :---: |
| Maximum Access Time (ns) | 150 | 200 |
| Read, Write Cycle (ns) | 300 | 375 |
| Read-Modify-Write Cycle (ns) | 345 | 435 |

- Industry Standard 16-pin DIP
- HMOS Technology
- Single +5 V Supply, $\pm 10 \%$ Tolerance
- All Inputs, Including Clocks, TTL Compatible


## - Pin 1 is No Connect to Allow for Future System Upgrade

## 128 Refresh Cycles/2 ms $\overline{\text { RAS-only }}$ Refresh

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

- Compatible with 2118
- Inputs Allow Negative Overshoot, $\mathbf{V}_{\text {IL }}$ MIN $=-2 V$


## - Page Mode and Hidden Refresh Capability

The Intel 2164 is a 65,536 words by 1 -bit $N$-channel MOS dynamic RAM fabricated in Intel's production proven HMOS process. The 2164 is packaged in the industry standard 16-pin DIP and is designed to operate with a single +5 V power supply, with $\pm 10 \%$ tolerance. The use of a single transistor cell and advanced dynamic circuitry enable the 2164 to achieve high speed at low power dissipation.

Multiplexing the 16 address bits into the 8 address input pins allows the 2164 to achieve high packaging density. The two 8 -bit TTL level address segments are latched into the 2164 by the two TTL clocks, Row Address Strobe ( $\overline{\mathrm{RAS}}$ ) and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ). Non-critical timing requirements for the $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ clocks allow the use of the address multiplexing technique while maintaining high performance.
The non-latched, three state, TTL compatible data output is controlled by $\overline{\text { CAS }}$, independent of $\overline{\text { RAS }}$. After a valid read or read-modify-write cycle, data is held on the data output pin by holding $\overline{C A S}$ low. The data output is returned to a high impedance state, by returning $\overline{\mathrm{CAS}}$ to a high state. Hidden refresh capability allows the device to maintain data at the output by holding $\overline{\text { CAS }}$ low while $\overline{\mathrm{RAS}}$ is used to execute $\overline{\mathrm{RAS}}$-only refresh cycles.
Refresh is required for data retention in one transistor storage cells: Refreshing is accomplished by performing $\overline{\operatorname{RAS}}-$ only cycles, hidden refresh cycles, or normal read or write cycles on the 128 address combinations of addresses $A_{0}$ through $A_{6}$, during a 2 ms period. Address input $A_{7}$ is a don't care during these refresh cycles. 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 $V_{\text {ss }} \ldots . . . . . . . . .$. . 7.5 V
Data Out Current . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50mA
Power Dissipation ......................................... . 1.0 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. 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}, V_{D D}=5 \mathrm{~V} \pm 10 \%, V_{S S}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{(2)}$ | Max. |  |  |  |
| \|ILI| | Input Load Current (any input) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ to $\mathrm{V}_{\text {DD }}$ |  |
| \|lol | Output Leakage Current for High Impedance State |  |  | 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 |  | 3 | 5 | mA | $\overline{\text { CAS }}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{1 H}$ |  |
| IDD2 | VDD Supply Current, Operating |  |  | 60 | mA | 2164-15, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
|  |  |  |  | 55 | mA | 2164-20, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
| IDD3 | VDD Supply Current, $\overline{\text { RAS }}$-Only Cycle |  |  | 50 | mA | 2164-15, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ |  |
|  |  |  |  | 40 | mA | 2164-20, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ |  |
| IDD5 | VDD Supply Current, Standby, Output Enabled |  |  | 7 | mA | $\overline{\text { CAS }}$ at $\mathrm{V}_{\mathrm{IL}}, \overline{\text { RAS }}$ at $\mathrm{V}_{\mathrm{IH}}$ | 3 |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (all inputs) | -2.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (all inputs) | 2.4 |  | 7.0 | V |  |  |
| Vol | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ |  |
| VOH | Output High Voltage | 2.4 |  |  | V | $1 \mathrm{OH}=-5 \mathrm{~mA}$ |  |

NOTES:

1. All voltages referenced to $V_{s s}$.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. $I_{D D}$ is dependent on output loading when the device output is selected. Specified $I_{D D}$ max is measured with the output open.

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

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

| Symbol | Parameter | Typ. | Max. | Unit |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Address, Data In | 3 | 6 | pF |
| $\mathrm{C}_{12}$ | $\overline{\text { WE, Data Out }}$ | 4 | 7 | pF |
| $\mathrm{C}_{13}$ | RAS, $\overline{\text { CAS }}$ | 5 | 8 | 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 ${ }^{[1,2,3]}$

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=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 | 2164.15 |  | 2164.20 |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $t_{\text {tac }}$ | Access Time From $\overline{\mathrm{RAS}}$ |  | 150 |  | 200 | ns | 4,5 |
| $\mathrm{t}_{\text {cac }}$ | Access Time From $\overline{\text { CAS }}$ |  | 85 |  | 110 | ns | 4,5,6 |
| $t_{\text {Ref }}$ | Time Between Refresh |  | 2 |  | 2 | ms |  |
| $\mathrm{t}_{\text {PP }}$ | $\overline{\text { RAS }}$ Precharge Time | 120 |  | 135 |  | ns |  |
| tcpn | $\overline{\text { CAS }}$ Precharge Time (non-page cycles) | 25 |  | 35 |  | ns |  |
| tcra | $\overline{\mathrm{CAS}}$ to $\overline{\mathrm{RAS}}$ Precharge Time | -20 |  | -20 |  | ns |  |
| $t_{\text {tab }}$ | $\overline{\text { RAS }}$ to $\overline{\mathrm{CAS}}$ Delay Time | 35 | 65 | 40 | 90 | ns | 7 |
| trsh | $\overline{\mathrm{RAS}}$ Hold Time | 85 |  | 110 |  | ns |  |
| tcsh | $\overline{\text { CAS }}$ Hold Time | 150 |  | 200 |  | ns |  |
| $\mathrm{taSm}^{\text {a }}$ | Row Address Set-Up Time | 0 |  | 0 |  | ns |  |
| $\mathrm{t}_{\text {RaH }}$ | Row Address Hold Time | 25 |  | 30 |  | ns |  |
| $\mathrm{t}_{\text {asc }}$ | Column Address Set-Up Time | 0 |  | 0 |  | ns |  |
| $\mathrm{t}_{\text {cah }}$ | Column Address Hold Time | 35 |  | 45 |  | ns |  |
| $t_{\text {AR }}$ | Column Address Hold Time, to $\overline{\mathrm{RAS}}$ | 100 |  | 135 |  | ns |  |
| $t_{T}$ | Transition Time (Rise and Fall) | 3 | 50 | 3 | 50 | ns | 8 |
| toff | Output Buffer Turn Off Delay | 0 | 40 | 0 | 50 | ns |  |

READ AND REFRESH CYCLES

| $\mathrm{t}_{\text {RC }}$ | Random Read Cycle Time | 300 |  | 375 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {RAS }}$ | $\overline{\text { RAS Pulse Width }}$ | 150 | 10000 | 200 | 10000 | ns |  |
| $\mathrm{t}_{\text {cas }}$ | $\overline{\text { CAS Pulse Width }}$ | 85 | 10000 | 110 | 10000 | ns |  |
| $\mathrm{t}_{\text {fics }}$ | Read Command Set-Up Time | 0 |  | 0 |  | ns |  |
| $\mathrm{t}_{\text {RCH }}$ | Read Command Hold Time | 0 |  | 0 |  | ns |  |

WRITE CYCLE

| $\mathrm{t}_{\text {RC }}$ | Random Write Cycle Time | 300 |  | 375 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {RAS }}$ | $\overline{\text { RAS Pulse Width }}$ | 150 | 10000 | 200 | 10000 | ns |  |
| $t_{\text {cas }}$ | $\overline{\text { CAS Pulse Width }}$ | 85 | 10000 | 110 | 10000 | ns |  |
| $t_{\text {wcs }}$ | Write Command Set-Up Time | 0 |  | 0 |  | ns | 9 |
| twCH | Write Command Hold Time | 30 |  | 40 |  | ns |  |
| $t_{\text {WCR }}$ | Write Command Hold Time, to $\overline{\text { RAS }}$ | 95 |  | 130 |  | ns |  |
| $t_{\text {wp }}$ | Write Command Pulse Width | 30 |  | 40 |  | ns |  |
| $t_{\text {RWL }}$ | Write Command to $\overline{\mathrm{RAS}}$ Lead Time | 40 |  | 50 |  | ns |  |
| $\mathrm{t}_{\text {cw }}$ | Write Command to $\overline{\text { CAS }}$ Lead Time | 40 |  | 50 |  | ns |  |
| $\mathrm{t}_{\mathrm{DS}}$ | Data-In Set-Up Time | 0 |  | 0 |  | ns |  |
| $t_{\text {DH }}$ | Data-In Hold Time | 35 |  | 45 |  | ns |  |
| $t_{\text {DHR }}$ | Data-In Hold Time, to $\overline{\mathrm{RAS}}$ | 100 |  | 135 |  | ns |  |

## READ-MODIFY-WRITE CYCLE

| $\mathrm{t}_{\text {RWC }}$ | Read-Modify-Write Cycle Time | 305 | 375 | ns |  |
| :--- | :--- | :--- | :--- | :---: | :---: |
| $\mathrm{t}_{\text {RRW }}$ | RMW Cycle $\overline{\text { RAS Pulse Width }}$ | 175 | 10000 | 230 | 10000 |
| $\mathrm{t}_{\text {CRW }}$ | RMW Cycle $\overline{\text { CAS }}$ Pulse Width | 110 | 10000 | 140 | 10000 |
| $\mathrm{t}_{\text {RWO }}$ | $\overline{R A S}$ to $\overline{W E}$ Delay | 130 | ns |  |  |
| $\mathrm{t}_{\text {cWD }}$ | $\overline{\text { CAS }}$ to $\overline{W E}$ Delay | 65 | 175 | ns |  |

## NOTES:

1. All voltages referenced to $\mathrm{V}_{\mathrm{SS}}$
2. Eight cycles are required atter power-up or prolonged periods (greater than 2 ms ) of $\overline{\text { AAS }}$ inactivity before proper device operation is achieved. Any 8 cycles which perform refresh are adequate for this purpose.
3. A.C. Characteristics assume $\mathrm{tr}^{\top}=5 \mathrm{~ns}$
4. Assume that $t_{C D} \leq \operatorname{tracD}^{(m a x}$ ). If $t_{R C D}$ is greater than $t_{R C D}$ (max.) then trac will increase by the amount that trcD exceeds trco (max.)
5. Load $=2 \mathrm{TTL}$ loads and 100 pF
6. Assumes trco $\geq$ thCD (max.)

## WAVEFORMS



WRITE CYCLE


Dout

$$
\mathrm{V}_{\mathrm{OH}} \quad \text { HIGH }
$$

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE



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



HIDDEN REFRESH CYCLE
(For Hidden Refresh Operation order 2164-15 S6491, 2164-20 S6492)


NOTES: 1.2. $V_{I H}$ 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 OUt
5. toff IS MEASURED TO lout $\leqslant \mid$ lol
6. tos AND tDH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. tRCH IS REFERENCED TO THE TRAILING EDGE OF $\overline{\mathrm{CAS}}$ OR $\overline{\text { RAS, WHICHEVER OCCURS FIRST }}$
8. ICRP REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A $\overline{\mathrm{CAS}}$ ONLY CYCLE (ı.e., FOR SYSTEMS WHERE $\overline{C A S}$ HAS NOT BEEN DECODED WITH $\overline{R A S})$.

## 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=5 \mathrm{~V} \pm 10 \%$, V SS $=0 \mathrm{~V}$, unless otherwise noted.
(For Page Mode Operation order 2164-15 S6493, 2164-20 S6494)

| Symbol | Parameter | $\begin{gathered} 2164-15 \\ \mathrm{~S} 6493 \end{gathered}$ |  | $\begin{gathered} 2164-20 \\ \text { S6494 } \end{gathered}$ |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| tpC | Page Mode Read or Write Cycle | TBD |  | TBD |  | ns |  |
| tPCM | Page Mode Read Modify Write | TBD |  | TBD |  | ns |  |
| $\mathrm{t}_{\mathrm{CP}}$ | $\overline{\mathrm{CAS}}$ Precharge Time, Page Cycle | TBD |  | TBD |  | ns |  |
| $\mathrm{t}_{\text {RPM }}$ | $\overline{\mathrm{RAS}}$ Pulse Width, Page Mode | TBD |  | TBD |  | ns |  |
| $\mathrm{t}_{\text {CAS }}$ | $\overline{\mathrm{CAS}}$ Pulse Width | TBD |  | TBD |  | ns |  |
| IDD4 | VDo Supply Current Page Mode, Minimum $t_{P C}$, Minimum $t_{C A S}$ |  | TBD |  | TBD | mA |  |

## WAVEFORMS

## PAGE MODE READ CYCLE



NOTES: 1,2. $V_{1 H}$ MIN AND $V_{I 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 \& ILol.
6. $t_{\text {RCH }}$ IS REFERENCED TO THE TRAILING EDGE OF $\overline{\operatorname{CAS}}$ OR $\overline{\text { RAS, }}$, WHICHEVER OCCURS FIRST.
7. ALL VOLTAGES REFERENCED TO VSS:
8. AC CHARACTERISTIC ASSUME tT $=$ sns.
9. SEE THE TYPICAL CHARACTERISTICS SECTION FOR VALUES OF THIS PARAMETER . SEE THE TYPICAL CHARACTERISTI
UNDER ALTERNATE CONDITIONS.
10. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\operatorname{RAS}} / \overline{C A S}$ CYCLES PRECEEDED BY A $\overline{C A S}-$ ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH $\overline{\text { RAS }}$ ).
11. ALL PREVIOUSLY SPECIFIED A.C. AND D.C. CHARACTERISTICS ARE APPLICABLE TO THEIR RESPECTIVE PAGE MODE DEVICE (i.e., 2164-15 S6493 WILL OPERATE AS A 2164-15).

PAGE MODE
WRITE CYCLE


PAGE MODE READ-MODIFY-WRITE CYCLE


NOTES: 1,2. $V_{I H}$ 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 |llol.
6. IDS AND tDH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. tRCH IS REFERENCED TO THE TRAILING EDGE OF CAS OR RAS, WHICHEVER OCCURS FIRST.
8. ICRP REQUIREMENT IS ONLY APPLICABLE FOR RAS/CAS CYCLES PRECEEDED BY A CASONLY CYCLE (1.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## DEVICE DESCRIPTION

The Intel® 2164 is produced with HMOS, a high performance MOS technology which incorporates on-chip substrate bias generation. This process, combined with new circuit design concepts, allows the 2164 to operate from a single +5 V power supply, eliminating the +12 V and -5 V requirements. Pin 1 is not connected, which allows P.C.B. layout for future higher density memory generations.

The 2164 is functionally compatible with the 2118 , the industry standard 5V-only 16 -pin 16 K dynamic RAM. This allows simple upgrade from 16 K to 64 K density merely by adding one additional multiplexed address line.

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

$\overline{\text { RAS }}$ and $\overline{\text { CAS }}$ have minimum pulse widths as defined by $t_{\text {RAS }}$ and $t_{C A S}$ respectively. These minimum pulse widths must be maintained for proper device operation and data integrity. A cycle, once begun by bringing $\cdot \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, $t_{\text {Rp }}$, has been met.

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

## WRITE CYCLE

A Write cycle is performed by taking $\overline{\text { WE low during a }}$ $\overline{R A S} / \overline{C A S}$ operation. Data Input ( $\mathrm{D}_{\text {IN }}$ ) must be valid relative to the negative edge of $\overline{\mathrm{WE}}$ or $\overline{\mathrm{CAS}}$, whichever transition occurs last.

## DATA OUTPUT OPERATION

The 2164 Data Output (Dout), which has three-state capability, is controlled by $\bar{C} \overline{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.

## Intel 2164 Data Output Operation

 for Various Types of Cycles| Type of Cycle | Dout State |
| :--- | :--- |
| Read Cycle | Data From Addressed <br> Memory Cell |
|  | HI-Z <br> Early Write Cycle |
| RAS-Only Refresh Cycle | HI-Z |
| CAS-Only Cycle | Read/Modify/Write Cycle |
| Data From Addressed |  |
| Memory Cell |  |
| Delayed Write Cycle | Mdeterminate |

## REFRESH CYCLES

There are 512 sense amplifiers, each controlling 128 storage cells. Thus the 2164 is refreshed in 128 cycles. Any combination of the seven (7) low order Row Addresses, $\mathrm{RA}_{0}$ through $\mathrm{RA}_{8}$, will select one row of data cells ( 512 cells/row). Row address 7 is not critical during a refresh operation and can be either high or low. Although any cycle, Read, Write, Read-Modify-Write, or $\overline{R A S}-o n l y$, will refresh the memory, the $\overline{\text { RAS-only cycle is recommended, }}$ since it allows about $20 \%$ system power reduction over the other types of cycles.

## HIDDEN REFRESH

An optional feature of the 2164 is that refresh cycles may be performed while maintaining valid data at the output pin. This is referred to as Hidden Refresh. Hidden Refresh is performed by holding $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IL}}$ and taking $\overline{\mathrm{RAS}}$ high and after a specified precharge period ( $t_{\text {RP }}$ ), 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

After the application of the $V_{D D}$ supply, or after extended periods of bias (greater than 2 ms ) without clocks, the device requires a minimum of eight (8) initialization cycles (any combination of cycles containing RAS clock such as $\overline{\text { RAS-only }}$ refresh) prior to normal operation.

The $\mathrm{V}_{\mathrm{DD}}$ current ( $\mathrm{I}_{\mathrm{DD}}$ ) requirement of the 2164 during power on is dependent upon the input levels of $\overline{\text { RAS }}$ and $\overline{\mathrm{CAS}}$. If the input levels of these clocks are at $\mathrm{V}_{\mathrm{IH}}$ or $\mathrm{V}_{\mathrm{DD}}$, whichever is lower; the $I_{D D}$ requirement per device is $I_{D D 1}$ ( $I_{D D}$ standby). If the input levels for these clocks are lower than $V_{I H}$ or $V_{D D}$ the $I_{D D}$ requirements will be greater than $I_{D D 1}$. For large systems, this current requirement for $I_{D D}$ could be substantially more than that for which the system has been designed. A system which has been designed assuming the majority of devices to be operating in the refresh/standby mode, may produce sufficient $I_{\text {DD }}$ loading such that the power supply may current limit. To assure that the system will not experience such loading during power on, a pullup resistor for each clock input to $V_{D D}$ to maintain the non-selected current level $\left(I_{D D 1}\right)$ for the power supply is recommended.

# 2164-25 <br> $65,536 \times 1$ BIT DYNAMIC RAM 

|  | $2164-25$ |
| :--- | :---: |
| Maximum Access Time (ns) | 250 |
| Read, Write Cycle (ns) | 465 |
| Read-Modify-Write Cycle (ns) | 530 |

- Industry Standard 16-pin DIP


## - HMOS Technology

- Single +5 V Supply, $\pm 10 \%$ Tolerance


## - All Inputs, Including Clocks, TTL Compatible

## - Pin 1 is No Connect to Allow for Future System Upgrade

## - 128 Refresh Cycles/2 ms $\overline{\text { RAS-only }}$ Refresh

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

- Compatible with 2118
- Inputs Allow Negative Overshoot, $\mathbf{V}_{\text {IL }}$ MIN $=\mathbf{- 2 V}$


## - Page Mode and Hidden Refresh Capability

The Intel 2164 is a 65,536 words by 1 -bit N-channel MOS dynamic RAM fabricated in Intel's production proven HMOS process. The 2164 is packaged in the industry standard 16-pin DIP and is designed to operate with a single +5 V power supply, with $\pm 10 \%$ tolerance. The use of a single transistor cell and advanced dynamic circuitry enable the 2164 to achieve high speed at low power dissipation.
Multiplexing the 16 address bits into the 8 address input pins allows the 2164 to achieve high packaging density. The two 8 -bit TTL level address segments are latched into the 2164 by the two TTL clocks, Row Address Strobe (RAS) and Column Address Strobe ( $\overline{\mathrm{CAS}}$ ). Non-critical timing requirements for the $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ clocks allow the use of the address multiplexing technique while maintaining high performance.
The non-latched, three state, TTL compatible data output is controlled by $\overline{\mathrm{CAS}}$, independent of $\overline{\mathrm{RAS}}$. After a valid read or read-modify-write cycle, data is held on the data output pin by holding $\overline{\text { CAS }}$ low. The data output is returned to a high impedance state, by returning $\overline{\mathrm{CAS}}$ to a high state. Hidden refresh capability allows the device to maintain data at the output by holding $\overline{C A S}$ low while $\overline{\mathrm{RAS}}$ is used to execute $\overline{\mathrm{RAS}}$-only refresh cycles.
Refresh is required for data retention in one transistor storage cells. Refreshing is accomplished by performing $\overline{\operatorname{RAS}}-$ only cycles, hidden refresh cycles, or normal read or write cycles on the 128 address combinations of addresses $A_{0}$ through $A_{6}$, during a 2 ms period. Address input $\mathrm{A}_{7}$ is a don't care during these refresh cycles. 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 $V_{s s} \ldots . . . . . . . . .$.
Data Out Current . . . ..................................... . . . 50mA
Power Dissipation ........................................... 1.0 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. 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}_{D D}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{(2)}$ | Max. |  |  |  |
| \|lıI| | Input Load Current (any input) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ to $\mathrm{V}_{\text {DD }}$ |  |
| \|lool | Output Leakage Current for High Impedance State |  |  | 10 | $\mu \mathrm{A}$ | Chip Deselected: $\overline{C A S}$ at $V_{1 H}$, $V_{\text {OUT }}=0$ to 5.5 V |  |
| IDD1 | VDD Supply Current, Standby |  | 3 | 5 | mA | $\overline{\text { CAS }}$ and $\overline{\text { RAS }}$ at VIH |  |
| IDD2 | VDD Supply Current, Operating |  |  | 50 | mA | 2164-25, $\mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
| IDD3 | VDD Supply Current, $\overline{\text { RAS }}$-Only Cycle |  |  | 36 | mA | 2164-25, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ |  |
| IDD5 | VDD Supply Current, Standby, Output Enabled |  |  | 7 | mA | $\overline{\text { CAS }}$ at $\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{RAS}}$ at $\mathrm{V}_{\mathrm{IH}}$ | 3 |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (all inputs) | -2.0 |  | 0.8 | V |  |  |
| V IH | Input High Voltage (all inputs) | 2.4 |  | 7.0 | V |  |  |
| VOL | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ |  |
| VOH | Output High Voltage | 2.4 |  |  | V | $1 \mathrm{OH}=-5 \mathrm{~mA}$ |  |

NOTES:

1. All voltages referenced to $V_{s s}$.
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. $I_{D D}$ is dependent on output loading when the device output is selected. Specified $I_{D D}$ MAX is measured with the output open.

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

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

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

NOTES:
I. 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 ${ }^{[1,2,3]}$

$\mathrm{T}_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{D D}=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 | $2164-25$ |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $t_{\text {RAC }}$ | Access Time from $\overline{\text { RAS }}$ |  | 250 | ns | 4,5 |
| $t_{\text {caC }}$ | Access Time from CAS |  | 135 | ns | 4,5,6 |
| $t_{\text {REF }}$ | Time Between Refresh |  | 2 | ms |  |
| $\mathrm{t}_{\mathrm{BP}}$ | $\overline{\text { RAS }}$ Precharge Time | 175 |  | ns |  |
| $t_{\text {CPN }}$ | $\overline{\text { CAS Precharge Time (Non-Page Cycles) }}$ | 45 |  | ns |  |
| $t_{\text {CRP }}$ | $\overline{\text { CAS }}$ to $\overline{\mathrm{RAS}}$ Precharge Time | -20 |  | ns |  |
| $\mathrm{t}_{\text {RCD }}$ | RAS to $\overline{\text { CAS }}$ Delay Time | 55 | 115 | ns | 7 |
| $t_{\text {RSH }}$ | RAS Hold Time | 135 |  | ns |  |
| $t_{\text {CSH }}$ | CAS Hold Time | 250 |  | ns |  |
| $t_{\text {ASR }}$ | Row Address Set-Up Time | 0 |  | ns |  |
| $t_{\text {RAH }}$ | Row Address Hold Time | 45 |  | ns |  |
| $t_{\text {ASC }}$ | Column Address Set-Up Time ... | 0 |  | ns |  |
| $t_{\text {CAH }}$ | Column Address Hold Time | 55 |  | ns |  |
| $t_{\text {AR }}$ | Column Address Hold Time, to $\overline{\text { RAS }}$ | 170 |  | ns |  |
| $t_{T}$ | Transition Time (Rise and Fall) | 3 | 50 | ns | 8 |
| $t_{\text {OFF }}$ | Output Buffer Túrn Off Delay | 0 | 60 | ns |  |

## READ AND REFRESH CYCLES

| $t_{\text {RC }}$ | Random Read Cycle Time | 465 | ns |  |
| :---: | :--- | :--- | :--- | :--- |
| $t_{\text {RAS }}$ | $\overline{R A S}$ Pulse Width | 250 | 10,000 | ns |
| $t_{\text {CAS }}$ | CAS Pulse Width | 135 | 10,000 | ns |
| $t_{\text {RCS }}$ | Read Command Set-Up Time | 0 | ns |  |
| $t_{\text {RCH }}$ | Read Command Hold Time | 0 | ns |  |

## WRITE CYCLE

| $\mathrm{t}_{\mathrm{RC}}$ | Random Write Cycle Time | 465 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {RAS }}$ | RAS Pulse Width | 250 | 10,000 | ns |  |
| $\mathrm{t}_{\text {cas }}$ | CAS Pulse Width | 135 | 10,000 | ns |  |
| $t_{\text {wCs }}$ | Write Command Set-Up Time | 0 |  | ns | 9 |
| $t_{\text {WCH }}$ | Write Command Hold Time | 50 |  | ns |  |
| $t_{\text {WCR }}$ | Write Command Hold Time, to $\overline{\text { RAS }}$ | 165 |  | ns |  |
| $t_{\text {WP }}$ | Write Command Pulse Width | 50 |  | ns |  |
| $t_{\text {RWL }}$ | Write Command to $\overline{\mathrm{RAS}}$ Lead Time | 60 |  | ns |  |
| $\mathrm{t}_{\text {CWL }}$ | Write Command to $\overline{\text { CAS }}$ Lead Time | 60 | $\cdots$ | ns |  |
| $\mathrm{t}_{\mathrm{DS}}$ | Data-In Set-Up Time | 0 |  | ns |  |
| $t_{\text {DH }}$ | Data-In Hold Time | 55 |  | ns |  |
| $t_{\text {DHR }}$ | Data-In Hold Time, to $\overline{\text { RAS }}$ | 170 |  | ns |  |

## READ-MODIFY-WRITE CYCLE

| $\mathrm{t}_{\text {RWC }}$ | Read-Modify-Write Cycle Time | 470 | ns |  |
| :---: | :--- | :--- | :--- | :--- |
| $\mathrm{t}_{\text {RRW }}$ | RMW Cycle $\overline{\text { RAS Pulse Width }}$ | 285 | ns |  |
| $\mathrm{t}_{\text {CRW }}$ | RMW Cycles $\overline{\text { CAS Pulse Width }}$ | 170 | ns |  |
| $\mathrm{t}_{\text {RWD }}$ | RAS to $\overline{\text { WE Delay }}$ | 220 | ns |  |
| $\mathrm{t}_{\text {CWD }}$ | $\overline{\text { CAS to WE Delay }}$ | 105 | ns |  |

## NOTES:

1. All voltages are referenced to $\mathrm{V}_{\mathrm{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 $t_{T}=5$ 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 $t_{R A C}$ will increase by the amount that $t_{R C D}$ exceeds $t_{R C D}$ (max.).
5. Load $=2 \mathrm{TTL}$ loads and 100 pF .
6. Assumes $\mathrm{t}_{\mathrm{RCD}} \geq \mathrm{t}_{\mathrm{RCD}}$ (max.).
7. $t_{\text {RCD }}$ (max.) is specified as a reference point only; if $t_{R C D}$ is less than $t_{R C D}$
 ${ }^{t_{R C D}}+t_{C A C}$
8. $t_{T}$ is measured between $\mathrm{V}_{\mathrm{IH}}$ (min.) and $\mathrm{V}_{\mathrm{IL}}$ (max.).
 (min.), the cycle is an early write cycle and the data-out pin will remain high im. pedance throughout the entire cycle; if $\mathrm{t}_{\mathrm{CWD}} \geq \mathrm{t}_{\mathrm{CWD}}$ (min.) and $\mathrm{t}_{\mathrm{RWD}} \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 CYCLE


Write cycle


NOTES: 1,2. $V_{I H}$ MIN $A N D V_{I L}$ MAX ARE REFERENCE LEVELS FDR 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 \& \|LO|.
6. tDS AND tDH ARE REFERENCED TO CAS OR WE, WHICHEVERIOCCURS LAST
7. trCH 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).

## WAVEFORMS

## READ-MODIFY-WRITE CYCLE


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


HIDDEN REFRESH CYCLE
(For Hidden Refresh Operation order 2164-25, S6496)


NOTES: 1,2. $V_{I H}$ 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 \& |llol.
6. tDS AND tDH ARE REFERENCED TO CAS OR WE, WHICHEVER OCCURS LAST.
7. $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 (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH $\overline{R A S}$ )

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

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%$, V Ss $=0 \mathrm{~V}$, unless otherwise noted.
(For Page Mode Operation order 2164-25, S6495)

| Symbol | Parameter | 2164-25, S6495 <br> Min. <br> Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $t_{P C}$ | Page Mode Read or Write Cycle | TBD | ns |  |
| $\mathrm{t}_{\text {PCM }}{ }^{\text {a }}$ | Page Mode Read-Modify-Write | TBD | ns |  |
| $t_{C P}$ | $\overline{\text { CAS Precharge Time, Page Cycle }}$ | TBD | ns |  |
| $t_{\text {RPM }}$ | $\overline{\text { RAS Pulse Width, Page Mode }}$ | TBD | ns |  |
| $t_{\text {CAS }}$ | $\overline{\text { CAS Pulse Width }}$ | TBD | ns |  |
| IDD4 | $\mathrm{V}_{\mathrm{DD}}$ Supply Current Page Mode, Minimum $\mathrm{t}_{\text {PC }}$, Minimum $\mathrm{t}_{\text {CAS }}$ | TBD | mA |  |

## 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 OUT
5. toff IS MEASURED TO IOUT IILOI.
6. trCH IS REFERENCED TO THE TRAILING EDGE OF CAS OR $\overline{\text { RAS }}$, WHICHEVER OCCURS FIRST
7. ALL VOLTAGES REFERENCED TO VSS.
8. AC CHARACTERISTIC ASSUME $\mathrm{t}_{T}=5$ Sns.
9. SEE THE TYPICAL CHARACTERISTICS SECTION FOR VALUES OF THIS PARAMETER UNDER ALTERNATE CONDITIONS.
10. tCRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\operatorname{RAS}} / \overrightarrow{C A S}$ CYCLES PRECEEDED BY A $\overrightarrow{C A S}-$ ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH $\overline{\text { RAS }}$ ).
11. ALL PREVIOUISLY SPECIFIED A.C. AND D.C. CHARACTERISTICS ARE APPLICABLE TO THEIR RESPECTIVE PAGE MODE DEVICE (i.e., 2164-25, S6493 WILL OPERATE AS A 2164-25).

PAGE MODE
WRITE CYCLE


PAGE MODE READ-MODIFY-WRITE CYCLE


NOTES 1.2. $\mathrm{V}_{\mathrm{IH}}$ MIN AND $V_{\text {II }}$ max ARE REFERENCE LEVELS FOR MEASURING TIMING OF INPUT SIGNALS
3.4. $V_{\text {OH MIN }}$ AND $V_{\text {OL MAX }}$ MRE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT
5. toff IS MEASURED TO Iout |loi.
6. tDS AND tDH 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 RAS/CAS CYCLES PRECEEDED BY A CASONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## DEVICE DESCRIPTION

The Intel ${ }^{(0)} 2164$ is produced with HMOS, a high performance MOS technology which incorporates on-chip substrate bias generation. This process, combined with new circuit design concepts, allows the 2164 to operate from a single +5 V power supply, eliminating the +12 V and -5 V requirements. Pin 1 is not connected, which allows P.C.B. layout for future higher density memory generations.

The 2164 is functionally compatible with the 2118 , the industry standard 5V-only 16-pin 16K dynamic RAM. This allows simple upgrade from 16 K to 64 K density merely by adding one additional multiplexed address line.

## $\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 $\mathrm{t}_{\mathrm{cas}}$ respectively. These minimum pulse widths must be maintained for proper device operation and data integrity. A cycle, once begun by bringing $\overline{\mathrm{R} .4 S}$ and/or $\overline{\text { 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.

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

## WRITE CYCLE

A Write cycle is performed by taking $\overline{W E}$ low during a $\overline{\text { RAS }} / \overline{\mathrm{CAS}}$ operation. Data Input ( $\mathrm{DiN}_{\text {I }}$ ) must be valid relative to the negative edge of $\overline{W E}$ or $\overline{C A S}$, whichever transition occurs last.

## DATA OUTPUT OPERATION

The 2164 Data Output (Dout), which has three-state capability, is controlled by CAS. During $\overline{\mathrm{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.

Intel 2164 Data Output Operation for Various Types of Cycles

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

## REFRESH CYCLES

There are 512 sense amplifiers, each controlling 128 storage cells. Thus the 2164 is refreshed in 128 cycles. Any combination of the seven (7) low order Row Addresses, RA $A_{0}$ through RA $_{6}$, will select one row of data cells ( 512 cells/row). Row address 7 is not critical during a refresh operation and can be either high or low. Although any cycle, Read, Write, Read-Modify-Write, or $\overline{R A S}-o n l y$, will refresh the memory, the $\overline{\mathrm{RAS}}$-only cycle is recommended, since it allows about $20 \%$ system power reduction over the other types of cycles.

## HIDDEN REFRESH

An optional feature of the 2164 is that refresh cycles may be performed while maintaining valid data at the output pin. This is referred to as Hidden Refresh. Hidden Refresh is performed by holding $\overline{C A S}$ at $V_{\mathrm{IL}}$ and taking $\overline{\mathrm{RAS}}$ high and after a specified precharge period (tap), executing a " $\overline{R A S}-O n l y "$ 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

After the application of the Voo supply, or after extended periods of bias (greater than 2 ms ) without clocks, the device requires a minimum of eight (8) initialization cycles (any combination of cycles containing RAS clock such as $\overline{\text { RAS-only refreshí) prior to normal operation. }}$

The $V_{D D}$ current ( $I_{D D}$ ) requirement of the 2164 during power on is dependent upon the input levels of RAS and CAS. If the input levels of these clocks are at $\mathrm{V}_{I H}$ or $\mathrm{V}_{\mathrm{DD}}$, whichever is lower, the $I_{D D}$ requirement per device is $I_{D D 1}$ ( $l_{D D}$ standby). If the input levels for these clocks are lower than $V_{I H}$ or $V_{D D}$ the $I_{D D}$ requirements will be greater than $\mathrm{I}_{\mathrm{DD} 1}$. For large systems, this current requirement for $I_{D D}$ could be substantially more than that for which the system has been designed. A system which has been designed assuming the majority of devices to be operating in the refresh/standby mode, may produce sufficient $I_{\text {DD }}$ loading such that the power supply may current limit. To assure that the system will not experience such loading during power on, a pullup resistor for each clock input to $V_{D D}$ to maintain the non-selected current level $\left(I_{D D 1}\right)$ for the power supply is recommended.

# HIGH SPEED 16,384×1 BIT STATIC RAM 

|  | 2167.55 | 2167.70 | $2167 \mathrm{~L} \cdot 70$ | 2167.10 |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 55 | 70 | 70 | 100 |
| Max. Active Current (mA) | 125 | 125 | 90 | 90 |
| Max. Standby Current (mA) | 40 | 40 | 30 | 30 |

## - 2141/2147 Upgrade <br> - Double Poly HMOS II Technology <br> - Completely Static Memory - No Clock or Timing Strobe Required <br> ■ Equal Access and Cycle Times <br> - Single + 5V Supply <br> - Automatic Power Down

## 0.8-2.0V Output Timing Reference Levels

- High Density 20-Pin Package
- Directly TTL Compatible - All Inputs and Output
Separate Data Input and Output
Three-State Output

The Intel ${ }^{\top} 2167$ is a 16,384 -bit static Random Access Memory organized as 16,384 words by 1 bit. This memory is fabricated using Intel's high-density, high-performance technology—Double Poly HMOS II. This state of the art technology brings high-density to high-performance static RAMs. The design of the 2167 offers a $4 \times$ density improvement over the industry standard 2141 and 2147 with compatible performance. The 2167 offers the automatic power-down feature pioneered by the Intel 2147.
$\overline{\mathrm{CS}}$ controls the power-down feature. In less than a cycle time after $\overline{\mathrm{CS}}$ goes high (deselecting the 2167), 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 $70 \%$ in larger systems where the majority of devices are deselected.
The 2167 is placed in a 20 -pin package configured with the industry standard $16 \mathrm{~K} \times 1$ pinout, offering the industry's highest density 16 K static RAM. 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 threestate output are used.

LOGIC SYMBOL.


PIN NAMES

| $A_{0}-A_{13}$ | ADDRESS INPUTS | $V_{C C}$ POWER ( +5 V ) |
| :--- | :--- | :--- |
| $\overline{\text { WE }}$ | WRITE ENABLE | GND GROUND |
| $\overline{C S}$ | CHIP SELECT |  |
| $D_{\text {IN }}$ | DATA INPUT |  |
| $D_{O U T}$ | DATA OUTPUT |  |

TRUTH TABLE

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

PIN CONFIGURATION


BLOCK DIAGRAM


| BSOLUTE MAXIN |  |
| :---: | :---: |
| 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 |  |
| r |  |
|  |  |

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}$

Respect to Ground. . . . . . . . . . . . . . . . . - -3.5 V to +7 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 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.


## Notes:

1. The operating ambient temperature 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. A puil-up resistor to $\mathrm{V}_{\mathrm{CC}}$ on the CS input is required to keep the device deselected; otherwise, power-on current approaches $\mathrm{I}_{\mathrm{CC}}$ active.

## A.C. TEST CONDITIONS <br> Input Pulse Levels Input Rise and Fall Times Input Timing Reference Level <br> Output Timing Reference Levels Output Load GND to 3.0 V 5 ns 5 ns 1.5V <br> 0.8-2.0V See Figure 1

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

$\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 | 7 | pF | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance | 6 | pF | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ |

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


Figure 1. Output Load


- Figure 2. Output Load for $t_{H Z}, t_{L Z}, t_{W Z}, t_{\text {WW }}$


## 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 | $2167.55$ <br> Min. Max. | $\begin{gathered} \text { 2167.70, } 2167 \text { L.70 } \\ \text { Min. Max. } \end{gathered}$ | $\begin{gathered} \text { 2167-10 } \\ \text { Min. Max. } \end{gathered}$ | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}{ }^{[1]}$ | Read Cycle Time | 55 | 70 | 100 | ns |
| $t_{\text {AA }}$ | Address Access Time | 55 | 70 | 100 | ns |
| $t_{\text {ACS }}$ | Chip Select Access Time | 55 | 70 | 100 | ns |
| ${ }^{\text {OH }}$ | Output Hold from Access Change | 5 | 5 | 5 | ns |
| $t_{L T}{ }^{[2,3]}$ | Chip Selection to Output in Low Z | 10 | 10 | 10 | ns |
| $t_{H Z}{ }^{[2,3]}$ | Chip Deselection to Output in High Z | 030 | $0 \quad 40$ | 040 | ns |
| $t_{\text {PU }}$ | Chip Selection to Power-Up Time | 40 | 50 | 55 | ns |
| $t_{\text {PD }}$ | Chip Deselection to Power-Down Time | 55 | 70 | 80 | ns |

## WAVEFORMS

## READ CYCLE NO. $1^{4.5}$



READ CYCLE NO. 24.6


## Notes:

1. All Read Cycle timings are referenced from the last valid address to the first transitioning address
2. 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.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2. This parameter is sampled and not $100 \%$ tested
4. $\overline{W E}$ is high for Read Cycles.
5. Device is continuously selected, $\overline{C S}=V_{1 L}$.
6. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.

## A.C. CHARACTERISTICS (Continued)

## WRITE CYCLE

| Symbol | Parameter | $2167.55$ <br> Min. Max. | $\begin{gathered} \text { 2167.70, } 2167 \mathrm{~L}-70 \\ \text { Min. Max. } \end{gathered}$ | $2167-10$ <br> Min. Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{W c}{ }^{[2]}$ | Write Cycle Time | 55 | 70 | 100 | ns |
| $\mathrm{t}_{\mathrm{CW}}$ | Chip Selection to End of Write | 55 | 70 | 90 | ns |
| $t_{\text {AW }}$ | Address Valid to End of Write | 55 | 70 | 95 | ns |
| $t_{\text {AS }}$ | Address Setup Time | 0 | 0 | 5 | ns |
| $t_{\text {wp }}$ | Write Pulse Width | 35 | 40 | 45 | ns |
| $t_{\text {WR }}$ | Write Recovery Time | 0 | 0 | 5 | ns |
| $t_{\text {dW }}$ | Data Valid to End of Write | 25 | 30 | 35 | ns |
| $t_{\text {DH }}$ | Data Hold Time | 0 | 0 | 0 | ns |
| $\mathrm{twz}^{[3]}$ | Write Enabled to Output in High Z | 025 | 035 | 035 | ns |
| Tow | Output Active from End of Write | 0 | 0 | 0 | ns |



Notes: 1. If $\overline{C S}$ goes high simultaneously with $\overline{W E}$ high, the output remains in a high impedance state.
2. All Write Cycle timings are referenced from the last valid address to the first transitioning address.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 2. This parameter is sampled and not $100 \%$ tested.
4. $\overline{C S}$ or $\overline{W E}$ must be high during address transitions.

# 8148 4096 x 8-BIT INTEGRATED RAM 

\author{

- Multiplexed Address and Data Buses <br> - 8 or 16-Bit System Capability <br> - On-Chip Arbitration <br> - Processor Handshake <br> - Proven HMOS-D2 Reliability <br> - 50 mA Active, 10 mA Standby
}
- Fully Integrated Refresh
- Fully Integrated Control Logic
- Automatic Wake-Up
- Multiple Refresh Modes
- 200 ns Access, 400 ns Cycle Times

The Intel 8148 is a 4096 -word by 8 -bit integrated random access memory-iRAM. Integrating all refresh control circuitry at the chip level allows the system designer to take advantage of dynamic RAM density, performance and price without the added cost of designing the refresh control interface. The 8148 is intended for use with multiplexed address/data bus microprocessors such as the Intel iAPX 86 and iAPX 88. Flexible data bus control options permit the 8148 to be arranged for operation on either 8 -bit or 16 -bit data buses. All operating parameters have been optimized for high performance, no WAIT state operation without TTL interface components. Output drive capabilities and access times are consistent with all present and future microprocessors.

Complete on-chip refresh control circuitry includes refresh address counting and multiplexing, refresh interval timing, and high speed request arbitration. Refresh operation may be controlled either externally by synchronously strobing the REFEN input 128 times in 2 msec , or internally by holding REFEN input to ground. In the internal mode of refresh operation, all refresh is automatic and nearly transparent to the user. A handshake signal to the processor, called READY, is provided to indicate when memory access occurs during refresh operation. READY is used to stop the microprocessor until the 8148 has finished doing refresh. READY, an open drain output, is then released to be pulled back high to $\mathrm{V}_{\mathrm{cc}}$, and the 8148 continues with the externally requested access cycle.

Data output location is controlled by two external pins. The internal 8-bit data bus can be shifted between the upper eight data I/O pins or the lower eight data I/O pins. This allows the same part to be used in either 8 -bit or 16 -bit systems. Multiple levels of chip selects permit linear selection of RAM by the highest order addresses.


PIN NAMES

| PIN NAMES |  |
| :---: | :---: |
| AD0-AD12 | ADDRESSIDATA I/O |
| D13-D15 | DATA I/O |
| READY | READY |
| REFEN | REFRESH ENABLE |
| WE | WRITE ENABLE |
| OE | OUTPUT ENABLE |
| ALE | ADDRESS LATCH ENABLE |
| $\overline{\text { BHE }} \overline{8}-16$ | BYTE HIGH ENABLE/8-16 |
| U/L | UPPER/LOWER |
| CS, CS, M/IO | CHIP SELECTS |
| VSS | GROUND |
| $V_{\text {cc }}$ | + 5 VOLTS |

# 2186/7 <br> $8192 \times 8$-BIT INTEGRATED RAM 

## Synchronous and Asynchronous Versions

- Fully Integrated On-Chip Refresh
- On-Chip Signal Arbitration
- Processor Handshake Signal
- Automatic Wake-Up
- 90 mA Active, 15 mA Standby
- JEDEC JC-42 Standard Pinout
- Single-Step Capability
- Two-Line Data Bus Control
- Single +5V $\pm 10 \%$ Supply
- Proven HMOS-D2 Reliability
- 200 ns Access, 320 ns Cycle Times

The Intel $2186 / 7$ is an 8192 -word by 8 -bit integrated random access memory fabricated on Intel's high performance HMOS-D2 dynamic RAM technology. By integrating all refresh control circuitry at the chip level, the 2186/7 allows the system designer to take advantage of dynamic RAM density, power consumption and price without the added cost of designing the refresh control interface. Complete on-chip circuitry includes refresh address counting and multiplexing, refresh interval timing and high speed request arbitration. Designed for flexible operation in virtually any microprocessor system, the $2186 / 7$ incorporates many features unique to microprocessor applications. These include auto precharge for single-step operation, automatic power-up, activated through the system reset, and two-line data bus control to eliminate bus contention.

Offered in two separate versions, the $2186 / 7$ is optimized to operate on either synchronous or asynchronous system memory buses. For synchronous operation, all internal functions are disabled except refresh address counting and multiplexing. In this application, the user must provide the specified 128 pulses to the REFEN input every 2 msec . For asynchronous operation, a handshake signal to the processor, called READY, is provided in lieu of REFEN to indicate when memory and system timings are incompatible (as during a refresh operation). A not ready condition occurs only when a 2186 has been accessed by CE going low during a refresh cycle. When this occurs, the refresh cycle is completed, READY is released to be pulled back high to $\mathrm{V}_{\mathrm{cc}}$, and the memory cycle continues to completion.


*REFEN OFFERED WITH SYNCHRONOUS VERSION ONLY RDY OFFERED WITH ASYNCHRONOUS VERSION ONLY

Read Only Memory and Memory Support

16K (2K x 8) UV ERASABLE PROM

- Fast Access Time
- 2716-1: 350 ns Max.
- 2716-2: 390 ns Max.
- 2716: 450 ns Max.
- 2716-5: 490 ns Max.
- 2716-6: 650 ns Max.
- Single +5 V Power Supply
- Low Power Dissipation
- Active Power: 525 mW Max.
- Standby Power: 132 mW Max.


## - Pin Compatible to Intel 2732A 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 ${ }^{\circledR} 2716$ is a 16,384 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 2716 operates from a single 5-volt power supply, has a static standby mode, and features fast single-address location programming. It makes designing with EPROMs faster, easier and more economical.

The 2716, with its single 5-volt supply and 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. A selected 2716-5 and a 2716-6 are available for slower speed applications. The 2716 is also the first EPROM with a static standby mode which reduces the power dissipation without increasing access time. The maximum active power dissipation is 525 mW while the maximum standby power dissipation is only 132 mW , a $75 \%$ savings.

The 2716 has the simplest and fastest method yet devised for programming EPROMs-single-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.
*Part(s) also available in extended temperature range for Military and Industrial grade applications.


Figure 1. Pin Configuration

## DEVICE OPERATION

The five modes of operation of the 2716 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 $\mathrm{a}+5 \mathrm{~V} \mathrm{~V}_{\mathrm{CC}}$ and $\mathrm{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.

## 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{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 $t_{\mathrm{OE}}$ after the falling edge of $\overline{\mathrm{OE}}$, assuming that $\overline{C E}$ has been low and addresses have been stable for at least $\mathrm{t}_{\mathrm{ACC}}{ }^{-t_{\mathrm{OE}}}$.

## 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{C E}$ input. When in standby mode, the outputs are in a high impedence state, independent of the $\overline{\mathrm{OE}}$ input.

## Output OR-Tieing

Because 2716s 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{\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 modes and that the output pins are only active when data is desired from a particular memory device.

## Programming

Initially, and after each erasure, all bits of the 2716 are in the "1" state. Data is introduced by selectively programming "0's" into the desired bit locations. Although only "0's" will be programmed, both " 1 's" and " 0 's" can be presented in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.

The 2716 is in the programming mode when the $V_{P P}$ 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

Table 1. Mode Selection

has a maximum width of 55 msec . The 2716 must not be programmed with a DC signal applied to the CE/PGM input.

Programming of multiple 2716 s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled 2716s may be connected together when they are programmed with the same data. A high-level TTL pulse applied to the CE/PGM input programs the paralleled 2716 s.

## 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 with $\mathrm{V}_{P P}$ at 25 V . Except during programming and program verify, $\mathrm{V}_{\mathrm{PP}}$ must be at 5 V .

## ERASURE CHARACTERISTICS

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

## 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 $\qquad$ +6 V to -0.3 V
VPP Supply Voltage with Respect to Ground During Program ......... . +26.5 V to -0.3 V
*NOTICE: 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}$ | $\mathbf{2 7 1 6 - 2}$ | $\mathbf{2 7 1 6 - 5}$ | $\mathbf{2 7 1 6 - 6}$ |
| :--- | :---: | :---: | :---: | :---: | :---: |
| 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}$ | $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 \%$ | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ |
| $\mathrm{~V}_{\mathrm{PP}}$ Power Supply ${ }^{[2]}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ |

## READ OPERATION

D.C. AND OPERATING CHARACTERISTICS

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[3]}$ | Max. |  |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}$ |
| ILO | 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{ICCl}{ }^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Standby) |  | 10 | 25 | mA | $\overline{C E}=V_{I H}, \overline{O E}=V_{I L}$ |
| $\mathrm{ICC2}^{[2]}$ | $\mathrm{V}_{\mathrm{CC}}$ Current (Active) |  | 57 | 100 | mA | $\overline{O E}=\overline{C E}=V_{I L}$ |
| $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}_{\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}$ |

## TYPICAL CHARACTERISTICS





## A.C. CHARACTERISTICS

| Symbol | Parameter | Limits (ns) |  |  |  |  |  |  |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 2716 |  | 2716-1 |  | 2716-2 |  | 2716-5 |  | 2716-6 |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {taCC }}$ | Address to Output Delay |  | 450 |  | 350 |  | 390 |  | 450 |  | 450 | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{\text {t CE }}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 450 |  | 350 |  | 390 |  | 490 |  | 650 | $\overline{O E}=V_{\text {IL }}$ |
| $\mathrm{t}_{\mathrm{OE}}{ }^{[4]}$ | Output Enable to Output Delay |  | 120 |  | 120 |  | 120 |  | 160 |  | 200 | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |
| $t_{\text {DF }}{ }^{[4]}$ | Output Enable High to Output Float | 0 | 100 | 0 | 100 | 0 | 100 | 0 | 100 | 0 | 100 | $\overline{C E}=V_{\text {IL }}$ |
| ${ }^{\text {toH }}$ | Output Hold from Addresses, $\overline{C E}$ or OE Whichever Occurred First | 0 |  | 0 |  | 0 |  | 0 |  | 0 |  | $\overline{C E}=\overline{O E}=V_{I L}$ |

CAPACITANCE ${ }^{[4]}\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter | Typ. | Max. | Units | Test <br> 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 Input Pulse Levels . . . . . . . . . . 0.8V to 2.2V Timing Measurement Reference Level:

Inputs . . . . . . . . . . . . . . . . . . . . . . 1V and 2V Outputs .................... 0.8 V and 2V
A.C. WAVEFORMS ${ }^{[1]}$


NOTES:

1. $V_{C C}$ must be applied simultaneously or before $V_{P P}$ and removed simultaneously or after $V_{P p}$.
2. VPP may be connected 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 $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. This parameter is only sampled and is not $100 \%$ tested.
5. $\overline{O E}$ may be delayed up to $t_{A C C}{ }^{-t} O E$ 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.

## PROGRAMMING CHARACTERSITICS ${ }^{[1]}$

D.C. PROGRAMMING CHARACTERISTICS $\quad\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}{ }^{[2]}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}{ }^{[2,3]}=25 \mathrm{~V} \pm 1 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Current (for Any Input) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V} / 0.45$ |
| IPP1 | VPP Supply Current |  |  | 5 | mA | $\overline{C E} /$ PGM $=V_{\text {IL }}$ |
| IPP2 | VPP Supply Current During Programming Pulse |  |  | 30 | mA | $\overline{C E} /$ PGM $=V_{I H}$ |
| $I_{\text {cc }}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  |  | 100 | mA |  |
| $\mathrm{V}_{\text {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 $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}{ }^{[2]}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}{ }^{[2,3]}=25 \mathrm{~V} \pm 1 \mathrm{~V}\right.$ )

| Symbol | Parameter | Min. | Typ. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AS }}$ | Address Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| toes | $\overline{\text { OE Setup Time }}$ | 2 |  |  | $\mu \mathrm{S}$ |  |
| ${ }^{t}{ }_{\text {DS }}$ | Data Setup Time | 2 |  |  | $\mu \mathrm{S}$ |  |
| ${ }^{\text {t }}$ AH | Address Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| toen | $\overline{\text { OE Hold Time }}$ | 2 |  |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ DH | Data Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {t }}$ D $F$ | Output Enable to Output Float Delay | 0 |  | 200 | ns | $\overline{C E} /$ PGM $=V_{1 L}$ |
| ${ }_{\text {toe }}$ | Output Enable to Output Delay |  |  | 200 | ns | $\overline{\mathrm{CE}} / \mathrm{PGM}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{\text {tPW }}$ | Program Pulse Width | 45 | 50 | 55 | ms |  |
| ${ }^{\text {tPRT }}$ | Program Pulse Rise Time | 5 |  |  | ns |  |
| $t_{\text {PFT }}$ | Program Pulse Fall Time | 5 |  |  | ns |  |

A.C. CONDITIONS OF TEST

| $V_{C C}$ | $5 \mathrm{~V} \pm 5 \%$ |
| :---: | :---: |
| VPP | $25 \mathrm{~V} \pm 1 \mathrm{~V}$ |
|  | 20 n |

Input Pulse Levels ............................. . . 0.8 to 2.2 V
Input Timing Reference Level ................... IV and 2V
Output Timing Reference Level .............. 0.8V and 2V

PROGRAMMING WAVEFORMS $\quad\left(V_{P P}=25 V \pm 1 V, V_{C C}=5 V \pm 5 \%\right)$


NOTE:
alL times shown in parentheses are minimum times and are $\mu$ SEC unless otherwise noted.

## NOTES:

1. Intel's standard product warranty applies only to devices programmed to specifications described herein.
2. $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$. The 2716 must not be inserted into or removed from a board with $\mathrm{V}_{\mathrm{PP}}$ at $25 \pm 1 \mathrm{~V}$ to prevent damage to the device.
3. The maximum allowable voltage which may be applied to the $V_{\rho p}$ pin during programming is +26 V . Care must be taken when switching the $V_{\text {PP }}$ supply to prevent overshoot exceeding this 26 V maximum specification.

32K (4K x 8) UV ERASABLE PROM

- 200 ns (2732A-2) Maximum Access Time . . . HMOS*-E Technology
- Compatible to High Speed 8 MHz 8086-2 MPU . . . Zero WAIT State
- Two Line Control


## - Pin Compatible to 2764 EPROM

\author{

- Industry Standard Pinout . . . JEDEC Approved <br> - Low Standby Current . . . 35 mA Maximum <br> - $\pm 10 \% V_{C C}$ Tolerance Available
}

The Intel ${ }^{\circledR}$. 2732 A is a 5 V only, 32,768 bit ultraviolet erasable and electrically programmable read-only memory (EPROM). It is pin compatible to Intel's 450 ns 2732 . The standard 2732A's access time is 250 ns with speed selection (2732A-2) available at 200 ns . The access time is compatible to high performance microprocessors, such as the $8 \mathrm{MHz} 8086-2$. In these systems, the 2732A allows the microprocessor to operate without the addition of WAIT states.
An important 2732A 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-72 describes the microprocessor system implementation of the $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}}$ controls on Intel's EPROMs. AP-72 is available from Intel's Literature Department.
The 2732A has a standby mode which reduces the power dissipation without increasing access time. The maximum active current is 125 mA , while the maximum standby current is only 35 mA , a $70 \%$ saving. The standby mode is achieved by applying a TTL-high signal to the $\overline{C E}$ input.
The 2732A is fabricated with HMOS*-E technology, Intel's high-speed N-channel MOS Silicon Gate Technology.
*HMOS is a patented process of Intel Corporation.


Figure 1. Block Diagram
Figure 2. Pin Configurations

[^3]
## ERASURE CHARACTERISTICS

The erasure characteristics of the 2732A are such that erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms (A) 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 2732A in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 2732A is to be exposed to these types of light ing conditions for extended periods of time, opaque labels are available from Intel which should be placed over the 2732A window to prevent unintentional erasure.

The recommended erasure procedure for the 2732A 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 $12000 \mu \mathrm{~W} / \mathrm{cm}^{2}$ power rating. The 2732A 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 2732A are listed in Table 1. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{Pp}}$ during programming. In the program mode the $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ input is pulsed from a TTL level to 21 V .

Table 1. Mode Selection

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

## Read Mode

The 2732A has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable $\overline{(C E)}$ 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 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_{\mathrm{ACC}}-\mathrm{t}_{\mathrm{OE}}$.

## Standby Mode

The 2732A has a standby mode which reduces the active power current from 125 mA to 35 mA . The 2732A is placed
in the standby mode by applying a TTL-high signal to the $\overline{C E}$ input. When in standby mode, the outputs are in a high impedance state, independent of the $\overline{\mathrm{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 connection. 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 use these two control lines most efficiently, 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 (See Programming Instruction Section for Waveforms.)

Programming is the same as Intel's 450 ns 2732 except for the programming voltage. In the program mode the 2732A $\overline{O E} / V_{\text {PP }}$ input is pulsed from a TTL low level to $21 \mathrm{~V}(25 \mathrm{~V}$ for the 2732). Exceeding 22 V will damage the 2732A.

Initially, and after each erasure, all bits of the 2732A 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 present in the data word. The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.

The 2732A is in the programming mode when the $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ input is at 21 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 2732A must not be programmed with a DC signal applied to the $\overline{\mathrm{CE}}$ input.

Programming of multiple 2732As in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled 2732As may be connected together when they are programmed with the same data. A low level TTL pulse applied to the $\overline{C E}$ input programs the paralleled 2732As.

## Program Inhibit

Programming of multiple 2732As in parallel with different data is also easily accomplished. Except for $\overline{C E}$, all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel 2732As may be common. A TTL level program pulse applied to a 2732A's $\overline{C E}$ input with $\overline{O E} / V_{P P}$ at 21 V will program that 2732 A . A high level $\overline{C E}$ input inhibits the other $2732 A 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_{\text {IL }}$. Data should be verified $t_{D V}$ after the falling edge of $\overline{C E}$.

## System Consideration

The power switching characteristics of HMOS-E EPROMs require careful decoupling of the devices. The supply current, Icc, has three segments that are of interest to the system designer-the standby current level, the active current level, and the transient current peaks that are produced on the falling and rising edges of Chip Enable. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated transient voltage peaks can be suppressed by complying with Intel's Two-Line Control, as detailed in Intel's Application Note, AP-72, and/or by properly selected decoupling capacitors. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high frequency capacitor of low inherent inductance. In addition, a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage droop caused by the inductive effects of the PC board-traces.

## 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 Programming . . . . . . . . . . . . . . +22 V to -0.3 V
*NOTICE: 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

|  | 2732A/A-2/A-3/A-4 | 2732A-20/A-25/A-30 |
| :--- | :---: | :---: |
| Operating Temperature Range | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\text {CC }}$ Power Supply | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 10 \%$ |

## READ OPERATION

## D.C. CHARACTERISTICS

| Symbol | Parameter | Limits |  |  | Units | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $I_{\text {IL }}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{~N}}=5.5 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | $\mathrm{V}_{\text {CC }}$ Current (Standby) |  |  | 35 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{1 H}, \overline{\mathrm{OE}}=\mathrm{V}_{1 \mathrm{~L}}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{V}_{\mathrm{CC}}$ Current (Active) |  |  | 125 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | 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}$ |

A.C. CHARACTERISTICS

| Symbol | Parameter | $\begin{aligned} & \text { 2732A-2 } \\ & \text { 2732A-20 } \end{aligned}$ |  | $\begin{gathered} \text { 2732A } \\ 2732 A-25 \end{gathered}$ |  | $\begin{gathered} \text { 2732A-3 } \\ 2732 A-30 \end{gathered}$ |  | 2732A-4 |  | Units | Test Conditions* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to Output Delay |  | 200 |  | 250 |  | 300 |  | 450 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{1 L}$ |
| $\mathrm{t}_{\text {CE }}$ | $\overline{\mathrm{CE}}$ to Output Delay |  | 200 |  | 250 |  | 300 |  | 450 | ns | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{t}_{\text {OE }}$ | $\overline{O E}$ to Output Delay |  | 70 |  | 100 |  | 150 |  | 150 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $t_{D F}{ }^{[2]}$ | $\overline{\text { OE High to Output Float }}$ | 0 | 60 | 0 | 90 | 0 | 130 | 0 | 130 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{1 \mathrm{~L}}$ |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ Whichever Occurred First | 0 |  | 0 |  | 0 |  | 0 |  | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |

## *A.C. TEST CONDITIONS

| Output Load .............. 1 TTL gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |  |
| :---: | :---: |
| Input Rise and Fall Times |  |
| Input Pulse L | 2.4 |
| Timing Measurement Reference Level: |  |
| Inputs | 0.8 and 2.0 V |
| Outputs | 0.8 and 2.0V |

CAPACITANCE ${ }^{[2]} \quad\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

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

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORM



## 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. $\overline{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impacting $t_{A C C}$
4. $t_{D F}$ is specified from $\overline{O E}$ or $\overline{C E}$, whichever occurs first.

## PROGRAMMING

D.C. PROGRAMMING CHARACTERISTICS ${ }^{[5]}\left(T_{A}=25 \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}=21 \mathrm{~V} \pm 0.5 \mathrm{~V}\right)$

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $I_{L I}$ | Input Current (All Inputs) |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{IL}}$ or $\mathrm{V}_{\mathrm{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}$ |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 85 | 125 | mÁ |  |
| $\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 |  |
| IPP | $\mathrm{V}_{\text {Pp }}$ Supply Current |  |  | 35 | mA | $\overline{C E}=V_{1 L}, \overline{O E}=V_{P P}$ |

## NOTE:

5. When programming the 2732 A , a $0.1 \mu \mathrm{~F}$ capacitor is required across $\overline{\mathrm{OE}} / \mathrm{V}_{\mathrm{PP}}$ and ground to suppress spurious voltage transients which may damage the device.
A.C. PROGRAMMING CHARACTERISTICS $\left(T_{A}=25 \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{P P}=21 \mathrm{~V} \pm 0.5 \mathrm{~V}\right.$ )

| Symbol | Parameter | Limits |  |  | Units | Test Conditions $\dagger$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $t_{\text {AS }}$ | Address Setup Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| toes | $\overline{O E}$ 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}$ |  |
| $\mathrm{t}_{\text {OEH }}$ | OE Hold Time | 2 |  |  | $\mu \mathrm{S}$ |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time | 2 |  |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip Enable to Output Float Delay | 0 |  | 130 | ns |  |
| $t_{\text {DV }}$ | Data Valid from $\overline{C E}$ |  |  | 1 | $\mu \mathrm{S}$ | $\overline{C E}=V_{\text {IL }}, \overline{O E}=V_{\text {IL }}$ |
| $t_{\text {PW }}$ | CE Pulse Width During Programming | 45 | 50 | 55 | ms |  |
| $t_{\text {PRT }}$ | $\overline{\text { OE Pulse Rise Time During Programming }}$ | 50 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{VR}}$ | $\mathrm{V}_{\text {PP }}$ Recovery Time | 2 |  |  | $\mu \mathrm{s}$ |  |

## tA.C. TEST CONDITIONS

|  |  |
| :---: | :---: |
| Input Pulse Levels | 0.45 V to 2.4 V |
| Input Timing Reference Level | . 0 and 2.0 V |
| Reference Leve | 0.8 and 2.0 V |

WAVEFORM


# 2764 <br> <br> (8K x 8) UV ERASABLE PROM 

 <br> <br> (8K x 8) UV ERASABLE PROM}

- 200 ns (2764-2) Maximum Access Time . . . HMOS*-E Technology


## - Compatible to High Speed 8 mHz 8086-2 MPU . . . Zero WAIT State

## - Two Line Control

- Pin Compatible to 2732A EPROM

■ Industry Standard Pinout . . . JEDEC Approved

- Low Active Current... 100 mA Max.
- $\pm 10 \% V_{\text {CC }}$ Tolerance Available

The Intel ${ }^{\oplus} 2764$ is a 5 V only, 65,536 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The standard 2764 access time is 250 ns with speed selection available at 200 ns . The access time is compatible to high performance microprocessors, such as Intel's $8 \mathrm{mHz} 8086-2$. In these systems, the 2764 allows the microprocessor to operate without the addition of WAIT states.

An important 2764 feature is the separate output control, Output Enable ( $\overline{(O E}$ ) 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-72 describes the microprocessor system implementation of the $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}}$ controls on Intel's EPROMs. AP-72 is available from Intel's Literature Department.

The 2764 has a standby mode which reduces the power dissipation without increasing access time. The active current is 100 mA , while the standby current is only 40 mA . The standby mode is achieved by applying a TTL-high signal to the $\overline{\mathrm{CE}}$ input.
$\pm 10 \% V_{C C}$ tolerance is available as an alternative to the standard $\pm 5 \% V_{C C}$ tolerance for the 2764. This can allow the system designer more leeway in terms of his power supply requirements and other system parameters.

The 2764 is fabricated with HMOS*-E technology, Intel's high-speed N-channel MOS Silicon Gate Technology.
MODE SELECTION

|  | $\begin{aligned} & \overline{C E} \\ & (20) \\ & \hline \end{aligned}$ | $\begin{gathered} \overline{O E} \\ (22) \\ \hline \end{gathered}$ | $\begin{aligned} & \overline{\text { PGM }} \\ & (27) \end{aligned}$ | $V_{\text {pp }}$ <br> (1) | $\mathbf{V}_{\mathrm{cc}}$ (28) | $\begin{aligned} & \text { Outputs } \\ & (11-13,15-19) \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{LL}}$ | $\mathrm{V}_{11}$ | $\mathrm{V}_{1 \mathrm{H}}$ | $V_{c c}$ | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{D}_{\text {OUT }}$ |
| Standby | $\mathrm{V}_{\text {th }}$ | x | x | $V_{c c}$ | $V_{c c}$ | High Z |
| Program | $\mathrm{V}_{\mathrm{LL}}$ | x | $\mathrm{V}_{1}$ | $V_{\text {Pp }}$ | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $\mathrm{V}_{\mathrm{L}}$ | $\mathrm{V}_{1}$ | $\mathrm{V}_{\text {IH }}$ | $V_{\text {pp }}$ | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{D}_{\text {out }}$ |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | x | $\times$ | $\mathrm{V}_{\text {pp }}$ | $\mathrm{V}_{\mathrm{cc}}$ | High Z |

$x$ can be either $V_{I L}$ or $V_{H}$
PIN NAMES

| $\mathrm{A}_{0}-\mathrm{A}_{12}$ | ADDRESSES |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | CHIP ENABLE |
| $\overline{\mathrm{OE}}$ | OUTPUT ENABLE |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | OUTPUTS |
| $\overline{\mathrm{PGM}}$ | PROGRAM |
| N.C. | NO CONNECT |

*HMOS is a patented process of Intel Corporation.

[^4]| ABSOLU |  |
| :---: | :---: |
| Temperature Under Bias $\ldots \ldots \ldots \ldots \ldots . .10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$Storage Temperature $\ldots . . . . . . . . . . . .-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
|  |  |
| All Input or Output Voltages with |  |
| Respect to Ground | 0.6 |
| $\mathrm{V}_{\text {pp }}$ Supply Voltage with Respect to Ground |  |
|  |  |

*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 A.C. OPERATING CONDITIONS DURING READ

|  | $\mathbf{2 7 6 4 - 2}$ | $\mathbf{2 7 6 4}$ | $\mathbf{2 7 6 4 - 3}$ | $\mathbf{2 7 6 4 - 4}$ |
| :--- | :---: | :---: | :---: | :---: |
| Operating Temperature <br> 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}$ | $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 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ |
| $\mathrm{~V}_{\mathrm{PP}}$ Voltage $^{2}$ | $\mathrm{~V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |


| $\mathbf{2 7 6 4 - 2 5}$ | $\mathbf{2 7 6 4 - 3 0}$ | $\mathbf{2 7 6 4 - 4 5}$ |
| :---: | :---: | :---: |
| $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |
| $5 \mathrm{~V} \pm 10 \%$ | $5 \mathrm{~V} \pm 10 \%$ | $5 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{~V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |

## READ OPERATION

## D.C. AND OPERATING CHARACTERISTICS

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{3}$ | Max |  |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{L}}$ | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {OUT }}=5.5 \mathrm{~V}$ |
| ${\mathrm{IPP} 1^{2}}$ | $\mathrm{V}_{\text {pp }}$ Current Read |  |  | 5 | mA | $\mathrm{V}_{\mathrm{PP}}=5.5 \mathrm{~V}$ |
| $\mathrm{ICCl}^{2}$ | $\mathrm{V}_{\text {cc }}$ Current Standby |  |  | 40 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |
| $\mathrm{ICC2}^{2}$ | $\mathrm{V}_{\mathrm{cc}}$ Current Active |  | 70 | 100 | mA | $\overline{\mathrm{CE}}=\cdot \overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{LL}}$ |
| $\mathrm{V}_{\mathrm{LL}}$ | Input Low Voltage | -. 1 |  | +. 8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V |  |
| $V_{\text {OL }}$ | Output Low Voltage |  |  | . 45 | 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}$ |

## A.C. CHARACTERISTICS

| Symbol | Parameter | 2764-2 Limits |  | 2764-25 \& 2764 Limits |  | 2764-30 \& 2764-3 Limits |  | 2764-45 \& 2764-4 Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| ${ }^{\text {t }}$ ACC | Address to Output Delay |  | 200 |  | 250 |  | 300 |  | 450 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\text {t }}$ CE | $\overline{\mathrm{CE}}$ to Output Delay |  | 200 |  | 250 |  | 300 |  | 450 | ns | $\overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{OE}$ | $\overline{\text { OE to Output Delay }}$ |  | 75. |  | 100 |  | 120 |  | 150 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }_{t D F}{ }^{4}$ | $\overline{\text { OE High to Output Float }}$ | 0 | 60 | 0 | 85 | 0 | 105 | 0 | 130 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{\text {t }} \mathrm{OH}$ | Output Hold from Addresses, $\overline{C E}$ or $\overline{O E}$ Whichever Occurred First | 0 |  | 0 |  | 0 |  | 0 |  | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{1 L}$ |

NOTES: 1. $V_{c c}$ must be applied simultaneously or before $V_{p p}$ and removed simultaneousiy or after $\forall_{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 $t_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
4. This parameter is only sampled and not $100 \%$ tested.

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

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

## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT
A.C. TESTING LOAD CIRCUIT

$C_{L}=100 \mathrm{pF}$
C INCLUDES JIG CAPACITANCE

## A.C. WAVEFORMS



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. $\overline{O E}$ may be delayed up to $t_{A C C}-t_{D E}$ after the falling edge of $\overline{C E}$ without impact on $t_{A C C}$.
4. $t_{D F}$ is specified from $\overline{O E}$ or $\overline{C E}$, whichever occurs first.

## PROGRAMMING

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}}=21 \mathrm{~V} \pm 0.5 \mathrm{~V}$ (see Note 1)

| Symbol | Parameter | Limits |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Unit |  |
| $\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{l}_{\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} 2}$ | $\mathrm{V}_{\mathrm{cc}}$ Supply Current (Active) |  |  | 100 | mA |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Level (All Inputs) | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Level | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V |  |
| $\mathrm{I}_{\text {PP }}$ | $\mathrm{V}_{\text {pp }}$ Supply Current |  |  | 30 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{LL}}=\overline{\text { PGM }}$ |

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}}=21 \mathrm{~V} \pm 0.5 \mathrm{~V}$ (see Note 1)

| Symbol | Parameter | Limits |  |  |  | Test Conditions* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Unit |  |
| $\mathrm{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}$ |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time | 2 |  |  | $\mu \mathrm{S}$ |  |
| $\mathrm{t}_{\mathrm{DF}}$ | Chip Enable to Output Float Delay | 0 |  | 130 | ns |  |
| $\mathrm{t}_{\mathrm{vs}}$ | $\mathrm{V}_{\text {pp }}$ Setup Time | 2 |  |  | $\mu \mathrm{S}$ |  |
| $\mathrm{t}_{\text {pw }}$ | $\overline{\text { PGM Pulse Width During Programming }}$ | 45 | 50 | 55 | ms |  |
| $\mathrm{t}_{\text {ces }}$ | $\overline{\overline{C E}}$ Setup Time | 2 |  |  | $\mu \mathrm{S}$ |  |
| toe | Data Valid from $\overline{\mathrm{OE}}$ |  |  | 150 | ns |  |

## *A.C. CONDITIONS OF TEST

Input Rise and Fall Times ( $10 \%$ to $90 \%$ ) . . . . . . . . . . 20 ns Input Pulse Levels . . . . . . . . . . . . . . . . . . . . . 0.45 V to 2.4 V Input Timing Reference Level . . . . . . . . . . . . . . 1 V and 2 V Output Timing Reference Level
0.8 V and 2.0 V

NOTE:

1. $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$.

## PROGRAMMING WAVEFORMS



## ERASURE CHARACTERISTICS

The erasure characteristics of the 2764 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 2764 in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the 2764 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 2764 window to prevent unintentional erasure.

The recommended erasure procedure for the 2764 is exposure to shortwave ultraviolet light which has a wavelength of 2537 Angstroms (Å). The integrated dose (i.e., UV intensity X exposure time) for erasure should be a minimum of 15 W -sec/ $\mathrm{cm}^{2}$. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with 12000 $\mu \mathrm{W} / \mathrm{cm}^{2}$ power rating. The 2764 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 2764 are listed in Table 1. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for $V_{p p}$.

TABLE 1. MODE SELECTION

|  | $\begin{array}{\|l\|} \hline \overline{\mathrm{CE}} \\ \hline(20) \end{array}$ | $\begin{aligned} & \overline{\mathrm{OE}} \\ & \text { (22) } \end{aligned}$ | $\begin{array}{\|c} \overline{\text { PGM }} \\ \mathbf{( 2 7 )} \end{array}$ | $\mathbf{V}_{\mathrm{PP}}$ <br> (1) | $\begin{aligned} & \mathbf{V}_{c c} \\ & (28) \end{aligned}$ | $\begin{array}{c\|} \text { Outputs } \\ (11-13,15-19) \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | V L | $\mathrm{V}_{1}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{D}_{\text {oút }}$ |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | x | x | $\mathrm{V}_{\mathrm{cc}}$ | $V_{c c}$ | High Z |
| Program | $\mathrm{V}_{\mathrm{LL}}$ | $\mathrm{V}_{\mathrm{iH}}$ | $\mathrm{V}_{\mathrm{LL}}$ | $\mathrm{V}_{\text {PP }}$ | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{D}_{\text {IN }}$ |
| Program Verify | $\mathrm{V}_{\mathrm{LL}}$ | $\mathrm{V}_{1 \mathrm{~L}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\text {PP }}$ | $\mathrm{V}_{\mathrm{cc}}$ | $\mathrm{D}_{\text {out }}$ |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | x | x | $\mathrm{V}_{\text {Pp }}$ | $\mathrm{V}_{\mathrm{cc}}$ | High Z |

$x$ can be either $\mathrm{V}_{\mathrm{L}}$ or $\mathrm{V}_{\mathrm{H}}$

## READ MODE

The 2764 has two control functions, both of which must be logically active in order to obtain data at the outputs. Chip Enable (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 after a delay of $\mathrm{t}_{\mathrm{OE}}$ from 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 2764 has a standby mode which reduces the active power current from 100 mA to 40 mA . The 2764 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 impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## Output OR-Tieing

Because EPROMs are usually used in larger memory arrays, Intel has provided 2 control lines which accommodate this multiple memory connection. The two control lines allow for:
a) the lowest possible memory power dissipation, and
b) complete assurance that output bus contention will not occur.

To use these two control lines most efficiently, $\overline{C E}$ (pin 20) should be decoded and used as the primary device selecting function, while $\overline{O E}$ ( pin 22 ) should 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.

## System Consideration

The power switching characteristics of HMOS-E EPROMs require careful decoupling of the devices. The supply current, ICC, has three segments that are of interest to the system designer - the standby current level, the active current level, and the transient current peaks that are produced on the falling and rising edges of Chip Enable. The magnitude of these transient current peaks is dependent on the output capacitance loading of the device. The associated transient voltage peaks can be suppressed by complying with Intel's Two-Line Control, as detailed in Intel's Application Note, AP-72, and/or by properly selected decoupling capacitors. It is recommended that a $0.1 \mu \mathrm{~F}$ ceramic capacitor be used on every device between $V_{C C}$ and GND. This should be a high
frequency capacitor of low inherent inductance. In addition, a $4.7 \mu \mathrm{~F}$ bulk electrolytic capacitor should be used between $V_{C C}$ and GND for each eight devices. The bulk capacitor should be located near where the power supply is connected to the array. The purpose of the bulk capacitor is to overcome the voltage droop caused by the inductive effects of the PC board-traces:

## Programming

## Caution: Exceeding 22V on pin 1 ( $V_{\mathrm{PP}}$ ) will damage the 2764.

Initially, and after each erasure, all bits of the 2764 are in the " 1 " state. Data is introduced by selectively programming " $0 s$ " into the desired bit locations. Although only "0s" will be programmed, both " 1 s " and " 0 s " can be present in the data word: The only way to change a " 0 " to a " 1 " is by ultraviolet light erasure.

The 2764 is in the programming mode when $\mathrm{V}_{\mathrm{pp}}$ input is at 21 V and $\overline{\mathrm{CE}}$ and $\overline{\mathrm{PGM}}$ are both at TTL low. 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.

For programming, $\overline{\mathrm{CE}}$ should be kept TTL low at all times while $\mathrm{V}_{\mathrm{pp}}$ is kept at 21 V . When the address and data are stable, a 50 msec , active low, TTL program pulse is applied to $\overline{\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 .

Programming of multiple 2764s in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled 2764s may be connected together when they are programmed with the same data. A low. level TTL pulse applied to the $\overline{\mathrm{PGM}}$ input programs the paralleled 2764s.

## Program Inhibit

Programming of multiple 2764s in parallel with different data is also easily accomplished. A high level $\overline{\mathrm{CE}}$ or $\overline{\mathrm{PGM}}$ input inhibits the other 2764s from being programmed. Except for $\overline{\mathrm{CE}}$ (or $\overline{\mathrm{PGM}}$ ), all like inputs (including $\overline{\mathrm{OE}}$ ) of the parallel 2764s may be common. A TTL low level pulse applied to a $2764 \overline{\mathrm{CE}}$ and $\overline{\mathrm{PGM}}$ input with $\mathrm{V}_{\text {Pp }}$ at 21 V will program that 2764.

## Program Verify

A verify should be performed on the programmed bits to determine that they were correctly programmed. The verify is accomplished with $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ at $\mathrm{V}_{\mathrm{IL}}$. However, $\overline{\mathrm{PGM}}$ is at $\mathrm{V}_{\mathrm{IH}}$.

ADVANCE INPORNATION

# 27128 <br> 128K (16K x 8) UV ERASABLE PROM 

- 200 ns (27128-2) Maximum Access Time . . . HMOS*-E Technology
- Compatible to High-Speed $8 \mathbf{M H z}$ 8086-2 MPU . . . Zero WAIT State


## - Pin Compatible to 2764 EPROM <br> - Industry Standard Pinout . . . JEDEC Approved <br> - $\pm 10 \% V_{\text {Cc }}$ Tolerance Available

## - Two-Line Control

The Intel 27128 is a 5 V only, 131,072 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The standard 27128 access time is 250 ns with speed selection available at 200 ns . The access time is compatible to high-performance microprocessors, such as Intel's $8 \mathrm{MHz} 8086-2$. In these systems, the 27128 allows the microprocessor to operate without the addition of WAIT states.
An important 27128 feature is the separate output control, Output Enable (OE) from the Chip Enable control (CE). The OE control eliminates bus contention in multiple-bus microprocessor systems. Intel's Application Note AP-72 describes the microprocessor system implementation of the OE and CE controls on Intel's EPROMs. AP-72 is available from Intel's Literature Department.
The 27128 has a standby mode which reduces the power dissipation without increasing access time. The active current is 150 mA , while the standby current is only 45 mA . The standby mode is achieved by applying a TTL-high signal to the CE input.
$\pm 10 \% V_{C C}$ tolerance is available as an alternative to the standard $\pm 5 \% V_{C C}$ tolerance for the 27128. This can allow the system designer more leeway in terms of his power supply requirements and other system parameters.
The 27128 is fabricated with HMOS*-E technology, Intel's high-speed N-channel MOS Silicon Gate Technology. *HMOS is a patented process of Intel Corporation.


Figure 1. Block Diagram

| PIN NAMES |  |
| :---: | :---: |
| $\mathrm{A}_{0}-\mathrm{A}_{13}$ | ADDRESSES |
| $\overline{\mathrm{CE}}$ | CHIP ENABLE |
| $\overline{\text { OE }}$ | OUTPUT ENABLE |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | OUTPUTS |
| PGM | PROGRAM |
| N.C. | NO CONNECT |



Figure 2. Pin Configuration

# 2815* <br> 16K (2K X 8) ELECTRICALLY ERASABLE PROM 

\author{

- Reliable Floating Gate Technology <br> - Cost-Effective Non-Volatile Memory Alternative <br> - Erase/Write Specifications Guaranteed $0-70^{\circ} \mathrm{C}$ <br> - Very Fast Access Times <br> -2815, 250 ns Max. <br> -2815-3, 350 ns <br> -2815-4, 450 ns
}

\author{

- Two-Line Control <br> - Low Power Dissipation <br> -Active Current, 110 mA <br> -Standby Current, 50 mA
}
- Compatible with 2716 EPROM
- Simple 21V Programming Interface

The Intel 2815 is a 2048-word by 8-bit Electrically Eraseable Programmable Read Only Memory ( $E^{2}$ PROM). It is fabricated using Intel's FLOTOX cell design and powerful HMOS $-E^{\dagger}$ technology. The 2815 's $E^{2}$ functionality enables in-circuit reprogrammable memory flexibility, while maintaining the non-volatility of the data stored.
The Intel 2815 is easily erased and written in-circuit. Byte and chip erasure are accomplished with a single 50 mS pulse after which data can be written a byte at a time. Becau'se of its unique architecture, selection of the chip to be erased or written is performed with the same address control circuitry as that used for read operations.
Read operations with the 2815 are performed at standard 5V TTL levels. The 250 ns access time is fast enough so that the 2815 can be interfaced to processor system busses with no wait states. The microprocessor to 2815 interface is achieved with a minimum of external circuitry.

The 2815 was designed in accordance with Intel's byte-wide pinout philosophy and therefore conforms to the JEDEC approved byte-wide family standard. The two-line control architecture of this standard ensures elimination of bus contention in high-speed microprocessor systems. The 2815 is pin-for-pin compatible with the Intel $2816 E^{2}$ PROM and it is therefore directly upgradable for those systems requiring faster write times in the future.
Application of the 2815 for program storage, error logging, or prototyping memory maximizes the user potential to reduce service costs. As a program storage medium, users are able to update firmware remotely, saving the costs of increased parts inventories and more frequent service calls. Revision levels, service call logs, and system configuration parameters can also be stored non-volatilely, so that they can be easily accessed or updated on a service call. The 2815 is also an excellent alternative to CMOS RAMs and batteries in systems requiring non-volatile parameter storage. The 2815's many features, wide temperature range, extremely reliable operation, and design-in ease combine to give you a powerful tool for adding dramatically increased functionality to your systems.
${ }^{\dagger}$ HMOS-E is a patented process of Intel Corporation.
*PART(S) ALSO AVAILABLE IN EXTENDED TEMPERATURE RANGE FOR INDUSTRIAL GRADE APPLICATIONS.


2815 Functional Block Diagram


Pin Configuration

| PIN NAMES |  |
| :--- | :--- |
| $A_{0} \cdot A_{10}$ | ADDRESSES |
| $\overline{C E}$ | CHIP ENABLE |
| $\overline{O E}$ | OUTPUT ENABLE |
| $0_{0} \cdot 0_{7}$ | DATA OUTPUTS |
| $I_{0}-17$ | DATA INPUTS |
| $V_{P P}$ | PROGRAM VOLTAGE |

## device operation

The 2815 has 6 modes of operation, listed in Table 1. All operational modes are designed to provide maximum microprocessor compatibility and system consistancy. The device pinout is a part of Intel's JEDEC approved byte-wide Non-Volatile Memory family, allowing appropriate and cost-effective density and functionality upgrades.

All control input signals are TTL compatible with the exception of chip erase. A 9 to 15 V signal is required at pin 20 to enable the chip erase function. The $V_{P P}$ voltage must also be pulsed to 21 V during chip erase, byte erase, and byte write, and held to 4 to 6 volts during the read and standby modes.

Table 1. Mode Selection $V_{C C}=+5 \mathrm{~V}$

| Pin <br> Mode | $\begin{aligned} & \overline{C E} \\ & \text { (18) } \end{aligned}$ | $\begin{gathered} \overline{O E} \\ (20) \end{gathered}$ | $V_{P P}$ <br> (21) | Inputs/ Outputs |
| :---: | :---: | :---: | :---: | :---: |
| READ | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +4 to +6 | Dout |
| STANDBY | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{array}{\|l\|} \hline \text { DON'T } \\ \text { CARE } \end{array}$ | +4 to +6 | HIGH Z |
| BYTE ERASE | $V_{1 L}$ | $\mathrm{V}_{\mathrm{IH}}$ | +21 | $\mathrm{D}_{\text {IN }}=\mathrm{V}_{1 H}$ |
| BYTE WRITE | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | +21 | $\mathrm{D}_{\text {IN }}$ |
| CHIP ERASE | VIL | $\begin{aligned} & +9 \text { to } \\ & +15 \mathrm{~V} \end{aligned}$ | +21 | ${ }_{D_{I N}=\dot{V}_{I H}}$ |
| E/W INHIBIT | $\mathrm{V}_{\text {IH }}$ | $\begin{array}{\|l\|} \text { DON'T } \\ \text { CARE } \end{array}$ | $\begin{aligned} & +4 \text { to } \\ & +22 V \end{aligned}$ | HIGH Z |

## ERASE MODE

The 2815 is erased and reprogrammed electrically rather than optically, as is required with EPROMs. By applying a pulse to the output enable ( $\overline{\mathrm{OE}}$ ) and $\mathrm{V}_{P P}$ pin of the 2815, the chip erase function is performed and all 2 K bytes of data are returned to a logic 1 (FF) state. The chip erase function is engaged when the $\overline{\mathrm{OE}}$ pin is raised above 9 volts. When $\overline{\mathrm{OE}}$ is greater than 9 volts and $\overline{C E}$ and $V_{P P}$ are in the normal write mode, the entire array is erased. The data input pins must be held to a TTL high level during this time. Figure 1 is the recommended $\overline{O E}$ control switch.

Byte erasure is accomplished by writing a pattern of FF to the byte being addressed while the $\overline{\mathrm{OE}}$ pin is held at a high TTL level.


Figure 1. $\overline{\mathbf{O E}}$ Chip Erase Control

## WRITE MODE

To write a byte of data, the selected address and data are provided at the inputs of the 2815 (all at TTL levels). The write is then performed when the $V_{P P}$ line is raised.

The shape of the $V_{P P}$ pulse is important in ensuring long term reliability and operating characteristics. $V_{\text {PP }}$ must be raised to 21 V through an RC waveform (exponential). See figure 2 a for a specific diagram of the $V_{P P}$ pulse. The $T_{P R C}$ specification has been designed to accommodate changes of RC due to temperature variations. Figure 2 shows a recommended $V_{P P}$ switch design, useful where programming will occur over the specified temperature and operating voltage conditions. The circuitry shown in this figure will provide sufficient drive for four 2815 devices. The circuitry in Figure 3 shows the additional circuitry needed to provide enough drive for eight 2815 devices.


Figure 2. VPP Switch Design-4 Devices


Figure 2a. $\mathbf{V P P}_{\text {P }}$ Waveform
For systems where 24 V is not available as a supply voltage, the design of a step-up regulator has been included (Figure 4). This design provides the necessary voltage and current to allow the programming of eight 2815 devices.

A characteristic of all $E^{2}$ PROMs is that the total number of erase/write cycles is not unlimited. The 2815 has been designed and manufactured to meet applications requiring up to $10^{4}$ erase/write cycles.


Figure 3. $\mathrm{V}_{\mathrm{PP}}$ Switch Design-8 Devices


Figure 4. Step-up Regulator Converts +5 V Into $+\mathbf{2 4 V}$

## READ OPERATION

Optimal system efficiency depends to a great extent on a tightly coupled microprocessor/memory interface. The $E^{2}$ PROM device should respond rapidly with data to allow the highest possible CPU performance. Program execution directly out of electrically eraseable memory has never before been possible. The 2815 opens this new, powerful application segment.

The 2815 uses Intel's proven 2-line control architecture for read operations. Both $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ must be at logic low levels to obtain information from the device.

By applying the appropriate address to lines $A_{0}-A_{10}$, 8 -bit data is presented at the data lines after an access delay. Assuming that the address is stable, lowering $\overline{C E}$ will cause data to be presented a maximum of $t_{\text {acc }}$ later ( $\overline{O E}$ is low at $t_{a c c}-t_{O E}$ time). With all conditions satisfied except $\overline{\mathrm{OE}}$, low data will be valid a maximum of $t_{\mathrm{OE}} \mathrm{ns}$ after $\overline{\mathrm{OE}}$ is lowered.

Figure 5 shows a typical system interconnection. Here, the 2815 contains program information that the 8088 requires for the system function.


Figure 5. iAPX 88/2815 Read Architecture

## STANDBY MODE

The 2815 has a standby mode which reduces active power dissipation by $50 \%$. The 2815 is placed in standby mode by applying aTTL high signal to the $\overline{\mathrm{CE}}$ input. When in the standby mode, the outputs are in high impedance state, independent of the $\overline{\mathrm{OE}}$ input.

## OR-TIEING

Because 2815s are usually used in larger memory arrays, Intel has provided a 2 -line control architecture that accommodates the use of multiple memory
connections. The 2 -line control allows removal of bus contention from the system environment and much easier memory system implementation.

To most effectively use these two control lines, it is recommended that CE be decoded from addresses as the primary device selection function. $\overline{\mathrm{OE}}$ should be made a common connection to all devices in the system, and connected to the RD line from the system 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. Timing for a system configured in this manner is illustrated in Figure 6.

## PIN COMPATIBILITY

The 2815 pinout has been designed for compatibility with present and future memory products. The 2815 $E^{2}$ PROM is a member of Intel's JEDEC standard, byte-wide mernory family which allows density upgrades, functional interchange, and extended product life. Figure 7 shows this JEDEC 28-pin site approach.

## APPLICATIONS

The 2815 has been designed to meet those applications where write and erase speed are not critical system parameters. Many of these applications exist in systems where $E^{2}$ is used to increase the system's serviceability. The 2815 is effective as a program storage, ROM patch, error logging, diagnostics, or signature storage medium.

Program Storage—The use of the 2815 for program storage enables the periodic update of firmware via a remote telecom link. In this application, the 2815 array is totally erased and new firmware containing advanced features, software corrections, or more efficient routines are loaded into the $E^{2}$ PROMs from the factory. Costly service calls to replace firmware stored in ROMis are thereby eliminated.

ROM Patch-Using the 2815 as branch table and firmware patch storage medium enables the user to store major routines in ROM, but maintain the flexibility to remotely update the code as a whole. This capability is illustrated in Figure 8. In Figure 8a, a system's structured firmware is shown stored in $\mathrm{E}^{2}$ PROM and ROM. The branch table, stored in 2815 devices, contains a series of calls to routines stored in ROM. These are called in sequence.

During the course of a product's life, faults could be discovered in the ROM routines. By remotely changing the branch table and adding a firmware patch, physical ROM swapping is avoided to correct these faults. This type of update (depicted in Figure 8b) is easily implemented with the 2815 . This powerful application of the 2815 can save you the costs of ordering new ROMs, distributing them to a service force, and servicing the customer's equipment.

Data Logging-The 2815 can be used to store randomly occurring error data. This data, which points to hard-to-detect system faults, can be directly loaded into the $E^{2}$ PROM. A record is thereby accumulated from which a serviceperson can spot troublesome timing paths or failing components. Faster time to repair and more productive preventative maintenance result.


Figure 6. Two-Line Control Architecture


Figure 7. JEDEC 28-Pin Site Byte-Wide Philosophy


Figure 8a. ROM Patch Technique Using 2815 (Original Firmware Configuration)


Figure 8b. Routine 2* Replaces Routine 2 (No Hardware Changes)

The 2815 can also store records of service and revision levels of the equipment in the end system itself. This process would distribute the record keeping to the user site where the records are immediately accessible.

System revision levels and repair records can then be accessed remotely, before a service call is made. A serviceperson can then be assured of carrying the correct equipment and spares for that particular installation. The costs incurred for managing this system documentation are also reduced.

Diagnostics-The 2815 is an excellent storage medium for diagnostics routines used by a diagnostic processor. This processor, concurrently with a main processor, would execute continuous machine diagnostics. Implemented with $E^{2}$ memory and a common interface, this diagnostic processor could be made generic for many user systems. Routines would be loaded into the 2815s on the diagnostic processor to test a particular user's system. After that user's system is debugged, the same diagnostic processor could be removed, have new routines loaded into the 2815s, and be inserted for the testing of another user's system.

Several cost-saving benefits result. By using the common diagnostic processor, reduced types of test equipment are required for service calls. Additionally, diagnostic routines would not have to be static. New, more powerful routines could be written during
a production system's life so that faster diagnostics and repair of those systems would be possible.

Signature Storage-A powerful diagnostic tool is the use of system signatures to speed the time of repair. When a system is first shipped a good signature, one obtained by exercizing the properly functioning system's circuitry, is stored in $2815 \mathrm{E}^{2}$ PROM. This application is shown in Figure 9a.

During the course of the equipment's life, a failure may occur which requires identification. A new signature is thus generated which will contain data from the failed circuitry. A comparison of the good and bad signatures is then sent to the factory via telephone, where the failed circuitry is identified (Figure 9b). One repair scenario is to have a serviceperson sent, with the correct equipment and spares, to quickly replace the faulty module. Another possibility is to have the customer do his own service by swapping the faulty board.

The power of the 2815 is especially evident for this application when there are several revision levels or options existing for the end equipment. This is particularly true when the users can configure or expand the system themselves. A common 2815 memory module can be used to store all revisions of good signatures. An example of this kind of situation is depicted in Figure 9c where a user has opted for a new RAM card. The new card is simply inserted and a new signature stored in the same 2815 memory array.


Figure 9. System Is Operational


Figure 9b. Component in Board 2 Fails


Figure 9c. Updated Good System Signature Is Stored

## AVAILABLE LITERATURE

Much of the literature which has been written about operation of the 2816 is equally applicable to the 2815. A brief synopsis of some applicable notes is given below as a reference to system designers and architects. These notes and others will be available in the $E^{2}$ PROM Family Applications Handbook II.
AP100-Reliability Aspects of a Floating Gate
E $^{2}$ PROM

AP-101-The 2816 Electrical Description
AP-102-2816 Microprocessor Interface Considerations

AP-103-Programming E ${ }^{2}$ PROM with a Single 5-Volt Power Supply

AP-107-Hardware and Software Download Techniques with 2816

AP135-8298 Integrated E ${ }^{2}$ Controller
AP136-A Multibus-Compatible 2816 E $^{2}$ PROM Memory Board

AP137-8298 Functional Specification and Firmware Description

AP138-A 2716 to 2816 Programming Socket Adapter

To obtain this literature, contact your local Field Sales office. Your Field Applications Engineer is available to discuss all aspects of the Intel $E^{2}$ product line with you.

## ABSOLUTE MAXIMUM RATINGS*


*NOTICE: 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 A.C. OPERATING CONDITIONS DURING READ AND WRITE

|  | 2815, 2815-3, 2815-4 |
| :---: | :---: |
| Temperature Range | $0^{\circ} \mathrm{C}-70^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ Power Supply $^{[7]}$ | $5 \mathrm{~V} \pm 5 \%$ |

## D.C. CHARACTERISTICS

## READ

| Symbol | Parameter | Min. | Typ. ${ }^{\text {[6] }}$ | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LII | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}$ |
| Lo | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{C} 2}$ | $\mathrm{V}_{\text {PP }}$ Current Active |  | 50 | 110 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| ${ }^{\text {l CC1 }}$ | VPP Current (Standby) |  | 25 | 50 | mA | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| IPP(R) | $\mathrm{V}_{\text {PP }}$ Current (Read) |  |  | 5 | mA | $\overline{\mathrm{CE}}=\mathrm{VIL}, \mathrm{V}_{\text {PP }} 4$ to 6 |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.1 |  | . 8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | .45 | V | $\mathrm{OL}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{l}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $V_{P P}$ | Read Voltage | 4 |  | 6 | V |  |

## WRITE

| Symbol | Parameter | Min. | Typ. ${ }^{[1]}$ | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{PP}}$ | Write/Erase Voltage | 20 | 21 | 22 | V |  |
| $\mathrm{~V}_{\mathrm{OE}}$ | $\overline{\mathrm{OE}}$ Voltage (Chip Erase) | 9 |  | 15 | V | $\overline{\mathrm{CE}}=\mathrm{VIL}$ |
| $\mathrm{IPP}(\mathrm{W})$ | $\mathrm{V}_{\mathrm{PP}}$ Current <br> (Byte Write/Erase) |  | 9 | 15 | mA | $\mathrm{I}_{\mathrm{OE}}=10 \mu \mathrm{~A}$ |
| $\mathrm{IPP}(\mathrm{C})$ | $\mathrm{V}_{\mathrm{PP}}$ Current (Chip Erase) |  | 3 | 5 | mA |  |
| $\mathrm{I}_{\mathrm{PP}(1)}$ | $\mathrm{V}_{\mathrm{PP}}$ Current Inhibit |  |  | 5 | mA | $\mathrm{~V}_{\mathrm{PP}}=22, \overline{\mathrm{CE}}=\mathrm{VIH}$ |

For footnotes see page 13.

CAPACITANCE ${ }^{[1]}\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter | Typ. | Max. | Units | Test <br> Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $C_{I N}$ | Input Capacitance | 5 | 10 | pF | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance |  | 10 | pF | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{VCC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Capacitance |  | 500 | pF | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{I H}$ |
| $\mathrm{C}_{\mathrm{VP}}$ | $\mathrm{V}_{\mathrm{PP}}$ Capacitance |  | 50 | pF | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{I H}$ |

## A.C. TEST CONDITIONS

Output Load: 1 TTL gate and

$$
\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}
$$

Input Pulse Levels: 0.45 to 2.4 V Timing Measurement Reference
Level: Input 1V and 2V
Output .8 V and 2 V

## A.C. CHARACTERISTICS

READ

| Symbol | Parameter | 2815 Limits |  |  | 2815-3 Limits |  |  | 2815-4 Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{1]}$ | Max. | Min. | Typ. ${ }^{[1]}$ | Max. | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $t_{\text {ACC }}$ | Address to Output Delay |  | 200 | 250 |  | 300 | 350 |  | 400 | 450 | ns | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ |
| tCE | $\overline{\mathrm{CE}}$ to Output Delay |  | 200 | 250 |  | 300 | 350 |  | 400 | 450 | ns | $\overline{O E}=V_{\text {IL }}$ |
| toe | Output Enable to Output Delay | 10 |  | 100 | 10 |  | 120 | 10 |  | 150 | ns | $\overline{C E}=V_{\text {IL }}$ |
| ${ }_{\text {t }}$ F | Output Enable High to Output Float | 0 |  | 80 | 0 |  | 100 | 0 |  | 130 | ns | $\overline{C E}=V_{\text {IL }}$ |
| ${ }^{\text {toh }}$ | Output Hold from Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ Whichever Occurred First | 0 |  | . | 0 |  |  | 0 |  |  | ns | $\overline{C E}=\overline{O E}=V_{I L}$ |

WRITE

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $t_{\text {AS }}$ | Add to VPP Set-Up Time | 150 |  |  | ns |  |
| $t \mathrm{CS}$ | $\mathrm{C}_{E}$ to VPP Set-Up Time | 150 |  |  | ns |  |
| $t_{\text {DS }}{ }^{(8)}$ | Data to VPP Set-Up Time | 0 |  |  | ns |  |
| $t_{\text {DH }}{ }^{(8)}$ | Data Hold Time | 50 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| ${ }_{T W P}{ }^{(6)}$ | Write Pulse Width | 50 |  | 70 | ms |  |
| twR | Write Recovery Time | 50 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| tos | Chip Erase Set-Up Time | 0 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}, \mathrm{~V}_{\mathrm{OE}}=9 \mathrm{~V}$ |
| $\mathrm{O}_{\mathrm{O}}$ | Chip Erase Hold Time | 0 |  |  | ns | $V_{P P}=6 \mathrm{~V}, \mathrm{~V}_{\text {OE }}=9 \mathrm{~V}$ |
| tPRC | VPP RC Time Constant | 450 | 600 | 750 | $\mu \mathrm{S}$ |  |
| $\mathrm{tPFT}^{(5)}$ | $V_{P P}$ Fall Time |  |  | 100 | $\mu \mathrm{S}$ | $V_{P P}=6 \mathrm{~V}$ |
| $\mathrm{t}_{\mathrm{BOS}}$ | Byte Erase/Write Set-Up Time | 0 |  |  | ns | $V_{P P}=6 \mathrm{~V}$ |
| $\mathrm{t}_{\mathrm{BOH}}$ | Byte Erase/Write Hold Time | 0 |  |  | ns | $V_{P P}=6 \mathrm{~V}$ |

WAVEFORMS


## BYTE WRITE



For footnotes see page 13.

## WAVEFORMS (Continued)

## CHIP ERASE



## NOTES:

1. This parameter is only sampled and not $100 \%$ tested.
2. OE may be delayed up to 300 ns after falling edge of $\overline{C E}$ without impact on $\mathrm{t}_{\mathrm{ACC}}$ for 2815.
3. $\mathrm{t}_{\mathrm{DF}}$ is specified from $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$ whichever occurs first.
4. The rising edge of $V_{p p}$ must follow an exponential waveform. That waveform's time constant is specified as tpRC. See Intel's AP-102 for details.
5. To allow immediate read verify capability, $\mathrm{V}_{\mathrm{PP}}$ can be driven low in less than 50 ns . See AP-101 for more information.
6. Adherence to TWP specification is important to device reliability.
7. To prevent spurious device erasure or write, $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before 21 -volt application of $\mathrm{V}_{\mathrm{PP}}$. $\mathrm{V}_{\text {PP }}$ cannot be driven to 21 volts without previously applying VCC.
8. The data-in set up and hold times are identical for byte erase and chip erase.

## 2816 <br> 16K (2K x 8) ELECTRICALLY ERASABLE PROM

- HMOS*-E FLOTOX Cell Design
- Reliable Floating Gate Technology
- Very Fast Access Time: -2816, 250 ns Max.
-2816-3, 350 ns Max.
-2816-4, 450 ns Max.
- Single Byte Erase/Write Capability
- 10 ms Byte Erase/Write Time


## - Chip Erase Time of 10 ms

Conforms to JEDEC Byte-Wide Family
Standard

- Microprocessor Compatible Architecture
- Low Power Dissipation: -Active Current, 110 mA Max.
-Standby Current, 50 mA Max.
- Erase/Write Specifications Guaranteed 0-70 ${ }^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR} 2816$ is a 16,384 bit electrically erasable programmable read-only memory ( $E^{2}$ PROM). The 2816 can be easily erased and reprogrammed on a byte basis. A chip erase function is also provided. The device operates from a 5-volt power supply in the read mode; writing and erasing are accomplished by providing a single 21-volt pulse.

The 2816, with its very fast read access speed, is compatible with high performance microprocessors such as the 8086-2. Using the fast access speed allows zero wait operation in large system configurations.

The electrical erase/write capability of the 2816 makes it ideal for a wide variety of applications requiring insystem, non-volatile erase and write. Never before has in-system alterability been possible with this combination of density, performance and flexibility. Any byte can be erased or written in 10 ms without affecting the data in any other byte. Alternatively, the entire memory can be erased in 10 ms allowing the total time to rewrite all 2 K bytes to be cut by $50 \%$. The 2816 provides a significant increase in flexibility allowing new applications (dynamic reconfiguration, continuous calibration) never before possible.
The 2816 E $^{2}$ PROM possesses Intel's 2-line control architecture to eliminate bus contention in a system environment. A power down mode is also featured; in the standby mode power consumption is reduced by over $55 \%$ without increasing access time. The standby mode is achieved by applying a TTL-high signal to the CE input.
Byte erase and write are controlled entirely by TTL signal levels, yet require no control signals beyond $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$. For byte write a selected chip ( $\overline{\mathrm{CE}}=\mathrm{TTL}$ low) senses the $21 \mathrm{~V} \mathrm{~V}_{\mathrm{PP}}$ pulse and automatically goes into write mode. Byte erase mode is identical to byte write except that data-in must be all logic ones (TTL-high). Never before has an in-system alteration of non-volatile information been implemented with such simple control.
*HMOS-E is a patented process of Intel Corporation.


| PIN NAMES |  |
| :--- | :--- |
| $A_{0} \cdot A_{10}$ | ADDRESSES |
| $\overline{C E}$ | CHIP ENABLE |
| $\overline{O E}$ | OUTPUT ENABLE |
| $\mathbf{O}_{0}-\mathbf{O}_{7}$ | DATA OUTPUTS |
| $\mathbf{I}_{0} \cdot 1_{7}$ | DATA INPUTS |
| $V_{P P}$ | PROGRAM VOLTAGE |

Figure 1. 2816 Functional Block Diagram

## DEVICE OPERATION

The 2816 has six modes of operation, listed in Table 1. All operational modes are designed to provide maximum microprocessor compatibility and system consistency. The device pinout is a part of Intel's JEDEC approved byte wide Non-Volatile Memory family, allowing appropriate and costeffective density and functionality upgrades.

All control inputs are TTL compatible with the exception of chip erase. The $\mathrm{V}_{\mathrm{pp}}$ voltage must be pulsed to 21 volts during write and erase, and held to 4 to 6 volts during the other two modes.

Table 1. Mode Selection $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V}$

|  | $\begin{gathered} \overline{C E} \\ \text { (18) } \end{gathered}$ | $\overline{O E}$ <br> (20) | $\begin{aligned} & \mathbf{V}_{\mathrm{PP}} \\ & \text { (21) } \end{aligned}$ | INPUTS/ OUTPUTS |
| :---: | :---: | :---: | :---: | :---: |
| READ | VIL | VIL | +4 to +6 | Dout |
| STANDBY | $\mathrm{V}_{\mathrm{IH}}$ | DON'T CARE | +4 to +6 | HIGH Z |
| BYTE ERASE | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | +21 | $\mathrm{D}_{1 \mathrm{~N}}=\mathrm{V}_{1 H}$ |
| BYTE WRITE | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{HH}}$ | +21 | $\mathrm{DiN}_{\text {IN }}$ |
| CHIP ERASE | VIL | $\begin{aligned} & +9 \text { to } \\ & +15 \mathrm{~V} \end{aligned}$ | +21 | $D_{I N}^{[10]}=V_{I H}$ |
| E/W INHIBIT | $\mathrm{V}_{\mathbf{I H}}$ | DON'T CARE | $\begin{aligned} & +4 \text { to } \\ & +22 \mathrm{~V} \end{aligned}$ | HIGH Z |

## Read Mode

Optimal system efficiency depends to a great extent on a tightly coupled microprocessor/memory interface. The E ${ }^{2}$ PROM device should respond rapidly with data to allow the highest possible CPU performance. The 2816 satisfies this high performance requirement because of access times typically less than 250 ns. Program execution directly out of electrically erasable memory has never before been possible; the 2816 opens this new, powerful applications segment.

The 2816 uses Intel's proven 2-line control architecture for read operation. Figure 3 shows the timing disadvantages of a single-line control architecture. 2-line control, shown in Figure 4, has been developed by Intel to solve this bus contention and the associated system reliability problems. Both $\overline{\mathrm{CE}}$ and $\overline{\mathrm{OE}}$ must be at logic low levels to obtain information from the device. Chip enable ( $\overline{\mathrm{CE}}$ ) is the power control pin and should be used for device selection. The output enable ( $\overline{\mathrm{OE}}$ ) pin serves to gate internal data to the output pins. Assuming that the address inputs are stable, address access time ( $t_{A C C}$ ) is equal to the delay from $\overline{C E}$ to output ( $t_{C E}$ ). Data is available at the outputs after a time delay of $\mathrm{t}_{\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}}$.

Figure 5 shows a typical system interconnection. Here the 2816 contains program information that the 8086 requires for system function.


For footnotes see page 13.
Figure 3. Single-Line Control and Bus Contention


Figure 4. Two-Line Control Architecture


For footnotes see page 13.
Figure 5. iAPX 86/2816 Read Architecture

## Write Mode

The 2816 is erased and reprogrammed electrically rather than optically, as opposed to EPROMs which require UV light. The device offers dramatic flexibility because both byte (single location) and chip erase are possible.

A close examination of the broad application spectrum for the $\mathrm{E}^{2}$ device reveals an inherent need for single location erase capability. Program store applications can be classified in several ways. Figure 6 lists various storage modes and the required erase function. In greater than $80 \%$ of all cases, a byte erase feature is necessary.


Figure 6. Microprocessor Storage Types

To write a particular location, that byte must be erased prior to a data write. Erasing is accomplished by applying logic 1 (TTL-high) inputs to the data input pins, lowering $\overline{C E}$, and applying a 21 -volt programming signal to $V_{\mathrm{Pp}}$. The $\overline{\mathrm{OE}}$ pin must be held at $\mathrm{V}_{1 H}$ during byte erase and write operations. The programming pulse width must be a minimum of 9 ms , and a maximum of 15 . The rising edge of $\mathrm{V}_{\mathrm{PP}}$ must conform to the RC time constant specified above. Once the location has been erased, the same operation is repeated for a data write. The input pins in this case reflect the byte that is to be stored.

A characteristic of all $E^{2} P R O M s$ is that the total number of erase/write cycles is not unlimited. The 2816 has been designed and manufactured to meet applications requiring up to $1 \times 10^{4}$ erase/write cycles per byte. The erase/write cycling characteristic is completely byte independent. Adjacent bytes are not affected during erase/write cycling.

Because the device is designed to be written in system, all data sheet specifications (including write and erase operations) hold over the full operating temperature range $\left(0-70^{\circ} \mathrm{C}\right)$.

## CONTROLLERS

## Controller I Description

The Controller I interface provides the lowest cost, smallest P.C. board space implementation, though it is unable to offer the maximum CPU throughput capability since wait states are inserted into the memory cycle during the 10 ms write time. Figure 7 shows the block diagram for this implementation. A timer device is provided to time 10 ms , which connects directly to the CPU READY line. When activated, the timer engages the $\mathrm{V}_{\mathrm{Pp}}$ switch, locks the CPU address, data, and control bus, and writes the 2816. After completion of the write cycle, the CPU is relinquished to do other tasks. Such a control application is appropriate when the processor can be dedicated to the write, such as in program store.


Figure 7. Controller I

## Controller II Description

To provide a higher CPU throughput capability, the interface shown in Figure 8 was designed. In this case, all latching and timing signals are generated by discrete devices. The CPU simply sends a write operation to the interface as it would to a RAM devire fifter the CPU has engaged the write sequence, it is free to perform other tasks not related to 2816 control. At the completion of the write cycle, the interface interrupts the CPU which then vectors to an interrupt service routine. Controller II offers realtime CPU performance with a high degree of hardware overhead.


Figure 8. Controller II

## Controller III Description

The Controller III implementation was designed to provide the real-time processing capability of Controller II, without the large hardware overhead. See Figure 9. In this design an Intel 8155 I/O port timer device is used to advantage. The ports provide the latching of data and address during the write cycle, while the timer performs accurate pulsing of the $\mathrm{V}_{\text {pp }}$ for the required duration. Much of the hardware has been reduced through the 8155. The interrupt structure of Controller II is used as well. Read access is very fast despite a multiplexer and a buffer delay.


Figure 9. Controller III

## Controller IV Description

Data store applications were in mind for the Controller IV design shown in Figure 10. In this case, read access was not a concern, though write erase For footnotes see page 13.
access and hardware overhead were exceptionally important. This controller takes the 2816 completely off-line for both read and write operations. The write cycle is accomplished in the same way as in Controller III. Reading, however, is accomplished through several I/O operations.


Figure 10. Controller IV

## Chip Erase Mode

Should one wish to erase the entire 2816 array at once, the device offers a chip erase function. When the chip erase function is performed all 2K bytes are returned to a logic 1 (FF) state.

The 2816's chip erase function is engaged when the output enable ( $\overline{(\overline{O E})}$ pin is raised above 9 volts. When $\overline{O E}$ is greater than 9 volts and $\overline{C E}$ and $V_{P P}$ are in the normal write mode, the entire array is erased. This chip erase function takes approximately 10 ms . The data input pins must be held to a TTL high level during this time. Figure 11 is a recommended $\overline{\mathrm{OE}}$ control switch.


Figure 11. $\overline{O E}$ Chip Erase Control

## $\mathbf{V}_{\text {PP }}$ Pulse

The shape of the VPp pulse is important in ensuring long term reliability and operating characteristics. $V_{P P}$ must rise to 21 V through an RC waveform (exponential). The $T_{P R C}$ specification has been designed to accommodate changes of RC due to temperature variations.

Figure 12a shows a recommended $V_{P P}$ switch design, useful where programming will occur over the specified temperature and operating voltage conditions. Figure 12b shows the waveform.

## Voltage Generation

The Intel 2816 is a new generation of non-volatile memory in which writing and erasing can be accomplished on board by providing a 21 volt pulse. In order to generate the VPP pulse, a power supply with output voltage of +24 V is needed. In a system environment where this voltage is not available, a switching regulator can be used to convert +5 V to +24 V . Figure 12 c shows the circuit diagram for such a voltage converter. In systems where 24 volts is not available, this circuit proves to be a cost effective alternative.


Figure 12a. Operational Amplifier $\mathrm{V}_{\mathrm{PP}}$ Switch Design ${ }^{[11]}$


Figure 12b. VPP Waveform


Figure 12c. Step-up Regulator Converts +5 V Into +24 V

## Applications

The $2816 \mathrm{E}^{2}$ PROM is a new and powerful addition to the non-volatile family. It offers a high degree of RAM-like flexibility while retaining the non-volatile characteristics of ROM.

Because of these device parameters, the device is ideal for new and future designs as well as a replacement for existing ROM devices. Some of these potential uses are listed below:

1. Calibration constants storage (continuous calibration).
2. Software alterable control stores (dynamic reconfiguration).
3. Remote communications programming.
4. PC and NC Industrial Applications.
5. CRT terminal configuration and custom graphic and font sets.
6. Military replacements for core memory and fuse-link PROMs.
7. Point of sale terminals.
8. Remote alterable look-up tables.
9. Printer and communications controllers.
10. Remote data gathering.

Because of these device attributes, applications never before possible can now be realized in high performance, consistent microprocessing systems.

Figures $13,14,15$, and 16 are block diagrams of some typical applications. These applications are explained as follows:

## DYNAMIC RECONFIGURATION

The ability of a computer system to alter its operating software while running is now possible with the 2816. The system can monitor external factors, as well as change loop constants, subroutines and other software features in real-time. Figure 13 illustrates this optimal performance. In memory systems, the 2816 can be used to map around hard memory


Figure 13. Dynamic Reconfiguration
failures in real-time, allowing self-healing memory systems. Such a self-correcting mechanism extends the operating time and reduces service costs to the end user.

## CONTINUOUS SELF-CALIBRATION

A high cost of machine service and downtime is due to instrument calibration and readjustments. Use of the 2816 and microprocessor based instruments to contain calibration constants allows features never before possible. See Figure 14. The instrument can now continuously calibrate itself, without expensive downtime in service interaction. The 2816 allows this flexibility and reduction of service costs.


Figure 14. Continuous Self-Calibration

## CRT TERMINAL

Custom fonts, graphics characters, and individual configurations can all benefit from the features of the 2816. A CRT terminal, shown in Figure 15, can now be enhanced by using the $E^{2}$ as a replacement for jumpers and dip switches. It can also be used as a programmable character generator, and in graphics configuration.

## POINT OF SALE TERMINAL

Using the 2816 to contain non-volatile price and product descriptions, as shown in Figure 16, is an ideal application in point of sale terminals. With the ability of the 2816 to be altered in-system comes the


Figure 15. CRT Terminal
capability to remotely (over telephone lines) configure the look up table from a central data base computer. The non-volatility of the 2816 is used to advantage as the data store remains intact after power is removed from the system.


Figure 16. POS Terminal

## Pin Compatibility

The 2816 pinout has been designed for compatibility with present and future memory products. The $E^{2}$ PROM is a member of Intel's JEDEC standard Byte-Wide memory family which allows density upgrades, functional interchange, and extended product life. Figure 17 shows this JEDEC 28 pin site pinout approach.


Figure 17. JEDEC 28 Pin Site Byte-Wide Philosophy

## Available Literature

To give the system designer an opportunity to more thoroughly understand the device attributes and uses, a library of $E^{2}$ information is available in the $E^{2}$ Applications Handbook Volume II. It includes these application notes:

AP100-Reliability Aspects of a Floating Gate $\mathrm{E}^{2} \mathrm{PROM}$

AP-101-The 2816 Electrical Description
AP-102-2816 Microprocessor Interface Considerations

AP-103-Programming $E^{2}$ PROM with a Single 5 -Volt Power Supply

AP-107-Hardware and Software Download Techniques with 2816

AP135-8298 Integrated $\mathrm{E}^{2}$ Controller
AP136-A Multibus-Compatible 2816 E $^{2}$ PROM Memory Board

For footnotes see page 13.

AP137-8298 Functional Specification and Firmware Description

AP138-A 2716 to 2816 Programming Socket Adapter

To obtain this literature contact your local Field Sales office. In addition, your Field Applications Engineer can discuss with you the controller interfaces for different MPU system configurations.

All of the above literature will be available at the end of Q2 1981. The E ${ }^{2}$ PROM Applications Handbook is available now.

## Standby Mode

The 2816 has a standby mode which reduces active power dissipation by $55 \%$ from 110 mA to 50 mA . The 2816 is placed in the standby mode by applying a TTL high signal to the CE input. When in the standby mode, the outputs are in a high impedance state, independent of the OE input.

## Output OR-TIEING

Because 2816s are usually used in larger memory arrays, Intel has provided a 2 -line control function that accommodates this use of multiple memory connections. The 2 -line control function allows low power dissipation (by deselecting unused devices), and the removal of bus contention from the system environment.

To most effectively use these two control lines, it is recommended that $\overline{C E}$ (pin 18) be decoded from addresses as the primary device selection function. $\overline{\mathrm{OE}}$ (pin 20) should be made a common connection to all devices in system, and connected to the $\overline{\mathrm{RD}}$ 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.

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias ............. $-10^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ |
| All Input or Output Voltages with |  |
| Respect to Ground | +6 V to -0.3 V |
| VPPSupply Voltage with Respect to |  |
| Ground During Write/E | , |
| Maximum Duration of VPP Supply at 22V |  |
| During E/W Inhibit |  |
| Maximum Duration of VPP Supply at 22V |  |
| During Write/Erase .......................... . 70 ms ${ }^{\text {[8] }}$ |  |

*NOTICE: 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 A.C. OPERATING CONDITIONS DURING READ AND WRITE

|  | $\mathbf{2 8 1 6}$ | $\mathbf{2 8 1 6 - 3}$ | $\mathbf{2 8 1 6 - 4}$ |
| :---: | :---: | :---: | :---: |
| 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 ${ }^{[9]}$ | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ |

## D.C. CHARACTERISTICS

READ

| Symbol | Parameter |  | Limits |  |  | Units |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |

WRITE

| Symbol | Parameter |  | Limits |  |  | Units |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | Test Conditions

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

| Symbol | Parameter | Typ. | Max. | Units | Test <br> Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | 10 | pF | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{OUT}}$ | Output Capacitance |  | 10 | pF | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Capacitance |  | 500 | pF | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |
| $\mathrm{C}_{\mathrm{VPP}}$ | $\mathrm{V}_{\text {PP }}$ Capacitance |  | 50 | pF | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IH}}$ |

## A.C. TEST CONDITIONS

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$ Input Pulse Levels: 0.45 to 2.4 V Timing Measurement Reference Level: Input 1V and 2V Output . 8 V and 2 V

## A.C. CHARACTERISTICS

## READ

| Symbol | Parameter | 2816 Limits |  |  | 2816-3 Limits |  |  | 2816-4 Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. | Min. | Typ. ${ }^{[1]}$ | Max. | Min. | Typ. ${ }^{\text {[1] }}$ | Max. |  |  |
| taCC | Address to Output Delay |  | 200 | 250 |  | 300 | 350 |  | 400 | 450 | ns | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ |
| t $\overline{C E}$ | $\overline{C E}$ to Output Delay |  | 200 | 250 |  | 300 | 350 |  | 400 | 450 | ns | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| t $\overline{O E}$ | Output Enable to Output Delay | 10 |  | 100 | 10 |  | 120 | 10 |  | 150 | ns | $\overline{C E}=V_{\text {IL }}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | Output Enable High to Output Float | 0 |  | 80 | 0 |  | 100 | 0 |  | 130 | ns | $\overline{C E}=V_{\text {IL }}$ |
| tor | Output Hold from $\qquad$ <br> Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ <br> Whichever Occurred <br> First | 0 |  |  | 0 |  |  | 0 |  |  | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |

WRITE

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $t_{\text {AS }}$ | Add to $\mathrm{V}_{\text {PP }}$ Set-Up Time | 150 |  |  | ns |  |
| ${ }^{\text {t }}$ cs | CE to VPP Set-Up Time | 150 |  |  | ns |  |
| $t_{\text {DS }}{ }^{[10]}$ | Data to VPP Set-Up Time | 0 |  |  | ns |  |
| ${ }^{\text {t }}{ }^{\text {[10] }}{ }^{\text {d }}$ | Data Hold Time | 50 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| $\mathrm{twP}^{[8]}$ | Write Pulse Width | 9 | 10 | 70 | ms |  |
| twR | Write Recovery Time | 50 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| tos | Chip Erase Set-Up Time | 0 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}, \mathrm{~V}_{\overline{\mathrm{OE}}}=9 \mathrm{~V}$ |
| ${ }^{\text {toh }}$ | Chip Erase Hold Time | 0 |  |  | ns | $V_{P P}=6 \mathrm{~V}, \mathrm{~V}_{\overline{\mathrm{OE}}}=9 \mathrm{~V}$ |
| tPRC | VPP RC Time Constant | 450 | 600 | 750 | $\mu \mathrm{s}$ |  |
| $\mathrm{tPFT}{ }^{[7]}$ | $V_{\text {PP }}$ Fall Time |  |  | 100 | $\mu \mathrm{S}$ | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| $\mathrm{t}_{\mathrm{BOS}}$ | Byte Erase/Write Set-Up Time | 0 |  |  | ns | $V_{P P}=6 \mathrm{~V}$ |
| ${ }^{\text {t }}$ BOH | Byte Erase/Write Hold Time | 0 |  |  | ns | $V_{P P}=6 \mathrm{~V}$ |

For footnotes see page 13.

## WAVEFORMS

READ


## BYTE ERASE OR WRITE ${ }^{[5]}$



## WAVEFORMS (Continued)

## CHIP ERASE ${ }^{[6]}$



## NOTES:

1. This parameter is only sampled and not $100 \%$ tested.
2. $\overline{\mathrm{OE}}$ may be delayed up to 230 ns after falling edge of $\overline{\mathrm{CE}}$ without impact on $t_{A C C}$ for 2816.
3. $t_{D F}$ is specified from $\overline{O E}$ or $\overline{C E}$ whichever occurs first.
4. The rising edge of $V_{P P}$ must follow an exponential waveform. That waveform's time constant is specified as tpRC. See Intel's AP-102 for details.
5. Prior to a data write, an erase operation must be performed. For erase, data in $=V_{1 H}$.
6. In the chip erase mode $D_{I N}=V_{I H}$.
7. To allow immediate read verify capability, $\mathrm{V}_{\mathrm{PP}}$ can be driven low in less than 50 ns. See AP-101 for more information.
8. Adherence to TWP specification is important to device reliability.
9. To prevent spurious device erasure or write, $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before 21 volt application of $V_{p p}$. VPP cannot be driven to 21 volts without previously applying VCC.
10. The data in set up and hold times for chip erase are identical to those specified for byte erase.
11. This switch includes automatic voltage shutdown on power fail.

## 2817

## 16K (2K X 8) ELECTRICALLY ERASABLE PROM

- Self Timed Byte Write with Automatic Erase
- Direct Microprocessor Interface Capability
- Static 21 Volt $V_{P P}$
- Reduces Support Component Requirement by 70\% to 90\% Over 2816 and 2815
- Byte Write Time: 75 mS $\dagger$
- Very Fast Read Access Time: 2817250 nS
2817-3 350 nS 2817-4 450 nS
- Reliable Intel FLOTOX E $\mathbf{E}^{2}$ PROM Technology

The Intel 2817 is a 16,384 bit Electrically Erasable Programmable Read Only Memory. Like the Intel 2816 and 2815, it has completely Non-Volatile Data Storage. However, in addition, it offers a high degree of integrated functionality which enables in-circuit byte writing to be performed with minimal hardware and software overhead. The Intel 2817 is a product of Intel's advanced $E^{2}$ PROM technology and uses the powerful HMOS*-E process for reliable, non-volatile, data storage.
The Intel 2817 eliminates all the interfacing hardware logic and firmware required to perform data writes. The device has complete self-timing which leaves the processor free to perform other tasks until the 2817 signals 'Ready.' With a transparent erase before write, the user benefits by saving an erase command contributing to efficient usage of system processing time.
The Intel 2817's very fast read access time makes it compatible with high performance microprocessor applications. It uses Intel's proven 2 -line control architecture which eliminates bus contention in a system environment. Combining these features with the 2817's 'Ready' signal makes the device an extremely powerful, yet simple to use, $\mathrm{E}^{2}$ memory-available to the designer today.
The density, and level of integrated control, makes the Intel 2817 suitable for users requiring low hardware overhead, high system performance, minimal board space and design ease. Designing with, and using the 2817, is extremely cost effective as $70 \%$ of the required voltage and interfacing hardware required for other $E^{2}$ PROM devices has been eliminated. See Figures 1, 2, and 3 for the Intel 2817's block diagram,. pinout, and simple interface requirements.
*HMOS-E is a patented process of ${ }^{\circ}$ Intel Corporation.
$\dagger$ Faster write times will be available.


Figure 1. 2817 Functional Block Diagram


Figure 2. 2817 Pin Configuration

[^6]
## 3628A <br> 8K (1K x 8) BIPOLAR PROM

| $3628 A-1$ | 50 ns Max. |
| :--- | :--- |
| $3628 A-3$ | 70 ns Max. |
| $3628 A-4$ | 90 ns Max. |

- Fast Access Time: 50 ns for 3628A-1
- Low Power Dissipation: 0.08 mW/Bit Typically

Four Chip Select Inputs for Easy Memory Expansion

## - $\pm 10 \%$ Power Supply Tolerance

- Three-State Outputs
- Hermetic 24-Pin DIP

Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability

The Intel 3628A is a fully decoded 8192-bit PROM organized as 1024 words by 8 bits. The worst case access time of 35 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 four 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.
The 3628A is a super-fast, high-density PROM. This 8192-bit PROM uses the most advanced technology available. As a result the 3628A combines higher performance and lower power in a smaller die than the 3628. The 3628A is packaged in a hermetic 24-pin dual in-line package with the exact pin configuration as the 3628.


Figure 1. Block Diagram

(1) To select the PROM $\overline{\mathrm{CS}}_{1}=\overline{\mathrm{CS}}_{2}=\mathrm{V}_{1 \mathrm{~L}}$ and $\mathrm{CS}_{3}=\mathrm{CS}_{4}=\mathrm{V}_{\mathrm{iH}}$

Figure 2. Pin Configuration


Figure 3. Logic Symbol

## PROGRAMMING

The programming specifications are described in the PROM programming section of the Data Catalog.

| ABSOLUTE MAXIMUM RATINGS* |  |
| :---: | :---: |
| Temperature Under Bias $\ldots . . . . . . . . .-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.5 V to 5.5 V |
| Output Currents |  |

*NOTICE: 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 (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}$ |
| IFS | 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}$ |
| IRA | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.5 \mathrm{~V}$ |
| IRS | 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}$ |
| $\mid \mathrm{l} \mathrm{O}^{\text {\| }}$ | Output Leakage for High Impedance State |  |  | 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}=\mathrm{CS}_{2}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{\text {[2] }}$ | Output Short Circuit Current | -20 | -40 | -100 | 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.5 \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.5 \mathrm{~V}, \mathrm{Is}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | 3.2 |  | V | $\mathrm{l}_{\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{IOL}=10 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 120 | 170 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V |  |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.

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

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |  |  |
| $\mathrm{C}_{\text {INA }}$ | Address Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {INS }}$ | Chip-Select Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 6 | 12 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

## NOTES:

1. This parameter is only periodically sampled and is not $100 \%$ tested.
A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Max. Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3628A-1 | 3628A-3 | 3628A-4 |  |  |
| $t_{\text {A }}$ | Address to Output Delay | 50 | 70 | 90 | ns ns ns | $\begin{aligned} & C S_{1}=C S_{2}=V_{I L} \text { and } \\ & C S_{3}=C S_{4}=V_{1 H} \text { to } \\ & \text { select the PROM. } \end{aligned}$ |
| $\mathrm{t}_{\mathrm{EN}}$ | Output Enable Time | 30 | 30 | 30 |  |  |
| ${ }^{\text {tois }}$ | Output Disable Time | 30 | 30 | 30 |  |  |

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



## CHIP SELECT TO OUTPUT DELAY



## 3632

32K (4K x 8) BIPOLAR PROM

| $3632-1$ | 40 ns Max. |
| :--- | ---: |
| 3632 | 50 ns Max. |

## 30 ns Typical Access

Low Power Dissipation: 0.02 mW/Bit Typically

- Two Chip Select Inputs for Easy
Memory Expansion


## - Three-State Outputs

- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability


## ■ $\pm 10 \%$ Power Supply Tolerance

The Intel ${ }^{\circledR} 3632$ is a high performance 32,768 -bit PROM organized as 4096 words by 8 bits. The worst case access time of 40 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.
The 3632 allows present $4 \mathrm{~K}, 8 \mathrm{~K}$ and 16K PROM users to significantly increase density without sacrificing performance. The 3632 is packaged in a hermetic 24 pin dual in-line package. This 32,768-bit PROM uses the most advanced technology available. As a result, the 3632 combines high performance, high density and lower power per bit than previous Bipolar PROM designs.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## 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.5 V to 5.5 V
Output Currents ..................................... 100 mA
*NOTICE: 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 (All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| IfA | 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.5 \mathrm{~V}$ |
| IRS | 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}$ |
| $\|10\|$ | Output Leakage for High Impedance State |  |  | 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}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{[2]}$ | Output Short Circuit Current | -15 | -40 | -100 | 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}_{\mathrm{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.2 |  | V | $\mathrm{IOH}=-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{l}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| ${ }^{\text {ICC }}$ | 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}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 10 \%$ |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.

CAPACITANCE ${ }^{(3)}\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |  |  |
| $\mathrm{C}_{\text {INA }}$ | Address Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {INS }}$ | Chip-Select Input Capacitance | 6 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 7 | 12 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{OUT}}=2.5 \mathrm{~V}$ |

NOTE:
3. This parameter is only periodically sampled and is not $100 \%$ tested.
A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Max. Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $3632-1$ | 3632 |  |  |
| $\mathrm{t}_{\mathrm{A}}$ | Address to Output Delay | 40 | 50 | ns | $\mathrm{CS}_{1}=\mathrm{V}_{\mathrm{IL}}$ and |
| $\mathrm{CS}_{2}=\mathrm{V}_{\mathrm{IH}}$ to |  |  |  |  |  |
| select the PROM. |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{EN}}$ | Output Enable Time | 30 | 35 | ns |  |
| $\mathrm{t}_{\mathrm{DIS}}$ | Output Disable Time | 30 | 35 | ns |  |

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

10 mA TEST LOAD


## WAVEFORMS



## CHIP SELECT TO OUTPUT DELAY



## 3636B <br> 16K (2K x 8) BIPOLAR PROM

| 3636B-1 | 35 ns Max. |
| :--- | :--- |
| $3636 \mathrm{~B}-2$ | 45 ns Max. |
| 3636 B | 55 ns Max. |

Fast Access Time: 25 ns Typically<br>Low Power Dissipation: $0.05 \mathrm{~mW} /$ Bit Typically<br>- Three Chip Select Inputs for Easy Memory Expansion<br>n $\pm 10 \%$ Power Supply Tolerance

- Three-State Outputs
- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability

The intel 3636B is a very fast, fully decoded 16,384 bit PROM organized as 2048 words by 8 bits. The worst case access time is 35 ns over a temperature range of $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ with a $10 \% \mathrm{~V}_{\mathrm{CC}}$ power supply tolerance. 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.

The 3636B is designed for use in performance based systems. This 16,384 bit PROM uses the most advanced technology available. As a result, the 3636B combines higher performance and equivalent power in a smaller die than previous 16 K Bipolar PROM designs. The 3636B is packaged in a hermetic 24 pin dual in-line package with the same pin configuration as the 3636 .


## PROGRAMMING

The programming specifications are described in the PROM programming section of the Data Catalog.

## ABSOLUTE MAXIMUM RATINGS*

|  |  |
| :---: | :---: |
|  |  |
|  |  |
|  |  |
|  |  |

*NOTICE: 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
(All Limits Apply for $\mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| $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}$ |
| IRA | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.5 \mathrm{~V}$ |
| IRS | 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}$ |
| $\|10\|$ | Output Leakage for High Impedance State |  |  | 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}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{[2]}$ | Output Short Circuit Current | -20 | -40 | -100 | 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{IS}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | 3.2 |  | V | $\mathrm{l}_{\mathrm{OH}}=-2.4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}$ |
| V OL | Output Low Voltage |  | 0.3 | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{l}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| Icc | 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}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V | $V_{C C}=5.0 \mathrm{~V} \pm 10 \%$ |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.

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

| Symbol | Parameter | Limits |  | Unit | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |  |  |  |
| CINA | Address Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{IN}}=2.5 \mathrm{~V}$ |
| CINS | Chip-Select Input Capacitance | 6 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{IN}}=2.5 \mathrm{~V}$ |
| COUT | Output Capacitance | 7 | 12 | 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.
A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Max. Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3636B-1 | 3636B-2 |  |  |
| $t_{A}$ | Address to Output Delay | 35 | 45 | ns | $\begin{aligned} & C S_{1}=V_{I L} \text { and } \\ & C S_{2}=C S_{3}=V_{1 H} \text { to } \\ & \text { select the PROM. } \end{aligned}$ |
| $\mathrm{t}_{\text {EN }}$ | Output Enable Time | 25 | 25 | ns |  |
| $t_{\text {DIS }}$ | Output Disable Time | 25 | 25 | ns |  |

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

10 mA TEST LOAD


## WAVEFORMS



CHIP SELECT TO OUTPUT DELAY


## 82S181/82HS181 8K (1K x 8) BIPOLAR PROM

| $82 S 181$ | 70 ns Max. |
| :--- | :--- |
| $82 H S 181$ | 50 ns Max. |

- Fast Access Time: $\mathbf{5 0} \mathbf{n s}$ for 82HS181

■ Low Power Dissipation: 0.08 mW/Bit Typically

## - Four Chip Select Inputs for Easy Memory Expansion

- Three-State Outputs
- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability

The Intel ${ }^{\circledR} 82 \mathrm{~S} 181$ and 82 HS 181 are fully decoded 8,192 -bit PROMs organized as 1024 words by 8 bits. The worst case access time of 50 ns is specified over the $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ temperature range. There are four 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.

This 8,192-bit PROM uses the most advanced technology available. As a result, the 82 S 181 and 82 HS 181 combine higher performance and lower power in a smaller die. The 82S181 and 82 HS 181 are packaged in hermetic 24 -pin dual in-line packages with industry-standard pin configurations.


Figure 1. Block Diagram

## PROGRAMMING

The programming specifications are described in the PROM programming section of the Intel Data Catalog. The algorithm is precisely the same as that used to program all other Intel bipolar PROMs.

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias ............ -65 ${ }^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| Storage Temperature |  |
| Output or Supply Voltages ............ - 0.5 V to 7 Volts |  |
| All Input Voltages |  |
| Output Currents | 100 mA |


#### Abstract

*NOTICE: 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 (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 |  |
| $\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}$ |
| IRA | Address Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=5.5 \mathrm{~V}$ |
| IRS | Chip Select Input Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{S}}=5.5 \mathrm{~V}$ |
| $\|10\|$ | Output Leakage for High Impedance State |  |  | 40 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V} \text { or } 0.5 \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 | -40 | -100 | 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}_{\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{OH}}$ | Output High Voltage | 2.4 | 3.2 |  | V | $\mathrm{l}_{\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.75 \mathrm{~V}, \mathrm{l} \mathrm{OL}=10 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 120 | 170 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V |  |
| $\mathrm{V}_{1} \mathrm{H}$ | Input "High" Voltage | 2.0 |  |  | V |  |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.

CAPACITANCE ${ }^{(1)}\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter |  | Limits |  | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |
|  |  | Typ. | Max. |  |  |
| $\mathrm{C}_{\text {INA }}$ | Address Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {INS }}$ | Chip-Select Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {IN }}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 6 | 12 | pF | $\mathrm{V}_{\text {CC }}=5 \mathrm{~V} \quad \mathrm{~V}_{\text {OUT }}=2.5 \mathrm{~V}$ |

## NOTES:

1. This parameter is only periodically sampled and is not $100 \%$ tested.
A.C. CHARACTERISTICS $\left(V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Max. Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 825181 | 82HS181 |  |  |
| $t_{\text {A }}$ | Address to Output Delay | 70 | 50 | $\begin{aligned} & \text { ns } \\ & \text { ns } \\ & \text { ns } \end{aligned}$ | $\begin{aligned} & \mathrm{CS}_{1}=C S_{2}=V_{I L} \text { and } \\ & c s_{3}=C S_{4}=V_{1 H} \text { to } \end{aligned}$ <br> select the PROM. |
| $t_{\text {en }}$ | Output Enable Time | 40 | 30 |  |  |
| tois | Output Disable Time | 40 | 30 |  |  |

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

10mA TEST LOAD


## WAVEFORMS



CHIP SELECT TO OUTPUT DELAY


## 82S191/82HS191 <br> 16K (2K x 8) BIPOLAR PROM

| 82 S 191 | 70 ns Max. |
| :--- | :--- |
| 82 HS 191 | 50 ns Max. |

- Fast Access Time: 25 ns Typically
- Low Power Dissipation: $0.05 \mathrm{~mW} /$ Bit Typically


## - Three Chip Select Inputs for Easy Memory Expansion

- Three-State Outputs
- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability

The Intel 82S191 and 82HS191 are very fast, fully decoded 16,384-bit PROMs organized as 2048 words by 8 bits. The worst case access time is 50 ns over a temperature range of $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$. 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.
The Intel 82S191 and 82HS191 are designed for use in performance-based systems. This 16,384-bit PROM uses the most advanced technology available. As a result, the Intel 82S191 and 82HS191 combine higher performance and equivalent power in a smaller die than previous 16K Bipolar PROM designs. The Intel 825191 and 82 HS 191 are packaged in hermetic 24 -pin dual in-line packages with industry-standard pin configurations.


## PROGRAMMING

The programming specifications are described in the PROM programming section of the Intel Data Catalog. The algorithm is precisely the same as that used to program all other Intel bipolar PROMs.

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | C to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $5^{\circ} \mathrm{C}$ to $+160^{\circ} \mathrm{C}$ |
| Output or Supply Voltages | V to 7 Volts |
| All Input Voltages | 1.5V to 5.5 V |
| Output Currents | 100 m |

*NOTICE: 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 (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. |  |  |
| $\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.5 \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.5 \mathrm{~V}$ |
| $\|10\|$ | Output Leakage for High Impedance State |  |  | 40 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V} \text { or } 0.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{CS}_{1}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{[2]}$ | Output Short Circuit Current | -20 | -40 | -100 | 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}_{\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{OH}}$ | Output High Voltage | 2.4 | 3.2 |  | V | $\mathrm{O}_{\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.75 \mathrm{~V}, \mathrm{l}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 130 | 175 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \pm 5 \%$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \pm 5 \%$ |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.

CAPACITANCE ${ }^{(1)}\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |  |  |  |
| CinA | Address Input Capacitance | 4 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{IN}}=2.5 \mathrm{~V}$ |
| CIns | Chip-Select Input Capacitance | 6 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{V}_{\mathrm{IN}}=2.5 \mathrm{~V}$ |
| COUT | Output Capacitance | 7 | 12 | 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.
A.C. CHARACTERISTICS $\left(V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Max. Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 825191 | 82HS191 |  |  |
| $t_{\text {A }}$ | Address to Output Delay | 70 | 50 | ns | $\begin{aligned} & \mathrm{CS}_{1}=\mathrm{V}_{1 L} \text { and } \\ & \mathrm{CS}_{2}=\mathrm{CS}_{3}=\mathrm{V}_{1 H} \text { to } \\ & \text { select the PROM. } \end{aligned}$ |
| $\mathrm{t}_{\text {EN }}$ | Output Enable Time | 30 | 25 | ns |  |
| ${ }_{\text {tis }}$ | Output Disable Time | 30 | 25 | ns |  |

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

10 mA TEST LOAD


## WAVEFORMS



CHIP SELECT TO OUTPUT DELAY


# 82S321/82HS321 32K (4K x 8) BIPOLAR PROM 

| $82 S 321$ | 50 ns Max. |
| ---: | :---: |
| $82 H S 321$ | 40 ns Max. |

## - 30 ns Typical Access

- Low Power Dissipation: 0.02 mW/Bit Typically


## - Two Chip Select Inputs for Easy Memory Expansion

## - Three-State Outputs

- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability

The Intel 82S321/82HS321 are high-performance 32,768-bit PROMs organized as 4096 words by 8 bits. The worst case access time of 40 ns is specified over the $0^{\circ} \mathrm{C}$ to $75^{\circ} \mathrm{C}$ temperature range. There are two 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.

The 82S321/82HS321 allows present 4K, 8K and 16K PROM users to increase density significantly without sacrificing performance. Intel's 82S321/82HS321 are packaged in hermetic 24-pin dual in-line packages. These 32,768-bit PROMs use the most advanced technology available. As a result, the 82S321/82HS321 combine more high performance, high density and lower power per bit than previous Bipolar PROM designs.


Figure 1. Block Diagram


Figure 2. Pin Configuration


Figure 3. Logic Symbol

## PROGRAMMING

The programming specifications are described in the PROM programming section of the Intel Data Catalog. This algorithm is precisely the same as that used to program all other Intel Bipolar PROMs.

## 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 Voltage | 0.5 V to 7 Volts |
| All Input Voltages | 1.5V to 5.5 V |
| Output Currents | 100 |

*NOTICE: 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 (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 {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.5 \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.5 \mathrm{~V}$ |
| $\|10\|$ | Output Leakage for High Impedance State |  |  | 40 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=5.5 \mathrm{~V} \text { or } 0.5 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{CS}_{1}=2.4 \mathrm{~V} \end{aligned}$ |
| $\mathrm{ISC}^{\text {[2] }}$ | Output Short Circuit Current | -15 | -40 | -100 | 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.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{OH}}$ | Output High Voltage | 2.4 | 3.2 |  | V | $\mathrm{l}_{\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.75, \mathrm{l}_{\mathrm{OL}}=10 \mathrm{~mA}$ |
| Icc | Power Supply Current |  | 130 | 175 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input "Low' Voltage |  |  | 0.85 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$ |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. Unmeasured outputs are open during this test.

CAPACITANCE ${ }^{(3)}\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter | 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}$ |
| $\mathrm{C}_{\text {INS }}$ | Chip-Select Input Capacitance | 6 | 10 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{~V}_{\mathrm{IN}}=2.5 \mathrm{~V}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 7 | 12 | pF | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{~V}_{\mathrm{OUT}}=2.5 \mathrm{~V}$ |

## NOTE:

3. This parameter is only periodically sampled and is not $100 \%$ tested.
A.C. CHARACTERISTICS $\quad\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.+75^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Max. Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathbf{8 2 S 3 2 1}$ | $\mathbf{8 2 H S 3 2 1}$ |  |  |
| $\mathrm{t}_{\mathrm{A}}$ | Address to Output Delay | 50 | 40 | ns | $\mathrm{CS}_{1}=\mathrm{V}_{1 \mathrm{~L}}$ and |
| $\mathrm{CS}_{2}=\mathrm{V}_{\text {IH }}$ to |  |  |  |  |  |
| select the PROM. |  |  |  |  |  |
| $\mathrm{t}_{\text {EN }}$ | Output Enable Time | 35 | 30 | ns |  |
| $\mathrm{t}_{\text {DIS }}$ | Output Disable Time | 35 | 30 | ns |  |

## SWITCHING CHARACTERISTICS

## Conditions of Test:

Input pulse amplitudes: 2.5V 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



## CHIP SELECT TO OUTPUT DELAY



## Bipolar PROM Programming

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 inputs must be floating until it is their turn for programming. The $\mathrm{V}_{\mathrm{CC}}$ power supply and the chip select (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$ 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 for a group of eight outputs.
The $V_{C C}$ program pulses are multiplexed during a cycle time to the outputs of the word to be programmed. The cycle time ( $t_{C Y C}$ ) between the $V_{C C}$ program pulses to the same output will increase as the $V_{C C}$ program pulse width increases from $0.2 \mu \mathrm{~s}$ to $8 \mu \mathrm{~s}$. The time ( $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 that are being programmed. 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. $\mathrm{I}_{\mathrm{CS}}$ is forced into $\mathrm{CS}_{4}$ (pin 18) of $3604 \mathrm{~A} / 3624 \mathrm{~A}, \mathrm{CS}_{2}$ (pin 10) of $3625 \mathrm{~A}, \mathrm{CS}_{3}$ (pin 19) of 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 $\pm 15 \mathrm{~V}$ power supply. The voltage on the chip select input will be approximately 10 V with the 1.2 K resistor.
4. The $I_{C C}$ source used for programming should be able to supply 600 mA during $\mathrm{V}_{I H}$.

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}$ | Vcc Program Pulse Amplitude | 12 | 12.5 | 13 | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | $\overline{\text { 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}_{1 \mathrm{H} 2}$ | $\overline{\text { CS }}$ During Verify | 0 | 0.2 | 0.4 | V |  |
| ${ }^{\text {tPW1 }}$ | $V_{\text {cc }}$ Pulse Width at Beginning of Pulse Train | 160 | 200 | 240 | ns | Measured at 12 V |
| ${ }^{\text {tpw2 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Pulse Width at End of Pulse Train | 7.2 | 8 | 8.8 | $\mu \mathrm{s}$ | Measured at 12 V |
| $\mathrm{T}_{\text {css }}$ | Chip Select Setup Time | 0 |  |  | ns | Measured from 1.5 V on rising edge of $\overline{\mathrm{CS}}$ 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}_{\text {cc }}$ |
| $\mathrm{T}_{\text {cYC }}$ | Time Between Pulses to Same Output | 9 | 10 |  | $\mu \mathrm{s}$ | Measured at 5V on $\mathrm{V}_{\text {cc }}$ |
| Top | DC Program Time After Verification Has Been Obtained | 2.2 | 2.5 | 2.8 | ms | Measured at 12V |
| $\mathrm{T}_{\mathrm{D}}$ | Time Between $V_{\text {CC }}$ Pulses to Successive Outputs | 1.5 | 1.8 |  | $\mu \mathrm{s}$ | Measured at 5 V on $\mathrm{V}_{\text {cc }}$ |
| TRAMP | Time During Which $V_{\text {CC }}$ <br> Pulse Width is Increased 4 outputs <br> Linearly from tpW1 to tpW2 | 160 | 180 | 200 | ms |  |
| $I_{\text {cs }}$ | 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 |

NOTE: 1. The minimum $\mathrm{V}_{\text {IL1 }}$ for the 3604AL (low power) is 4.5 V


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{C S} \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 \mathrm{~ms} V_{C C}$ AND C̄̄̄ PULSE SHOULD BE APPLIED WHILE SIMULTANEOUSLY ENABLING THE CURRENT SOURCES TO ALL OUTPUTS WHICH ARE TO BE PROGRAMMED.


Figure 2. Programming Cycle Details.
(a) RAMP TIME IN PROGRAMMING 8 OUTPUTS

(b) RAMP TIME IN PROGRAMMING 4 OUTPUTS


Figure 3. VCC Pulse Width vs. Programming Time.

BIPOLAR PROM FAMILY

| No.   No. <br> of <br> of Organization <br> Pins     | Output | Maximum <br> Access <br> (ns) | Maximum <br> Power <br> Dissipation <br> (mW) | Operating <br> Temperature <br> Range <br> ( ${ }^{\circ}$ C) | Power <br> Supply <br> (V) |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $3628 \mathrm{~A}-1$ | 8192 | $1024 \times 8$ | 24 | T.S. | 50 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ |
| $3628 \mathrm{~A}-3$ | 8192 | $1024 \times 8$ | 24 | T.S. | 70 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ |
| $3628 \mathrm{~A}-4$ | 8192 | $1024 \times 8$ | 24 | T.S. | 90 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ |
| 3636 | 16384 | 204888 | 24 | T.S. | 80 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ |
| $3636-1$ | 16384 | $2048 \times 8$ | 24 | T.S. | 65 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ |
| $3636 \mathrm{~B}-1$ | 16384 | $2048 \times 8$ | 24 | T.S. | 35 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ |
| $3636 \mathrm{~B}-2$ | 16384 | $2048 \times 8$ | 24 | T.S. | 45 | 998 | 0 to 75 | $5 \mathrm{~V} \pm 10 \%$ |
| M3636 | 16384 | $2048 \times 8$ | 24 | T.S. | 80 | 998 | -50 to 125 | $5 \mathrm{~V} \pm 5 \%$ |

BIPOLAR PROM CROSS REFERENCE

|  |  |  | Intel Part Number |  |
| :--- | :---: | :---: | :---: | :---: |
| Part <br> Number | Prefix and <br> Manufacturer | Organization | Direct <br> Replacement | For New <br> Designs |
|  |  |  |  |  |
| 82S181 | N-Signetics | $1024 \times 8$ | $3628 \mathrm{~A}-3$ | $3628 \mathrm{~A}-1$ |
| 82S191 | N-Signetics | $2048 \times 8$ | 3636 | $3636 \mathrm{~B}-1$ |
| $82 S 191$ | S-Signetics | $2048 \times 8$ | M3636 |  |

inter

## BPK70 <br> 1 MBIT BUBBLE STORAGE SUBSYSTEM

- Contains Components for Production of 1 MBit Bubble Storage Subsystem
- One 7230 Current Pulse Generator

One 7242 Dual Formatter/Sense Amplifier

- One 7250 Coil Pre-Driver
- Two 7254 Quad VMOS Drive Transistors
- One 71101 MBit Bubble Memory
- One 7904 Socket for $\mathbf{7 1 1 0}$



## ORDER INFORMATION

| Part Number | Description |
| :---: | :---: |
| BPK70-0 <br> BPK70-1 <br> BPK70-2 | $0-50^{\circ} \mathrm{C} 1 \mathrm{MBit}$ Bubble Storage Sub-System <br> $0-70^{\circ} \mathrm{C} 1 \mathrm{MBit}$ Bubble Storage Sub-System <br> $10-50^{\circ} \mathrm{C} 1$ MBit Bubble Storage Sub-System |

# BPK72 <br> BUBBLE STORAGE PROTOTYPE KIT 

- One BPK70 1 Megabit Bubble Storage Subsystem
- One 7220-1 Controller
- Blank 10 cm x 10 cm PC Board for Assembly
- Complete with Accessories and Documentation for Prototyping

BPK72 prototype kit contains the necessary components, accessories and documentation required to build a 1 megabit bubble storage prototype system with minimum design effort. Application information on system interconnections is included.

 CREDIT, RMX/80, $\mu$ Scope, Multibus, PROMPT, Promware, Megachassis, Library Manager, MAIN MULTIMODULE, and the combination of MCS, ICE, SBC, RMX or iCS and a numerical suffix; e.g., iSBC-80.
©INTEL CORPORATION, 1981

## ORDERING INFORMATION

| Order Code | Description |
| :---: | :---: |
| BPK72-1 | $0-70^{\circ} \mathrm{C} \quad 1$ Megabit Storage System Prototype Kit |

ITEMS IN KIT

| Item | Part/Manual Number |
| :--- | :--- |
| BPK72 User's Manual | $121685-002$ |
| Blank Printed Circuit Board | IMB-72 |
| 1 MBit Bubble Memory, |  |
| 0 to $70^{\circ} \mathrm{C}$ | $7110-1$ |
| Socket for 7110 | 7904 |
| Seed Module | 7901 |
| VMOS Transistor | 7902 |
| Solder Tip | 7903 |
| Dummy Module | 7900 |
| Bubble Memory Controller | $7220-1$ |
| Current Pulse Generator | 7230 |
| Dual Formatter/Sense Amp | 7242 |
| Coil Pre-Driver | 7250 |
| Quad VMOS Drive Transistors | $2 \times 7254$ |

## 7110 <br> 1 MEGABIT BUBBLE MEMORY

| $7110-0$ | $0-50^{\circ} \mathrm{C}$ |
| :---: | :---: |
| $7110-1$ | $0-70^{\circ} \mathrm{C}$ |
| $7110-2$ | $10-50^{\circ} \mathrm{C}$ |

## 1,048,576 Bits of Usable Data Storage

- Non-Volatile, Solid-State Memory
- True Binary Organization: 512 Bit Page and 2048 Pages


## Major Track — Minor Loop Architecture

## Redundant Loops with On-Chip Loop Map and Index

## Block Replicate for Read: Block Swap for Write

## - Single Chip 20-Pin Dual In-Line Leadless Package and Socket

## - Small Physical Volume

- Low Power per Bit
- Maximum Data Rate $100 \mathrm{KbIt} / \mathrm{sec}$

The Intel Magnetics 7110 is a very high density 1 megabit non-volatile, solid-state memory utilizing the magnetic bubble technology. The usable data storage capacity is $1,048,576$ bits. The defect tolerant design incorporates redundant storage loops. The gross capacity of Intel Magnetics bubble memory is $1,310,720$ bits

The 7110 has a true binary organization to simplify system design, interfacing, and system software. The device is organized as 256 data storage loops each having 4096 storage bits. When used with Intel Magnetics complete family of support electronics the resultant minimum system is configured as 128 K bytes of usable data storage. The support circuits also provide automatic error correction and transparent handling of redundant loops.
The 7110 has a major track-minor loop architecture. It has separate read and write tracks. Logically, the data is organized as a 512 bit page with a total of 2048 pages. The redundant loop information is stored on-chip in the bootstrap loop along with an index address code. When power is disconnected, the 7110 retains the data stored and the bubble memory system is restarted when power is restored via the support electronics under software control.

The 7110 is packaged in a dual in-line leadless package complete with permanent magnets and coils for the in-plane rotating field. in addition, the 7110 has a magnetic shield surrounding the bubble memory chip to protect the data from externally induced magnetic fields.

The 7110 operating data rate is $100 \mathrm{Kbit} / \mathrm{sec}$. The 7110 can be operated asynchronously and has start/stop capability.


Block Diagram of Single Bubble Memory System - 128K Bytes


NOTE THAT PINS 13 AND 14 SHOULD BE EXTERNALLY CONNECTED.

## PIN CONFIGURATION

## GENERAL FUNCTIONAL DESCRIPTION

The Intel Magnetics 7110 is a 1 megabit bubble memory module organized as two identical 512 K binary half sections. See Major Track-Minor Loop architecture diagram. Each half section is in turn organized as two 256K subsections referred to as quads.

The module consists of a bubble die mounted in a substrate that accommodates two orthogonal drive coils that surround the die. The drive coils produce a rotating magnetic field in the plane of the die when they are excited by $90^{\circ}$ phase shifted triangular current waveforms. The rotating in-plane field is responsible for bubble propagation. One drive field rotation propagates all bubbles in the device one storage location (or cycle). The die-substrate-coil sub-assembly is enclosed in a package consisting of permanent magnets and a shield. The shield serves as a flux return path for the permanent magnets in addition to isolating the device from stray magnetic fields. The permanent magnets produce a bias field that is nearly perpendicular to the plane of the die. This field supports the existence of the bubble domains.
The package is constructed to maintain a 2.5 degree tilt between the plane of the bias magnet faces and the plane of the die. This serves to introduce a small component of the bias field into the plane of the die. During operation when the drive coils are energized this small in-plane component is negligible. During standby or when power is removed the small inplane field ensures that the bubbles will be confined to their appropriate storage locations. The direction of the in-plane field introduced by the package tilt (holding field) is coincident with the $0^{\circ}$ phase direction of the drive field.

## Quad Architecture

A 7110 quad sub-section is composed of the following elements shown on the architecture diagram.

1) Storage Loops

Eighty identical 4096 bit storage loops provide a total maximum capacity of 327,680 bits. The excess storage is provided for two purposes: a) it allows a redundancy scheme to increase device yield; and b) it provides the extra storage required to implement error correction.
2) Replicating Generator (GEN)

The generator operates by replicating a seed bubble that is always present at the generator site, (GEN).
3) Input Track and Swap Gate

Bubbles following generation are propagated down an input track. Bubbles are transferred to/from the input track from/to the 80 storage loops via series connected swap gates spaced every four propagation cycles along the track. The swap gate's ability to transfer bubbles in both directions during an operation eliminates the overhead associated with removing old data from the loops before new data can be written. The swap gate is designed to function such that the logical storage loop position occupied by the bubble transferred out of each loop is filled by the bubble being transferred into each loop. Transferred out bubbles propagate down the remaining portion of the input track where they are dumped into a bubble bucket guard rail.
4) Output Track and Replicate Gate

Bubbles are read out of the storage loops in a nondestructive fashion via a set of replicate gates. The bubble is split in two. The leading bubble is retained in the storage loop and the trailing bubble is transferred onto the output track. Replicate gates are spaced every four propagation cycles along the output track.
5) Detector

Bubbles, following replication, are propagated along the output track to a detector that operates on the magneto-resistance principle. The cylindrical bubble domains are stretched into long strip domains by a chevron expander and are then propagated to the active portion of the detector. The detector consists of a stack of interconnected chevrons through which a current is passed. As the strip domain propagates through the stack, its magnetic flux causes a fractional change in stack resistance which produces an output signal on the order of a few millivolts. The strip domain following detection is propagated to a bubble bucket guard rail. A "dummy" detector stack sits in the immediate vicinity. It is connected in series with the active detector and serves to cancel common mode pickup which originates predominately from the in-plane drive field.
6) Boot Loop, Boot Swap, and Boot Replicate One of the two quads in each half chip contains a functionally active Boot Storage Loop. This loop is used to store:
a) A loop mask code that defines which loops within the main storage area should be accessed. Faulty loops are "masked out" by the support electronics.
b) A synchronization code that assigns data addresses (pages) to the data in the storage loops. Since bubbles move from one storage location to the next every field rotation, the actual physical location of a page of data is determined by the number of field rotations that have elapsed with respect to a reference.

The boot loop is read from and written into via the same input and output tracks as the main" storage loops. However, it has independently accessed swap and replicate gates. The boot swap, under normal circumstances, is intended only to be used during basic initialization at the factory at which time loop mask and synchronization codes are written. The boot replicate is intended to be accessed every time power is applied to the bubble module and its peripheral control electronics. At such a time, the control electronics would read and store the mask information, plus. utilize the synchronization information to establish the location of the data circulating within the loops.


MAJOR TRACK-MINOR LOOP ARCHITECTURE OF 7110 (ONE HALF SHOWN)


SOCKET OUTLINE

## PIN DESCRIPTION

BOOT.REP (Pin 4)
Two-level current pulse input for reading the boot loop.

## BOOT.SWAP (Pin 5)

Single-level current pulse for writing data into the boot loop. This pin is normally used only in the manufacture of the MBM.

## DET.COM (Pin 15)

Ground return for the detector bridge.

## DET.OUT (Pins 16 through 19)

Differential pair ( $\mathrm{A}+, \mathrm{A}-$ and $\mathrm{B}+, \mathrm{B}-$ ) outputs which have signals of several millivolts peak amplitude.
DET.SUPPLY (Pin 20)
+12 volt supply pin.

## GEN.A and GEN.B (Pins 7, 8)

Two-level current pulses for writing data onto the input track.

## PULSE.COM (Pin 1)

+ 12 volt supply pin.
REP.A and REP.B (Pins 3 and 2)
Two-level current pulses for replicating data from storage loops to output track.

SWAP.A and SWAP.B (Pins 13, 14)
Single-level current pulse for swapping data from input track to storage loops.

X-.COIL.IN, X+.COIL.IN (Pins 9, 10)
Terminals for the $X$ or inner coil.

Y-.COIL.IN, Y+.COIL.IN (Pins 11, 12)
Terminals for the $Y$ or outer coil.

## ABSOLUTE MAXIMUM RATINGS*

Operating Temperature . . . . . . . . . . . . . . . . . . . . . $0-70^{\circ} \mathrm{C}$
Relative Humidity ...................................... $95 \%$
Non-Volatile Storage Temperature ..... - 40 to $+100^{\circ} \mathrm{C}$
Shelf Storage Temperature (Data
Integrity Not Guaranteed) .......... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage Applied to DET.SUPPLY . . . . . . . . . . . . . 14 Volts
Voltage Applied to PULSE.COM . . . . . . . . . . . . 12.6 Volts
Continuous Current between DET.COM and
$\qquad$
Coil Current ........................................ 0.5A D.C.
External Magnetic Field for Non-Volatile Storage

20 Oersteds
Non-Operating Handling Shock (without socket) 200G
Operating Vibration ( 2 Hz to 2 kHz with socket)

20G
*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}=25^{\circ} \mathrm{C}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Nom. ${ }^{[1]}$ | Max. |  |  |
| $\mathrm{R}_{1}$ | Resistance: PULSE.COM to REP.A or REP.B |  | 20 |  | ohms |  |
| $\mathrm{R}_{2}$ | Resistance: PULSE.COM to BOOT.REP |  | 8 |  | ohms |  |
| $\mathrm{R}_{3}$ | Resistance: PULSE.COM to BOOT.SWAP |  | 17 |  | ohms |  |
| $\mathrm{R}_{4}$ | Resistance: PULSE.COM to GEN.A or GEN.B |  | 32 |  | ohms |  |
| $\mathrm{R}_{5}$ | Resistance: PULSE.COM to SWAP.A or SWAP.B |  | 120 |  | ohms |  |
| $\mathrm{R}_{6}$ | Resistance: DET.COM to DET.OUT.A + or DET.OUT.B+ |  | 640 |  | Ohms |  |
| $\mathrm{R}_{7}$ | Resistance: DET.COM to DET.OUT.Aor DET.OUT.B- |  | 670 |  | ohms |  |
| $\mathrm{R}_{8}$ | Resistance: DET.COM to DET.SUPPLY |  | 510 |  | ohms | . |
| $\mathrm{R}_{\mathrm{X}}$ | $X$ Coil Resistance |  | 5.2 |  | ohms |  |
| $\mathrm{R}_{\mathrm{Y}}$ | $Y_{n}$ Coil Resistance |  | 2.7 |  | ohms |  |
| $L_{X}$ | $X$ Coil Inductance |  | 98.5 |  | $\mu \mathrm{H}$ | . |
| $L_{Y}$ | Y Coil Inductance |  | 79 |  | $\mu \mathrm{H}$ |  |

## DRIVE REQUIREMENTS

$T_{A}=$ Range specified in Table 1.

| Symbol | Parameter | Min. | Nom. ${ }^{[1]}$ | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{R}}$ | Field Rotation Frequency | 49.95 | 50.00 | 50.05 | KHz |
| $\phi_{L}$ | Phase Lag from Y.COIL to X.COIL | 85 | 90 | 95 | Degrees |
| $I_{P X}$ | X.COIL Peak Current |  | 600 |  | mA |
| $I_{P Y}$ | Y.COIL Peak Current |  | 750 |  | mA |
| $\mathrm{T}_{\mathrm{DX}}$ | X.COIL Positive Turn On Phase |  | 270 |  | Degrees |
| $\mathrm{T}_{1 \mathrm{X}}$ | X.COIL Positive Turn On Width |  | 108 |  | Degrees |
| $\mathrm{T}_{2 \mathrm{X}}$ | X.COIL Positive Decay Width |  | 72 |  | Degrees |
| $\mathrm{T}_{3 \mathrm{X}}$ | X.COIL Negative Turn On Width |  | 108 |  | Degrees |
| $\mathrm{T}_{4 \mathrm{X}}$ | X.COIL Negative Decay Width |  | 72 |  | Degrees |
| T ${ }_{\text {DY }}$ | Y.COIL Positive Turn On Phase |  | 0 |  | Degrees |
| $\mathrm{T}_{1 Y}$ | Y.COIL Positive Turn On Width |  | 108 |  | Degrees |
| $\mathrm{T}_{2 Y}$ | Y.COIL Positive Decay Width |  | 72 |  | Degrees |
| $\mathrm{T}_{3 Y}$ | Y.COIL Negative Turn On Width |  | 108 |  | Degrees |
| $\mathrm{T}_{4} \mathrm{Y}$ | Y.COIL Negative Decay Width |  | 72 |  | Degrees |
| $\mathrm{P}_{\mathrm{T}}$ | Total Coil Power |  | 1.3 |  | Watt |

Note: 1. Nominal values are at $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## CONTROL PULSE REQUIREMENTS

Nominal values at $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$. See Notes 2 and 3 .

| Pulse | Amplitude (mA) | Phase of Leading Edge <br> (Degrees) | Width (Degrees) |
| :--- | :---: | :---: | :---: |
| GEN.A, GEN.B Cut | 64 | 270 (Odd), 90 (Even) | 4.5 |
| GEN.A, GEN.B Transfer | 36 | 270 (Odd), 90 (Even) | 90 |
| REP.A, REP.B Cut | 180 | 270 | 4.5 |
| REP.A, REP.B Transfer | 140 | 270 | 90 |
| SWAP | 120 | 180 | 517 |
| BOOT.REP Cut | 90 | 270 | 4.5 |
| BOOT.REP Transfer | 70 | 270 | 90 |
| BOOT.SWAP | 70 | 180 | See Note 4. |

Note: 2. Pulse timing is given in terms of the phase relations as shown below. For example, a 7110 operating at $f_{R}=50.000 \mathrm{kHz}$ would have a REP.A transfer width of $90^{\circ}$ which is $5 \mu \mathrm{~s}$.

Table 1. 7110 Family

| Part Number | $\mathrm{T}_{\mathbf{A}}$ Range |
| :---: | :---: |
| 7110 | $0-50^{\circ} \mathrm{C}$ |
| $7110-1$ | $0-70^{\circ} \mathrm{C}$ |
| $7110-2$ | $10-50^{\circ} \mathrm{C}$ |

## X-Y COIL WAVEFORMS


3. Two level pulses are described as shown below.

4. BOOT.SWAP is not normally accessed during operation. It is utilized at the factory to write the index address and redundant loop information into the bootstrap loops before shipment.

OUTPUT CHARACTERISTICS
$T_{A}=25^{\circ} \mathrm{C}$ unless otherwise specified.

| Symbol | Min. | Nom. | Max. | Units | Test <br> Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{S}_{1}$ |  | 6 |  | mV | See Figures |
| $\mathrm{S}_{0}$ |  | 1 |  | mV | below. |

## TEST SET-UP FOR OUTPUT VOLTAGE MEASUREMENT



DETECTOR OUTPUT WAVEFORMS


# 7220-1 <br> BUBBLE MEMORY CONTROLLER 

## 8080/8085/8088/8086 Microprocessor Interface

## ■ Interfaces Up to Eight BPK-70 Bubble Storage Subsystems

Self-Contained Timing

■ DMA Handshake Capability

- Single or Multiple Page Block Transfers

■ HMOS Technology
■ Standard 40-Pin Dual In-Line Package

The Intel ${ }^{(8220-1}$ is a complete Bubble Memory Controller (BMC) designed to provide all the interface between Intel Bubble Memories and standard microprocessors such as the 8080, 8085, 8088, and 8086.

The 7220-1 has self-contained timing generation and DMA handshake capability. Single and/or multiple page block transfer capability is supported.
The 7220-1 is capable of interfacing with up to eight BPK 70 one megabit bubble storage subsystems.
The 7220-1 uses Intel's high performance HMOS technology. The 7220-1 is packaged in a standard 40-pin dual in-line package. All inputs and outputs are directly TTL compatible and the device uses a single +5 volt supply.



Figure 2. Pin Configuration

Figure 1. Block Diagram of a 128 K Byte Bubble Storage System

## HARDWARE DESCRIPTION

The 7220-1 Bubble Memory Controller is packaged in a 40-pin Dual In-Line Package (DIP). The following lists the individual pins and describes their function.

Table 1. Pin Description

| Signal Name | Pin No. | I/O | Source/Destination | Description |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | 40 | 1 |  | +5 VDC Supply |
| GND | 20 | 1 |  | Ground |
| PWR.FAIL | 1 | 1 | 7230 CPG | A low forces a controlled stop sequence and holds BMC in an IDLE state (similar to RESET). |
| RESET.OUT | 2 | 0 | 7250 CPD/7242 FSA 7230 Reference Current Switch | An active low signal to disable external logic initiated by PWR.FAIL or RESET signals, but not active until a stopping point in a field rotation is reached (if the BMC is causing the bubble memory drive field to be rotated). |
| CLK | 3 | 1 | Host Bus | 4 MHz , TTL-level clock. |
| $\overline{\text { RESET }}$ | 4 | 1 | Host Bus | A low on this pin forces the interruption of any BMC sequencer activity, performs a controlled shut-down, and initiates a reset sequence. After the reset sequence is concluded, a low on this pin causes a low on the RESET.OUT pin, furthermore, the next BMC sequencer command must be either the Initialize or Abort command; all other commands are ignored. |
| $\overline{\mathrm{RD}}$ | 5 | 1 | Host Bus | A low on this pin enables the BMC output data to be transferred to the host data bus ( $\mathrm{D}_{0}-\mathrm{D}_{8}$ ). |
| $\overline{\text { WR }}$ | 6 | 1 | Host Bus | A low on this pin enables the contents of the host data bus ( $\mathrm{D}_{0}-\mathrm{D}_{8}$ ) to be transferred to the BMC. |
| $\overline{\text { DACK }}$ | 7 | 1 | Host Bus | A low signal is a DMA acknowledge. This notifies the BMC that the next memory cycle is available to transfer data. This line should be active only when DMA transfer is desired and the DMA ENABLE bit has been set. CS should not be active during DMA transfers except to read status. If DMA is not used, DACK requires an external pullup to $\mathrm{V}_{\mathrm{cc}}(5.1 \mathrm{~K}$ ohm). |
| DRQ | 8 | 0 | Host Bus | A high on this pin indicates that a data transfer between the BMC and the host memory is being requested. |
| INT | 9 | 0 | Host Bus | A high on this pin indicates that the BMC has a new status and requires servicing when enabled by the host CPU. |
| $A_{0}$ | 10 | 1 | Host Bus | A high on this pin selects the command/status registers. A low on this pin selects the data register. |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 11-18 | 1/0 | Host Bus | Host CPU data bus. An eight-bit bidirectional port which can be read or written by using the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ strobes. $\mathrm{D}_{0}$ shall be the LSB. |
| $\mathrm{D}_{8}$ | 19 | I/O | Host Bus | Parity bit. |

7220-1

Table 1. Pin Description (Continued)

| Signal Name | Pin No. | I/O | Source/Destination | Description |
| :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { CS }}$ | 21 | 1 | Host Bus | Chip Select Input. A high on this pin shall disable the device to all but DMA transfers (i.e., it ignores bus activity and goes into a high impedance state). |
| DIO | 22 | 1/0 | 7242 FSA | A bidirectional active high data line that shall be used for serial communications with 7242 FSA devices. |
| SYNC | 23 | 0 | 7242 FSA | An active low output utilized to create time division multiplexing slots in a 7242 FSA chain. It shall also indicate the beginning of a data or command transfer between BMC and 7242 FSA. |
| $\overline{\text { SHIFT.CLK }}$ | 24 | 0 | 7242-FSA | A controller generated clock that initiates data transfer between selected FSAs and their corresponding bubble memory devices. The timing of SHIFT.CLK shall vary depending upon whether data is being read or written to the bubble memory. |
| $\overline{\text { BUS.RD }}$ | 25 | 0 | * | An active low signal that indicates that the DIO line is in the output mode. It shall be used to allow off-board expansion of 7242 FSA devices. |
| $\overline{\text { WAIT }}$ | 26 | I/O | * | A bidirectional pin that shall be tied to the WAIT pin on other BMCs when operated in parallel. It shall indicate that an interrupt has been generated and that the other BMCs should halt in synchronization with the interrupting BMC. WAIT is an open collector active low signal. Requires an external pullup resistor to $\mathrm{V}_{\mathrm{cc}}$ ( 5.1 K ohm). |
| ERR.FLG | 27 | 1 | 7242 FSA | An active low input generated externally by 7242 FSA indicating that an error condition exists. It is an open collector input which requires an external pullup resistor ( 5.1 K ohm). |
| $\overline{\text { DET.ON }}$ | 28 | 0 | * | An active low signal that indicates the system is in the read mode and may be detecting. It is useful for power saving in the MBM. |
| C/ $\bar{D}$ | 29 | 0 | 7242 FSA | A high on this line indicates that the BMC is beginning an FSA command sequence. A low on this line indicates that the BMC is beginning a data transmit or receive sequence. |
| $\overline{\text { BOOT.SW.EN }}$ | 30 | 0 | 7230 CPG | An active low signal which may be used for enabling the BOOT.SWAP of the 7230 CPG. |
| SWAP.EN | 31 | 0 | 7230 CPG | An active low signal used to create the swap function in external circuits. |
| BOOT.EN | 32 | 0 | 7230 CPG | An active low signal enabling the bootstrap loop replicate function in external circuitry. |
| REP.EN | 33 | 0 | 7230 CPG | An active low signal used to enable the replicate function in external circuitry. |
| $\overline{\text { TM. } B}$ | 34 | 0 | 7230 CPG | An active low timing signal generated by the decoder logic for determining TRANSFER pulse width. |
| $\overline{\text { TM. }}$ | 35 | 0 | 7230 CPG | An active low timing signal generated by the decoder logic for determining CUT pulse width. |
| $\overline{\bar{Y}-}, \overline{Y_{+}},$ | 36-39 | 0 | 7250 CPD | Four active low timing signals generated by the decoding logic and used to create coil drive currents in the bubble memory device. |

[^7]
## FUNCTIONAL DESCRIPTION

The 7220-1 Bubble Memory Controller provides the user interface to the bubble memory system. The BMC generates all memory system timing and control, maintains memory address information, interprets and executes user request for data transfers, and provides a

Microprocessor-Bus compatible interface for the magnetic bubble memory system.

Figure 3 is a block diagram of the 7220-1 Bubble Memory Controller (BMC). The following paragraphs describe the functions of the individual functional sections of the BMC.


Figure 3. 7220-1 Bubble Memory Controller (BMC), Block Diagram

System Bus Interface - The System Bus Interface (SBI) logic contains the timing and control logic required to interface the BMC to a non-multiplexed bus. The logic also contains the circuitry to check and generate odd parity on transfers across the bus. The interface has input data, output data, and status data latches. The BMC can interface asynchronously to the host CPU. With a 4-MHz clock, it is capable of sustaining a 1.14 Mbyte per second transfer rate, while data is available in the BMC FIFO.
FIFO- The FIFO consists of a $40 \times 8$ bit FIFO RAM for data storage. The FIFO block also contains input and output data latches, providing double data buffering, to improve the R/W cycle times seen at the system bus interface. The FIFO may be used as a general purpose FIFO when a ${ }^{\circ}$ command is not being executed by the BMC Sequencer. In this mode, the FIFO READY status bit becomes a FIFO not-empty indicator indicating that
the RAM and input/output latches have at least one byte of data.

DMA and Interrupt Logic-The DRQ pin has two functions:
(1) If the DMA enable bit in the enable register is set, the DRQ pin, in conjunction with the DACK pin, provides a standard DMA transfer capability; i.e., it has the ability to handshake with an 8257 or 9517/8237 DMA controller chip.
(2) If the DMA enable bit is reset, the DRQ pin acts as a "ready for data transfer interrupt" pin. It becomes active when 22 bytes may be read from or written into the BMC; it is reset when this condition no longer exists.

Register File-The register file contains 7 eight-bit registers that are accessible by the host CPU. Refer to the Register Section for details.

MBM Address Logic and RAM - The MBM address logic consists of the block length counter, starting address counter, adder, and MBM Address RAM. The MBM Address RAM is used to store the next available page address for each of up to 8 dual FSAs. The address maintained is the read address; the write address is generated, when needed, by adding a constant to the stored read address.
The block length counter enables multiple page transfers of up to 2048 pages in length.
The starting address counter is used as a register to hold the desired start address. Once the start address is reached, the counter is incremented on each subsequent page transfer so that its value is equal to the present read address.
DIO Bootloop Decoder/Encoder-- Performs parallel-toserial and serial-to-parallel conversions between the FIFO data and the serial bit stream on the DIO line. This block also generates the $\overline{B U S . R D}$ signal, which indicates the direction of data transfer on the DIO line (this is useful in situations which require external buffering on the DIO line). This block also contains the circuitry which decodes the bootloop data during a Read Bootloop or Initialize operation, and encodes the bootloop data during a Write Bootloop operation.
Sequencer-Controls the execution of commands by decoding the contents of its own internal ROM in which the BMC firmware is located. This block also sets and resets flags and status bits, and controls actions in other parts of the BMC.
Power Fail and Reset-Provides a means of resetting the bubble systems in an orderly manner, when activated by the PWR.FAIL signal, the RESET signal, or the ABORT command. The additive noise on the PWR.FAIL pin should be less than 150 mV for proper powerfail operation.
FSA Select Logic block contains the logic which controls the timing of the interaction between the BMC and the FSAs. The FSA selection is determined by the four high-order bits in the BLR and the four high-order bits in the AR, both set by the user.
Bubble Signal Decoder block contains the logic for creating all the MBM timing signals. The BMC to bubble memory interface consists of active low timing signals. The starting and stopping point of each signal is determined by the decoder logic. Each signal may occur every field rotation or only once in a number of field rotations. The field rotation in which a timing pulse occurs is controlled by the sequencer logic.
Figure 4 and Table 2 illustrate the typical timing signals for the BMC. These signals are described in the following paragraphs.
$\overline{X+}, \overline{X-}, \overline{Y+}$, and $\overline{Y-}$ go to the 7250 CPDs, and are used to enable the coil drive currents in the MBMs.
$\overline{T M . A}$ and $\overline{T M . B}$ go to the 7230 CPGs, and are used to determine, respectively, the pulse widths for the CUT and TRANSFER functions used in replicating and generating the bubbles.

Table 2. 7220-1 BMC Timing (Degrees)

| Signal | Start | Width | End |
| :---: | :---: | :---: | :---: |
| $\bar{X}+$ | $270^{\circ}$ | $108^{\circ}$ | $378^{\circ}$ |
| $\overline{Y+}$ | $0^{\circ}$ | $108^{\circ}$ | $108^{\circ}$ |
| $\bar{X}$ | $90^{\circ}$ | $108^{\circ}$ | $198^{\circ}$ |
| $\bar{Y}$ | $180^{\circ}$ | $108^{\circ}$ | $288^{\circ}$ |
| $\overline{\text { TM.A }}$ (ODD) | $270^{\circ}$ | $4.5^{\circ}$ | $274.5^{\circ}$ |
| $\overline{\text { TM.A }}$ (EVEN) | $90^{\circ}$ | $4.5^{\circ}$ | $94.5^{\circ}$ |
| $\overline{\text { TM.B }}$ (ODD) | $270^{\circ}$ | $90^{\circ}$ | $360^{\circ}$ |
| $\overline{\text { TM.B }}$ (EVEN) | $90^{\circ}$ | $90^{\circ}$ | $180^{\circ}$ |
| $\overline{\text { BOOT.EN }}$ | $252^{\circ}$ | $108^{\circ}$ | $360^{\circ}$ |
| $\overline{\text { REP.EN }}$ | $252^{\circ}$ | $108^{\circ}$ | $360^{\circ}$ |
| $\overline{\text { SWAP.EN }}$ | $180^{\circ}$ | $5.7^{\circ}$ | $697^{\circ}$ |
| $\overline{\text { BOOT.SW.EN }}$ | $180^{\circ}$ | $\mathrm{DC}^{*}$ | $180^{\circ}$ |
| $\overline{\text { SHIFTCLK (RD) }}$ | $186.75^{\circ}$ | $99^{\circ}$ | $285.75^{\circ}$ |
| $\overline{\text { SHIFTCLK (WR) }}$ | $72^{\circ}$ | $288^{\circ}$ | $360^{\circ}$ |

*Stays low for 4118 field rotation periods when writing the MBM Bootloop.

SWAP.EN, $\overline{R E P . E N}, \overline{B O O T . S W . E N, ~ a n d ~ B O O T . E N ~ a l l ~ g o ~}$ to the 7230 CPG. They are used to enable, respectively, the data swap, data replicate, boot swap, and boot replicate functions within the MBMs.
$\overline{\text { SHIFT.CLK }}$ goes to the FSAs. It is used to control the timing of events at the interface between each FSA and its corresponding MBM. (Refer to 7242 FSA Specification for a description of the BMC/FSA interface.)
$\overline{S Y N C}$ and $C / \bar{D}$ control the serial communications between the BMC and the FSAs (on the DIO line).

## USER-ACCESSIBLE REGISTERS

The user operates the bubble memory system by reading from or writing to specific registers within the bubble memory controller (BMC). The following paragraphs identify these registers and gives brief functional descriptions, including bit configurations and address assignments.

## Register Addressing

Selection of the user-accessible registers depends on register address information sent from the user to the BMC. This address information is sent via a single address line (designated $A_{0}$ ) and data bus lines $D_{0}$ through $D_{4}$.
Both Command Register (CMDR) and Register Address Counter (RAC) are 4-bit registers which are loaded from $D_{0}-D_{3}$. The status register is selected and read by a single read request. The command register is selected and loaded by a single write request. The remaining registers are accessed indirectly, and the desired register is first selected by placing its address in the RAC, and then read or written with a subsequent read or write request.


Figure 4. 7220-1 BMC Timing Diagram

Table 3 gives a complete listing of the address asignments for the user-accessible registers. The registers are listed in two groups. The first group (STR, CMDR, RAC) consists of those registers that are selected and accessed in one operation. The second group (UR, BLR, ER, AR, FIFO) consists of those registers that are addressed indirectly by the contents of RAC.

Table 3. Address Assignments for the User-Accessible Registers

| A0 D7 D6 D5 D4 D3 D2 D1 D0 | Symbol | Name of Register | Read/Write |  |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | $C$ | $C$ | $C$ | $C$ | CMDR | Command <br> Register <br> 1 | 0 | 00

Table 3. Address Assignments for the User-Accessible Registers (Continued)

| RAC |  |  |  |  | Symbol | Name of Register | Read/Write |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| AO | B3 | B2 | B1 | B0 |  |  |  |
| 0 | 1 | 0 | 1 | 0 | UR | Utility Register | Read or Write |
| 0 | 1 | 0 | 1 | 1 | BLR LSB | Block Length Register LSB | Write Only |
| 0 | 1 | 1 | 0 | 0 | BLR MSB | Block Length Register MSB | Write Only |
| 0 | 1 | 1 | 0 | 1 | ER | Enable Register | Write Only |
| 0 | 1 | 1 | 1 | 0 | AR LSB | Address Register LSB | Read or Write |
| 0 | 1 | 1. | 1 | 1 | AR MSB | Address Register MSB | Read or Write |
| 0 | 0 | 0 | 0 | 0 | FIFO | FIFO Data Buffer | Read or Write |

SSSSSSSS $=8$-bit status information returned to the user from the STR $C C C=4$-bit command code sent to the CMDR by the user. BBBB $=4$-bit register address sent to the RAC by the user.
B3B2B1B0 $=4$-bit contents of RAC at the time the user makes a read or write request with $A 0=0$.
LSB $=$ Least Significant Byte
MSB $=$ Most Significant Byte

The register file contains the registers with address 1010 through 1111. These registers are also called parametric registers because they contain flags and parameters that determine exactly how the BMC will respond to commands written to the CMDR.

To facilitate such operations, the BMC automatically increments the RAC by one count after each transfer of data to or from a parametric register.

The RAC increments from the initially loaded value through address 1111 and then on to 0000 (the FIFO address). When it has reached 0000, it no longer increments. All subsequent data transfers (with $A 0=0$ ) will be to or from the FIFO until such time as the RAC is loaded with a different register address.

## REGISTER DESCRIPTIONS

## Command Register (CMDR) 4 Bits, Write Only

The user issues a command to the BMC by writing a 4-bit command code to the CMDR.

Table 4 lists the 4-bit command codes used to issue the sixteen commands recognized by the BMC:

Table 7 is a listing of the commands and their functions.

Table 4. Command Code Definitions

| D3 | D2 | D1 | Do | Command Name |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | Write Bootloop Register Masked |
| 0 | 0 | 0 | 1 | Initialize |
| 0 | 0 | 1 | 0 | Read Bubble Data |
| 0 | 0 | 1 | 1 | Write Bubble Data |
| 0 | 1 | 0 | 0 | Read Seek |
| 0 | 1 | 0 | 1 | Read Bootloop Register |
| 0 | 1 | 1 | 0 | Write Bootloop Register |
| 0 | 1 | 1 | 1 | Write Bootloop |
| 1 | 0 | 0 | 0 | Read FSA Status |
| 1 | 0 | 0 | 1 | Abort Seak |
| 1 | 0 | 1 | 0 | Write Seek |
| 1 | 0 | 1 | 1 | Read Bootloop |
| 1 | 1 | 0 | 0 | Read Corrected Data |
| 1 | 1 | 0 | 1 | Reset FIFO |
| 1 | 1 | 1 | 0 | MBM Purge |
| 1 | 1 | 1 | 1 | Software Reset |

The most commonly used commands in nermal operation are:

Initialize
Read Bubble Data
Write Bubble Data
Reset FIFO
Read Seek
Write Seek
Abort
Read Corrected Data
Software Reset
Read FSA Status
MBM Purge

Commands relating to the bootloop, and used only for diagnostic purposes, are:

Read Bootloop Register
Write Bootloop Register
Write Bootloop Register Masked
Read Bootloop
Write Bootloop

## Status Register (STR) 8 Bits, Read Only

The user reads the BMC status register in response to an interrupt signal, or as part of the polling process in a polled data transfer mode. The status register provides information about error conditions, completion or termination of commands, and about the BMC's readiness to transfer data or accept new commands. The individual bit descriptions are as follows:


BUSY (when $=1$ ) indicates that the BMC is in the process of executing a command. When equal to 0 , BUSY indicates that the BMC is ready to receive a new command. In the case of Read Bubble Data, Read Bootloop, read Bootloop Register, or Read Corrected Data commands, BUSTY may also indicate that the data has not been completely removed from the FIFO, and that DRQ is still active. BUSY will then drop as soon as DRQ does (after the user has finished reading the data remaining in the FIFO).

OP COMPLETE (when = 1 ) indicates the successful completion of a command.

OP FAIL (when =1) indicates that the BUSY bit has gone inactive with either the TIMING ERROR or UNCORRECTABLE ERROR bits active.

TIMING ERROR (when = 1) indicates that a FSA has reported a timing error to the BMC, or that the host system has failed to keep up with the BMC, thereby causing the BMC FIFO to overflow or to underflow. TIMING ERROR is also set if no bootloop sync word is found during initialization, or if a Write Bootloop command is issued when the WRITE BOOTLOOP ENABLE bit is equal to zero in the enable register.

CORRECTABLE ERROR (when $=1$ ) indicates that a FSA has reported to the BMC that a correctable error has been detected in the last data block transferred.

UNCORRECTABLE ERROR (when $=1$ ) indicates that at least one FSA has reported to the BMC that an uncorrectable error has been detected in the last data block transferred.

PARITY ERROR (when $=1$ ) indicates that the BMC's parity check circuitry has detected a parity error on a data byte sent to the BMC by the user on the data lines $D_{0}-D_{8}$.

FIFO READY has two functions. The FIFO READY functions are as follows:

NOTE: IF RAC $\neq$ FIFO, FIFO READY $=1$

| STATUS BITS |  | READ | WRITE |
| :---: | :---: | :---: | :---: |
| FIFO READY | BUSY |  | 1 |
| 1 | data in <br> FIFO | space in <br> FIFO |  |
| 0 | 1 | no data | no space |
| 1 | 0 | - data in FIFO - <br> 0 |  |

Although the status word can be read at any time, the status information, bit 1 through 6 , is not valid until the BUSY bit is low.

STR Bits 1 through 6 are reset when a new command is issued. They may also be reset by making a write request ( $W R=0$ ) to the BMC with $A_{0}=1, D_{4}=0$, and $D_{5}=1$ (that is, writing the RAC with $D_{5}=1$ ). This operation also resets the "INT" pin to " 0 ". NOTE: A byte of FIFO data can be lost when using this procedure if the RAC is written to other than the FIFO address when data is still present in FIFO.

## Enable Register (ER) 8 Bits, Write Only

The user sets various bits of the enable register to enable or disable various functions within the BMC or the FSAs. The individual bit descriptions are as follows:


In the above figure and in the text below, the following abbreviations are used:

```
ICD = INTERNALLY CORRECT DATA
RCD = READ CORRECTED DATA
UCE = UNCORRECTABLE ERROR
CE = CORRECTABLE ERROR
TE = TIMING ERROR
```

ENABLE PARITY INTERRUPT enables the BMC to interrupt the host system (via the INT line) when the BMC detects a parity error on the data bus lines $D_{0}-D_{7}$.

ENABLE ICD enables the BMC to give the Internally Correct Data command to the FSAs when an error has been detected by the FSA's error detection and correction circuitry. Each FSA responds to such a command by internally cycling the data through its error correction network. When finished, the FSA returns status to the BMC as to whether or not the error is correctable. The value of ENABLE ICD affects the action of INTERRUPT ENABLE (ERROR).

ENABLE RCD enables the BMC to give the Read Corrected Data command to the FSAs when an error has been detected. This causes each FSA to correct the error (if possible) and also to transfer the corrected data to the BMC. The Read Corrected Data command is also used to read into the BMC data previously corrected by the FSA in response to an Internally Correct Data command. In either case, when the data transfer has been completed, the BMC reads each FSA's status to determine whether or not the error was correctable. In the case of an uncorrectable error, bad data may have been sent to the user. The value of ENABLE RCD affects the action of INTERRUPT ENABLE (ERROR).

WRITE BOOTLOOP ENABLE (when = 1) enables the bootloop to be written. If this bit is equal to zero, and a Write Bootloop command is received by the BMC, the command is aborted and the TIMING ERROR bit is set in the STR.
MFBTR controls the maximum burst transfer rate from FSA(s) to BMC FIFO. This rate is variable on the "last page" of a multiple page transfer. (In one page transfers the last page is the only page.) See Table 5 for effects of this bit on the various 7220-1 commands.

Table 5. MFBTR Bit Definitions

| Number <br> of MBMs <br> Operated <br> in Parallel | Maximum <br> Required <br> Host Interface <br> Data Rate | MFBTR Bit |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Read Command | Write Command |  |  |
| 1 | 50 K byte/sec | 0 | N/A |  |
| 2 | 100 K byte/sec | 0 | N/A |  |
| 4 | 200 K byte/sec | 0 | N/A |  |
| 8 | 400 K byte/sec | 0 | N/A |  |
| 1 | 12.5 K byte/sec | 1 | 0 |  |
| 2 | 25 K byte/sec | 1 | 0 |  |
| 4 | 50 K byte/sec | 1 | 0 |  |
| 8 | 100 K byte/sec | 1 | 0 |  |

NOTE: The MFBTR bit should always be set to " 0 " for all commands except "Read Bubble Data."

DMA ENABLE (when $=1$ ) enables the BMC to operate in DMA data transfer mode, using the DRQ and $\overline{\text { DACK }}$ signals in interaction with a DMA controller. When equal to zero, DMA ENABLE sets up the controller to support interrupt driven or polled data transfer.

INTERRUPT ENABLE (ERROR) selects error conditions under which the BMC stops command execution and interrupts the host processor (via the INT line). INTERRUPT ENABLE (ERROR) operates in conjunction with ENABLE ICD and ENABLE RCD.

| Enable <br> ICD | Enable <br> RCD | Interrupt <br> Enable <br> (ERROR) | Interrupt Action |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | No interrupts due to errors |
| 0 | 0 | 1 | Interrupt on TE only |
| 0 | 1 | 0 | Interrupt on UCE or TE |
| 0 | 1 | 1 | Interrupt on UCE, CE, or TE |
| 1 | 0 | 0 | Interrupt on UCE or TE |
| 1 | 0 | 1 | Interrupt on UCE, CE, or TE |
| 1 | 1 | 0 | Not used |
| 1 | 1 | 1 | Not used |

$\mathrm{TE}=$ Timing Error, $\mathrm{CE}=$ Correctable Error,
UCE = Uncorrectable Error.
INTERRUPT ENABLE (NORMAL) (when = 1) enables the BMC to interrupt the host system (via the INT line), when a command execution has been successfully completed (OP COMPLETE $=1$ in the STR).

## Utility Register (UR) 8 Bits, Read or Write

The utility register is a general purpose register available to the user in connection with bubble memory system operations. It has no direct effect on the BMC operation, but is provided as a convenience to the user.

## Block Length Register (BLR) 16 Bits, Write Only

The contents of the block length register determine the system page size and also the number of pages to be transferred in response to a single bubble data read or write command. The bit configuration is as follows:


NUMBER OF FSA
NUMBER OF PAGES TO BE TRANSFERRED
CHANNELS (NFC)
The system page size is proportional to the number of magnetic bubble memory modules (MBMs) operating in parallel during the data read or write operation. Each MBM requires two FSA channels. Bits 4 through 7 of BLR MSB actually specify the number of FSA channels to be accessed.
The BLR LSB, together with the 3 least significant bits of the BLR MSB, specify the number of pages to be transferred. Up to 2048 pages can be transferred in response to a single bubble data read or write command, hence the requirement for 11 bits. All 11 bits equal to zero specifies a 2048 page transfer.

## Address Register (AR) 16 Bits, Read or Write

The contents of the address register determine which MBM group is to be accessed, and, within that group,
what starting address location shall be used in a data read or write operation. The bit configuration is as follows:


Within each MBM there are 2048 possible starting address locations for a data read or write operation, hence the requirement for 11 bits in the starting address.
The selection of the MBMs to be read or written is specified by AR MSB Bits 3-6. The BMCs interpretation of these bits depends on the number of MBMs in a group, which is specified by BLR MSB Bits 4-7.

Table 6 shows which MBM groups are selected in response to given values for BLR MSB Bits 4-7 and AR MSB Bits 3-6. A 1-megabyte system ( 8 MBMs ) is represented, with the FSA channels numbered 0 through F:

Table 6. Selection of FSA Channels

| AR MSB Bits$(6,5,4,3)$ | BLR MSB Bits (7,6,5,4) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | 0000 | 0001 | 0010 | 0100 | 1000 |
| 0000 | 0 | 0,1 | 0,1,2,3 | 0 to 7 | 0 to F |
| 0001 | 1 | 2,3 | 4,5,6,7 | 8 to $F$ |  |
| 0010 | 2 | 4,5 | 8,9,A,B |  |  |
| 0011 | 3 | 6,7 | C,D,E,F |  |  |
| 0100 | 4 | 8,9 |  |  |  |
| 0101 | 5 | A,B |  |  |  |
| 0110 | 6 | C,D |  |  |  |
| 0.111 | 7 | E,F |  |  |  |
| 1000 | 8 |  |  |  |  |
| 1001 | 9 |  |  |  |  |
| 1010 | A |  |  |  |  |
| 1011 | B |  |  |  |  |
| 1100 | C |  |  |  |  |
| 1101 | D |  |  |  |  |
| 1110 | E |  |  |  |  |
| 1111 | F |  |  |  |  |

The accessing of single FSA channels is done only as part of diagnostic processes. AR MSB Bit 7 is not used.

## FIFO Data Buffer (FIFO) $40 \times 8$ Bits, Read or Write

The BMC FIFO is a 40-byte buffer through which data passes on its way from the FSAs to the user, or from the user to the FSAs. The FIFO allows the data transfer to proceed in an asynchronous and flexible manner, and relaxes timing constraints, both to the FSAs and also to the user's equipment. The user's system must, however, meet the data rate requirements. When the BMC is busy (executing a command) the FIFO functions as a data buffer. When the BMC is not busy, the FIFO is available to the user as a general purpose FIFO.

## FUNCTIONAL OPERATION

The IC components used in the bubble memory systems have been designed with transparency in mind-that is, a maximum number of operations are handled by the hardware and firmware of these components.

Each one-Megabit Bubble Memory (MBM) operates in its own domain, and is unaffected by the number of bubble memories in the system. The roles played by the MBM's immediate support circuitry can be described as if the system contained only one MBM module.

## Data Flow Within the Magnetic Bubble Memory (MBM) System (Single MBM Systems)

During a read operation, data flows as follows: The data from the MBM is input to the Formatter/Sense Amplifier (FSA). Data from each channel (A channel or B channel) of the MBM goes to the corresponding channel of the FSA. In the FSA, the data is paired up with the corresponding bit in the FSA's bootloop register to determine whether it represents data from a 'good' loop. If it does, the data bit is stored in the FSA FIFO. Error detection and correction (if enabled by the user) is applied to each block of 256 data bits.

From the FSA FIFO, data is sent to the bubble memory controller (BMC) in the form of a serial bit stream, via a one-line bidirectional data bus (DIO). The data is multiplexed onto the DIO line, with data bits coming alternately from the A and B channels of the FSA. The BMC outputs a SYNC pulse to the SELECT.IN input of the FSA. The FSA responds by placing a data bit from the A channel FIFO on the DIO line. One clock cycle later, a
data bit from the B channel FIFO is placed on the DIO line. The BMC continues to output SYNC pulses, once every $\mathbf{2 0}$ or $\mathbf{8 0}$ clock cycles, each time receiving two data bits in return.
In the BMC, the data undergoes serial-to-parallel conversion, and is assembled into bytes, which are then placed in the BMC FIFO, which can hold 40 bytes of data. From this FIFO, the data bytes are written onto the user interface.

During a write operation, the data flow consists of the corresponding operations in the reverse order.

## Multiple-MBM Systems

The 7220-1 BMC can interface up to 8 one-megabit BPK70 Bubble Storage subsystems. The data flow in a multipleBPK70 system is in most respects similar to that which occurs in a one-BKP70 subsystem. The difference is in the time-division multiplexing that occurs on the DIO bus line between the BMC and the FSAs.
For data transfer operations, the BMC may exchange data with as few as two FSA channels (one BPK70) or as many as 16 FSA channels (eight BPK70s).

SOFTWARE INTERFACE-The general procedure for communicating with the BMC is:

Pass parameters to the BMC by loading the registers.
Send the desired command.
Read the status/command register until BMC is not busy (or use "INT" pin).
Examine the status register to determine whether the operation was successful.

Table 7. Detailed Command Descriptions

| Initialize | The BMC executes the Initialize command by first interrogating the bubble system to <br> determine how many FSAs are present, then reading and decoding the bootloop from each <br> MBM and storing the results in the corresponding FSA's bootloop register. All the parametric <br> registers must be properly set up before issuing the Initialize command. |
| :--- | :--- |
| Read Bubble Data |  |
| The Read Bubble Data command causes data to be read from the MBMs into the BMC FIFO. |  |
| The selection of the MBMs to be accessed and the starting address for the read operation is |  |
| specified in the address register (AR). The block length register (BLR) specifies the number of |  |
| system pages to be read. All the parametric registers must be properly set up before issuing |  |
| the Read Bubble Data command. |  |

Table 7. Detailed Command Descriptions (Continued)

| Write Seek | The Write Seek command rotates the selected MBMs to a designated page address location. No data transfer occurs. The positioning is such that the next data location available to be written is the specified (inAR) page address plus one. The Write Seek command may be used to reduce latency (access time) in cases where information is available for the user to predict the location of an impending write reference to the MBMs. |
| :---: | :---: |
| Abort | The Abort command causes a controlled termination of the command currently being executed by the BMC. The Abort command will be accepted by the BMC (and is typically issued) when the BMC is busy. |
| MBM Purge | The MBM Purge command clears all BMC registers, counters, and the MBM address RAM. Furthermore, it determines how many FSA channels are present in the system and stores this value in the 7220-1. The "INITIALIZE" command uses this command as a subroutine. |
| Read Corrected Data | The Read Corrected Data command causes the BMC to read into the BMC FIFO a 256-bit block of data from the FIFO of each selected FSA channel, after an error has been detected. The data cycles through the error correction network of the FSA. After the data has been read, the FSA reports to the BMC whether or not the error was correctable. The Read Corrected Data command is used only when the system is in error correction mode (ENABLEICD or ENABLE RCD set in the ER). |
| Software Reset | The Software Reset command clears the BMC FIFO and all registers, except those containing initialization parameters. It also causes the BMC to send the Software Reset command to selected FSAs in the system. No reinitialization is needed after this command. |
| Read FSA Status | The Read FSA Status command causes the BMC to read the 8 -bit status register of all FSAs, and to store this information in the BMC FIFO. The Read FSA Status command is independent all parametric registers. |
| Read Bootloop Register | The Read Bootloop Register command causes the BMC to read the bootloop register of the selected FSA channels and to store this information in the BMC FIFO. Twenty bytes are transferred for each FSA channel selected. |
| Write Bootloop Register Masked | Proper operation of the FSAs during data transfer to or from the MBMs requires that the bootloop register contain (if error correction is used) exactly 270 logic 1 s for each FSA bootloop register. The user may select any subset of 270 "good" loops from the total number of available loops (if error correction is not used, 270 replaced by 272). As an alternative, the Write Bootloop Register Masked command may be used. This command counts the number of logic 1s and masks out the remaining is after the proper count has been reached. The Initialize command uses this command as a subroutine. |
| Read Bootloop | The Read Bootloop command causes the BMC to read the bootloop from the selected MBM, and to store the decoded bootloop information in the BMC FIFO. The Initialize command uses this command as a subroutine. |
| Write Bootloop | The Write Bootloop command causes the existing contents of the selected MBM's bootloop to be replaced by new bootloop data based on 40 bytes of information stored in the FIFO (the user must actually write 41 bytes, where the 41st byte is all $0 s)$. Encoding of the bootloop data is done by the BMC hardware. |

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

VCC Supply Voltage . . . . . . . . . . . . . . . . . . - 0.5 V to 7 V
*NOTICE: 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(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}+5 \%,-10 \%\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH(1) }}$ | dnput High Voltage (all but PWR.FAIL) | 2.0 |  | V |  |
| $\mathrm{V}_{1 H(2)}$ | Input High Voltage ( $\overline{\text { PWR.FAIL }}$ ) | 2.5 |  | V |  |
| $\mathrm{V}_{\mathrm{OL}(1)}$ | Output Low Voltage <br> (All outputs except $\overline{\mathrm{DET} . \mathrm{ON}}, \overline{\mathrm{BUS.RD}}$, SHIFT.CLK, and SYNC |  | . 45 | V | $\mathrm{l}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL(2) }}$ | Output Low Voltage DET.ON, BUS.RD, SHIFT.CLK, $\overline{\text { SYNC }}$ |  | . 45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}$ |
| $\left\|\mathrm{I}_{\text {LL }}\right\|$ | Input Leakage Current |  | 10 | $\mu \mathrm{A}$ | $0 \leqslant V_{\text {IN }} \leqslant V_{\text {CC }}$ |
| \|ofl| | Output Float Leakage |  | 10 | $\mu \mathrm{A}$ | $0.45 \leqslant V_{\text {OUT }} \leqslant V_{\text {CC }}$ |
| $I_{\text {cc }}$ | Power Supply Current from $\mathrm{V}_{\mathrm{CC}}$ |  | 200 | mA |  |

## A.C. CHARACTERISTICS

( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%,-10 \% ; \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$; unless otherwise noted.)

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{P}$ | Clock Period | 249.75 | 250.25 | ns |  |
| $t_{\varnothing}$ | Clock Phase Width (High Time) | $.45 t_{P}$ | $.55 t_{p}$ |  |  |
| $t_{R}-t_{F}$ | Input Signal Rise and Fall Time |  | 30 | ns |  |

## FSA INTERFACE TIMINGS

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ CDV | CLK to DIO Valid Delay |  | 150 | ns | Under Pin Loads* |
| $\mathrm{t}_{\text {CDF }}$ | CLK to DIO Entering Float | 10 | 250 | ns | Under Pin Loads* |
| $\mathrm{t}_{\text {CDE }}$ | CLK to DIO Enabled from Float |  | 150 | ns | Under Pin Loads* |
| $\mathrm{t}_{\mathrm{CDH}}$ | CLK to DIO Hold Time | 10 |  | ns | Under Pin Loads* |
| ${ }^{\text {c CSOL }}$ | CLK to $\overline{\text { SYNC }}$ Leading Edge Delay |  | 120 | ns | Under Pin Loads* |
| $\mathrm{t}_{\text {csot }}$ | CLK to SYNC Trailing Edge Delay | 20 | 100 | ns | Under Pin Loads* |
| $t_{\text {DC }}$ | DIO Setup Time to Clock | 80 |  | ns | Under Pin Loads* |
| ${ }^{\text {t }}$ DHC | DIO Hold Time from Clock | 0 |  | ns | Under Pin Loads* |
| ${ }^{\text {cool }}$ | CLK to Output Leading Edge |  | 150 | ns | Under Pin Loads* |
| $\mathrm{t}_{\mathrm{COT}}$ | CLK to Output Trailing Edge | 0 | 190 | ns | Under Pin Loads* |
| $\mathrm{t}_{\mathrm{EW}}$ | ERR. FLG Pulse Width | 200 |  | ns | Under Pin Loads* |
| ${ }^{\text {tsCFT }}$ | $\overline{\text { SHIFTCLK }}$ to $\bar{Y}$ - Trailing Edge | 80 | 200 | ns | Under Pin Loads* |

[^8]A.C. CHARACTERISTICS (Continued) $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{cc}}=5.0+5 \%,-10 \% ; \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} ;$ unless

READ CYCLE (HOST INTERFACE) otherwise noted.)

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A C}$ | Select Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | ns |  |
| $t_{\text {ca }}$ | Select Hold from $\overline{\mathrm{RD}} \uparrow$ | 0 |  | ns |  |
| $t_{\text {RR }}$ | $\overline{\mathrm{RD}}$ Pulse Width | 200 |  | ns |  |
| $t_{\text {AD }}$ | Data Delay from Address |  | 150 | ns |  |
| $t_{\text {RD }}$ | Data Delay from $\overline{\mathrm{RD}} \downarrow$ |  | 150 | ns |  |
| $t_{\text {dF }}$ | Output Float Delay | 10 | 100 | ns | TBD |
| $t_{\text {D }}$ | DACK Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | ns |  |
| ${ }_{\text {t }} \mathrm{CD}$ | DACK Hold from $\overline{\mathrm{RD}} \uparrow$ | 0 |  | ns |  |
| $t_{\text {KD }}$ | Data Delay from $\overline{\text { DACK }} \downarrow$ |  | 150 | ns |  |
| ${ }^{\text {t }} \mathrm{CYCR}$ | "Read" Cycle Time | $\begin{aligned} & \text { (DMA Mode) } \\ & 4 t_{p}-t_{\phi} \end{aligned}$ |  | ns | In non DMA mode. <br> $\mathrm{t}_{\text {CYCR }}$ Min. $=6 \mathrm{t}_{\mathrm{p}}-\mathrm{tg}_{\mathrm{g}}$ |

WRITE CYCLE (HOST INTERFACE)

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A C}$ | Select Setup to WR $\downarrow$ | 0 |  | ns |  |
| ${ }^{\text {t }}$ CA | Select Hold from $\overline{W R} \uparrow$ | 0 |  | ns |  |
| tww | $\overline{\text { WR Pulse Width }}$ | 200 |  | ns |  |
| tow | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 200 |  | ns |  |
| twD | Data Hold from $\overline{W R} \uparrow$ | 0 |  | ns |  |
| $t_{\text {DC }}$ |  | 0 |  | ns |  |
| ${ }^{t} \mathrm{CD}$ | $\overline{\text { DACK }}$ Hold from $\overline{W R} \uparrow$ | 0 |  | ns |  |
| tcrew | "Write" Cycle Time | $4 t_{p}+t_{w w}$ |  |  |  |
| ${ }^{\text {t }}$ CQ | Request Hold from $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ (Non-Burst Mode) |  | 150 | ns |  |
| tDEADW | Inactive Time between $\overline{W R} t$ and $\overline{W R}!$ | $4 t_{p}$ |  | ns |  |
| tDEADR | Inactive Time between $\overline{\mathrm{RD}}$ t and $\overline{\mathrm{RD}} \downarrow$ | 150 |  |  |  |

## 7250-7230 INTERFACE TIMINGS

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CBL}}$ | CLK to Bubble Signal Leading Edge |  | 250 | ns | Under Pin Loads* |
| $\mathrm{t}_{\mathrm{CBT}}$ | CLK to Bubble Signal Trailing Edge |  | 250 | ns | Under Pin Loads* |

*Bubble Pin Loads Shown Below
PIN LOADINGS

| Pin Names | Value | Unit |
| :---: | :---: | :---: |
| $\overline{X+}, \bar{X}-, \overline{Y+}, \overline{Y-}$ | 150 | pF |
| $\overline{\text { TM.A }}, \overline{T M . B}, \overline{\text { REP.EN, }} \overline{B O O T . E N}$, $\overline{\text { SWAP.EN, }} \overline{\text { BOOT.SW.EN, }} \overline{\mathrm{C} / D}$, ERR.FLG, WAIT, SYNC | 50 | pF |
| $\overline{\text { DET.ON \& SHIFT.CLK }}$ | 100 | pF |
| BUS.READ | 10 | pF |

## WAVEFORMS

## READ (HOST INTERFACE)



WRITE (HOST INTERFACE)


DMA (HOST INTERFACE)


## WAVEFORMS (Continued)

7242 INTERFACE TIMINGS


7250 \& 7230 INTERFACE TIMINGS


## 7230 <br> CURRENT PULSE GENERATOR FOR BUBBLE MEMORIES

\author{

- TTL Compatible Inputs <br> - Provides all Pulses for IM's Bubble Memories <br> - Replicate, Swap, Generate, Boot Replicate and Bootswap <br> - Current Sink Outputs Designed to Directly Drive Bubble Memory
}

The Intel 7230 is a Current Pulse Generator (CPG) designed to drive Intel Magnetics Bubble Memories. The 7230 is a Schottky Bipolar, TTL input compatible device that converts digital timing signals to analog current pulses. The CPG provides all pulses for Intel Magnetics Bubble Memories (7110 Family). These include Replicate, Swap, Generate, Boot Replicate and Bootswap pulses. The high current sinking outputs directly drive the bubble memory. It also directly interfaces to the Intel Magnetics Bubble Memory Controller (7220-1) and Formatter/Sense amplifier (7242).
The 7230 operates from 5-volt and 12-volt power supplies and is in a standard 22-pin dual-in-line package.


## LOGIC DIAGRAM



## EXTERNAL RESISTOR REQUIREMENTS

Connect a $1 \% 3.48 \mathrm{~K}$ ohm resistor based between pin 20 and ground or referenced current switch as outlined in BPK72 User's Manual

## PIN DESCRIPTION

## BOOT.EN (Pln 10)

An active low input enabling the BOOT.REP output current pulse.

## BOOT.REP (Pin 13)

An output providing the current pulse for bootstrap loop replication in the bubble memory.

## BOOT.SWAP (PIn 14)

An output providing a current pulse which may be used for writing data into the bootstrap loop.

## $\overline{\text { BOOT.SW.EN (Pin 9) }}$

An active low input enabling the BOOT.SWAP output current pulse.

## $\overline{\text { CS }}$ (Pin 7)

An active low input for selecting the chip. The chip powers down during deselect.

## GEN.A (Pin 18)

An output providing the current pulse for writing data into the " $A$ " quads of the bubble memory.

## GEN.B (Pin 19)

An output providing the current pulse for writing data into the " $B$ " quads of the bubble memory.

## $\overline{\text { GEN.EN.A }}$ (Pin 5)

An active low input enabling the GEN.A output current pulse.

## $\overline{\text { GEN.EN.B }}$ (Pin 4)

An active low input enabling the GEN.B output current pulse.

## $\overline{\text { PWR.FAIL (Pin 21) }}$

An active low, open collector output indicating that either $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{DD}}$ is below its threshold value.

## REFR. (Pin 20)

The pin for the reference current generator to which an external resistance must be connected.

## REP.A (Pin 15)

An output providing the current pulse for replication of data in the " $A$ " quads of the bubble memory.

## REP.B (Pin 16)

An output providing the current pulse for replication of data in the " $B$ " quads of the bubble memory.

REP.EN (Pin 8)
An active low input enabling the REP.A and REP.B outputs.

## PIN DESCRIPTION (continued)

## SWAP (PIn 17)

An output providing the current pulse for exchanging the data between the input track and the storage loops in the bubble memory.

## $\overline{\text { SWAP.EN (Pin 6) }}$

An active low input enabling the SWAP output.

## $\overline{\text { TM.A }}$ (Pin 2)

An active low timing signal determining the cut pulse widths of the BOOT.REP, GEN.A, GEN.B, REP.A and REP.B outputs.

## $\overline{T M . B}$ (Pin 3)

An active low timing signal determining the transfer pulse widths of the BOOT.REP, GEN.A, GEN.B, REP.A and REP.B outputs.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . $-20^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$\mathrm{V}_{\mathrm{Cc}}$ and Input Voltages . . . . . . . . . . . . . . . . -0.5 V to +7 V
$V_{D D}$ and Output Voltages . . . . . . . . . . . -0.5 V to +12.6 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 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

( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%,-10 \%$;
$V_{D D}=12 \mathrm{~V} \pm 5 \%$; unless otherwise specified)

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| IIL | Input Low Current |  |  | -0.4 | mA | $\mathrm{V}_{\text {IL }}=0.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{IH}}$ | Input High Current |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  |  | V |  |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  |  | -1.5 | V | $\mathrm{I}=-18 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $I_{\text {CEX1 }}$ | Output Leakage Current (All Outputs except PWR.FAIL) |  |  | 1.0 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=12.6 \mathrm{~V}$ |
| $I_{\text {cex2 }}$ | PWR.FAIL Output Leakage Current |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{OH}}=\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | PWR.FAIL Output Low Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=4 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| $\mathrm{V}_{\text {CCTH }}$ | $\mathrm{V}_{\text {cc }}$ Threshold (for $\overline{\text { PWR.FAIL }}$ ) |  | 4.65 |  | V | $\mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V}$ |
| $\mathrm{V}_{\text {DDTH }}$ | $\mathrm{V}_{\text {DD }}$ Threshold (for PWR.FAIL) |  | 11.2 |  | V | $V_{C C}=5 \mathrm{~V}$ |
| ICC1 | Current from $\mathrm{V}_{\mathrm{CC}}$ - Selected |  | 30 | 45 | mA | $\mathrm{CS}=\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| IDD1 | Current from $\mathrm{V}_{\mathrm{DD}}$ - Selected |  | 20 | 35 | mA | $\mathrm{CS}=\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{DD}}=5.25 \mathrm{~V}$ |
| IDD2 | Current from $\mathrm{V}_{\mathrm{DD}}$ - Power Down |  | 12 | 19 | mA | $\mathrm{CS}=\mathrm{V}_{\mathrm{IH}}, \mathrm{V}_{\mathrm{DD}}=12.6 \mathrm{~V}$ |

A.C. CHARACTERISTICS $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}+5 \%,-10 \%$;
$V_{D D}=12 \mathrm{~V} \pm 5 \%$; unless otherwise specified)

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions* |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{DON}}$ | Propagation Delay (Turn On) | 50 | 100 | ns |  |
| $\mathrm{t}_{\mathrm{DOFF}}$ | Propagation Delay (Turn Off) | 20 | 50 | ns |  |
| $\mathrm{t}_{\mathrm{r}}$ | Output Current Rise Time |  | 160 | ns | See Test Setup Below |
| $\mathrm{t}_{\mathrm{f}}$ | Output Current Fall Time |  | 20 | ns | See Test Setup Below |
| $\mathrm{t}_{\mathrm{DIS}}$ | $\overline{\mathrm{CS}}$ Disable Time |  | 50 | ns |  |
| $\mathrm{t}_{\mathrm{EN}}$ | $\overline{\mathrm{CS}}$ Enable Time |  | 500 | ns |  |

*Note: $V_{C C}=4.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{DD}}=10.8 \mathrm{~V}$ for all tests.

## WAVEFORMS




Test Setup for Output Current Rise and Fall Time Measurement

## CAPACITANCE*

( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Typ. | Max. | Unit | Test Conditions* |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF |  |

*This parameter is periodically sampled and not $100 \%$ tested. Condition of measurement is $\mathrm{f}=1 \mathrm{MHz}$.

## OUTPUT CURRENTS

$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%\right)$

| Output (V.0ut $=3.0 \mathrm{~V}$ ) | Nominal Values at 50 KHz |  |
| :--- | :---: | :---: |
|  | Current (mA) | Pulse Width ( ss ) |
| REP.A, REP.B CUT | 180 | 0.25 |
| REP.A, REP.B TRANSFER | 140 | 5.0 |
| BOOT.REP CUT | 90 | 0.25 |
| BOOT.REP TRANSFER | 70 | 5.0 |
| GEN.A, GEN.B CUT | 64 | 0.25 |
| GEN.A, GEN.B TRANSFER | 36 | 5.0 |
| SWAP | 120 | 28.75 |
| BOOT.SWAP | 70 | See Note |

Two-level pulses are defined as shown:


Note: Writing data into the bootstrap loop would require 4096 pulses of $20 \mu \mathrm{~s}$ width.

## 7242 <br> DUAL FORMATTER/SENSE AMPLIFIER FOR BUBBLE MEMORIES

## - Error Detection/Correction Done Automatically <br> Dual Channel <br> - On-Chip Sense Amplifiers <br> - Automatically Handles Redundant Loops

## FIFO Data Block Buffer <br> Daisy-Chained Selects for Multiple Bubble Memory Systems <br> MOS N-Channel Technology <br> Standard 20-Pin Dual-In-Line Package

The Intel 7242 is a Dual Formatter/Sense Amplifier (FSA) designed to interface directly with Intel Magnetics Bubble Memories. The 7242 features on-chip sense amplifier for system ease of use and minimization of system part count. The 7242 also provides for automatically handling the bubble memories' redundant loops so they appear transparent to the user. In addition, complete burst error detection and correction can be done automatically by this device.
The 7242 has a full FIFO data block buffer. This device can be daisy-chained for multiple bubble memory systems. Up to eight FSA's can be controlled by one 7220-1 Bubble Memory Controller (BMC).

The 7242 utilizes an advanced NMOS technology to incorporate the on-chip sense amplifiers and other unique features. The device is packaged in a standard high density 20 -pin dual-in-line package.


7242

## LOGIC DIAGRAM



## PIN DESCRIPTION

## CID (Pin 3)

Command/Data signal. This signal shall cause the FSA to enter a receive command mode when high and to interpret the serial data line as data when low. Any previously active command will be immediately terminated by $C / \bar{D}$.

## CLK (Pin 18)

Same TTL level clock used to generate internal timing as used for 7220-1.

## $\overline{\mathbf{C S}}$ (Pin 1)

An active low signal used for multiplexing of FSA's. The FSA is disabled whenever $\overline{\mathrm{CS}}$ is high (i.e., it presents a high impedance to the bus and ignores all bus activity.)

## $\overline{\text { DATA.OUT.A, }} \overline{\text { DATA.OUT.B }}$ (Pins 11 and 12)

Output data from the FIFO to the MBM generate circuitry. Used to write data into the bubble device (active low).

DET.A + , DET.A - , DET.B + , DET.B - (Pins 6, 7, 8, and 9) Differential signal lines from the MBM detector.

## DIO (Pin 17)

The Serial Bus data line (a bidirectional active high signal).

## ENABLE.A, ENABLE.B (Pins 13 and 14)

TTL level outputs utilized as chip selects for other interface circuits. They shall be set and reset by the Command Decoder under instruction of the Controller (active low).

## ERR.FLG (Pin 4)

An error flag used to interrupt the Controller to indicate that an error condition exists. It shall be an open drain active low signal.

## RESET (Pin 16)

An active low signal that shall reset all flags and pointers in the FSA as well as disabling the chip as the CS signal does. The RESET pulse width must be 5 clock periods to assure the FSA is properly reset.

## SELECT.IN (Pin 19)

An input utilized for time division multiplexing. An active low signal whose presence indicates that the FSA is to send or receive data from the Serial Bus during the next two clock periods.

## SELECT.OUT (Pin 2)

The SELECT.IN pulse delayed by two clocks. It shall be connected to the SELECT.IN pin of the next FSA. It is delayed by two clocks because the FSA is a dual channel device. Channel A shall internally pass SELECT.IN to Channel B (delayed by one clock).

## SHIFT.CLK (Pin 15)

A Controller generated clock signal that shall be used to clock data out of the bubble I/O Output Latch to the bubble module during a write operation and to cause bubble signals to be converted by the Sense Amp and clocked into the Bubble I/O Input Latch on a read.

## FUNCTIONAL DESCRIPTION

The following is a brief description of each block of the 7242 FSA.

Serial Communications - The Serial Communications block handles all transfers on the Serial Bus and is shared by both channels of the FSA.
Command Decoder - The Command Decoder interprets commands by the Serial Communication logic and sets the appropriate command and enable lines. It also maintains FSA status, and generates various reset lines.

Internal Data Bus - The Internal Data Bus is the main data link between the Serial Communications block and all other data sources in each half of the FSA.
I/O Latches, Flags, and Bus Control - Each channel of the FSA has its own Internal Data Bus, on which all data transfers are made. There is a Flag and a bidirectional Latch in each "I/O Latches - Flag" block. Only one Latch is used in a given operation and the Flag tells the Bus Controller whether or not the Latch is full. The Bus Controller monitors these flags, and other control signals, to determine. when each device should have access to the Internal Data Bus. When a transfer is to be made, the appropriate devices are enabled, the Bus is enabled, and the transfer takes place synchronously by virtue of a transparent State Machine Sequencer.
FIFO - The FIFO is a variable length First-In-First-Out buffer utilized to store data passing to and from the MBM module. The FIFO is logically 272 bits in length in the "no error correction" mode. It is 270 bits in the "error correction" mode, since 256 bits of data and a 14 bit error correction code must be used in this mode of operation.

The FIFO pointers are reset by hardware or software resets or each time a command to read or write is received by the Command Decoder.
If a block length other than 272 bits is used in the no error correction mode, the FIFO pointers will not return to word zero at the end of each block transfer. This is of no consequence if one is not concerned about the absolute location of data in the FIFO. Keeping in mind that the FIFO is only 272 bits physically, any block length may be used up to and including 320.
Bootstrap Loop Register - The Bootstrap Loop Register is a 160 -bit register that contains information detailing the location of bad loops in the MBM module. This data will enable bubble I/O to ensure that bits are not loaded in the FIFO from bad loops, or written from the FIFO into bad loops. A logic zero (absence of a bubble) is written into bad loops.

Error Correction Logic - The Error Correction Logic contains the circuitry to implement a burst error correcting code capable of correcting any single burst error of length equal to or less than 5, anywhere in the 270-bit data stream, including the error correction code which is 14 bits in length. A Correction Enable bit may be set or reset via a special command. When reset, the entire error correction network is disabled and block length may vary from 270 bits. Error detection shall be accomplished on all data transfers (when enabled); however, correction cannot take place unless the FSA is operated in a buffered mode (i.e., an entire block is read prior to passing any data to the Controller).
Bubble I/O - The Bubble I/O consists of an integrated Sense Amplifier and an output driver. The Sense Amplifier consists of a sample-and-hold circuit and a differential, chopper stabilized comparator.

Enables - The ENABLE.A and ENABLE.B outputs are utilized as chip selects for external circuitry. To set an ENABLE line, the desired channel of the FSA must be selected and a Read or Write MBM, Set Enable Bit, Initialize, Read Corrected Data, or Internally Correct Data command is sent. Any other command sequence will reset the ENABLE lines.

## COMMANDS

## FSA Commands

The FSA shall receive a four-bit command word via the Serial Bus. In addition, some of the commands require additional data bits, e.g., status to be passed serially. The four bits shall be interpreted as shown in Table 1. The effects on the Status bits, Correction Enable bit, and Enable pins are summarized in Table 2.
The following is a brief description of each command available in the 7242 FSA.
No Operation - Deselects the chip and prevents further internal activity (default state for reset, unselected or unaddressed channels). Resets the FIFO and Bootloop pointers. The Enable pins (ENABLE.A and ENABLE.B) become inactive.

Software Reset - Resets all FIFO and Bootloop pointers and flags. Status flags, Error Correction Enable bit, error correction shift register, and the Enable pins become inactive.
Initialize - The chip is set to read data from the MBM Bootloop and pass it to the Controller. Resets the FIFO and Bootloop pointers and the Error Correction Logic, and disables the Bootloop register (so that it does not interfere with the data flow). The Enable pins become active in addressed channels.

Table 1. Command Code Descriptions

| Code | Description | Data |  |
| :---: | :---: | :---: | :---: |
|  |  | Correction Enabled | Not Enabled |
| 0000 | No Operation | None | None |
| 0001 | (Reserved) | - | - |
| 0010 | Software Reset | None | None |
| 0011 | Initialize | MBM Bootloop | MBM Bootloop |
| 0100 | Write MBM Data | 270 Bits In | Variable |
| 0101 | Read MBM Data | 270 Bits Out | Variable |
| 0110 | Internally Correct Data | None | ーー |
| 0111 | Read Corrected Data | 270 Bits Out | - - |
| 1000 | Write Bootloop Register | 160 Bits In | 160 Bits In |
| 1001 | Read Bootloop Register | 160 Bits Out | 160 Bits Out |
| 1010 | (Reserved) | -- | -- |
| 1011 | (Reserved) | - | -- |
| 1100 | Set Enable Bit | None | None |
| 1101 | Read ERR.FLG Status | 1 Bit Out | 1 Bit Out |
| 1110 | Set Correction Enable Bit | None | None |
| 1111 | Read Status Register | 8 Bits Out | 8 Bits Out |

7242

Table 2. Command Function Summary

| Command Description | Command <br> Code | Data Flow <br> (R/W) | Reset FIFO <br> \& Bootloop <br> Pointers | Reset Status <br> (Errors) | Reset Error <br> Correction <br> Logic | Enable |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| No Operation | 0000 | -- | X |  |  | H |
| Software Reset | 0010 | - | X | X | X | H |
| Initialize | 0011 | R | X | X | X | L |
| Write MBM Data | 0100 | W | X |  | X | L |
| Read MBM Data | 0101 | R | X |  | X | L |
| Internally Correct Data | 0110 | - | X |  | L |  |
| Read Corrected Data | 0111 | R | X |  | L |  |
| Write Bootloop Register | 1000 | W | X |  | H |  |
| Read Bootloop Register | 1001 | R | X |  | H |  |
| Set Enable Bit | 1100 | - | X |  |  | L |
| Read ERR.FLG Status | 1101 | R |  |  | H |  |
| Set Error Correction Enable Bit | 1110 | - | X |  | H |  |
| Read Status Register | 1111 | R |  |  | H |  |

Write MBM Data - Data input by the Controller is written into the good loops in use in the MBM (under control of the Bootloop register) each time a SHIFT.CLK is received. It also activates the Enable pins and resets the FIFO and Bootloop pointers. If the Correction Enable bit is set, the FSA computes the correction code and appends it to the data stream to be stored in the MBM (last 14 of 270 bits).

Read MBM Data - This command activates the ENABLE pins and resets the FIFO and Bootloop pointers independent of the state of the Correction Enable bit. If the Correction Enable bit is reset, data from the MBM, of block length dictated by 2 times the number of logic "1s" in the Bootloop register, is sensed and screened by the FSA Sense Amp and Bootloop register, and stored in the FIFO. As soon as one bit is guaranteed in the FIFO, simultaneous reading from the FIFO may be done by the Controller. The FIFO need not be emptied after each page is read, but one must insure that more than 272 bits of FIFO are not needed at any time during the transfer.
If the Correction Enable is set, data must be read in a buffered mode. First, a full block of data is read from the MBM. At that point the FIFO contains 270 bits of data. If an error is detected by the Error Correction network, the FSA raises the UNCORR.ERR and CORR.ERR flags which generate an interrupt to the controller. If no error is detected, the 270 bits of data may be read from the FIFO while simultaneously reading and checking the next block of data from the MBM. When an error is detected the Controller may respond to the interrupt in one of three ways.

1. Ignore it and try again (must make sure to reset the Error Correction shift register before a retry).
2. Send a Read Corrected Data command to the FSA. This command will correct the data stream (if possible) and interrupt the Controller when the block has been read. At this time the Controller can send a

Read Status command to see if the error was correctable (CORR.ERR) or uncorrectable (UNCORR.ERR).
3. Send an Internally Correct Data command to the FSA. The FSA corrects the data without transferring it to the Controller. When finished, the FSA interrupts the Controller. At this point it can be determined whether or not the error is correctable. If so, a Read Corrected Data command may be sent to read the good data.
Internally Correct Data - Internally cycles the data through the error correction network and returns status as to whether or not the data is correctable.
Requires approximately 1400 clock cycles to complete. ERR.FLG will be inactive during internal cycling, but will return active at its completion. Also activates the ENABLE pins and resets the FIFO and Bootloop pointers.
Read Corrected Data - Cycles data through the error correction network with each Controller read (SELECT.IN at the FSA). At the end of 270 reads, status is available to indicate whether or not the data was successfully corrected. ERR.FLG acts as in Internally Correct Data. This command is required to read data corrected internally as well, but has no effect on the data read if it was successfully corrected. Activates the ENABLE pins and resets the FIFO and Bootloop pointers.
Write Bootloop Register - Contents of the FSA's Bootloop register are written with 160 bits from the Controller. The Controller must read the MBM Bootloop first, to determine which loops are good. The number of good bits in the 160 -bit register is 135 if correction is used, and variable up to 160 if operating in the no correction mode. ENABLE pins become inactive and the FIFO and Bootloop pointers are reset.
Read Bootloop Register - As above except that data is read from the FSA Bootloop to the Controller.
Set Enable Bit - ENABLE pins become active for addressed channels, inactive for unaddressed channels. Also resets the FIFO and Bootloop pointers.

Read ERR.FLG Status - Reads the composite error status for addressed channels of the FSA. (The composite status is the logic OR of CORR.ERR, UNCORR.ERR and TIMER.R. The ERR.FLG pin is the logic NOR of both channels' composite error status: ERR.FLG.A and ERR.FLG.B.) ENABLE pins become inactive.
Set Error Correction Enable Bit - Enables the Error Correction Logic in addressed FSAs and disables it in unaddressed FSAs. ENABLE pins become inactive and FIFO and Bootloop pointers are reset. Furthermore, when this enable is set, the corresponding FIFO becomes a 270 -bit FIFO (logically) instead of a 272 -bit FIFO as in the no correction mode.
Read Status Register - The 8-bit Status Word for the addressed FSA is output to the Controller. Only one FSA channel can be addressed at a time, or bus contention may result. ENABLE pins become inactive and error flags in the addressed FSA channel are reset.

## SERIAL INTERFACE

Command Sequence - The FSA communicates with the Controller via a Serial Interface. The Controller/FSA Interface contains the following signals:

1. CLK
2. SELECT.IN (Formatter)
3. SELECT.OUT (Formatter)
4. $\overline{\text { SYNC }}$ (Controller)
5. DIO
6. $\mathrm{C} / \overline{\mathrm{D}}$
7. SHIFT.CLK
8. ERR.FLG

Commands from the Controller to the FSA shail take place in the following format (see Figure 1).

1. Controller raises $C / \bar{D}$ flag indicating that a command is coming, and simultaneously outputs a SYNC pulse. This SYNC pulse is shifted down the FSA chain in shift register fashion via the FSA SELECT.IN/ SELECT.OUT lines.
2. Controller outputs a serial data stream on the DIO line beginning in the clock period following SYNC. Each bit in the stream corresponds to an address bit for a particular FSA (up to 16 channels). Each FSA, upon receiving SELECT.IN, will look for the presence or absence of a logic one on DIO in the clock period following receipt of SELECT.IN. (A logic one indicates that the FSA shall accept the command.)
3. Twenty clock periods after the first $\overline{\text { SYNC, }}$, the Controller sends C/D low followed by a four-bit command on the DIO line.
4. If the command is a Read Status command (1111), the addressed FSA returns 8 bits of Status starting 4 clock periods after the last command bit is received. Note that the Status is returned during this period for any FSA position. Therefore only one FSA channel should be addressed at a time to avoid contention.
5. If the command requires further data (see section on FSA Commands), more $\overline{\text { SYNC }}$ pulses are sent by the Controller. This will occur at integral multiples of 80 or 20 clock periods starting no sooner than 40 clocks after the first command SYNC pulse. Some number of $\overline{\text { SYNC }}$ periods may pass before the second SYNC to allow the FSA to set itself up and get data ready for the Controller. There are several possibilities:
a. For the Read ERR.FLG Status command the second SYNC can occur 40 clocks after the first SYNC. This SYNC (or SELECT.IN) causes each addressed FSA to send the appropriate Status information. No further SYNCS (without C/Ī high) should be sent.


Figure 1. Command Sequences
b. For the Read MBM Data (or Initialize) command the second SYNC must wait the appropriate number of SHIFT.CLOCKs to assure that valid data is available in the FIFO.

After this wait, each addressed FSA channel sends one bit of data on the DIO line for each SYNC (or SELECT.IN) pulse.
c. For the Read Bootloop Register command, the second SYNC can occur 60 clock cycles after the first SYNC. The data transfer then proceeds as in b. above.
d. For the Write MBM Data or Write Bootloop commands, the DIO line is used to transfer data to the FSA on successive SYNC pulses. The first data bit can be transferred by a second SYNC pulse, 40 clock cycles after the first SYNC. (However, data to the MBM will not be available at the Dataout pins until 40 clock cycles after the SYNC which transferred it.) Each transfer to the addressed FSA will be initiated by a SYNC (or SELECT.IN).
6. SYNC ( $\overline{\text { SELECT.IN }}$ ) precedes the data it transfers by 1 clock cycle. Data Transfers to or from the FSA's FIFO must contain the proper number of SYNCs (externally counted) or a timing error may occur (TIMERR flag will be set, causing an interrupt to the Controller).
Data Sequences - Bubble data shall be passed between the Controller and FSAs in the following fashion (see Figure 2).

1. Controller outputs a $\overline{\text { SYNC }}$ pulse.
2. Each FSA then outputs (inputs) a single bit on DIO after SYNC (SELECT.IN) has been clocked into its control section. Only previously enabled FSAs output (input) data and the Controller must know when to input (output) data bits.
3. After 80 or 20 clocks, another $\overline{\text { SYNC }}$ pulse is output and the sequence repeats untill all data has been transferred.
Error Conditions - Each FSA shall upon detection of an error set a Status bit and pull down ERR.FLG. This signal can be asynchronous to SYNC. Error Status bits shall be:
4. Correctable Error
5. Uncorrectable Error
6. Timing Error

The Status Word that shall be passed to the Controller after receipt of a Read Status command shall be in the following format:


NOTE: ERROR FLAGS SHALL BE RESET UPON
BEING READ BY THE CONTROLLER OR BY A
SOFTWARE RESET OR INITIALIZE.


Figure 2. Data Sequences

## BUBBLE INTERFACE

Bubble Interface - Each Bubble Interface shall consist of a DATAOUT signal and a pair of differential inputs from the MBM detector bridge.
Read Timing - The timing for reading a bit from the memory shall be as follows:

1. Controller outputs a SHIFT.CLK. FSA samples bubble signal during SHIFT.CLK and holds signal after trailing edge.
2. Trailing edge of SHIFT.CLK initiates signal conversion timing.
3. Data is latched at end of conversion period in the Bubble Input latch, and will subsequently be loaded into the FIFO.
Write Timing - The timing for writing a bit from the FIFO shall be as follows:
4. Controller lowers SHIFT.CLK.
5. Data is gated out of FSA by SHIFT.CLK.
6. Controller outputs a generate pulse (to external logic; not to FSA).
7. Controller raises SHIFT.CLK. The DATA.OUT pin is forced high.
8. FIFO and Bootloop register are incremented after the leading edge of SHIFT.CLK.
System Timing - The $\overline{\text { SYNC }}$ pulse (which denotes the beginning of a data transfer from Controller to Formatter or vice-versa) shall be synchronous with the beginning of a bubble memory field rotation. Due to timing constraints in the FSA, the following statements hold:
9. Data read from the bubble memory into the FSA shall not be available to the Controller until 40 clock cycles after SHIFT.CLK.
10. Data cannot be written to the bubble memory until 40 clock cycles afer SYNC.

## FSA ERROR CORRECTION

Error Correction - The error correction logic consists of a burst error correcting Fire code capable of correcting 5 or fewer bits in a single burst; the number of check bits is 14.* Error correction/detection shall take place on each 256 -bit data block. The FSA shall set low ERR.FLG each time a correctable or uncorrectable error is detected. ERR.FLG shall be set high upon being read by the Controller or by a software reset being issued. The polynomial implemented is given below:

$$
G(X)=1+X^{2}+X^{5}+X^{9}+X^{11}+X^{14}
$$

## DATA FORMAT

Data Format-Data into a single FSA channel from the bubble memory shall be in the format described below. The two channels of the bubble are represented identically. The following definitions apply:

$$
o_{\eta}=\text { data from odd half of bubble device, loop } \eta
$$

$e_{\eta}=$ data from even half of bubble device, loop $\eta$

$$
\begin{aligned}
& \text { Data Block Format - } \\
& \text { 1st bit } O_{1} e_{1} O_{1} e_{1} O_{2} e_{2} \mathrm{O}_{2} e_{2} \ldots o_{80} e_{80} \mathrm{O}_{80} e_{80}
\end{aligned}
$$

320th bit
When using correction, the first $\mathbf{2 7 0}$ good bits will be used; the last 14 of these are to be used for the error correcting code. The remaining 50 bits must be masked as "bad" bits in the FSA Bootloop register.
When operating without correction, any number of bits may be used by loading the Bootloop register appropriately. The preferred number is 272 bits, however.

[^9]
## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Blas . . . . . . . . . . . . $-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 and
Vcc Supply Voltage . . . . . . . . . . . . . . . . . -0.5 V to +7 V
$V_{\text {DD }}$ Supply Voltage . . . . . . . . . . . . . . . . . . -0.5 V to +14 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}}=5.0 \mathrm{~V}+5 \%,-10 \% ; \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{V}_{\text {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 |  |
| VoL | Output Low Voltage (All Outputs Except SELECT.OUT) |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |
| Volso | Output Low Voltage (SELECT.OUT) |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OH }}$ | Output High Voltage (All Outputs Except SELECT.OUT) | 2.4 |  |  | V | $\mathrm{IOH}=400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {OHSO }}$ | Output High Voltage (SELECT.OUT) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {THR }}$ | Detector Threshold | 2.0 |  | 3.0 | mV | $\mathrm{V}_{\mathrm{DD}}=12.0 \mathrm{~V}$ |
| HILI | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $0 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| \|lofu | Output Float Leakage |  |  | 10 | $\mu \mathrm{A}$ | $0.45 \leqslant V_{\text {OUT }} \leqslant V_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current from VCC |  |  | 120 | mA |  |
| $I_{\text {DD }}$ | Power Supply Current from V $\mathrm{VD}^{\text {d }}$ |  |  | 30 | mA |  |

## A.C. CHARACTERISTICS $\quad T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{Cc}}=5.0 \mathrm{~V}+5 \%,-10 \%$;

$V_{D D}=12 \mathrm{~V} \pm 5 \% ; \mathrm{C}_{\mathrm{L}}=120 \mathrm{pF}$; unless otherwise noted)

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{p}}$ | Clock Period | 240 | 500 | ns |  |
| $t_{\phi}$ | Clock Phase Width | $0.4 \mathrm{t}_{\mathrm{p}}$ | $0.6 \mathrm{t}_{\mathrm{p}}$ |  |  |
| $t_{r}, t_{f}$ | Clock Rise and Fall Time |  | 30 | ns |  |
| $\mathrm{t}_{\text {sic }}$ | SELECT.IN Setup Time to CLK | 50 |  | ns |  |
| $\mathrm{t}_{\mathrm{CDC}}$ | C/D Setup Time to CLK | 50 |  | ns |  |
| $\mathrm{t}_{\mathrm{CYC}}$ | SELECT.IN or SHIFT.CLK Cycle Time | $20 \mathrm{t}_{\mathrm{p}}$ |  |  |  |
| $t_{\text {dC }}$ | DIO Setup Time to Clock (Read Mode) | 50 |  | ns |  |
| $\mathrm{t}_{\mathrm{csc}}$ | $\overline{\text { CS }}$ Setup Time to CLK | 100 |  | ns |  |
| $t_{\text {RIC }}$ | RESET.IN Setup Time to CLK | 100 |  | ns |  |
| $\mathrm{t}_{1+}$ | Control Input Hold Time for C/D, SELECT.IN and DIO | 20 |  | ns |  |
| ${ }^{\text {t }}$ SOL | CLK to SELECT.OUT Leading Edge Delay |  | 100 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $\mathrm{t}_{\text {csot }}$ | CLK to SELECT.OUT Trailing Edge Delay |  | 100 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $\mathrm{t}_{\text {cov }}$ | CLK to DIO Valid Delay* |  | 100 | ns |  |
| ${ }_{\text {t }}$ | CLK to DIO Hold Time* | 0 |  | ns |  |
| $\mathrm{t}_{\text {CDE }}$ | CLK to DIO Enabled from Float* |  | 100 | ns |  |
| ${ }^{\text {t }}$ IIDE | SELECT.IN Trailing Edge to DIO Enabled from Float* |  | 70 | ns |  |
| $\mathrm{t}_{\text {CDF }}$ | CLK to DIO Entering Float* |  | 100 | ns |  |
| $\mathrm{t}_{\text {SCDO }}$ | SHIFT.CLK to DATAOUT Delay* |  | 200 | ns |  |
| ${ }^{\text {tscwr }}$ | $\overline{\text { SHIFT.CLK }}$ Width (Read) | $4 t_{p}$ | $\begin{array}{\|c} \hline \mathrm{t}_{\mathrm{cryc}} \\ 11 \mathrm{t}_{\mathrm{p}} \end{array}$ |  |  |
| ${ }_{\text {tscww }}$ | SHIFT.CLK Width (Write) | $t_{p}$ | $\begin{gathered} \mathrm{t}_{\mathrm{Crc}}- \\ 2 \mathrm{t}_{\mathrm{p}} \end{gathered}$ |  |  |

## CAPACITANCE

( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}$ )

| Symbol | Parameter | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $C_{\text {IN }}$ | Input Capacitance |  | 10 | pF |  |
| $C_{\text {OUT }}$ | Output Capacitance |  | 10 | pF |  |
| $\mathrm{C}_{\text {DIO }}$ | DIO Capacitance |  | 10 | pF |  |

*DIO Write Mode.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



DIO INTERFACE TIMING


BUBBLE DATA INTERFACE TIMING


## 7250 <br> COIL PRE-DRIVER FOR BUBBLE MEMORIES

## Very Low Power

## Power Fail Reset for Maximum Protection of Bubble Memory

- TTL Compatible Inputs
- Only One Power Supply Required, $+12 \mathrm{~V}$
- CMOS Technology
- Standard 16-Pin Dual In-Line Package

The Intel 7250 is a low power Coil Pre-Driver (CPD) for use with Intel Magnetics Bubble Memories. The 7250 is controlled by the Intel 7220-1 Bubble Memory Controller (BMC) and directly drives either Quad VMOS transistor packs or Quad Bipolar transistor packs which are connected to the coils of the bubble memory.
The 7250 is a high voltage, high current driver constructed using CMOS technology. The device has TTL compatible inputs and the outputs are designed to drive either low on-resistance VMOS transistors or bipolar transistors.

The 7250 is in a standard 16 -pin dual in-line package.


## ABSOLUTE MAXIMUM RATINGS*

|  |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |

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

## D.C. AND OPERATING CHARACTERISTICS

( $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V}+5 \%,-10 \%$; unless otherwise specified)

| Symbol | Parameter | Limits |  |  |  | Test Conditions |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |

## A.C. CHARACTERISTICS

( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=12 \mathrm{~V} \pm 5 \%$, unless otherwise specified)

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $t_{\mathrm{p} 1}$ | Propagation Delay from $\overline{X+. I N}$, <br> $\overline{X-. I N}, \overline{Y+. I N}, \overline{Y-. I N}$ |  |  | 100 | ns | 500 pF Load |
| $\mathrm{t}_{\mathrm{p} 2}$ | Propagation Delay from $\overline{\mathrm{CS}}$ or <br> RESET |  |  | 150 | ns | 500 pF Load |
| $\mathrm{t}_{\mathrm{r}}$ | Rise Time (10\% to $90 \%)$ |  |  | 45 | ns | 500 pF Load |
| $\mathrm{t}_{\mathrm{F}}$ | Fall Time (90\% to 10\%) |  |  | 45 | ns | 500 pF Load |
| $\mathrm{t}_{\mathrm{S}}$ | Skew Between an Output and <br> its Complement |  |  | 20 | ns |  |

## A.C. TEST CONDITIONS



CAPACITANCE* $\quad\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BI}}{ }^{2}=2 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF |  |

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

## PIN DESCRIPTION

## $\overline{\mathrm{CS}}$ (Pin 1)

Chip select. It is active low. When high chip is deselected and $I_{D D}$ is significantly reduced.

## $\overline{\text { RESET }}$ (Pin 2)

Active low Input from RESET.OUT of 7220-1 Controller forces 7250 outputs inactive so that bubble memory is protected in the event of power supply failure.

## $\overline{X+I N}, \overline{X-I N}$ (Pins 3, 4)

Active low inputs from controller which turn on the high current $X$ outputs.

X - .OUT, $\overline{X-. O U T}, \overline{X+. O U T}, X+$. OUT (Pins 12-15)
High current outputs and their complements for driving the gates of the 7254 VMOS quad transistors which in turn drive the X coils of the bubble memory.
$\overline{Y+. I N}, \overline{Y-. I N}$ (Pins 5, 6)
Active low inputs from controller which turn on the high current Y outputs.
 High current outputs and their complements for driving the gates of the 7254 VMOS quad transistors which in turn drive the Y coils of the bubble memory.

## LOGIC DIAGRAM



## 7254 <br> QUAD VMOS DRIVE TRANSISTORS FOR BUBBLE MEMORIES

- Designed to Drive $X$ and $Y$ Coils of
7110 Bubble Memories
- No Bias Currents Required
- Fast Turn-on and Turn-off: 30 ns Maximum


## - Built-in Diode Commutates Coil

 Current When Transistor is Turned Off- Operates from VDD Only

■ VMOS FET Technology

- N-Channel and P-Channel Transistors in the Same Package

■ Standard 14-Pin Dual-In-Line Package

The 7254 is a quad transistor pack designed to drive the $X$ and $Y$ coils of Intel Magnetics Bubble Memories. Two 7254 packages are required for each bubble memory device. Each 7254 package would drive either the $X$ or $Y$ coil as shown under "circuit diagram." This recommended connection circuit takes into account the fact the Q1/Q2 and Q3/Q4 are tested as a pair for "On" resistance value to assure optimal bubble performance.

PIN CONFIGURATION
BLOCK DIAGRAM


Block Diagram of Single Bubble Memory System - 128K Bytes

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . $-30^{\circ}$ to $+85^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-40^{\circ}$ to $+150^{\circ} \mathrm{C}$
DGate Voltage (with respect to
Source and Drain) . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15V
Continuous Drain Current . . . . . . . . . . . . . . . . . . . . . . . 2A
Peak Drain Current . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3A
Power Dissipation ( $\mathrm{T}_{\mathrm{A}}=80^{\circ} \mathrm{C}$ ) . . . . . . . . . . . . . . . . . . 1.05W
Power Dissipation $\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$. . . . . . . . . . . . . . . . . 1.75 W
*COMMENT: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS

All Limits Apply for N - and P-Channel transistors, $\mathrm{T}_{\mathrm{A}}=-30^{\circ}$ to $85^{\circ} \mathrm{C}$ unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $B V_{\text {DSS }}$ | Drain-Source Breakdown Voltage | 20 |  |  | V | $V_{G S}=0, I_{D}=10 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {GS }}(\mathrm{th})$ | Gate-Source Threshold Voltage | 0.8 |  |  | V | $\mathrm{V}_{\mathrm{GS}}=\mathrm{V}_{\mathrm{DS}} \overline{l_{D}} \mathrm{I}=1 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
|  |  | 0.65 |  |  | V | $V_{G S}=V_{D S}, I_{D}=1 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=85^{\circ} \mathrm{C}$ |
| IGSS | Gate Leakage Current |  |  | 10 | $\eta \mathrm{A}$ | $\mathrm{V}_{\mathrm{GS}}=12 \mathrm{~V}, \mathrm{~V}_{\mathrm{DS}}=0, \mathrm{~T}_{\mathrm{A}}=85^{\circ} \mathrm{C}$ |
| IDSs | Drain Leakage Current |  |  | 500 | ${ }_{\eta} \mathrm{A}$ | $V_{G S}=0, V_{D S}=20 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=85^{\circ} \mathrm{C}$ |
| $R_{\text {DS }}$ | On-Resistance for sum of Q1+Q2, Q3+Q4 (Note 1) | 2.0 | 2.5 | 3.0 | $\Omega$ | $V_{G S}=11.4 \mathrm{~V}, 1_{D}=1 \mathrm{~A}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{F} 1}$ | Parasitic Diode Forward Voltage (Note 1) |  |  | . 75 | V | $\mathrm{V}_{\mathrm{GS}}=0 \mathrm{~V}, \mathrm{I}_{\mathrm{D}}=50 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{F}} \mathbf{2}$ | Parasitic Diode Forward Voltage (Note 1) |  |  | 1.20 | V | $\mathrm{V}_{\mathrm{GS}}=0 \mathrm{~V}, \mathrm{I}_{\mathrm{D}}=1000 \mathrm{~mA}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

Note: 1. Pulse test $-80 \mu \mathrm{~s}$ pulse, $1 \%$ duty cycle, ros increase $0.6 \% /{ }^{\circ} \mathrm{C}$.
A.C. CHARACTERISTICS
$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{ON}}(\mathrm{N})$ | N-Channel Turn-On Time |  |  | 30 | ns | See Switching Time Test Circuit and Waveforms below |
| $\mathrm{t}_{\text {ON }}(\mathrm{P})$ | P-Channel Turn-On Time |  |  | 30 | ns |  |
| $\mathrm{t}_{\text {OFF }}(\mathrm{N})$ | N-Channel Turn-Off Time |  |  | 30 | ns |  |
| $\mathrm{t}_{\text {OFF }}(\mathrm{P})$ | P-Channel Turn-Off Time |  |  | 30 | ns |  |

SWITCHING TIME TEST CIRCUIT



## Capacitance

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {iss }}(\mathrm{N})$ | N -Channel Input Capacitance |  |  | 175 | pF | $\mathrm{V}_{\mathrm{GS}}=0, \mathrm{~V}_{\mathrm{DS}}=12 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{iss}}(\mathrm{P})$ | P-Channel Input Capacitance |  |  | 190 | pF | $\mathrm{V}_{\mathrm{GS}}=0, \mathrm{~V}_{\mathrm{DS}}=12 \mathrm{~V}, \mathrm{f}=1 \mathrm{MHz}$ |

## CIRCUIT DIAGRAM



## PACKAGING INFORMATION




DIMENSIONS IN INCHES AND (MILLIMETERS)

# Telephony and Signal Processing 

# 2910A <br> PCM CODEC - $\mu$ LAW <br> 8-BIT COMPANDED AID AND DIA CONVERTER 

| 2910A | Microcomputer* Mode <br> or Direct Mode |
| :---: | :--- |
| 2910A-4 | Direct Mode Only |

- Per Channel, Single Chip Codec
- CCITT G711 and G712 Compatible, ATT T1 Compatible with 8th Bit Signaling
- Microcomputer Interface with On-Chip Timeslot Computation (2910A)
- Simple Direct Mode Interface When Fixed Timeslots are Used
- 78 dB Dynamic Range, with Resolution Equivalent to 12-Bit Linear Conversion Around Zero
- $\pm 5 \%$ Power Supplies: +12V, +5V, -5V
- Precision On-Chip Voltage Reference
- Low Power Consumption 230 mW Typ. Standby Power 33 mW Typ.


## - Fabricated with Reliable N-Channel MOS Process

The Intel ${ }^{\otimes}$ 2910A 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 and provide in-band signaling.
The primary applications are in telephone systems:

- Transmission - T1 Carrier
- Switching - Digital PBX's and Central Office Switching Systems
- Concentration - Subscriber Carrier/Concentrators

The wide dynamic range of the $2910 \mathrm{~A}(78 \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
*Microcomputer mode is explained on page 4.


## PIN CONFIGURATION

BLOCK DIAGRAM


PIN NAMES

| CAP 1 ${ }^{\text {, CAP }} \mathrm{2}_{\mathrm{x}}$ | Holding Capacitor |
| :---: | :---: |
| $V F_{X}$ | Analog input |
| $V F_{R}$ | Analog Output |
| $\mathrm{D}_{\mathrm{R}}, \mathrm{D}_{\mathrm{C}}, \mathrm{SIG}_{\mathrm{X}}$ | Digital Input |
| $\mathrm{SIG}_{\mathrm{R}}, \mathrm{D}_{\mathrm{x}},{ }^{\text {TS }}$ ¢ | Digital Output |
|  | Clock Input |
| $\mathrm{FS}_{\mathrm{X}}, \mathrm{FS}_{\mathrm{R}}$ | Frame Sync Input |
| AUTO | Auto Zero Output |
| $V_{\text {BB }}$ | Power (-5V) |
| $V_{\text {cc }}$ | Power ( +5 V ) |
| $V_{\text {DD }}$ | Power ( +12 V ) |
| PDN | Power Down |
| GRDA | Analog Ground |
| GRDD | Digital Ground |
| NC | No Connect |



## PIN DESCRIPTION

| Pin No. | Symbol | Function | Description |
| :---: | :---: | :---: | :---: |
| 1 | CAP1 X | Hold | Connections for the transmit holding capacitor. Refer to Applications section. |
| 2 | CAP2 ${ }^{\text {x }}$ |  |  |
| 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 $\mathrm{FS}_{\mathbf{x}}$, 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 (+5V for negative, -5 V for positive inputs). 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 | $\mathrm{SIG}_{\mathrm{R}}$ | Output | Signaling output $S I G_{R}$ is updated with the 8th bit of the receive PCM word on signaling frames, and is latched between two signaling frames. TTL interface. |
| 7 | $V_{D D}$ | Power | $+12 \mathrm{~V} \pm 5 \%$; referenced to GRDA. |
| 8 | $\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{R}}, \mathrm{D}_{\mathrm{C}}$, and $\mathrm{CLK}_{\mathrm{C}}$. |
| 9 | PDN | Output | Active high when Codec is in the power down state. TTL interface. Open drain output. |
| 10 | $\mathrm{VF}_{\mathrm{R}}$ | Output | Analog output. The voltage present on $\mathrm{VF}_{\mathrm{R}}$ is the decoded value of the PCM word received on lead $D_{R}$. This value is held constant between two conversions. |
| 11 | NC | No Connects | Recommended practice is to strap these NC's to GRDA. |
| 12 | NC |  |  |
| 13 | GRDD | Ground | Ground return common to the logic power supply, $\mathrm{V}_{\mathrm{Cc}}$. |
| 14 | $\mathrm{D}_{\mathrm{X}}$ | Output | Output of the transmit side onto the send PCM highway (serial bus). The 8-bit PCM word is serially sent out on this pin at the proper time defined by $\mathrm{FS}_{\mathrm{X}}$, $\mathrm{CLK}_{\mathrm{X}}, \mathrm{D}_{\mathrm{C}}$, and CLK $\mathrm{C}_{\mathrm{C}}$. TTL threestate output. |


| Pin No. | Symbol | Function | Description |
| :---: | :---: | :---: | :---: |
| 15 | $\mathrm{TS}_{\mathbf{x}}$ | Output | Normally high, this signal goes low while the Codec is transmitting an 8-bit PCM word on the Dx lead. (Timeslot information used for diagnostic purposes and also to gate the data on the Dx lead.) TTL interface, open drain output. |
| 16 | $\mathrm{V}_{\text {cc }}$ | Power | $+5 \mathrm{~V} \pm 5 \%$, referenced to GRDD. |
| 17 | $\mathrm{CLK}_{\mathrm{R}}$ | Input | Master receive clock defining the bit rate on the receive PCM highway. Typically 1.544 Mbps for a T1 carrier system. Maximum rate 2.1 Mbps . $50 \%$ duty cycle. TTL interface. |
| 18 | $\mathrm{FS}_{\mathrm{R}}$ | Input | Frame synchronization pulse for the receive PCM highway. Resets the on-chip timeslot counter 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. |
| 19 | $\mathrm{CLK}_{\mathrm{X}}$ | Input | Master transmit clock defining the bit rate on the transmit PCM highway. Typically 1.544 Mbps for a T1 carrier system. Maximum rate 2.1 Mbps . $50 \%$ duty cycle. TTL interface. |
| 20 | FSX | Input | Frame synchronization pulse for the transmit PCM highway. Resets the on-chip timeslot counter for the transmit side. Maximum repetition rate 12 KHz . Also used to differentiate between non-signaling frames on the transmit side. |
| 21 | $\mathrm{SIG}_{\mathrm{X}}$ | Input | Signaling input. This digital input is transmitted as the 8th bit of the PCM word on the Dx lead, on signaling frames. TTL interface. |
| 22 | $\mathrm{V}_{\mathrm{BB}}$ | Power | $-5 \mathrm{~V} \pm 5 \%$, referenced to GRDA. |
| 23 | $\mathrm{D}_{\mathrm{C}}$ | Input | Data input to program the Codec for the chosen mode of operation. Becomes an active low chip select when CLK ${ }_{C}$ is tied to $\mathrm{V}_{\mathrm{CC}}$. TTL interface. |
| 24 | $\mathrm{CLK}_{\mathrm{C}}$ | Input | Clock input to clock in the data on the $\mathrm{D}_{\mathrm{C}}$ lead when the timeslot assignment feature is used; tie to $V_{C C}$ to disable this feature. TTL interface. |

## FUNCTIONAL DESCRIPTION

The 2910A 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 ( $\mathrm{FS}_{\mathrm{X}}$ ) into an 8 -bit PCM word which is sent out on the $D_{x}$ lead at the proper time. Similarly, the Codec fetches an 8-bit PCM word from the receive highway ( $\mathrm{D}_{\mathrm{R}}$ lead) and decodes an analog value which will remain constant on lead $\mathrm{VF}_{\mathrm{R}}$ until the next receive frame. Transmit and receive frames are independent. They can be asynchronous (transmission) or synchronous (switching) with each other.
For channel associated signaling, the Codec transmit side will encode the incoming analog signal as previously described and substitute the signal present on lead SIG $_{x}$ 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 $\mathrm{SIG}_{\mathrm{R}}$ lead until the next signaling frame. Signaling frames on the send and receive sides are independent of each other, and are selected by a double-width frame sync pulse on the appropriate channel.


## Functional Block Diagram of Line CIrcuit

The 2910A 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 prerecorded announcements, can be sent through the voice-path; digital 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 timeslots. In small systems this may eliminate the need for any external timeslot exchange; in large systems it provides one level of concentration. This feature can be bypassed and discrete timeslots sent to each Codec within a system.
In the power-down mode, most functions of the Codec are directly disabled to reduce power dissipation to a minimum.

## CODEC OPERATION Codec Control

The operation of the 2910A is defined by serially loading an 8-bit word through the $\mathrm{D}_{\mathrm{C}}$ lead (data) and the CLK $_{\mathrm{C}}$ lead (clock). The loading is asynchronous with the other operations of the Codec, and takes place whenever transitions occur on the CLK $C$ lead. The $D_{C}$ input is loaded in during the trailing edge of the $\mathrm{CLK}_{\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, powerdown mode (11). In the last case (11), the following 6 bits are irrelevant.

The last 6 bits of the control word define the timeslot assignment, from 000000 (timeslot 1) to 111111 (timeslot 64). Bit 3 is the most significant bit and bit 8 the least significant bit and last into the Codec.

| Blt 1 | Bit 2 | Mode |
| :---: | :---: | :---: |
| 0 | 0 | $\mathrm{X} \& \mathrm{R}$ |
| 0 | 1 | X |
| 1 | 0 | R |
| 1 | 1 | Standby |


| Bit |  |  |  |  |  | Timeslot |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | 4 | 5 | 6 | 7 | 8 |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 | 1 | 2 |
|  |  |  |  |  |  | $\bullet$ |
|  |  |  |  |  |  | $\bullet$ |
|  |  |  |  |  |  | $\bullet$ |
| 1 | 1 | 1 | 1 | 1 | 1 | 64 |

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 timeslots for switching applications.

## Microcomputer Control Mode (2910A)

In the microcomputer mode, each Codec performs its own timeslot computation independently for the transmit and receive channels by counting clock pulses (CLK $K_{X}$ and CLKK ). All Codecs tied to the same data bus receive identical framing pulses ( $F S_{X}$ and $\mathrm{FS}_{\mathrm{R}}$ ). The framing pulses reset the on-chip timeslot counters every frame; hence the timeslot counters of all devices are synchronized. Each Codec is programmed via CLK $C_{C}$ and $\mathrm{D}_{\mathrm{C}}$ for the desired transmit and receive timeslots according to the description in the Codec Control Section. All Codecs tied to the same $D_{R}$ bus will, in general, have different receive timeslots, although that is not a device requirement. There may be separate busses for transmit and receive or all Codecs may transmit and receive over the same bus, in which case the transmit and receive channels must be synchronous (CLK $X_{X}=$ CLK $_{\mathrm{R}}$.) There are no other restrictions on timeslot 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 $C L K_{C}-D_{C}$ interface in the microcomputer mode.

1. A complete timeslot assignment, consisting of eight negative transitions of $C L K_{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). CLK ${ }_{C}$ must be left at a TTL low level when not assigning a timeslot.
2. A dead period of two frames must always be observed between successive timeslot assignments. The two frame delay is measured from the rising edge of the first CLK $_{C}$ transition of the previous timeslot assigned.
3. When the device is in the power-down state a single control word will suffice to power-up the Codec and make a timeslot assignment. That is, the first assignment brings the device out of power-down and registers the timeslot information in the lower six bits of the control word.
4. Initialization sequence: The device contains an onchip power-on clear function which guarantees that with proper sequencing of the supplies ( $V_{C C}$ or $V_{D D}$ on last), the device will initialize with no timeslot assigned to either the transmit or receive channel. After a supply failure or whenever the supplies are applied, it is recommended that either power down assignment be made first, or the first timeslot assignment be a transmit timeslot or a transmit/receive timeslot. The consequence of making a receive timeslot assignment first, after supply application, is that the transmit channel will assume timeslot 1, potentially producing bus contention.
5. Transmit only/receive only operation is permitted provided that a power down assignment is made first. Otherwise, special circuits which use only one channel should be physically disconnected from the unused bus; this allows a timeslot to be made to an unused channel without consequence.

## Example of Microcomputer Control Mode:

The two words 01000001 and 10000010 have been loaded into the Codec. The transmit side is now programmed for timeslot 2 and the receive side for timeslot 3. The Codec will output a PCM word on the transmit PCM highway (bus) during the timeslot 2 of the transmit frame, and will fetch a PCM word from the receive PCM highway during timeslot 3.


In this example the Codec interface to the PCM highway then functions as shown below. ( $\mathrm{FS} \mathrm{S}_{\mathrm{X}}$ and $\mathrm{FS}_{\mathrm{R}}$ may be asynchronous.)


## Direct Control Mode

The direct mode of operation will be selected when the CLK ${ }_{C}$ pin is strapped to the +5 volt supply ( $\mathrm{V}_{\mathrm{CC}}$ ). In this mode, the $D_{C}$ pin is an active low chip select. In other words, when $D_{C}$ is low, the device transmits and receives in the timeslots which follow the appropriate framing pulses. With $\mathrm{D}_{\mathrm{C}}$ high the device is in the power down state. Even though $\mathrm{CLK}_{\mathrm{C}}$ characteristics are simpler for the 2910A it will operate properly when plugged into a 2910 board.
Deactivation of a channel by removal of the appropriate framing pulse ( $\mathrm{FS}_{\mathrm{X}}$ or $\mathrm{FS}_{\mathrm{R}}$ ) is generally not permitted. Specifically, framing pulses must be applied for a
minimum of two frames after a change in state of $D_{C}$ in order for the $D_{C}$ change to be internally sensed. In particular, when entering standby in the direct mode, framing pulses must be applied as usual for two frames after $D_{C}$ is brought high. Thereafter, the framing pulses could, if desired, be removed until such time as the device is to be reactivated by the reapplication of framing pulses with $D_{C}$ low.
The Codec will enter the direct mode within three frame times $(375 \mu \mathrm{sec})$ as measured from the time the device power supplies settle to within the specified limits. This assumes that CLK ${ }_{C}$ is tied to $V_{C C}$ and that all clocks are available at the time the supplies have settled.

## General Control Requirements

All bit and frame clocks should be applied whenever the device is active. In particular, an unused channel cannot be deactivated by removal of its associated frame or bit clock while the other channel of the same device remains active.

A single channel cannot be deactivated except by physical disconnection of the data lead ( $D_{x}$ or $D_{R}$ ) from the system data bus. A device (both transmit and receive channels) may be deactivated 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 timeslot. The PCM word is then output on the $D_{\mathrm{x}}$ lead at the proper timeslot occurrence 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 $D_{R}$ lead from the PCM highway at the proper timeslot occurrence: The decoded value is held on an internal sample and hold capacitor.

The buffered non-return to zero output signal on the $\mathrm{VF}_{\mathrm{R}}$ lead has a dynamic range of approximately $\pm 2.2$ volts RMS ( $\pm 3.1$ volts peak).

## Signaling

The duration of the $\mathrm{FS}_{\mathrm{X}}$ and $\mathrm{FS}_{\mathrm{R}}$ 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 (CLK $X$ period for $\mathrm{FS}_{\mathrm{x}}, \mathrm{CLK}_{\mathrm{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 CLK ${ }_{X}$ periods for FS $_{X}$, two $C L K_{R}$ periods for $F S_{R}$ ) designates a signaling frame.
On the encoding side, when the $\mathrm{FS}_{\mathrm{X}}$ pulse is widened, the 8th bit of the PCM word will be replaced by the value on the SIG input at the time when the 8th bit is output on the $D_{X}$ lead.


On the decoding side, when the $\mathrm{FS}_{\mathrm{R}}$ pulse is widened, the 8th bit of the PCM word is detected and transmitted on the SIG $_{R}$ 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 SIG $_{\mathrm{R}}$ lead is reset to a TTL low level whenever the Codec is in the power-down state.


## T1 Framing

The Codec will accept the standard D3/D4 framing format of 193 clock pulses per frame (equivalent to

CLK $_{X}$, CLK $_{R}$ of $1.544 \mathrm{Mb} / \mathrm{sec}$ ). However, the 193 rd bit may be blanked (equivalent to CLK $\mathrm{X}, \mathrm{CLK}_{\mathrm{R}}$ of $1.536 \mathrm{Mb} / \mathrm{sec}$ ) if desired.

## Standby Mode - Power Down

To minimize power consumption and heat dissipation a standby mode is provided where all Codec functions are disabled except for $\mathrm{D}_{\mathrm{C}}$ and $C L K_{\mathrm{C}}$ leads. These allow the Codec to be reactivated. In the microcomputer mode the Codec is placed into standby by loading a control word $\left(D_{C}\right)$ with a " 1 " in bits 1 and 2 locations. In the direct mode when $\mathrm{D}_{\mathrm{C}}$ is brought high, the all " 1 ' $s$ " control word is internally transferred to the control register,
invoking the standby condition.
While in the standby mode, the $D_{x}$ output is actively held in a high impedance state to guarantee that the PCM bus will not be driven. The SIG $_{R}$ output is held low to provide a known condition and remains this way upon activation until it is changed by signaling.
The power consumption in the standby mode is typically 33 mW .

## Power-On Clear

Whether the device is used in the direct or microcomputer mode, an internal reset (power-on clear) is generated, forcing the device into the power down state, when power is supplied by any of the following methods. (1) Device power supplies are turned on in a system power-up situation where either $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{DD}}$ is applied last. (2) A large supply transient causes either of the two positive supplies to drop to less than approximately 2 volts. (3) A board containing Codecs is plugged into a "hot" system where $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{DD}}$ is the last contact
made. It may be necessary to trim back the edge connector pins or fingers on $V_{C C}$ or $V_{D D}$ relative to the other supply to guarantee that the power-on clear will operate properly when a board is plugged into a "hot" system. Furthermore, the Codec will inhibit activity on $T S_{X}$ and $D_{X}$ during the application of power supplies.
The device is also tolerant of transients in the negative supply $\left(\mathrm{V}_{\mathrm{BB}}\right)$ so long as $\mathrm{V}_{\mathrm{BB}}$ remains more negative than -3.5 volts. $V_{B B}$ transients which exceed this level should be detected and followed by a system reinitialization.

## Precision Voltage Reference for the DIA 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.

## $\mu$-Law Conversion

$\mu$-law represents a particular implementation of a piecewise linear approximation to a logarithmic compression curve which is:

$$
F(x)=\operatorname{Sgn}(x) \frac{\ln (1+\mu|x|)}{\ln (1+\mu)}, 0 \leqslant|x| \leqslant 1
$$

$$
\text { where } \begin{aligned}
x & =\text { input signal } \\
\operatorname{Sgn}(x) & =\text { sign of input signal } \\
\mu & =255(\text { defined by AT\&T) }
\end{aligned}
$$

The 2910A $\mu=255$ law Codec uses a 15 segment approximation to the logarithmic law. Each segment consists of 16 steps. In adjacent segments the step sizes are in a ratio of two to one. Within each segment the step size is constant except for the first step of the first segment of the encoder, as indicated in the attached table. 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:

$$
\begin{gathered}
y_{n}=\frac{x_{n}+x_{n+1}}{2} \text { for } 1 \leqslant n \leqslant 127 \\
y_{0}=x_{0}=0 \text { for } n=0
\end{gathered}
$$

These relationships are implicit in the attached table.

## CODER TRANSFER CHARACTERISTIC

(A/D CONVERSION)


## CODEC TRANSFER CHARACTERISTIC



DECODER TRANSFER CHARACTERISTIC (D/A CONVERSION)


During signaling frames, a 7-bit transfer characteristic is implemented in the decoder. This characteristic is derived from the decoder values in the attached table by assuming a value of " 1 " for the LSB ( 8 th bit) and shifting the decoder transfer characteristic one half-step away from the origin. For example, the maximum decoder output level for signaling frames has normalized value 7903, whereas it has value 8031 in normal (nonsignaling) frames.

Theoretical $\mu$-Law - Positive Input Values (for Negative Input Values, Invert Bit 1)


## Notes:

1. 8159 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 $(255-n)$ expressed as a binary number.
3. The PCM word on the highways is the same as the one shown in column 6.
4. 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 .
5. $\mathrm{x}_{128}$ is a virtual decision value.

## APPLICATIONS

## Circuit Interface - <br> Without External Auto Zero



## Holding Capacitor

For an 8 KHz sampling system the transmit holding capacitor CAPx should be $2000 \mathrm{pF} \pm 20 \%$.

## Auto Zero

The 2910A contains a transparent on-chip auto zero plus a device pin for implementing a sign-bit driven external auto zero feedback loop. The on-chip auto zero reduces the input offset voltage of the encoder (VFX) to less than 3 mV . For most telephony applications, this input offset is perfectly acceptable, since it insures the encoder is biased in the lower 25\% of the first segment.
Where lower input offset is required the external auto zero loop may be used to bias the encoder exactly at the zero crossing point. The consequence of the external auto zero loop, aside from extra components, is the addition of the dithering auto-zero signal to the input signal, resulting in slightly higher idle channel noise (approximately 2 dB ) than when the external loop is not used. Consequently, where the application permits, it is recommended that the external auto zero loop not be used.

The circuit interface without external auto zero shows a possible connection between VFX and AUTO leads with

Circult Interface -
With External Auto Zero

the recommended values of $C_{1}=0.1 \mu \mathrm{~F}$ and $\mathrm{R}_{1}=150 \mathrm{~K}$. The circuit interface with auto zero drawing shows a possible connection between the VFX and AUTO leads with the recommended values of $\mathrm{C}_{1}=0.3 \mu \mathrm{~F}, \mathrm{R}_{1}$ $=150 \mathrm{KQ}, R_{2}=330$ \&, and $R_{3}=470 \mathrm{~K} \Omega$.

## Filters Interface

The filters may be interfaced as shown in the circuit interface diagrams. Note that the output pulse stream is of the non-return-to-zero type and hence requires the $(\sin x) / x$ correction provided by the 2912A filter.

## Dx Buffering

For higher drive capability or increased system reliability it may be desirable that the $\mathrm{D}_{\mathrm{X}}$ output of a group of Codecs be buffered from the system PCM bus with an external three-state or open collector buffers. A buffer can be enabled with the appropriate Codec generated $\overline{\mathrm{TS}} \mathbf{x}$ signal or signals. $\overline{\mathrm{TS}}$ signal may also be used to activate external zero code suppression logic, since the occurrence of an active state of any $\overline{\mathrm{TS}_{\mathrm{x}}}$ implies the existence of PCM voice bits (as opposed to transparent data bits) on the bus.

## Grounding, Decoupling, and Layout Recommendations

The most important steps in designing a low noise line card are to insure that the layout of the circuit components and traces results in a minimum of cross coupling between analog and digital signals, and to provide well bypassed and clean power supplies, solid ground planes, and minimal lead lengths between components.

1. All power source leads should be bypassed to ground on each printed circuit board (PCB), on which codecs are provided. At least one electrolytic bypass capacitor (at least $10 \mu \mathrm{~F}$ ) per board is recommended at the point where all power traces from the codecs and filters join prior to interfacing with the edge connector pins assigned to the power leads.
2. When using two-sided PCBs, use both corresponding pins on opposite sides of the board for the same power lead. Strap them together both on the PCB and on the back of the edge connector.
3. Lay out the traces on codec- and filter-equipped boards such that analog signal and capacitor leads from the digital clock and data leads are separated as widely as possible.
4. Connect the codec sample and hold capacitor with the shortest leads possible. Mount it as close to the codec CAP1X, CAP2X pins as possible. Shield the capacitor traces with analog ground.
5. Do not lay out any board traces (especially digital) that pass between or near the leads of the sample and hold capacitor(s) since they are in high impedance circuits which are sensitive to noise coupling.
6. Keep analog voice circuit leads paired on their layouts so that no intervening circuit leads are permitted to run parallel to them and/or between them.
7. Arrange the layout for each duplicated line, trunk or channel circuit in identical form.
8. Line circuits mounted extremely close to adjacent line circuits increase the possibility of interchannel crosstalk.
9. Avoid assignment of edge connector pins to any analog signal adjacent to any lead carrying digital (periodic) signals or power.
10. The optimum grounding configuration is to maintain separate digital and analog grounds on the circuit boards, and to carry these grounds back to the power supply with a low impedance connection. This keeps the grounds separate over the entire system except at the power supply.
11. The voltage difference between ground leads GRDA and GRDD (analog and digital ground) should not exceed two volts. One method of preventing any substantial voltage difference between leads GRDA and GRDD is to connect two diodes back to back in opposite directions across these two ground leads on each board. An additional or alternate method of suppressing ground lead noise is to bridge a RF choke of about 1 to $2 \mu \mathrm{H}$ or greater, as space allows, between leads GRDA and GRDD on each board.
12. Codec-filter pairs should be aligned so that pins 9 through 16 of the filter face pins 1 through 12 of the codec. This minimizes the distance for analog connections between devices and with no crossing analog lines.
13. No digital or high voltage level (such as ringing supply) lines should run under or in parallel with these analog VF connections. If the analog lines are on the top (component side) of the PC board, then GRDD, GRDA, or power supply leads should be directly under them, on the bottom to prevent analog/digital coupling.
14. Both the codec and filter devices should be shielded from traces on the bottom of the PCB by using ground or power supply leads on the top side directly under the device (like a ground plane).
15. Two +5 volt power supply leads ( $V_{c C}$ ) should be used on each PCB, one to the filters, the other to the codecs. These leads should be separately decoupled at the PCB where they then join to a single 5 volt supply at the backplane connector. Decoupling can be accomplished with either a series resistor/ parallel capacitor (RC lowpass) or a series RF choke and parallel capacitor for each 5 volt lead. The capacitor should be at least $10 \mu \mathrm{~F}$ in parallel with a $0.1 \mu \mathrm{~F}$ ceramic. This filters both high and low frequencies and accommodates large current spikes due to switching.
16. Both grounds and power supply leads must have low resistance and inductance. This should be accomplished by using a ground plane whenever possible. When narrower traces must be used, a minimum width of 4 millimeters should be maintained. Either multiple or extra large plated through holes should be used when passing the ground connections through the PCB.
17. The 2912A PCM filter should have all power supplies bypassed to analog ground (GRDA). The 2910A Codec +5 V power supplies shouid be bypassed to the digital ground (GRDD). This is appropriate when separate +5 V power supply leads are used as suggested in item 15 . The -5 V and +12 V supplies should be bypassed to analog ground (GRDA). Bypass capacitors at each device should be high frequency capacitors of approximately 0.1 to $1.0 \mu \mathrm{~F}$ value. Their lead lengths should be minimized by routing the capacitor leads to the appropriate ground plane under the device (either GRDA or GRDD).
18. Relay operation, ring voltage application, interruptions, and loop current surges can produce enormous transients. Leads carrying such signals must be routed well away from both analog and digital circuits on the line card and in backplanes. Lead pairs carrying current surges should be routed closely together to minimize possible inductive coupling. The microcomputer clock lead is particularly vulnerable, and should be buffered. Care should also be used in the backplane layout to prevent pickup surges. Any other latching components (relay buffers, etc.) should also be protected from surges.

## 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 $\mathrm{V}_{\mathrm{BB}}$. . . . . . . . . . . . . . . . . . . . -0.3 V to +20 V
$V_{c c}, V_{D D}$, GRDD, and GRDA with Respect

Power Dissipation. . . . . . . . . . . . . . . . . . . . . . . . . . . 1.35W
"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 rellability.

## 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 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 5 \%$, $\mathrm{GRDA}=0 \mathrm{~V}$, GRDD $=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ $^{1}$ | Max |  |  |

## DIGITAL INTERFACE

| IIL | Low Level Input Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {IL }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{H}}$ | High Level Input Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}>\mathrm{V}_{\text {IH }}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage |  | 0.4 | V | $\mathrm{D}_{\mathrm{X}}, \mathrm{I}_{\mathrm{OL}}=4.0 \mathrm{~mA}$ <br> $\mathrm{SIG}_{\mathrm{R}}, \mathrm{I}_{\mathrm{OL}}=0.5 \mathrm{~mA}$ <br> $\overline{\mathrm{TS}}, \mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$, open drain <br> PDN, $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$, open drain |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\begin{aligned} & D_{X}, I_{O H}=15 \mathrm{~mA} \\ & S_{\mathrm{R}}, \mathrm{I}_{\mathrm{OH}}=0.08 \mathrm{~mA} \end{aligned}$ |

## ANALOG INTERFACE

| $\mathrm{Z}_{\text {Al }}$ | Input Impedance when Sampling, $\mathrm{VF}_{\mathrm{X}}$ | 125 | 300 | 500 | $\Omega$ | in series with CAP ${ }_{\mathrm{X}}$ to GRDA, $-3.1 \mathrm{~V}<\mathrm{V}_{\text {IN }}<3.1 \mathrm{~V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $Z_{\text {AO }}$ | Small Signal Output Impedance, $\mathrm{VF}_{\mathrm{R}}$ | 100 | 180 | 300 | $\Omega$ | $-3.1 \mathrm{~V}<\mathrm{V}_{\text {OUT }}<3.1 \mathrm{~V}$ |
| $V_{\text {OR }}$ | Output Offset Voltage at $\mathrm{VF}_{\mathrm{R}}$ |  |  | $\pm 50$ | mV | all "1s" code sent to $\mathrm{D}_{\mathrm{R}}$ |
| $\mathrm{V}_{\text {IX }}$ | Input Offset Voltage at VFX |  |  | $\pm 5$ | mV | $V F_{X}$ voltage required to produce all "1s" code at $D_{X}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage, Auto Zero |  | $V_{B B}$ | $\left(\mathrm{V}_{\mathrm{BB}}+2\right)$ | V | $400 \mathrm{~K} \Omega$ to GRDA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage, Auto Zero | $\left(\mathrm{V}_{\mathrm{CC}}-2\right)$ | $\mathrm{V}_{\mathrm{CC}}$ |  | V | $400 \mathrm{~K} \Omega$ to GRDA |

POWER DISSIPATION

| $I_{\mathrm{DDO}}$ | Standby Current |  | 0.7 | 1.1 | mA |  |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{CCO}}$ | Standby Current |  | 4 | 7.0 | mA |  |
| $\mathrm{I}_{\mathrm{BBO}}$ | Standby Current |  | 1 | 2.5 | mA |  |
| $\mathrm{I}_{\mathrm{DDI}}$ | Operating Current |  | 11 | 16 | mA | clock frequency $=2.048 \mathrm{MHz}$ |
| $\mathrm{I}_{\mathrm{CCI}}$ | Operating Current |  | 13 | 21 | mA |  |
| $\mathrm{I}_{\mathrm{BBI}}$ | Operating Current |  | 4 | 6.0 | mA |  |

## Notes:

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

## A.C. Characteristics

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V}_{ \pm} 5 \%$, GRDA $=0 \mathrm{~V}, \mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  | Min | Typ $^{1}$ | Max |  |  |

TRANSMISSION (any two Codecs, end-to-end, unless otherwise specified)

| SID | Signal/Total Distortion Ratio, C-Message Weighted (see Figure 1) | Fig. 1 | Fig. 1 |  | dB | $\mathrm{VF}_{\mathrm{x}}=1.02 \mathrm{KHz}$, sinusoid |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| S/D | Signal/Total Distortion Ratio, C-Message Weighted (half-channel) ${ }^{2}$ (see Figure 1) |  | Fig. 1 |  | dB | $\mathrm{VF}_{\mathrm{x}}=1.02 \mathrm{KHz}$, sinusoid |
| $\Delta \mathrm{G}$ | Gain Tracking Error (half-channel) ${ }^{2}$ (see Figure 2) | SPECIFICATIONS UNDER REVISION, CONSULT INTEL REPRESENTATIVE |  |  | dB dB dB | $\begin{aligned} & \mathrm{VF} F_{\mathrm{x}}=1.02 \mathrm{KHz}, \text { sinusoid } \\ & -37 \mathrm{dBm} 0 \leqslant \mathrm{VF} \mathrm{~F}_{\mathrm{x}}<0 \mathrm{dBm} 0 \\ & -50 \mathrm{dBm} 0 \leqslant \mathrm{VF} x-37 \mathrm{dBm0} \\ & -55 \mathrm{dBm} 0 \leqslant \mathrm{VF}<-50 \mathrm{dBm0} \end{aligned}$ |
| $\mathrm{N}_{161}$ | Idle Channel Noise, C-Message Weighted |  | 2 | 10 | dBrnco | no signaling ${ }^{3}$ |
| $\mathrm{N}_{1}{ }^{2}$ | Idie Channel Noise, C-Message Weighted |  | 10 | 13 | dBrnco | with 6th and 12th frame signaling ${ }^{3}$ |
| HD | Harmonic Distortion (2nd or 3rd) |  | -48 | -44 | dB | $\mathrm{VF}_{\mathrm{X}}=1.02 \mathrm{KHz}, 0 \mathrm{dBm0} ;$ measured at decoder output $\mathrm{VF}_{\mathrm{R}}$ |
| IMD | Intermodulation Distortion 2nd Order 3rd Order |  |  | $\begin{aligned} & -45 \\ & -55 \end{aligned}$ | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \end{aligned}$ | 4-tone stimulus in accordance with BSTR PUB 41009 |



Figure 1. Signal/Total Distortion Ratio


Figure 2. Gain Tracking Error ( $\Delta \mathbf{G}$ ) vs Signal Level 0 dBmO

## A.C. Characteristics (continued)

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%$, $\mathrm{GRDA}=0 \mathrm{~V}$, GRDD $=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Plmits | Unit | Test Conditions |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  |  |  |  | Typ $^{1}$ | Max |  |

GAIN AND DYNAMIC RANGE

| DmW | Digital Milliwatt Response | 5.53 | 5.63 | 5.73 | dBm | $23^{\circ} \mathrm{C}$, nominal supplies ${ }^{4}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{DmW}_{\mathrm{T}}$ | DmW0 Variation with Temperature |  | -0.001 | -0.002 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | relative to $23{ }^{\circ} \mathrm{C}^{4}$ |
| $\mathrm{DmW}_{\mathbf{S}}$ | DmW ${ }_{\text {O }}$ Variation with Supplies |  |  | $\pm 0.07$ | dB | supplies $\pm 5 \%{ }^{4}$ |
| $A_{\text {IR }}$ | Input Dynamic Range | 2.17 | 2.20 | 2.23 | $V_{\text {RMS }}$ | using D.C. and A.C. tests ${ }^{5}$ $23^{\circ} \mathrm{C}$, nominal supplies |
| $A_{\text {IRT }}$ | Input Dynamic Range with Temperature |  |  | -0.5 | $\mathrm{mV}_{\text {RMS }} /{ }^{\circ} \mathrm{C}$ | relative to $23^{\circ} \mathrm{C}$ |
| A IRS | Input Dynamic Range with Supplies |  |  | $\pm 18$ | mV RMS | supplies $\pm 5 \%$ |
| $A_{\text {OR }}$ | Output Dynamic Range, $\mathrm{VF}_{\mathrm{R}}$ | 2.13 | 2.16 | 2.19 | $\mathrm{V}_{\text {RMS }}$ | $23^{\circ} \mathrm{C}$, nominal supplies |
| A ORT | $A_{\text {OR }}$ Variation with Temperature |  |  | -0.5 | $\mathrm{mV}_{\text {RMS }} /{ }^{\circ} \mathrm{C}$ | relative to $23^{\circ} \mathrm{C}$ |
| A ORS | AOR Variation with Supplies |  |  | $\pm 18$ | $\mathrm{mV}_{\text {RMS }}$ | supplies $\pm 5 \%$ |

SUPPLY REJECTION AND CROSSTALK

| PSRR $_{1}$ | $V_{D D}$ Power Supply Rejection Ratio | 50 |  |  | dB | decoder alone $^{6}$ |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| PSRR $_{2}$ | $V_{B B}$ Power Supply Rejection Ratio | 35 |  |  | dB | decoder alone $^{6}$ |
| PSRR $_{3}$ | $V_{C C}$ Power Supply Rejection Ratio | 50 |  |  | dB | decoder alone $^{6}$ |
| PSRR $_{4}$ | $V_{\mathrm{DD}}$ Power Supply Rejection Ratio | 50 |  |  | dB | encoder alone $^{7}$ |
| PSRR $_{5}$ | $\mathrm{~V}_{\mathrm{BB}}$ Power Supply Rejection Ratio | 45 |  |  | dB | encoder alone $^{7}$ |
| $\mathrm{PSRR}_{6}$ | $\mathrm{~V}_{\mathrm{CC}}$ Power Supply Rejection Ratio | 50 |  |  | dB | encoder alone $^{7}$ |
| $\mathrm{CT}_{\mathrm{R}}$ | Crosstalk Isolation, Receive Side | 75 | 80 |  | dB | see Note 8 |
| $\mathrm{CT}_{T}$ | Crosstalk Isolation, Transmit Side | 75 | 80 |  | dB | see Note 9 |
| CAPX | Input Sample and Hold Capacitor | 1600 | 2000 | 2400 | pF |  |

## Notes:

1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. Measured in one direction, either decoder or encoder and an ideal device.
3. If the external auto-zero is used $\mathrm{NIC}_{\mathrm{C}}$ has a typical value of 8 dBrnc 0 and NIC 2 has a typical value of 13 dBrnc 0 .
4. $\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 $\mathrm{VF}_{\mathrm{R}}$ output.
5. With the D.C. method the positive and negative clipping levels are measured and $A_{I R}$ is calculated. With the A.C. method a sinusoidal input signal to $V F_{X}$ is used where $A_{I R}$ is measured directly.
6. D.U.T. decoder; impose 200 mV p.p, 1.02 KHz on appropriate supply; measurement made at decoder output; decoder in idle channel conditions.
7. D.U.T. encoder; impose 200 mV p.p, 1.02 KHz on appropriate supply; measurement made at encoder output; encoder in idle channel conditions.
8. $V F_{X}$ of D.U.T. encoder $=1.02 \mathrm{KHz}, 0 \mathrm{dBmO}$. Decoder under quiet channel conditions; measurement made at decoder output.
9. $\mathrm{VF}_{\mathrm{X}}=0 \mathrm{Vrms}$. Decoder $=1.02 \mathrm{KHz}, 0 \mathrm{dBm} 0$. Encoder under quiet channel conditions; measurement made at encoder output.

## A.C. Characteristics - Timing Specification

$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 \%$, $\mathrm{GRDA}=0 \mathrm{~V}$, GRDD $=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Parameter | Limits |  | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| CLOCK SECTION |  |  |  |  |  |
| $t_{C Y}$ | Clock Period | 485 |  | ns | CLK $_{\text {x }}$, CLK $_{\text {R }}$ (2.048 MHz systems), CLK $_{\text {C }}$ |
| $t_{r}, t_{f}$ | Clock Rise and Fall Time | 0 | 30 | ns | CLK $_{\text {x }}$, CLK $_{\text {R }}$, CLK $_{C}$ |
| $\mathrm{t}_{\text {cLK }}$ | Clock Pulse Width | 215 |  | ns | CLK $_{x}$, CLK $_{\text {R }}$, CLK $_{\text {c }}$ |
| $t_{\text {cDC }}$ | Clock Duty Cycle ( $\mathrm{tcLK}^{\div}+\mathrm{t}_{\text {CY }}$ ) | 45 | 55 | \% | CLK $_{\text {x }}$, CLK $_{\text {R }}$ |

TRANSMIT SECTION

| $\mathrm{t}_{\mathrm{VFX}}$ | Analog Input Conversion | 20 |  | timeslot | from leading edge of transmit timeslot ${ }^{1}$ |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{t}_{\mathrm{DZX}}$ | Data Enabled on TS Entry | 50 | 180 | ns | $0<\mathrm{C}_{\text {LOAD }}<100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{DHX}}$ | Data Hold Time | 80 | 230 | ns | $0<\mathrm{C}_{\text {LOAD }}<100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{HZX}}$ | Data Float on TS Exit | 75 | 245 | ns | $\mathrm{C}_{\text {LOAD }}=0$ |
| $\mathrm{t}_{\text {SON }}$ | Timeslot $X$ to Enable | 30 | 220 | ns | $0<\mathrm{C}_{\text {LOAD }}<100 \mathrm{pF}$ |
| $\mathrm{t}_{\text {SOFF }}$ | Timeslot $X$ to Disable | 70 | 225 | ns | $\mathrm{C}_{\text {LOAD }}=0$ |
| $\mathrm{t}_{\text {SS }}$ | Signal Setup Time | 0 |  | ns | relative to bit 7 falling edge |
| $\mathrm{t}_{\text {SH }}$ | Signal Hold Time | 100 |  | ns | relative to bit 8 falling edge |
| $\mathrm{t}_{\text {FSD }}$ | Frame Sync Delay | 15 | 150 | ns |  |

## RECEIVE AND CONTROL SECTIONS

| $t_{\text {VFR }}$ | Analog Output Update | $91 / 16$ | $91 / 16$ | timeslot | from leading edge of the channel timeslot |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $t_{\text {DSR }}$ | Receive Data Setup | 20 |  | ns |  |
| $\mathrm{t}_{\text {DHR }}$ | Receive Data Hold | 60 |  | ns |  |
| $\mathrm{t}_{\text {SIGR }}$ | SIG $_{\text {R }}$ Update |  | 1 | $\mu \mathrm{~s}$ | from trailing edge of the channel timeslot |
| $\mathrm{t}_{\text {FSD }}$ | Frame Sync Delay | 15 | 150 | ns |  |
| $\mathrm{t}_{\text {DSC }}$ | Control Data Setup | 100 |  | ns | Microcomputer mode only |
| $\mathrm{t}_{\text {DHC }}$ | Control Data Hold | 100 |  | ns | Microcomputer mode only |

## Notes:

1. The 20 timeslot 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 timeslots. 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 1.5 V , except $\mathrm{t}_{\mathrm{HZX}}$ and $\mathrm{t}_{\text {SOFF }}$ which reference a high impedance state.

# 2911A <br> PCM CODEC - A LAW <br> 8-BIT COMPANDED AID AND DIA CONVERTER 

| 2911A-1 | Microcomputer* Mode <br> or Direct Mode |
| :--- | :--- |
| 2911A-2 | Direct Mode Only |

■ Per Channel, Single Chip Codec

- CCITT G711 and G732 Compatible, Even Order Bits Inversion Included
- Microcomputer Interface with On-Chip Time-Slot Computation (2911A-1)


## ■ Simple Direct Mode Interface When Fixed Timeslots Are Used

66 dB Dynamic Range, with Resolution Equivalent to 11-Bit Linear Conversion Around Zero
■ $\pm 5 \%$ Power Supplies: $+12 \mathrm{~V}, \mathbf{+ 5 V}$, $\mathbf{- 5 V}$

- Precision On-Chip Voltage Reference

■ Low Power Consumption 230 mW Typ. Standby Power 33 mW Typ.

## - Fabricated with Reliable N-Channel MOS Process

The Intel ${ }^{\circledR}$ 2911A 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 Systems at 2.048 Mbps
- Switching - Digital PBX's and Central Office Switching Systems
- Concentration - Subscriber Carrier/Concentrators

The wide dynamic range of the $2911 \mathrm{~A}(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
*Microcomputer mode is explained on page 4.
PIN CONFIGURATION
BLOCK DIAGRAM


| PIN NAMES |  |
| :---: | :---: |
| CAP 1 ${ }_{\text {X }}$, CAP $2^{\text {X }}$ | Holding Capacitor |
| $\mathrm{VF}_{\mathrm{X}}$ | Analog input |
| $\mathrm{VF}_{\mathrm{R}}$ | Analog Output |
| $\mathrm{D}_{\mathrm{R}}, \mathrm{D}_{\mathrm{C}}$ | Digital Input |
| $\mathrm{D}_{\mathrm{x}}, \overline{T S}_{\mathrm{X}}$ | Digital Output |
| CLK $_{\text {C }}, \mathrm{CLK}_{\mathrm{X}}, \mathrm{CLK}_{\mathrm{R}}$ | Clock Input |
| $\mathrm{FS}_{\mathrm{X},} \mathrm{FS}_{\mathrm{R}}$ | Frame Sync Input |
| AUTO | Auto Zero Output |
| $\mathrm{V}_{\mathrm{BB}}$ | Power ( -5 V ) |
| $\mathrm{V}_{\mathrm{CC}}$ | Power ( +5 V ) |
| $V_{D D}$ | Power ( +12 V ) |
| PDN | Power Down |
| GRDA | Analog Ground |
| GRDD | Digital Ground |
| NC | No Connect |



PIN DESCRIPTION

| Pin No. | Symbol | Function | Description |
| :---: | :---: | :---: | :---: |
| 1 | CAP1 ${ }^{1}$ | Hold | Connections for the transmit holding capacitor. Refer to Applications section. |
| 2 | CAP2x |  |  |
| 3 | $\mathrm{VF}_{\mathrm{X}}$ | 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 $\mathrm{FS}_{\mathrm{x}}$, 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 (+5V for negative, -5 V for positive values). 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 | $\mathrm{V}_{\mathrm{DD}}$ | Power | $+12 \mathrm{~V} \pm 5 \%$; referenced to GRDA. |
| 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{R}}, \mathrm{D}_{\mathrm{C}}$, and $\mathrm{CLK}_{\mathrm{C}}$. |
| 8 | PDN | Output | Active high when the Codec is in the power down mode. TTL interface. Open drain output. |
| 9 | $\mathrm{VF}_{\mathrm{R}}$ | Output | Analog Output. The voltage present on $\mathrm{VF}_{\mathrm{R}}$ is the decoded value of the PCM word received on lead $D_{R}$. This value is held constant between two conversions. |
| 10 | NC | No Connects | Recommended practice is to strap these NC's to GRDA. |
| 11 | NC |  |  |
| 12 | GRDD | Ground | Ground return common to the logic power supply; $\mathrm{V}_{\mathrm{Cc}}$. |
| 13 | $\mathrm{D}_{\mathrm{X}}$ | Output | Output of the transmit side onto the send PCM highway (serial bus). The 8-bit PCM word is serially sent out on this pin at the proper time defined by $\mathrm{FS}_{\mathrm{x}}$, $\mathrm{CLK}_{\mathrm{X}}, \mathrm{D}_{\mathrm{C}}$, and CLK $\mathrm{K}_{\mathrm{C}}$. TTL threestate output. |


| Pin No. | Symbol | Function | Description |
| :--- | :--- | :--- | :--- |
| 14 | TS $_{X}$ | Output | Normally high, this signal goes <br> low while the Codec is transmit- <br> ting an 8-bit PCM word on the <br> DX lead. (Timeslot information <br> used for diagnostic purposes <br> and also to gate the data on the <br> DX lead.) TTL interface, open <br> drain output. |
| 15 | $V_{\mathrm{CC}}$ | Power | +5V $\pm 5 \%$, referenced to GRDD. |

## FUNCTIONAL DESCRIPTION

The 2911A 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 ( $\mathrm{FS}_{\mathrm{x}}$ ) into an 8-bit PCM word which is sent out on the $D_{X}$ lead at the proper time. Similarly, on the receive link, the Codec fetches an 8-bit PCM word from the receive highway ( $\mathrm{D}_{\mathrm{R}}$ lead) and decodes an analog value which will remain constant on lead $\mathrm{VF}_{\mathrm{R}}$ 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 timeslots. In small systems this may eliminate the need for any external timeslot exchange; in large systems it provides one level of concentration. This feature can be bypassed and


Functional Block Diagram of Line Circult
discrete timeslots sent to each Codec within a system. In the power-down mode, most functions of the Codec are directly disabled to reduce power dissipation to a minimum.

## CODEC OPERATION

## Codec Control

The operation of the 2911A is defined by serially loading an 8 -bit word through the $\mathrm{D}_{\mathrm{C}}$ lead (data) and the $\mathrm{CLK}_{\mathrm{C}}$ lead (clock). The loading is asynchronous with the other operations of the Codec, and takes place whenever transitions occur on the CLK ${ }_{C}$ lead. The $D_{C}$ input is loaded in during the trailing edge of the CLK $_{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, powerdown mode (11). In the last case (11), the following 6 bits are irrelevant.

The last 6 bits of the control word define the timeslot assignment, from 000000 (timeslot 1) to 111111 (timeslot 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 | X \& R |
| 0 | 1 | $X$ |
| 1 | 0 | $R$ |
| 1 | 1 | Standby |


| Bit |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | 4 | 5 | 6 | 7 | 8 | Time-Slot |  |
| 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |
| 0 | 0 | 0 | 0 | 0 | 1 | 2 |  |
|  |  | $\vdots$ |  |  | $\vdots$ |  |  |
|  |  | $\bullet$ |  |  | $\vdots$ |  |  |
|  |  |  | $\bullet$ |  |  | $\vdots$ |  |
| 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 timeslots for switching applications.

## Microcomputer Control Mode (2911A-1)

In the microcomputer mode, each Codec performs its own timeslot computation independently for the transmit and receive channels by counting clock pulses (CLK ${ }_{x}$ and CLK ${ }_{R}$ ). All Codecs tied to the same data bus receive identical framing pulses ( $F S_{X}$ and $\mathrm{FS}_{\mathrm{R}}$ ). The framing pulses reset the on-chip timeslot counters every frame; hence the timeslot counters of all devices are synchronized. Each Codec is programmed via CLK ${ }_{C}$ and $D_{C}$ for the desired transmit and receive timeslots according to the description in the Codec Control Section. All Codecs tied to the same $D_{R}$ bus will, in general, have different receive timeslots, although that is not a device requirement. There may be separate busses for transmit and receive or all Codecs may transmit and receive over the same bus, in which case the transmit and receive channels must be synchronous (CLK ${ }_{X}=C L K_{R}$ ). There are no other restrictions on timeslot 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 timeslot assignment, consisting of eight negative transitions of $\mathrm{CLK}_{\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). CLK $\mathrm{C}_{\mathrm{C}}$ must be left at a TTL low level when not assigning a timeslot.
2. A dead period of two frames must always be observed between successive timeslot assignments. The two frame delay is measured from the rising edge of the first CLK $_{C}$ transition of the previous timeslot assigned.
3. When the device is in the power-down state a single control word will suffice to power-up the Codec and make a timeslot assignment. That is, the first assignment brings the device out of power-down and registers the timeslot information in the lower six bits of the control word.
4. Initialization sequence: The device contains an onchip power-on clear function which guarantees that with proper sequencing of the supplies ( $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{DD}}$ on last), the device will initialize with no timeslot assigned to either the transmit or receive channel. After a supply failure or whenever the suppHes are applied, it is recommended that either power down assignment be made first, or the first timeslot assignment be a transmit timeslot or a transmit/receive timeslot. The consequence of making a receive timeslot assignment first, after supply application, is that the transmit channel will assume timeslot 1, potentially producing bus contention.
5. Transmit only/receive only operation is permitted provided that a power down assignment is made first. Otherwise, special circuits which use only one channel should be physically disconnected from the unused bus; this allows a timeslot to be made to an unused channel without consequence.

## Example of Microcomputer Control Mode:

The two words 01000001 and 10000010 have been loaded into the Codec. The transmit side is now programmed for timeslot 2 and the receive side for timeslot 3. The Codec will output a PCM word on the transmit PCM highway (bus) during the timeslot 2 of the transmit frame, and will fetch a PCM word from the receive PCM highway during timeslot 3 .


In this example the Codec interface to the PCM highway then functions as shown below. ( $F S_{X}$ and $\mathrm{FS}_{\mathrm{R}}$ may be asynchronous.)


## Direct Control Mode

The direct mode of operation will be selected when the CLK $_{C}$ pin is strapped to the +5 volt supply $\left(V_{c C}\right)$. In this mode, the $D_{C}$ pin is an active low chip select. In other words, when $D_{C}$ is low, the device transmits and receives in the timeslots which follow the appropriate
framing pulses. With $D_{C}$ high the device is in the power down state. Even though $\mathrm{CLK}_{\mathrm{C}}$ characteristics are simpler for the 2911A it will operate properly when plugged into a 2911 board.
Deactivation of a channel by removal of the appropriate framing pulse ( $\mathrm{FS}_{\mathrm{X}}$ or $\mathrm{FS}_{\mathrm{R}}$ ) is generally not permitted.

Specifically, framing pulses must be applied for a minimum of two frames after a change in state of $D_{C}$ in order for the $D_{C}$ change to be internally sensed. In particular, when entering standby in the direct mode, framing pulses must be applied as usual for two frames after $D_{C}$ is brought high. Thereafter, the framing pulses could, if desired, be removed until such time as the device is to
be reactivated by the reapplication of framing pulses with $\mathrm{D}_{\mathrm{C}}$ low.
The Codec will enter the direct mode within three frame times ( $375 \mu \mathrm{sec}$ ) as measured from the time the device power supplies settle to within the specified limits. This assumes that CLK ${ }_{\mathrm{C}}$ is tied to $\mathrm{V}_{\mathrm{CC}}$ and that all clocks are available at the time the supplies have settled.

## General Control Requirements

All bit and frame clocks should be applied whenever the device is active. In particular, an unused channel cannot be deactivated by removal of its associated frame or bit clock while the other channel of the same device remains active.

A single channel cannot be deactivated except by physical disconnection of the data lead ( $D_{x}$ or $D_{R}$ ) from the system data bus. A device (both transmit and receive channels) may be deactivated 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 $V F_{X}$ lead. An internal switch samples the signal and the hold function is performed by the external capacitor connected to the CAP1 1 and CAP2x leads. The sampling and conversion
is synchronized with the transmit timeslot. The PCM word is then output on the $D_{X}$ lead at the proper timeslot occurrence 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 $D_{R}$ lead from the PCM highway at the proper timeslot occurrence. The decoded value is held on an internal sample and hold capacitor.

The buffered non-return to zero output signal on the $\mathrm{VF}_{\mathrm{R}}$ lead has a dynamic range of $\pm 2.2$ volts RMS ( $\pm 3.1$ volts peak).

## Standby Mode - Power Down

To minimize power consumption and heat dissipation a standby mode is provided where all Codec functions are disabled except for $D_{C}$ and $C L K_{C}$ leads. These allow the Codec to be reactivated. In the microcomputer mode the Codec is placed into standby by loading a control word $\left(\mathrm{D}_{\mathrm{C}}\right)$ with a " 1 " in bits 1 and 2 locations. In the direct mode when $D_{C}$ is brought high, the all " 1 's" control
word is internally transferred to the control register, invoking the standby condition.

While in the standby mode, the $\mathrm{D}_{\mathrm{X}}$ output is actively held in a high impedance state to guarantee that the PCM bus will not be driven.

The power consumption in the standby mode is typically 33 mW .

## Power-On Clear

Whether the device is used in the direct or microcomputer mode, an internal reset (power-on clear) is generated, forcing the device into the power down state, when power is supplied by any of the following
methods. (1) Device power supplies are turned on in a system power-up situation where either $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{DD}}$ is applied last. (2) A large supply transient causes either of the two positive supplies to drop to approximately 2 volts. (3) A board containing Codecs is plugged into a
"hot" system where $V_{C C}$ or $V_{D D}$ is the last contact made. It may be necessary to trim back the edge connector pins or fingers on $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{D D}$ relative to the other supply to guarantee that the power-on clear will operate properly when a board is plugged into a "hot" system. Furthermore, the Codec will Inhiblt activity on TS $x$ and

Dx during the application of power supplies.
The device is also tolerant of transients in the negative supply ( $\mathrm{V}_{\mathrm{BB}}$ ) so long as $\mathrm{V}_{\mathrm{BB}}$ remains more negative than -3.5 volts. $V_{B B}$ transients which exceed this level should be detected and followed by a system reinitialization.

## Precision Voltage Reference for the DIA 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 commonly referred to as the A Law.

The Codec provides a piecewise linear approximation of the logarithmic 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 $\mathrm{x}_{\mathrm{n}}$ by the expression:

$$
y_{n}=\frac{x_{n-1}+x_{n}}{2}, \quad 0<n \leqslant 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)

| 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Segment Number | No. of Steps x Step Size | Value at Segment End Points | Decision Value Number $n$ | Decision <br> Value $x_{n}{ }^{1}$ | PCM Word $^{4}$ Bit Number 12345678 | Normalized Value at Decoder Output $y_{n}{ }^{5}$ | Decoder Output Value Number |
| 7 | $16 \times 128$ | $4096{ }^{3}$ | (128) | (4096) |  | 1 | I |
|  |  |  |  |  | 11111111 | 4032 | 128 |
|  |  |  | 127 | 3968 |  | 1 | 1 |
|  |  |  | I | 1 |  | 1 | I |
|  |  |  | 1 | 1 | (see Note 2) | I | 1 |
|  |  |  | 1 | 1 | (see Note 2) | I | 1 |
|  |  |  | I | 1 |  | 1 | I |
| 6 | $16 \times 64$ |  | 113 | 2176 |  | 1 | I |
|  |  | 2048 |  |  | 11110000 | 2112 | 113 |
|  |  |  | 112 | 2048 |  | I | I |
|  |  |  | I | I |  | I | 1 |
|  |  |  | 1 | I | (see Note 2) | I | 1 |
|  |  |  | 1 | I | (see Note 2) | 1 | I |
|  |  |  | 97 | I |  | I | 1 |
| 5 | $16 \times 32$ |  |  | 1088 |  | I | 1 |
|  |  | 1024 |  |  | 11100000 | 1056 | 97 |
|  |  |  | 96 | 1024 |  | 1 | I |
|  |  |  | 1 | I |  | 1 | I |
|  |  |  | 1 | 1 | (see Note 2) | 1 | 1 |
|  |  |  | 1 | 1 | (see Note 2) | 1 | I |
|  |  |  | 1 | 1 |  | 1 | 1 |
| 4 |  |  | 81 | 544 |  | I | I |
|  | $16 \times 16$ | 512 | 80 | 5121 | 1101000 | 528 | 81 |
|  |  |  |  |  |  | I | 1 |
|  |  |  |  |  |  | 1 | 1 |
|  |  |  | 1 | I | (see Note 2) | 1 | I |
|  |  |  | 1 | 1 | (see Note 2) | I | I |
|  |  |  | I | I |  | I | 1 |
| 3 | $16 \times 8$ |  | 65 | 272 |  | I | I |
|  |  | 256 | 64111149 | 25611 | 11000000 | 264 | 65 |
|  |  |  |  |  |  | I | I |
|  |  |  |  |  |  | I | 1 |
|  |  |  |  | 1 | (see Note 2) | 1 | I |
|  |  |  |  | I | (see Note 2) | I | I |
|  |  |  |  | 1 |  | 1 | 1 |
| 2 | $16 \times 4$ |  |  | 136 |  | I | 1 |
|  |  | 128 | 48111133 |  | 10110000 | 132 | 49 |
|  |  |  |  | 128 |  | 1 | 1 |
|  |  |  |  | I |  | 1 | 1 |
|  |  |  |  | I | (see Note 2) | 1 | 1 |
|  |  |  |  | 1 | (see Note 2) | I | 1 |
|  |  |  |  | 1 |  | I | I |
| 1 | $32 \times 2$ |  |  | 68 |  | 1 | 1 |
|  |  | 64 | 3211111 | 641 | 10100000 | 66 | 33 |
|  |  |  |  |  | (see Note 2) | I | 1 |
|  |  |  |  |  |  | I | 1 |
|  |  |  |  | 1 |  | I | I |
|  |  |  |  | 1 |  | I | I |
|  |  |  |  | $1$ |  | 1 | I |
|  |  |  |  | 2 | 10000000 | 1 | 1 |
|  |  |  | 0 | 0 | 100000 | 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 2911A provides for the inversion of the even order bits on both the send and receive sections.
5. The voltage output on the $\mathrm{VF}_{\mathrm{R}}$ lead is equal to the normalized value given in the table, augmented by an offset. The offset value is approximately 15 mV .

## APPLICATIONS

## Holding Capacitor

For an 8 KHz sampling system the transmit holding capacitor CAPx should be $2000 \mathrm{pF} \pm \mathbf{2 0 \%}$.

## Circuit Interface -

## Without External Auto Zero



## Filters Interface

The filters may be interfaced as shown in the circuit interface diagrams. Note that the output pulse stream is of the non-return-to-zero type and hence requires the $(\sin x) / \mathrm{x}$ correction provided by the 2912A filter.

## DX Buffering

For higher drive capability or increased system reliability it may be desirable that the $D_{X}$ output of a group of Codecs be buffered from the system PCM bus with an external three-state or open collector buffers. A buffer can be enabled with the appropriate Codec generated $\overline{T S}_{X}$ signal or signals. $\overline{T S}_{X}$ signal may also be used to activate external zero code suppression logic, since the occurrence of an active state of any $\overline{\mathrm{TS}}_{\mathrm{X}}$ implies the existence of PCM voice bits (as opposed to transparent data bits) on the bus.

Circuit Interface -
With External Auto Zero


## Auto Zero

The 2911A contains a transparent on-chip auto zero plus a device pin for implementing a sign-bit driven external auto zero feedback loop. The on-chip auto zero reduces the input offset voltage of the encoder ( $\mathrm{VF}_{\mathrm{X}}$ ) to less than 3 mV . For most telephony applications, this input offset is perfectly acceptable, since it insures the encoder is biased in the lower $\mathbf{2 5 \%}$ of the first segment.
Where lower input offset is required the external auto zero loop may be used to bias the encoder exactly at the zero crossing point. The consequence of the external auto zero loop, aside from extra components, is the addition of the dithering auto-zero signal to the input signal, resulting in slightly higher idle channel noise (approximately 2 dB ) than when the external loop is not used. Consequently, where the application permits, it is recommended that the external auto zero loop not be used.
The circuit interface without external auto zero shows a possible connection between $V F_{X}$ and AUTO leads with the recommended values of $C_{1}=0.1 \mu F$ and $R_{1}=150 \mathrm{~K}$.
The circuit interface with external auto zero drawing shows a possible connection between VFX and AUTO leads with the recommended values of $C_{1}=0.3 \mu \mathrm{~F}$, $R_{1}=150 \mathrm{~K} \Omega, R_{2}=330 \Omega$, and $R_{3}=470 \mathrm{~K} \Omega$.

## Grounding, Decoupling, and Layout Recommendations

The most important steps in designing a low noise line card are to insure that the layout of the circuit components and traces results in a minimum of cross coupling between analog and digital signals, and to provide well bypassed and clean power supplies, solid ground planes, and minimal lead lengths between components.

1. All power source leads should be bypassed to ground on each printed circuit board (PCB), on which codecs are provided. At least one electrolytic bypass capacitor (at least $10 \mu \mathrm{~F}$ ) per board is recommended at the point where all power traces from the codecs and filters join prior to interfacing with the edge connector pins assigned to the power leads.
2. When using two-sided PCBs, use both correspond-
ing pins on opposite sides of the board for the same power lead. Strap them together both on the PCB and on the back of the edge connector.
3. Lay out the traces on codec- and filter-equipped boards such that analog signal and capacitor leads from the digital clock and data leads are separated as widely as possible.
4. Connect the codec sample and hold capacitor with the shortest leads possible. Mount it as close to the codec CAP1X, CAP2X pins as possible. Shield the capacitor traces with analog ground.
5. Do not lay out any board traces (especially digital) that pass between or near the leads of the sample and hold capacitor(s) since they are in high impedance circuits which are sensitive to noise coupling.
6. Keep analog voice circuit leads paired on their
layouts so that no intervening circuit leads are permitted to run parallel to them and/or between them.
7. Arrange the layout for each duplicated line, trunk or channel circuit in identical form.
8. Line circuits mounted extremely close to adjacent line circuits increase the possibility of interchannel crosstalk.
9. Avoid assignment of edge connector pins to any analog signal adjacent to any lead carrying digital (periodic) signals or power.
10. The optimum grounding configuration is to maintain separate digital and analog grounds on the circuit boards, and to carry these grounds back to the power supply with a low impedance connection. This keeps the grounds separate over the entire system except at the power supply.
11. The voltage difference between ground leads GRDA and GRDD (analog and digital ground) should not exceed two volts. One method of preventing any substantial voltage difference between leads GRDA and GRDD is to connect two diodes back to back in opposite directions across these two ground leads on each board. An additional or alternate method of suppressing ground lead noise is to bridge a RF choke of about 1 to $2 \mu \mathrm{H}$ or greater, as space allows, between leads GRDA and GRDD on each board.
12. Codec-filter pairs should be aligned so that pins 9 through 16 of the filter face pins 1 through 12 of the codec. This minimizes the distance for analog connections between devices and with no crossing analog lines.
13. No digital or high voltage level (such as ringing supply) lines should run under or in parallel with these analog VF connections. If the analog lines are on the top (component side) of the PC board, then GRDD, GRDA, or power supply leads should be directly under them, on the bottom to prevent analog/digital coupling.
14. Both the codec and filter devices should be shielded from traces on the bottom of the PCB by using ground or power supply leads on the top side directly under the device (like a ground plane).
15. Two +5 volt power supply leads ( $\mathrm{V}_{\mathrm{cc}}$ ) should be used on each PCM, one to the filters, the other to the codecs. These leads should be separately decoupled at the PCB where they then join to a single 5 volt supply at the backplane connector. Decoupling can be accomplished with either a series resistor/ parallel capacitor (RC lowpass) or a series RF choke and parallel capacitor for each 5 volt lead. The capacitor should be at least $10 \mu \mathrm{~F}$ in parallel with a $0.1 \mu \mathrm{~F}$ ceramic. This filters both high and low frequencies and accommodates large current spikes due to switching.
16. Both grounds and power supply leads must have low resistance and inductance. This should be accomplished by using a ground plane whenever possible. When narrower traces must be used, a minimum width of 4 millimeters should be maintained. Either multiple or extra large plated through holes should be used when passing the ground connections through the PCB.
17. The 2912A PCM filter should have all power supplies bypassed to analog ground (GRDA). The 2911A Codec +5 V power supplies should be bypassed to the digital ground (GRDD). This is appropriate when separate +5 V power supply leads are used as suggested in item 15. The -5 V and +12 V supplies should be bypassed to analog ground (GRDA). Bypass capacitors at each device should be high frequency capacitors of approximately 0.1 to $1.0 \mu \mathrm{~F}$ value. Their lead lengths should be minimized by routing the capacitor leads to the appropriate ground plane under the device (either GRDA or GRDD).
18. Relay operation, ring voltage application, interruptions, and loop current surges can produce enormous transients. Leads carrying such signals must be routed well away from both analog and digital circuits on the line card and in backplanes. Lead pairs carrying current surges should be routed closely together to minimize possible inductive coupling. The microcomputer clock lead is particularly vulnerable, and should be buffered. Care should also be used in the backplane layout to prevent pickup surges. Any other latching components (relay buffers, etc.) should also be protected from surges.

## Absolute Maximum Ratings*

| Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ <br> All Input or Output Voltages with <br>  |
| :---: |
|  |  |
|  |  |

$\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$, GRDA, and GRDA with Respect

Power Dissipation. 1.35W
*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}_{\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.

| Symbol | Parameter |  | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| DIGITAL INTERFACE |  |  |  |  |  |  |
| IIL | Low Level Input Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {IL }}$ |
| $\mathrm{IIH}^{\text {H }}$ | High Level Input Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}>\mathrm{V}_{\text {IH }}$ |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage |  |  | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.2 |  |  | V |  |
| V OL | Output Low Voltage |  |  | 0.4 | V | $\begin{aligned} & \mathrm{D}_{\mathrm{X}}, I_{\mathrm{OL}}=4.0 \mathrm{~mA} \\ & \mathrm{TS}_{\mathrm{X}}, \mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA} \text {, open drain } \\ & \mathrm{PDN}, \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \text {, open drain } \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{D}_{\mathrm{X}}, \mathrm{I}_{\mathrm{OH}}=15 \mathrm{~mA}$ |
| ANALOG INTERFACE |  |  |  |  |  |  |
| $Z_{\text {Al }}$ | Input Impedance when Sampling, $\mathrm{VF}_{\mathrm{X}}$ | 125 | 300 | 500 | $\Omega$ | In series with CAP ${ }^{x}$ to GRDA, $-3.1 \mathrm{~V}<\mathrm{V}_{\text {IN }}<3.1 \mathrm{~V}$ |
| $\mathrm{Z}_{\text {AO }}$ | Small Signal Output Impedance, $\mathrm{VF}_{\mathrm{R}}$ | 100 | 180 | 300 | $\Omega$ | $-3.1 \mathrm{~V}<\mathrm{V}_{\text {OUT }}<3.1 \mathrm{~V}$ |
| $V_{\text {OR }}$ | Output Offset Voltage at $\mathrm{VF}_{\mathrm{R}}$ | $-50$ |  | 50 | mV | Minimum code to $\mathrm{D}_{\mathrm{R}}$ |
| $V_{\text {IX }}$ | Input Offset Voltage at VFX | -5 |  | 5 | mV | Minimum positive code produced at $D_{x}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage, Auto Zero |  | $\mathrm{V}_{\mathrm{BB}}$ | $\left(\mathrm{V}_{\mathrm{BB}}+2\right)$ | V | 400 K ¢ to GRDA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage, Auto Zero | $\left(V_{c c}-2\right)$ | $\mathrm{V}_{\mathrm{CC}}$ |  | V | 400 K ¢ to GRDA |
| POWER DISSIPATION |  |  |  |  |  |  |
| IDDO | Standby Current |  | 0.7 | 1.1 | mA |  |
| Ícoo | Standby Current |  | 4.0 | 7.0 | mA |  |
| $I_{\text {BBO }}$ | Standby Current |  | 1.0 | 2.5 | mA | clock frequency $=2.048 \mathrm{MHz}$ |
| IDDI | Operating Current |  | 11 | 16 | mA | ( |
| $\mathrm{I}_{\mathrm{CCI}}$ | Operating Current |  | 13 | 21 | mA |  |
| $\mathrm{I}_{\text {BBI }}$ | Operating Current |  | 4.0 | 6.0 | mA |  |

## Notes:

1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply values.
A.C. Characteristics
$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{C C}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{B B}=-5 \mathrm{~V} \pm 5 \%$, $\mathrm{GRDA}=0 \mathrm{~V}$, GRDD $=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Parameter |  | Limits |  | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ $^{1}$ | Max |  | Then |

TRANSMISSION (any two Codecs, end-to-end, unless otherwise specified)

| S/D | Signal to Total Distortion Ratio. CCITT G. 712 Method 1 | TBD |  |  | dB | signal level -3 dBm 0 to -6dBm0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | TBD |  |  | dB | Signal level to -27dBm0 |
|  |  | TBD |  |  | dB | Signal level to - $34 \mathrm{dBm0}$ |
|  |  | TBD |  |  | dB | Signal level to $-40 \mathrm{dBm0}$ |
|  |  | TBD |  |  | dB | Signal level to -55 dBm0 |
| S/D | Signal to Total Distortion Ratio. See Figure 2. CCITT G. 712 Method 2 | 35 |  |  | dB | Signal level 0 dBmO to $-30 \mathrm{dBm0}$ |
|  |  | 29 |  |  | dB | Signal level to $-40 \mathrm{dBm0}$ |
|  |  | 24 |  |  | dB | Signal level to -45dBm0 |
| S/D | Signal to Total Distortion Ratio. CCITT G. 712 Method 2 (Half Channel) | 37 |  |  | dB | Signal level $0 \mathrm{dBm0}$ to $-30 \mathrm{dBm0}$ |
|  |  | 31 |  |  | dB | Signal level to $-40 \mathrm{dBm0}$ |
|  |  | 26 |  |  | dB | Signal level to $-45 \mathrm{dBm0}$ |
| $\Delta \mathrm{G}$ | Gain Tracking Deviation from Gain at -10dBm0. CCITT G. 712 Method 2. <br> (Half Channel) | SPECIFICATIONS UNDER REVISION, CONSULT INTEL REPRESENTATIVE |  |  | dB | Signal level +3dBm0 to $-40 \mathrm{dBm0}$ |
|  |  |  |  |  | dB | Signal level to -50 dBm0 |
|  |  |  |  |  | dB | Signal level to -55dBm0 |
| $\mathrm{N}_{\text {IC }}$ | Idle Channel Noise |  | -85 | -78 | dBm0p | See Note 2 |
| HD | Harmonic Distortion (2nd or 3rd) |  | -48 | -44 | dB | $V F_{X}=1.02 \mathrm{KHz}, 0 \mathrm{dBm0} ;$ <br> measured at decoder output $V F_{R}$ |
| $\begin{aligned} & \mathrm{IMD}_{1} \\ & \mathrm{IMD}_{2} \end{aligned}$ | Intermodulation Distortion G. 712 (8.1) G. 712 (8.2) G. 712 (8.2) |  |  | $\begin{array}{r} -45 \\ -50 \\ \hline \end{array}$ | $\begin{gathered} \mathrm{dB} \\ \mathrm{dBmO} \end{gathered}$ | See Note 3 |

## Notes:

1. Typical values are for $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. If the external auto zero is used $N_{I C}$ has a typical value of -76 dBmo .
3. According to the two tone method. CCITT G. 712 recommendation.

## A.C. Characteristics (continued)

$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} \pm 5 \%, G R D A=0 \mathrm{~V}$, $\mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Limits | Unit | Test Conditions |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Max |  |  |

## GAIN AND DYNAMIC RANGE

| DmW | Digital Milliwatt Response | 5.58 | 5.66 | 5.78 | dBm | $23^{\circ} \mathrm{C}$, nominal supplies ${ }^{4}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{DmW}_{T}$ | DmW0 Variation with Temperature |  | -0.001 | -0.002 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}^{4}$ |
| $\mathrm{DmW}_{S}$ | DmW ${ }_{\text {O }}$ Variation with Supplies |  |  | $\pm 0.07$ | dB | Supplies $\pm 5 \%^{4}$ |
| $\mathrm{A}_{\text {IR }}$ | Input Dynamic Range | 2.17 | 2.20 | 2.23 | $\mathrm{V}_{\text {RMS }}$ | Usjing D.C. and A.C. tests ${ }^{5}$ $23^{\circ} \mathrm{C}$, nominal süpplies |
| A IRT | Input Dynamic Range vs Temperature |  |  | -0.5 | $\mathrm{mV}_{\text {RMS }} \mathrm{I}^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}$ |
| A IRS | Input Dynamic Range vs Supplies |  |  | $\pm 18$ | mV RMS | Supplies $\pm 5 \%$ |
| $A_{\text {OR }}$ | Output Dynamic Range, $\mathrm{VF}_{\text {R }}$ | 2.14 | 2.17 | 2.20 | $\mathrm{V}_{\text {RMS }}$ | $23^{\circ} \mathrm{C}$, nominal supplies |
| A ORT | $\mathrm{A}_{\text {OR }}$ Variation with Temperature |  |  | -0.5 | $\mathrm{mV}_{\text {RMS }} /^{\circ} \mathrm{C}$ | Relative to $23^{\circ} \mathrm{C}$ |
| $A_{\text {ORS }}$ | $A_{\text {OR }}$ Variation with Supplies |  |  | $\pm 18$ | $\mathrm{mV}_{\text {RMS }}$ | Supplies $\pm 5 \%$ |

SUPPLY REJECTION AND CROSSTALK

| PSRR $_{1}$ | $\mathrm{V}_{\mathrm{DD}}$ Power Supply Rejection Ratio | 50 |  |  | dB | decoder alone ${ }^{6}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{PSRR}_{2}$ | $\mathrm{V}_{\text {BB }}$ Power Supply Rejection Ratio | 35 |  |  | dB | decoder alone ${ }^{6}$ |
| $\mathrm{PSRR}_{3}$ | $\mathrm{V}_{\text {CC }}$ Power Supply Rejection Ratio | 50 |  |  | dB | decoder alone ${ }^{6}$ |
| $\mathrm{PSRR}_{4}$ | $\mathrm{V}_{\mathrm{DD}}$ Power Supply Rejection Ratio | 50 |  |  | dB | encoder alone ${ }^{7}$ |
| $\mathrm{PSRR}_{5}$ | $\mathrm{V}_{\text {BB }}$ Power Supply Rejection Ratio | 45 |  |  | dB | encoder alone ${ }^{7}$ |
| $\mathrm{PSRR}_{6}$ | $\mathrm{V}_{\text {CC }}$ Power Supply Rejection Ratio | 50 |  |  | dB | encoder alone ${ }^{7}$ |
| $\mathrm{CT}_{\mathrm{R}}$ | Crosstalk Isolation, Receive Side | 75 | 80 |  | d3 | See Note 8 |
| $\mathrm{CT}_{\text {T }}$ | Crosstalk Isolation, Transmit Side | 75 | 80 |  | dB | See Note 9 |
| CAPX | Input Sample and Hold Capacitor | 1600 | 2000 | 2400 | pF |  |

Notes:
4. $\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.
5. With the D.C. method the positive and negative clipping levels are measured and $A_{I R}$ is calculated. With the A.C. method a sinusoidal input signal to $V F_{X}$ is used where $A_{I R}$ is measured directly.
6. D.U.T. decoder; impose $200 \mathrm{mV}_{\text {p.p, }}, 1.02 \mathrm{KHz}$ on appropriate supply; measurement made at decoder output; decoder in idle channel conditions.
7. D.U.T. encoder, impose 200 mV p.p, 1.02 KHz on appropriate supply; measurement made at encoder output; encoder in idle channel conditions.
8. VF $X$ of D.U.T. encoder $=1.02 \mathrm{KHz}, 0 \mathrm{dBmO}$. Decoder under quiet channel conditions; measurement made at decoder output.
9. $V F_{X}=0 \mathrm{Vrms}$. Decoder $=1.02 \mathrm{KHz}, 0 \mathrm{dBmO}$. Encoder under quiet channel conditons; measurement made at encoder output.


Figure 1. Gain Variation ( $\Delta \mathrm{G}$ ) vs. Signal Level


Figure 2. Signal/Total Distortion Ratio, End-to-End

## A.C. Characteristics - Timing Specification and Waveforms ${ }^{\text {II }}$

$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}_{B B}=-5 \mathrm{~V} \pm 5 \%, G R D A=0 \mathrm{~V}$, GRDD $=0 \mathrm{~V}$, unless otherwise specified.

| Symbol | Parameter | Limits |  | Units | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| CLOCK SECTION |  |  |  |  |  |
| $t_{C Y}$ | Clock Period | 485 |  | ns | $\mathrm{CLK}_{\mathrm{x}}, \mathrm{CLK}_{\mathrm{R}}$ (2.048 MHz systems), $\mathrm{CLK}_{\mathrm{C}}$ |
| $t_{r}, t_{f}$ | Clock Rise and Fall Time | 0 | 30 | ns | CLK $_{x}$, CLK $_{\text {R }}$, CLK $_{\text {c }}$ |
| $\mathrm{t}_{\text {CLK }}$ | Clock Pulse Width | 215 |  | ns | CLK $_{x}$, CLK $_{\text {R }}$, CLK $_{C}$ |
| $\mathrm{t}_{\text {CDC }}$ | Clock Duty Cycle ( $\mathrm{t}_{\text {cLK }} \div \mathrm{t}_{\mathrm{CY}}$ ) | 45 | 55 | \% | CLK $_{\text {X }}$, CLK $_{\text {R }}$ |

## TRANSMIT SECTION

| $t_{\text {VFX }}$ | Analog Input Conversion | 20 |  | timeslot | from leading edge of transmit timeslot ${ }^{2}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {DZX }}$ | Data Enabled on TS Entry | 50 | 180 | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| $t_{\text {DHX }}$ | Data Hold Time | 80 | 230 | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| $t_{\text {HZX }}$ | Data Float on TS Exit | 75 | 245 | ns | $\mathrm{C}_{\text {LOAD }}=0$ |
| $\mathrm{t}_{\text {SON }}$ | Timeslot X to Enable | 30 | 185 | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| tSOFF | Timeslot X to Disable | 70 | 225 | ns | $C_{\text {LOAD }}=0$ |
| $t_{\text {FSD }}$ | Frame Sync Delay | 15 | 150 | ns |  |

## RECEIVE AND CONTROL SECTIONS

| $t_{\text {VFR }}$ | Analog Output Update | $91 / 16$ | $91 / 16$ | timeslot | from leading edge of the channel timeslot |
| :---: | :--- | :---: | :---: | :---: | :--- |
| $t_{\text {DSR }}$ | Receive Data Setup | 20 |  | ns |  |
| $\mathrm{t}_{\text {DHR }}$ | Receive Data Hold | 60 |  | ns |  |
| $\mathrm{t}_{\text {FSD }}$ | Frame Sync Delay | 15 | 150 | ns |  |
| $\mathrm{t}_{\mathrm{DSC}}$ | Control Data Setup | 100 |  | ns | Microcomputer mode only |
| $\mathrm{t}_{\text {DHC }}$ | Control Data Hold | 100 |  | ns | Microcomputer mode only |




## Notes:

1. All timing parameters referenced to 1.5 V , except $t_{H Z X}$ and $t_{\text {SOFF }}$, which reference a high impedance state.
2. The $\mathbf{2 0}$ timeslot minimum insures that the complete A/D conversion will take place under any combination of recelve interrupt or asynchronous operation of the Codec. Consult an Intel applications specialist or Intel Corporation for applications information which would allow operation with less than 20 timeslots.


Notes:

1. All timing parameters referenced to 1.5 V , except $\mathrm{t}_{\mathrm{HZX}}$ and $\mathrm{t}_{\text {SOFF }}$ which reference a high impedance state.

## 2912A <br> PCM TRANSMIT/RECEIVE FILTER

- Low Power Consumption: 60 mW Typical without Power Amplifiers
80mW Typical with Power Amplifiers 0.5mW Typical Standby
- Low Idle Channel Noise: 2 dBrnc0 Typical, Receive 6 dBrnc0 Typical, Transmit
- Excellent Power Supply Rejection: 40dB Typical on VCC @ 50kHz 30dB Typical on VBB @ 50kHz
- High Pass Filter Rejects Low Frequency Noise: 23dB @ 60Hz 25dB @ 50Hz
50dB @ 16Hz
- Adjustable Gain in Both Directions
- Fully Compatible with the Industry Standard Intel 2912
- D3/D4 and CCITT G712 Compatible
- Common Mode Op Amp Input Rejection 75dB Typical
- Direct Interface to the Intel 2910A/2911A PCM Codecs Including Stand-By Power Down Mode
- Direct Interface with Transformer or Electronic Hybrids
- Fabricated with Reliable N-Channel MOS Process

The Intel 2912A 2nd generation PCM line filter is a fully integrated monolithic device containing the two filters of a PCM line or trunk termination. It has improved key parameters of power consumption, idle channel noise, and power supply rejection. A single part exceeds both AT\&T D3/D4 and CCITT transmission specs, exceeds digital Class 5 central office switching system stringent specifications, and is fully compatible with the 2912. The primary application for the 2912A is in telephone systems for transmission, switching, or remote concentration.

An advanced version of the switched capacitor technique used for the 2912 is used to implement the transmit and receive passband filter sections of the 2912A. The device is fabricated using Intel's reliable two layer polysilicon gate NMOS technology. (See Intel Reliability Report RR-24 on the 2910A, 2911A, and 2912.) The combination of advances in the switched capacitor techniques first used on the 2912 and the NMOS technology results in a monolithic 2912A filter which is packaged in a standard 16-pin DIP.


Figure 1. Block Diagram


PIN NAMES


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin <br> No. | Function | Description |
| :---: | :---: | :---: | :---: |
| VFXI+ | 1 | 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 frequency rejection and the antialiasing filters before being sent to the Codec for encoding. |
| VFxI- | 2 | Input | Inverting input of the gain adjustment operational amplifier on the transmit filter. |
| GSX | 3 | Output | Output of the gain adjustment operational amplifier on the transmit filter. Used for gain setting of the transmit filter. |
| $\mathrm{VF} \mathrm{R}^{\mathrm{O}}$ | 4 | 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 PWRO+ and PWRO-. |
| PWRI | 5 | Input | Input to the power driver amplifiers on the receive side for interface to transformer hybrids. High impedance input. When tied to $\mathrm{V}_{\mathrm{BB}}$, the power amplifiers are powered down. |
| PWRO+ | 6 | Output | Non-inverting side of the power amplifiers. Power driver output capable of directly driving transformer hybrids. |
| PWRO- | 7 | Output | Inverting side of the power amplifiers. Power driver output capable of directly driving transformer hybrids. |
| $V_{\text {BB }}$ | 8 | Power | $-5 \mathrm{~V} \pm 5 \%$ referenced to GRDA |
| $\mathrm{V}_{\mathrm{CC}}$ | 9 | Power | $+5 \mathrm{~V} \pm 5 \%$ referenced to GRDA |


| Symbol | Pin <br> No. | Function | Description |
| :---: | :---: | :---: | :---: |
| $V F_{R}{ }^{\prime}$ | 10 | 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 2910A and 2911A Codecs. |
| GRDD | 11 | Ground | Digital ground return for internal clock generator. |
| CLK ${ }^{(1)}$ | 12 | Input | Clock input. Three clock frequencies can be used: <br> $1.536 \mathrm{MHz}, 1.544 \mathrm{MHz}$ or 2.048 MHz ; pin 14, CLKO, has to be strapped accordingly. High impedance input, TTL voltage levels. |
| PDN | 13 | Input | Control input for the stand-by power down mode. An internal pull up to +5 V is provided for interface to the Intel 2910A and 2911A PDN outputs. TTL voltage levels. |
| CLKO ${ }^{(1)}$ | 14 | Input | Clock (pin 12, CLK) frequency selection. If tied to VBB, CLK should be 1.536 MHz . If tied to Ground, CLK should be 1.544 MHz . If tied to $\mathrm{V}_{\mathrm{CC}}, \mathrm{CLK}$ should be 2.048 MHz . |
| GRDA | 15 | Ground | Analog return common to the transmit and receive analog circuits. Not connected to GRDD internally. |
| VFXO | 16 | Output | Analog output of the transmit filter. The output voltage range is directly compatible with the Intel 2910A and 2911A Codecs. |

NOTE:

1. The three clock frequencies are directly compatible with the Intel 2910A and 2911A Codecs. The following table should be observed in selecting the clock frequency.

| Codec Clock | Clock Bits/Frame | CLK, Pin 12 | CLK0, Pin 14 |
| :---: | :---: | :---: | :---: |
| 1.536 MHz | 192 | 1.536 MHz | VBB (-5V) |
| 1.544 MHz | 193 | 1.544 MHz | GRDD |
| 2.048 MHz | 256 | 2.048 MHz | VCC $(+5 \mathrm{~V})$ |

## FUNCTIONAL DESCRIPTION

The 2912A provides the transmit and receive filters found on the analog 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 Sinx/x correction necessary to interface the Intel 2910A ( $\mu$ Law) and 2911A (A Law) Codecs which have a non-return-tozero 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 2912A and can be directly controlled by the 2910A/ 2911A Codecs.

The 2912A can interface directly with a transformer hybrid ( 2 to 4 wire conversion) or with electronic hybrids; in the latter case the power dissipation is reduced by powering down the output amplifier provided on the 2912A.


Figure 3. Typical Line Termination

## 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 3000 and a unity gain bandwidth of 1 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 25 pF . The input signal on lead 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 d B$ in the pass band.


Figure 4. Transmit Filter Gain Adjustment

## Receive Filter Output

The $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ lead is capable of driving high impedance electronic hybrids. The gain of the receive section from $V F_{R}$ l to $V F_{R} \mathrm{O}$ is:

$$
\frac{\left(\frac{\pi f}{8000}\right)}{\operatorname{Sin}\left(\frac{\pi f}{8000}\right)}
$$

which when multiplied by the output response of the Intel 2910A and 2911A 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{R}_{\mathrm{T}}$ on $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ should not be less than $10 k \Omega$.

## 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 VF $\mathrm{RO}^{\mathrm{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 PWRO+ and PWRO-, the maximum voltage swing across the load is $\pm 5.0$ volts. The series combination of RS 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.

When the power amplifier is not needed it should be deactivated to save power. This is accomplished by tying the PWRI pin to $V_{B B}$ before the device is powered up.

## Power Down Mode

Pin 13, PDN, provides the power down control. When the signal on this lead is brought high, the 2912A goes into a standby, power down mode. Power dissipation is reduced to 0.5 mW . In the stand-by mode, all outputs go into a high impedance state. This feature allows multiple 2912As to drive the same analog bus on a time-shared basis.


Figure 5. Receive Filter Output Gain Adjustment


Figure 6. Typical Connection of Output Driver Amplifier

When power is restored, the settling time of the 2912A is typically 15 ms .
The PDN interface is directly compatible with the Intel 2910A and 2911A PDN 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.

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}$ |  |
| Supply Voltage with Respect to VBB ... -0.3 V to +14.0 V |  |
| All Input and Output Voltages with |  |
| Respect to $\mathrm{V}_{\mathrm{BB}}$ | -0.3V to +14.0V |
| ll Output Currents | $\pm 50 \mathrm{~mA}$ |
| er Dissipat |  |

*NOTICE: 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 condi-
tions for extended periods may affect device reliability.

## D.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 \% ; \mathrm{V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%$; GRDA $=0 \mathrm{~V}$; GRDD $=0 \mathrm{~V}$; unless otherwise specified.)

DIGITAL INTERFACE (CLK, CLKO, and PDN Pins)

| Symbol | Parameter | Min | Typ ${ }^{(1)}$ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LIIC | Input Load Current, CLK |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {IL }}$ MIN to $V_{\text {IH }}$ MAX |
| ILIO | Input Load Current, CLKO |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {BB }}$ to $\mathrm{V}_{\text {IH }}$ MAX |
| ILIP | Input Load Current, PDN |  |  | -100 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {IL }}$ MIN to $V_{\text {IH }}$ MAX |
| $V_{\text {IL }}$ | Input Low Voltage (except CLKO) |  |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (except CLKO) | 2.0 |  |  | V |  |
| VILO | Input Low Voltage, CLK0 | $V_{B B}$ |  | $\mathrm{V}_{\mathrm{BB}}{ }^{+0.5}$ | V |  |
| $V_{110}$ | Input Intermediate Voltage, CLKO | $\mathrm{GRDD}^{-0.5}$ |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IHO }}$ | Input High Voltage, CLKO | $\mathrm{VCC}^{-0.5}$ |  | VCC | V |  |

## POWER DISSIPATION

| Symbol | Parameter | Min | Typ ${ }^{(1)}$ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I'CO0 | $\mathrm{V}_{\text {CC }}$ Standby Current |  | 50 | 100 | $\mu \mathrm{A}$ | PDN $=\mathrm{V}_{\text {IH }} \mathrm{MIN}$ |
| IBB0 | $V_{\text {BB }}$ Standby Current |  | 50 | 100 | $\mu \mathrm{A}$ | PDN $=\mathrm{V}_{\text {IH }}$ MIN |
| ${ }^{\text {ICC1 }}$ | $\mathrm{V}_{\mathrm{CC}}$ Operating Current, Power Amplifiers Inactive |  | 6 | 10 | mA | PWRI $=V_{\text {BB }}$ |
| IBB1 | VBB Operating Current, Power Amplifiers Inactive |  | 6 | 10 | mA | PWRI $=V_{\text {BB }}$ |
| ICC2 | VCC Operating Current |  | 8 | 14 | mA |  |
| IBB2 | VBB Operating Current |  | 8 | 14 | mA |  |

NOTE:

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

## D.C. CHARACTERISTICS

$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{C}}=+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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {IBXI }}$ | Input Leakage Current, $\mathrm{VFXI}^{+}$, VFXI- |  |  | 100 | nA | $-2.2 \mathrm{~V}<\mathrm{V}$ IN $<2.2 \mathrm{~V}$ |
| $\mathrm{R}_{1 \times 1}$ | Input Resistance, $\mathrm{VF}^{\text {I }}{ }^{1+}, \mathrm{VF} \mathrm{X}^{1-}$ | 10 |  |  | $\mathrm{M} \Omega$ |  |
| V OSXI | Input Offset Voltage, VFXI+, VFXI- |  |  | 25 | mV | $-2.2 \mathrm{~V}<\mathrm{V}_{\text {IN }}<2.2 \mathrm{~V}$ |
| CMRR1 | Common Mode Rejection, VFXI', VFXI- | 60 | 75 |  | dB | $-2.2 \mathrm{~V}<\mathrm{V}_{\mathrm{IN}}<-2.2 \mathrm{~V}, 0 \mathrm{dBmO} \equiv$ <br> 1.1V RMS, Input at VFXI- |
| $\mathrm{CMRR}_{2}$ | Common Mode Rejection, $\mathrm{VFXI}^{\text {l }}$, VFXI- | 40 |  |  | dB | -2.2V<ViN $<2.2 \mathrm{~V}$ |
| AVOL | DC Open Loop Voltage Gain, GSX | 3000 |  |  |  |  |
| ${ }^{\text {f }}$ C | Open Loop Unity Gain Bandwidth, GSX |  | 1 |  | MHz |  |
| VOXI | Output Voltage Swing, GSX | $\pm 2.5$ |  |  | V | $\mathrm{R}_{\mathrm{L}} \geqslant 10 \mathrm{k} \Omega$ |
| $C_{L X I}$ | Load Capacitance, GSX |  |  | 25 | pF |  |
| R ${ }_{\text {LXI }}$ | Minimum Load Resistance, GSX | 10 |  |  | $\mathrm{k} \Omega$ | Minimum $\mathrm{R}_{\mathrm{L}}$ |

ANALOG INTERFACE, TRANSMIT FILTER (See Figure 10)

| Symbol | Parameter | Min | Typ ${ }^{(1)}$ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ROX | Output Resistance, VFXO |  | 20 | 35 | $\Omega$ |  |
| Vosx | Output DC Offset, VFXO |  |  | 100 | mV | VFXI+ Connected to GRDA, Input Op Amp at Unity Gain |
| $\mathrm{PSRR}_{1}$ | Power Supply Rejection of $\mathrm{VCC}_{\mathrm{CC}}$ at $1 \mathrm{kHz}, \mathrm{VFXO}$ | 30 | 40 |  | dB | Note 2 |
| $\mathrm{PSRR}_{2}$ | Power Supply Rejection of $\mathrm{V}_{\mathrm{BB}}$ at $1 \mathrm{kHz}, \mathrm{VFXO}$ | 25 | 30 |  | dB | Note 2 |
| $C_{L X}$ | Load Capacitance, VFXO |  |  | 25 | pF |  |
| RLX | Minimum Load Resistance, VFXO | 10 |  |  | k $\Omega$ | Minimum $\mathrm{R}_{\mathrm{L}}$ |
| VOX | Output Voltage Swing, 1kHz, VFXO | $\pm 3.2$ |  |  | V | $R_{L} \geqslant 10 \mathrm{k} \Omega$ or with 2910A or 2911A |

ANALOG INTERFACE, RECEIVE FILTER (See Figure 9)

| Symbol | Parameter | Min | Typ ${ }^{(1)}$ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $I_{B R}$ | Input Leakage Current, $\mathrm{VF}_{\mathrm{R}}$ I |  |  | 3 | $\mu \mathrm{A}$ | $-3.2 \mathrm{~V}<\mathrm{V}_{\text {IN }}<3.2 \mathrm{~V}$ |
| RIR | Input Resistance, $\mathrm{VF}_{\mathrm{R}}$ I | 1 |  |  | $\mathrm{M} \Omega$ |  |
| ROR | Output Resistance, $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ |  |  | 100 | $\Omega$ |  |
| VOSR | Output DC Offset, VFRO |  |  | 100 | mV | VF $\mathrm{R}^{\prime}$ Connected to GRDA |
| $\mathrm{PSRR}_{3}$ | Power Supply Rejection of $\mathrm{V}_{\mathrm{CC}}$ at $1 \mathrm{kHz}, \mathrm{VF}_{\mathrm{R}} \mathrm{O}$ | 30 | 45 |  | dB |  |
| $\mathrm{PSRR}_{4}$ | Power Supply Rejection of $V_{B B}$ at $1 \mathrm{kHz}, \mathrm{VF}_{\mathrm{R}} \mathrm{O}$ | 30 | 35 |  | dB |  |
| CLR | Load Capacitance, $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ |  |  | 25 | pF |  |
| $\mathrm{R}_{\mathrm{LR}}$ | Minimum Load Resistance, $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ | 10 |  |  | $\mathrm{k} \Omega$ | Minimum $\mathrm{R}_{\mathrm{L}}$ |
| $\mathrm{V}_{\text {OR }}$ | 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 $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply values. 2. $\mathrm{PSRR}_{1,2}$ include input op amp in transmit section.

## 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}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%$; GRDA $=0 \mathrm{~V}$; GRDD $=0 \mathrm{~V}$; unless otherwise specified.)

## ANALOG INTERFACE, RECEIVE FILTER DRIVER AMPLIFIER STAGE

| Symbol | Parameter | Min | Typ ${ }^{(1)}$ | Max | Unit | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IBRA | Input Leakage Current, PWRI |  |  | 3 | $\mu \mathrm{A}$ | $-3.2 \mathrm{~V}<\mathrm{V}_{\text {IN }}<3.2 \mathrm{~V}$ |  |
| RIRA | Input Resistance, PWRI | 10 |  |  | $\mathrm{M} \Omega$ |  |  |
| RORA | Output Resistance, PWRO+, PWRO- |  | 1 |  | $\Omega$ | $\begin{aligned} & \|I \mathrm{OUT}\|<10 \mathrm{~mA} \\ & -3.0 \mathrm{~V}<\mathrm{V}_{\text {OUT }}<3.0 \mathrm{~V} \\ & \hline \end{aligned}$ |  |
| VOSRA | Output DC Offset, PWRO+, PWRO- |  |  | 50 | mV | PWRI Connected to GRDA |  |
| CLRA | Load Capacitance, PWRO+, PWRO- |  |  | 100 | pF |  |  |
| VORA1 | Output Voltage Swing Across RL, PWRO+, PWRO- Single Ended Connection | $\pm 3.2$ |  |  | V | $R_{L}=10 \mathrm{k} \Omega$ | RLConnected to GRDA |
|  |  | $\pm 2.9$ |  |  | V | $R_{L}=600 \Omega$ |  |
|  |  | $\pm 2.5$ |  |  | V | $\mathrm{R}_{\mathrm{L}}=300 \Omega$ |  |
| Vora2 | Differential Output Voltage Swing, PWRO+, PWRO- <br> Balanced Output Connection | $\pm 6.4$ |  |  | V | $R_{L}=20 \mathrm{k} \Omega$ | RL Connected Between PWRO+ and PWRO- |
|  |  | $\pm 5.8$ |  |  | V | $R_{L}=1200 \Omega$ |  |
|  |  | $\pm 5.0$ |  |  | V | $R_{L}=600 \Omega$ |  |


Clock Input Frequency: $C L K=1.536 \mathrm{MHz} \pm 0.1 \% ;$ CLKO $=\mathrm{V}_{\mathrm{ILO}}$ (Tied to $\mathrm{V}_{\mathrm{BB}}$ ) $\quad \mathrm{CLK}=2.048 \mathrm{MHz} \pm 0.1 \% ; \mathrm{CLKO}=\mathrm{V}_{\mathrm{IHO}}$ ( Tied to $\mathrm{V}_{\mathrm{CC}}$ ) $C L K=1.544 \mathrm{MHz} \pm 0.1 \% ;$ CLKO $=V^{1} 10$ (Tied to GRDD)

TRANSMIT FILTER TRANSFER CHARACTERISTICS (See Transmit Filter Transfer Characteristics, Figure 7)

| Symbol | Parameter | Min | Typ ${ }^{(1)}$ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{GRXX}^{\text {l }}$ | Gain Relative to Gain at 1kHz |  |  |  |  | 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 |
|  | 16.67 Hz |  | -56 | -50 | dB |  |
|  | 50 Hz |  |  | -25 | dB |  |
|  | 60 Hz |  |  | -23 | dB |  |
|  | 200 Hz | -1.0 |  | -0.125 | dB |  |
|  | 300 Hz to 3000 Hz | -0.125 |  | 0.125 | dB |  |
|  | 3300 Hz | -. 35 |  | 0.03 | dB |  |
|  | 3400 Hz | -0.7 |  | -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{R}_{\mathrm{L}}=\infty$, Note 3 |
| $\mathrm{G}_{\text {AXT }}$ | Gain Variation with Temperature at 1 kHz |  | . 0002 | . 002 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | OdBmO Signal Level |
| GAXS | Gain Variation with Supplies at 1 kHz |  | . 01 | . 07 | dB/V | 0dBmO Signal Level, Supplies $\pm 5 \%$ |
| CTRT | Cross Talk, Receive to Transmit, Measured at $\mathrm{VFXO}_{\mathrm{X}}$ $20 \log \frac{V F_{X O}}{V F_{R} O}$ |  | -75 | -65 | dB | $\mathrm{VF}_{\mathrm{R}} \mathrm{I}=1.6 \mathrm{~V}_{\mathrm{RMS}}, 1 \mathrm{kHz}$ Input VFxI+, VFxi-Connected to GSX, GSX Connected through $10 \mathrm{k} \Omega$ to GRDA |
| $\mathrm{N}_{\mathrm{CX} 1}$ | Total C Message Noise at Output, VFXO |  | 6 | 11 | $\underset{\|2\|}{\mathrm{dBrncO}}$ | Gain Setting Op Amp at Unity Gain |
| $\mathrm{N}_{\mathrm{CX} 2}$ | Total C Message Noise at Output, VFxO |  | 9 | 13 | $\begin{array}{\|c\|} \hline \text { dBrnco } \\ \|2\| \end{array}$ | Gain Setting Op Amp at 20 dB Gain- |
| DDX | Differential Envelope Delay, VFxO 1 kHz to 2.6 kHz |  |  | 60 | $\mu \mathrm{S}$ |  |
| DAX | Absolute Delay at $1 \mathrm{kHz}, \mathrm{VFXO}$ |  |  | 110 | $\mu \mathrm{s}$ |  |
| $\mathrm{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 dBmO at $\mathrm{VFXO}_{\mathrm{X}}$ |  |  | -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 $\mathrm{VFXO}_{\mathrm{X}}$ is $2.26 \mathrm{~V}_{\mathrm{RMS}}$ |

See next page for NOTES.

## A.C. CHARACTERISTICS

( $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{C}}=+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.)
Clock Input Frequency: CLK $=1.536 \mathrm{MHz} \pm 0.1 \% ; \mathrm{CLKO}=\mathrm{V}_{\mathrm{IL}} 0$ (Tied to $\mathrm{V}_{\mathrm{BB}}$ )
$C L K=1.544 \mathrm{MHz} \pm 0.1 \% ;$ CLKO $=\mathrm{V}_{110}$ (Tied to GRDD) CLK $=2.048 \mathrm{MHz} \pm 0.1 \% ;$ CLKO $=\mathrm{V}_{\mathrm{IHO}}$ (Tied to $\mathrm{V}_{\mathrm{CC}}$ )

RECEIVE FILTER TRANSFER CHARACTERISTICS (See Receive Filter Transfer Characteristics, Figure 8)

| Symbol | Parameter | Min | Typ ${ }^{(1)}$ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| GRR | Gain Relative to Gain at 1 kHz with Sinx/x Correction of 2910A or 2911A |  |  |  |  | $\begin{aligned} & \text { OdBmO Input Signal } \\ & \text { OdBmO Signal } \equiv 1.6 \text { VRMS } x \\ & \operatorname{Sin}\left(\frac{\pi f}{8000}\right)\left(\frac{\pi f}{8000}\right) \\ & \text { Input at VF }{ }^{\text {I }} \text { I } \end{aligned}$ |
|  | Below 200Hz |  |  | 0.125 | dB |  |
|  | 200 Hz | -0.5 |  | 0.125 | dB |  |
|  | 300 Hz to 3000 Hz | -0.125 |  | 0.125 | dB |  |
|  | 3300 Hz | -. 35 |  | 0.03 | dB |  |
|  | 3400 Hz | -0.7 |  | -0.1 | dB |  |
|  | 4000 Hz |  |  | -14 | dB |  |
|  | 4600 Hz and Above |  |  | -30 | dB |  |
| GAR | Absolute Passband Gain at $1 \mathrm{kHz}, \mathrm{VF}_{\mathrm{R}} \mathrm{O}$ | -0.1 | 0 | +0.1 | dB | $\mathrm{R}_{\mathrm{L}}=\infty$, Notes 3, 4 |
| $\mathrm{GART}^{\text {AR }}$ | Gain Variation with Temperature at 1 kHz |  | . 0002 | . 002 | $\mathrm{dB} /{ }^{\circ} \mathrm{C}$ | OdBmO Signal Level |
| GARS | Gain Variation with Supplies at 1 kHz |  | . 01 | . 07 | dB/V | $\begin{aligned} & \text { OdBmO Signal Level, Supplies } \\ & \pm 5 \% \end{aligned}$ |
| CTTR | Cross Talk, Transmit to Receive, Measured at $\mathrm{VF}_{\mathrm{RO}} ; 20 \log \left(\mathrm{VF}_{\mathrm{R}} \mathrm{O} / \mathrm{VF} \mathrm{XO}^{\mathrm{O}}\right)$ |  | -70 | -60 | dB | $V F_{X I}=1.1 \mathrm{~V}_{\text {RMS }}, 1 \mathrm{kHz}$ Output VF $\mathrm{R}^{\prime}$ Connected to GRDA |
| NCR | Total C Message Noise at Output, $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ |  | 2 | 6 | dBrnc0 [2] | VFRO Output or PWRO+ and PWRO- Connected with Unity Gain |
| DDR | Differential Envelope Delay, $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$, 1 kHz to 2.6 kHz |  |  | 100 | $\mu \mathrm{S}$ |  |
| DAR | Absolute Delay at $1 \mathrm{kHz}, \mathrm{VF}_{\mathrm{R}} \mathrm{O}$ |  |  | 110 | $\mu \mathrm{S}$ |  |
| $\mathrm{DP}_{\mathrm{R} 1}$ | Single Frequency Distortion Products |  |  | -48 | dB | OdBm Input Signal at 1kHz |
| $\mathrm{DP}_{\mathrm{R} 2}$ | Single Frequency Distortion Products at Maximum Signal Level of +3 dBmO at $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ |  |  | -45 | dB | +3dBmO Signal Level of 2.26 VRMS, 1 kHz Input at $\mathrm{VF}_{\mathrm{R}} \mathrm{O}$ |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2. A noise measurement of 12 dBrnc into a $600 \Omega$ load at the 2912 A device is equivalent to 6 dBrnc 0 .
3. For gain under load refer to output resistance specs and perform gain calculation.
4. Output is non-inverting.

## TRANSFER CHARACTERISTICS



Figure 7. Transmit Filter


NOTES: 1 TYPICAL TRANSFER FUNCTION OF THE RECEIVE FILTER AS A SEPARATE COMPONENT.
TYPICAL. TRANSFER FUNCTION OF THE RECEIVE FILTER DRIVENBY THE SAMPLE AND
HOLD OUTPUT OF THE INTEL 2910 A AND 2911 A CODECS. THE COMBINED FILTER/CODEC response meets the stated specifications.

Figure 8. Receive Filter

POWER SUPPLY REJECTION TYPICAL VALUES OVER 3 RANGES


Figure 9. Receive Filter


Figure 10. Transmit Filter

APPLICATIONS (Circuit Interface)


Figure 11. A Typical 2910A Codec and 2912A Filter Configuration

## Codec Interface

The 2912A PCM Filter is designed to directly interface to the 2910A and 2911A Codecs as shown above. The transmit path is completed by connecting the VFXO output of the 2912A to the coupling capacitor associated with the VFX input of the 2910A and 2911A codecs. The receive path is completed by directly connecting the codec output $V F_{R}$ to the receive input of the 2912A VFRI. The PDN input of the 2912A should be connected to the PDN 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 2912A should be connected to the same clock provided to the receive bit clock, CLKR of 2910A or 2911A Codec as shown above. The CLK0 input of the 2912A 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.

## Layout Guidelines

The most important steps in designing a low noise line card are to insure that the layout of the circuit components and traces result in a minimum of cross coupling between analog and digital signals, and to provide well bypassed and clean power supplies, solid ground planes, and minimal lead lengths between components. Considering these items in more detail:

- All power source leads should be bypassed to ground on each printed circuit board (PCB), on which codecs are provided. At least one electrolytic bypass capacitor (approx. 50 microfarad) per board is recommended at the point where each power trace from the codec and filter joins prior to interfacing with the edge connector pins assigned to the power leads.
- Layout the traces on codec and filter equipped boards such that analog signal and capacitor leads are separated as widely as possible from the digital clock and data leads.
- Position the codec sample and hold capacitor as close to the codec as possible, and connect it with leads as short as possible.
- Do not layout any board traces (especially digital) that pass between or near the leads of the sample and hold capacitor(s) since they are in high impedance circuits which are sensitive to noise coupling.
- Keep analog traces situated in their layouts so that no intervening circuit leads are permitted to run parallel to or between them.
- The optimum grounding configuration is to maintain separate digital and analog grounds on the circuit boards, and to carry these grounds back to the power supply ground with a low impedance connection. This keeps the grounds separate over the entire system except at that one location.
- The voltage difference between ground leads GRDA and GRDD (analog and digital ground) should not exceed two volts. One method of preventing any
substantial voltage difference between leads GRDA and GRDD is to connect two diodes back to back in opposite directions across these two ground leads on each codec.
- Codec-filter pairs should be aligned so that pins 9 through 16 of the filter face pins 1 through 12 of the codec. This minimizes the distance for analog connections between devices and prevents crossing analog lines.
- No digital lines or high level analog lines should run under or in parallel with analog interconnections from codec to filter. If the analog lines are on top (component side) of the PCB, then GRDD, GRDA, or power supply leads should be directly under them, on the bottom of the PCB (to prevent analog/ digital coupling).
- Both the codec and filter devices should be shielded from traces on the bottom of the PCB by using ground or power supply leads on the top side directly under the device (like a ground plane).
- For each printed circuit board, two +5 volt power supply leads should be used, one for codecs and the other for filters, and separately decoupled where they join a single 5 volt supply at the PCB connector. Decoupling can be accomplished with a RClowpass filter or a RF choke per power supply input. Both grounds and power leads must have low resistance and inductance which can be accomplished by using a ground plane whenever possible. If narrower traces must be used, maintain a minimum width of 4 millimeters and use multiple or extra large plated holes when passing ground connections through the PCB.
- The 2912A PCM filter should have all power supplies bypassed to analog ground (GRDA). The 2910A/ 11 A codec +5 V power supplies should be bypassed to the digital ground (GRDD) but the -5 V and +12 V supplies should be bypassed to analog ground (GRDA).


# 2913 and 2914 Combined Single Chip PCM Codec and Filter 

## 2914 Asynchronous clocks, 8th bit signaling, loop back test capability 2913 Synchronous clocks only

## AT\&T D3/D4 and CCITT Compatible

\author{

- Two Timing Modes: <br> - Fixed Data Rate Mode: <br> Clock Options: 1.536 MHz , 1.544 MHz, 2.048 MHz <br> - Variable Data Mode: 64 kHz-4.096 MHz
}


## - No External Components for Sample and Hold and Auto Zero Functions <br> - Precision On-Chip Voltage References <br> - Low Power Dissipation: <br> 10 mW Typical Standby <br> 175 mW Typical Operating <br> - Compatible with Intel Direct Mode 2910A, 2911A and 2912A

## - Excellent Power Supply Rejection Eliminates On-Board Regulator

## - Pin Selectable $\mu$-Law or A-Law Operation

The Intelब 2913 and 2914 are fully integrated PCM (pulse code modulation) codecs (coder-decoder) and transmit/ receive filters fabricated in a highly reliable and proven N -channel MOS silicon gate technology. These devices provide the functions that were formerly provided by two complex chips (2910A or 2911A and 2912A). Besides the higher level of integration the performance of the 2913 and 2914 is superior to that of the separate devices.
The primary applications for the 2913 and 2914 are in telephone systems:

- Switching-2913-Digital PBX's and Central Office Switching Systems
- Transmission-2914-D3/D4 Channel Banks
- Concentration-2913 or 2914-Subscriber Carrier and Concentrators

The wide dynamic range of the 2913 and $2914(78 \mathrm{~dB}$ ) and the minimal conversion time make them ideal products for other applications such as:

- Data Acquisition - Secure Communications Systems
- Telemetry
- Signal Processing Systems


Figure 1. Pin Configuration


Figure 2. Block Diagram

Table 1. Pin Names

| $V_{B B}$ | Power (-5V) | GS ${ }_{\text {x }}$ | Gain Control |
| :---: | :---: | :---: | :---: |
| PWRO+, PWRO- | Power Amplifier Outputs | VF $\mathrm{XI}^{\prime}$-, VFXI+ | Analog Inputs |
| $\mathrm{GS}_{\mathrm{R}}$ | Gain Setting Input for | GRDA | Analog Ground |
|  | Receive Channel | NC | No Connect |
| $\overline{\text { PDN }}$ | Power Down Select | $\mathrm{SIG}_{X}$ | Transmit Digital Signaling |
| CLKO | Master Clock Select |  | Input |
| LOOP | Analog Loop Back | ASEL | $\mu$ - or A-law Select |
| $\mathrm{SIG}_{R}$ | Signaling Bit Output | $\overline{T S}_{X}$ | Digital Output - Timeslot <br> Strobe |
| $\mathrm{DCLK}_{R}$ | Receive Data Rate Clock |  | Strobe |
| $\mathrm{D}_{\mathrm{R}}$ | Receive Channel Input | $\mathrm{DCLK}_{\mathrm{x}}$ | Transmit Data Rate Clock |
| $\mathrm{FS}_{\mathrm{R}}$ | Receive Frame Synchronization Clock | $\begin{aligned} & \mathrm{D}_{\mathrm{X}} \\ & \mathrm{FS}_{\mathrm{X}} \end{aligned}$ | Transmit (Digital) Output Transmit Frame Synchroniza- |
| TS $\mathrm{R}^{\prime}$ | Receive Frame Synchronization and Timeslot | TS ${ }_{\text {X }}$ | tion Clock <br> Transmit Frame Synchroniza- |
| GRDD | Digital Ground |  | tion and Timeslot Strobe |
| $V_{\text {cc }}$ | Power (+5V) | CLK ${ }_{\text {x }}$ | Transmit Master Clock |
|  |  | $\mathrm{CLK}_{\mathrm{R}}$ | Receive Master Clock |

2913 and 2914

Table 2. Pin Description

| Symbol | Pin Number |  | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
|  | 2913 | 2914 |  |  |
| $\mathrm{V}_{\mathrm{BB}}$ | 1 | 1 | Power | -5V, $\pm 5 \%$ |
| PWRO + | 2 | 2 | Output | Non-inverting output of power amplifier. Capable of directly driving transformer hybrids or high impedance loads, either single ended or differentially. |
| PWRO - | 3 | 3 | Output | Inverting output of power amplifier. Capable of directly driving transformer hybrids or high impedance loads, either single ended or differentially. |
| $\mathrm{GS}_{\mathbf{R}}$ | 4 | 4 | Input | Input to gain setting network on the receive side of filter. See Receive Output Amplifier and Gain Setting sections for details. |
| $\overline{\text { PDN }}$ | 5 | 5 | Input | Power down select. When at a TTL low level, the device is in low power standby state; when at a TTL high, the device is active. |
| CLKO | 6 | 6 | Pinstrap | Input which must be pinstrapped to reflect the input master clock frequency CLK $_{X}$, CLK $_{R}$. |
| LOOP |  | 7 | Input | Analog loop back. When this pin is TTL high, receive output (PWRO + ) is internally connected to $\mathrm{VF}_{\mathrm{X}} \mathrm{I}+, \mathrm{GS}_{\mathrm{R}}$ is internally connected to PWRO + , and VFXI - is internally connected to GS $_{x}$. |
| SIG ${ }_{\text {R }}$ |  | 8 | Output | Signaling bit output. SIG $_{\mathrm{R}}$ reflects the logical state of the 8th bit of the received PCM word in the most recent receive signaling frame when $\mathrm{DCLK}_{R}=\mathrm{V}_{\mathrm{BB}} . \mathrm{SIG}_{\mathrm{R}}$ is held low while the device is in the low power standby state. |
| $\mathrm{DCLK}_{R}$ | 7 | 9 | Input | Selects fixed or variable data rate mode. <br> To select the variable data rate mode, this pin must be the bit clock for the receive PCM highway. Also $\mathrm{TS}_{\mathrm{R}} \mathrm{I}, \mathrm{TS}_{\mathrm{X}} \mathrm{I}$ and DCLK $\mathrm{K}_{\mathrm{X}}$ must have the appropriate inputs. Data is received on eight consecutive negative transitions occurring while $\mathrm{TS}_{\mathbf{R}}$ I is high. Data can be clocked at any frequency from 64 kHz to 4.096 MHz . <br> To select the fixed rate mode DCLK $\mathrm{R}_{\mathrm{R}}$ must be connected to $\mathrm{V}_{\mathrm{BB}}$. Then 2910A or 2911A type timing is used and $\mathrm{FS}_{\mathrm{R}}, \mathrm{FS}_{\mathrm{X}}$, and $\mathrm{TS}_{\mathrm{X}}$ must have the appropriate inputs. |
| $\mathrm{D}_{\mathrm{R}}$ | 8 | 10 | Input | Receive channel input from the PCM highway data bus. PCM data is clocked in on this lead. In the fixed data rate mode, CLK $_{R}$ acts as the bit clock; in the variable data rate mode, DCLK ${ }_{R}$ becomes the bit clock. |
| $\mathrm{FS}_{\boldsymbol{R}} / \mathrm{TS}_{\mathbf{R}} \mathrm{l}$ | 9 | 11 | Input | In the fixed data rate mode, this pin is the receive synchronization clock. It defines the beginning of the receive timeslot on the receive PCM highway; the width of $\mathrm{FS}_{\mathrm{R}}$ is used to distinguish between signaling and non-signaling frames for the receive channel. <br> In variable data rate mode, this pin ( $\left.\mathrm{TS}_{\mathrm{R}} \mathrm{I}\right)$ defines the duration of the receive timeslot. <br> The device enters the standby state whenever $\mathrm{FS}_{X}$ and $\mathrm{FS}_{R}$ are removed for several milliseconds. |
| GRDD | 10 | 12 | Ground | Digital ground return for all internal logic circuits. Not internally tied to GRDA. |

Table 2. PIn Description (Continued)

| Symbol | Pin Number |  | Type | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
|  | 2913 | 2914 |  |  |
| $\mathrm{CLK}_{\text {R }}$ | - | 13 | Input | Master and bit (data) clock for the fixed data rate mode and receive master clock only for the variable data rate mode. As a bit clock, PCM data is clocked in on 8 successive negative transitions of the bit clock beginning with the first negative transition following $\mathrm{FS}_{\mathrm{R}}$. |
| $\mathrm{CLK}_{\mathrm{X}}$ | 11 | 14 | Input | Master and bit (data) clock for the fixed data rate mode and transmit master clock only for the variable data rate mode. As a bit clock PCM data is clocked out on 8 successive positive transitions of the bit clock, beginning with the first transition following $\mathrm{FS}_{\mathrm{x}}$. |
| $\mathrm{FS}_{\mathrm{x}} / \mathrm{TS} \times 1$ | 12 | 15 | Input | In fixed data rate mode, this pin is the transmit frame synchronization clock. It defines the beginning of the transmit timeslot on the transmit PCM highway; the width of $\mathrm{FS}_{\mathrm{X}}$ is used to distinguish between signaling and non-signaling frames for the transmit channel. <br> In the variable data rate mode, this pin (TSXI) defines the duration of the transmit timeslot. <br> The device enters low power standby whenever $\mathrm{FS}_{\mathrm{X}}$ and $\mathrm{FS}_{\mathrm{R}}$ are removed (held low). |
| $\mathrm{D}_{\mathrm{x}}$ | 13 | 16 | Output | Transmit channel PCM data output. In fixed data rate mode, $D_{X}$ is active only while $\overline{\mathrm{TS}}_{\mathrm{x}}$ is low. In variable data rate mode, $\mathrm{D}_{\mathrm{x}}$ is active only while $T S_{x}$ is active and is clocked out at by DCLK $K_{x}$. |
| $\overline{\text { TS }}_{\text {I/DCLK }}$ X | 14 | 17 | Output/ Input | Transmit channel timeslot strobe or data rate clock for the transmit PCM highway. When DCLK $_{R}=V_{B B}$, this pin is an open drain output designed to be used as an enable signal for an offchip three-state buffer if buffering between $\mathrm{D}_{\mathrm{X}}$ and the transmit bus is desired. <br> When DCLK $_{R} \neq V_{B B}$, this pin defines the data rate to the tansmit PCM highway, and data is transmitted on eight consecutive negative transitions occurring while $\mathrm{TS}_{\mathrm{X}} \mathrm{I}$ is high. Data can be clocked at any frequency from 64 kHz to 4.096 MHz . |
| SIGX/ASEL | 15 | 18 | Input/ Pinstrap | A dual purpose pin. When externally pinstrapped to $\mathrm{V}_{\mathrm{BB}}$, A -law operation is selected. <br> For $\mu$-law operation this is a TTL level input, the logical state of which replaces the 8th bit (least significant bit, LSB) of the transmit PCM word in transmit signaling frames. |
| NC |  | 19 |  | No Connect |
| GRDA | 16 | 20 | Ground | Analog ground return for all internal voice circuits. Not internally connected to GRDD. |
| VF ${ }_{\text {x }}+$ | 17 | 21 | Input | Non-inverting analog input of uncommitted op amp. |
| VFFI- | 18 | 22 | Input | Inverting analog input of uncommitted op amp. |
| $\mathrm{GS}_{\mathrm{X}}$ | 19 | 23 | Input/ Output | Output terminal of on-chip uncommitted op amp. Internally, this pin is the voice signal input to the transmit filter. |
| $\mathrm{V}_{\text {cc }}$ | 20 | 24 | Power | + 5 V , $\pm 5 \%$ |

## FUNCTIONAL DESCRIPTION

The 2913 and 2914 provide the analog-to-digital and the digital-to-analog conversions and the transmit and receive filtering necessary to interface a full duplex (4 wires) voice telephone circuit with the PCM highways of a time division multiplexed (TDM) system. They are intended to be used at the analog termination of a PCM line or trunk.

The following major functions are provided:

- Bandpass filtering of the analog signals prior to encoding and after decoding
- Encoding and decoding of voice and call progress information
- Encoding and decoding of the signaling and supervision information


Figure 3. Typical Line Terminations

## TRANSMIT OPERATION

## Transmit Filter

The input section provides gain adjustment in the passband which is provided by an input operational amplifier. This operational amplifier has a common mode range of +2.2 volts, a DC offset of typically 25 mV , a voltage gain of typically 5000 , and a unity gain bandwidth of typically 1 MHz . Gain of up to 20 dB can be set without degrading the noise performance of the filter. The load impedance connected to the amplifier output must be greater than 10 K ohms in parallel with less than 50 pF . The input signal on lead $\mathrm{V} \mathrm{F}_{\mathrm{x}} \mathrm{I}+$ can be either AC or DC coupled. The input op amp can also be used in the Inverting mode or differential amplifier mode. (See Figure 4.)


Figure 4. Transmit Filter Gain Adjustment

A low pass anti-aliasing section is included on chip. This section typically provides 35 dB attenuation at the sampling frequency. No external components are required to provide the necessary anti-aliasing function for the switched capacitor section of the transmit filter.
The passband section provides flatness and stopband attenuation which fulfills the AT\&T® D3/D4 specification and the CCITT G. 712 recommendation. The 2913 and 2914 specifications meet the digital class 5 central office switching systems requirements. The transmit filter transfer characteristics and specifications will be within the limits shown in Figure 5.

A high pass section configuration was chosen to reject low frequency noise from 50 and 60 Hz power lines, 17 Hz European electric railroads, ringing frequencies and their harmonics, and other low frequency noise. Even though there is high rejection at these frequencies, the sharpness of the band edge gives low attenuation at 200 Hz . This feature allows the use of low cost transformer hybrids without external components. Transformer hybrids have difficulty in obtaining good coupling at low frequencies.

## Encoding

The encoder internally samples the output of the transmit filter and holds the sample on an internal sample and hold capacitor. An on-chip auto zero circuit corrects for DC offset. Thus, no external components are required to perform sample and hold and auto zero functions. In addition, a special circuit in the encoder will prevent the sign-bit from toggling under idie channel conditions, even though the auto zero function is still being performed.
After the encoding the PCM data are presented at the. $\mathrm{D}_{\mathrm{x}}$ pin on the first 8 bits of the frame.


Figure 5. Transmit Filter Transfer Characteristics

## RECEIVE OPERATION

## Decoding

The PCM word is serially fetched by the $D_{R}$ lead from the PCM highway at the proper timeslot occurrence. The decoded value is held on an internal sample and hold capacitor; no external receive sample and hold capacitor is needed.

## Receive Filter

The receive section of the filter provides a passband flatness and stopband rejection which fulfills the AT\& ${ }^{\top}$ D3/D4 specification and the CCITT G. 712 recommendation when used with a decoder which contains a sample and hold amplifier at its output. The filter contains the required compensation for the $\sin x / x$ response of such decoders. The receive filter transfer characteristics and specifications will be within the limits shown in Figure 6.

## Receive Output Power Amplifiers

A balanced output amplifier is provided in order to allow maximum flexibility in output configuration. Either of the two outputs PWRO + and PWRO - can be used single ended (referenced to GRDA) to drive single ended loads. Alternatively, the differential output will drive a bridged load directly. The output current drive capability is capable of driving loads as low as 300 ohms single ended or 600 ohms differentially.

The receive channel transmission level may be adjusted between specified limits by manipulation of the $\mathrm{GS}_{\mathrm{R}}$ input. $\mathrm{GS}_{\mathrm{R}}$ is internally connected to an analog gain setting network. When $\mathrm{GS}_{\boldsymbol{R}}$ is externally strapped to PWRO - , the receive transmission level is maximized; when tied to PWRO + , the transmission level is minimized. These transmission levels are specified in terms of the receive channel output under digital milliwatt conditions; that is, the rms 1 kHz output when the receive digital channel is receiving the 8 -bit code sequence specified in CCITT recommendation G.711. The output transmission level interpolates between these limits as $\mathrm{GS}_{\mathrm{R}}$ is interpolated (with a potentiometer) between PWRO + and PWRO - . The use of the output gain set is illustrated in Figure 7.

## Gain Setting Configurations To Adjust Receive Output Levels

PWRO + and PWRO - are low impedance complementary outputs. The voltages at the nodes are:

$$
\begin{aligned}
& \mathrm{Vo}^{+} \text {at PWRO+ } \\
& \mathrm{Vo}{ }^{-} \text {at PWRO- } \\
& \mathrm{Vo}=\mathrm{Vo}^{+}-\mathrm{Vo}^{-} \text {(total differential response) }
\end{aligned}
$$

$R_{1}$ and $R_{2}$ are a gain setting resistor network with the center tap connected to the $\mathrm{GS}_{\mathrm{R}}$ input.


Figure 6. Receive Filter Transfer Characteristics

A value greater than 10K ohms and less than 100K for $R_{1}+R_{2}$ is recommended because:
(a) The parallel combination of $R_{1}+R_{2}$ and $R_{L}$ sets the total loading
(b) The total capacitance at the $\mathrm{GS}_{\mathrm{R}}$ input and the parallel combination of $\mathbf{R}_{1}$ and $\mathbf{R}_{\mathbf{2}}$ define a time constant which has to be minimized to avoid inaccuracies
$\mathrm{V}_{\mathrm{A}}$ represents the maximum available digital milliwatt output response. ( $\mathrm{V}_{\mathrm{A}}=1.50 \mathrm{~V}_{\mathrm{RMS}}$ ).


Figure 7. Gain Setting Configuration
$V_{0}=-A V_{A}$
where $A=\frac{1 / 4}{1-3 / 4 \frac{R_{1} / R_{2}}{1+R_{1} / R_{2}}}$
For design purposes, a useful form is $R_{1} / R_{2}$ as a function of $A$.

$$
R_{1} / R_{2}=\frac{8 A-2}{-2 A+2}
$$

(Allowable values for $A$ are those which make $R_{1} / R_{2}$ positive.)

## Examples are:

If $A=1$, (maximum output) then
$R_{1} / R_{2}=\infty$ or $V\left(G S_{R}\right)=\mathrm{Vo}^{-}$; i.e., $\mathrm{GS}_{\mathrm{R}}$ is tied to PWRO-
If $A=1 / 2$, then

$$
R_{1} / R_{2}=2
$$

If $A=1 / 4$, (minimum output) then

$$
R_{1} / R_{2}=0 \text { or } V\left(G_{R}\right)=V_{0}+\text {; i.e., } G_{R} \text { is tied to PWRO }+
$$

## GENERAL OPERATION

## Fixed Timing Mode

Fixed data rate timing, which is 2910A and 2911A compatible, is selected by connecting DCLK ${ }_{R}$ to $V_{B B}$. It employs the frame synchronization clocks $\mathrm{FS}_{X}$ and $\mathrm{FS}_{R^{\prime}}$, master clocks CLK R $_{\text {a }}$ and CLKX, and output TS ${ }_{x}$. On a non-signaling frame on the transmit side, the codec section encodes the analog signal into an 8-bit PCM word at the frame rate $\mathrm{FS}_{\mathrm{x}}$. This word is then gated by $\mathrm{TS}_{\mathrm{x}}$ onto the PCM highway ( $\mathrm{D}_{\mathrm{x}}$ lead). This encoding follows either the $\mu$-law or A-law conversion algorithms.
On the receive side in a non-signaling frame, the codec section decodes the incoming PCM data word into an analog voltage at the frame rate FSx. It is then held on an internal sample and hold capacitor.
The frequency of CLK ${ }_{X}$ and CLK $_{R}$, which serve both as master clocks to operate the codec and filter and bit clocks to clock-in the data, is selected by the CLKO pin to be either $1.544 \mathrm{MHz}, 2.048 \mathrm{MHz}$, or 1.536 MHz . No other frequency of operation is allowed in the fixed data rate mode.

## Variable Timing Mode

Variable data rate timing is selected by connecting $\mathrm{DCLK}_{\mathrm{R}}$ to the bit clock for the receive PCM highway rather than to $\mathrm{V}_{\mathrm{BB}}$. It employs frame synchronization clocks TS $_{R}$ I and TS ${ }_{X}$ I, bit clocks DCLK ${ }_{R}$ and DCLK ${ }_{X}$, and master clocks CLK $_{X}$ and CLK $\mathrm{R}_{\mathrm{R}}$. Variable data rate timing allows for a flexible data frequency. It provides the ability to vary the frequency of the bit clocks, which can be asynchronous as in the case of the 2914 or synchronous
 frame synchronization clocks (replacing $\mathrm{FS}_{\mathrm{X}}$ and $\mathrm{FS}_{\mathrm{R}}$ ). DCLK $_{R}$ and DCLK $X$ become the data rate clocks for the receive and transmit PCM highway. While TS $x$ I is high, PCM data from $D_{X}$ is transmitted onto the highway upon the next eight consecutive positive transitions of DCLK ${ }_{x}$. Similarly, while TS $_{R} l$ is high, each PCM bit from the highway is received by $D_{R}$ on the next eight consecutive negative transitions of DCLK ${ }_{R}$. In this way, the PCM data rates for both transmit and receive are variable; hence, it is called variable data rate timing. The PCM data rate can be varied from 64 kHz to 4.096 MHz .
The fixed data rate mode accommodates signaling. Variable data rate timing does not allow signaling, since there is no means to specify which frames are to be signaling frames.

## Transmit Only Operation

If transmit only operation is desired, $\mathrm{FS}_{x} / \mathrm{TS}_{x} I$ and $\mathrm{CLK}_{x}$ should be applied to the device while CLK $R_{R}$ and $\mathrm{FS}_{\boldsymbol{R}} / T S_{\mathbf{R}}$ I can be removed. If $\mathrm{FS}_{\mathbf{R}} / T S_{R}$ I is removed, the receive section of device will enter the power-down state resulting in much lower power dissipation.
The digital PCM data ( $D_{X}$ ) on the transmit side will continue to be serially outputted during the frame as long as DCLK ${ }_{X}$ is pulsed and $T S_{X}$ is high. This function
allows the PCM word to be transmitted to the transmit PCM highway more than once per frame, if desired. (See Table 3.)

## Receive Only Operation

If receive only operation is desired, $\mathrm{FS}_{\mathbf{R}} / \mathrm{TS}_{\boldsymbol{R}} \mathrm{I}$ and $\mathrm{CLK}_{\mathbf{R}}$ should be applied to the device while CLK ${ }_{x}$ and FS ${ }_{x} / T S_{x}$ I can be removed. If $F S_{x} / T S_{x} I$ is grounded, transmit section of device will enter power down-state resulting in much lower power dissipation. In addition, $\mathrm{TS}_{\mathrm{x}}$ will be forced internally to a TTL high and $\mathrm{D}_{\mathrm{x}}$ will be held in the high impedance state. (See Table 3.)

## Standby Mode - Power-Down

To minimize power consumption and heat dissipation a standby mode is provided where most 2913/2914 functions are disabled. Only the power-down, clock, and frame sync buffers, which are required to power-up the device, are enabled in this mode.
To provide flexibility there are 4 power-down methods. These methods are presented in Table 3 along with digital output conditions which safeguard the PCM highway.

Placing and holding $\overline{T S}_{X}$ and $D_{X}$ in a high impedance state enhances system reliability by guaranteeing that the PCM highway will not be driven while entering and remaining in the standby mode. The SIG $_{R}$ output is held at a TTL low to provide a known condition; it remains low upon power-up until it is changed by signaling.

To further enhance system reliability, $\overline{\mathrm{TS}}_{X}$ and $\mathrm{D}_{\mathrm{X}}$ will be placed and held in a high impedance state several milliseconds after an interruption of CLKx. This interruption could possibly occur with some kind of fault condition.

## Power-On

Methods for powering-up the 2913 or 2914 maintain PCM highway integrity because they eliminate chances of jamming or putting noise on the highway.

The device can be powered up by pulsing either $\mathrm{FS}_{\mathrm{R}}$ or FS $X_{x}$ or both and by applying a TTL high voltage to $\overline{P D N}$. If only $\mathrm{FS}_{\mathrm{R}}$ and $\overline{P D N}$ are applied, only the receive side will power up. If only FSX and PDN are applied, only the transmit side will power up. If all three are applied then both sides will power up. This assumes $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{BB}}$ have been previously applied.

## Signaling

Signaling can only be performed with the 2914 and in the fixed data rate timing mode ( $D C L K_{R}=V_{B B}$ ). In this mode, the timing is similar to the 2910A utilizing $\mathrm{FS}_{\mathrm{X}}$ and $\overline{T S}_{x}$.

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 G. 733 recommendation and will output the least significant bit value on the SIG $\mathrm{R}_{\mathrm{R}}$ lead until the next signaling frame. Signaling frames on the send and receive sides are independent of each other and are selected by a double-width frame sync pulse on the appropriate channel.

The duration of the $\mathrm{FS}_{\mathrm{X}}$ and $\mathrm{FS}_{\mathrm{R}}$ pulses defines whether a frame is an information frame or a signaling frame in the following manner:

- A non-signaling frame is designated by an FSx pulse which is a full CLK $X_{x}$ period in duration (CLK ${ }_{x}$ period for $\mathrm{FS}_{\mathrm{X}}, \mathrm{CLK}_{\mathrm{R}}$ period for $\mathrm{FS}_{\mathrm{R}}$ )
- A signaling frame is designated by an FSx pulse which is two full CLK $X_{X}$ periods in duration (two CLK $X_{X}$ periods for $\mathrm{FS}_{X}$, two $\mathrm{CLK}_{\mathrm{R}}$ periods for $\mathrm{FS}_{\mathrm{R}}$ )
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 SIG $_{x}$ input at the time the 8th bit is output on the $D_{x}$ lead. (See Figure 8.)

Table 3. Power-Down Methods

| Device Status | Power-Down Method | Digital Output Status |
| :---: | :---: | :---: |
| (1) Both Transmit and receive side on standby | $\overline{\mathrm{PDN}}=0$ | $\overline{T S}_{X}$ and $D_{X}$ are placed in a high impedance state and $S_{G_{R}}$ is placed in a TTL low state in the frame immediately following onset of $\overline{P D N}=0$. |
| (2) Same as (1) | $F_{X} / T_{X} I$ and $\mathrm{FS}_{\mathbf{R}} / T S_{\mathbf{R}} I$ are removed | $\overline{T S}_{x}$ and $D_{x}$ are placed in a high impedance state and $S I G_{R}$ is placed in a TTL low state several milliseconds after $\mathrm{FS}_{\mathrm{X}} / T S_{X} 1$ and $F_{S_{R}} / T_{R} l$ are removed. |
| (3) Only transmit is on standby | $\mathrm{FS}_{\mathrm{x}} / \mathrm{TS}_{\mathrm{x}} \mathrm{I}$ is removed | Same as (2) except SIG $_{R}$ is still operational. |
| (4) Only receive is on standby | $\mathrm{FS}_{\mathrm{R}} / \mathrm{TS}_{\mathrm{R}} \mathrm{I}$ is removed | SIG ${ }_{R}$ is placed in a TTL low state several milliseconds after removal of $\mathrm{FS}_{\mathrm{R}} / T \mathrm{~S}_{\mathrm{R}} \mathrm{l}$. |



Figure 8. Signaling Timing (Used Only with Fixed Data Rate Mode)

Call progress tones (dial tone, busy tone, ring-back tone, re-order tone) and pre-recorded announcements, can be sent through the voice-path; digital signaling (off hook and disconnect supervision, rotary dial pulses, ring control) is sent through the signaling path.

## Precision Voltage Reference

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 con-
verter. The precision voltage reference determines the initial gain and dynamic range characteristics.

Separate references are supplied to both transmit and receive sections. Each reference is trimmed independently during manufacturing.

## Conversion Laws

The 2913 or 2914 can be selected for either A-law or $\mu$ 255-law operation (as specified by CCITT G.711). If A-law operation is desired, SIG $_{\mathrm{X}}$ should be tied to $\mathrm{V}_{\mathrm{BB}}$. Signaling will not be allowed during A-law operation. Signaling is allowed when $\mu 255$-law is selected and in fixed data rate mode. If $\mu$ 255-law operation is selected, SIG $_{x}$ should be operated between GRDD and $\mathrm{V}_{\text {cc }}$.

## ABSOLUTE MAXIMUM RATINGS*

Temperature . . . . . . . . . . . . . . . . . . . . . . $-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

$\mathrm{V}_{\mathrm{CC}}$ and GRDD with Respect to $\mathrm{V}_{\mathrm{BB}} \ldots . .-0.3 \mathrm{~V}$ to 15 V
Power Dissipation. . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.35 W
*NOTICE: Stresses above those listed under "Adsolute 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 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 5 \%, \mathrm{GRDA}=0 \mathrm{~V}$, GRDD $=0 \mathrm{~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 }}{ }^{2} \leq \mathrm{V}_{\text {IL }}$ |
| $\mathrm{I}_{\text {IH }}$ | High Level Input Current |  | 10 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{1{ }^{2}}{ }^{2} \mathrm{~V}_{\mathrm{IH}}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | . 8 |  | V | Except CLKO |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage |  | 2.0 |  | V | Except CLKO |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | . 4 |  | V | $\begin{aligned} & \mathrm{loL}=3.2 \mathrm{~mA} \text { at } \\ & \text { pins } \mathrm{D}_{\mathrm{X}} \text { and }{ }^{T S_{X}} \\ & \mathrm{SIG}_{\mathrm{R}}=\mathrm{loL}_{\mathrm{X}} \\ & 1.6 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage |  | 2.4 |  | V | $\begin{aligned} & \mathrm{D}_{\mathrm{X}}=I_{\mathrm{OH}}=10 \mathrm{~mA} \\ & \mathrm{SIG}_{\mathrm{R}}=I_{\mathrm{OH}}=.6 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\text {ILO }}$ | Input Low Voltage, CLKO | $\mathrm{V}_{\mathrm{BB}}$ |  | $\mathrm{V}_{\mathrm{BB}}+.5$ | V |  |
| $\mathrm{V}_{110}$ | Input Intermediate Voltage, CLKO | GRDD - 0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IHO}}$ | Input High Voltage, CLKO | $\mathrm{V}_{\text {CC }}-.5$ |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |

## Power Dissipation

| Symbol | Parmeter | Limits |  |  | Unit | Test Conditions |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $\mathrm{I}_{\mathrm{CCO}}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current |  | .9 |  | mA |  |
| $\mathrm{I}_{\mathrm{BBO}}$ | $\mathrm{V}_{\mathrm{BB}}$ Standby Current |  | .9 |  | mA |  |
| $\mathrm{I}_{\mathrm{CCI}}$ | $\mathrm{V}_{\mathrm{CC}}$ Operating Current |  | 16 |  | mA |  |
| $\mathrm{I}_{\mathrm{BBI}}$ | $\mathrm{V}_{\mathrm{BB}}$ Operating Current |  |  | 16 |  | mA |
| $\mathrm{P}_{\mathrm{D} 1}$ | Operating Power Dissipation |  | 175 |  | mW |  |
| $\mathrm{P}_{\mathrm{DO}}$ | Standby Power Dissipation |  | 10 |  | mW |  |

Note 1: Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal power supply values.
2: $\mathrm{V}_{\mathrm{IN}}$ is voltage on any digital input pin.

## D.C. CHARACTERISTICS (Continued)

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

## Power Supply Rejection (Transmit = Receive)

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $\mathrm{PSRR}_{1}$ | Vcc Power Supply Rejection |  | -40 |  | dB | Idle Channel; 200 mV P-P signal of $f_{0}$ on supply; $0 \leqslant f_{0}$ $\leqslant 50 \mathrm{kHz}$ <br> Measure at both $\mathrm{D}_{\mathrm{X}}$ and PWRO + or PWRO - |
| $\mathrm{PSRR}_{2}$ | $\mathrm{V}_{\mathrm{BB}}$ Power Supply Rejection |  | -35 |  | dB | Idle Channel; 200 mV P-P signal of $\mathrm{f}_{0}$ on supply; $0 \leqslant f_{0}$ $\leqslant 50 \mathrm{kHz}$ <br> Measure at both $\mathrm{D}_{\mathrm{X}}$ and PWRO + or PWRO - |

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

## 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 \%, \mathrm{GRDA}=0 \mathrm{~V}$, $\mathrm{GRDD}=0 \mathrm{~V}$, unless otherwise specified.
Clock Input Frequency:

$$
\begin{aligned}
& \mathrm{CLK}=1.536 \mathrm{MHz} \pm 0.1 \%, \mathrm{CLKO}=\mathrm{V}_{\mathrm{CC}} \\
& \mathrm{CLK}=1.544 \mathrm{MHz} \pm 0.1 \%, \text { CLKO }=\mathrm{GRDD} \\
& \mathrm{CLK}=2.048 \mathrm{MHz} \pm 0.1 \%, \mathrm{CLKO}=\mathrm{V}_{\mathrm{BB}}
\end{aligned}
$$

Half Channel Transmission Characteristics (Transmit = Receive)

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| S/D | Signal/Total Distortion Ratio; AT\&T PUB43801 and CCITT G.712, Method 2 (weighted sinusoid) testing) (Figure 9) |  | $\begin{array}{r} 37 \\ 31 \\ \cdot 26 \end{array}$ |  | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \\ & \mathrm{~dB} \end{aligned}$ | $0 \leqslant V F_{X I}<-30 \mathrm{dBmO}$ <br> $-30 \leqslant V F_{X} \mid<-40 \mathrm{dBmO}$ <br> $-40 \leqslant V F_{X} \mid<-45 \mathrm{dBmO}$ <br> $V F_{X} I=1.02 \mathrm{kHz}$ sinusoid, either $\mu$-law or A-law |
| S/D | Signal/Total Distortion Ratio; CCITT G.712, Method 1 (white noise testing) |  | $\begin{aligned} & \text { TBD } \\ & \text { TBD } \\ & \text { TBD } \\ & \text { TBD } \\ & \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | dB <br> dB <br> dB <br> dB <br> dB <br> dB | $0 \leqslant \mathrm{VF}_{\mathrm{X}} \mathrm{l}<-3 \mathrm{dBmO}$ $-3 \leqslant \mathrm{VF}_{\mathrm{X}}<-6 \mathrm{dBmO}$ $-6 \leqslant \mathrm{VF}_{\mathrm{X}}<-27 \mathrm{dBmO}$ $-27 \leqslant V F_{X I}<-34 \mathrm{dBmO}$ $-34 \leqslant V F_{x}<-40 \mathrm{dBmO}$ $-40 \leqslant V F_{X} \mid<-55 \mathrm{dBmO}$ |
| $\Delta \mathrm{G}$ | Gain Tracking Error; AT\&T PUB43801 and CCITT G.712, Method 2 (weighted sinusoid testing) (Figure 10) |  | $\begin{aligned} & \pm .20 \\ & \pm .30 \\ & \pm 1.0 \end{aligned}$ |  | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \\ & \mathrm{~dB} \end{aligned}$ | $+3 \leqslant V F_{X I}<-37 \mathrm{dBmO}$ <br> $-37 \leqslant V F_{X}<50 \mathrm{dBmO}$ <br> $-50 \leqslant \mathrm{VF} \mathrm{XI}<55 \mathrm{dBmO}$ <br> Relative input of 0 dBmO <br> at 1004 Hz |

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


NOTE: THE SHADED TEMPLATE REFLECTS HALF-CHANNEL
TRANSMISSION STANDARD CONSISTENT WITH AT\&T
TECHNICAL ADVISARY NO. 64, AT\&T PRELIMINARY
DIGITAL CHANNEL BANK REQUIREMENTS (PUB 43801),
AND CCITT STUDY GROUP XVIII.

Figure 9. SID Half-Channel Signal/Total Distortion Ratio; Transmit or Receive


Figure 10. $\Delta G$, Half-Channel Gain Tracking; Transmit or Receive
A.C. CHARACTERISTICS (Continued)
$\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 \%, \mathrm{GRDA}=0 \mathrm{~V}$, GRDD $=0 \mathrm{~V}$, unless otherwise specified.
Clock Input Frequency:

$$
\begin{aligned}
& \mathrm{CLK}=1.536 \mathrm{MHz} \pm 0.1 \%, \mathrm{CLKO}=\mathrm{V}_{\mathrm{CC}} \\
& \mathrm{CLK}=1.544 \mathrm{MHz} \pm 0.1 \%, \text { CLKO }=\text { GRDD } \\
& \mathrm{CLK}=2.048 \mathrm{MHz} \pm 0.1 \%, \mathrm{CLKO}=\mathrm{V}_{\mathrm{CC}}
\end{aligned}
$$

## Half Channel Transmission Characteristics (Transmit = Receive)

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $\mathrm{N}_{161}$ | Idie Channel Noise C-Message Weighted Psophometric Weighted |  | $\begin{gathered} 9 \\ -81 \end{gathered}$ |  | dBrncO dBmOp | Input grounded; no signaling |
| $\mathrm{N}_{161}$ | Idle Channel Noise C-Message Weighted (2914 only) |  | 12 |  | dBrncO | With 6th and 12th Frame signaling |
| DP ${ }^{\prime}$ | Single Frequency Distortion Products (In-band distortion) |  | -47 |  | dB | $\begin{aligned} & V F_{x I}=1.02 \mathrm{kHz} \\ & 0 \mathrm{dBmO} \end{aligned}$ |
| $\begin{aligned} & \mathrm{IMD}_{2} \\ & \mathrm{IMD}_{3} \end{aligned}$ | Intermodulation Distortion 2nd order <br> 3rd order |  | $\begin{aligned} & \text { TBD } \\ & \text { TBD } \end{aligned}$ |  | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \end{aligned}$ |  |

## Transmit Transmission Characteristics

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $\mathrm{A}_{\text {IR }}$ | Transmit Input Dynamic Range (Called $\mathrm{T}_{\text {MAX }}$ in CCITT Rec. G.711) |  | 1.533土.008 |  | $\mathrm{V}_{\text {RMS }}$ | 1 kHz, Input Op-amp with gain |
| CT TR | Crosstalk, XMIT to RCV |  | -80 |  | dB | $\begin{aligned} & V F_{x}=0 \mathrm{dBmO} \\ & 1.02 \mathrm{kHz} ; \mathrm{D}_{\mathrm{R}}=\text { all } \end{aligned}$ <br> one's, measure at PWRO + or PWRO - |

Receive Transmission Characteristics

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| DmW | Digital Milliwatt Response single ended outputs |  | 4.00士.04 |  | dBm <br> into <br> load <br> ( $\mathrm{R}_{\mathrm{L}}$ ) of <br> 9008 | $D_{R}=D m W$ Sequence per CCITT G. 711 |
| $\mathrm{CT}_{\mathrm{RT}}$ | Crosstalk, RCV to XMIT |  | $-80$ |  | dB | $\begin{aligned} & \mathrm{D}_{\mathrm{R}}=0 \mathrm{dBmO} \\ & 1.02 \mathrm{kHz}, \mathrm{VF}_{\mathrm{X}}= \end{aligned}$ <br> GRDA, measure at $D_{x}$ |

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

## A.C. CHARACTERISTICS (Continued)

## Clock Section

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $t_{C Y}$ | Clock Period | 485 |  |  | ns | CLK $_{x}$, CLK $_{R}$ <br> 2.048 MHz systems |
| ${ }_{\text {t CLK }}$ | Clock Pulse Width | 215 |  |  | ns | CLK $_{\text {x }}$, CLK $_{\text {R }}$ |
| $t_{\text {cDC }}$ | Clock Duty Cycle ((tclu $/ \mathrm{t}_{\mathrm{CY}}$ ) X100) |  | 50 |  | \% | CLK $_{\text {x }}$, CLK $_{\text {R }}$ |
| $t_{r}, t_{f}$ | Clock Rise and Fall Time | 5 |  | 30 | ns | CLK $_{\text {x }}$, CLK $_{\text {R }}$ |

## Transmit Section - Fixed Data Rate Mode

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $t_{\text {DIX }}$ | Data Enabled on TS Entry |  | 70 |  | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| $t_{\text {DDX }}$ | Data Delay from DCLK ${ }_{\text {x }}$ |  | 125 |  | ns | . |
| $t_{\text {HZX }}$ | Data Float on TS Exit |  | 110 |  | ns | $C_{\text {LOAD }}=0$ |
| $\mathrm{t}_{\text {SON }}$ | Timeslot X to Enable |  | 70 |  | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| $\mathrm{t}_{\text {SOFF }}$ | Timeslot X to Disable |  | 110 |  | ns | $\mathrm{C}_{\text {LOAD }}=0$ |
| $\mathrm{t}_{\text {FSD }}$ | Frame Sync Delay |  | 50 |  | ns | Timing relationship between $\mathrm{FS}_{\mathrm{R}}$ and CLK $_{\text {R }}$ |
| $t_{\text {SS }}$ | Signal Setup Time | 0 |  |  | ns | Relative to Bit-7 Falling Edge |
| $\mathrm{t}_{\text {SH }}$ | Signal Hold Time | 2 |  |  | $\mu \mathrm{S}$ | Relative to Bit-8 Falling Edge |

Receive Section - Fixed Data Rate Mode

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $t_{\text {DSR }}$ | Receive Data Setup |  | 30 |  | ns |  |
| $t_{\text {DHR }}$ | Receive Data Hold |  | 50 |  | ns |  |
| $\mathrm{t}_{\text {FSD }}$ | Frame Sync Delay |  | 50 |  | ns | Timing relationship between $\mathrm{FS}_{\mathrm{R}}$ and CLK $_{R}$ |
| ${ }^{\text {SIIGR }}$ | SIG $\mathrm{R}_{\text {Update }}$ |  | 300 |  | ns | From the trailing edge of the channel timeslot |

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

## A.C. CHARACTERISTICS (Continued)

## Transmit Section - Variable Data Rate Mode

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $t_{\text {TSDX }}$ | Timeslot Delay |  | 15 |  | ns | TSx ${ }^{\text {l }}$ |
| $t_{\text {wSX }}$ | Transmit Timeslot Clock Width (DCLK $\times 18$ ) |  | $8 / \mathrm{f}_{\mathrm{DX}}$ |  | $\mu \mathrm{S}$ |  |
| ${ }_{\text {t }}$ DXX | Data Delay from DCLKx |  | 125 |  | ns |  |
| $t_{\text {pon }}$ | Timeslot to $\mathrm{D}_{\mathrm{x}}$ Active |  | 35 |  | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| $t_{\text {doff }}$ | Timeslot to $\mathrm{D}_{\mathrm{X}}$ Inactive |  | 40 |  | ns | $0<C_{\text {LOAD }}<100 \mathrm{pF}$ |
| $\begin{aligned} & f_{D x} \\ & (\mathrm{~min}) \end{aligned}$ | Data Clock Frequency |  | 64 |  | kHz | Duty Cycle $=50 \%$ |
| $f_{D X}$ (max) | Data Clock Frequency |  | 4096 |  | kHz | Duty Cycle = 50\% |
| $\mathrm{f}_{\text {TSXI }}$ | Timeslot Clock Frequency |  | 8 |  | kHz |  |
| $t_{f}, t_{r}$ | Clock Rise and Fall Times |  | 5 | 30 | ns | TS ${ }_{\text {l }}$, DCLKx |

## Receive Section - Variable Data Rate Mode

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{1}$ | Max |  |  |
| $t_{\text {TSDR }}$ | Timeslot Delay |  | 15 | 50 | ns | TS ${ }_{\text {R }}$ |
| $t_{\text {WSR }}$ | Receive Timeslot Clock |  | $8 / \mathrm{f}_{\text {DR }}$ |  | ns |  |
| $t_{\text {DSR }}$ | Data Setup Time |  | 30 |  | ns |  |
| $t_{\text {DHR }}$ | Data Hold Time |  | 50 |  | ns |  |
| $f_{D R}$ (min) | Data Clock Frequency |  | 64 |  | kHz | Duty Cycle = 50\% |
| $f_{D R}$ (max) | Data Clock Frequency |  | 4096 |  | kHz | Duty Cycle = 50\% |
| $t_{r}, t_{f}$ | Clock Rise and Fall Times | 5 |  | 30 | ns | $T S_{R} I, D_{R}$ DCLK $_{R}$ |

[^10]
## WAVEFORMS

## Fixed Data Rate Timing

## TRANSMIT TIMING



## RECEIVE TIMING



NOTE: ALL TIMING PARAMETERS REFERENCED TO $V_{I H}$ AND $V_{I L}$.

## Variable Data Rate Timing

## TRANSMIT TIMING



## 2920/2921 <br> SIGNAL PROCESSOR

## 2920-User-Programmable/Erasable EPROM Program Memory (TCYC = $\mathbf{6 0 0} \mathrm{ns}$ ) 2921-Mask-Programmable ROM Program Memory (TCYC = 400 ns)

Real Time Digital Processing of Analog Signals<br>- Nominal Signal Bandwidths from DC to $\mathbf{1 0 k H z}$<br>- Digital Processing Accuracy and Stability<br>- Special Purpose Instruction Set for Signal Processing<br>- INTELLEC® Compatible Development System Software and Hardware

The Intel 2920 Signal Processor is a programmable, single chip analog and digital signal processor specifically designed to replace analog subsystems in real time processing applications. The 2921 is an improved performance mask programmable (ROM) version of the 2920 which is pin compatible with the 2920 . Its instruction set plus the high precision ( 25 bits) digital arithmetic logic unit provides the capability to implement very complex subsystems. Typical functions performed by the 2920 include: Lowpass and Bandpass filters with up to 20 complex pole and/or zero pairs; Threshold Detectors; Limiters; Rectifiers; up to 25-bit multiplication and division; approximations to nonlinear functions such as square law and logarithm; logical operations; input and Output multiplexing of signals; logical outputs for decision-type processing; and analog outputs for multifrequency oscillators, waveform generators, etc. In addition, several 2920 's may be cascaded for very complex processing applications with no loss in throughput rate.


[^11]Figure 1. Functional Block Diagram (Run Mode)

Table 1. Pin Description (Run Mode)

| Symbol | Function |
| :---: | :---: |
| SIGOUT | 8 pins corresponding to the 8 demultiplexed analog outputs (0-7). |
| GRDA | Analog signal ground held at or near GRDD typically. |
| $\mathrm{CAP}_{1}$ \& CAP ${ }_{2}$ | External capacitor connections for the input signal sample and hold circuit. Not required for 2921. |
| VREF | Input Reference Voltage |
| SIGIN | 4 pins corresponding to the 4 multiplexed analog inputs (0-3). |
| $V_{\text {BB }}$ | Most negative power pin set at -5 volts during run mode (different voltage in program mode). |
| $X_{2}$ /CLK | Clock input when using external clock signals; oscillator input for external crystal when using internal clock. |
| X1 | Oscillator input for external crystal when using internal clock. |
| GRDD | Digital ground. |
| $V_{\text {CC }}$ | 5 volts in run mode. |
| $\overline{\text { CCLK }}$ | Internal fetch cycle clock output. The falling edge designates the START of a new PROM fetch cycle. $\overline{\text { CCLK }}$ is $1 / 16$ of $X_{2}$ /CLK rate. |
| RUN/PROG | Mode control tied to GRDD in run mode. |
| $\overline{\mathrm{RST}} / \overline{\mathrm{EOP}}$ | Low $\overline{\text { RST }}$ input initializes program fetch counter to first location. As an |


| Symbol | Function |
| :--- | :--- |
|  | output it signifies EOP instruction <br> present (open drain, active low.) |
| $\overline{\text { OF }}$ | Indicates an overflow in the current <br> ALU operation (open drain, active <br> low). |
| VSP | EPROM/ROM power Pin, O volts for <br> RUN mode (different voltage in pro- <br> gram/verify mode). |
| M1, M2 | Two pins which specify the output <br> mode of the SIGOUT pins (see <br> Table 8). |



Figure 2. Run Mode Pin Configuration

Table 2. Pin Description (Program/Verify Mode)

| Symbol | Function |
| :--- | :--- |
| D0,D1,D2,D3 | 4 pins carrying EPROM program <br> data for both input and output (open <br> drain, active low output; active high <br> input). |
| $\mathrm{V}_{\mathrm{B} 1}, \mathrm{~V}_{\mathrm{B} 2}$, <br> $\mathrm{V}_{\mathrm{B} 3}, \mathrm{~V}_{\mathrm{B} 4}$ | Digital ground in PROGRAM mode <br> (different voltage for RUN mode). |
| $\mathrm{V}_{\mathrm{S} 1}, \mathrm{~V}_{\mathrm{S} 2}, \mathrm{~V}_{\mathrm{S} 3}$ | +5 volts in PROGRAM mode (func- <br> tion changes for RUN mode). |
| $\overline{\text { INCR }}$ | Input pulse increments the nibble <br> (4-bits) counter in PROG mode <br> (function changes in RUN mode). |


| Symbol | Function |
| :--- | :--- |
| VSP | EPROM/ROM power pin, +5 volts for <br> VERIFY mode. For 2920 program <br> mode pin is + 25 volts (different volt- <br> age in RUN mode). |
| PROG/ $\overline{\text { VER }}$ | Controls EPROM bi-directional data <br> bus for verify (low) or program <br> (high). |
| $\overline{\text { RST }}$ | Input pulse resets nibble counter to <br> position zero for start of pro- <br> gramming. |



Figure 3. Program Mode Pin Configuration

## FUNCTIONAL DESCRIPTION

The Intel 2920 is a programmable, single chip analog and digital signal processor which has been designed specifically to replace analog systems in real-time processing applications. The 2920 operates its analog circuitry simultaneously with the digital circuitry thereby achieving the efficiency and speed needed for real-time operation. Digital Circuitry includes: EPROM/ROM program storage, RAM scratch pad memory, clock and timing circuitry, binary scaler, and the arithmetic logic unit (ALU). The analog circuitry is composed of 4 analog inputs, an input multiplexer, an input sample and hold ( $\mathrm{S} \& \mathrm{H}$ ), A/D and D/A converters, an output multiplexer, 8 analog outputs, and buffered output S\&H's.
Once the EPROM/ROM is programmed, the 2920 is ready for operation as an analog subsystem. The following signal flow and operations can be described with reference to the functional block diagram shown in Figure 1.

## Clock and Timing Logic

The 2920/2921 can use an external clock or can generate its own clock with an external crystal placed across Pins 15 and 16. The program counter is incremented one instruction count for every 4 master clock cycles and continues to increment until it reaches a count of 191 or an EOP instruction is executed. Instructions are executed sequentially and no program jumps are provided. The sample rate is determined by the number of instructions in the program and the instruction cycle time. A 6.67 MHz clock ( 600 nsec instruction cycle time) and a full 192 instructions will result in a sample rate of 8680 Hz .

## Program Storage and Control

The EPROM/ROM is made up of 192 words with 24bits per word. Each 24 -bit word contains 6 instruction
fields (see Table 3) which control the individual subsystems in the 2920.

## RAM

The memory consists of a random-access read/write array organized as 40 words of 25 -bits each. The address space is extended to provide constants and access to a register (DAR) for interfacing the memoryALU with the analog conversion section. The RAM is a two port memory where the " $A$ " location is Read Only and passes via a scaler to the ALU as one operand. The " $B$ " location data passes to the ALU input as its second operand and the ALU result is written back to it. Both the RAM and the ALU represent data in two's complement format. All operations are performed in two's complement arithmetic. Program operations are simplified by assuming the binary point to the right of the sign bit.
An extended address space is used to generate constants within the program. It is accessed through the " A " port only and may be addressed using the last 16 locations of the " $A$ " address field (i.e., " $A$ " address $11 \mathrm{XXXX})$. The constant is determined by the 4 least significant " A " address bits.
These 4 bits are treated as the 4 most significant bits at the input to the binary shifter. A sequence of extended addresses with shift operations can generate any constant up to 25 bits long.
The DAR is 9 bits wide and can be accessed in several ways. As a memory location, the DAR occupies the 9 most significant bit positions of the 25 -bit word and can be accessed as " $A$ " and/or " $B$ " port. The DAR output is also tied directly to the D/A converter inputs and is used as a successive approximation register for A/D conversion under control of the analog function instruction fields. Each bit position of the DAR can also be selected and tested for conditional arithmetic operations.

## Binary Shifter

The 2920 has a binary shifter between the memory " $A$ " port output and the ALU " A " operand input. This feature allows the " A " operand to be scaled by any magnitude between $2^{2}$ and $2^{-13}$ (left shift 2 to right shift 13). When a number is shifted right vacated bit positions are filled with the sign bit. ( 2 's complement arithmetic shift). Shift op codes are shown in Table 4.

## ALU

The Arithmetic-Logic Unit calculates a 25 -bit result based on an operation performed on the scaled " $A$ " and the " B " operands delivered from memory. The 25bit result is written back into the " $B$ " memory location near the end of the instruction cycle. The ALU has logic to accommodate the left shift scaling. For arithmetic operations, this logic is used to calculate a 25 -bit result for normal operations and to maintain the sign bit when an overflow occurs. An overflow occurs only when the magnitude of the result is larger than the
largest number that can be stored in memory ( 25 bits). In that event, the result is set to the largest magnitude value with the correct sign. This overflow algorithm protects the continuity of the digitized analog signals and helps maintain the stability of the signal processing functions implemented. It is analogous to an overdriven amplifier going into saturation.

## Instruction Set

The 2920 assembler uses the following program format to specify the 24-bit instruction word stored in the EPROM:

| INSTRUCTION <br> (3 BITS) | ADDRESS <br> (B BITS) | ADDRESS <br> (6 BITS) | SHIFT <br> CODE <br> (4 BITS) | ANALOG <br> INSTRUCTION <br> (5 BIT) |
| :---: | :---: | :---: | :---: | :---: |

All processing subsystems are implemented using a combination of analog and digital instructions to input and output signals and/or data, and to realize the processing functions, respectively.
The analog input and output instructions are IN(K) and OUT(K), respectively. A sequence of IN(K) instructions followed by the sign conversion and amplitude conversion instructions CVTS and CVT(K) respectively are used to perform the input A/D conversion.

A simple sequence of OUT $(\mathrm{K})$ instructions is all that is needed to output a 9-bit amplitude on channel K. Other analog instructions are the EOP instruction which resets the program counter, NOP which is simply a no-operation, and CNDS or CND(K) which are conditional operators which select and test a bit in the DAR for the conditional ADD or LDA instructions or define the destination of the carry bit for the conditional SUB instruction.
If used, the EOP instruction must be placed at a program location up to location 188 which is a multiple of four. The three instructions immediately following the EOP instruction will be executed. The RST/ $\overline{\mathrm{EOP}}$ output pulse requires an EOP instruction.
The ALU arithmetic instructions are ADD,SUB,LDA which perform the operations of addition, subtraction, and data transfer respectively. When these instructions are conditioned, they may be used to perform multiplication or division by a variable or data dependent switching.

Other digital instructions include the absolute value ABS, the absolute value and add ABA, and the ideal limit instruction LIM.

These instructions and their corresponding op codes are detailed in Table 5.

## Table 3. Nibble Organization for Loading Program



Note: The input pins for each nibble bit from left to right are D0, D1, D2, D3.

Table 4. Shift OP Codes

| Operation | Mnemonic | Op Code |  |  | Scale Factor |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 3 | 2 | 1 |  |  |
| Shift Right 13 Bits |  | 1 | 1 | 0 | 0 | $2^{-13}$ |
| Shift Right 12 Bits | R12 | 1 | 0 | 1 | 1 | $2^{-12}$ |
| Shift Right 1 Bit | $\vdots$ | $\vdots$ | $\vdots$ | $\vdots$ | $\vdots$ | $\vdots$ |
| No Shift | R01 | 0 | 0 | 0 | 0 | $2^{-1}$ |
| Shift Left 1 Bit | R00 | 1 | 1 | 1 | 1 | 1 |
| Shift Left 2 Bits | L01 | 1 | 1 | 1 | 0 | 2 |

Table 5. Instruction Set and OP Codes

| Mnemonics | Op-Codes ${ }^{[1]}$ |  |  | Operations | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Code Condition | ALU | ADF | ADK |  |  |
| Digital Instructions | 0,1,2 | 0,1 | 2,1,0 |  |  |
| ADD <br> SUB <br> LDA <br> XOR <br> AND <br> ABS <br> $A B A{ }^{[11]}$ <br> LIM <br> ADD CND( ) ${ }^{[2]}$ <br> SUB CND( $)^{[2][8]}$ <br> LDA CND( ) ${ }^{[2]}$ <br> ABA ${ }^{[11]}$ CND ( $)^{[9]}$ <br> XOR CND( ) ${ }^{[9]}$ | $\begin{aligned} & \hline 011 \\ & 101 \\ & 111 \\ & 000 \\ & 100 \\ & 110 \\ & 001 \\ & 010 \\ & 011 \\ & \\ & 101 \\ & \\ & 111 \\ & \\ & 001 \\ & 000 \end{aligned}$ |  |  |  | [5] |
| Analog Instructions |  |  |  |  |  |
| IN(K) OUT(K) CVTS CVT(K) EOP NOP CND(K) CNDS |  | $\begin{aligned} & 00 \\ & 10 \\ & 00 \\ & 01 \\ & 00 \\ & 00 \\ & 11 \\ & 00 \end{aligned}$ | $\begin{gathered} 0-3 \\ 0-7 \\ 6 \\ 0-7 \\ 5 \\ 4 \\ 0-7 \\ 7 \end{gathered}$ | Signal Sample from Input Channel K <br> D/A to Output Channel K <br> Determine Sign Bit <br> Perform A/D on Bit K <br> Program Counter to Zero <br> No Operation <br> Select Bit K for Conditional Instructions <br> Select Sign Bit for Conditional Instructions | [6] |

Notes: 1. Op codes ALU and ADF are in binary notation, ADK is in decimal notation and represents the value " $K$ " when ap. propriate.
2. CND( ) can be either CND(K) or CNDS testing amplitude bits or the sign bit of the DAR respectively.
3. Determined by analog instructions below.
4. $B$ is set to full scale (F.S.) amplitude with the same sign as the " $A$ " port operand.
5. The previous carry bit ( $\mathrm{CY}_{\mathrm{p}}$ ) is tested to determine the operation. The present carry bit ( CY ) is loaded into the Kth bit location of the DAR. "Present carry (CY) is generated independent of overflow. It will represent the carry (CY) of a calculated 28-bit result."
6. EOP will also enable overflow correction if it was disabled during a program pass.
7. Determined by digital insiructions above.
8. For SUB CNDS operation $\overline{\mathrm{CY}} \rightarrow \operatorname{DAR}(\mathrm{S})$.
9. Does not affect DAR. In this case, CND is used with XOR/ABA to enable/disable the ALU overflow saturation algorithm. Use of either instruction causes the ALU output to roll over rather than go to full scale with sign bit preserved. An EOP instruction will also enable the ALU overflow saturation algorithm.
10. Clarification of CY OUt sense for certain operations. For LDA, XOR, AND, ABS; $C Y_{\text {out }} \rightarrow 0$.
11. Recommend that the $A B S$ \& $A D D$ instructions be used in place of $A B A$. The $A B A$ instruction typically runs $2 \mathbf{M H z}$ slower. The saturation logic, however can be set and reset at full speed.

## Input Multiplexer and S\&H

The input channels consist of four analog sampling switches which use a common sampling capacitor (external capacitor for the 2920, internal for the 2921). The external capacitor should be approximately 500 pF to yield an offset of less than $-1 / 2$ LSB. The acquisition time should be approximately six times the RC time constant of the sample and hold circuitry (i.e., 500 pF times $1.5 \mathrm{~K} \Omega$ equals 750 nsec ). Acquisition time equal to six or more time constants should keep the input
crosstalk to below -54 dB . For systems which require less dynamic range, the input acquisition time can be reduced. For 600 nsec cycle approximately eight IN(K) instructions would be required. For serial digital inputs, fewer $I N(K)$ instructions can be used. For systems with 2920 cycle times much greater than 600 nsec the external sampling capacitor should be increased to 1000 pF to reduce the droop rate with a corresponding increase in the RC time constant.

## A/D-D/A Conversion

The successive approximation analog to digital conversion is performed under program control. It uses the CVTS instruction first to set the sign bit and the CVT(K) instruction to determine the value of the Kth DAR bit starting with the MSB. NOPs equivalent to $1.2 \mu \mathrm{sec}$ must follow each CVT(K) instruction to allow the D/A to settle. The suggested conversion sequence for nine bit resolution with the 2920 cycle time equal to 600 nsec is shown below in Table 6. Digital inputs and inputs with less than nine bits resolution will have a shorter sequence.

Table 6. Suggested Input and Conversion Sequence

where "." equals available digital instruction

## Output Demultiplexer and S\&Hs

The 2920's eight analog output channels include a sample and hold circuit per channel demultiplexed from a common, buffered D/A output. Two rules for outputting samples are: (1) No outputting should be done while writing to the DAR; (2) A sequence of 3 analog NOP instructions should be used to settle the D/A converter, and a sequence of OUT(K) instructions equal to $3.5 \mu \mathrm{sec}$ should be used to settle the S\&H output. The suggested sequence for a nine bit resolution output with a 600 nsec cycle time is outlined in Table 7.

Table 7. Suggested Output Sequence

| Digital | Analog |
| :---: | :---: |
| LDA, DAR, X,RO, | NOP |
| . . . . | NOP |
| . . . . | NOP |
| . . . . | NOP |
| . . . . | OUT(K) |
| . . . . | OUT(K) |
| . . . . | OUT(K) |
| . . . . | OUT(K) |
| . . . . | OUT(K) |
| . . . . | OUT(K) |

where $K=$ desired output, "." available digital instruction
Conditional operations should not immediately precede or follow an OUT instruction. Otherwise a CND(K) may affect the value of the Kth output.

## TTL Output

The SIGOUT(K) pins can be selected to be either analog out or TTL compatible as seen in Table 8. The analog mode allows the full 9-bit D/A output to be present. The LIM instruction can be used to yield a " 0 " or " 1 " decision for the TTL mode. This output can be presented to the SIGOUT(K) pins and is compatible to a single TTL gate or equivalent. The internal threshold required is 1.5 volts for a high level output. An external pullup resistor to $\mathrm{V}_{\mathrm{CC}}$ is also required.

Table 8. Output Mode for SIGOUT Pins as Function of M1 and M2

| M1 | M2 | SIGOUT Pins |
| :---: | :---: | :--- |
| 5 V | 5 V | $0-7$ Analog |
| 5 V | -5 V | $0-3$ Analog, 4-7 TTL |
| -5 V | 5 V | $0-3 \mathrm{TTL}, 4-7$ Analog |
| -5 V | -5 V | $0-7 \mathrm{TTL}$ |

## Reference Voltage

The internal D/A converter requires a single positive reference voltage (VREF) to establish its voltage range. This user supplied reference can range from 1 V to 2 V . The resulting input and output signal voltage range is
$\pm$ VREF. If the TTL output is required, VREF $>1.5 \mathrm{~V}$ is necessary. The minimum voltage step (LSB) of the D/A converter is $V_{\text {REF }} / 256$ volts. Voltage variations on $V_{\text {REF }}$ will appear as noise to the D/A converter. It is therefore necessary to provide a noise free voltage source for the reference. The input signal voltage range is ( $\pm$ VREF) $-1 / 2$ LSB.

## EPROM PROGRAMMING

The 2920 EPROM in the programming mode is arranged as a 1152-by-4-bit memory. Each instruction ( 24 bits) is loaded as 6 nibbles ( 4 bits) as seen in Table 3. Figure 7 shows the timing relationships of the signals required to program and verify the EPROM contents. In the program mode all voltages are referenced to VBB which is set to digital ground, thereby allowing TTL logic to be used for controlling the
programming cycle. The D pins are bidirectional with the direction controlled by the PROG/VER pin. A high level at the PROG/VER pin switches to input mode, a low to output mode (see Figure 7). This feature allows the programmed data to be verified before going on to the next address.
The internal nibble counter is incremented during the falling edge of $\overline{\mathrm{NCR}} .1152$ INCR transitions will complete the full program cycle. To initialize at address (nibble) 0, RST must be pulsed low, then INCR can be issued. From then on, programming is accomplished according to Figure 7.
The RUN/PROG pin must be tied to $V_{B B}$ and VSP should be pulsed between +5 V and $+25 \pm 1 \mathrm{~V}$ at 15 mA maximum. The D pins have an open drain in the output direction.


Figure 4. Typical Power Hookups for Run and Program Mode


Figure 5. External Clock Driver

## 2920 DEVELOPMENT SUPPORT TOOLS

Support tools for the 2920 are based on the Intellec ${ }^{\circledR}$ Microcomputer Development Systems. A 2920 Software Support Package (SPS-20) consisting of the Signal Processing Applications Software/Compiler (SPAS-20), the 2920 Software Simulator, and the 2920 Assembler is available to facilitate design and development efforts. EPROM programming support includes the Intel EPROM programmer and the 2920 personality module (UPP-820). A complete Signal Processing Support System (MCl-20-DS1) consisting of the Microcomputer Development System, the 2920 Software Support Package, the EPROM programmer and personality module is recommended and is available at a reduced price.
The 2920 Signal Processing Applications Software/ Compiler is an interactive tool for designing software to be executed on the 2920 Signal Processor. The compiler accepts English-like statements from the user and generates 2920 assembly language code.

The assembler translates symbolic 2920 assembly language programs into the machine operation codes. The user can load the codes into the 2920 simulator or to the Universal EPROM Programmer for programming the 2920 itself.
The simulator, operating entirely in software, allows the user to test and debug 2920 programs. The user
can specify input signals, simulate program execution, set up breakpoints, display input and output, display and alter the contents of the 2920 registers and memory locations, and graph the output waveforms.

The compiler, assembler and simulator enable the designer to develop and test an entire program without programming the device. The 2920 designer works at the Intellec ${ }^{\text {® }}$ Microcomputer Development System rather than at a breadboard. The development system facilitates the designing and testing of 2920 applications.
The SDK-2920 contains all of the components required to assemble a complete single board microcomputer system for programming and evaluation of the 2920 Analog Signal Processor. The 8085/8041A microcom-puter-based program development section allows you to immediately enter programs in 2920 assembly mnemonics, translate them to 2920 object code, and program the on-board 2920 EPROM. The kit supports basic filing options such as up/down loading to/from an Intellec, audio cassette, and line printer. The SDK2920 also provides the user with a 2920 run mode section allowing real-time execution of a programmed 2920. This section comes complete with BNC connectors and Intel's 2912 PCM line filters required for one input and one output network. The kit supports optional input and output circuitry on the run mode section.

## ABSOLUTE MAXIMUM RATINGS*

*NOTICE: 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 (Run Mode) ( $\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 \%$ )

ANALOG (SIGIN(K), SIGOUT(K))

| Symbol | Parameter | 2920 |  |  | 2921 |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| $Z_{1}$ | Input Impedance |  | 100 |  |  | 100 |  | $\mathrm{K} \Omega$ | Unsampled Input |
| $\mathrm{Z}_{\text {SH }}$ | S\&H Impedance |  | 1.5 |  |  | 1.5 |  | K $\Omega$ | Series resistance with S\&H |
|  | A/D Resolution |  |  | 9 |  |  | 9 | bits |  |
|  | Input Differential Linearity |  | $\pm 1$ |  |  | $\pm 1$ |  | LSB |  |
|  | Input Integral Linearity |  | $\pm 1$ |  |  | $\pm 1$ |  | LSB |  |
| $T_{\text {A }}$ | Aperture |  | 5 |  |  | 5 |  | nsec | Equivalent SNR = 60dB @ 10kHz |
| $\mathrm{X}_{1}$ | Input Crosstalk |  | -54 |  |  | -54 |  | dB | Input to input |
| $V_{\text {ID }}$ | Input Droop Rate |  | 50 |  |  | TBD |  | uv/us | 500pF cap. with dark cover (2920 only) |
| $V_{1 R}$ | Input Voltage Range |  |  | $\pm$ VREF |  |  | $\pm$ VREF | V |  |
| VIOS | Input Zero Offset |  | 8 |  |  | TBD |  | mV |  |
| lize | Input Zero Crossing Error |  | 12 |  |  | 0 |  | mV |  |
| $\mathrm{G}_{1}$ | Input Gain |  | 1 |  |  | 1 |  |  |  |
|  | Gain Error |  | 2 |  |  | 0 |  | \% | ratio of Neg. \& Pos. gains |
| TIA | Input Acquisition Time |  | 4.5 |  |  | 3.2 |  | $\mu \mathrm{s}$ | 9 bit resolution* |
| ZO | Output Impedance |  | 1 |  |  | 1 |  | $K \Omega$ |  |
| 10 | Output Drive Current |  | 400 |  |  | 400 |  | $\mu \mathrm{A}$ | 20pF load |
|  | D/A Resolution |  |  | 9 |  |  | 9 | bits |  |
|  | Output Differential Linearity |  | $\pm 1 / 2$ |  |  | $\pm 1 / 2$ |  | LSB | SIGOUT load 100K $\Omega$ $-1<\text { SIGOUT }<1$ |
|  | Output Integral Linearity |  | $\pm 1$ |  |  | $\pm 1$ |  | LSB | SIGOUT load 100K $-1<$ SIGOUT < 1 |
| $\mathrm{XO}_{0}$ | Output Crosstalk |  | -54 |  |  | -54 |  | dB | Output to output |
| $\mathrm{V}_{\text {OD }}$ | Output Droop Rate |  | 0.2 |  |  | 0.2 |  | $\mathrm{mv} / \mu \mathrm{sec}$ | @ $70^{\circ} \mathrm{C}$ with dark cover |
| $V_{\text {OR }}$ | Output Voltage Range | -2 |  | +2 | -2 |  | +2 | V |  |
| Voos | Output Zero Offset |  |  | -100 |  | TBD |  | mV |  |
| Vozc | Output Zero Crossing Error |  | 8 |  |  | 0 |  | mV |  |
| Go | Output Gain |  | 0.85 |  |  | 1 |  | V/V |  |
| - | Gain Error |  | TBD |  |  | 0 |  | \% | ratio of Neg. \& Pos. Gains |
| TOA | Output Acquisition Time |  | 3.5 |  |  | 3.5 |  | $\mu \mathrm{s}$ | 9 bit resolution* |
| GT | Throughput Gain |  | 0.85 |  |  | 1 |  | V/V | A/D to D/A |
| VREF | Voltage Reference Level | 1.0 |  | 2.0 | 1.0 |  | 2.0 | V |  |
| IVR | Voltage Reference Current | 60 |  | 115 |  | TBD |  | $\mu \mathrm{A}$ | VREF equal 1 volts |

[^12]
## DIGITAL ( $\overline{O F}, \overline{C C L K}, \overline{E O P}$, SIGOUT in TTL mode)

| Symbol | Parameter | 2920 |  |  | 2921 |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| IL | Low Level Input Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {IL }}$ Driving RST |
| ${ }^{1 / H}$ | High Level Input Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}<\mathrm{V}_{\mathrm{IH}}$ Driving RST |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  |  | 0.8 |  |  | 0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 |  |  | 2.0 |  |  | V |  |
| $V_{\text {IXL }}$ | Input Low Voltage, X2/CLK | -4.5 |  | -5 | -4.5 |  | -5 | V |  |
| VIXH | Input High Voltage, X2/CLK | -2.6 |  | 0 | -2.6 |  | 0 | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 |  |  | 0.4 | V | $\begin{aligned} & \mathrm{IOL}=2.5 \mathrm{~mA}, \\ & \mathrm{CCLK} \mathrm{ONLY} \end{aligned}$ |
| IOL | Output High Current |  | 2 |  |  | 2 |  | mA | $\overline{\mathrm{EOP}}, \overline{\mathrm{OF}}, \overline{\mathrm{CCLK}}$, SIGOUT. $\mathrm{VOL}=0.4 \mathrm{~V}$ |
| ${ }^{\mathrm{I}} \mathrm{OH}$ | Output Low Current |  | 10 |  |  | 10 |  | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{EOP}}, \overline{\mathrm{OF}}, \overline{\mathrm{CCLK}} \\ & \text { SIGOUT } \end{aligned}$ |

## POWER DISSIPATION

| $I C C$ | Operating Current |  | 30 | 50 |  | 50 |  | $m A$ | $V_{C C}=5.25 \mathrm{~V}$ |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| $I_{B B}$ | Operating Current |  | 110 | 150 |  | 150 |  | $m A$ | $V_{B B}=-5.25 \mathrm{~V}$ |

A.C. CHARACTERISTICS (Run Mode) ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$; $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$; $\mathrm{V}_{\mathrm{BB}}=-5 \mathrm{~V}$ )

| FOSC |  |  | 6.67 |  |  | 10 |  | MHz | Oscillator <br> frequency |
| :--- | :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| TCYC | Instruction Cycle Period |  | 600 |  |  | 400 |  | ns | 4 clock cycles |
| TCE | Cycle Start to EOP Valid |  | 160 |  |  | TBD |  | ns |  |
| TEH | EOP Hold Time |  | TCYC |  |  | TCYC |  | ns |  |
| TFH | OF Hold Time |  | TCYC |  |  | TCYC |  | ns |  |
| TCW | CCLK Pulse Width |  | TCYC |  |  | TCYC |  | ns |  |
| TCO | Cycle Start to OF Valid |  | TCYC |  |  | TCYC |  | ns |  |



Figure 6. Run Mode Timing
D.C. CHARACTERISTICS (Program/Verify Mode) $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{S S}=5 \mathrm{~V} ; \mathrm{V}_{\mathrm{BB}}=0 \mathrm{~V}$ )

| Symbol | Parameter | 2920 |  |  | 2921 |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max |  |  |
| ITL | Low Level Input Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {IL }}$ |
| 1 IH | High Level Input Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}<\mathrm{V}_{\text {IH }}$ |
| $V_{\text {IL }}$ | Input Low Voltage |  |  | 0.8 |  |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  |  | 2.0 |  |  | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.8 |  |  | 0.8 | V | $\mathrm{IOL}=2.5 \mathrm{~mA}$ |
| ISP | Program Pulse Current |  |  | 16 | - | - | - | mA | Data Input $=0000$ |
| $\mathrm{V}_{\mathrm{P} 1}$ | Program Pulse ON Voltage | 24 | 25 | 26 | - | - | - | V | 20 |
| $\mathrm{V}_{\mathrm{P} 2}$ | Program Pulse OFF Voltage |  | 5 |  | - | - | - | V | Only |

## POWER DISSIPATION (Program/Verify Mode)

| ISS | Operating Current |  | 100 |  |  | TBD |  | mA | $\mathrm{V}_{\mathrm{SS}}=5 \mathrm{~V}+10 \%$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## A.C. CHARACTERISTICS (Program/Verify Mode) $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C} ; \mathrm{V}_{S S}=5 \mathrm{~V} ; \mathrm{V}_{\mathrm{BB}}=0 \mathrm{~V}$ )



NOTE: 1. VSP must not undershoot 5 V by more than 0.5 V . Add undershoot settling time to TPV. *25V program pulse must NOT be applied to 2921.


Figure 7. 2920 Program/Verify, 2921 Verify Timing

Automotive

## P80A49H/P80A39HL

HMOS SINGLE COMPONENT 8-BIT MICROCOMPUTER

## Automotive

P80A49H—Mask Programmable ROM—8MHz
P80A39HL—CPU Only with Power Down

- Extended Temperature Range of $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ in Low-Cost Plastic Package
- Reduced Power Consumption, High Performance HMOS


## Interval Timer/Event Counter

■ $1.88 \mu \mathrm{sec}$ Cycle Time (8.0MHz)

\author{

- $2 K \times 8$ ROM <br> $128 \times 8$ RAM <br> 27 VO Lines <br> - Two Single Level Interrupts <br> Over 90 Instructions: 70\% Single Byte
}

Intel Corporation has recognized the need for high performance, single-chip, microcomputers that operate in the extended temperature and rigorous environment of an automobile. To meet this need, Intel has developed automotive grade products which feature extended operating temperature ranges in cost-effective plastic packages for selected microcomputers. These automotive grade products have been characterized and tested to provide an optimum balance between cost and performance over the standard automotive temperature range of $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$.
Intel's automotive grade products are fully compatible with the corresponding standard products with respect to architecture, instruction set, programming, and software portability.
All automotive grade products are supported by extensive reliability and quality qualification tests, in-process testing, and product monitor testing. This testing program has been designed to ensure that the automotive grade products comply with the rigorous reliability and quality requirements of the automotive industry.


Figure 1.
Block Diagram


Figure 2.
Logic Symbol


Figure 3. Pin Configuration (top view)

Table 1. Pin Description

| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| VSS | 20 | Circuit GND potential |
| $V_{\text {DD }}$ | 26 | Low power standby pin |
| $\mathrm{V}_{\text {CC }}$ | 40 | Main power supply; +5V during operation. |
| PROG | 25 | Output strobe for 8243 I/O expander. |
| P10-P17 <br> Port 1 | 27-34 | 8-bit quasi-bidirectional port. |
| P20-P27 Port 2 | $\begin{gathered} 21-24 \\ \& \\ 35-38 \end{gathered}$ | 8-bit quasi-bidirectional port. 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 . |
| $\begin{aligned} & \text { DBO-DB7 } \\ & \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{R D}$, and $\overline{W R}$. |
| TO | 1 | Input pin testable using the conditional transfer instructions JTO and JNTO. TO can be designated as a clock output using ENTO CLK instruction. |
| T1. | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. |
| $\overline{\text { INT }}$ | 6 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. |


| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
|  | 8 | Also testable with conditional jump instruction. (Active low) |
| $\overline{R D}$ |  | 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. (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 conjunction 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 for external source. (Non TTL $V_{1 H}$ ) |
| XTAL2 | 3 | Other side of crystal input. |

*Interrupt pin must remain low for at least 3 C CY to ensure proper operation.

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=1$ | 2 | 2 |
| JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
| JF0 addr | Jump on F0 $=1$ | 2 | 2 |
| JF1 addr | Jump on $F 1=1$ | 2 | 2 |
| JTF addr | Jump on tımer flag | 2 | 2 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |


| Flags |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| CLR C | Clear carry | 1 | 1 |
| CPL C | Complement carry | 1 | 1 |
| CLR F0 | 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 |


| Data Moves |  |  |  |
| :--- | :--- | :--- | :--- |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
| XCH A, @R | Exchange A and data memory | 1 | 1 |
| XCHD A, @R | Exchange nibble of A and | 1 |  |
|  | register |  |  |
| 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 |


| Timer/Counter |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |


| Control |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | Disable external interrupt | 1 | 1 |
| SEL RB0 | 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 |
| ENT0 CLK | Enable clock output on T0 | 1 | 1 |


| Mnemonic <br> NOP | Description <br> No operation | Bytes Cycles | 1 |
| :--- | :--- | :---: | :---: |

ABSOLUTE MAXIMUM RATINGS*
Ambient Temperature Under Bias $\ldots-40^{\circ} \mathrm{C}$ to $+110^{\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

* NOTICE: 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 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}=-40^{\circ} \mathrm{C}\right.$ to $+110^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{D D}=5 \mathrm{~V} \pm 10 \%$, $\mathrm{V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | $\begin{aligned} & \text { P80A49H } \\ & \text { P80A39HL } \end{aligned}$ |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ* | Max |  |  |
| $V_{\text {IL }}$ | $\begin{aligned} & \text { Input Low Voltage } \\ & \text { (All Except RESET, X1, X2) } \end{aligned}$ | -. 5 |  | . 7 | v |  |
| VIL1 | Input Low Voltage ( $\overline{\mathrm{RESET}}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 6 | V |  |
| V IH | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.2 |  | VCC | V |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage (X1, X2, $\overline{\text { RESET }}$ ) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| VOL | Output Low Voltage (BUS) |  |  | 45 | V | $\mathrm{OL}=2.0 \mathrm{~mA}$ |
| VOL1 | Output Low Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ |  |  | . 45 | V | $\mathrm{I}^{\prime} \mathrm{OL}=1.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage (PROG) |  |  | . 45 | V | $\mathrm{IOL}=0.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL3 }}$ | Output Low Voltage (All Other Outputs) |  |  | . 45 | V | $\mathrm{IOL}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{VOH}^{\text {O }}$ | Output High Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | $\mathrm{IOH}^{\prime}=-100 \mu \mathrm{~A}$ |
| $\mathrm{VOH}^{2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | $\mathrm{IOH}^{\prime}=-30 \mu \mathrm{~A}$ |
| LL1 | Input Leakage Current ( $\mathrm{T} 1, \overline{\mathrm{INT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| 'LII | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{\mathrm{SS}}$ ) |  |  | -600 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| ILO | 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}}$ |
| IDD | VDD Supply Current (power down) |  | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & 10 \\ & 20 \end{aligned}$ | mA | $T_{A}=+25^{\circ} \mathrm{C}$ <br> Full Temp. Range |
| $\begin{aligned} & \text { IDD + } \\ & \text { ICC } \end{aligned}$ | Total Supply Current |  | $\begin{aligned} & 50 \\ & 75 \end{aligned}$ | $\begin{aligned} & 100 \\ & 145 \end{aligned}$ | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> Full Temp. Range |
| $V_{\text {DD }}$ | RAM Standby PIN Voltage | 3.0 |  | 5.5 | V | Standby Mode, Reset $\leqslant 0.6 \mathrm{~V}$ |

[^13]
## A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $+110^{\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{aligned} & f(\text { tcY } \\ & \text { (Note 3) } \end{aligned}$ | $\begin{aligned} & \hline \text { P80A49H } \\ & \text { P80A39HL } \end{aligned}$ |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| tLL | ALE Pulse Width | 7/30 ter -170 | 260 |  | ns |  |
| ${ }^{\text {t }} \mathrm{AL}$ | Addr Setup to ALE | 1/5 tcy -110 | 260 |  | ns |  |
| tLA | Addr Hold from ALE | 1/15 tcy -40 | 80 |  | ns |  |
| ${ }^{\text {t CCO }}$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 tcy -200 | 740 |  | ns |  |
| ${ }^{\text {t CC2 }}$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | $2 / 5$ tcy -200 | 550 |  | ns |  |
| tow | Data Setup before $\overline{\mathrm{WR}}$ | 13/30 tcy -200 | 610 |  | ns |  |
| twd | Data Hold after $\overline{W R}$ | 1/15 tcy -50 | 70 |  | ns | (Note 2) |
| tDR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | 1/10 tcy -30 | 0 | 160 | ns |  |
| tro1 | $\overline{\mathrm{RD}}$ to Data in | $2 / 5$ tcy -200 |  | 550 | ns |  |
| trin 2 | $\overline{\text { PSEN }}$ to Data in | 3/10 tcy -200 |  | 360 | ns |  |
| taw | Addr Setup to WR | $2 / 5$ tcy -150 | 600 |  | ns |  |
| ${ }^{\text {t }}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 t CY -250 |  | 1190 | ns |  |
| tAD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | 3/5 tcy-250 |  | 870 | ns |  |
| ${ }^{\text {t } A F C 1 ~}$ | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15$ tcy -40 | 210 |  | ns |  |
| tAFC2 | Addr Float to PSEN | 1/30 tey -40 | 20 |  | ns |  |
| tLAFC1 | ALE to Control ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5 \mathrm{tcy}-75$ | 300 |  | ns |  |
| tLAFC2 | ALE to Control ( $\overline{\text { PSEN }}$ ) | 1/10 tcy -75 | 110 |  | ns |  |
| tCA1 | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | 1/15 tey -40 | 80 |  | ns |  |
| tCA2 | Control to ALE ( $\overline{\text { PSEN }}$ ) | 4/15 tcy -40 | 460 |  | ns |  |
| tCP | Port Control Setup to PROG | $2 / 15$ t $\mathrm{CY}-80$ | 170 |  | ns |  |
| tpe | Port Control Hold to PROG | 4/15 tcy -200 | 300 |  | ns |  |
| tPR | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tor -120 |  | 1000 | ns |  |
| tpF | Input Data Hold from PROG | $1 / 10 \mathrm{t}_{\mathrm{CY}}$ | 0 | 190 | ns |  |
| tDP | Output Data Setup | $2 / 5 \mathrm{tcy}-150$ | 600 |  | ns |  |
| tPD | Output Data Hold | 1/10 ter -50 | 140 |  | ns |  |
| tpP | $\overline{\text { PROG Pulse Width }}$ | 7/10 ter -250 | 1060 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | 4/15 tcy -200 | 300 |  | ns |  |
| tLP | Port 2 I/O Hold to ALE | 1/10 tcy -100 | 90 |  | ns |  |
| tPV | Port Output from ALE | $3 / 10 \mathrm{t}_{\mathrm{CY}}+100$ |  | 660 | ns |  |
| tcy | Cycle Time | (1/fXTAL) $\times 15$ | 1.88 |  | $\mu \mathrm{S}$ | (Note 4) |
| toprR | T0 Rep Rate | $3 / 15 \mathrm{t} \mathrm{CY}$ | 370 |  | ns |  |

## Notes:

1. Control Outputs $C_{L}=80 \mathrm{pF}$ BUS Outputs $C_{L}=150 \mathrm{pF}$
2. BUS High Impedance Load 20 pF
3. Equation to calculate theoretical AC timing parameters at frequency of choice. Calculated values will be equal to or better than published values. Equation assumes $50 \%$ duty cycle on X1, X2.

## WAVEFORMS




Figure 4. A.C. Testing Input, Output Waveform


Figure 5. A.C. Testing Load Circuit

## PORT 2 EXPANDER TIMING



## I/O PORT TIMING



## TYPICAL OSCILLATOR MODES

OSCILLATOR MODE

$\mathbf{C 1}=\mathbf{5 p F} \pm 1 / 2 \mathrm{pF}$, stray capacitance must be less than 5 pF C2 $=$ less than 8 pF
$C 3=20 \mathrm{pF} \pm 1 \mathrm{pF}$, stray capacitance must be less than 5 pF

CRYSTAL SERIES RESISTANCE SHOULD BE LESS THAN $75 \Omega$ AT $8 M H z$ : LESS THAN 180 』 AT 3.6 MHz .

DRIVING FROM
EXTERNAL SOURCE


XTAL1 MUST BE HIGH 35-65\% OF THE PERIOD. AND XTAL. 2 MUST BE HIGH 35-65\% OF THE PERIOD

RISE AND FALL TIMES MUST
NOT EXCEED 20 ns

## P80A48L

## HMOS SINGLE COMPONENT 8-BIT MICROCOMPUTER

Automotive

P80A48L—Mask Programmable ROM—4MHz

- Extended Temperature Range of $-40^{\circ} \mathrm{C}$ to $\mathbf{+ 1 1 0 ^ { \circ }} \mathrm{C}$ in Low-Cost Plastic Package
- Reduced Power Consumption, High Performance HMOS
- Interval Timer/Event Counter

1K x 8 ROM<br>$64 \times 8$ RAM<br>27 I/O Lines<br>- Two Single Level Interrupts<br>■ Over 90 Instructions: 70\% Single Byte

■ $3.75 \mu \mathrm{sec}$ Cycle Time (4.0MHz)
Intel Corporation has recognized the need for high performance, single-chip, microcomputers that operate in the extended temperature and rigorous environment of an automobile. To meet this need, Intel has developed automotive grade products which feature extended operating temperature ranges in cost-effective plastic packages for selected microcomputers. These automotive grade products have been characterized and tested to provide an optimum balance between cost and performance over the standard automotive temperature range of $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$.

Intel's automotive grade products are fully compatible with the corresponding standard products with respect to architecture, instruction set, programming, and software portability.
All automotive grade products are supported by extensive reliability and quality qualification tests, in-process testing, and product monitor testing. This testing program has been designed to ensure that the automotive grade products comply with the rigorous reliability and quality requirements of the automotive industry.


Figure 1.
Block Diagram


Figure 2.
Logic Symbol


Figure 3. Pin Configuration (top view)

P80A48L

Table 1. Pin Description

| Symbol | Pin No. | Function | Symbol | Pin No. | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{v}_{\mathrm{SS}} \\ & \mathrm{v}_{\mathrm{DD}} \\ & \mathrm{v}_{\mathrm{CC}} \end{aligned}$ | 2026 | Circuit GND potential <br> Low power standby pin <br> Main power supply; +5V during operation. | $\overline{\mathrm{RD}}$ | 8 | Also testable with conditional jump instruction. (Active low) |
|  |  |  |  |  |  |
|  | 40 |  |  |  | Output strobe activated during a BUS read. Can be used to enable |
| PROG | 25 | Output strobe for 8243 I/O expander. |  |  | data onto the bus from an external device. |
| P10-P17 <br> Port 1 | 27-34 | 8-bit quasi-bidirectional port. |  |  | Used as a read strobe to external data memory. (Active low) |
| $\begin{aligned} & \text { P20-P27 } \\ & \text { Port } 2 \end{aligned}$ | $\begin{gathered} 21-24 \\ \& \\ 35-38 \end{gathered}$ | 8-bit quasi-bidirectional port. 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{\text { RESET }}$ | 4 | Input which is used to initialize the processor. (Active low) (Non TTL VIH) |
|  |  |  | $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) <br> Used as write strobe to external data memory. |
| $\begin{aligned} & \text { DB0-DB7 } \\ & \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{R D}$, and $\overline{W R}$. | 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. |
|  |  |  | $\overline{\text { PSEN }}$ | 9 | Program store enable. This output occurs only during a fetch to external program memory. <br> (Active low) |
|  |  |  | $\overline{\mathrm{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 essential for |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be |  |  | testing and program verification. (Active high) |
|  |  | designated the timer/counter input using the STRT CNT instruction. | XTAL1 | 2 | One side of crystal input for internal oscillator. Also input for external source. (Non TTL $V_{1 H}$ ) |
| $\overline{\text { INT }}$ | 6 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset.* | XTAL2 | 3 | Other side of crystal input. |

*Interrupt pin must remain low for at least $3{ }^{\text {t }} \mathrm{CY}$ to ensure proper operation.

P80A48L

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description |  |  |
| JMP addr | Jump unconditional | Bytes | Cycles |
| JMPP @A | Jump indirect | 2 | 2 |
| DJNZ R, addr | Decrement register and skip | 1 | 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 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=1$ | 2 | 2 |
| JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
| JF0 addr | Jump on F0 $=1$ | 2 | 2 |
| JF1 addr | Jump on F1 $=1$ | 2 | 2 |
| JTF addr | Jump on timer flag | 2 | 2 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |


| Flags |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Data Moves |  |  |  |
| :--- | :--- | :---: | :--- |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
| XCH A, @R | Exchange A and data memory | 1 | 1 |
| XCHD A, @R | Exchange nibble of A and | 1 |  |
| MOVX A, @R | register | Move external data memory to A | 1 |
| 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 |


| Timer/Counter |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |


| Control |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | Disable external interrupt | 1 | 1 |
| SEL RB0 | 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 |
| ENT0 CLK | Enable clock output on T0 | 1 | 1 |


| Mnemonic Description Bytes Cycles  <br> NOP No operation 1 1 |
| :--- | :--- | :---: |

ABSOLUTE MAXIMUM RATINGS*
Ambient Temperature Under Bias $\ldots-40^{\circ} \mathrm{C}$ to $+110^{\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

* NOTICE: 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 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}=-40^{\circ} \mathrm{C}\right.$ to $\left.+110^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=\mathrm{OV}\right)$

| Symbol | Parameter | P80A48L |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ* | Max |  |  |
| $V_{\text {IL }}$ | Input Low Voltage <br> (All Except $\overline{\text { RESET, }} \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 7 | V |  |
| $V_{\text {IL } 1}$ | Input Low Voltage ( $\overline{\mathrm{RESET}}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.2 |  | VCC | V |  |
| $\mathrm{V}_{1+1}$ | Input High Voltage ( $\mathrm{X} 1, \mathrm{X} 2, \overline{\mathrm{RESET}}$ ) | 3.8 |  | $\mathrm{V}_{\text {CC }}$ | V |  |
| VOL | Output Low Voltage (BUS) |  |  | . 45 | V | $\mathrm{IOL}=2.0 \mathrm{~mA}$ |
| VOL1 | Output Low Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ |  |  | . 45 | V | $\mathrm{IOL}=1.8 \mathrm{~mA}$ |
| VOL2 | Output Low Voltage (PROG) |  |  | . 45 | V | $\mathrm{IOL}=0.8 \mathrm{~mA}$ |
| VOL3 | Output Low Voltage <br> (All Other Outputs) |  |  | . 45 | V | $\mathrm{IOL}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS) | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| VOH1 | Output High Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | $\mathrm{IOH}^{\prime}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage <br> (All Other Outputs) | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}=-30 \mu \mathrm{~A}$ |
| L1 | Input Leakage Current ( $\mathrm{T} 1, \overline{\mathrm{INT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| l $\mathrm{L} / 1$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{\mathrm{SS}}$ ) |  |  | -600 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current (BUS,TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| IDD | VDD Supply Current (power down) |  | 1 4 | $\begin{aligned} & 4 \\ & 6 \end{aligned}$ | mA | $T_{A}=+25^{\circ} \mathrm{C}$ <br> Full Temp. Range |
| $\begin{aligned} & \text { IDD + } \\ & \text { ÍCC } \end{aligned}$ | Total Supply Current |  | $\begin{aligned} & 15 \\ & 30 \end{aligned}$ | $\begin{aligned} & 20 \\ & 50 \end{aligned}$ | mA | $T_{A}=25^{\circ} \mathrm{C}$ <br> Full Temp. Range |
| $V_{\text {DD }}$ | RAM Standby PIN Voltage | 3.0 |  | 5.5 | V | Standby Mode, Reset $\leqslant 0.6 \mathrm{~V}$ |

[^14]A.C. CHARACTERISTICS
$\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.+110^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}\right)$

| Symbol | Parameter | $\begin{gathered} f(\text { tcY } \\ \text { (Note 3) } \end{gathered}$ | P80A48L |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| tLL | ALE Pulse Width | 7/30 tcy -170 | 700 |  | ns |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | 1/5 ter -110 | 640 |  | ns |  |
| tha | Addr Hold from ALE | 1/15 tcy -40 | 210 |  | ns |  |
| ${ }^{t} \mathrm{CC} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 tcy -200 | 1670 |  | ns |  |
| ${ }^{\text {t CC2 }}$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | $2 / 5 \mathrm{tcY}-200$ | 1300 |  | ns |  |
| tow | Data Setup before $\overline{W R}$ | 13/30 tcy -200 | 1420 |  | ns |  |
| twD | Data Hold after $\overline{\mathrm{WR}}$ | 1/15 tcy -50 | 200 |  | ns | (Note 2) |
| tDR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | 1/10 tey -30 | 0 | 350 | ns |  |
| tRD1 | $\overline{\mathrm{RD}}$ to Data in | $2 / 5 \mathrm{tcy}-200$ |  | 1300 | ns |  |
| tRD2 | $\overline{\text { PSEN }}$ to Data in | 3/10 ter -200 |  | 920 | ns |  |
| ${ }^{\text {t }}$ AW | Addr Setup to $\overline{\mathrm{WR}}$ | $2 / 5 \mathrm{tcy}-150$ | 1350 |  | ns |  |
| tAD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 tcy -250 |  | 2620 | ns |  |
| ${ }^{\text {t }}$ AD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | 3/5 tcy-250 |  | 2000 | ns |  |
| $\mathrm{t}_{\mathrm{AFC}}$ | Addr Fioat to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 2/15 tcy -40 | 460 |  | ns |  |
| ${ }^{\text {t }}$ AFC2 | Addr Float to PSEN | 1/30 tcy -40 | 80 |  | ns |  |
| t LAFC1 | ALE to Control ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5 \mathrm{tcy}-75$ | 670 |  | ns |  |
| tLAFC2 | ALE to Control ( $\overline{\text { PSEN }}$ ) | 1/10 teY -75 | 300 |  | ns |  |
| ${ }^{\text {t }}$ (A1 | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15$ tcy -40 | 210 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CA} 2$ | Control to ALE ( $\overline{\text { PSEN }}$ ) | 4/15 tcy -40 | 960 |  | ns |  |
| ${ }^{t} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 tey -80 | 420 |  | ns |  |
| $t \mathrm{PC}$ | Port Control Hold to PROG | 4/15 tcy -200 | 800 |  | ns |  |
| tPR | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy -120 |  | 2130 | ns |  |
| tPF | Input Data Hold from $\overline{\text { PROG }}$ | 1/10 t CY | 0 | 380 | ns |  |
| tDP | Output Data Setup | 2/5 tcy -150 | 1350 |  | ns |  |
| tPD | Output Data Hold | 1/10 teY -50 | 320 |  | ns |  |
| tpp | $\overline{\text { PROG Pulse Width }}$ | 7/10 tcy -250 | 2370 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | 4/15 tcy -200 | 800 |  | ns |  |
| tLP | Port 2 I/O Hold to ALE | 1/10 ter -100 | 270 |  | ns |  |
| tPV | Port Output from ALE | $3 / 10 t_{\text {cY }}+100$ |  | 1220 | ns |  |
| ${ }^{t} \mathrm{Cy}$ | Cycle Time | (1/fXTAL) $\times 15$ | 3.75 |  | $\mu \mathrm{s}$ | (Note 4) |
| toprR | T0 Rep Rate | $3 / 15 \mathrm{t} \mathrm{CY}$ | 750 |  | ns |  |

## Notes:

1. Control Outputs $C_{L}=80 \mathrm{pF}$ BUS Outputs $C_{L}=150 \mathrm{pF}$
2. BUS High Impedance Load 20 pF
3. Equation to calculate theoretical AC timing parameters at frequency of choice. Calculated values will be equal to or better than published values. Equation assumes $50 \%$ duty cycle on X 1 , X2.
4. Maximum $\mathrm{t}_{\mathrm{C}}=15.0 \mu \mathrm{~s}(1.0 \mathrm{MHz})$.

## WAVEFORMS




Figure 4. A.C. Testing Input, Output Waveform


Figure 5. A.C. Testing Load Circuit

PORT 2 EXPANDER TIMING


## I/O PORT TIMING



## TYPICAL OSCILLATOR MODES

## OSCILLATOR MODE



C1 $=\mathbf{5 p F} \pm 1 / 2 \mathrm{pF}$, stray capacitance must be less than 5 pF C2 $=$ less than 8 pF C3 $=\mathbf{2 0 p F} \pm 1 \mathrm{pF}$, stray capacitance must be less than 5pF

CRYSTAL SERIES RESISTANCE SHOULD BE LESS THAN $180 \Omega$ AT 3.6 MHz .

## DRIVING FROM

 EXTERNAL SOURCE

XTAL1 MUST BE HIGH 35-65\% OF THE PERIOD. AND XTAL2 MUST BE HIGH 35-65\% OF THE PERIOD.

RISE AND FALL TIMES MUST NOT EXCEED 20 ns .

P80A48H/P80A35HL

# HMOS SINGLE COMPONENT 8-BIT MICROCOMPUTER 

## Automotive

- P80A48H—Mask Programmable ROM—8MHz
- P80A35HL—CPU Only with Power Down

■ Extended Temperature Range of $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$ in Low-Cost Plastic Package<br>- Reduced Power Consumption, High Performance HMOS<br>- Interval Timer/Event Counter<br>- $1.88 \mu \mathrm{sec}$ Cycle Time (8.0MHz)

\author{

- 1K x 8 ROM <br> $64 \times 8$ RAM 27 I/O Lines <br> - Two Single Level Interrupts <br> ■ Over 90 Instructions: 70\% Single Byte
}

Intel Corporation has recognized the need for high performance, single-chip, microcomputers that operate in the extended temperature and rigorous environment of an automobile. To meet this need, Intel has developed automotive grade products which feature extended operating temperature ranges in cost-effective plastic packages for selected microcomputers. These automotive grade products have been characterized and tested to provide an optimum balance between cost and performance over the standard automotive temperature range of $-40^{\circ} \mathrm{C}$ to $+110^{\circ} \mathrm{C}$.
Intel's automotive grade products are fully compatible with the corresponding standard products with respect to architecture, instruction set, programming, and software portability.
All automotive grade products are supported by extensive reliability and quality qualification tests, in-process testing, and product monitor testing. This testing program has been designed to ensure that the automotive grade products comply with the rigorous reliability and quality requirements of the automotive industry.


Figure 1.
Block Diagram


Figure 2.
Logic Symbol


Figure 3. Pin Configuration (top view)

Table 1. Pin Description

| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| $V_{\text {SS }}$ | 20 | Circuit GND potential |
| VDD | 26 | Low power standby pin |
| $V_{C C}$ | 40 | Main power supply; +5V during operation. |
| PROG | 25 | Output strobe for 8243 I/O expander. |
| P10-P17 <br> Port 1 | 27-34 | 8 -bit quasi-bidirectional port. |
| P20-P27 <br> Port 2 | $\begin{gathered} 21-24 \\ \& \\ 35-38 \end{gathered}$ | 8-bit quasi-bidirectional port. 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 . |
| $\begin{aligned} & \text { DB0-DB7 } \\ & \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{R D}$, and $\overline{W R}$. |
| 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. |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. |
| $\overline{\text { INT }}$ | 6 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset.* |


| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
|  |  | 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. <br> Used as a read strobe to external data memory. (Active low) |
| $\overline{\text { RESET }}$ | 4 | Input which is used to initialize the processor. (Active low) (Non TTL VIH) |
| $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) <br> 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. <br> 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 conjunction 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 for external source. (Non TTL $\mathrm{V}_{1 \mathrm{H}}$ ) |
| XTAL2 | 3 | Other side of crystal input. |

*Interrupt pin must remain low for at least ${ }^{3 t} \mathrm{CY}$ to ensure proper operation.

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=1$ | 2 | 2 |
| JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
| JF0 addr | Jump on F0 $=1$ | 2 | 2 |
| JF1 addr | Jump on F1 $=1$ | 2 | 2 |
| JTF addr | Jump on timer flag | 2 | 2 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |


| Flags |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Data Moves |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
| XCH A, @R | Exchange A and data memory | 1 | 1 |
| XCHD A, @R | Exchange nibble of A and | 1 |  |
|  | register |  |  |
| 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, @ | Move to A from page 3 | 1 | 2 |


| Timer/Counter |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |


| Control |  |  |
| :--- | :--- | :---: |
| Mnemonic | Description | Bytes Cycles |
| EN 1 | Enable external interrupt | 1 |
| DIS 1 | Disable external interrupt | 1 |
| SEL RB0 | Select register bank 0 | 1 |
| SEL RB1 | Select register bank 1 | 1 |
| SEL MB0 | Select memory bank 0 | 1 |
| SEL MB1 | Select memory bank 1 | 1 |
| ENTO CLK | Enable clock output on TO | 1 |

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots-40^{\circ} \mathrm{C}$ to $+110^{\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

* NOTICE: 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 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}=-40^{\circ} \mathrm{C}\right.$ to $+110^{\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{aligned} & 80 \mathrm{~A} 48 \mathrm{H} \\ & 80 \mathrm{~A} 35 \mathrm{HL} \\ & \hline \end{aligned}$ |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ* | Max |  |  |
| $V_{\text {IL }}$ | Input Low Voltage <br> (All Except $\overline{\text { RESET, }} \mathbf{X 1}, \mathrm{X} 2$ ) | -. 5 |  | . 7 | V |  |
| $\mathrm{V}_{\text {IL1 }}$ | Input Low Voltage ( $\overline{\mathrm{RESET}}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.2 |  | VCC | V |  |
| $\mathrm{V}_{1} \mathrm{H} 1$ | Input High Voltage (X1, X2, $\overline{\text { RESET }}$ ) | 3.8 |  | VCC | V |  |
| VOL | Output Low Voltage (BUS) |  |  | . 45 | V | $1 \mathrm{OL}=2.0 \mathrm{~mA}$ |
| VOL1 | Output Low Voltage <br> ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ |  |  | . 45 | V | $\mathrm{IOL}=1.8 \mathrm{~mA}$ |
| VOL2 | Output Low Voltage (PROG) |  |  | . 45 | V | $1 \mathrm{OL}=0.8 \mathrm{~mA}$ |
| VOL3 | Output Low Voltage (All Other Outputs) |  |  | . 45 | V | $\mathrm{OL}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| VOH1 | Output High Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | $\mathrm{I}^{\prime} \mathrm{OH}=-100 \mu \mathrm{~A}$ |
| $\mathrm{VOH}^{2}$ | Output High Voltage (All Other Outn: is) | 2.4 |  |  | V | $\mathrm{I}^{\mathrm{OH}}=-30 \mu \mathrm{~A}$ |
| LL1 | Input Leakage Current ( $\mathrm{T} 1, \overline{\mathrm{INT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ! LI 1 | Input Leakage Current $\text { (P10-P17, P20-P27, EA, } \overline{\mathrm{S}})$ |  |  | -600 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| ILO | Output Leakage Current (BUS,TO) (High Impedance State) | . | . | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| IDD | VDD Supply Current (power down) |  | $\begin{aligned} & 4 \\ & 6 \end{aligned}$ | $\begin{gathered} 8 \\ 12 \end{gathered}$ | mA | $T_{A}=+25^{\circ} \mathrm{C}$ <br> Full Temp. Range |
| $\begin{aligned} & \text { IDD + } \\ & \text { ICC } \end{aligned}$ | Total Supply Current |  | $\begin{aligned} & 40 \\ & 50 \end{aligned}$ | $\begin{aligned} & 75 \\ & 95 \end{aligned}$ | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> Full Temp. Range |
| $\mathrm{V}_{\text {DD }}$ | RAM Standby PIN Voltage | 3.0 |  | 5.5 | V | Standby Mode, Reset $\leqslant 0.6 \mathrm{~V}$ |

[^15]
## A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.+110^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{D D}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}\right)$

| Symbol | Parameter | $\begin{gathered} \text { f(tcY) } \\ \text { (Note 3) } \end{gathered}$ | $\begin{aligned} & \text { P80A48H } \\ & \text { P80A35HL } \\ & \hline \end{aligned}$ |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| tLL | ALE Pulse Width | 7/30 tcy -170 | 260 |  | ns |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | 1/5 tcy -110 | 260 |  | ns |  |
| tLA | Addr Hold from ALE | 1/15 tCY -40 | 80 |  | ns |  |
| tCC1 | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 tcy -200 | 740 |  | ns |  |
| tcC2 | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | $2 / 5$ tcy -200 | 550 |  | ns |  |
| tow | Data Setup before $\overline{\mathrm{WR}}$ | 13/30 tcy -200 | 610 |  | ns |  |
| tWD | Data Hold after $\overline{W R}$ | 1/15 tcy -50 | 70 |  | ns | (Note 2) |
| tDR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\text { PSEN }}$ ) | 1/10 ter -30 | 0 | 160 | ns |  |
| tRD1 | $\overline{\mathrm{RD}}$ to Data in | $2 / 5$ tcy -200 |  | 550 | ns |  |
| trD2 | $\overline{\text { PSEN }}$ to Data in | 3/10 tcy -200 |  | 360 | ns |  |
| taw | Addr Setup to WR | $2 / 5 \mathrm{t}_{\mathrm{CY}}-150$ | 600 |  | ns |  |
| ${ }^{\text {t }}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 tcy -250 |  | 1190 | ns |  |
| ${ }^{\text {t AD2 }}$ | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | 3/5 tcy-250 |  | 870 | ns |  |
| tAFC1 | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15$ tcy -40 | 210 |  | ns |  |
| ${ }^{\text {t } A F C 2}$ | Addr Float to PSEN | 1/30 tcy -40 | 20 |  | ns |  |
| tLAFC1 | ALE to Control ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/5 tcy -75 | 300 |  | ns |  |
| tLAFC2 | ALE to Control ( $\overline{\text { PSEN }}$ ) | 1/10 tey -75 | 110 |  | ns |  |
| tCA1 | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}})$ | 1/15 tcy -40 | 80 |  | ns |  |
| tca2 | Control to ALE ( $\overline{\text { PSEN }}$ ) | 4/15 tcy -40 | 460 |  | ns |  |
| tcP | Port Control Setup to PROG | 2/15 tcy -80 | 170 |  | ns |  |
| tPC | Port Control Hold to PROG | 4/15 tcy -200 | 300 |  | ns |  |
| tPR | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcY -120 |  | 1000 | ns |  |
| tPF | Input Data Hold from PROG | $1 / 10$ tcy | 0 | 190 | ns |  |
| tDP | Output Data Setup | $2 / 5$ tcy -150 | 600 |  | ns |  |
| tPD | Output Data Hold | 1/10 tcy -50 | 140 |  | ns |  |
| tPP | $\overline{\text { PROG Pulse Width }}$ | 7/10 tey -250 | 1060 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | 4/15 tcy -200 | 300 |  | ns |  |
| tLP | Port 2 I/O Hold to ALE | 1/10 ter -100 | 90 |  | ns |  |
| tpV | Port Output from ALE | 3/10 tCY +100 |  | 660 | ns |  |
| tcy | Cycle Time | (1/fXTAL) $\times 15$ | 1.88 |  | $\mu \mathrm{s}$ | (Note 4) |
| topRR | T0 Rep Rate | $3 / 15$ tcy | 370 |  | ns |  |

## Notes:

1. Control Outputs $C_{L}=80 \mathrm{pF}$ BUS Outputs $C_{L}=150 \mathrm{pF}$
2. BUS High Impedance Load 20 pF
3. Equation to calculate theoretical AC timing parameters at frequency of choice. Calculated values will be equal to or better than published values. Equation assumes $50 \%$ duty cycle on X 1 , X2.
4. Maximum tey $=15.0 \mu \mathrm{~s}(1.0 \mathrm{MHz})$.

## WAVEFORMS



Instruction Fetch From External Program Memory


Read From External Data Memory


Write to External Data Memory


Figure 4. A.C. Testing Input, Output Waveform


Figure 5. A.C. Testing Load Circuit

## PORT 2 EXPANDER TIMING



## I/O PORT TIMING



## TYPICAL OSCILLATOR MODES

## OSCILLATOR MODE


$\mathbf{C 1}=\mathbf{5 p F} \pm 1 / 2 \mathrm{pF}$, stray capacitance must be less than 5pF $\mathbf{C 2}$ = less than 8 pF
C3 $=20 \mathrm{pF} \pm 1 \mathrm{pF}$, stray capacitance must be less than 5 pF

CRYSTAL SERIES RESISTANCE SHOULD BE LESS THAN $75 \Omega$ AT 8 MHz ; LESS THAN $180 \Omega \mathrm{AT} 3.6 \mathrm{MHz}$

## DRIVING FROM EXTERNAL SOURCE

XTAL1 MUST BE HIGH 35-65\% OF THE PERIOD, AND XTAL2 MUST BE HIGH 35-65\% OF THE PERIOD

RISE AND FALL TIMES MUST NOT EXCEED 20 ns .

## MCS-48 ${ }^{\text {™ }}$

Microprocessors
6

8020H

# HMOS SINGLE-COMPONENT 8-BIT MICROCOMPUTER 

8-bit CPU, ROM, RAM, I/O in Single 20-pin Package<br>Single +5 V 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.

\author{

- 1K x 8 ROM <br> $64 \times 8$ RAM <br> 13 I/O Lines <br> - Internal Timer/Counter <br> 30mA Operation @ $25^{\circ} \mathrm{C}$
}

The Intel ${ }^{(8020 H}$ is a cost-effective single-chip microcomputer for high volume, cost-sensitive applications such as home entertainment products, appliances and simple control jobs. The 8020 H is an 8-bit computer fabricated on a single silicon chip using Intel's advanced N -channel silicon gate HMOS process.

The 8020 H key features include a subset of the industry standard 8048 's instruction set optimized for the consumer an appliance marketplaces. Some of these features are a $1 \mathrm{~K} \times 8$ program memory, a $64 \times 8$ data memory, 13 I/O lines and an 8-bit timer/counter in addition to on-board oscillator and clock circuits. The 20pin package provides board real estate savings.

A specific requirement in many of these market-type applications is the need for more $1 / 0$. The 8020 H has instructions and hardware on-board to interface to TTL I/O expansion packages.

To make efficient use of the program memory size, the 8020 H has an instruction set optimized for byte efficiency and control. No instructions are longer than 2 bytes, with $70 \%$ of the instructions at 1 byte. For control-oriented applications, arithmetic instructions are supported using binary and BCD operands.


Figure 1.
Figure 2.
Figure 3. Pin
Logic Symbol
Block Diagram
Configuration

[^16]8020H

Table 1. Pin Description

| Symbol | Pin No. | Function |
| :--- | :---: | :--- |
| V $_{\text {SS }}$ | 15 | Circuit GND potential |
| VCC $^{\text {PROG }}$ | 4 | +5 V power supply |
| PROG | 5 | Output strobe for TTL I/O expansion |
| P00-P07 <br> Port 0 | $6-13$ | 8-bit quasi-bidirectional port |
| P3-P17 <br> Port 1 | $19-20$ <br> $1-3$ | 5-bit quasi-bidirectional port |
| TI | 14 | Input pin testable using the JT1 and JNT1 instructions. Can be designated the timer/event <br> counter input using the STRT CNT instruction. Also allows zero-crossover sensing of slowly <br> moving AC inputs |
| RESET | 18 | Input used to initialize the processor by clearing status flip-flops and setting program <br> counters to zero. |
| XTAL1 | 16 | One side of crystal or inductor input for internal oscillator. Also input for external source. <br> (Not TTL compatible.) |
| XTAL2 | 17 | Other side of timing control elernent. |

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Descripsion | Bytes Cycles |  |
| 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 with carry | 1 | 1 |
| ADDC A, @R | Add with carry | 1 | 1 |
| ADDC A, \# data | Add 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, \& | 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 nibles 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 |


| Registers |  |  |
| :--- | :--- | :---: |
| Mnemonic | Description | Bytes Cycles |
| INC R | Increment register | 1 |
| INC @R | Increment data memory | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description |  |  |
| JMP addr | Jump unconditional | Bytes Cycles |  |
| JMPP @A | Jump indirect | 2 | 2 |
| DJNZ R, addr | Decrement register and Jump | 1 | 2 |
|  | on R not zero | 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 |
| JT1 addr | Jump on T1 =1 | 2 | 2 |
| JNT1 addr | Jump on T1 =0 | 2 | 2 |
| JTF addr | Jump on timer flag | 2 | 2 |


| Input/Output |  |  |
| :--- | :--- | :---: |
| Mnemonic | Description | Bytes Cycles |
| IN A, P | Input port to A | 1 |
| OUTL P, A | Output A to port | 1 |


| Flags |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonics | Description | Bytes Cycles |  |
| CLR C | Clear Carry | 1 | 1 |
| CPL C | Complement Carry | 1 | 1 |

Table 2. Instruction Set Summary (cont.)

| Data Moves |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonics | Description | Bytes Cycles |  |
| 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 | 2 | 2 |
|  | memory |  |  |
| XCH A, R | Exchange A and register | 1 | 1 |
| XCH A, @R | Exchange A and data memory | 1 | 1 |
| XCHD A, @R | Exchange nibble of A and | 1 | 1 |
| MOVP A, @A | register | Move to A from current page | 1 |


| Timer/Counter |  |  |  |
| :--- | :--- | :---: | :--- |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
|  |  |  |  |
| Mnemonics | Description | Bytes Cycles |  |
| NOP | No Operation | 1 | 1 |

*NOTICE: 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.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (All except XTAL 1 \& 2, T1, RESET) | 3.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | 隹 |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage (XTAL $1 \& 2, \mathrm{~T} 1$, RESET) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}}(10 \%)$ | Input High Voltage (All except XTAL 1 \& 2, T1, RESET) | 2.0 |  | $V_{\mathrm{CC}}$ | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{V}_{1 \mathrm{H} 1}(10 \%)$ | Input High Voltage (XTAL 1 \& 2, T1, RESET) | 3.5 |  | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 10 \%$ |
| VOL | Output Low Voltage |  |  | 0.45 | V | $1 \mathrm{OL}+1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage (All unless Open Drain) | 2.4 |  |  | V | $\mathrm{IOH}^{\prime}=40 \mu \mathrm{~A}$ |
| ILO | Output Leakage Current (Open Drain Option-Port 0) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 30 | 60 | mA |  |

T1 ZERO CROSS 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}, \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ )

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{Z X}$ | Zero-Cross Detection Input (T1) | 1 | 3 | $V_{P P}$ | AC Coupled, $\mathrm{C}=.2 \mu \mathrm{~F}$ |
| AZX | Zero-Cross Accuracy |  | $\pm 135$ | mV | 60 Hz Sine Wave |
| FZX | Zero-Cross Detection Input <br> Frequency (T1) | 0.05 | 1 | kHz |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Cycle Time | 8.38 | 50.0 |  | $3.58 \mathrm{MHz} \mathrm{XTAL}=8.38 \mu \mathrm{~s}$ t CY |

## 8020H FUNCTIONAL SPECIFICATIONS

The following is a functional description of the major elements of the 8020 H .

## Program Memory

The 8020 H 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 4. 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 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 repetitive-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. The unincremented program counter address is stored in the address stack. The stack contents is incremented before being loaded into the program counter during a return from subroutine. 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 addreses 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 stratchpad location. For example, if only 3 levels of subroutine nesting are used, then only locations 8-13 need be reserved for the address stack, and locations 14-63 can be used for data storage.


Figure 4. Internal RAM Organization.

## Oscillator and Clock

The 8020 H contains its own onboard oscillator and clock circuit, requiring only an external timing control element. This control element can be a crystal, inductor, or clock in. The capacitor normally required in inductor timing control operation is integrated onto the 8020 H . All internal time slots are derived from the external element, and all outputs are a function of the oscillator frequency. Pins XTAL1 and XTAL2 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. (See Figure 5.) Therefore, to obtain a $10 \mu \mathrm{sec}$ instruction cycle, a 3 MHz crystal should be used. An oscillator frequency of approximately 3 MHz may also be obtained by connecting a $470 \mu \mathrm{H}$ inductor between XTAL1 and XTAL2. Note that the required inductance may vary and should be adjusted as necessary.
The 8020 H utilizes dynamic RAM and certain other dynamic logic. Due to the clocking required with dynamic circuits, the oscillator frequency must be equal to or greater than 600 K Hz , or improper operation may occur.


Figure 5. 8020H Timing Diagram

## Timer/Event Counter

The 8020 H has internal timer/event counter circuits that can monitor elapsed time or count external events that occur during program execution. The circuit has an 8-bit binary up-counter that is presettable and readable with two MOV instructions. These instructions transfer the contents of the accumulator to the counter and vice versa. The counter content is not affected by Reset, and is initialized solely by the MOV T,A instruction. The counter is stopped by a RESET or STOP TCNT instruction and remains stopped until started as a timer by a STRT T instruction or as an event counter by a STRT CNT instruction. Once started, the counter increments to its maximum count (FF), and overflows to zero. The count continues until stopped by a STOP TCNT instruction or RESET. The increment from maximum count to zero (overflow) sets an overflow flag. The state of the overflow flag is testable with the conditional jump instruction JTF. The flag is reset by JTF but not by executing a RESET, unlike the 8748.

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 ${ }^{\circ}(00 \mathrm{H})$ timer flag is set. A conditional branch instruction (JTF) 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 stops upon the STOP TCNT instruction.
The STRT CNT instruction connects the T1 input pin to the event counter input and enables the counter. Subsequent high-to-low transitions on T1
increment the counter. The maximum rate at which the counter can increment is once per three instruction cycles ( $30 \mu \mathrm{~s}$ for a 3 MHz oscillator). There is no minimum frequency. T1 input must remain high for at least 500ns after each transition. The event counter is stopped by a STOP TCNT instruction.

## Input/Output Capabilities

The 8020 H I/O configurations are highly flexible. A number of different configurations are possible, tailoring an 8020 H to a given task. Other than the power supply and dedicated pins, all other pins (13) can be used for input, output, or both, depending on the configuration.
All ports are quasi-bidirectional to facilitate standalone use. A simplified schematic of the quasibidirectional interface is shown in Figure 6. This configuration allows buffered outputs, and also allows external input. Data written to these ports is statically latched and remains unchanged until rewritten. As input ports these lines are non-latching, i.e., inputs must be present until read by an input instruction. 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 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 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.


Figure 6. Quasi-Bidirectional Port Structure

## T1 Input

The 8020 H T1 input line can be used as an input for the following functions:

- Event Counter (external input)
- Test input for branch instructions
- Zero voltage crossing detection

The operation of T1 as an input to the Event Counter is described in the Timer/Event Counter section. When used as a test input, the JT1 and JNT1 instructions test for 1 and 0 levels, respectively.

The T1 pin can also be used to detect the zero crossing of slowly moving AC signals ( 60 Hz ). The selfbiasing circuit shown in Figure 7 permits the Test 1 input to detect when the input voltage crosses zero within $\pm 5 \%$; the voltage is then coupled through a $1.0 \mu \mathrm{f}$ capacitor. Maximum input voltage is 3 V peak-to-peak. The zero cross detection is especially useful in SCR control of 60 Hz power and in developing time-of-day and other timing routines. As a ROM mask option there is a pullup resistor that is useful for switch contact input or standard TTL.
The 8020 H can use standard low cost TTL to expand the number of I/O lines.

## CPU

The 8020 H 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 $B C D$ arithmetic capability using the DAA, SWAP A, and XCHD instructions. In addition, MOVP A,@A allows table lookup for display formating and constants. The conditional branch logic within the processor enables several conditions internal and external to the processor to be tested by the users program. Use the conditional jump instructions with the tests listed below to effect a change in the program execution sequence:

| Test | Jump Condition | Jump Instructions |
| :---: | :---: | :---: |
| Accumulator | $A=0 A \neq 0$ | JZ JNZ |
| Carry Flag | 01 | , JC |
| Timer Overflow Flag | - 1 | JTF |
| Test Input-T1 | 01 | JNT1, JT1 |

## Reset

A positive-going signal to the RESET input resets the necessary miscellaneous flip-flops and sets the program counter and stack pointer to zero.


Figure 7. Test 1 Pin

# SINGLE COMPONENT 8-BIT MICROCOMPUTER 

\author{

- 8-Bit CPU, ROM, RAM, I/O in Single 28-Pin Package <br> - Single 5V Supply (+4.5V to 6.5V) <br> ■ $8.38 \mu \mathrm{sec}$ Cycle With 3.58 MHz XTAL; All Instructions 1 or 2 Cycles <br> Instructions-8048 Subset <br> High Current Drive Capability-2 Pins
}

\author{

- 1K x 8 ROM <br> $64 \times 8$ RAM <br> 21 I/O Lines <br> - Interval Timer/Event Counter <br> - Clock Generated With Single Inductor or Crystal <br> - Zero-Cross Detection Capability <br> - Easily Expandable I/O
}

The Intel ${ }^{\oplus} 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 1K X 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 the development problems and maximize flexibility, an 8021 system can be easily designed using the 8021 emulation board, the EM-1. The EM-1 contains a 40 -pin socket which can accommodate either the 8748 shipped with the board or an ICE-49 plug. Also, the necessary discrete logic to reproduce the 8021's additional I/O features is included.


Figure 1.
Block Diagram


Figure 2. Logic Symbol


Figure 3. Pin Configuration

## HMOS SINGLE-COMPONENT 8-BIT MICROCOMPUTER

8-Bit CPU, ROM, RAM, I/O in Single 28-Pin Package<br>■ Single 5V Supply (+4.5V to 6.5V)<br>■ $8.38 \mu \mathrm{sec}$ Cycle with 3.58 MHz XTAL; All instructions 1 or 2 Cycles<br>- 30mA Operation @ $25^{\circ} \mathrm{C}$<br>■ Instructions-8048 Subset<br>- High Current Drive Capability-2 Pins

\author{

- 1K x 8 ROM <br> $64 \times 8$ RAM 21 I/O Lines <br> ■ Interval Timer/Event Counter <br> - Clock Generated with Single Inductor or Crystal <br> - Zero-Cross Detection Capability <br> ■ Easily Expandable I/O
}

The Intele ${ }^{(8021 \mathrm{H}}$ is a totally self-sufficient 8-bit parallel computer fabricated on a single silicon chip using Intel's advanced N-channel silicon gate HMOS process. The features of the 8021 H include a subset of the 8048 features optimized for low cost, high volume applications, plus additional I/O flexibility and power.

The 8021 H contains $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 H can be expanded using the 8243 or discrete logic.

This microcomputer is designed to be an efficient controller as well as an arithmetic processor. The 8021 H 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 H system can be easily designed using the 8021 H emulation board, the EM-1. The EM-1 contains a 40-pin socket which can accommodate either the 8748 shipped with the board or an ICE-49 plug. Also, the necessary discrete logic to reproduce the 8021 H 's additional I/O features is included.


Figure 1.
Block Diagram

Figure 2.
Logic Symbol


Figure 3. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Function |
| :--- | :---: | :--- |
| V SS | 14 | Circuit GND potential |
| VCC | 28 | +5V power supply |
| PROG | 3 | Output Strobe for 8243 I/O Expander |
| P00-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$ <br> $1-2$ | 4-bit quasi-bidirectional port P20-P23 also serve as a 4-bit I/O expander bus for 8243 |
| T1 | 13 | Input pin testable using the JT1 and JNT1 instructions. Can be designated the timer/event <br> counter input using the STRT CNT instructions. Also allows zero-crossover sensing of slowly <br> moving AC inputs. |
| RESET | 17 | Input used to initialize the processor by clearing status flip-flops and setting program <br> counters to zero. |
| ALE | 12 | Address Latch Enable. Signal occurring once every 30 input clocks, used as an output clock. <br> XTAL1 <br> 15One side of crystal or inductor input for internal oscillator. Also input for external source. <br> (Not TTL compatible.) |
| XTAL2 | 16 | Other side of timing control element. |

Table 2. Instruction Set Summary

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 with carry | 1 | 1 |
| ADDC A, @R | Add with carry | 1 | 1 |
| ADDC A, \# data | Add 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| IN A, P | Input port to A | 1 | 2 |
| OUTL P, A | Output A to port | 1 | 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| INC R |  |  |  |

INC @R $\quad$| Increment register |  |  |  |
| :--- | :--- | :---: | :---: |
| Increment data memory | 1 | 1 |  |
| Branch |  |  |  |
| Mnemonic | Description | Bytes Cycles |  |
| JMP addr | Jump unconditional | 2 | 2 |
| JMPP @A | Jump indirect | 1 | 2 |
| DJNZ R, addr | Decrement register and Jump | 2 | 2 |
|  | on R not zero |  |  |

| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JT1 addr | Jump on T1 $=1$ | 2 | 2 |
| JNT1 addr | Jump on T1 $=0$ | 2 | 2 |
| JTF addr | Jump on timer flag | 2 | 2 |


| Subroutine |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| CALL | Jump to subroutine | 2 | 2 |
| RET | Return | 1 | 2 |


| Flags |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| CLR C | Clear Carry | 1 | 1 |
| CPL C | Complement Carry | 1 | 1 |

Table 2. Instruction Set Summary (cont.)

| Data Moves |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 | 2 | 2 |
| XCH A, R | memory | Exchange A and register | 1 |
| XCH A, @R | Exchange A and data memory | 1 | 1 |
| XCHD A, @R | Exchange nibble of A and | 1 | 1 |
| MOVP A, @A | register | Move to A from current page | 1 |


| Timer/Counter |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
|  |  |  |  |
| Mnemonic | Description | Bytes Cycles |  |
| NOP | No Operation | 1 | 1 |

ABSOLUTE MAXIMUM RATINGS*
Ambient Temperature Under Bias $\ldots \ldots \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.......................5V to +7 V
Power Dissipation..............................
*NOTICE: 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}_{C C}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage (All except <br> XTAL 1 \& 2, T1, RESET) | 3.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage (XTAL 1 \& 2, T1, <br> RESET) | 3.8 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH}(10 \%)}$ | Input High Voltage (All except <br> XTAL 1 \& 2, T1, RESET) | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{~V}_{\mathrm{IH} 1(10 \%)}$ | Input High Voltage (XTAL 1 \& 2, T1, <br> RESET) | 3.5 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}+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 <br> Open Drain) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=40 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current (Open <br> Drain Option-Port 0) |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{SS}}+0.4 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | VCC Supply Current |  | 30 | 60 | mA |  |

T1 ZERO CROSS 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}, \mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ )

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| V ZX $^{\|c\|}$ | Zero-Cross Detection Input (T1) | 1 | 3 | VPP | AC Coupled, C $=.2 \mu \mathrm{~F}$ |
| AZX | Zero-Cross Accuracy |  | $\pm 135$ | mV | 60 Hz Sine Wave |
| FZX | Zero-Cross Detection Input <br> Frequency (T1) | 0.05 | 1 | kHz |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Cycle Time | 8.38 | 50.0 |  | $3.58 \mathrm{MHz} \mathrm{XTAL}=8.38 \mu \mathrm{~s}$ t CY |

A.C. 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}$ )

Test Conditions: $\mathrm{C}_{\mathrm{L}}=80_{\mathrm{p}} \mathrm{F}$, tcy $=8.38 \mu \mathrm{~s}$

|  | Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Normal Operation | $t_{\text {c }} \mathrm{Y}$ | Cycle Time | 8.38 | 50.0 | $\mu \mathrm{S}$ | 3.58 MHz XTAL |
|  | tPRL | ALE to Time $\mathrm{P}_{ \pm}$Input Must Be Valid (input setup) |  | 4.0 | $\mu \mathrm{s}$ |  |
|  | ${ }^{\text {tPL }}$ | Output Data Setup Time | 0.6 |  | $\mu s$ |  |
|  | tip | Output Data Hold Time | 0.6 |  | $\mu \mathrm{s}$ |  |
|  | tPFL | Input Data Hold Time | 0 |  | $\mu \mathrm{s}$ |  |
|  | tLL | ALE Pulse Width | 0.8 |  | $\mu \mathrm{s}$ |  |
|  | $\mathrm{t}_{\mathrm{R}}$ | Reset High | 3 |  | ${ }_{\text {t }}^{\text {cr }}$ |  |
|  | RXTAL | Resistor Across XTAL | . 5 | 1 |  |  |
| Expander Operation | ${ }^{\text {t }}$ CP | Port Control Setup Before Falling Edgle of PROG | 0.3 |  | $\mu \mathrm{S}$ |  |
|  | $t_{\text {cP }}$ | Port Control Hold After Falling Edge of PROG | 0.8 |  | $\mu \mathrm{s}$ |  |
|  | tPR | PROG to Time $\mathrm{P} \pm$ Input Must Be Valid | 2.0 | 4.0 | $\mu \mathrm{s}$ |  |
|  | tDP | Output Data Setup Time | 1.0 |  | $\mu \mathrm{s}$ |  |
|  | tPD | Output Data Hold Time | 0.6 |  | $\mu \mathrm{S}$ |  |
|  | $t_{\text {PF }}$ | Input Data Hold Time | 0 | . 15 | $\mu \mathrm{S}$ |  |
|  | $t_{\text {PP }}$ | PROG Pulse Width | 6.0 |  | $\mu \mathrm{S}$ | - |

PORT 2 TIMING


## 8021H FUNCTIONAL SPECIFICATIONS

The following is a functional description of the major elements of the 8021 H .

## Program Memory

The 8021 H 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 4. 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 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 repetitive-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. The unincremented program counter address is stored in the address stack. The stack contents is incremented before being loaded into the program counter during a return from subroutine. 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-13 need be reserved for the address stack, and locations 14-63 can be used for data storage.


Figure 4. Internal RAM Organization

## Oscillator and Clock

The 8021 H contains its own onboard oscillator and clock circuit, requiring only an external timing control element. This control element can be a crystal, inductor, or clock in. The capacitor normally required in inductor timing control operation is integrated onto the 8021 H . All internal time slots are derived from the external element, and all outputs are a function of the oscillator frequency. Pins XTAL1 and XTAL2 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. (See Figure 5.) Therefore, to obtain a $10 \mu \mathrm{sec}$ instruction cycle, a 3 MHz crystal should be used. An oscillator frequency of approximately 3 MHz may also be obtained by connecting a $470 \mu \mathrm{H}$ inductor between XTAL1 and XTAL2. Note that the required inductance may vary and should be adjusted as necessary.
The 8021 H utilizes dynamic RAM and certain other dynamic logic. Due to the clocking required with dynamic circuits, the oscillator frequency must be equal to or greater than 600 K Hz , or improper operation may occur.


Figure 5. 8021H Timing Diagram

## Timer/Event Counter

The 8021 H has internal timer/event counter circuits that can monitor elapsed time or count external events that occur during program execution. The circuit has an 8-bit binary up-counter that is presettable and readable with two MOV instructions. These instructions transfer the contents of the accumulator to the counter and vice versa. The counter content is not affected by Reset, and is initialized solely by the MOV T,A instruction. The counter is stopped by a RESET or STOP TCNT instruction and remains stopped until started as a timer by a STRT T instruction or as an event counter by a STRT CNT instruction. Once started, the counter increments to its maximum count (FF), and overflows to zero. The count continues until stopped by a STOP TCNT instruction or RESET. The increment from maximum count to zero (overflow) sets an overflow flag. The state of the overflow flag is testable with the conditional jump instruction JTF. The flag is reset by JTF but not by executing a RESET, unlike the 8748 .

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 instruction (JTF) 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 stops upon the STOP TCNT instruction.
The STRT CNT instruction connects the T1 input pin to the event counter input and enables the counter. Subsequent high-to-low transitions on T1
increment the counter. The maximum rate at which the counter can increment is once per three instruction cycles ( $30 \mu \mathrm{~s}$ for a 3 MHz oscillator). There is no minimum frequency. T1 input must remain high for at least 500ns after each transition. The event counter is stopped by a STOP TCNT instruction.

## Input/Output Capabilities

The 8021 H I/O configurations are highly flexible. A number of different configurations are possible, tailoring an 8021 H 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.
All ports are quasi-bidirectional to facilitate standalone use. A simplified schematic of the quasibidirectional interface is shown in Figure 6. This configuration allows buffered outputs, and also allows external input. Data written to these ports is statically latched and remains unchanged until rewritten. As input ports these lines are non-latching, i.e., inputs must be present until read by an input instruction. 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 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 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.


Figure 6. Quasi-Bidirectional Port Structure

## T1 Input

The 8021 H T1 input line can be used as an input for the following functions:

- Event Counter (external input)
- Test input for branch instructions
- Zero voltage crossing detection

The operation of T1 as an input to the Event Counter is described in the Timer/Event Counter section. When used as a test input, the JT1 and JNT1 instructions test for 1 and 0 levels, respectively.
The T1 pin can also be used to detect the zero crossing of slowly moving AC signals ( 60 Hz ). The selfbiasing circuit shown in Figure 7 permits the Test 1 input to detect when the input voltage crosses zero within $\pm 5 \%$; the voltage is then coupled through a $1.0 \mu \mathrm{~F}$ capacitor. Maximum input voltage is 3 V peak-to-peak. The zero cross detection is especially useful in SCR control of 60 Hz power and in developing time-of-day and other timing routines. As a ROM mask option there is a pullup resistor that is useful for switch contact input or standard TTL.

## 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 VSS +2.5 volts. (For clarity, this is 7 mA to $\mathrm{V}_{\mathrm{SS}}$ 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.

## Expanded I/O

The 8021 H can be used with 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 8. The timing diagram is shown in Figure 9.
The 8021 H can also use standard low-cost TTL to expand the number of $I / O$ lines.


Figure 7. Test 1 Pin


Figure 8. I/O Expander Interface


Figure 9. Expanded I/O Timing Diagram

## CPU

The 8021 H 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 using the DAA, SWAP A, and XCHD instructions. In addition, MOVP A,@A allows table lookup for display formating and constants. The conditional branch logic within the processor enables several conditions internal and external to the processor to be tested by the users program. Use the conditional jump instructions with the tests listed below to effect a change in the program execution sequence:

| Test | Jump Condition | Jump Instructions |
| :---: | :---: | :---: |
| Accumulator | $A=0 A \neq 0$ | JZ JNZ |
| Carry Flag | 01 | , JC |
| Timer Overflow Flag | - 1 | JTF |
| Test Input-T1 | 01 | JNT1, JT1 |

## Reset

A positive-going signal to the RESET input resets the necessary miscellaneous flip-flops and sets the program counter and stack pointer to zero.

## DIFFERENCES BETWEEN THE 8021H AND THE 8748

Although the 8021 H is basically an electrical and functional subset of the 8748 , there are some differences:

1. Pin Out-As the 8021 H is a 28 -pin DIP, some form of adapter must be used to interface the 8021H socket to ICE-49. An emulation board,

EM-1, has been designed to perform this function. The EM-1 also accounts for the increased flexibility of some $8021 \mathrm{H} \mathrm{I/O}$ lines.
2. Instruction Time -The 8021 H 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 H 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 8021H ports are quasi-bidirectional 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 H 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 8021H 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 $\mathrm{V}_{\mathrm{SS}}$ 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. Instruction Set - The following instructions, which are found in the 8748, have been deleted from the 8021 H instruction set:

| Data Moves |  | Registers |  | Branch |  | Timer |  | Control |  | Input/Output |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOV MOV MOVX MOVX 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 <br> addr <br> addr <br> addr <br> addr <br> addr | EN | TCNTI | EN 1 <br> DIS 1 <br> SEL RB0 <br> SEL RB1 <br> SEL MB0 <br> SEL MB1 |  | ANL ORL INS OUTL ANL ORL | P,\#data <br> P,\#data <br> A,BUS* <br> BUS, $A^{*}$ <br> BUS,\#data <br> BUS,\#data |
|  |  | Flags |  |  |  | DIS | TCNTI |  |  |  |  |
|  |  | CLR | F0 |  |  | Subrour | utine |  |  |  |  |
|  |  | CPL | FO |  |  |  | TR |  |  |  |  |
|  |  | CLR CPL | F1 |  |  |  | TR |  |  |  |  |

*These instructions have been replaced in the 8021 H by IN A,PO and OUTL PO,A, respectively.

# SINGLE COMPONENT 8-BIT MICROCOMPUTER WITH ON-CHIP A/D CONVERTER 

\author{

- 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 Inductor or Crystal
- Easily Expanded I/O

The Intel ${ }^{\oplus} 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 2K bytes of program memory (ROM), 64 bytes of data memory (RAM), 28 I/ O lines, an on-chip 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 5V 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


8022

Table 1. Pin Description

| Designation | Pin No. | Function | Designation | Pin No. | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VSS VCC PROG | $\begin{aligned} & 20 \\ & 40 \\ & 37 \end{aligned}$ | Circuit GND potential. <br> +5 V circuit power supply. <br> Output strobe for Intel® 8243 1/O expander. | RESET | 24 | Input used to initiaize the processor by clearing status flipflops and setting the program counter to zero. |
| $\begin{array}{\|l\|} \hline \text { P00-P07 } \\ \text { Port 0 } \end{array}$ | 10-17 | 8-bit open-drain port with comparator inputs. The switching threshold is set externally by VTH. Optional pull-up resistors may be added via ROM mask selection. | AVSS | 7 | A/D converter GND Potential, Also establishes the lower limit of the conversion range. |
|  |  |  | AVCC | 3 | AVD + 5V power supply. |
| VTH |  |  | SUBST | 21 | Substrate pin used with a bypass capacitor to stabilize the substrate voltage and improve A/D accuracy. |
| P10-P17 Port 1 P20-P27 | 25-32 $33-36$ | 8-bit quasi-bidirectional port. 8 -bit quasi-bidirectional port. | VAREF | 4 | A/D converter reference voltage. Establishes the upper limit of the conversion range. |
| Port 2 | $\begin{gathered} 38-39 \\ 1-2 \end{gathered}$ | P20-23 also serve as a 4-bit I/O expander for Intel© 8243. | ANO, AN1 | 6,5 | Analog inputs to $A / D$ converter. Software selectable on-chip via |
| 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. |  |  | 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. |
| 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. | XTAL 1 | 22 | One side of crystal or inductor 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. |



Figure 3.The Stand Alone 8022

## 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
*NOTICE: 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}_{C C}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V}$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | V | VTH Floating |
| VIH1 | Input Low Voltage (Port 0) | -0.5 |  | VTH-0.1 | V |  |
| VIH | High Voltage <br> (All except XTAL 1, RESET) | 2.0 |  | VCC | V | $\begin{aligned} & \text { VCC }=5.0 \mathrm{~V} \pm 10 \% \\ & \text { VTH Floating } \end{aligned}$ |
| VIH1 | Input High Voltage <br> (All except XTAL 1, RESET) | 3.0 |  | Vcc | V | $\begin{aligned} & \text { VCC }=5.5 \mathrm{~V} \pm 1 \mathrm{~V} \\ & \text { VTH Floating } \end{aligned}$ |
| VIH2 | Input High Voltage (Port 0) | VTH+0.1 |  | Vcc | V |  |
| - VIH3 | Input High Voltage (RESET, XTAL 1) | 3.0 |  | VCC | V | $\mathrm{VCC}=5.0 \mathrm{~V} \pm 10 \%$ |
| VTH | Port 0 Threshold Reference Voltage | 0 |  | . 4 VCC | V |  |
| VOL | Output Low Voltage |  |  | 0.45 | V | $1 \mathrm{OL}=1.6 \mathrm{~mA}$ |
| VOL1 | Output Low Voltage (P10, P11) |  |  | 2.5 | V | $1 \mathrm{OL}=7 \mathrm{~mA}$ |
| VOH | Output High Voltage (all unless Open Drain Option - Port 0) | 2.4 |  |  | V | $\mathrm{IOH}=50 \mu \mathrm{~A}$ |
| ILI | Input Current (T1) |  |  | $\pm 200$ | $\mu \mathrm{A}$ | VCC $\geqslant \mathrm{VIN} \geqslant \mathrm{VSS}+.45 \mathrm{~V}$ |
| ILO | Output Leakage Current (Open Drain Option-Port 0) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{VCC} \geqslant \mathrm{VIN} \geqslant \mathrm{VSS}+0.45 \mathrm{~V}$ |
| ICC | VCC Supply Current |  | 50 | 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 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| tCY | Cycle Time | 8.38 | 50.0 | $\mu \mathrm{~S}$ | 3 MHz XTAL $=10 \mu \mathrm{~s}$ tCY |
| VZX | Zero-Cross Detection Input (T1) | 1 | 3 | VACpp | AC Coupled |
| AZX | Zero-Cross Accuracy |  | $\pm 135$ | mV | 60 Hz Sine Wave |
| FZX | Zero-Cross Detection Input <br> Frequency (T1) | 0.05 | 1 | kHz |  |

## A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}, \mathrm{~V}_{S S}=0 \mathrm{~V}$

Test Conditions: $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF} \quad \mathrm{t}_{\mathrm{C}}=8.38 \mu \mathrm{~s}$


## Port 2 Timing



A/D CONVERTER 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}, \mathrm{AV} \mathrm{CC}=5.5 \mathrm{~V} \pm 1 \mathrm{~V}$, $A_{S S}=0 V, A V_{C C} / 2 \leqslant V_{\text {AREF }} \leqslant A V_{C C}$

| Parameter | Min | Typ | Max | Unit | Comments |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Resolution | 8 |  |  | Bits |  |
| Absolute Accuracy |  |  | $.8 \%$ FSR $\pm 1 / 2$ LSB | LSB | (Note 1) |
| Sample Setup Before Falling Edge of ALE ( $\mathrm{tSS}_{\mathrm{SS}}$ ) |  | 0.20 |  | $\mathrm{t}_{\mathrm{CY}}$ |  |
| Sample Hold After Falling Edge of ALE ( $\mathrm{tSH}^{\prime}$ ) |  | 0.10 |  | $\mathrm{t}_{\mathrm{CY}}$ |  |
| Input Capacitance (AN0, AN1) |  | 1 |  | pF |  |
| Conversion Time | 4 |  |  | $\mathrm{t}_{\mathrm{CY}}$ |  |

Analog Input Timing


NOTE:

1. The analog input must be maintained at a constant voltage during the sample time $\left(t_{S S}+t_{S H}\right)$.

Table 2. Instruction Set Summary

|  | Mnemonic | Description | Bytes | Cycle | Hexadecimal Opcode |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | ADD A, $\mathrm{R}_{\mathrm{r}}$ | Add register to A | 1 | 1 | 68-6F |
|  | ADD A,@R | Add data memory to A | 1 | 1 | 60-61 |
|  | ADD A, \#data | Add immediate to A | 2 | 2 | 03 |
|  | ADDC A, $\mathrm{R}_{\mathbf{r}}$ | Add register with carry | 1 | 1 | 78-7F |
|  | ADDC A,@ R | Add data memory with carry | 1 | 1 | 70.71 |
|  | ADDC A,\#data | Add immediate with carry | 2 | 2 | 13 |
|  | ANL A, $\mathrm{R}_{\mathrm{r}}$ | And register to A | 1 | 1 | 58-5F |
|  | ANL A,@R | And data memory to A | 1 | 1 | 50-51 |
|  | ANL A, \# data | And immediate to A | 2 | 2 | 53 |
|  | ORL A, $\mathrm{R}_{\mathrm{r}}$ | Or register to A | 1 | 1 | 48-4F |
|  | ORL A,@R | Or data memory to $A$ | 1 | 1 | 40-41 |
|  | ORL A, \#data | Or immediate to $A$ | 2 | 2 | 43 |
|  | XRL $A, R_{r}$ | Exclusive Or register to $A$ | 1 | 1 | D8-DF |
|  | XRL A,@ R | Exclusive Or data memory to A | 1 | 1 | D0-D1 |
|  | XRL A, \# data | Exclusive Or immediate to $A$ | 2 | 2 | D3 |
|  | INC A | Increment A | 1 | 1 | 17 |
|  | DEC A | Decrement A | 1 | 1 | 07 |
|  | CLR A | Clear A | 1 | 1 | 27 |
|  | CPL A | Complement A | 1 | 1 | 37 |
|  | DA A | Decimal adjust A | 1 | 1 | 57 |
|  | SWAP A | Swap nibbles of $A$ | 1 | 1 | 47 |
|  | RL A | Rotate A left | 1 | 1 | E7 |
|  | RLC A | Rotate A left through carry | 1 | 1 | F7 |
|  | RR A | Rotate A right | 1 | 1 | 77 |
|  | RRC A | Rotate A right through carry | 1 | 1 | 67 |
|  | IN A, $\mathrm{P}_{\mathrm{p}}$ | Input port to A | 1 | 2 | 08,09,0A |
|  | OUTL $P_{p}, A$ | Output A to port | 1 | 2 | 90,39,3A |
|  | $\text { MOVD A, } P_{p}$ | Input expander port to $A$ | 1 | 2 | $\mathrm{OC}-\mathrm{OF}$ |
|  | MOVD $P_{p}, A$ | Output A to expander port | 1 | 2 | 3C-3F |
|  | ANLD $P_{p}, A$ | And $A$ to expander port | 1 | 2 | 9C-9F |
|  | ORLD $P_{p}, A$ | Or A to expander port | 1 | 2 | 8C-8F |
|  | INC $\mathrm{R}_{\mathrm{r}}$ | Increment register | 1 | 1 | 18.1F |
|  | INC @ R | Increment data memory | 1 | 1 | 10.11 |
| $\begin{aligned} & \text { ᄃ ㅡㅡㅌ } \\ & \text { ᄐim } \end{aligned}$ | JMP addr | Jump unconditional | 2 | 2 | $\begin{aligned} & \text { 04,24,44,64, } \\ & \text { 84,A4,C4,E4 } \end{aligned}$ |
|  | JMPP @ A | Jump indirect | 1 | 2 | B3 |
|  | DJNZ R,addr | Decrement register and jump on R not zero | 2 | 2 | E8-EF |
|  | JC addr | Jump on carry=1 | 2 | 2 | F6 |
|  | JNC addr | Jump on carry=0 | 2 | 2 | E6 |
|  | JZ addr | Jump on A zero | 2 | 2 | C6 |
|  | JNZ addr | Jump on A not zero | 2 | 2 | 96 |


|  | Mnemonic | Description | Bytes | Cycle | Hexadecimal Opcode |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | JTO addr | Jump on TO=1 | 2 | 2 | 36 |
|  | JNTO addr | Jump on TO=0 | 2 | 2 | 26 |
|  | 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 |
|  | CALL addr | Jump to subroutine | 1 | 2 | $\begin{aligned} & 14,34,54,74 \\ & 94, B 4, D 4, F 4 \end{aligned}$ |
|  | RET | Return | 1 | 2 | 83 |
| 告 | CLR C | Clear carry | 1 | 1 | 97 |
|  | CPL C | Complement carry | 1 | 1 | A7 |
|  | 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 $\mathrm{R}_{\mathrm{r}}, \mathrm{A}$ | Move $A$ to register | 1 | 1 | A8-AF |
|  | MOV @ R,A | Move A to data memory | 1 | 1 | AO-A 1 |
|  | 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 |
|  | XCH 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 |
| 末 <br> 0 <br> 0 <br> 0 <br> 0 <br> 0 <br> 0 <br> i | RAD | Move conversion resuli register to A | 1 | 2 | 80 |
|  | SEL ANO | Select analog input zero | 1 | 1 | 85 |
|  | SEL AN 1 | Select analog input one | 1 | 1 | 95 |
|  | EN I | Enable external interrupt | 1 | 1 | 05 |
|  | DIS I | Disable external interrupt | 1 | 1 | 15 |
|  | EN TCNTI | Enable timer/counter interrupt | 1 | 1 | 25 |
|  | DIS TCNTI | Disable timer/counter interrupt | 1 | 1 | 35 |
|  | RET I | Return from interrupt | 1 | 2 | 93 |
|  | NOP | No operation | 1 | 1 | 00 |

SYMBOLS AND ABBREVIATIONS USED

|  |  |
| :--- | :--- |
| A | Accumulator |
| addr | 11-Bit Program Memory Address |
| ANO, AN1 | Analog Input 0, Analog Input 1 |
| CNT | Event Counter |
| data | 8-Bit Number or Expression |
| I | Interrupt |

$P$
$P_{p}$
$R_{r}$
$T$
TO, T1
$\#$
@

Mnemonic for "in-page" Operation
Port Designator ( $\mathrm{P}=0,1,2$ or 4-7)
Register Designator ( $r=0-7$ )
Timer
Test 0, Test 1
Immediate Data Prefix
Indirect Address Prefix

# 8022H <br> HIGH PERFORMANCE <br> SINGLE COMPONENT 8-BIT MICROCOMPUTER WITH ON-CHIP A/D 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)
■ Two Interrupts-External and Timer

2K x 8 ROM, $64 \times 8$ RAM, 28 I/O Lines
$5 \mu \mathrm{sec}$ Cycle; All Instructions 1 or 2
Cycles ( 6 MHz Clock)
■ Instructions-8048 Subset

- Interval Time/Event Counter
- Clock Generated with Single Inductor or Crystal
- Easily Expanded I/O

The Intel* 8022 H 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 H addresses these applications by integrating many new functions on-chip, such as A/D conversion, comparator inputs and zero-cross detection.

The features of the 8022 H include 2 K bytes of program memory (ROM), 64 bytes of data memory (RAM), 28 I/O lines, an on-chip 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 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 H 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 8022H's hardware implementation of the $A / D$ converter which simplifies interfacing to analog signals.


Figure 1.
Block Diagram


Figure 2. Logic Symbol
P26
P27

Figure 3. Pin Configuration

[^17]
# 8031/8051/8751 SINGLE-COMPONENT 8-BIT MICROCOMPUTER 

\author{

- 8031 - Control Oriented CPU With RAM and I/O <br> - 8051 - An 8031 With Factory Mask-Programmable ROM <br> ■ 8751 - An 8031 With User Programmable/Erasable EPROM
}


## - 4K x 8 ROM/EPROM <br> - $128 \times 8$ RAM <br> - Four 8-Bit Ports, $321 / 0$ Lines <br> - Two 16-Bit Timer/Event Counters <br> - High-Performance Full-Duplex <br> Serial Channel <br> - External Memory Expandable to 128 K <br> - Compatible with MCS-80®/MCS-85 ${ }^{\circledR}$ Peripherals

- Boolean Processor
- MCS-48 ${ }^{\circledR}$ Architecture Enhanced with:
- Non-Paged Jumps
- Direct Addressing
- Four 8-Register Banks
- Stack Depth Up to 128-Bytes
- Multiply, Divide, Subtract, Compare
- Most Instructions Execute in $1 \mu \mathrm{~s}$
- $4 \mu \mathrm{~s}$ Multiply and Divide

The Intel ${ }^{\circledR} 8031 / 8051 / 8751$ is a stand-alone, high-performance single-chip computer fabricated with Intel's highly-reliable +5 Volt, depletion-load, N-Channel, silicon-gate HMOS technology and packaged in a 40-pin DIP. It provides the hardware features, architectural enhancements and new instructions that are necessary to make it a powerful and cost effective controller for applications requiring up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.
The 8051/8751 contains a non-volatile $4 \mathrm{~K} \times 8$ read-only program memory; a volatile $128 \times 8$ read/write data memory; 32 I/O lines; two 16-bit timer/counters; a five-source, two-priority-level, nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and clock circuits. The 8031 is identical, except that it lacks the program memory. For systems that require extra capability, the 8051 can be expanded using standard TTL compatible memories and the byte oriented MCS-80 and MCS-85 peripherals.
The 8051 microcomputer, like its 8048 predecessor, is efficient both as a controller and as an arithmetic processor. The 8051 has extensive facilities for binary and BCD arithmetic and excels in bit-handling capabilities. Efficient use of program memory results from an instruction set consisting of $44 \%$ one-byte, $41 \%$ two-byte, and $15 \%$ three-byte instructions. With a 12 MHz crystal, $58 \%$ of the instructions execute in $1 \mu \mathrm{~s}, 40 \%$ in $2 \mu \mathrm{~s}$ and multiply and divide require only $4 \mu \mathrm{~s}$. Among the many instructions added to the standard 8048 instruction set are multiply, divide, subtract and compare.


Figure 1.
Block Diagram


Figure 2. Logic Symbol


Figure 3. Pin Configuration

## INTRODUCTION

This data sheet provides an introduction to the 8051 family. A detailed description of the hardware required to expand the 8051 with more program memory, data memory, I/O, specialized peripherals and into multiprocessor configurations is described in the 8051 Family User's Manual.

## The 8051 Family

The 8051 is a stand-alofie high-performance singlechip computer intendéd for use in sophisticated real-time applications such as instrumentation, industrial control and intelligent computer peripherals. It provides the hatdware features, architectural enhancements and nefv instructions that make it a powerful and cost effective controller for applications requiring up to 64 K -bytes of program memory and/or up to 64 K -bytes of data storage. A Block Diagram is shown in Figure 1.
The 8031 is a control-oriented CPU without on-chip program memory. It can address 64 K -bytes of external Program Memory in addition to 64 K -bytes of External Data Memory. For systems requiring extra capability, each member of the 8051 family can be expanded using standard memories and the byte oriented MCS-80 and MCS-85 peripherals. The 8051 is an 8031 with the lower 4K-bytes of Program Memory filled with on-chip mask programmable ROM while the 8751 has 4 K -bytes of UV-light-erasable/electrically-programmable ROM.
The three pin-compatible versions of this component reduce development problems to a minimum and provide maximum flexibility. The 8751 is well suited for development, prototyping, low-volume production and applications requiring field updates; the 8051 for low-cost, high volume production; and the 8031 for applications desiring the flexibility of external Program Memory which can be easily
modified and updated in the field.

## MACRO-VIEW OF THE 8051 <br> ARCHITECTURE

On a single die the 8051 microcomputer combines CPU; non-volatile 4K $\times 8$ read-only program memory; volatile $128 \times 8$ read/write data memory; 32 I/O lines; two 16-bit timer/event counters; a five-source, two-priority-level, nested interrupt structure; serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and clock circuits. This section will provide an overview of the 8051 by providing a high-level description of its major elements: the CPU architecture and the on-chip functions peripheral to the CPU. The generic term "8051" is used to refer collectively to the 8031, 8051, and 8751.

## 8051 CPU Architecture

The 8051 CPU manipulates operands in four memory spaces. These are the 64K-byte Program Memory, 64K-byte External Data Memory, 384-byte Internal Data Memory and 16-bit Program Counter spaces. The Internal Data Memory address space is further divided into the 256-byte Internal Data RAM and 128-byte Special Function Register (SFR) address spaces shown in Figure 4. Four Register Banks (each with eight registers), 128 addressable bits, and the stack reside in the Internal Data RAM. The stack depth is limited only by the available Internal Data RAM and its location is determined by the 8-bit stack pointer. All registers except the Program Counter and the four 8-Register Banks reside in the Special Function Register address space. These memory mapped registers include arithmetic registers, pointers, I/O ports, interrupt system registers, timers and serial port. 128 bit locations in the SFR address space are addressable as bits. The 8051 contains 128 bytes of Internal Data RAM and 20 SFRs.


Figure 4. 8051 Family Memory Organization

The 8051 provides a non-paged Program Memory address space to accommodate relocatable code. Conditional branches are performed relative to the Program Counter. The register-indirect jump permits branching relative to a 16 -bit base register with an offset provided by an 8 -bit index register. Sixteen-bit jumps and calls permit branching to any location in the contiguous 64K Program Memory address space.
The 8051 has five methods for addressing source operands: Register, Direct, Register-Indirect, Immediate and Base-Register- plus Index-RegisterIndirect Addressing. The first three methods can be used for addressing destination operands. Most instructions have a "destination, source" field that specifies the data type, addressing methods and operands involved. For operations other than moves, the destination operand is also a source operand.
Registers in the four 8 -Register Banks can be accessed through Register, Direct, or RegisterIndirect Addressing; the 128 bytes of Internal Data RAM through Direct or Register-Indirect Addressing; and the Special Function Registers through Direct Addressing. External Data Memory is accessed through Register-Indirect Addressing. Look-UpTables resident in Program Memory can be accessed through Base-Register-plus Index-Register-Indirect Addressing.
The 8051 is classified as an 8 -bit machine since the internal ROM, RAM, Special Function Registers, Arithmetic/Logic Unit and external data bus are each 8 -bits wide. The 8051 performs operations on bit, nibble, byte and double-byte data types.
The 8051 has extensive facilities for byte transfer, logic, and integer arithmetic operations. It excels at bit handling since data transfer, logic and conditional branch operations can be performed directly on Boolean variables.
The 8051's instruction set is an enhancement of the instruction set familiar to MCS-48 users. It is enhanced to allow expansion of on-chip CPU peripherals and to optimize byte efficiency and execution speed. Op codes were reassigned to add new high-power operations and to permit new addressing modes which make the old operations more orthogonal. Efficient use of program memory results from an instruction set consisting of 49 single-byte, 45 two-byte and 17 three-byte instructions. When using a 12 MHz oscillator, 64 instructions execute in $1 \mu \mathrm{~s}$ and 45 instructions execute in $2 \mu \mathrm{~s}$. The remaining instructions (multiply and divide) execute in only $4 \mu \mathrm{~s}$. The number of bytes in each instruction and the number of oscillator periods required for execution are listed in the appended 8051 Instruction Set Summary.

## On-Chip Peripheral Functions

Thus far only the CPU and memory spaces of the 8051 have been described. In addition to the CPU and memories, an interrupt system, extensive I/O facilities, and several peripheral functions are integrated on-chip to relieve the CPU of repetitious, complicated or time-critical tasks and to permit stringent real-time control of external system interfaces. The extensive I/O facilities include the I/O pins, parallel I/O ports, bicírectional address/data bus and the serial port for I/O expansion. The CPU peripheral functions integrated on-chip are the two 16 -bit counters and the serial port. All of these work together to greatly boost system performance.

## INTERRUPT SYSTEM

External events and the real-time-driven on-chip peripherals require service by the CPU asynchronous to the execution of any particular section of code. To tie the asynchronous activities of these functions to normal program execution, a sophisticated mul-tiple-source, two-priority-level, nested interrupt system is provided. Interrupt response latency ranges from $3 \mu$ s to $7 \mu$ s when using a 12 MHz crystal.
The 8051. acknowledges interrupt requests from five sources: Two from external sources via the $\overline{\text { INTO }}$ and INT1 pins, one from each of the two internal counters and one from the serial I/O port. Each interrupt vectors to a separate location in Program Memory for its service program. Each of the five sources can be assigned to either of two priority levels and can be independently enabled and disabled. Additionally all enabled sources can be globally disabled or enabled. Each external interrupt is programmable as either level- or transition-activated and is active-low to allow the "wire or-ing" of several interrupt sources to the input pin. The interrupt system is shown diagrammatically in Figure 5.

## I/O FACILITIES

The 8051 has instructions that treat its 32 I/O lines as 32 individually addressable bits and as four parallel 8 -bit ports addressable as Ports $0,1,2$ and 3. Ports 0,2 and 3 can also assume other functions. Port 0 provides the multiplexed low-order address and data bus used for expanding the 8051 with standard memories and peripherals. Port 2 provides the high-order address bus when expanding the 8051 with external Program Memory or more than 256 bytes of External Data Memory. The pins of Port 3 can be configured individually to provide external interrupt request inputs, counter inputs, the serial port's receiver input and transmitter output, and to generate the control signals used for reading and writing External Data Memory. The generation or use of an alternate function on a Port 3 pin is done automatically by the 8051 as long as the pin


Figure 5. 8051 Interrupt System
is configured as an input. The configuration of the ports is shown on the 8051 Family Logic Symbol of Figure 2.

## Open Drain I/O Pins

Each pin of Port 0 can be configured as an open drain output or as a high impedance input. Resetting the microcomputer programs each pin as an input by writing a one (1) to the pin. If a zero (0) is later written to the pin it becomes configured as an output and will continuously sink current. Re-writing the pin to a one (1) will place its output driver in a highimpedance state and configure the pin as an input. Each I/O pin of Port 0 can sink two TTL loads.

## Quasi-Bidirectional I/O Pins

Ports 1, 2 and 3 are quasi-bidirectional buffers. Resetting the microcomputer programs each pin as an input by writing a one (1) to the pin. If a zero (0) is later written to the pin it becomes configured as an output and will continuously sink current. Any pin that is configured as an output will be reconfigured as an input when a one (1) is written to the pin. Simultaneous to this reconfiguration the output driver of the quasi-bidirectional port will source current for two oscillator periods. Since current is sourced only when a bit previously written to a zero $(0)$ is updated to a one (1), a pin programmed as an input will not source current into the TTL gate that is driving it if the pin is later written with another one (1). Since the quasi-bidirectional output driver sources current for only two oscillator periods, an internal
pullup resistor of approximately 20 K - to 40 K -ohms is provided to hold the external driver's loading at a TTL high level. Ports 1, 2 and 3 can sink/source one TTL load.

## Microprocessor Bus

A microprocessor bus is provided to permit the 8051 to solve a wide range of problems and to allow the upward growth of user products. This multiplexed address and data bus provides an interface compatible with standard memories, MCS-80 peripherals and the MCS-85 memories that include on-chip programmable I/O ports and timing functions. These are summarized in the 8051 Microcomputer Expansion Components chart of Figure 6.
When accessing external memory the high-order address is emitted on Port 2 and the low-order address on Port 0 . The ALE signal is provided for strobing the address into an external latch. The program store enable (PSEN) signal is provided for enabling an external memory device to Port 0 during a read from the Program Memory address space. When the MOVX instruction is executed Port 3 automatically generates the read ( $\overline{\mathrm{RD}}$ ) signal for enabling an External Data Memory device to Port 0 or generates the write (WR) signal for strobing the external memory device with the data emitted by Port 0 . Port 0 emits the address and data to the external memory through a push/pull driver that can sink/source two TTL loads. At the end of the read/write bus cycle Port 0 is automatically reprogrammed to its high

|  | Category | I.D. | Description | Comments | Program Or Data Memory | Crystal Frequency MHz (Max) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1/O Expander |  | 8 Line I/O Expander (Shift Register) | Low Cost I/O Expander |  | 12 |
|  | Standard EPROMs | $\begin{aligned} & 2758 \\ & 2716-1 \\ & 2732 \\ & 2732 A \end{aligned}$ | 1K $\times 8450$ ns Light Erasable $2 \mathrm{~K} \times 8350 \mathrm{~ns}$ Light Erasable 4K $\times 8450 \mathrm{~ns}$ Light Erasable 4K x 8250 ns Light Erasable | User programmable and erasable. | P | 9 <br> 11 <br> 9 $12$ |
|  | Standard RAMs | $\begin{aligned} & 2114 \mathrm{~A} \\ & 2148 \\ & 2142-2 \end{aligned}$ | 1K x 4100 ns RAM $1 \mathrm{~K} \times 470$ ns RAM 1K x 4200 ns RAM | Data memory can be easily expanded using standard NMOS RAMs. | $\begin{aligned} & D \\ & D \\ & D \end{aligned}$ | $\begin{aligned} & 12 \\ & 12 \\ & 12 \end{aligned}$ |
|  | Multiplexed Address/ Data RAMs | 8185A | $1 \mathrm{~K} \times 8300 \mathrm{~ns} \mathrm{RAM}$ |  | D | 12 |
|  | Standard I/O | 8212 <br> 8282 <br> 8283 <br> 8255A <br> 8251A | 8-Bit I/O Port <br> 8-Bit I/O Port <br> 8-Bit I/O Port <br> Programmable Peripheral Interface Programmable Communications Interface | Serves as Address Latch or I/O port. <br> Three 8-bit programmable I/O ports. Serial Communications Receiver/Transmitter. | $\begin{aligned} & \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \end{aligned}$ | $\begin{aligned} & 12 \\ & 12 \\ & 12 \\ & 12 \\ & 12 \end{aligned}$ |
|  | Standard Peripherals | $\begin{aligned} & 8205 \\ & 8286 \\ & 8287 \\ & 8253 A \\ & 8279 \\ & \\ & 8291 \\ & 8292 \end{aligned}$ | 1 of 8 Binary Decoder <br> Bi-directional Bus Driver <br> Bi-directional Bus Driver (Inverting) <br> Programmable Interval Timer <br> Programmable Keyboard/Display Interface (128 Keys) GPIB Talker/Listener GPIB Controller | MCS-80 and MCS-85 peripheral devices are compatible with the 8051 allowing easy addition of specialized interfaces. Future MCS-80/85 devices will also be compatible. | $\begin{aligned} & \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \\ & \mathrm{D} \\ & \\ & \mathrm{D} \\ & \mathrm{D} \end{aligned}$ | 12 12 12 <br> 12 <br> 12 $\begin{gathered} 12 \\ 11.7 \end{gathered}$ |
|  | Universal Peripheral Interfaces | $\begin{aligned} & 8041 A \\ & 8741 A \end{aligned}$ | ROM Program Memory EPROM Program Memory | User programmable to perform custom I/O and control functions. | $\begin{aligned} & \mathrm{D} / \mathrm{P} \\ & \mathrm{D} / \mathrm{P} \end{aligned}$ | $\begin{aligned} & 12 / 11.7 \\ & 12 / 11.7 \end{aligned}$ |
|  | Memories with on-chip I/O and Peripheral Functions | $\begin{aligned} & 8155-2 \\ & 8355-2 \\ & 8755-2 \end{aligned}$ | $256 \times 8330$ ns RAM <br> $2 \mathrm{~K} \times 8330 \mathrm{~ns}$ ROM <br> 2K $\times 8330 \mathrm{~ns}$ EPROM |  | $\begin{aligned} & D \\ & P \\ & P \end{aligned}$ | $\begin{gathered} 12 \\ 11.6 \\ 11.6 \end{gathered}$ |

Figure 6. $\mathbf{8 0 5 1}$ Microcomputer Expansion Components
impedance state and Port 2 is returned to the state it had prior to the bus cycle. The 8051 generates the address, data and control signals needed by memory and I/O devices in a manner that minimizes the requirements placed on external program and data memories. At 12 MHz , the Program Memory cycle time is 500 ns and the access times required from stable address and $\overline{\text { PSEN }}$ are approximately 320 ns and 150 ns respectively. The External Data Memory cycle time is $1 \mu \mathrm{~s}$ and the access times required from stable address and from read ( $\overline{\mathrm{RD}}$ ) or write ( $\overline{\mathrm{WR}}$ ) command are approximately 600 ns and 250 ns respectively.

## TIMER/EVENT COUNTERS

The 8051 contains two 16-bit counters for measuring time intervals, measuring pulse widths, counting events and generating precise, periodic interrupt requests. Each can be programmed independently to operate similar to an 80488 -bittimer with divide by 32 prescaler or as an 8 -bit counter with divide by 32 prescaler (Mode 0 ), as a 16 -bit time-interval or event counter (Mode 1), or as an 8-bit time-interval or event counter with automatic reload upon overflow (Mode 2).
Additionally, counter 0 can be programmed to a mode that divides it into one 8 -bit time-interval or
event counter and one 8 -bit time-interval counter (Mode 3). When counter 0 is in Mode 3, counter 1 can be programmed to any of the three aforementioned modes, although it cannot set an interrupt request flag or generate an interrupt. This mode is useful because counter 1's overflow can be used to pulse the serial port's transmission-rate generator. Along with their multiple operating modes and 16 -bit precision, the counters can also handle very high input frequencies. These range from 0.1 MHz to 1.0 MHz (for 1.2 MHz to 12 MHz crystal) when programmed for an input that is a division by 12 of the oscillator frequency and from 0 Hz to an upper limit of 50 KHz to 0.5 MHz (for 1.2 MHz to 12 MHz crystal) when programmed for external inputs. Both internal and external inputs can be gated to the counter by a second external source for directly measuring pulse widths.
The counters are started and stopped under software control. Each counter sets its interrupt request flag when it overflows from all ones to all zeros (or autoreload value). The operating modes and input sources are summarized in Figures 7 and 8. The effects of the configuration flags and the status flags are shown in Figures 9 and 10.

## SERIAL COMMUNICATIONS

The 8051 has a serial I/O port that is useful for serially linking peripheral devices as well as multiple 8051s through standard asynchronous protocols with full-duplex operation. The serial port also has a synchronous mode for expansion of I/O lines using CMOS and TTL shift registers. This hardware serial communications interface saves ROM code and permits a much higher transmission rate than could be achieved through software. In response to a serial port interrupt request the CPU has only to read/write the serial port's buffer to service the serial link. A block diagram of the serial port is shown in Figures 11 and 12. Methods for linking UART (universal asynchronous receiver/transmitter) devices are


Figure 7. Timer/Event Counter Modes 0, 1 and 2


Figure 8. Timer/Event Counter 0 in Mode 3


Figure 9. Timer/Counter 0 Control and Status Flag Circuitry


Figure 10. Timer/Counter 1 Control and Status Flag Circuitry


Figure 11. Serial Port-Synchronous Mode 0


Figure 12. Serial Port—UART Modes 1, 2, and 3


Figure 13. UART Interfacing Schemes
shown in Figure 13 and a method for I/O expansion is shown in Figure 14.
The full-duplex serial I/O port provides asynchronous modes to facilitate communications with standard UART devices, such as printers and CRT terminals, or communications with other 8051s in multi-processor systems. The receiver is double buffered to eliminate the overrun that would occur if the CPU failed to respond to the receiver's interrupt before the beginning of the next frame. Double buffering of the transmitter is not needed since the 8051 can generally maintain the serial link at its maximum rate without it. A minor degradation in transmission rate can occur in rare events such as when the servicing of the transmitter has to wait for a lengthy interrupt service program to complete. In asynchronous modes, false start-bit rejection is provided on received frames. For noise rejection a best two-out-ofthree vote is taken on three samples near the center of each received bit.
When interfacing with standard UART devices the serial channel can be programmed to a mode (Mode 1) that transmits/receives a ten-bit frame or programmed to a mode (Mode 2 or 3 ) that transmits/ receives an eleven-bit frame as shown in Figure 15. The frame consists of a start bit, eight or nine data bits and a stop bit. In Modes 1 and 3 , the transmissionrate timing circuitry receives a pulse from counter 1 each time the counter overflows. The input to counter 1 can be an external source or a division by 12 of the oscillator frequency. The auto-reload mode of the counter provides communication rates of 122 to 31,250 bits per second (including start and stop bits) for a 12 MHz crystal. In Mode 2 the communication rate is a division by 64 of the oscillator frequency yielding a transmission rate of 187,500 bits per second (including start and stop bits) for a 12 MHz crystal.
Distributed processing offers a faster, more powerful system than can be provided by a single CPU processor. This results from a hierarchy of interconnected processors, each with its own memories and


Figure 14. I/O Expansion Technique


Figure 15. Typical Frame Formats

1. Slaves-Configure serial port to interrupt CPU if the received ninth data bit is a one (1).
2. Master-Transmit frame containing address in first 8 data bits and set ninth data bit (i.e. ninth data bit designates address frame).
3. Slaves-Serial port interrupts CPU when address frame is received. Interrupt service program compares received address to its address. The slave which has been addressed reconfigures its serial port to interrupt the CPU on all subsequent transmissions.
4. Master-Transmit control frames and data frames (these will be accepted only by the previously addressed slave).

Figure 16. Protocol for Multi-Processor Communications

I/O. In multiprocessing, a host 8051 microcomputer controls a multiplicity of 8051 s configured to operate simultaneously on separate portions of the program, each controlling a portion of the overall process. The interconnected 8051s reduce the load on the host processor and result in a low-cost system of data transmission. This form of distributed processing is especially effective in systems where controls in a complex process are required at physically separated locations.
In Modes 2 and 3 the automatic wake-up of slave processors through interrupt driven address-frame recognition is provided to facilitate interprocessor communications. The protocol for interprocessor communications is shown in Figure 16. In synchronous mode (Mode 0 ) the high speed serial port provides an efficient, low-cost method of expanding I/O lines using standard TTL and CMOS shift registers. The serial channel provides a clock output for synchronizing the shifting of bits to/from an external register. The data rate is a division by 12 of the oscillator frequency and is 1 M bits per second at 12 MHz .

## 8051 Family Pin Description

$V_{S S}$
Circuit ground potential.
$V_{C C}$
+5 V power supply during operation, programming and verification.

## PORT 0

Port 0 is an 8 -bit open drain bidirectional I/O port.

It is also the multiplexed low-order address and data bus when using external memory. It is used for data input and output during programming and verification. Port 0 can sink/source two TTL loads.

## PORT 1

Port 1 is an 8-bit quasi-bidirectional I/O port. It is used for the low-order address byte during programming and verification. Port 1 can sink/source one TTL load.

## PORT 2

Port 2 is an 8-bit quasi-bidirectional I/O port. It also emits the high-order address byte when accessing external memory. It is used for the high-order address and the control signals during programming and verification. Port 2 can sink/source one TTL load.

## PORT 3

Port 3 is an 8-bit quasi-bidirectional I/O port. It also contains the interrupt, timer, serial port and $\overline{R D}$ and $\overline{W R}$ pins that are used by various options. The output latch corresponding to a secondary function must be programmed to a one (1) for that function to operate. Port 3 can sink/source one TTL load. The secondary functions are assigned to the pins of Port 3, as follows:
—RXD/data (P3.0). Serial port's receiver data input (asynchronous) or data input/output (synchronous).
— TXD/clock (P3.1). Serial port's transmitter data output (asynchronous) or clock output (synchronous).

- INT0 (P3.2). Interrupt 0 input or gate control input for counter 0.
- INT1 (P3,3). Interrupt 1 input or gate control input for counter 1.
- T0 (P3.4). Input to counter 0.
- T1 (P3.5). Input to counter 1.
$-\overline{W R}$ (P3:6). The write control signal latches the data byte from Port 0 into the External Data Memory.
- $\overline{R D}$ (P3.7). The read control signal enables External Data Memory to Port 0.


## RST/VPD

A low to high transition on this pin (at approximately $3 V$ ) resets the 8051. If VPD is held within its spec (approximately +5 V ), while $\mathrm{V}_{\mathrm{CC}}$ drops below spec, VPD will provide standby power to the RAM. When VPD is low, the RAM's current is drawn from VCC. A small internal resistor permits power-on reset using only a capacitor connected to VCC.

## ALE/PROG

Provides Address Latch Enable output used for latching the address into external memory during normal operation. Receives the program pulse
input during EPROM programming.

## PSEN

The Program Store Enable output is a control signal that enables the external Program Memory to the bus during normal fetch operations.

## EA/VDD

When held at a TTL high level, the 8051 executes instructions from the internal ROM/EPROM when the PC is less than 4096. When held at a TTL low level, the 8051 fetches all instuctions from external Program Memory. The pin also receives the 21V EPROM programming supply voltage.

## XTAL1

Input to the oscillator's high gain amplifier. A crystal or external source can be used.

## XTAL2

Output from the oscillator's amplifier. Required when a crystal is used

## 8051 FAMILY DEVELOPMENT SYSTEM AND SOFTWARE SUPPORT

The 8051 is supported by a total range of Intel development tools. This broad range of support shortens the product development cycle and thus brings the product to market sooner.

- ASM51 Absolute macro assembler for the 8051.
- CONV51 8048 assembly language source code to 8051 assembly source code conversion program.
- EM-51 8051/8751 emulator board that uses a modified 8051 and an EPROM.
- ICE-51 ${ }^{\text {TM }}$ Real-time in-circuit emulator.
- SDK-51 System design kit for developing user Prototype around the 8051.
- UPP-551 8751 personality card for UPP-103 Universal PROM Programmer. 8051 Workshop.


## 8051 Software Development Package (ASM51 and CONV51)

The 8051 software development package provides development system support for the powerful 8051 family of single-chip microcomputers. The package contains a symbolic macro assembler and a 8048 to 8051 source code converter. This diskette-based software package runs under ISIS-II on any Intellec ${ }^{\circledR}$ Microcomputer Development System with 64 K bytes of memory.

## 8051 Macro Assembler (ASM51)

The 8051 macro assembler translates symbolic 8051
assembly language instructions into machine executable object code. These assembly language mnemonics are easier to program and are more readable than binary or hexidecimal machine instructions. Also, by allowing the programmer to give symbolic names to memory locations rather than absolute addresses, software design and debug are performed more quickly and reliably.

ASM51 provides symbolic access for the many useful addressing methods in the 8051 architecture which reference bit, nibble and byte locations.
The assembler supports macro definitions and calls. This provides a convenient means of programming a frequently used code sequence only once. The assembler also provides conditional assembly capabilities. Cross referencing is provided in the symbol table listing, which shows the user the lines in which each symbol was defined and referenced.
If an 8051 program contains errors, the assembler provides a comprehensive set of error diagnostics, which are included in the assembly listing.
The object code generated may be used to program the 8751 EPROM version of the chip or sent to Intel for fabricating the 8051 ROM version. The assembler output can also be debugged using the ICE-51 in-circuit emulator.

## 8048 to 8051 Assembly Language Converter Utility Program (CONV51)

The 8048 to 8051 assembly language converter is a utility to help users of the MCS-48 family of microcomputers upgrade their designs to the high performance 8051 architecture. By converting 8048 source code to 8051 source code, the investment in software developed for the 8048 is maintained when the system is upgraded.

## 8051 Emulation Board (EM-51)

The EM-51 8051 emulation board is a small (2.85" $x$ 5.25") board which emulates an 8031/8051/8751 microcomputer using standard PROMs or EPROMs in place of the 8051's on-chip program memory. The board includes a modified 8051 microcomputer, supporting circuits, and two sockets for program memory. The user may select two 2716 EPROMs, a 2732 EPROM, or two 3636 bipolar PROMs depending on crystal frequency and power requirements.

## 8051 In-Circuit Emulator (ICE-51 ${ }^{\text {M }}$ )

The 8051 In-Circuit Emulator resides in the Intellec development system. The development system interfaces with the user's 8051 system through an in-cable buffer box with the cable terminating in an 8051 pin-compatible plug. Together these replace the 8051 device in the system. With the emulator plug in place, the designer can exercise the system in real-time while collecting up to 255 instruction
cycles of real-time data. In addition, he can single step the system program.
Static RAM memory is available in the ICE- 51 buffer box to emulate the 8051's internal and external program memories and external data memory. The designer can display and alter the contents of the replacement memory in the ICE-51 buffer box, internal 8051 registers, internal data RAM, and Special Function Registers. Symbolic reference capability allows the designer to use meaningful symbols provided by ASM51 rather than absolute values when examining and modifying these memory, register, flag, and I/O locations in his system.

## Personality Card for Universal <br> PROM Programmer (UPP-551)

The UPP-551 is a personality cara ror the UPP-103 Universal PROM Programmer. The Universal PROM

Programmer is an Intellec system peripheral capable of programming and verifying the 8751 when the UPP-551 is inserted. Programming and verfication operations are initiated from the Intellec development system console and are controlled by the Universal PROM Mapper (UPM) program.

## 8051 Workshop

The workshop provides the design engineer or system designer hands-on experience with the 8051 microcomputers. The course includes explanation of the Intel 8051 architecture, system timing and input/output design. Lab sessions will allow the attendee to gain detailed familiarity with the 8051 family and support tools.

## INSITE ${ }^{\text {TM }}$ Library

The INSITE Library contains 8051 utilities and applications programs.

## 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 ( $\mathrm{V}_{\mathrm{SS}}$ ) $\ldots \ldots \ldots \ldots . . .$.
Power Dissipation ...................................... 2 Watts
*NOTICE: 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 \%$; $\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage (All except XTAL1) | -0.5 |  | 0.8 | V |  |
| VIL1 | Input Low Voltage (XTAL1) | -0.5 |  | TBD | V |  |
| $V_{\text {IH }}$ | Input High Voltage <br> (All Except XTAL1, RST/VPD) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}{ }^{+0.5}$ | V |  |
| $\mathrm{V}_{1} \mathrm{H} 1$ | Input High Voltage (XTAL1) | TBD |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | Input High Voltage (RST) | 3.0 |  | $v_{C C}+0.5$ | V |  |
| $\mathrm{V}_{1} \mathrm{H} 3$ | Input High Voltage ( $\mathrm{V}_{\mathrm{PD}}$ ) | 4.5 |  | 5.5 | V | Power Down Only $\left(V_{C C}=0\right)$ |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage <br> (All Outputs Except Port 0) |  |  | 0.45 | V | $!\mathrm{OL}^{\prime}=2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage (Port 0) |  |  | 0.45 | V | ${ }^{\prime} \mathrm{OL}=4 \mathrm{~mA}$ |
| VOH | Output High Voltage (All Outputs Except Port 0, ALE and PSEN) | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}^{\prime}=-100 \mu \mathrm{~A}$ |
| $\mathrm{VOH1}$ | Output High Voltage (ALE and PSEN. Port 0 in External Bus Mode) | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}^{=}=-400 \mu \mathrm{~A}$ |
| Lo | Pullup Resistor Current (P1, P2, P3) |  |  | 500 | $\mu \mathrm{A}$ | . $45 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| 'LO1 | Output Leakage Current (PO) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | . $45 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{VCC}$ |
| ICC | Power Supply Current (All Outputs Disconnected) |  |  | 150 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| IPD | Power Down Supply Current |  |  | 20 | mA | $\begin{aligned} & T_{A}=25^{\circ} \mathrm{C}, \mathrm{~V}_{P D}=5 \mathrm{~V}, \\ & V_{C C}=0 \mathrm{~V} \end{aligned}$ |
| ClO | Capacitance Of I/O Buffer |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$; $\mathrm{C}_{\mathrm{L}}$ for Port 0 , ALE and $\overline{\text { PSEN }}$ Outputs $=150 \mathrm{pF} ; \mathrm{C}_{\mathrm{L}}$ for All Other Outputs $=80 \mathrm{pF}$ )

## Program Memory Characteristics

|  | Parameter | 12 MHz Clock |  |  | Variable Clock 1/TCLCL $=1.2 \mathrm{MHz}$ to 12 MHz |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min | Max | Units | Min | Max | Units |
| TCLCL | Oscillator Period | 83 |  | ns |  |  | ns |
| TCY | Min Instruction Cycle Time | 1.0 |  | $\mu \mathrm{s}$ | 12TCLCL | 12TCLCL | ns |
| TLHLL | ALE Pulse Width | 140 |  | ns | 2TCLCL-30 |  | ns |
| TAVLL | Address Set Up To ALE | 60 |  | ns | TCLCL-25 |  | ns |
| TLLAX | Address Hold After ALE | 50 |  | ns | TCLCL-35 |  | ns |
| TPLPH | PSEN Width | 230 |  | ns | 3TCLCL-20 |  | ns |
| TLHLH | PSEN, ALE Cycle Time | 500 |  | ns | 6 TCLCL |  | ns |
| TPLIV | $\overline{\text { PSEN }}$ To Valid Instruction In |  | 150 | ns |  | 3TCLCL-100 | ns |
| TPHDX | Input Data Hold After $\overline{\text { PSEN }}$ | 0 |  | ns | 0 |  | ns |
| TPHDZ | Input Data Float After $\overline{\text { PSEN }}$ |  | 75 | ns |  | TCLCL-10 | ns |
| TAVIV | Address To Valid Instr In |  | 320 | ns |  | 5TCLCL-100 | ns |
| TAZPL | Address Float To $\overline{\text { PSEN }}$ | 0 |  | ns | 0 |  | ns |

## External Data Memory Characteristics

| Symbol | Parameter | 12 MHz Clock |  |  | Variable Clock |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Units | Min | Max | Units |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | 400 |  | ns | 6TCLCL-100 |  | ns |
| TWLWH | $\overline{\text { WR Pulse Width }}$ | 400 |  | ns | 6TCLCL-100 |  | ns |
| TRLDV | $\overline{\mathrm{RD}}$ To Valid Data In |  | 250 | ns |  | 5TCLCL-170 | ns |
| TRHDX | Data Hold After $\overline{\mathrm{RD}}$ | 0 |  | ns | 0 |  | ns |
| TRHDZ | Data Float After $\overline{\mathrm{RD}}$ |  | 100 | ns |  | 2TCLCL-70 | ns |
| TAVDV | Address To Valid Data In |  | 600 | ns |  | 9TCLCL-150 | ns |
| TAVWL | Address To $\overline{W R}$ or $\overline{R D}$ | 200 |  | ns | 4TCLCL-130 |  | ns |
| TDVWX | Data Valid To $\overline{W R}$ Transition |  |  | ns |  |  | ns |
| TQVWH | Data Setup Before $\overline{W R}$ | 400 |  | ns | 7TCLCL-180 |  | ns |
| TWHQX | Data Held After $\bar{W}$ | 80 |  | ns | 2TCLCL-90 |  | ns |

## NOTE:

There are 2 to 8 ALE cycles per instruction. Clocks and state timing are shown on the timing diagram for reference purposes only. They are not accessible outside the package. TCY is the minimum instruction cycle time which consists of 12 oscillator clocks or two ALE cycles.
Address setup and hold time from ALE are the same for data and program memory.


Data Memory Read Cycle


Data Memory Write Cycle

## Table 1. 8051 Instruction Set Summary

Notes on instruction set and addressing modes:

| Rn data | -Register R7-R0 of the currently selected Register Bank. <br> -8-6it internal data location's address. This could be an Internal Data Ram location (0-127) or a SFR (i.e. I/O port, control register, status register, etc. (128-255). |
| :---: | :---: |
| @Ri | -8-bit Internal Data RAM Iocation (0-255) addressed indirectly through register R1 or RO. |
| \#data | 8 -bit constant included in instruction. |
| \#data | constant in |
| addr16 | -16 -bit destination address. Used by LCALL \& LJMP. A branch can be anywhere within the 64 K -byte Program Memory address space. |
| addr 11 | - 11-bit destination address. Used by ACALL \& AJMP. The branch will be within the same 2 K -byte page of program memory as the first byte of the following instruction. |
| rel | -Signed (two's complement) 8-bit offset byte. Used by SJMP and all conditional jumps. Range is -128 to +127 bytes relative to first byte of the following instruction. |
| bit | -Direct Addressed bit in Internal Data RAM or Special Function Register. |
|  | New operation not provided by 8048/8049. |

Interrupt Response Time: To finish execution of current instruction, respond to the interrupt request, push the PC and to vector to the first instruction of the interrupt service program requires 38 to 81 oscillator periods (3 to $7 \mu \mathrm{~s} @ 12 \mathrm{MHz}$ ).
INSTRUCTIONS THAT AFFECT FLAG SETTINGS'

| INSTRUCTION | FLAG |  |  | INSTRUCTION | FLAG |  |  |
| :--- | :--- | :---: | :---: | :--- | :--- | :--- | :--- |
|  | C | OV | AC |  |  | C | OV |
| ACD |  |  |  |  |  |  |  |

'Note that operations on SFR byte address 208 or bit addresses 209 215 (i.e. the PSW or bits in the PSW) will also affect flag settings.

| Data Transfer |  |  |  | Logic |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Oscillator |  |  |  | Oscillator |
| Mnemonic | Description | Bytes | Periods | Mnemonic | Description | Bytes | Periods |
| MOV A,Rn | Move register to $A$ | 1 | 12 | ANL A,Rn | AND register to $A$ | 1 | 12 |
| *MOV A,data | Move direct byte to $A$ | 2 | 12 | *ANL A, data | AND direct byte to $A$ | 2 | 12 |
| MOV A,@Ri | Move indirect RAM to $A$ | 1 | 12 | ANL A,@Ri | AND indirect RAM to $A$ | 1 | 12 |
| MOV A,\#data | Move immediate data to $A$ | 2 | 12 | ANL A.\#data | AND immediate data to $A$ | 2 | 12 |
| MOV Rn,A | Move A to register | 1 | 12 | *ANL data, A | AND A to direct byte | 2 | 12 |
| *MOV Rn,data | Move direct byte to register | 2 | 24 | *ANL data, \#data | AND immediate data to direct | 3 | 24 |
| MOV Rn,\#data | Move immediate data to register | 2 | 12 | *ANL C,bit | byte |  |  |
| *MOV data, A | Move A to direct byte | 2 | 12 | *ANL C,/bit | AND complement of direct bit | 2 | 24 |
| *MOV data, Rn | Move register to direct byte | 2 | 24 |  | to carry |  |  |
| *MOV data, data | Move direct byte to direct byte | 3 | 24 | ORL A, Rn | OR register to $A$ | 1 | 12 |
|  |  |  |  | *ORL A, data | OR direct byte to $A$ | 2 | 12 |
| *MOV data,@Ri | Move indirect RAM to direct byte | 2 | 24 | ORL A, @Ri | OR indirect RAM to A |  | 12 |
|  |  |  |  | ORL A,\#data | OR immediate data to $A$ | 2 | 12 |
| *MOV data, \#data | Move immediate data to direct byte | 3 | 24 | * ORL data, A | OR A to direct byte | 2 | 12 |
|  |  |  |  | *ORL data, \#data | OR immediate data to direct byte | 3 | 24 |
| MOV @Ri,A | Move A to indirect RAM | 1 | 12 |  |  |  |  |
| *MOV @Ri,data | Move direct byte to indirect | 2 | 24 | * ORL C,bit | OR direct bit to carry | 2 | 24 |
|  | RAM |  |  | *ORL C, /bit | OR complement of direct bit to carry | 2 | 24 |
| MOV @Ri,\#data | Move immediate data to indirect RAM | 2 | 12 |  |  | 1 | 12 |
| *MOV DPTR, \#data16 | Move 16-bit constant to Data Pointer | 3 | 24 | * XRL A,data XRL A,@Ri | Exclusive-OR direct byte to $A$ Exclusive-OR indirect RAM to A | 2 | 12 |
|  |  |  |  |  |  | 1 | 12 |
| *MOV C,bit | Pointer Move direct bit to carry | 2 | 12 |  |  |  |  |
| *MOV bit,C <br> *MOVC A,@A+ DPTR | Move carry to direct bit Move Program Memory byte addressed by A+DPTR to A | 2 | 24 | XRL A,\#data | Exclusive-OR immediate data to A | 2 | 12 |
|  |  | 1 | 24 | * XRL data, A |  |  | 12 |
| - MOVC A,@A+PC | Move Program Memory byte addressed by A+PC to A | 1 | 24 | * XRL data, \#data | Exclusive-OR immediate data to direct byte | 3 | 24 |
| MOVX A,@Ri | Move External Data (8-bit address) to A | 1 | 24 | *SETB C | Set carry | 1 | 12 |
|  |  | 1 | 24 | * SETB bit | Set direct bit Clear A | 2 | 12 |
| *MOVX A,@DPTR | Move External Data (16-bit address) to A |  |  | CLR C | Clear carry | 1 | 12 |
| MOVX @Ri,A | Move $A$ to External Data (8-bit address) | 1 | 24 | * CLR bit | Clear direct bit | 2 | 12 |
|  |  |  |  | CPL A | Complement A | 1 | 12 |
| *MOVX @DPTR,A | Move A to External Data (16-bit address) | 1 | 24 | CPL C | Complement carry | 1 | 12 |
|  |  |  |  | * CPL bit | Complement direct bit | 2 | 12 |
| * PUSH data | Move direct byte to stack and inc. SP | 2 | 24 | RL A | Rotate A Left | 1 | 12 |
|  |  |  |  | RLC A | Rotate A Left through carry | 1 | 12 |
| * POP data | Move direct byte from stack and dec. SP | 2 | 24 | RR A | Rotate A Right | 1 | 12 |
|  |  |  |  | RRC A | Rotate A Right through carry | 1 | 12 |
| XCH A,Rn | Exchange register with $A$ Exchange direct byte with $A$ Exchange indirect RAM | 121 | $\begin{aligned} & 12 \\ & 12 \\ & 12 \end{aligned}$ | SWAP A | Rotate A left four (exchange nibbles within A) | 1 | 12 |
| * XCH A,data |  |  |  |  |  |  |  |
| XCH A,@Ri |  |  |  |  |  |  |  |


| Arithmetic |  |  |  |
| :---: | :---: | :---: | :---: |
|  |  |  | Oscillator |
| Mnemonic | Description | Bytes | Periods |
| ADD A,Rn | Add register to $\mathbf{A}$ | 1 | 12 |
| *ADD A,data | Add direct byte to A | 2 | 12 |
| ADD A,@Ri | Add indirect RAM to $\mathbf{A}$ | 1 | 12 |
| ADD A,\#data | Add immediate data to $\mathbf{A}$ | 2 | 12 |
| ADDC A,Rn | Add register and carry flag to A | 1 | 12 |
| *ADDC A,data | Add direct byte and carry flag to A | 2 | 12 |
| ADDC A,@Ri | Add indirect RAM and carry flag to $A$ | 1 | 12 |
| ADDC A,\#data | Add immediate data and carry flag to A | 2 | 12 |
| *SUBB A,Rn | Subtract register and carry flag from $A$ | 1 | 12 |
| *SUBB A,data | Subtract direct byte and carry flag from $A$ | 2 | 12 |
| *SUBB A,@Ri | Subtract indirect RAM and carry flag from $A$ | 1 | 12 |
| *SUBB A,\#data | Subtract immediate data and carry flag from $A$ | 2 | 12 |
| INC A | Increment A | 1 | 12 |
| INC Rn | Increment register | 1 | 12 |
| *INC data | Increment direct byte | 2 | 12 |
| INC @Ri | Increment indirect RAM | 1 | 12 |
| DEC A | Decrement A | 1 | 12 |
| DEC Rn | Decrement register | 1 | 12 |
| *DEC data | Decrement direct byte | 2 | 12 |
| *DEC @Ri | Decrement indirect RAM | 1 | 12 |
| *INC DPTR | Increment Data Pointer | 1 | 24 |
| *MUL AB | Multiply A times B | 1 | 48 |
| *DIV AB | Divide A by B | 1 | 48 |
| DA A | Decimal add Adjust of A | 1 | 12 |


| Other |  |  | Oscillator |
| :--- | :---: | :---: | :---: |
| Mnemonic | Description | Bytes | Periods |
| NOP | No Operation | 1 | 12 |


| Control Transfer (Branch) |  |  |  |
| :---: | :---: | :---: | :---: |
| Mnemonic | Description | Bytes | Oscillator Periods |
| AJMP addr 11 | Absolute Jump | 2 | 24 |
| *LJMP addr16 | Long Jump | 3 | 24 |
| *SJMP rel | Short Jump | 2 | 24 |
| *JMP @A+DPTR | Jump indirect relative to the DPTR | 1 | 24 |
| JZ rel | Jump if $A$ is zero | 2 | 24 |
| JNZ rel | Jump if $A$ is not zero | 2 | 24 |
| JC rel | Jump if carry is set | 2 | 24 |
| JNC rel | Jump if carry is not set | 2 | 24 |
| *JB bit,rel | Jump relative if direct bit is set | 3 | 24 |
| *JNB bit,rel | Jump relative if direct bit is not set | 3 | 24 |
| *JBC bit,rel | Jump relative if direct bit is set, then clear bit | 3 | 24 |
| *CJNE A,data,rel | Compare direct byte to $\mathbf{A}$ \& Jump if not Eq. See Note a. | 3 | 24 |
| *CJNE A,\#data,rel | Compare immed. to A \& Jump if not Eq. See Note a. | 3 | 24 |
| *CJNE Rn,\#data, rel | Compare immed. to reg \& Jump if not Eq. See Note a. | 3 | 24 |
| *CNJE @Ri, \#data,rel | Compare immed. to indirect RAM \& Jump if not Eq. See Note a. | 3 | 24 |
| DJNZ Rn,rel | Decrement register \& Jump if not zero | 2 | 24 |
| *DJNZ data,rel | Decrement direct byte \& Jump if not zero | 3 | 24 |


| Control Transfer (Subroutine) |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description <br> Oscillator |  |  |
| ACALL addr11 | Absolute Subroutine Call | Bytes | Periods |
| LCALL addr16 | Long Subroutine Call | 2 | 24 |
| RET | Return from Subroutine Call | 1 | 24 |
| RETI | Return from Interrupt Call | 1 | 24 |

# 8048H/8048H-1/8035HL/8035HL-1 HMOS SINGLE COMPONENT 8-BIT MICROCOMPUTER 

\author{

- 8048H/8048H-1 Mask Programmable ROM <br> - 8035HL/8035HL-1 CPU Only with Power Down Mode
}
- 8-BIT CPU, ROM, RAM, I/O in Single

Package

- High Performance HMOS
- Reduced Power Consumption
- $1.4 \mu \mathrm{sec}$ and $1.9 \mu \mathrm{sec}$ Cycle Versions All Instructions 1 or 2 Cycles
- Over 90 Instructions: 70\% Single Byte
- $1 \mathrm{~K} \times 8$ ROM
$64 \times$ RAM
27 I/O Lines
- Interval Timer/Event Counter
- Easily Expandable Memory and I/O
- Compatible with 8080/8085 Series

Peripherals

- Two Single Level Interrupts

The Intel ${ }^{\circledR} 8048 \mathrm{H} / 8048 \mathrm{H}-1 / 8035 \mathrm{HL} / 8035 \mathrm{HL}-1$ are totally self-sufficient, 8 -bit parallel computers fabricated on single silicon chips using Intel's advanced N -channel silicon gate HMOS process.
The 8048 H contains a 1 KX 8 program memory, a64 X8 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 H can be expanded using standard memories and MCS-80 ${ }^{\circledR} /$ MCS- $85{ }^{\circledR}$ peripherals. The 8035 HL is the equivalent of the 8048 H without program memory and can be used with external ROM and RAM.
To reduce development problems to a minimum and provide maximum flexibility, a logically and functionally pin compatible version of the 8048 H with UV-erasable user-programmable EPROM program memory is available. The 8748 will emulate the 8048 H up to 6 MHz clock frequency with minor differences.
The 8048 H is fully compatible with the 8048 when operated at 6 MHz .
These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have 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.


Figure 1. Block Diagram


Figure 2. Logic Symbol


Figure 3. Pin Configuration (top view)

Table 1. Pin Description

| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| VSS | 20 | Circuit GND potential |
| VDD | 26 | Low power standby pin |
| $V_{C C}$ | 40 | Main power supply; +5 V during operation. |
| PROG | 25 | Output strobe for 8243 I/O expander. |
| P10-P17 <br> Port 1 | 27-34 | 8-bit quasi-bidirectional port. |
| P20-P27 <br> Port 2 | 21-24 | 8-bit quasi-bidirectional port. |
|  | 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} & \text { DBO-DB7 } \\ & \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. |
|  |  | 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 { 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}$. |
| 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. |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. |
| $\overline{\text { INT }}$ | 6 | Interrupt input. Initiates an interrupt if interrupt is enabled. Interrupt is disabled after a reset. |


| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
|  |  | 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. <br> Used as a read strobe to external data memory. (Active low) |
| $\overline{\text { RESET }}$ | 4 | Input which is used to initialize the processor. (Active low) (Non TTL VIH) |
| $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) <br> 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. <br> 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{\mathrm{SS}}$ | 5 | Single step input can be used in conjunction 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 for external source. (Non TTL $\mathrm{V}_{1 \mathrm{H}}$ ) |
| XTAL2 | 3 | Other side of crystal input. |

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=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 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Control |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | Disable external interrupt | 1 | 1 |
| SEL RB0 | 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 |
| ENT 0 CLK | Enable clock output on T0 | 1 | 1 | | Mnemonic | Description | Bytes Cycles |  |
| :--- | :--- | :--- | :--- |
| NOP | No operation | 1 | 1 |

## 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 Respett
to Ground $\qquad$
$\qquad$ -0.5 V to +7 V
Power Dissipation .............................. 1.5 Watt
*NOTICE: 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 device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. CHARACTERISTICS (TA $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}+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{R E S E T}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 8 | V |  |
| $V_{\text {IL1 }}$ | Input Low Voltage ( $\overline{\text { RESET, }}$ X1, X2) | -. 5 |  | . 6 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{R E S E T}$ ) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage ( $\mathrm{X} 1, \mathrm{X} 2, \overline{\mathrm{RESET}}$ ) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage (BUS) |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{v}_{\text {OL1 }}$ | Output Low Voltage <br> ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PS} E N}, \mathrm{ALE})$ |  |  | . 45 | V | $\mathrm{IOL}=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 (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |
| VOH | Output High Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}^{\prime}=-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}$ |
| LL1 | Input Leakage Current ( $\mathrm{T} 1, \overline{\mathrm{NT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{S S} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILIT | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{\mathrm{SS}}$ ) |  |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{S S}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| IDD | $V_{\text {DD }}$ Supply Current |  | 4 | 8 | mA |  |
| $\begin{array}{\|l} \mathrm{IDD}^{+} \\ \mathrm{I} \mathrm{CD} \end{array}$ | Total Supply Current |  | 40 | 80 | mA |  |
| VDD | RAM Standby Pin Voltage | 2.2 |  | 5.5 | V | Standby Mode, Reset $\leqslant 0.6 \mathrm{~V}$ |


A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=\mathrm{OV}$ )

| Symbol | Parameter | F (tcy) | $\begin{aligned} & 8048 \mathrm{H} \\ & 8035 \mathrm{HL} \\ & \hline \end{aligned}$ |  |  |  | $\begin{gathered} 8048 \mathrm{H}-1 \\ 8035 \mathrm{HL}-1 \\ \hline 11 \mathrm{MHz} \\ \hline \end{gathered}$ |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | 6 MHz |  | 8 MHz |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max | Min | Max |  |  |
| tLL | ALE Pulse Width | 7/30 tcy -170 | 410 |  | 260 |  | 150 |  |  |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | 1/5 tcy -110 | 390 |  | 260 |  | 160 |  |  |  |
| tLA | Addr Hold from ALE | 1/15 tCY -40 | 120 |  | 80 |  | 50 |  |  |  |
| tcC1 | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 tCY -200 | 1050 |  | 730 |  | 480 |  |  |  |
| ${ }^{\text {t CC2 }}$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 tcy -200 | 800 |  | 550 |  | 350 |  |  |  |
| tow | Data Setup before $\overline{\mathrm{WR}}$ | 13/30 tCY -200 | 880 |  | 610 |  | 390 |  |  |  |
| tWD | Data Hold after $\overline{W R}$ | 1/15 tCY -50 | 350 |  | 220 | . | 40 |  |  | (Note 2) |
| tDR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\text { PSEN }}$ ) | 1/10 tCY -30 | 0 | 220 | 0 | 160 | 0 | 110 |  |  |
| tRD1 | $\overline{\mathrm{RD}}$ to Data in | 2/5 t CY -200 |  | 800 |  | 550 |  | 350 |  |  |
| tRD2 | $\overline{\text { PSEN }}$ to Data in | 3/10 tcy -200 |  | 550 |  | 360 |  | 210 |  |  |
| taw | Addr Setup to $\overline{W R}$ | 2/5 tcy -150 | 850 |  | 600 |  | 300 |  |  |  |
| ${ }^{\text {taD1 }}$ | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 t $\mathrm{CY}-250$ |  | 1670 |  | 1190 |  | 750 |  |  |
| tAD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5$ t CY - 250 |  | 1250 |  | 880 |  | 480 |  |  |
| tAFC1 | Addr Float to $\overline{\mathrm{RD}}$, $\overline{\mathrm{WR}}$ | 2/15 tCY -40 | 290 |  | 210 |  | 140 |  |  |  |
| tAFC2 | Addr Float to $\overline{\text { PSEN }}$ | 1/30 tCY -40 | 40 |  | 20 |  | 10 |  |  |  |
| t 4 AFC1 | ALE to Control ( $\overline{\mathrm{R}}, \overline{\mathrm{WR}}$ ) | $1 / 5$ tcy -75 | 420 |  | 300 |  | 200 |  |  |  |
| tLAFC2 | ALE to Control ( $\overline{\text { PSEN }}$ ) | 1/10 tCy -75 | 170 |  | 110 |  | 60 |  |  |  |
| tcA1 | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | 1/15 tCY -40 | 120 |  | 80 |  | 50 |  |  |  |
| tCA2 | Control to ALE ( $\overline{\text { PSEN }}$ ) | 4/15 tcy -40 | 620 |  | 460 |  | 320 |  |  |  |
| tCP | Port Control Setup to PROG | $2 / 15$ t $\mathrm{CY}-80$ | 210 |  | 140 |  | 100 |  |  |  |
| tpC | Port Control Hold to PROG | 4/15 tcy -200 | 460 |  | 300 |  | 700 |  |  |  |
| tPR | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy-120 |  | 1300 |  | 940 |  | 650 |  |  |
| tPF | Input Data Hold from PROG | $1 / 10$ tcy |  | 250 | 0 | 190 | 0 | 140 |  |  |
| tDP | Output Data Setup | 2/5 tcy -150 | 850 |  | 600 |  | 400 |  |  |  |
| tPD | Output Data Hold | 1/10 tCY -50 | 200 |  | 130 |  | 90 |  |  |  |
| tPP | $\overline{\text { PROG Pulse Width }}$ | 7/10 tcy -250 | 1500 |  | 1060 |  | 700 |  |  |  |
| tPL | Port 2 I/O Setup to ALE | 4/15 tCY -200 | 460 |  | 300 |  | 160 |  |  |  |
| tLP | Port 2 I/O Hold to ALE | 1/10 tcy -100 | 150 |  | 80 |  | 40 |  |  |  |
| tPV | Port Output from ALE | 3/10 tCY + 100 |  | 850 |  | 660 |  | 510 |  |  |
| tcy | Cycle Time |  | 2.5 |  | 1.875 |  | 1.36 |  |  |  |
| tOPRR | TO Rep Rate | 3/15 tCY | 500 |  | 370 |  | 270 |  |  |  |

## Notes:

1. Control Outputs CL $=80 \mathrm{pF}$

BUS Outputs $C L=150 \mathrm{pF}$
2. BUS High Impedance Load 20pF

## WAVEFORMS



## PORT 2 TIMING



I/O PORT TIMING


Crystal Oscillator Mode


C1 $=5 \mathrm{pF} \pm \mathbf{1} / 2 \mathrm{pF}+\mathrm{STRAY}<5 \mathrm{pF}$ $\mathbf{C 2}=\mathbf{C R Y S T A L}+\mathbf{S T R A Y}<\mathbf{8 p F}$ C3 $=20 \mathrm{pF} \pm 1 \mathrm{pF}+\mathrm{STRAY}<\mathbf{5 p F}$

## LC Oscillator Mode



EACH C SHOULD BE APPROXIMATELY 20pF, INCLUDING STRAY CAPACITANCE.

Driving From External Source


ADVANCE INPORMATION

## 80C48/80C35 CHMOS SINGLE-COMPONENT 8-BIT MICROCOMPUTER

- 80C48 Low Power Mask Programmable ROM

80C35 Low Power, CPU only

- Pin-to-pin compatible with Intel's 8048H/8035HL
- $1.36 \mu \mathrm{sec}$ Instruction Cycle. All instructions 1 or 2 cycles
- Ability to maintain operation during AC power line interruptions
- Exit Idle mode with an external or internal interrupt signal
- Battery Operation
- 3 power consumption selections —Normal Operation:

15 mA @ 11 MHz @ 6V
-Idle Mode: $500 \mu \mathrm{~A}$ @ 11 MHz @ 6V
—Power down: $10 \mu \mathrm{~A}$ @ 2.0V

- 11 MHz , TTL compatible operation; $V_{C C}=5 V \pm 10 \%$
CMOS compatible operation;
$V_{C C}=5 V \pm 20 \%$

Intel's 80C48/80C35 are low power, CHMOS versions of the popular MCS-48 HMOS family members. CHMOS is a technology built on HMOS II and features high resistivity $P$ substrate, diffused $N$ well, and scaled $N$ and $P$ channel devices. The $80 \mathrm{C} 48 / 80 \mathrm{C} 35$ have been designed to provide low power consumption and high performance.

The 80 C 48 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 an on-board oscillator and clock circuits. For systems that require extra capability, the 80C48 can be expanded using CMOS external memories and MCS-80® and MCS-85 ${ }^{\circledR}$ peripherals. The 80 C 35 is the equivalent of the 80 C 48 without program memory on-board.

The CHMOS design of the 80C48 opens new application areas that require battery operation, low power standby, wide voltage range, and the ability to maintain operation during AC power line interruptions. These applications include portable and hand-held instruments, telecommunications, consumer, and automotive.


Figure 1.
Block Diagram


Figure 2. Logic Symbol


Figure 3. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Function | Symbol | Pin No. | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{S S}$ <br> VDD <br> $V_{C C}$ |  | Circuit GND potential <br> Low power standby pin <br> Main power supply; +5 V during operation. | $\overline{\mathrm{RD}}$ | 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) |
|  |  |  |  |  |  |
|  | 40 |  |  |  |  |
| PROG | 25 | Output strobe for 8243 I/O expander. |  |  |  |
| P10-P17 <br> Port 1 | 27-34 | 8-bit quasi-bidirectional port. | RESET | 4 | Input which is used to initialize the processor. (Active low) (Non TTL $\mathrm{V}_{\mathrm{IH}}$ ) |
| P20-P27 <br> Port 2 | $\begin{aligned} & 21-24 \\ & 35-38 \end{aligned}$ | 8-bit quasi-bidirectional port. P20-P23 contain the four high order program counter bits dur- | $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) |
| $\begin{aligned} & \text { DBO-DB7 } \\ & \text { BUS } \end{aligned}$ | 12-19 | ing an external program memory fetch and serve as a 4-bit I/O expander bus for 8243. | ALE | 11 | Used as write strobe to external data memory. <br> Address latch enable. This signal |
|  |  | True bidirectional port which can be written or read synchronously using the $\overline{R D}, \overline{W R}$ 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 $\overline{\text { 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}$. |  |  | 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. |
|  |  |  | $\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 conjunction with ALE to "single step" the processor through each instruction. (Active low) |
| T0 | $\begin{array}{r}1 \\ \\ \hline\end{array}$ | 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 essential for testing and program verification. |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. | XTAL1 | 2 | (Active high) <br> One side of crystal input for internal oscillator. Also input for external source. (Non TTL $\mathrm{V}_{\mathrm{IH}}$ ) |
| $\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) Interrupt pin must remain low for at least $3 t_{c y}$ to ensure proper operation. | XTAL2 | 3 | Other side of crystal input. |

## IDLE MODE DESCRIPTION

The 80C48, when placed into Idle mode, keeps the oscillator, the internal timer and the external interrupt and counter pins functioning and maintains the internal register and RAM status.

To place the 80 C 48 in Idle mode, a command instruction (op code 01 H ) is executed. To terminate Idle mode, interrupts must be enabled and an interrupt signal generated. There are two interrupt sources that can restore normal operation. One is an external signal applied to the interrupt pin. The other is from the overflow of the timer/counter. When either interrupt is invoked the CPU is taken out of Idle mode and vectors to the interrupt's service routine address. A reset signal will also take the processor out of Idle mode. Along with the Idie mode, the standard MCS-48 power-down mode is still maintained.

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=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 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :---: | :---: | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |
| Flags |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| Data Moves |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| XCH A, @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 $\mathbf{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, @ | Move to A from page 3 | 1 | 2 |
| Timer/Counter |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| 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 TGNT | Stop timer/counter | 1 | 1 |
| EN TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |


| Control |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | Disable external interrupt | 1 | 1 |
| SEL RB0 | 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 |
| ENT0 CLK | Enable clock output on T0 | 1 | 1 |


| Mnemonic | Description |  | Bytes Cycles |  |
| :--- | :--- | :--- | :---: | :---: |
| NOP | No operation |  | 1 | 1 |
| IDL | Select Idle operation | $\ddots$ | 1 | 1 |

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias ....... $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature $. . . . . . . . . . . . . \quad-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage On Any Pin With Respect to Ground -0.5 V to +7 V
Voltage on Any Pin with Respect to $\mathrm{V}_{\mathrm{CC}}$ $V_{C C}+0.5 \mathrm{~V}$
Max Package Power Dissipation
$\qquad$ 1.5 Watt
*NOTICE: 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}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=\mathrm{OV}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| $V_{\text {IL }}$ | Input Low Voltage <br> (All Except RESET, X1, X2) | -. 5 |  | . 8 | V |  |
| VIL1 | Input Low Voltage (RESET, X1, X2) | -. 5 |  | . 6 | V |  |
| $V_{\text {IH }}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage (X1, X2, $\overline{\text { RESET }}$ ) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage (BUS) |  |  | . 45 | V | $\mathrm{IOL}=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 (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage (BUS) | 2.4 |  |  | V | ${ }^{\mathrm{I}} \mathrm{OH}^{\prime}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage <br> ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}^{\prime}=-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}$ |
| ${ }^{\text {L } 11}$ | Input Leakage Current (T1, $\overline{\mathrm{NNT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| ${ }_{\text {LLI }}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{\mathrm{SS}}$ ) |  |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILI2 | Input leakage Current (RESET) |  |  | -300 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {ILI }}$ |
| 'Lo | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ${ }^{\text {I D D }}$ | $\mathrm{V}_{\text {DD }}$ Supply Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {DD }}=2.0 \mathrm{~V}$ |
| ${ }^{1} \mathrm{Cc}$ | Supply Current |  |  | $\begin{aligned} & 15 \\ & 8.5 \\ & 1.5 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & f=11 \mathrm{MHz} \\ & f=6 \mathrm{MHz} \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| IIDLE | Idle Mode Current |  |  | $\begin{gathered} 500 \\ 300 \\ 60 \\ \hline \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & f=11 \mathrm{MHz} \\ & f=6 \mathrm{MHz} \\ & f=1 \mathrm{MHz} \end{aligned}$ |

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}_{S S}=\mathrm{OV}$ )

| Symbol | Parameter | f (tcY) (Note 3) | 11 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| ${ }^{\text {t LL }}$ | ALE Pulse Width | $7 / 30 \mathrm{t}_{\mathrm{CY}}-170$ | 150 |  | ns |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | 1/5 $\mathrm{t}_{\mathrm{CY}}{ }^{-110}$ | 160 |  | ns |  |
| ${ }^{\text {t L }}$ A | Addr Hold from ALE | $1 / 15 \mathrm{t}_{\mathrm{CY}}-40$ | 50 |  | ns |  |
| ${ }^{t} \mathrm{CC} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 t CY-200 | 480 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 ${ }^{\mathrm{t}} \mathrm{CY}{ }^{-200}$ | 350 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup before $\overline{W R}$ | $13 / 30{ }^{\text {t }}$ CY -200 | 390 |  | ns |  |
| twd | Data Hold after $\overline{W R}$ | 1/15 ter -50 | 40 |  | ns |  |
| ${ }^{t}$ DR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | $1 / 10{ }^{t} \mathrm{CY}^{-30}$ | 0 | 110 | ns |  |
| ${ }^{\text {R RD1 }}$ | $\overline{\mathrm{RD}}$ to Data in | $2 / 5 \mathrm{t}^{\text {CY }}{ }^{-200}$ |  | 350 | ns |  |
| ${ }^{\text {tr }}$ R2 | $\overline{\text { PSEN }}$ to Data in | $3 / 10 \mathrm{t}_{\mathrm{CY}}-200$ |  | 210 | ns |  |
| ${ }^{t}$ AW | Addr Setup to $\overline{W R}$ | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t }}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | $23 / 30 \mathrm{t}_{\mathrm{CY}}-250$ |  | 800 | ns |  |
| ${ }^{\text {t }}$ AD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5 \mathrm{t}^{\text {CY }}{ }^{-250}$ |  | 570 | ns |  |
| ${ }^{\text {t }}$ AFC1 | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 140 |  | ns | (Note 2) |
| ${ }^{\text {t } A F C 2}$ | Addr Float to PSEN | $1 / 30{ }^{\text {t }}$ CY -40 | 10 |  | ns | (Note 2) |
| ${ }^{\text {LLAFC1 }}$ | ALE to Control, ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | ${ }^{1 / 5} \mathrm{t}^{\text {CY }}{ }^{-75}$ | 200 |  | ns |  |
| ${ }^{\text {t }}$ LAFC2 | ALE to Control ( $\overline{\text { PSEN }}$ ) | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-75}$ | 60 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CA} 1$ | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15{ }^{\text {t }} \mathrm{CY}^{-40}$ | 50 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CA} 2$ | Control to ALE ( $\overline{\text { PSEN }}$ ) | $4 / 15{ }^{\text {t }} \mathrm{CY}^{-40}$ | 320 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 t $\overline{\mathrm{CY}}$ - 80 | 100 |  | ns |  |
| ${ }^{\text {t PC }}$ | Port Control Hold to $\overline{\text { PROG }}$ | $4 / 15 \mathrm{t}^{\text {CY }}{ }^{-200}$ | 160 |  | ns |  |
| ${ }^{\text {t }}$ PR | $\widehat{\text { PROG }}$ to P2 Input Valid | 6/10 tcy -120 |  | 700 | ns |  |
| ${ }^{\text {t PFF }}$ | Input Data Hold from $\overline{\text { PROG }}$ | $1 / 10{ }^{\text {t }} \mathrm{CY}$ | 0 | 140 | ns |  |
| ${ }^{t} \mathrm{DP}$ | Output Data Setup | $2 / 5 \mathrm{t}^{\text {CY }}{ }^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t PD }}$ | Output Data Hold | 1/10 ${ }^{\text {c }} \mathrm{CY}^{-50}$ | 90 |  | ns |  |
| ${ }^{\text {t PP }}$ | PROG Pulse Width | $7 / 10{ }^{\text {t }} \mathrm{CY}^{-250}$ | 700 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | $4 / 15{ }^{\text {t }} \mathrm{CY}^{-200}$ | 160 |  | ns |  |
| ${ }^{\text {t }}$ LP | Port $2 \mathrm{I} / \mathrm{O}$ Hold to ALE | ${ }^{1 / 10}{ }^{t} \mathrm{CY}^{-100}$ | 40 |  | ns |  |
| ${ }^{\text {t P }} \mathrm{PV}$ | Port Output from ALE | $3 / 10{ }^{\text {t }} \mathrm{CY}^{+100}$ |  | 510 | ns |  |
| ${ }^{\text {t }} \mathrm{C} Y$ | Cycle Time | 15/(fXTAL) | 1.36 |  | $\mu \mathrm{s}$ |  |
| toprR | T0 Rep Rate | $3 / 15{ }^{\text {t }} \mathrm{CY}$ | 270 |  | ns |  |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF}$ BUS Outputs $C L=150 p F$
2. BUS High Impedance Load 20pF
3. $f(t \mathrm{CY})$ assumes $50 \%$ duty cycle on X 1 and X 2 .

## WAVEFORMS



## PORT 2 EXPANDER TIMING



I/O PORT TIMING


DRIVING FROM

OSCILLATOR MODE

$C 1=5 p F \pm 1 / 2 p F+(S T R A Y<5 p F)$
C2 $=($ CRYSTAL SHUNT CAPACITANCE + STRAY $)<8 \mathrm{PF}$ $\mathrm{C} 3=20 \mathrm{pF} \pm 1 \mathrm{pF}+(S T R A Y<5 \mathrm{pF})$

CRYSTAL SERIES RESISTANCE SHOULD BE LESS THAN $75 \Omega$ II $6 M H z$; LESS THAN $180 \Omega /$ AT 3.6 MHz .

LC OSCILLATOR MODE


EACH C SHOULD BE APPROXIMATELY 20 pF . including stray capacitance.

## EXTERNAL SOURCE



FOR THE 80C48, XTAL1 MUST BE HIGH 35-65\% OF THE PERIOD AND XTAL2 MUST BE HIGH $35-65 \%$ OF THE PERIOD.

RISE AND FALL TIMES MUST NOT EXCEED 20 ns .

# 8748H/8035H HMOS SINGLE-CHIP EPROM MICROCOMPUTER 

8748H 11 MHz User Programmable EPROM<br>- 8035H 11 MHz CPU Only with RAM and I/O

- 8-BIT CPU, EPROM, RAM, I/O in Single Package
- High Performance HMOS
- 1.36 Instruction Cycle

All Instructions 1 or 2 Cycles

- Over 90 instructions: 70\% Single Byte

Compatible with 8080/8085 Series Peripherals

1K x 8 EPROM
$64 \times 8$ RAM
27 I/O Lines
Interval Timer/Event Counter
Easily Expandable Memory and I/O
Two Single Level Interrupts

The Intel 8748 H is a totally self-sufficient, 8 -bit parallel computer fabricated on a single silicon chip using Intel's advanced N-channel silicon gate HMOS process.
The 8748 H contains on-chip a $1 \mathrm{~K} \times 8$ UV-erasable, user-programmable program memory, a $64 \times 8$ RAM data memory, 27 I/O lines, 2 interrupt sources, and an 8 -bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability the 8748 H can be expanded using standard memories and MCS-80®/MCS-85® peripherals. The 8035 H is the equivalent of the 8748 H without program memory and can be used with external ROM and RAM.

To reduce development problems to a minimum and provide maximum flexibility, three interchangeable pin-compatible versions of this single component microcomputer exist: the 8748 H with user-programmable and erasable EPROM program memory, the 8048 H with factory-programmed mask ROM program memory for low cost, high volume production, and the 8035 H without program memory for use with external program memories.

These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have 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.


## Table 1. Pin Description

| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| $V_{\text {ss }}$ | 20 | Circuit GND Potential |
| $V_{D D}$ | 26 | Programming power supply; +21V during program, +5 V during operation. |
| $\mathrm{V}_{\mathrm{cc}}$ | 40 | Main power supply; +5 V during operation and programming. |
| PROG | 25 | Program pulse ( +18 V ) input pin during 8749 H programming. <br> Output strobe for 8243 I/O expander. |
| $\begin{aligned} & \text { P10-P17 } \\ & \text { Port } 1 \end{aligned}$ | 27-34 | 8-bit quasi-bidirectional port. |
| $\begin{gathered} \text { P20-P27 } \\ \text { Port } 2 \end{gathered}$ | $\begin{aligned} & 21-24 \\ & 35-38 \end{aligned}$ | 8-bit quasi-bidirectional port. <br> 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. |
| $\begin{gathered} \mathrm{DB}_{0}-\mathrm{DB}_{7} \\ \mathrm{BUS} \end{gathered}$ | 12-19 | True bidirectional port which can be written or read synchronously using the $\overline{R D}, \overline{W R}$ 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{R D}$, and 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, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. |
| 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) |


| Symbol | Pin No. | . Function |
| :---: | :---: | :---: |
| $\overline{\mathrm{RD}}$ | 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) |
| $\overline{\text { RESET }}$ | 4 | Input which is used to initialize the processor. Also used during PROM programming verification; and power down. (Active low) <br> (Non TTL VIH) |
| $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) <br> 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. <br> 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 conjunction 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 for external source. (Non TTL $V_{I H}$ ) |
| XTAL2 | 3 | Other side of crystal input. |

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JT0 addr | Jump on TO $=1$ | 2 | 2 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=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 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :---: | :---: | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |
| Flags |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| Data Moves |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| XCH A, @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, @ | Move to A from page 3 | 1 | 2 |
| Timer/Counter |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| 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 TGNT | Stop timer/counter | 1 | 1 |
| EN TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |
| Control |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | 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 |
| ENT 0 CLK | Enable clock output on TO | 1 | 1 |
| Mnemonic | Description | Bytes | Cycles |
| NOP | No operation | 1 | 1 |

Mnemonicse Intel Corporation, 1981.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\qquad$ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage On Any Pin With Respect to Ground -0.5 V to +7 V
Power Dissipation ............................... 1.5 Watt
*NOTICE: 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}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| VIL | Input Low Voltage <br> (All Except RESET, X1, X2) | -. 5 |  | . 8 | V |  |
| VIL1 | Input Low Voltage (RESET, X1, X2) | -. 5 |  | . 6 | V |  |
| $V_{\text {IH }}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\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{I}^{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\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}^{\prime} \mathrm{L}=1.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL3 }}$ | Output Low Voltage (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage (BUS) | 2.4 |  |  | V | ${ }^{\prime} \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 | ${ }^{\prime} \mathrm{OH}^{\prime}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | ${ }^{1} \mathrm{OH}=-40 \mu \mathrm{~A}$ |
| $l_{\text {L1 }}$ | Input Leakage Current (T1, $\overline{\mathrm{NT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ${ }^{\text {L LI1 }}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{S S}$ ) |  |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| 'LO | Output Leakage Current (BUS, TO) <br> (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IDD | $V_{\text {DD }}$ Supply Current |  | 5 | 10 | mA |  |
| $\left\lvert\, \begin{aligned} & I_{D D}+ \\ & I_{C C} \end{aligned}\right.$ | Total Supply Current |  | 50 | 110 | mA |  |

(
A.C. CHARACTERISTICS $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{D D}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | $f(t c y)$ | 11 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| ${ }_{t}$ LL | ALE Pulse Width | 7/30 tey ${ }^{-170}$ | 150 |  | ns |  |
| ${ }^{\text {t }}$ L | Addr Setup to ALE | $1 / 5 \mathrm{t}_{\mathrm{CY}}-110$ | 160 |  | ns |  |
| $t_{\text {LA }}$ | Addr Hold from ALE | $1 / 15 \mathrm{t}_{\mathrm{CY}}-40$ | 50 |  | ns |  |
| ${ }^{t} \mathrm{CC} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 tey -200 | 480 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 ${ }^{\text {t }}$ CY -200 | 350 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup before $\overline{\mathrm{WR}}$ | 13/30 t $\mathrm{CY}^{-200}$ | 390 |  | ns |  |
| ${ }^{\text {t }}$ WD | Data Hold after $\overline{W R}$ | 1/15 tCY -50 | 40 |  | ns | (Note 2) |
| ${ }^{\text {t }}$ DR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | $1 / 10 \mathrm{t}^{\text {CY }}{ }^{-30}$ | 0 | 110 | ns |  |
| ${ }^{\text {RRD1 }}$ | $\overline{\mathrm{RD}}$ to Data in | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-200}$ |  | 350 | ns |  |
| ${ }^{\text {t R }}$ 2 2 | $\overline{\text { PSEN }}$ to Data in | 3/10 t ${ }^{\text {cy }}$-200 |  | 210 | ns |  |
| ${ }^{\text {t }}$ AW | Addr Setup to $\overline{W R}$ | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns | $\cdots$ |
| ${ }^{t}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | $23 / 30 \mathrm{t}_{\mathrm{CY}}-250$ |  | 800 | ns |  |
| ${ }^{\text {t }} \mathrm{AD} 2$ | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5{ }^{\text {t }} \mathrm{CY}{ }^{-250}$ |  | 570 | ns |  |
| ${ }^{\text {t }}$ AFC1 | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 140 |  | ns |  |
| ${ }^{\text {t }}$ AFC2 | Addr Float to $\overline{\text { PSEN }}$ | ${ }^{1 / 30} \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 10 |  | ns |  |
| ${ }^{\text {L LAFC1 }}$ | ALE to Control, ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5{ }^{\text {t }} \mathrm{CY}^{-75}$ | 200 |  | ns |  |
| ${ }^{\text {L LAFC2 }}$ | ALE to Control ( $\overline{\text { PSEN }}$ ) | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-75}$ | 60 |  | ns |  |
| ${ }^{t} \mathrm{CA} 1$ | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 50 |  | ns |  |
| ${ }^{t} \mathrm{CA} 2$ | Control to ALE ( $\overline{\text { PSEN }}$ ) | $4 / 15{ }^{\text {t }} \mathrm{CY}^{-40}$ | 320 |  | ns |  |
| ${ }^{t} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 tç -80 | 100 |  | ns |  |
| ${ }^{\text {P }} \mathrm{PC}$ | Port Control Hold to $\overline{\text { PROG }}$ | $4 / 15 \mathrm{t}_{\mathrm{CY}}{ }^{-200}$ | 160 |  | ns |  |
| ${ }^{\text {tPR }}$ | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy -120 |  | 700 | ns |  |
| ${ }^{\text {t PF }}$ | Input Data Hold from $\overline{\text { PROG }}$ | $1 / 10{ }^{t} \mathrm{CY}$ | 0 | 140 | ns |  |
| ${ }^{t} \mathrm{DP}$ | Output Data Setup | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t }}$ PD | Output Data Hold | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-50}$ | 90 |  | ns |  |
| ${ }^{\text {t }}$ PP | PROG Pulse Width | 7/10 t ${ }^{\text {CY }}$-250 | 700 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | $4 / 15 \mathrm{t}_{\mathrm{CY}}{ }^{-200}$ | 160 |  | ns | $\cdots$ |
| ${ }_{\text {LP }}$ | Port 2 I/O Hold to ALE | ${ }^{1 / 10} \mathrm{t}_{\mathrm{CY}}{ }^{-100}$ | 40 |  | ns |  |
| ${ }^{\text {t }} \mathrm{PV}$ | Port Output from ALE | $3 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{+100}$ |  | 510 | ns |  |
| ${ }^{\text {t }} \mathrm{CY}$ | Cycle Time | 1/( fXTAL $\times 15$ ) | 1.36 |  | $\mu \mathrm{s}$ |  |
| topRR | TO Rep Rate | $3 / 15{ }^{\text {t }} \mathrm{CY}$ | 270 |  | ns |  |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF}$ BUS Outputs CL $=150 \mathrm{pF}$
When driven by an ext. clock, AC specs are based on $50 \%$ duty cycles.

The 8748 H exhibits some sensitivity to light The RAM storage area can be altered when exposed to light. When operating the 8748 H , the window must be covered with an opaque material.

## WAVEFORMS



## PORT 2 EXPANDER TIMING



## WAVEFORMS

## COMBINATION PROGRAM/VERIFY MODE (EPROM'S ONLY)




The 8748 H EPROM can be programmed by:
Universal PROM Programmer (UPP series) peripheral of the Intellec® Development System with a UPP-848 Personality Card and a UPP-549 adapter socket.


## PROGRAMMING, VERIFYING, AND ERASING THE 8748H 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 |
| :--- | :--- |
| $\frac{\text { XTAL 1 }}{}$ Reset | Clock Input (1 to 3MHz) |
| 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-22 | Address Input |
| VDD | Programming Power Supply |
| PROG | Program Pulse Input |

WARNING:
An attempt to program a missocketed 8748 H 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. $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$, Clock applied or internal oscillator operating, $\overline{\mathrm{RESET}}=0 \mathrm{~V}, \mathrm{TEST} 0=5 \mathrm{~V}, \mathrm{EA}=5 \mathrm{~V}$, BUS and PROG floating. P10 and P11 must be tied to ground.
2. Insert 8748 H in programming socket.
3. TEST $0=O \mathrm{~V}$ (select program mode)
4. $E A=18 \mathrm{~V}$ (activate program mode)
5. Address applied to BUS and P20-22
6. $\overline{\mathrm{RESET}}=5 \mathrm{~V}$ (latch address)
7. Data applied to BUS
8. $\mathrm{V}_{\mathrm{DD}}=21 \mathrm{~V}$ (programming power)
9. $\mathrm{PROG}=0 \mathrm{~V}$ followed by one 50 ms pulse to 18 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. $\overline{\operatorname{RESET}}=0 \mathrm{~V}$ and repeat from step 5
15. Programmer should be at conditions of step 1 when 8748 H is removed from socket.
A.C. TIMING SPECIFICATION FOR PROGRAMMING $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=20 \mathrm{~V} \pm 1 \mathrm{~V}\right)$

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {aw }}$ | Address Setup Time to $\overline{\mathrm{RESET}} \dagger$ | 4 tcr |  |  |  |
| twa | Address Hold Time After RESET $\dagger$ | 4 tcr |  |  |  |
| tow | Data in Setup Time to PROG 1 | 4 tcr |  |  |  |
| two | Data in Hold Time After PROG ! | 4 tcr |  |  |  |
| $\mathrm{t}_{\text {PH }}$ | RESET Hold Time to Verify | 4 tcr |  |  |  |
| tvodw | $V_{D D}$ | 4 tcr |  |  |  |
| tvooh | Vod Hold Time After PROG ! | 0 |  |  |  |
| tpw | Program Pulse Width | 50 | 60 | mS |  |
| trw | Test 0 Setup Time for Program Mode | $4 \mathrm{tcr}_{\mathrm{cr}}$ |  |  |  |
| $t_{\text {wi }}$ | Test 0 Hold Time After Program Mode | 4 tcr |  |  |  |
| too | Test 0 to Data Out Delay |  | 4 tcr |  |  |
| tww | RESET Pulse Width to Latch Address | 4 tcy |  |  |  |
| $t_{1}, t_{1}$ | $V_{\text {DD }}$ 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 EAI | 4 tcr |  |  |  |

NOTE: If Test 0 is high too can be triggered by RESET $\uparrow$
D.C. SPECIFICATION FOR PROGRAMMING $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{D D}=21 \mathrm{~V} \pm .5 \mathrm{~V}\right)$

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $V_{D O H}$ | $V_{D D}$ Program Voltage High Level | 20.5 | 21.5 | V |  |
| $V_{D D L}$ | V $_{\text {DD }}$ Voltage Low Level | 4.75 | 5.25 | V |  |
| $V_{P H}$ | PROG Program Voltage High Level | 17.5 | 18.5 | V |  |
| $\mathrm{~V}_{P L}$ | PROG Voltage Low Level |  | 0.2 | V |  |
| $\mathrm{~V}_{\text {EAH }}$ | EA Program or Verify Voltage High Level | 17.5 | 18.5 | V |  |
| $\mathrm{I}_{\mathrm{DD}}$ | V $_{\text {DD }}$ High Voltage Supply Current |  | 30.0 | mA |  |
| IPROG | PROG High Voltage Supply Current |  | 16.0 | mA |  |
| $\mathrm{I}_{\text {EA }}$ | EA High Voltage Supply Current |  | 1.0 | mA |  |

PRELONONARY

# 8049H Mask Programmable ROM 8039HL CPU Only with Power Down Mode 

- 8-BIT CPU, ROM, RAM, I/O in Single Package
- High Performance HMOS

Reduced Power Consumption

- $1.4 \mu \mathrm{sec}$ and $1.9 \mu \mathrm{sec}$ Cycle Versions All Instructions 1 or 2 Cycles.
- Over 90 instructions: 70\% Single Byte
- 2K x 8 ROM
$128 \times 8$ RAM
27 I/O Lines
- Interval Timer/Event Counter
- Easily Expandable Memory and I/O

■ Compatible with 8080/8085 Series Peripherals

- Two Single Level Interrupts

The Intel ${ }^{\circledR} 8049 \mathrm{H} / 8039 \mathrm{HL}$ are totally self-sufficient, 8 -bit parallel computers fabricated on single silicon chips using Intel's advanced N -channel silicon gate HMOS process.

The 8049 H contains a 2 K X 8 program memory, a 128 X 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 H can be expanded using standard memories and MCS-80®/MCS-85® peripherals. The 8039 HL is the equivalent of the 8049 H without program memory and can be used with external ROM and RAM.
To reduce development problems to a minimum and provide maximum flexibility, a logically and functionally pin compatible version of the 8049 H with UV-erasable user-programmable EPROM program memory will soon be available. The 8749 will emulate the 8049 H up to 11 MHz clock frequency with minor differences.
The 8049 H is fully compatible with the 8049.
These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have 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.


Figure 1. Block Diagram


Figure 2. Logic Symbol


Figure 3. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Function | Symbol | Pin No. | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {SS }}$ | 20 | Circuit GND potential | $\overline{\mathrm{RD}}$ | 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 | Low power standby pin |  |  |  |
| $V_{C C}$ | 40 | Main power supply; +5V during operation. |  |  |  |
| PROG | 25 | Output strobe for 8243 I/O expander. |  |  |  |
| P10-P17 Port 1 | 27-34 | 8-bit quasi-bidirectional port. | RESET | 4 | Input which is used to initialize the processor. (Active low) (Non TTL $V_{1 H}$ ) |
| P20-P27 <br> Port 2 | 21-24 | 8-bit quasi-bidirectional port. | $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) |
|  | 35-38 | P20-P23 contain the four high order program counter bits dur- |  |  | Used as write strobe to external data memory. |
|  |  | ing 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. |
| $\begin{aligned} & \text { DBO-DB7 } \\ & \text { BUS } \end{aligned}$ | 12-19 | True bidirectional port which can be written or read synchronously using the $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ |  |  | The negative edge of ALE strobes address into external data and program memory. |
|  |  | statically latched. <br> Contains the 8 low order program counter bits during an external program memory fetch. | $\overline{\text { PSEN }}$ | 9 | Program store enable. This output occurs only during a fetch to external program memory. (Active low) |
|  |  | and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM | $\overline{\text { SS }}$ | 5 | Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active low) |
|  |  | data store instruction, under control of ALE, $\overline{R D}$, and $\overline{W R}$. | EA | 7 | External access input which forces all program memory |
| TO | 1 | Input pin testable using the conditional transfer instructions JTO and JNTO. TO can be designated as a clock output using ENTO CLK instruction. |  |  | fetches to reference external memory. Useful for emulation and debug, and essential for testing and program verification. (Active high) |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. | XTAL1 XTAL2 | 2 3 | One side of crystal input for internal oscillator. Also input for external source. (Non TTL $\mathrm{V}_{\mathrm{IH}}$ ) Other side of crystal input. |
| $\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) |  |  |  |

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description |  |  |
| 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 |  |  |
| RRC A | Rotate A right through carry | 1 | 1 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=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 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :---: | :---: | :---: | :---: |
| Mnemonic | Description | Bytes | cles |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |
| Flags |  |  |  |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
| Data Moves |  |  |  |
| Mnemonic | Description | Bytes Cycles |  |
| 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 $\mathbf{A}$ and register | 1 | 1 |
| XCH A, @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 |  | 2 |
| MOVP A, @A | Move to A from current page | 1 | 2 |
| MOVP3 A, @ | Move to A from page 3 | 1 | 2 |
| Timer/Counter |  |  |  |
| Mnemonic | Description | Bytes Cycles |  |
| 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 TGNT | Stop timer/counter | 1 | 1 |
| EN TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |


| Control |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | Disable external interrupt | 1 | 1 |
| SEL RB0 | 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 |
|  |  |  |  |
| Mnemonic | Description | Bytes Cycles |  |
| NOP | No operation | 1 | 1 |

## 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
*NOTICE: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 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}_{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 RESET, X1, X2) | -. 5 |  | . 8 | V |  |
| $\mathrm{V}_{\text {IL1 }}$ | Input Low Voltage (RESET, X1, X2) | -. 5 |  | . 6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\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 | $1 \mathrm{OL}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\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 (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{I}^{\prime} \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}$ |
| ${ }^{\text {LL1 }}$ | Input Leakage Current (T1, $\overline{\mathrm{INT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leq \mathrm{V}_{\mathbb{I N}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ${ }^{\text {L LI }}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{S S}$ ) |  |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| 'Lo | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IDD | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 5 | 10 | mA |  |
| $\left\lvert\, \begin{aligned} & \text { IDD } \\ & \text { ICC } \end{aligned}\right.$ | Total Supply Current |  | 50 | 100 | mA | - |



## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{D D}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=\mathrm{O}$ )

| Symbol | Parameter | $f$ (tcr) <br> (Note 3) | 11 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| $t_{L L}$ | ALE Pulse Width | 7/30 tey -170 | 150 |  | ns |  |
| ${ }^{\text {ALL }}$ | Addr Setup to ALE | 1/5 t CY -110 | 160 |  | ns |  |
| ${ }_{\text {t LA }}$ | Addr Hold from ALE | $1 / 15 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 50 |  | ns |  |
| ${ }^{t} \mathrm{CC} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 ${ }^{\text {t }} \mathrm{CY}$-200 | 480 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 ${ }^{\text {t }}$ CY -200 | 350 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup before $\overline{W R}$ | 13/30 t ${ }^{\text {CY }}$-200 | 390 |  | ns |  |
| ${ }^{\text {t W }}$ D | Data Hold after $\bar{W}$ | 1/15 tCY -50 | 40 |  | ns | (Note 2) |
| ${ }^{t}$ DR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-30}$ | 0 | 110 | ns |  |
| ${ }^{\text {t }}$ RD1 | $\overline{\mathrm{RD}}$ to Data in | $2 / 5 \mathrm{t}^{\text {CY }}$-200 |  | 350 | ns |  |
| ${ }^{\text {tr }}$ R2 | $\overline{\text { PSEN }}$ to Data in | $3 / 10 \mathrm{t}_{\mathrm{CY}} \mathbf{- 2 0 0}$ |  | 210 | ns |  |
| ${ }^{\text {t }}$ AW | Addr Setup to $\overline{W R}$ | $2 / 5 \mathrm{t}_{\mathrm{CY}}{ }^{-150}$ | 400 |  | ns |  |
| ${ }^{t}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 ${ }^{\text {c }}$ CY -250 |  | 800 | ns |  |
| ${ }^{t}$ AD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5 \mathrm{t} \mathrm{CY}^{-250}$ |  | 570 | ns |  |
| ${ }^{\text {t }}$ AFC1 | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 2/15 ${ }^{\text {t }} \mathrm{CY}^{-40}$ | 140 |  | ns |  |
| ${ }^{t}$ AFC2 | Addr Float to PSEN | $1 / 30{ }^{\text {t }} \mathrm{CY}^{-40}$ | 10 |  | ns |  |
| ${ }^{\text {L LAFC }} 1$ | ALE to Control, ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5{ }^{\text {t }} \mathrm{CY}{ }^{-75}$ | 200 |  | ns |  |
| ${ }^{\text {t LAFC2 }}$ | ALE to Control ( $\overline{\text { PSEN }}$ ) | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-75}$ | 60 |  | ns |  |
| ${ }^{t} \mathrm{CA} 1$ | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 50 |  | ns |  |
| ${ }^{\text {t }}$ CA2 | Control to ALE ( $\overline{\text { PSEN }}$ ) | ${ }^{4 / 15}{ }^{\text {t }} \mathrm{CY}^{-40}$ | 320 |  | ns |  |
| ${ }^{1} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 tcy -80 | 100 |  | ns |  |
| ${ }^{\text {t }} \mathrm{PC}$ | Port Control Hold to $\overline{\text { PROG }}$ | $4 / 15{ }^{\text {t }}{ }^{\text {CY }}$-200 | 160 |  | ns |  |
| ${ }^{\text {t }}$ PR | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy -120 |  | 700 | ns |  |
| ${ }^{\text {t PF }}$ | Input Data Hold from $\widehat{\text { PROG }}$ | $1 / 10{ }^{\text {t }} \mathrm{CY}$ | 0 | 140 | ns |  |
| ${ }^{\text {t }}$ DP | Output Data Setup | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t PD }}$ | Output Data Hold | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-50}$ | 90 |  | ns |  |
| ${ }^{1} \mathrm{PP}$ | $\overline{\text { PROG }}$ Pulse Width | 7/10 ${ }^{\text {t }} \mathrm{CY}{ }^{-250}$ | 700 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | 4/15 ${ }^{+} \mathrm{CY}^{-200}$ | 160 |  | ns |  |
| ${ }_{\text {t }}$ P | Port 2 I/O Hold to ALE | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-100}$ | 40 |  | ns |  |
| ${ }^{\text {t P PV }}$ | Port Output from ALE | $3 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{+100}$ |  | 510 | ns |  |
| ${ }^{t} \mathrm{Cr}$ | Cycle Time | 1/( fXTAL $\times 15$ ) | 1.36 |  | $\mu \mathrm{s}$ |  |
| ${ }^{\text {topRR }}$ | TO Rep Rate | $3 / 15{ }^{\text {t }} \mathrm{CY}$ | 270 |  | ns |  |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF}$
BUS Outputs CL $=150 \mathrm{pF}$
2. Interrupt pin must remain low for at
least $3 t_{c y}$ to ensure proper operation.
3. BUS High Impedance Load 20pF
4. Calculated values will be equal to or better than published 8049 values. $f\left(t_{c y}\right)$ assumes $50 \%$ duty cycle on X1, X2.

WAVEFORMS


PORT 2 EXPANDER TIMING


## I/O PORT TIMING



## OSCILLATOR MODE



C1 $=5 \mathbf{5 F} \pm \mathbf{1 / 2 p F}+$ STRAY $<\mathbf{5 p F}$ C2 $=$ CRYSTAL + STRAY $<8$ PF C3 $=20 \mathrm{pF} \pm 1 \mathrm{pF}+\mathrm{STRAY}<5 \mathrm{pF}$

CRYSTAL SERIES RESISTANCE SHOULD BE LESS THAN $75 \Omega$ AT 6MHz; LESS THAN $180 \Omega$ AT 3.6 MHz .

LC OSCILLATOR MODE


EACH C ShOULD BE APPROXIMATELY 20pF, INCLUDING STRAY CAPACITANCE.

DRIVING FROM EXTERNAL SOURCE


FOR THE 8049, XTAL1 MUST BE HIGH $35-65 \%$ OF THE PERIOD AND XTAL2 MUST BE HIGH $35-65 \%$ OF THE PERIOD.

RISE AND FALL TIMES MUST NOT EXCEED 20 ns .

## 80C49/80C39 <br> CHMOS SINGLE-COMPONENT 8-BIT MICROCOMPUTER

## 80C49 Low Power Mask Programmable ROM <br> - 80C39 Low Power, CPU only

## ■ Pin-to-pin compatible with Intel's 8049H/8039HL

## - $1.36 \mu \mathrm{sec}$ Instruction Cycle. All instructions 1 or 2 cycles

## - Ability to maintain operation during AC power line interruptions

## - Exit Idle mode with an external or internal interrupt signal

- Battery Operation
- 3 power consumption selections —Normal Operation:

15 mA @ 11 MHz @ 6V
-Idle Mode: $500 \mu \mathrm{~A}$ @ 11 MHz @ 6V
-Power down: $10 \mu \mathrm{~A}$ @ 2.0V
■ 11 MHz , TTL compatible operation; $V_{C C}=5 V \pm 10 \%$
CMOS compatible operation;
$V_{C C}=5 V \pm 20 \%$

Intel's 80C49/80C39 are low power, CHMOS versions of the popular MCS-48 HMOS family members. CHMOS is a technology built on HMOS II and features high resistivity $P$ substrate, diffused $N$ well, and scaled $N$ and $P$ channel devices. The 80C49/80C39 have been designed to provide low power consumption and high performance.

The 80 C 49 contains a $2 \mathrm{~K} \times 8$ program memory, a $128 \times 8$ RAM data memory, $27 \mathrm{I} / \mathrm{O}$ lines, and an 8 -bit timer/counter in addition to an on-board oscillator and clock circuits. For systems that require extra capability, the 80C49 can be expanded using CMOS external memories and MCS-80 and MCS-85 peripherals. The 80 C 39 is the equivalent of the 80 C 49 without program memory on-board.

The CHMOS design of the 80C49 opens new application areas that require battery operation, low power standby, wide voltage range, and the ability to maintain operation during AC power line interruptions. These applications include portable and hand-held instruments, telecommunications, consumer, and automotive.


Figure 1.
Block Diagram


Figure 2.
Logic Symbol


Figure 3.
Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Function | Symbol | Pin No. | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{S S}$ | 20 | Circuit GND potential | $\overline{\mathrm{RD}}$ | 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) |
| VDD | 26 | Low power standby pin |  |  |  |
| $V_{C C}$ | 40 | Main power supply; +5 V during operation. |  |  |  |
| PROG | 25 | Output strobe for 8243 I/O expander. |  |  |  |
| P10-P17 Port 1 | 27-34 | 8-bit quasi-bidirectional port. | RESET | 4 | Input which is used to initialize the processor. (Active low) (Non TTL $V_{I H}$ ) |
| P20-P27 Port 2 | 21-24 | 8-bit quasi-bidirectional port. | $\overline{W R}$ | . 10 | Output strobe during a bus write. (Active low) |
|  | 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. |
| $\begin{aligned} & \text { DBO-DB7 } \\ & \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. |  |  | The negative edge of ALE strobes address into external data and program memory. <br> Program store enable. This out- |
|  |  | Contains the 8 low order program counter bits during an |  | 9 | Program store enable. This output occurs only during a fetch to external program memory. <br> (Active low) |
|  |  | and receives the addressed instruction under the control of PSEN. Also contains the address and data during an external RAM | $\overline{\text { SS }}$ | 5 | Single step input can be used in conjunction with ALE to "single step" the processor through each instruction. (Active low) |
|  |  | 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 for emulation and debug, and essential for testing and program verification. (Active high) |
| TO | 1 | Input pin testable using the conditional transfer instructions JTO and JNTO. TO can be designated as a clock output using ENTO CLK instruction. |  |  |  |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. | XTAL1 XTAL2 | 2 3 | One side of crystal input for internal oscillator. Also input for external source. (Non TTL $\mathrm{V}_{1 \mathrm{H}}$ ) Other side of crystal input. |
| $\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) |  |  |  |

## IDLE MODE DESCRIPTION

The 80C49, when placed into Idle mode, keeps the oscillator, the internal timer and the external interrupt and counter pins functioning and maintains the internal register and RAM status.
To place the 80C49 in Idle mode, a command instruction (op code 01H) is executed. To terminate Idle mode, interrupts must be enabled and an interrupt signal generated. There are two interrupt sources that can restore normal operation. One is an external signal applied to the interrupt pin. The other is from the overflow of the timer/counter. When either interrupt is invoked the CPU is taken out of Idle mode and vectors to the interrupt's service routine address. A reset signal will also take the processor out of Idle mode. Along with the Idle mode, the standard MCS-48 power-down mode is still maintained.

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Registers |  |  |  |
| :---: | :---: | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |
| Branch |  |  |  |
| Mnemonic | Description | Bytes | Cycles |
| JMP addr | Jump unconditional | 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 |
| JNTO addr | Jump on TO $=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 F0 $=1$ | 2 | 2 |
| JF1 addr | Jump on F1 = 1 | 2 | 2 |
| JTF addr | Jump on timer flag | 2 | 2 |
| JN1 addr | Jump on INT = 0 | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |
| Flags |  |  |  |
| Mnemonic | Deseription |  |  |
| CLR C | Clear carry |  |  |
| 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 |


| Data Moves |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
| XCH A, @R | Exchange A and data memory | 1 | 1 |
| XCHD A, @R | Exchange nibble of A and | 1 | 1 |
|  | register |  |  |
| 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, @ | Move to A from page 3 | 1 | 2 |


| Timer/Counter |  |  |  |
| :--- | :--- | :---: | :---: |
| Minemonic | Description | Bytes Cycles |  |
| 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 TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |


| Control |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | 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 |
| ENT 0 CLK | Enable clock output on T0 | 1 | 1 |
|  |  |  |  |
| Mnemonic | Description | Bytes Cycles |  |
| NOP | No operation | 1 | 1 |
| IDL | Select Idle operation | 1 | 1 |

## 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
Power Dissipation ................................. 1.5 Watt
*NOTICE: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 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}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| $V_{\text {IL }}$ | Input Low Voltage <br> (All Except RESET, X1, X2) | -. 5 |  | . 8 | V |  |
| VIL1 | Input Low Voltage (RESET, X1, X2) | -. 5 |  | . 6 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\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 | $1 \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}^{\text {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{I}^{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{I}^{\prime} \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{VOH}_{1}$ | Output High Voltage <br> ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}^{\prime}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | v | $\mathrm{IOH}^{\prime}=-40 \mu \mathrm{~A}$ |
| ${ }_{\text {L1 }}$ | Input Leakage Current ( $\mathrm{T} 1, \overline{\mathrm{NTT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ${ }^{\text {LIII }}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{S S}$ ) |  |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| 'Lo | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IDD | $\mathrm{V}_{\text {DD }}$ Supply Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {DD }}=2.0 \mathrm{~V}$ |
| ${ }^{\text {I CC }}$ | Supply Current |  |  | $\begin{aligned} & \hline 15 \\ & 8.5 \\ & 1.5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | $\begin{aligned} & f=11 \mathrm{MHz} \\ & f=6 \mathrm{MHz} \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| IIDLE | Idle Mode Current |  |  | $\begin{gathered} 500 \\ 300 \\ 60 \\ \hline \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ $\mu \mathrm{A}$ | $\begin{aligned} & f=11 \mathrm{MHz} \\ & f=6 \mathrm{MHz} \\ & f=1 \mathrm{MHz} \end{aligned}$ |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=\mathrm{OV}$ )

| Symbol | Parameter | $f(t c r)$ | 11 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| $t_{\text {LL }}$ | ALE Pulse Width | 7/30 tey ${ }^{-170}$ | 150 |  | ns |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | $1 / 5 \mathrm{t} \mathrm{CY}-110$ | 160 |  | ns |  |
| ${ }_{\text {t }}$ A | Addr Hold from ALE | 1/15 t $\mathrm{CY}^{-40}$ | 50 |  | ns |  |
| ${ }^{\text {t }} \mathrm{C}$ C1 | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 ${ }^{\text {t }} \mathrm{CY}$-200 | 480 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 ${ }^{\text {t }} \mathrm{CY} \mathrm{C}^{-200}$ | 350 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup before $\overline{\mathrm{WR}} \quad \cdots$ | 13/30 t $\mathrm{Cr}^{-200}$ | 390 |  | ns |  |
| ${ }^{t}$ WD | Data Hold after $\overline{\text { WR }}$ | 1/15 ${ }_{\text {t } \mathrm{C} Y}-50$ | 40 |  | ns | (Note 2) |
| ${ }^{\text {t }}$ DR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | 1/10 ter ${ }^{-30}$ | 0 | 110 | ns |  |
| ${ }^{\text {t R }}$ 1 1 | $\overline{\mathrm{RD}}$ to Data in | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-200}$ |  | 350 | ns |  |
| ${ }^{\text {t RD2 }}$ | $\overline{\text { PSEN }}$ to Data in | $3 / 10{ }^{\text {t }}$ CY -200 |  | 210 | ns |  |
| ${ }^{t}$ AW | Addr Setup to $\overline{W R}$ | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{t}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 t $\mathrm{CY}^{-250}$ |  | 800 | ns |  |
| ${ }^{\text {t }}$ AD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5 \mathrm{t}^{\text {CY }}{ }^{-250}$ |  | 570 | ns | . |
| ${ }^{\text {AFCC1 }}$ | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15{ }^{\text {t }} \mathrm{CY}^{-40}$ | 140 |  | ns |  |
| ${ }^{\text {t }}$ AFC2 | Addr Float to $\overline{\text { PSEN }}$ | $1 / 30 \mathrm{t}_{\mathrm{CY}}-40$ | 10 | $\because$ | ns |  |
| ${ }^{\text {t LAFC1 }}$ | ALE to Control, ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5 \mathrm{t}^{\text {CY }}{ }^{-75}$ | 200 |  | ns |  |
| ${ }^{\text {L LAFC2 }}$ | ALE to Control ( $\overline{\text { PSEN }}$ ) | $1 / 10{ }^{\mathrm{C}_{\mathrm{CY}}-75}$ | 60 |  | ns |  |
| ${ }^{t} \mathrm{CA1}$ | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15{ }^{\text {t }} \mathrm{CY}^{-40}$ | 50 |  | ns |  |
| ${ }^{t}$ CA2 | Control to ALE ( $\overline{\text { PSEN }}$ ) | $4 / 15{ }^{\text {t }} \mathrm{CY}^{-40}$ | 320 |  | ns |  |
| ${ }^{t} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 $\overline{\mathrm{t} \overline{\mathrm{CY}}-80}$ | 100 |  | ns |  |
| ${ }^{\text {P }}$ PC | Port Control Hold to $\overline{\text { PROG }}$ | $4 / 15{ }^{\text {t }} \mathrm{CY}^{-200}$ | 160 |  | ns |  |
| $t_{\text {PR }}$ | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy -120 |  | 700 | ns |  |
| ${ }^{\text {t PF }}$ | Input Data Hold from $\overline{\text { PROG }}$ | $1 / 10{ }^{t} \mathrm{CY}$ | 0 | 140 | ns |  |
| ${ }^{t}$ DP | Output Data Setup | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t }}$ PD | Output Data Hold | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-50}$ | 90 |  | ns | ; ". |
| ${ }^{\text {t }}$ PP | $\overline{\text { PROG }}$ Pulse Width | $7 / 10{ }^{\text {t }} \mathrm{CY}^{-250}$ | 700 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | $4 / 15 \mathrm{t}^{\text {CY }}{ }^{-200}$ | 160 |  | ns |  |
| ${ }_{\text {LPP }}$ | Port 2. 1/O Hold to ALE | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-100}$ | 40 |  | ns |  |
| ${ }^{\text {t P }}$ V | Port Output from ALE | $3 / 10{ }^{\text {CY }}{ }^{+100}$ |  | 510 | ns | * |
| ${ }^{t} \mathrm{CY}$ | Cycle Time | 1/( ${ }^{\text {¢ }}$ (TAL $\times 15$ ) | 1.36 |  | $\mu \mathrm{s}$ |  |
| $\mathrm{t}_{0}$ PRR | T0 Rep Rate | $3 / 15{ }^{\text {t }} \mathrm{CY}$ | 270 |  | ns |  |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF}$ BUS Outputs CL $=150 \mathrm{pF}$
2. BUS High Impedance Load 20pF
3. Interrupt pin must remain low for at least $3 \mathrm{t}_{\mathrm{cy}}$ to ensure proper operation.

## WAVEFORMS



Instruction Fetch From External Program Memory


Write to External Data Memory


Read From External Data Memory

## PORT 2 EXPANDER TIMING



## I/O PORT TIMING



# 8749H/8749H-8/8039H/8039H-8 HMOS SINGLE-CHIP EPROM MICROCOMPUTER 

8749H 11MHz User Programmable EPROM<br>- 8749H-8 6MHz User Programmable EPROM<br>- 8039H 11MHz CPU Only with RAM and I/O<br>- 8039H-8 6MHz CPU Only with RAM and I/O

- 8-BIT CPU, EPROM, RAM, I/O in Single Package
- High Performance HMOS
- $1.4 \mu \mathrm{sec}$ and $2.5 \mu \mathrm{sec}$ Cycle Versions All Instructions 1 or 2 Cycles.
- Over 90 instructions: 70\% Single Byte
- Compatible with 8080/8085 Series Peripherals

2K x 8 EPROM
$128 \times 8$ RAM
27 I/O Lines

## Interval Timer/Event Counter

Easily Expandable Memory and I/O
Two Single Level Interrupts

The Intel ${ }^{(8749 H} / 8749 \mathrm{H}-8$ are totally self-sufficient, 8 -bit parallel computers fabricated on single silicon chips using Intel's advanced N -channel silicon gate HMOS process.

The $8749 \mathrm{H} / 8749 \mathrm{H}-8$ contains on-chip a 2 K X 8 UV-erasable, user-programmable program memory, a $128 \times 8$ RAM data memory, 27 I/O lines, 2 interrupt sources, and an 8-bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability the $8749 \mathrm{H} / 8749 \mathrm{H}-8$ can be expanded using standard memories and MCS-80®/MCS-85® peripherals. The 8039 H is the equivalent of the $8749 \mathrm{H} /$ $8749 \mathrm{H}-8 / 8049 \mathrm{H}$ without program memory and can be used with external ROM and RAM.
To reduce development problems to a minimum and provide maximum flexibility, three interchangeable pin-compatible versions of this single component microcomputer exist: the 8749 H with user-programmable and erasable EPROM program memory, the 8049 H with factory-programmed mask ROM program memory for low cost, high volume production, and the 8039 H without program memory for use with external program memories.
These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have 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.


## Table 1. Pin Description

| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| $V_{s s}$ | 20 | Circuit GND Potential |
| VDD | 26 | Programming power supply; +20V during program, +5 V during operation. |
| V cc | 40 | Main power supply; +5 V during operation and programming. |
| PROG | 25 | Program pulse ( +18 V ) input pin during 8749 H programming. <br> Output strobe for 8243 I/O expander. |
| $\begin{aligned} & \text { P10-P17 } \\ & \text { Port } 1 \end{aligned}$ | 27-34 | 8-bit quasi-bidirectional port. |
| P20-P27 | 21-24 | 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 I/O expander bus for 8243. |
| $\begin{gathered} \mathrm{DB}_{0}-\mathrm{DB}_{7} \\ \mathrm{BUS} \end{gathered}$ | 12-19 | True bidirectional port which can be written or read synchronously using the $\overline{R D}, \overline{W R}$ 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{R D}$, and $\overline{W R}$. |
| T0 | 1 | Input piri 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, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. |
| $\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) |


| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| $\overline{\mathrm{RD}}$ | 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) |
| $\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 $\mathrm{V}_{\mathrm{IH}}$ ) |
| $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) <br> 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. <br> 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 conjunction 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 for external source. (Non TTL $V_{1 H}$ ) |
| XTAL2 | 3 | Other side of crystal input. |

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | Increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JT0 addr | Jump on TO $=1$ | 2 | 2 |
| JNT0 addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=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 |
| JN1 addr | Jump on INT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |

## 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
*NOTICE: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 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}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| VIL | Input Low Voltage <br> (All Except RESET, X1, X2) | -. 5 |  | . 8 | V |  |
| VIL1 | Input Low Voltage ( $\overline{\mathrm{RESET}}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 6 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, RESET) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage ( $\mathrm{X} 1, \mathrm{X} 2, \overline{\text { RESET }}$ ) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage (BUS) |  |  | . 45 | V | $1 \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 (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| V OH | Output High Voltage (BUS) | 2.4 |  |  | V | ${ }^{1} \mathrm{OH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{PSEN}, \mathrm{ALE})$ | 2.4 |  |  | V | ${ }^{1} \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}$ |
| ${ }_{\text {L } 11}$ | Input Leakage Current (T1, $\overline{\mathrm{NT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| 'LI1 | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{S S}$ ) |  |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILO | Output Leakage Current (BUS, TO) <br> (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IDD | $V_{\text {DD }}$ Supply Current |  | 5 | 10 | mA |  |
| $\left\lvert\, \begin{aligned} & \text { IDD } \\ & \text { ICC } \end{aligned}\right.$ | Total Supply Current |  | 50 | 110 | mA |  |


A.C. CHARACTERISTICS $T_{A}=0^{\circ} \mathrm{C}$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=\mathrm{V}\right)$

| Symbol | Parameter | $f(t C y)$ | 11 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| ${ }_{t}$ LL | ALE Pulse Width | 7/30 ${ }_{\text {t }}^{\text {CY }}$-170 | 150 |  | ns |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | 1/5 t $\mathrm{CY}^{-110}$ | 160 |  | ns |  |
| ${ }_{\text {t }}$ LA | Addr Hold from ALE | 1/15 tCY ${ }^{-40}$ | 50 |  | ns |  |
| ${ }^{\text {t }} \mathrm{C} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 tey -200 | 480 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 t ${ }^{\text {CY }}{ }^{-200}$ | 350 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup before $\overline{W R}$ | 13/30.t. ${ }^{\text {CY -200 }}$ | 390 |  | ns |  |
| ${ }^{t}$ WD | Data Hold after $\overline{W R}$ | 1/15 tcy -50 | 40 |  | ns | (Note 2) |
| ${ }^{t}$ DR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\text { PSEN }}$ ) | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-30}$ | 0 | 110 | ns |  |
| ${ }^{\text {t RD1 }}$ | $\overline{\mathrm{RD}}$ to Data in | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-200}$ |  | 350 | ns |  |
| ${ }^{\text {t RD2 }}$ | $\overline{\text { PSEN }}$ to Data in | 3/10 t ${ }_{\text {CY }}-200$ |  | 210 | ns |  |
| ${ }^{\text {t }}$ WW | Addr Setup to $\overline{W R}$ | $2 / 5 \mathrm{t}^{\text {CY }}{ }^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t }}$ AD1, | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 $\mathrm{t}_{\mathrm{CY}}-250$ |  | 800 | ns |  |
| ${ }^{\text {t }}$ AD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5 \mathrm{t}_{\mathrm{CY}}{ }^{-250}$ |  | 570 | ns |  |
| ${ }^{\text {t AFC1 }}$ | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 140 |  | ns |  |
| ${ }^{\text {taFC2 }}$ | Addr Float to $\overline{\text { PSEN }}$ | $1 / 30 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 10 |  | ns |  |
| ${ }^{\text {t LAFC1 }}$ | ALE to Control, ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5{ }^{\text {t }}{ }^{\text {CY }}{ }^{-75}$ | 200 |  | ns |  |
| ${ }^{\text {t LAFC2 }}$ | ALE to Control ( $\overline{\text { PSEN }}$ ) | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-75}$ | 60 |  | ns |  |
| ${ }^{\text {t }}$ CA1 | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 50 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CA} 2$ | Control to ALE ( $\overline{\text { PSEN }}$ ) | $4 / 15 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 320 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 toy - 80 | 100 |  | ns |  |
| ${ }^{\text {t PC }}$ | Port Control Hold to $\overline{\text { PROG }}$ | 4/15 ${ }^{\text {c }} \mathrm{CY}^{-200}$ | 160 |  | ns |  |
| ${ }^{\text {tPR }}$ | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tç -120 |  | 700 | ns |  |
| $\mathrm{t}_{\mathrm{PF}}$ | Input Data Hold from $\overline{\text { PROG }}$ | ${ }^{1 / 10}{ }^{\text {t }} \mathrm{CY}$ | 0 | 140 | ns |  |
| ${ }^{t} \mathrm{DP}$ | Output Data Setup | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t PD }}$ | Output Data Hold | 1/10 ${ }^{\text {CY }}$-50 | 90 |  | ns |  |
| ${ }^{t} \mathrm{PP}$ | PROG Pulse Width | 7/10 ${ }^{\text {t }} \mathrm{CY}^{-250}$ | 700 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | 4/15 ${ }^{\text {c }} \mathrm{CY}^{-200}$ | 160 |  | ns | . |
| $t_{\text {LP }}$ | Port 2 I/O Hold to ALE | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-100}$ | 40 |  | ns |  |
| tPV | Port Output from ALE | $3 / 10{ }^{\text {t }}{ }^{\text {CY }}+100$ |  | 510 | ns | $\cdots$ |
| ${ }^{\mathrm{t}} \mathrm{CY}$ | Cycle Time | 1/(fXTAL $\times 15$ ) | 1.36 |  | $\mu \mathrm{s}$ | $\begin{array}{\|l\|} \hline 2.5 \mu \mathrm{~S} \mathrm{tCYMIN} \\ \text { FOR } 8749 \mathrm{H}-8 \\ \hline \end{array}$ |
| ${ }^{\text {t OPRRR }}$ | T0 Rep Rate | $3 / 15 \mathrm{t}_{\mathrm{CY}}$ | 270 | , | ns | - |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF}$ BUS Outputs CL $=150 \mathrm{pF}$
When driven by an ext. clock, AC specs are based on $50 \%$ duty cycles.
2. BUS High Impedance Load 20pF
,
$\qquad$

The 8749H exhibits some sensitivity to light.
The RAM storage area can be altered when exposed to light. When operating the 8749 H , the window must be covered with an opaque material.

## WAVEFORMS



## PORT 2 EXPANDER TIMING



## WAVEFORMS



The 8749 H EPROM can be programmed by:
Universal PROM Programmer (UPP series) peri-
pheral of the Intellec® Development System with a
UPP-848 Personality Card and a UPP-549 adapter card.

## CRYSTAL OSCILLATOR MODE


$\mathrm{C} 1=5 \mathrm{pF} \pm 1 / 2 \mathrm{pF}+\mathrm{STRAY}<5 \mathrm{pF}$
$\mathrm{C} 2=\mathrm{CRYSTAL} \pm$ STRAY $<8 \mathrm{pF}$
$\mathrm{C} 3=20 \mathrm{pF} \pm 1 \mathrm{pF}+$ STRAY $<5 \mathrm{p}$
CRYSTAL SERIES RESISTANCE SHOULD BE LESS THAN $75 \Omega$ AT 6 MHz ; LESS THAN $180 \Omega$ AT 3.6 MHz .

## LC OSCILLATOR MODE



EACH C SHOULD BE APPROXIMATELY 20 pF, INCLUDING STRAY CAPACITANCE.

## DRIVING FROM EXTERNAL SOURCE



FOR XTAL 1 AND XTAL 2 DEFINE "HIGH" AS VOLTAGES ABOVE 1.6V AND "LOW" ASVOLTAGES BELOW 1.6V. THE DUTY CYCLE REQUIREMENTS FOR EXTERNALLY DRIVING XTAL 1 AND XTAL 2 USING THE CIRCUIT SHOWN ABOVE ARE AS FOLLOWS

FOR THE 8749H, XTAL 1 MUST BE HIGH 45-50\% OF THE PERIOD AND XTAL 2 MUST BE HIGH 50-55\% OF THE PERIOD. RISE AND FALL TIMES MUST NOT EXCEED 20 ns

## PROGRAMMING, VERIFYING, AND ERASING THE 8749H 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 |
| :--- | :--- |
| $\frac{\text { XTAL 1 }}{\text { Reset }}$ | Clock Input (1 to 3MHz) |
| Test 0 | Initialization and Address Latching |
| Selection of Program or Verify Mode |  |
| EA | Activation of Program/Verify Modes |
| BUS | Address and Data Input |
| P20-22 | Data Output During Verify |
| Address Input |  |
| VDD | Programming Power Supply |
| PROG | Program Pulse Input |

WARNING:
An attempt to program a missocketed 8749 H 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. $V_{D D}=5 \mathrm{~V}$, Clock applied or internal oscillator operating, RESET $=0 \mathrm{~V}, \mathrm{TEST} 0=5 \mathrm{~V}, \mathrm{EA}=5 \mathrm{~V}$, BUS and PROG floating. P10 and P11 must be tied to ground.
2. Insert 8749 H in programming socket.
3. TEST $0=O V$ (select program mode)
4. $E A=18 \mathrm{~V}$ (activate program mode)
5. Address applied to BUS and P20-22
6. $\overline{\operatorname{RESET}}=5 \mathrm{~V}$ (latch address)
7. Data applied to BUS
8. $\mathrm{V}_{\mathrm{DD}}=20 \mathrm{~V}$ (programming power)
9. $\mathrm{PROG}=0 \mathrm{~V}$ followed by one 50 ms pulse to 18 V
10. $V_{D D}=5 \mathrm{~V}$
11. TEST $0=5 \mathrm{~V}$ (verify mode)
12. Read and verify data on BUS
13. $\operatorname{TEST} 0=0 \mathrm{~V}$
14. $\overline{\operatorname{RESET}}=\mathrm{OV}$ and repeat from step 5
15. Programmer should be at conditions of step 1 when 8749 H is removed from socket.
A.C. TIMING 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}}=20 \mathrm{~V} \pm 1 \mathrm{~V}$ )

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {Aw }}$ | Address Setup Time to $\overline{\text { RESET }}$ | $4 \mathrm{tcr}_{\text {cr }}$ |  |  |  |
| twa | Address Hold Time After RESET 1 | $4 \mathrm{tcr}_{\text {cr }}$ |  |  |  |
| tow | Data in Setup Time to PROG 1 | $4 t_{c r}$ |  |  |  |
| two | Data in Hold Time After PROG ! | 4 tcr |  |  |  |
| $\mathrm{t}_{\text {PH }}$ | RESET Hold Time to Verify | 4 tcr |  |  |  |
| tvodw | $V_{D D}$ | 4 tcr |  |  |  |
| tvodh | VDD Hold Time After PROG ! | 0 |  |  |  |
| tpw | Program Pulse Width | 50 | 60 | mS |  |
| $t_{\text {tw }}$ | Test 0 Setup Time for Program Mode | $4 t_{\text {cr }}$ |  |  |  |
| $t_{\text {wi }}$ | Test 0 Hold Time After Program Mode | $4 t_{\text {cr }}$ |  |  |  |
| too | Test 0 to Data Out Delay |  | 4 tcr |  |  |
| tww | $\overline{\text { RESET Pulse Width to Latch Address }}$ | 4tcr |  |  |  |
| $\mathrm{t}_{\mathrm{r}, \mathrm{t}_{\text {t }}}$ | $V_{D D}$ and PROG Rise and Fall Times | 0.5 | 2.0 | $\mu \mathrm{s}$ |  |
| tcr | CPU Operation Cycle Time | 5.0 |  | $\mu \mathrm{s}$ |  |
| $t_{\text {RE }}$ | $\overline{\mathrm{RESET}}$ Setup Time before EAI | 4 tcr |  |  |  |

NOTE: If Test 0 is high too can be triggered by $\overline{\text { RESET } ~}$ i
D.C. SPECIFICATION FOR PROGRAMMING $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{D D}=20 \mathrm{~V} \pm .5 \mathrm{~V}\right)$

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $V_{D O H}$ | $V_{D D}$ Program Voltage High Level | 19.5 | 20.5 | V |  |
| $V_{D D L}$ | V $_{\text {DD }}$ Voltage Low Level | 4.75 | 5.25 | V |  |
| $\mathrm{~V}_{P H}$ | PROG Program Voltage High Level | 17.5 | 18.5 | V |  |
| $\mathrm{~V}_{P L}$ | PROG Voltage Low Level |  | 0.2 | V |  |
| $\mathrm{~V}_{\text {EAH }}$ | EA Program or Verify Voltage High Level | 17.5 | 18.5 | V |  |
| $\mathrm{I}_{\mathrm{DD}}$ | V $_{\text {DD }}$ High Voltage Supply Current |  | 30.0 | mA |  |
| $\mathrm{I}_{P R O G}$ | PROG High Voltage Supply Current |  | 16.0 | mA |  |
| $\mathrm{I}_{\text {EA }}$ | EA High Voltage Supply Current |  | 1.0 | mA |  |

# 8243 <br> MCS-48® INPUT/OUTPUT EXPANDER 

## Low Cost <br> Simple Interface to MCS-48® <br> 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 $1 / 0$ expansion for the MCS $-48{ }^{\circledR}$ 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.



Figure 2. 8243
Pin Configuration

Figure 1. 8243
Block Diagram

Table 1. Pin Description

| Symbol | Pin No. | Function |
| :--- | :---: | :--- |
| PROG | 7 | Clock Input. A high to low transi- <br> tion on PROG signifies that ad- <br> dress and control are available on <br> P20-P23, and a low to high transi- <br> tion signifies that data is available <br> on P20-P23. <br> Chip Select Input. A high on CS <br> inhibits any change of output or <br> internal status. <br> Four (4) bit bi-directional port con- |
| $\overline{\text { CS }}$ |  | $11-8$ |
| P20-P23 | tains the address and control bits <br> on a high to low transition of <br> PROG. During a low to high tran- <br> sition contains the data for a sel- <br> ected output port if a write opera- <br> tion, or the data from a selected <br> port before the low to high transi- <br> tion if a read operation. |  |
| GND | 12 | 0 volt supply. <br> Four (4) bit bi-directional I/O ports. |
| P40-P43 <br> P50-P53 | $1,23-21$ |  |
| P60-P63 | $20-17$ |  |
| P70-P73 | $13-16$ | May be programmed to be input <br> (during read), low impedance <br> latched output (after write), or a tri- <br> state (after read). Data on pins <br> P20-P23 may be directly written, <br> ANDed or ORed with previous <br> data. <br> +5 volt supply. |

## FUNCTIONAL DESCRIPTION

## 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 4-7. 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 VCC drops below 1 V .

| P21 | P20 | Address <br> Code | P23 | P22 | Instruction <br> 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.

8243

## 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
*NOTICE: 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 <br> $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ <br> 10\%

| Symbol | Parameter | Min | Typ | Max | Units | Test <br> Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| VIH | Input High Voltage | 2.0 |  | VCC +0.5 | V |  |
| VOL1 | Output Low Voltage Ports 4-7 |  |  | 0.45 | V | IOL $=4.5 \mathrm{~mA}^{*}$ |
| VOL2 | Output Low Voltage Port 7 |  |  | 1 | V | $\mathrm{IOL}=20 \mathrm{~mA}$ |
| VOH1 | Output High Voltage Ports 4-7 | 2.4 |  |  | V | IOH $=240 \mu \mathrm{~A}$ |
| IIL1 | Input Leakage Ports 4-7 | -10 |  | 20 | $\mu \mathrm{~A}$ | Vin $=$ VCC to OV |
| IIL2 | Input Leakage Port 2, CS, PROG | -10 |  | 10 | $\mu \mathrm{~A}$ | Vin $=$ VCC to OV |
| VOL3 | Output Low Voltage Port 2 |  |  | 45 | V | IOL $=0.6 \mathrm{~mA}$ |
| ICC | VCC Supply Current |  | 10 | 20 | mA |  |
| VOH2 | Output Voltage Port 2 | 2.4 |  |  |  | IOH $=100 \mu \mathrm{~A}$ |
| IOL | Sum of all IOL from 16 Outputs |  |  | 72 | mA | 4.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} \quad 10 \%$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| tA | Code Valid Before PROG | 100 |  | ns | 80 pF Load |
| tB | Code Valid After PROG | 60 |  | ns | 20 pF Load |
| t C | Data Valid Before PROG | 200 |  | ns | 80 pF Load |
| tD | Data Valid After PROG | 20 |  | ns | 20 pF Load |
| tH | Floating After PROG | 0 | 150 | ns | 20 pF Load |
| tK | PROG Negative Pulse Width | 700 |  | ns |  |
| tcs | CS Valid Before/After PROG | 50 |  | ns |  |
| tPO | Ports 4-7 Valid After PROG |  | 700 | ns | 100 pF Load |
| tLP1 | Ports 4-7 Valid Before/After PROG | 100 |  | ns |  |
| tACC | Port 2 Valid After PROG |  | 650 | ns | 80 pF Load |



WAVEFORMS



## Figure 3

## Sink Capability

The 8243 can sink $5 \mathrm{~mA} @ .45 \mathrm{~V}$ on each of its $16 \mathrm{I} / \mathrm{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 IOL 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?

$$
\begin{aligned}
& \mathrm{IOL}=5 \times 1.6 \mathrm{~mA}=8 \mathrm{~mA} \\
& \epsilon \mathrm{IOL}=60 \mathrm{~mA} \text { from curve } \\
& \text { \# pins }=60 \mathrm{~mA} \div 8 \mathrm{~mA} / \mathrm{pin}=7.5=7
\end{aligned}
$$

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 mA @ 1V (port 7 only)
8 loads-4 mA @.45V
6 loads-3.2 mA @.45V Is this within the specified limits?
$\epsilon \mathrm{IOL}=(2 \times 20)+(8 \times 4)+(6 \times 3.2)=91.2 \mathrm{~mA}$. From the curve: for $1 O L=4 \mathrm{~mA}, \epsilon \mathrm{IOL} \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 $\epsilon \mathrm{IOL}$, it is the largest current required @ . 45 V which determines the maximum allowable $\epsilon \mathrm{IOL}$.

NOTE: A10 to $50 \mathrm{~K} \Omega$ pullup resistor to +5 V should be added to 8243 outputs when driving to 5 V CMOS directly.


Figure 4. Expander Interface


Figure 5. Output Expander Timing


Figure 6. Using Multiple 8243's

# HMOS SINGLE COMPONENT 8-BIT MICROCOMPUTER 

## - 8050H 11MHz Mask Programmable ROM <br> - 8040H 11MHz CPU Only with Power Down Mode

- 8-Bit CPU, ROM, RAM, I/O in Single Package

■ High Performance HMOS

- Reduced Power Consumption
- $1.36 \mu \mathrm{sec}$ Cycle Version All Instructions 1 or 2 Cycles.

\author{

- Over 90 Instructions: 70\% Single Byte
}
- 4K x 8 ROM
$256 \times 8$ RAM 27 I/O Lines
- Interval Timer/Event Counter
- Easily Expandable Memory and I/O
- Compatlble with 8080/8085 Series Peripherals
- Two Single Level Interrupts

The Intel 8050 H is a totally self-sufficient, 8-bit parallel computer fabricated on single silicon chips using Intel's advanced N -channel silicon gate HMOS process.
The 8050 H contains a $4 \mathrm{~K} \times 8$ non-volatile program read-only memory, a $256 \times 8$ RAM data memory, $27 \mathrm{I} / \mathrm{O}$ lines, and an 8-bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability, the $8050 \mathrm{H} / 8040 \mathrm{H}$ can be expanded using MCS-80 $/ \mathrm{MCS}-85{ }^{\circ}$ peripherals. The 8040 H is the equivalent of the 8050 H without program memory and can be used with external ROM and RAM.
To minimize development problems and provide maximum flexibility, a logically and functionally pin-compatible version of the 8050 H with UV-erasable user-programmable EPROM program memory will be available. The 8750 H emulates the 8050 H to 11 MHz with minor differences.
These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have 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.


Figure 1.
Block Diagram

Figure 2. Logic Symbol


Figure 3.
Pin Configuration

[^18]Table 1. Pin Description

| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| $\mathrm{V}_{\text {SS }}$ | 20 | Circuit GND potential |
| VDD | 26 | Low power standby pin |
| $V_{C C}$ | 40 | Main power supply; +5 V during operation. |
| PROG | 25 | Output strobe for 8243 I/O expander. |
| P10-P17 <br> Port 1 | 27-34 | 8-bit quasi-bidirectional port. |
| P20-P27 <br> Port 2 | $\begin{aligned} & 21-24 \\ & 35-38 \end{aligned}$ | 8-bit quasi-bidirectional port. 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 . |
| DB0-DB7 BUS | 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 $\overline{\text { 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}$. |
| 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. |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the STRT CNT instruction. |
| $\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) |


| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| $\overline{\mathrm{RD}}$ | 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) |
| $\overline{\text { RESET }}$ | 4 | Input which is used to initialize the processor. (Active low) (Non TTL $V_{I H}$ ) |
| $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) <br> 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. <br> 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{\mathbf{S S}}{ }^{*}$ | 5 | Single step input can be used in conjunction 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 for external source. (Non TTL $\mathrm{V}_{\mathrm{IH}}$ ) |
| XTAL2 | 3 | Other side of crystal input. |

*Note: Unused input pins should be connected to $\mathrm{V}_{\mathrm{CC}}$ or $\mathrm{V}_{\mathrm{SS}}$ as appropriate (e.g., $\overline{\mathrm{SS}}$ tied to $\mathrm{V}_{\mathrm{CC}}$, EA tied to $\mathrm{V}_{\mathrm{DD}}$ ).

Table 2. Instruction Set

| Accumulator |  |  |  |
| :--- | :--- | :---: | :--- |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |


| Input/Output |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |


| Registers |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| INC R | Increment register | 1 | 1 |
| INC @R | increment data memory | 1 | 1 |
| DEC R | Decrement register | 1 | 1 |


| Branch |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| 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 |
| JNTO addr | Jump on TO $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=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 |
| JN1 addr | Jump on iNT $=0$ | 2 | 2 |
| JBb addr | Jump on accumulator bit | 2 | 2 |


| Subroutine |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes | Cycles |
| CALL addr | Jump to subroutine | 2 | 2 |
| RETR | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |


| Flags |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| CLR C | Clear carry | 1 | 1 |
| CPL C | Complement carry | 1 | 1 |
| CLR F0 | 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 |


| Data Moves |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 |
| XCH A, @R | Exchange A and data memory | 1 | 1 |
| XCHD A, @R | Exchange nibble of A and | 1 | 1 |
|  | register |  |  |
| 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, @ | Move to A from page 3 | 1 | 2 |


| Timer/Counter |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| 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 TCNT1 | Enable timer/counter interrupt | 1 | 1 |
| DIS TCNT1 | Disable timer/counter interrupt | 1 | 1 |


| Control |  |  |  |
| :--- | :--- | :---: | :---: |
| Mnemonic | Description | Bytes Cycles |  |
| EN 1 | Enable external interrupt | 1 | 1 |
| DIS 1 | Disable external interrupt | 1 | 1 |
| SEL RB0 | 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 TO | 1 | 1 |


| Mnemonic | Description | Bytes Cycles |  |
| :--- | :--- | :---: | :---: |
| NOP | No operation | 1 | 1 |

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
*NOTICE: 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 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}}=\mathrm{V}_{\mathrm{DD}}=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 |  | . 8 | V |  |
| $\mathrm{V}_{\text {IL } 1}$ | Input Low Voltage (RESET, X1, X2) | -. 5 |  | . 6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.0 |  | $\mathrm{v}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage ( $\mathrm{X} 1, \mathrm{X} 2, \overline{\mathrm{RESET}}$ ) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage (BUS) |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage <br> ( $\overline{R D}, \overline{W R}, \overline{P S E N}, ~ A L E)$ |  |  | . 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 (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage (BUS) | 2.4 |  |  | V | ${ }^{\mathrm{OHH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage <br> ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ | 2.4 |  |  | V | ${ }^{\prime} \mathrm{OH}=-100 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage <br> (All Other Outputs) | 2.4 |  |  | V | $\mathrm{I}^{\mathrm{OH}}=-40 \mu \mathrm{~A}$ |
| ${ }_{\text {L } 11}$ | Input Leakage Current (T1, /(NT) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| ${ }_{\text {LII }}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{S S}$ ) |  |  | -500 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILo | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IDD | $V_{\text {DD }}$ Supply Current |  | 10 | 20 | mA |  |
| $\begin{aligned} & \mathrm{I}_{\mathrm{DD}} \\ & \mathrm{I} \mathrm{CC} \end{aligned}$ | Total Supply Current |  | 40 | 80 | mA |  |
| VDD | RAM Standby Voltage | 2.2 |  | $\mathrm{v}_{\mathrm{CC}}$ | V | Standby Mode, Reset $\leq \mathrm{V}_{\mathrm{IL} 1}$ |

( 50 mA

## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ 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} \text { ( (tcY) } \\ \text { (Note 4) } \end{gathered}$ | 11 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| ${ }_{\text {t }}$ LL | ALE Pulse Width | 7/30 tey ${ }^{\text {-170 }}$ | 150 |  | ns |  |
| ${ }^{t} A L$ | Addr Setup to ALE | 1/5 tcy -110 | 160 |  | ns |  |
| ${ }^{\text {t L }}$ A | Addr Hold from ALE | 1/15 t ${ }^{\text {CY }}{ }^{-40}$ | 50 |  | ns |  |
| ${ }^{t} \mathrm{CC} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 t ${ }^{\text {cy }}$-200 | 480 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 ${ }^{\text {t }} \mathrm{CY}{ }^{-200}$ | 350 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup before $\overline{W R}$ | 13/30 t $\mathrm{CY}^{-200}$ | 390 |  | ns |  |
| two | Data Hold after $\overline{W R}$ | 1/15 t' CY -50 | 40 |  | ns | (Note 2) |
| ${ }^{\text {t }}$ DR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | 1/10 t $\mathrm{CY}^{-30}$ | 0 | 110 | ns |  |
| ${ }^{\text {tr }}$ D1 | $\overline{\mathrm{RD}}$ to Data in | $2 / 5 \mathrm{t}^{\text {CY }}{ }^{-200}$ |  | 350 | ns |  |
| $t^{\text {R }}$ 2 2 | $\overline{\text { PSEN }}$ to Data in | $3 / 10 \mathrm{t}_{\mathrm{CY}}-200$ |  | 210 | ns |  |
| ${ }^{t}$ AW | Addr Setup to WR | $2 / 5{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{t} A D 1$ | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 t $\mathrm{CY}-250$ |  | 800 | ns |  |
| ${ }^{t} A D 2$ | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5 \mathrm{t}^{\text {CY }}$-250 |  | 570 | ns |  |
| ${ }^{t}$ AFC1 | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 140 |  | ns |  |
| ${ }^{\text {t }}$ AFC2 | Addr Float to PSEN | $1 / 30 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 10 |  | ns |  |
| tLAFC1 | ALE to Control, ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5{ }^{\text {t }} \mathrm{CY}^{-75}$ | 200 |  | ns |  |
| ${ }^{\text {t LAFC2 }}$ | ALE to Control ( $\overline{\text { PSEN }}$ ) | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-75}$ | 60 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CA1}$ | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 50 |  | ns |  |
| ${ }^{t}$ CA2 | Control to ALE ( $\overline{\text { PSEN }}$ ) | $4 / 15 \mathrm{t}^{\text {c }}{ }^{-40}$. | 320 |  | ns |  |
| ${ }^{t} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 tcy -80 | 100 |  | ns |  |
| ${ }^{\text {t PC }}$ | Port Control Hold to $\overline{\text { PROG }}$ | $4 / 15 \mathrm{t}^{\text {c }}{ }^{-200}$ | 160 |  | ns |  |
| ${ }^{t} \mathrm{PR}$ | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy-120 |  | 700 | ns |  |
| ${ }^{\text {t PF }}$ | Input Data Hold from $\overline{\text { PROG }}$ | ${ }^{1 / 10}{ }^{\text {t }} \mathrm{CY}$ | 0 | 140 | ns |  |
| ${ }^{t} \mathrm{DP}$ | Output Data Setup | $2 / 5 \mathrm{t}_{\mathrm{CY}}{ }^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t PD }}$ | Output Data Hold | 1/10 $\mathrm{t}_{\mathrm{CY}}{ }^{-50}$ | 90 |  | ns |  |
| ${ }^{\text {t }}$ PP | $\overline{\text { PROG Pulse Width }}$ | $7 / 10 \mathrm{t}_{\mathrm{CY}}-250$ | 700 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | $4 / 15 \mathrm{t}^{\text {CY }}{ }^{-200}$ | 160 |  | ns |  |
| ${ }^{\text {t }}$ LP | Port 2 I/O Hold to ALE | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-100}$ | 40 |  | ns |  |
| ${ }^{\text {t PV }}$ | Port Output from ALE | $3 / 10 \mathrm{t}_{\mathrm{CY}}+100$ |  | 510 | ns |  |
| ${ }^{t} \mathrm{C} Y$ | Cycle Time | 1/(15/f ${ }_{\text {XTAL }}$ ) | 1.36* |  | $\mu \mathrm{s}$ | (Note 3) |
| toprR | TO Rep Rate | $3 / 15{ }^{\text {t }} \mathrm{CY}$ | 270 |  | ns |  |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF} \quad$ 2. BUS High Impedance BUS Outputs CL $=150 \mathrm{pF}$
2. Interrupt pin must remain low for at least $3 \mathrm{t}_{\mathrm{cy}}$ to ensure proper operation.
3. $f\left(t_{c y}\right)$ assumes $50 \%$ duty cycle on X1 and X2.

## WAVEFORMS



PORT 2 EXPANDER TIMING


I/O PORT TIMING


## SUGGESTED CIRCUITS

## OSCILLATOR MODE



CRYSTAL SERIES RESISTANCE SHOULD BE LESS THAN $75 \Omega$ AT 6 MHz ; LESS THAN $180 \Omega$ AT 3.6 MHz .

LC OSCILLATOR MODE


EACH C SHOULD BE APPROXIMATELY 20pF, INCLUDING STRAY CAPACITANCE.

DRIVING FROM EXTERNAL SOURCE


FOR THE 8050H, XTAL1 MUST BE HIGH 35-65\% OF THE PERIOD AND XTAL2 MUST BE HIGH 35-65\% OF THE PERIOD.

RISE AND FALL TIMES MUST NOT EXCEED 2Ons. 8-BIT N-CHANNEL MICROPROCESSOR

## - 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 ${ }^{\circledR}$ 8080A is a complete 8-bit parallel central processing unit (CPU). It is fabricated on a single LSI chip using Intel's n-channel silicon gate MOS process. This offers the user a high performance solution to control and processing applications.

The 8080A contains 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 multi-processor operation.
NOTE:
The 8080A is functionally and electrically compatible with the Intel ${ }^{8} 8080$.


Figure 1. Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{A}_{15}-\mathrm{A}_{0}$ | 0 | Address Bus: The address bus provides the address to memory (up to 64 K 8 -bit words) or denotes the l/O device number for up to 256 input and 256 output devices. $A_{0}$ is the least significant address bit. |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 1/O | Data Bus: The data bus provides bi-directional communication betweeen 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 | 0 | Synchronizing Signal: The SYNC pin provides a signal to indicate the beginning of each machine cycle. |
| DBIN | 0 | 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 | I | 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 WAITstate for as long as the READY line is low. READY can also be used to single step the CPU. |
| WAIT | 0 | Wait: The WAIT signal acknowledges that the CPU is in a WAIT state. |
| $\overline{W R}$ | 0 | 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{\mathrm{WR}}=0$ ). |
| HOLD | 1 | 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 busses for the current machine cycle. It is recognized under the following conditions: <br> - the CPU is in the HALT state. <br> - the CPU is in the T2 or TW state and the READY signal is active. As a result of entering the HOLD state the CPU ADDRESS BUS $\left(\mathrm{A}_{15}-\mathrm{A}_{0}\right)$ and DATA BUS $\left(\mathrm{D}_{7}-\mathrm{D}_{0}\right)$ will be in their high impedance state. The CPU acknowledges its state with the HOLD ACKNOWLEDGE (HLDA) pin. |
| HLDA | 0 | Hold Acknowledge: The HLDA signal appears in response to the HOLD signal and indicates that the data and address bus will go to the high impedance state. The HLDA signal begins at: <br> - T3 for READ memory or input. <br> - The Clock Period following T3 for WRITE memory or OUTPUT operation. <br> In either case, the HLDA signal appears after the rising edge of $\phi_{2}$. |
| INTE | 0 | 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 | I | 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 ${ }^{1}$ | 1 | Reset: While the RESETsignal 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. |
| $\mathrm{V}_{\text {SS }}$ |  | Ground: Reference. |
| $V_{\text {DD }}$ |  | Power: $+12 \pm 5 \%$ Volts. |
| $\mathrm{V}_{\mathrm{CC}}$ |  | Power: $+5 \pm 5 \%$ Volts. |
| $V_{B B}$ |  | Power: $-5 \pm 5 \%$ Volts. |
| $\phi_{1}, \phi_{2}$ |  | Clock Phases: 2 externaHy supplied clock phases. (non TTL compatible) |

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Input or Output Voltages
With Respect to $V_{B B}$. . . . . . . . . . $\quad-0.3 V$ to +20 V
$\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{SS}}$ With Respect to $\mathrm{V}_{\mathrm{BB}} \quad-0.3 \mathrm{~V}$ to +20 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . 1.5W
*NOTICE: 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}_{D D}=+12 \mathrm{~V} \pm 5 \%$,

$$
V_{C C}=+5 \mathrm{~V} \pm 5 \%, V_{B B}=-5 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V} \text {; unless otherwise noted) }
$$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VILC | Clock Input Low Voltage | $\mathrm{V}_{\mathrm{SS}}$-1 |  | $\mathrm{V}_{\text {SS }}+0.8$ | V | $\begin{aligned} & \int-\mathrm{I}_{\mathrm{OL}}=1.9 \mathrm{~mA} \text { on all outputs, } \\ & \mathrm{IOH}_{\mathrm{OH}}=-150 \mu \mathrm{~A} . \end{aligned}$ |
| $\mathrm{V}_{\text {IHC }}$ | Clock Input High Voltage | 9.0 |  | $\mathrm{V}_{\mathrm{DD}}+1$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $\mathrm{V}_{\mathrm{SS}}-1$ |  | $\mathrm{V}_{\text {SS }}+0.8$ | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 3.3 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 3.7 |  |  | V |  |
| $\mathrm{I}_{\mathrm{DD}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{DD}}$ ) |  | 40 | 70 | mA | Operation$\mathrm{T}_{\mathrm{CY}}=.48 \mu \mathrm{sec}$ |
| $\mathrm{ICC}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{CC}}$ ) |  | 60 | 80 | mA |  |
| $\mathrm{I}_{\mathrm{BB}}(\mathrm{AV})$ | Avg. Power Supply Current ( $\mathrm{V}_{\mathrm{BB}}$ ) |  | . 01 | 1 | mA |  |
| $I_{\text {IL }}$ | Input Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \\ & \mathrm{v}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{CLOCK}} \leqslant \mathrm{~V}_{\mathrm{DD}} \end{aligned}$ |
| $I_{\text {CL }}$ | Clock Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ |  |
| $\mathrm{I}_{\mathrm{DL}}{ }^{[2]}$ | Data Bus Leakage in Input Mode |  |  | $\begin{aligned} & -100 \\ & -2.0 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{SS}}+0.8 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{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 $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V}\right)$

| 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 |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 10 | 20 | pf | Returned to $\mathrm{V}_{\mathrm{SS}}$ |

## NOTES:

1. The RESET signal must be active for a minimum of 3 clock cycles.
2. $\Delta I$ supply $/ \Delta T_{A}=-0.45 \% /{ }^{\circ} \mathrm{C}$.


Typical Supply Current vs. Temperature, Normalized ${ }^{[3]}$

8080A/8080A-1/8080A-2

## A.C. CHARACTERISTICS (8080A) $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ 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)



## A.C. TESTING LOAD CIRCUIT


$C_{L}=100 \mathrm{pF}$
$C_{L}$ INCLUDES JIG CAPACITANCE

## WAVEFORMS



NOTE:
Timing measurements are made at the following reference voltages: CLOCK "1" $=8.0 \mathrm{~V}$, $" 0 "=1.0 \mathrm{~V}$; INPUTS $" 1 "=3.3 \mathrm{~V},{ }^{\prime 0} 0=0.8 \mathrm{~V}$; OUTPUTS $" 1 "=2.0 \mathrm{~V}, " 0 "=0.8 \mathrm{~V}$.

WAVEFORMS (Continued)


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.
$t_{D H}=50 \mathrm{~ns}$ or $\mathrm{t}_{\mathrm{DF}}$, whichever is less.
2. $\mathrm{t}_{\mathrm{CY}}=\mathrm{t}_{\mathrm{D} 3}+\mathrm{t}_{\mathrm{r} \boldsymbol{2} 2}+\mathrm{t}_{\boldsymbol{\phi} 2}+\mathrm{t}_{\mathrm{f} \boldsymbol{2} 2}+\mathrm{t}_{\mathrm{D} 2}+\mathrm{t}_{\mathrm{r} \phi 1} \geqslant 480 \mathrm{~ns}(-1: 320$ $\mathrm{ns},-2: 380 \mathrm{~ns}$ ).

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

3. The following are relevant when interfacing the 8080A to devices having $\mathrm{V}_{\mathrm{IH}}=3.3 \mathrm{~V}$ :
a) Maximum output rise time from 8 V to $3.3 \mathrm{~V}=100 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}$
= SPEC.
b) Output delay when measured to $3.0 \mathrm{~V}=\mathrm{SPEC}+60 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}$
$=$ SPEC.
c) If $\mathrm{C}_{\mathrm{L}}=$ 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}_{\mathrm{SPEC}}$.
4. $\mathrm{t}_{\mathrm{AW}}=2 \mathrm{t}_{\mathrm{CY}}-\mathrm{t}_{\mathrm{D} 3}-\mathrm{t}_{\mathrm{r} \phi 2}-140 \mathrm{~ns}(-1: 110 \mathrm{~ns},-2: 130 \mathrm{~ns})$.
5. $t_{D W}=t_{C Y}-t_{D 3}-t_{r \phi 2}-170 \mathrm{~ns}(-1: 150 \mathrm{~ns},-2: 170 \mathrm{~ns})$.
6. If not HLDA, $t_{W D}=t_{W A}=t_{D 3}+t_{r \phi 2}+10 \mathrm{~ns}$. If HLDA, $t_{W D}$ $=t_{W A}=t_{W F}$.
7. $\left.t_{H F}=t_{D 3}+t_{r \phi 2}-50 \mathrm{~ns}\right)$.
8. $t_{W F}=t_{D 3}+t_{r \phi 2}-10 \mathrm{~ns}$.
9. Data in must be stable for this period during DBIN $\mathrm{T}_{3}$. Both $t_{D S 1}$ and $t_{D S 2}$ must be satisfied.
10. Ready signal must be stable for this period during $T_{2}$ or $T_{W}$. (Must be externally synchronized.)
11. Hold signal must be stable for this period during $T_{2}$ or $T_{w}$ when entering hold mode, and during $T_{3}, T_{4}, T_{5}$ and $T_{W H}$ when in hold mode. (External synchronization is not required.)
12. Interrupt signal must be stable during this period of the last clock cycle of any instruction in order to be recognized on the following instruction. (External synchronization is not required.)
13. This timing diagram shows timing relationships only; it does not represent any specific machine cycle.

## INSTRUCTION SET

The accumulator group instructions include arithmetic and logical operators with direct, indirect, and immediate addressing modes.
Move, load, and store instruction groups provide the ability to move either 8 or 16 bits of data between memory, the six working registers and the accumulator using direct, indirect, and immediate addressing modes.
The ability to branch to different portions of the program is provided with jump, jump conditional, and computed jumps. Also the ability to call to and return from subroutines is provided both conditionally and unconditionally. The RESTART (or single byte call instruction) is useful for interrupt vector operation.
Double precision operators such as stack manipulation and double add instructions extend both the arithmetic and interrupt handling capability of the 8080A. The ability to
increment and decrement memory, the six general registers and the accumulator is provided as well as extended increment and decrement instructions to operate on the register pairs and stack pointer. Further capability is provided by the ability to rotate the accumulator left or right through or around the carry bit.
Input and output may be accomplished using memory addresses as I/O ports or the directly addressed I/O provided for in the 8080A instruction set.
The following special instruction group completes the 8080A instruction set: the NOP instruction, HALT to stop processor execution and the DAA instructions provide decimal arithmetic capability. STC allows the carry flag to be directly set, and the CMC instruction allows it to be complemented. CMA complements the contents of the accumulator and XCHG exchanges the contents of two 16 -bit register pairs directly.

## Data and Instruction Formats

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

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

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}
\mathrm{D}_{7} & \mathrm{D}_{6} & \mathrm{D}_{5} & \mathrm{D}_{4} & \mathrm{D}_{3} & \mathrm{D}_{2} & \mathrm{D}_{1} & \mathrm{D}_{0} \\
\hline
\end{array} \text { OP CODE }
$$

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

## TYPICAL INSTRUCTIONS

Register to register, memory reference, arithmetic or logical, rotate, return, push, pop, enable or disable Interrupt 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}$ | 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}$ |
| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |

OP CODE
LOW ADDRESS OR OPERAND 1
HIGH ADDRESS OR OPERAND 2

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

Table 2. Instruction Set Summary

| Mnemonic |  |  |  |  |  |  |  |  | Operations Description | Clock Cycles [2] |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MOVE, LOAD | D, AN | AND S |  | TORE |  |  |  |  | Move register to register Move register to memory | 5 |
| MOVr1,r2 | 0 | 1 | D | D | D | S | S | S |  |  |
| MOV M,r |  | 1 |  |  | 0 | S | S | S |  | 7 |
| MOV r,M |  | 1 | D | D | D | 1 | 1 | 0 | Move memory to register | 7 |
| MVI r |  | 0 | D | D | D | 1 | 1 | 0 | Move immediate register | 7 |
| MVI M | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | Move immediate memory | 10 |
| LXIB | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | Load immediate register Pair B \& C | 10 |
| LXID | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | Load immediate register Pair D \& E | 10 |
| LXIH | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | Load immediate register Pair H \& L | 10 |
| STAX B | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | Store A indirect | 7 |
| STAX D | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | Store A indirect | 7 |
| LDAX B | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | Load $\mathbf{A}$ indirect | 7 |
| LDAX D | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | Load $\mathbf{A}$ indirect | 7 |
| STA | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | Store A direct | 13 |
| LDA | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | Load A direct | 13 |
| SHLD | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | Store H \& L direct | 16 |
| LHLD | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | Load H \& L direct | 16 |
| XCHG | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | Exchange D \& E, H\&L Registers | 4 |
| STACK OPS |  |  |  |  |  |  |  |  | Push register Pair B \& C on stack | 11 |
| PUSH B | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 1 |  |  |
| PUSH D | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | Push register Pair D \& E on stack | 11 |
| PUSH H | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | Push register Pair H \& L on stack | 11 |
| PUSH | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | Push A and Flags | 11 |
| PSW |  |  |  |  |  |  |  |  | on stack |  |
| POP B | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | Pop register Pair B \& C off stack | 10 |
| POP D | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | Pop register Pair D \& E off stack | 10 |
| POP H | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | Pop register Pair H \& L off stack | 10 |
| POP PSW | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | Pop A and Flags off stack | 10 |
| XTHL | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | Exchange top of stack, H \& L | 18 |
| SPHL | 1 | , | 1 | 1 | 1 | 0 | 0 | - 1 | H\& L to stack pointer | 5 |
| LXI SP | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | Load immediate stack pointer | 10 |
| INX SP | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | Increment stack pointer | 5 |
| DCX SP | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | Decrement stack pointer | 5 |
| JUMP |  |  |  |  |  |  |  |  |  |  |
| JMP | 1 |  | 0 | 0 | 0 | 0 | 1 | 1 | Jump unconditional | 10 |
| JC | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | Jump on carry | 10 |
| JNC | 1 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | Jump on no carry | 10 |
| JZ | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | Jump on zero | 10 |
| JNZ | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Jump on no zero | 10 |
| JP | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | Jump on positive | 10 |
| JM | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | Jump on minus | 10 |
| JPE | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | Jump on parity even | 10 |


| Mnemonic | Instruction Code [1] |  |  |  |  |  |  |  | Operations <br> Description | Clock Cycles [2] |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JPO PCHL | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ |  | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | Jump on parity odd H\& L to program counter | $\begin{array}{r} 10 \\ 5 \end{array}$ |
| CALL |  |  |  |  |  |  |  |  |  |  |
| CALL | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | Call unconditional | 17 |
| CC | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | Call on carry | 11/17 |
| CNC | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | Call on no carry | 11/17 |
| CZ | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | Call on zero | 11/17 |
| CNZ | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | Call on no zero | 11/17 |
| CP | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | Call on positive | 11/17 |
| CM | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | Call on minus | 11/17 |
| CPE | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0. | Call on parity even | 11/17 |
| CPO | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | Call on parity odd | 11/17 |
| RETURN |  |  |  |  |  |  |  |  |  |  |
| RET | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | Return | 10 |
| RC | 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | Return on carry | 5/11 |
| RNC | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | Return on no carry | 5/11 |
| RZ | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | Return on zero | 5/11 |
| RNZ | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | Return on no zero | 5/11 |
| RP | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | Return on positive | 5/11 |
| RM | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | Return on minus | 5/11 |
| RPE | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | Return on parity even | 5/11 |
| RPO | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | Return on parity odd | 5/11 |
| RESTART |  |  |  |  |  |  |  |  |  |  |
| INCRENENT AND DECREMENT |  |  |  |  |  |  |  |  |  |  |
| INR r | 0 | 0 | D | D | D | 1 | 0 | 0 | Increment register | 5 |
| DCR r | 0 | 0 | D | D | D | 1 | 0 | 1 | Decrement register | 5 |
| INR M | 0 | 0 | 1 | 1. | 0 | 1 | 0 | 0 | Increment memory | 10 |
| DCR M | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 | Decrement memory | 10 |
| INX B | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | Increment B \& C registers | 5 |
| INX D | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | Increment D \& E registers | 5 |
| INX H | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | Increment H \& L registers | 5 |
| DCX B | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | Decrement B \& C | 5 |
| DCX D | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | Decrement D \& E | 5 |
| DCX H | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | Decrement H \& L | 5 |
| ADD |  |  |  |  |  |  |  |  |  |  |
| ADD $r$ | 1 | 0 | 0 | 0 | 0 | S | S | S | Add register to $\mathbf{A}$ | 4 |
| ADC r | 1 | 0 | 0 | 0 | 1 | S | S | S | Add register to A with carry | 4 |
| ADD M | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | Add memory to $A$ | 7 |
| ADC M | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | Add memory to $\mathbf{A}$ with carry | 7 |
| ADI | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | Add immediate to A | 7 |
| ACI | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | Add immediate to $\mathbf{A}$ with carry | 7 |
| DAD B | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | Add B \& C to H \& L | 10 |
| DAD D | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | Add D \& E to H\&L | 10 |
| DAD H | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | Add H\&L to H\&L | 10 |
| DAD SP | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | Add stack pointer to H\&L | 10 |

Summary of Processor Instructions (Cont.)


## NOTES:

1. $D D D$ or $S S S: 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

# 8085AH/8085AH-2/8085AH-1 8-BIT HMOS MICROPROCESSORS 

- Single +5V Power Supply with 10\% Voltage Margins
- $3 \mathrm{MHz}, 5 \mathrm{MHz}$ and 6 MHz Selections Available
- 20\% Lower Power Consumption than 8085A for 3 MHz and 5 MHz
- $1.3 \mu$ s Instruction Cycle (8085AH); 0.8 $\mu \mathrm{s}$ (8085AH-2); $0.67 \mu \mathrm{~s}$ (8085AH-1)
- 100\% Compatible with 8085A
- 100\% Software Compatible with 8080A
- 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 8080A-Compatible Interrupt
- Serial In/Serial Out Port
- Decimal, Binary and Double Precision Arithmetic


## - Direct Addressing Capability to 64K Bytes of Memory

The Intel ${ }^{\circledR} 8085 \mathrm{AH}$ is a complete 8 bit parallel Central Processing Unit (CPU) implemented in N -channel, depletion load, silicon gate technology (HMOS). 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 [8085AH (CPU), 8156H (RAM/IO) and 8355/8755A (ROM/PROM/IO)] while maintaining total system expandability. The 8085AH-2 and 8085AH-1 are faster versions of the 8085AH.
The 8085AH 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 8085AH 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 \mathrm{H} / 8156 \mathrm{H} / 8355 / 8755 \mathrm{~A}$ memory products allow a direct interface with the 8085AH.


Figure 2. 8085AH Pin Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $A_{8}-A_{15}$ | 0 | 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. |
| $A D_{0-7}$ | 1/0 | 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 | 0 | 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. |
| $\mathrm{S}_{0}, \mathrm{~S}_{1}$, and $10 / \bar{M}$ | 0 | Machine Cycle Status: <br> $S_{1}$ can be used as an advanced $R / \bar{W}$ status. $10 / \bar{M}, S_{0}$ and $S_{1}$ become valid at the beginning of a machine cycle and remain stable throughout the cycle. The falling edge of ALE may be used to latch the state of these lines. |
| $\overline{\mathrm{RD}}$ | 0 | Read Control: A low level on $\overline{\mathrm{RD}}$ indicates the selected memory or I/O device is to be read and that the Data Bus is available for the data transfer, 3 -stated during Hold and Halt modes and during RESET. |
| $\overline{W R}$ | 0 | Write Control: A low level on WR indicates the data on the Data Bus is to be written into the selected memory or I/O location. Data is set up at the trailing edge of $\overline{W R}$. 3stated during Hold and Halt modes and during RESET. |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| READY | 1 | Ready: If READY is high during a read or write cycle, it indicates that the memory or peripheral is ready to send or receive data. If READY is low, the cpu will wait an integral number of clock cycles for READY to go high before completing the read or write cycle. READY must conform to specified setup and hold times. |
| HOLD | 1 | Hold: Indicates that another master is requesting the use of the address and data buses. The cpu, upon receiving the hold request, will relinquish the use of the bus as soon as the completion of the current bus transfer. Internal processing can continue. The processor can regain the bus only after the HOLD is removed. When the HOLD is acknowledged, the Address, Data $\overline{R D}, \overline{W R}$, and $10 / \bar{M}$ lines are 3-stated. |
| HLDA | 0 | Hold Acknowledge: Indicates that the cpu has received the HOLD request and that it will relinquish the bus in the next clock cycle. HLDA goes low after the Hold request is removed. The cpu takes the bus one half clock cycle after HLDA goes low. |
| INTR | I | Interrupt Request: Is used as a general purpose interrupt. It is sampled only during the next to the last clock cycle of an instruction and during Hold and Halt states. If it is active, the Program Counter (PC) will be inhibited from incrementing and an INTA will be issued. During this cycle a RESTART or CALL instruction can be inserted to jump to the interrupt service routine. The INTR is enabled and disabled by software. It is disabled by Reset and immediately after an interrupt is accepted. |
| $\overline{\text { INTA }}$ | 0 | Interrupt Acknowledge: Is used instead of (and has the same timing as) $\overline{\mathrm{RD}}$ during the Instruction cycle after an INTR is accepted. It can be used to activate an 8259A Interrupt chip or some other interrupt port. |
| RST 5.5 RST 6.5 RST 7.5 | 1 | Restart Interrupts: These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted. <br> The priority of these interrupts is ordered as shown in Table 2. These interrupts have a higher priority than INTR. In addition, they may be individually masked out using the SIM instruction. |

Table 1. Pin Description (Continued)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| TRAP | 1 | Trap: 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 2.) |
| RESET IN | 1 | Reset In: 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{R E S E T ~ I N}$ is a Schmitt-triggered input, allowing connection to an R-C network for power-on RESET delay (see Figure 3). Upon power-up, $\overline{R E S E T I N}$ must remain low for at least 10 ms after minimum $V_{C C}$ has been reached. For 'proper reset operation after the power-up duration, $\overline{R E S E T ~ I N}$ should be kept low a minimum of three clock periods. The CPU is held in the reset condition as long as RESET IN is applied. |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| RESET OUT | 0 | Reset Out: Reset Out indicates cpu is being reset. Can be used as a system reset. The signal is synchronized to the processor clock and lasts an integral number of clock periods. |
| $\mathrm{x}_{1}, \mathrm{X}_{2}$ | 1 | $\mathrm{X}_{1}$ and $\mathrm{X}_{2}$ : Are connected to a crystal, LC, or RC network to drive the internal clock generator. $\mathrm{X}_{1}$ can also be an external clock input from a logic gate. The input frequency is divided by 2 to give the processor's internal operating frequency. |
| CLK | 0 | Clock: Clock output for use as a system clock. The period of CLK is twice the $X_{1}, X_{2}$ input period. |
| SID | 1 | Serial Input Data Line: The data on this line is loaded into accumulator bit 7 whenever a RIM instruction is executed. |
| SOD | 0 | Serial Output Data Line: The output SOD is set or reset as specified by the SIM instruction. |
| $\mathrm{V}_{\text {CC }}$ |  | Power: +5 volt supply. |
| $\mathrm{V}_{\text {SS }}$ |  | Ground: Reference. |

Table 2. 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.


Figure 3. Power-On Reset Circuit

## FUNCTIONAL DESCRIPTION

The 8085AH is a complete 8-bit parallel central processor. It is designed with N -channel, depletion load, silicon gate technology (HMOS), and requires a single +5 volt supply. Its basic clock speed is 3 MHz ( 8085 AH ), 5 MHz ( $8085 \mathrm{AH}-2$ ), or 6 MHz (8085AH-1), 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 (8085AH), a RAM/IO (8156H), and a ROM or EPROM/IO chip (8355 or 8755A).

The 8085AH 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 8085AH 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 <br>  <br>  <br>  <br> Registers; data <br> 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-bit space) |

The 8085AH 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 8085AH provides $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{S}_{0}, \mathrm{~S}_{1}$, and $10 / \bar{M}$ signals for bus control. An Interrupt Acknowledge signal ( $\overline{\mathrm{NTA}}$ ) is also provided. HOLD and all Interrupts are synchronized with the processor's internal clock. The 8085AH also provides Serial Input Data (SID) and Serial Output Data (SOD) lines for simple serial interface.

In addition to these features, the 8085AH has three maskable, vector interrupt pins, one nonmaskable TRAP interrupt, and a bus vectored interrupt, INTR.

## INTERRUPT AND SERIAL I/O

The 8085AH 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 2.)

There are two different types of inputs in the restart interrupts. RST 5.5 and RST 6.5 are high levelsensitive 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 (a normally high level signal with a low going pulse is recommended for highest system noise immunity). 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 8085AH. The RST 7.5 internal flipflop 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 5 of the MCS-80/85 User's Manual.)

The interrupts are arranged in a fixed priority that determines which interrupt is to be recognized if more than one is pending as follows: TRAPhighest priority, RST 7.5, RST 6.5, RST 5.5 , INTRlowest 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 4 illustrates the TRAP interrupt request circuitry within the 8085AH. 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 4. 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 the MCS-80/85 Family User's Manual.

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 8085AH, 8085AH-2, or 8085AH-1 with a crystal, an LC tuned circuit, an RC network, or an external clock source. The crystal frequency must be at least 1 MHz , and must be twice the desired internal clock frequency; hence, the 8085AH is operated with a 6 MHz crystal (for 3 MHz clock), the 8085AH-2 operated with a 10 MHz crystal (for 5 MHz clock), and the 8085AH-1 can be operated with a 12 MHz crystal (for 6 MHz clock). If a crystal is used, it must have the following characteristics:

Parallel resonance at twice the clock frequency desired
$\mathrm{C}_{\mathrm{L}}$ (load capacitance) $\leqslant 30 \mathrm{pF}$
$\mathrm{C}_{\mathrm{S}}$ (shunt capacitance) $\leqslant 7 \mathrm{pF}$
$\mathrm{R}_{\mathrm{S}}$ (equivalent shunt resistance) $\leqslant 75$ Ohms
Drive level: 10 mW
Frequency tolerance: $\pm .005 \%$ (suggested)
Note the use of the 20 pF capacitor between $\mathrm{X}_{2}$ and ground. This capacitor is 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 8085 AH , 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 frequencydetermining network for the 8085AH 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 5 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 and maximum low level voltage of 0.8 V .

For driving frequencies up to and including 6 MHz you may supply the driving signal to $X_{1}$ and leave $X_{2}$ open-circuited (Figure 5D). If the driving frequency is from 6 MHz to 12 MHz , stability of the clock generator will be improved by driving both $X_{1}$ and $X_{2}$ with a push-pull source (Figure 5E). To prevent self-oscillation of the 8085AH, be sure that $X_{2}$ is not coupled back to $X_{1}$ through the driving circuit.


Figure 5. Clock Driver Circuits

## GENERATING AN 8085AH WAIT STATE

If your system requirements are such that slow memories or peripheral devices are being used, the circuit shown in Figure 6 may be used to insert one WAIT state in each 8085AH machine cycle.

The D flip-flops should be chosen so that

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


Figure 6. Generation of a Wait State for 8085AH CPU

As in the 8080, the READY line is used to extend the read and write pulse lengths so that the 8085AH 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 8085AH family includes memory components, which are directly compatible to the 8085AH CPU. For example, a system consisting of the three chips, $8085 \mathrm{AH}, 8156 \mathrm{H}$, 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 7.

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 8 shows the system configuration of Memory Mapped I/O using 8085AH.

The 8085AH 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 9.


Figure 7. 8085AH Minimum System (Standard I/O Technique)


Figure 8. MCS-85 ${ }^{\text { }}$ Minimum System (Memory Mapped I/O)


Figure 9. MCS-85 ${ }^{\text {® }}$ System (Using Standard Memories)

8085AH/8085AH-2/8085AH-1

## BASIC SYSTEM TIMING

The 8085AH has a multiplexed Data Bus. ALE is used as a strobe to sample the lower 8 -bits of address on the Data Bus. Figure 10 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction). Note that during the $\mathrm{I} / \mathrm{O}$ write and read cycle that the $\mathrm{I} / \mathrm{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 ( $10 / \bar{M}, \mathrm{~S}_{1}, \mathrm{~S}_{0}$ ) and the three control signals ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\overline{\mathrm{NTA}}$ ). (See Table 3.) The status lines can be used as advanced controls (for device selection, for example), since they become active at the $T_{1}$ state, at the outset of each machine cycle. Control lines $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ 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 4.

Table 3. 8085AH Machine Cycle Chart

| MACHINE CYCLE |  | STATUS |  |  | CONTROL |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 10/M | S1 | So | $\overline{\mathrm{RD}}$ | $\overline{\text { WR }}$ | 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 4. 8085AH Machine State Chart

| Machine State | Status \& Buses |  |  |  | Control |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | s1, S 0 | 10/M | $A_{8}-A_{15}$ | $A D_{0}-A D_{7}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $\overline{\text { 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 |

$\begin{array}{rr}0=\text { Logic " } 0 " & \text { TS }=\text { High Impedance } \\ 1=\text { Logic " } 1 \text { " } & X=\text { Unspecified }\end{array}$
$1=$ Logic " 1 " $\mathrm{X}=$ Unspecified

* ALE not generated during 2nd and 3rd machine cycles of DAD instruction.
$+10 / \mathrm{M}=1$ during $\mathrm{T}_{4}-\mathrm{T}_{6}$ of INA machine cycle.


Figure 10. 8085AH Basic System Timing

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

8085AH, 8085AH-2: ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$; unless otherwise specified)
$8085 \mathrm{AH}-1:\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$; unless otherwise specified)

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ |  | Power Supply Current |  | 135 | mA |
|  |  |  | 200 | mA | $8085 \mathrm{AH}, 8085 \mathrm{AH}-2$ |
|  |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\text {LO }}$ | Output Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{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 LeveI, RESET | 2.4 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{HY}}$ | Hysteresis, RESET | 0.25 |  | V |  |

## A.C. CHARACTERISTICS

8085AH, 8085AH-2: ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )
$8085 \mathrm{AH}-1:\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\right)$

| Symbol | Parameter | $\begin{gathered} \text { 8085AH }^{[2]} \\ \text { (Final) } \end{gathered}$ |  | $\begin{aligned} & \text { 8085AH-2 }{ }^{[2]} \\ & \text { (Final) } \end{aligned}$ |  | 8085AH-1 (Preliminary) |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {t Cry }}$ | CLK Cycle Period | 320 | 2000 | 200 | 2000 | 167 | 2000 | ns |
| $\mathrm{t}_{1}$ | CLK Low Time (Standard CLK Loading) | 80 |  | 40 |  | 20 |  | ns |
| $\mathrm{t}_{2}$ | CLK High Time (Standard CLK Loading) | 120 |  | 70 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | CLK Rise and Fall Time |  | 30 |  | 30 |  | 30 | ns |
| $t_{\text {XKR }}$ | $X_{1}$ Rising to CLK Rising | 25 | 120 | 25 | 100 | 20 | 100 | ns |
| ${ }_{\text {t }}^{\text {XKF }}$ | $X_{1}$ Rising to CLK Falling | 30 | 150 | 30 | 110 | 25 | 110 | ns |
| ${ }^{\text {t }}$ C | $\mathrm{A}_{8-15}$ Valid to Leading Edge of Control ${ }^{[1]}$ | 270 |  | 115 |  | 70 |  | ns |
| ${ }^{\text {t }}$ ACL | $A_{0-7}$ Valid to Leading Edge of Control | 240 |  | 115 |  | 60 |  | ns |
| ${ }^{\text {t }}$ AD | $A_{0-15}$ Valid to Valid Data In |  | 575 |  | 350 |  | 225 | ns |
| $t_{\text {AFR }}$ | Address Float After Leading Edge of $\overline{\text { READ }}$ (INTA) |  | 0 |  | 0 |  | 0 | ns |
| ${ }^{\text {tal }}$ | $\mathrm{A}_{8-15}$ Valid Before Trailing Edge of ALE ${ }^{\text {[1] }}$ | 115 |  | 50 |  | 25 |  | ns |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | $\begin{gathered} \text { 8085AH }{ }^{[2]} \\ \text { (Final) } \end{gathered}$ |  | $\begin{aligned} & \text { 8085AH-2 } 2^{[2]} \\ & \text { (Final) } \end{aligned}$ |  | 8085AH-1 <br> (Preliminary) |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {ALL }}$ | $\mathrm{A}_{0-7}$ Valid Before Trailing Edge of ALE | 90 |  | 50 |  | 25 |  | ns |
| $t_{\text {ARY }}$ | READY Valid from Address Valid |  | 220 |  | 100 |  | 40 | ns |
| ${ }^{\text {t CA }}$ | Address ( $\mathrm{A}_{8-15}$ ) Valid After Control | 120 |  | 60 |  | 30 |  | ns |
| ${ }^{\mathrm{t}} \mathrm{CC}$ | Width of Control Low ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{INTA}}$ ) Edge of ALE | 400 |  | 230 |  | 150 |  | ns |
| ${ }^{\mathrm{t}} \mathrm{CL}$ | Trailing Edge of Control to Leading Edge of ALE | 50 |  | 25 | $\cdots$ | 0 |  | ns |
| tDW | Data Valid to Trailing Edge of WRITE | 420 |  | 230 |  | 140 |  | ns |
| $t_{\text {HABE }}$ | HLDA to Bus Enable |  | 210 |  | 150 |  | 150 | ns |
| $\mathrm{t}_{\text {HABF }}$ | Bus Float After HLDA |  | 210 |  | 150 |  | 150 | ns |
| $\mathrm{t}_{\text {HACK }}$ | HLDA Valid to Trailing Edge of CLK | 110 |  | 40 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{HDH}}$ | HOLD Hold Time | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {HDS }}$ | HOLD Setup Time to Trailing Edge of CLK | 170 |  | 120 |  | 120 |  | ns |
| tiNH | INTR Hold Time | 0 |  | 0 |  | 0 |  | ns |
| tins | INTR, RST, and TRAP Setup Time to Falling Edge of CLK | 160 |  | 150 |  | 150 |  | ns |
| $t_{\text {LA }}$ | Address Hold Time After ALE | 100 |  | 50 |  | 20 | . | ns |
| $t_{\text {LC }}$ | Trailing Edge of ALE to Leading Edge of Control | 130 |  | 60 |  | 25 | $\therefore$ | ns |
| tLCK | ALE Low During CLK High | 100 |  | 50 |  | 15 |  | ns |
| tLDR | ALE to Valid Data During Read |  | 460 |  | 270 |  | 175 | ns |
| t LDW | ALE to Valid Data During Write |  | 200 |  | 120 |  | 110 | ns |
| tLL | ALE Width | 140 |  | 80 |  | 50 |  | ns |
| tLRY | ALE to READY Stable |  | 110 |  | 30 |  | 10 | ns |
| $t_{\text {RAE }}$ | Trailing Edge of $\overline{R E A D}$ to Re-Enabling of Address | 150 | " | 90 |  | 50 | , | ns |
| $\mathrm{t}_{\mathrm{RD}}$ | $\overline{\text { READ ( }}$ ( $\overline{\text { INTA }}$ ) to Valid Data |  | 300 |  | 150 |  | 75 | ns |
| $t_{\text {RV }}$ | Control Trailing Edge to Leading Edge of Next Control | 400 |  | 220 |  | 160 |  | ns |
| $\mathrm{t}_{\text {RDH }}$ | Data Hold Time After READ INTA | 0 |  | 0 |  | 0 |  | ns |
| ${ }_{\text {t }}^{\text {RYH }}$ | READY Hold time | 0 |  | 0 |  | 5 |  | ns |
| $\mathrm{t}_{\mathrm{RYS}}$ | READY Setup Time to Leading Edge of CLK | 110 |  | 100 |  | 100 |  | ns |
| twD | Data Valid After Trailing Edge of $\overline{\text { WRITE }}$ | 100 |  | 60 | - | 30 |  | ns |
| ${ }^{\text {t WDL }}$ | LEADING Edge of $\overline{\text { WRITE }}$ to Data Valid |  | 40 |  | 20 |  | 30 | ns |

## NOTES:

1. $A_{8}-A_{15}$ address Specs apply $I O / \bar{M}, S_{0}$, and $S_{1}$ except $A_{8}-A_{15}$ are undefined during $\mathrm{T}_{4}-\mathrm{T}_{6}$ of OF cycle whereas $\mathrm{IO} / \overline{\mathrm{M}}, \mathrm{S}_{0}$, and $\mathrm{S}_{1}$ are stable.
2. Test Conditions: $\mathrm{t}_{\mathrm{CYC}}=320 \mathrm{~ns}(8085 \mathrm{AH}) / 200 \mathrm{~ns}(8085 \mathrm{AH}-2)$;/ 167 ns ( $8085 \mathrm{AH}-1$ ); $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


3. For all output timing where $C_{L} \neq 150 \mathrm{pF}$ use the following correction factors:

$$
\begin{aligned}
& 25 \mathrm{pF} \leqslant \mathrm{C}_{\mathrm{L}}<150 \mathrm{pF}:-0.10 \mathrm{~ns} / \mathrm{pF} \\
& 150 \mathrm{pF}<\mathrm{C}_{\mathrm{L}} \leqslant 300 \mathrm{pF}:+0.30 \mathrm{~ns} / \mathrm{pF}
\end{aligned}
$$

4. Output timings are measured with purely capacitive load.
5. To calculate timing specifications at other values of $\mathrm{t}_{\mathrm{CYC}}$ use Table 5.

## A.C. TESTING LOAD CIRCUIT



Table 5. Bus Timing Specification as a $\mathbf{T}_{\mathrm{CYC}}$ Dependent

| Symbol | 8085AH | 8085AH-2 | 8085AH-1 |  |
| :---: | :---: | :---: | :---: | :---: |
| ${ }_{\text {t }}^{\text {AL }}$ | (1/2) T - 45 | (1/2) T - 50 | (1/2) T - 58 | Minimum |
| $t_{\text {LA }}$ | (1/2) T - 60 | (1/2) T - 50 | (1/2) T - 63 | Minimum |
| til | (1/2) T - 20 | (1/2) T-20 | (1/2) T-33 | Minimum |
| tLCK | (1/2) T - 60 | (1/2) T - 50 | (1/2) T - 68 | Minimum |
| tLC | (1/2) T-30 | (1/2) T - 40 | (1/2) T - 58 | Minimum |
| $t_{\text {AD }}$ | $(5 / 2+N) T-225$ | $(5 / 2+N) T-150$ | (5/2 + N ) T-192 | Maximum |
| $t_{\text {RD }}$ | $(3 / 2+N) T-180$ | $(3 / 2+N) T-150$ | $(3 / 2+N) T-175$ | Maximum |
| $t_{\text {RAE }}$ | (1/2) T - 10 | (1/2) T-10 | (1/2) T-33 | Minimum |
| ${ }^{\text {t }}$ CA | (1/2) T-40 | (1/2) T-40 | (1/2) T-53 | Minimum |
| tow | $(3 / 2+N) T-60$ | $(3 / 2+N) T-70$ | $(3 / 2+N) T-110$ | Minimum |
| two | (1/2) T-60 | (1/2) T-40 | (1/2) T-53 | Minimum |
| ${ }^{\text {t }} \mathrm{C}$ | $(3 / 2+N) T-80$ | $(3 / 2+N) T-70$ | $(3 / 2+N) T-100$ | Minimum |
| ${ }^{\text {t }}$ CL | (1/2) T-110 | (1/2) T - 75 | (1/2) T - 83 | Minimum |
| $t_{\text {AR }}$ | (3/2) T-260 | (3/2) T-200 | (3/2) T-210 | Maximum |
| $t_{\text {HACK }}$ | (1/2) T - 50 | (1/2) T - 60 | $(1 / 2) T-83$ | Minimum |
| $t_{\text {HABF }}$ | (1/2) T+50 | (1/2) T+50 | $(1 / 2) T+67$ | Maximum |
| $t_{\text {HABE }}$ | (1/2) $T+50$ | (1/2) T+50 | $(1 / 2) T+67$ | Maximum |
| ${ }^{\text {t }}$ C | (2/2) T - 50 | (2/2) T - 85 | (2/2) T - 97 | Minimum |
| $t_{1}$ | (1/2) T-80 | (1/2) T-60 | (1/2) T-63 | Minimum |
| $\mathrm{t}_{2}$ | (1/2) T-40 | (1/2) T-30 | (1/2) T-33 | Minimum |
| $t_{\text {RV }}$ | (3/2) T-80 | (3/2) T-80 | (3/2) T-90 | Minimum |
| tidR | (4/2) T-180 | (4/2) T-130 | (4/2) T-159 | Maximum |

NOTE: $\quad N$ is equal to the total WAIT states. $T=t_{\mathrm{CYC}}$.

## WAVEFORMS






## WAVEFORMS (Continued)

READ OPERATION WITH WAIT CYCLE (TYPICAL) — SAME READY TIMING APPLIES TO WRITE


## INTERRUPT AND HOLD



Table 6. Instruction Set Summary



Table 6. Instruction Set Summary (Continued)

| Mnemonic |  |  |  |  |  |  |  |  |  |  | Operations Description |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LOGICAL |  |  |  |  |  |  |  |  |  | And register with $\mathbf{A}$ Exclusive OR register with A |  |
| ANA r |  | 0 | 0 | 1 | 0 | 0 | S | S | S |  |  |
| XRA r |  |  |  | 1 | 0 | 1 | S | S | S |  |  |
| ORA r |  | 0 | 0 | 1 | 1 | 0 | S | S | S |  | R register with A |
| CMP r |  | 0 | 0 | 1 | 1 | 1 | S | S | S |  | Compare register with A |
| ANA M |  | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 |  | And memory with A |
| XRA M |  |  | 0 | 1 | 0 | 1 | 1 | 1 | 0 |  | Exclusive OR memory with A |
| ORA M |  | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 |  | OR memory with A |
| CMP M |  |  | 0 | 1 | 1 | 1 | 1 | 1 | 0 |  | Compare memory with A |
| ANI |  | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 |  | And immediate with A |
| XRI |  |  | 1 | 1 | 0 | 1 | 1 | 1 | 0 |  | Exclusive OR immediate with $A$ |
| ORI |  | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |  | R immediate with A |
| CPI |  |  | 1 | 1 | 1 | 1 | 1 | 1 | 0 |  | Compare immediate with A |
| ROTATE RLC |  | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |  | Rotate A left |
| RRC | 0 |  | 0 | 0 | 0 | 1 | 1 | 1 | 1 |  | Rotate A right |
| RAL |  |  | 0 | 0 | 1 | 0 | 1 |  | 1 |  | Rotate A left through carry |
| RAR |  |  | 0 | 0 | 1 | 1 | 1 | 1 | 1 |  | Rotate A right through carry |



## NOTES:

1. DDS or SSS: B 000, C 001, D 010, E011, H 100, L 101, Memory 110, A 111.
2. Two possible cycle times $(6 / 12)$ indicate instruction cycles dependent on condition flags.
*All mnemonics copyrighted ©Intel Corporation 1976.

# 8085A/8085A-2 <br> SINGLE CHIP 8-BIT N-CHANNEL MICROPROCESSORS 

- Single +5V Power Supply
- 100\% Software Compatible with 8080A
- $1.3 \mu$ 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 Pin Configuration

## 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
*NOTICE: 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}}=0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$; unless otherwise specified)

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

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

| Symbol | Parameter | 8085A ${ }^{[2]}$ |  | 8085A-2 ${ }^{[2]}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{crc}}$ | CLK Cycle Period | 320 | 2000 | 200 | 2000 | ns |
| $\mathrm{t}_{1}$ | CLK Low Time (Standard CLK Loading) | 80 |  | 40 |  | ns |
| $\mathrm{t}_{2}$ | CLK High Time (Standard CLK Loading) | 120 |  | 70 |  | ns |
| $t_{r}, t_{\text {f }}$ | CLK Rise and Fall Time |  | 30 |  | 30 | ns |
| ${ }_{\text {t }}$ KKR | $X_{1}$ Rising to CLK Rising | 30 | 120 | 30 | 100 | ns |
| ${ }_{\text {t }}$ KKE | $X_{1}$ Rising to CLK Falling | 30 | 150 | 30 | 110 | ns |
| ${ }^{\text {t }}$ A | $A_{8-15}$ Valid to Leading Edge of Control ${ }^{(1)}$ | 270 |  | 115 |  | ns |
| $\mathrm{t}_{\text {ACL }}$ | $A_{0-7}$ Valid to Leading Edge of Control | 240 |  | 115 |  | ns |
| ${ }^{\text {A }}$ AD | $\mathrm{A}_{0-15}$ Valid to Valld Data In |  | 575 |  | 350 | ns |
| ${ }_{\text {A AFR }}$ | Address Float After Leading Edge of READ (INTA) |  | 0 |  | 0 | ns |
| $t_{\text {AL }}$ | $\mathrm{A}_{8-15}$ Valid Before Trailing Edge of ALE ${ }^{[1]}$ | 115 |  | 50 |  | ns |
| $\mathrm{t}_{\text {ALL }}$ | $\mathrm{A}_{0-7}$ Valid Before Trailing Edge of ALE | 90 |  | 50 |  | ns |
| ${ }_{\text {t }}^{\text {ARY }}$ | READY Valid from Address Valid |  | 220 |  | 100 | ns |
| $\mathrm{t}_{\text {ca }}$ | Address ( $\mathrm{A}_{8-15}$ ) Valld After Control | 120 |  | 60 |  | ns |
| ${ }_{\text {t }} \mathrm{C}$ | Width of Control Low (RD, WR, INTA) Edge of ALE | 400 |  | 230 |  | ns |
| ${ }^{\text {ctL }}$ | 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 |
| ${ }_{\text {thabf }}$ | Bus Float After HLDA |  | 210 |  | 150 | ns |
| $\mathrm{t}_{\text {HACK }}$ | HLDA Valid to Trailing Edge of CLK | 110 |  | 40 |  | ns |
| ${ }_{\text {thich }}$ | HOLD Hold Time | 0 |  | 0 |  | ns |
| ${ }_{\text {thDS }}$ | HOLD Setup Time to Trailing Edge of CLK | 170 |  | 120 |  | ns |
| ${ }_{\text {I }}$ | INTR Hold Time | 0 |  | 0 |  | ns |
| tins | INTR, RST, and TRAP Setup Time to Falling Edge of CLK | 160 |  | 150 |  | ns |
| tha | Address Hold Time After ALE | 100 |  | 50 |  | ns |
| ${ }_{\text {t }}^{\text {LC }}$ | Trailing Edge of ALE to Leading Edge of Control | 130 |  | 60 |  | ns |
| $\mathrm{t}_{\text {LCK }}$ | ALE Low During CLK High | 100 |  | 50 |  | ns |
| ${ }_{\text {L L }}$ | ALE to Valid Data During Read |  | 460 |  | 270 | ns |
| tow | ALE to Valid Data During Write |  | 200 |  | 120 | ns |
| $\mathrm{t}_{\text {LL }}$ | ALE WIdth | 140 |  | 80 |  | ns |
| ${ }_{\text {L LRY }}$ | ALE to READY Stable |  | 110 |  | 30 | ns |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | $\text { 8085A }{ }^{[2]}$ |  | 8085A-2 ${ }^{[2]}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {t RAE }}$ | Trailing Edge of $\overline{\text { READ }}$ to Re -Enabling of Address | 150 |  | 90 |  | ns |
| $t_{\text {RD }}$ | $\overline{\text { READ }}$ (or $\overline{N T A}$ ) to Valid Data |  | 300 |  | 150 | ns |
| ${ }^{\text {t }} \mathrm{RV}$ | Control Trailing Edge to Leading Edge of Next Control | 400 |  | 220 |  | ns |
| $t_{\text {RDH }}$ | Data Hold Time After $\overline{\mathrm{READ}} \overline{\text { INTA }}^{[7]}$ | 0 |  | 0 |  | ns |
| ${ }^{\text {t }}$ RYM ${ }^{\text {r }}$ | READY Hold Time | 0 |  | 0 |  | ns |
| ${ }^{\text {t RYS }}$ | READY Setup Time to Leading Edge of CLK | 110 |  | 100 |  | ns |
| ${ }^{\text {twD }}$ | Data Valid After Trailing Edge of WRITE | 100 |  | 60 | , | ns |
| ${ }^{\text {t WDL }}$ | LEADING Edge of WRITE to Data Valid |  | 40 |  | 20 | ns |

NOTES:

1. $A_{8} \cdot 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 $O F$ cycle whereas $10 / \bar{M}, \mathrm{~S}_{0}$, andS ${ }_{1}$ are stable.
2. Test conditions: $\mathrm{t}_{\mathrm{CYC}}=320 \mathrm{~ns}(8085 \mathrm{~A}) / 200 \mathrm{~ns}(8085 \mathrm{~A}-2) ; \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
3. For all output timing where $C_{L}=150 \mathrm{pF}$ use the following correction factors: $25 \mathrm{pF} \leqslant \mathrm{C}_{\mathrm{L}}<150 \mathrm{pF}:-0.10 \mathrm{~ns} / \mathrm{pF}$ $150 \mathrm{pF}<\mathrm{C}_{\mathrm{L}} \leqslant 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 votage $\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 $\mathrm{t}_{\mathrm{CYC}}$ use Table 7.
7. Data hold time is guaranteed under all loading conditions.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## 8155H/8156H/8155H-2/8156H-2 2048-BIT STATIC HMOS RAM WITH I/O PORTS AND TIMER

\author{

- Single +5 V Power Supply with $\mathbf{1 0 \%}$ Voltage Margins <br> - 30\% Lower Power Consumption than the $\mathbf{8 1 5 5}$ and 8156 <br> - 100\% Compatible with 8155 and 8156 <br> - 256 Word $x 8$ Bits <br> - Completely Static Operation <br> - Internal Address Latch
}
- 2 Programmable 8-Bit I/O Ports
- 1 Programmable 6-Bit I/O Port
- Programmable 14-Bit Binary Counter/ Timer
- Compatible with 8085AH, 8085A and 8088 CPU
- Multiplexed Address and Data Bus


#### Abstract

The Intel ${ }^{\circledR} 8155 \mathrm{H}$ and 8156 H are RAM and I/O chips implemented in N -Channel, depletion load, silicon gate technology (HMOS), to be used in the 8085AH and 8088 microprocessor systems. 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 8085AH CPU.The $8155 \mathrm{H}-2$ and $8156 \mathrm{H}-2$ have maximum access times of 330 ns for use with the $8085 \mathrm{AH}-2$ and the 5 MHz 8088 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.




Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| RESET | 1 | Reset: Pulse provided by the 8085AH to initialize the system (connect to 8085AH 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 8085AH clock cycle times. |
| $\mathrm{AD}_{0-7}$ | 1/0 | Address/Data: 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 \mathrm{H} / 56 \mathrm{H}$ on the falling edge of ALE. The address can be either for the memory section or the $/ / 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{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ input signal. |
| CE or CE | I | Chip Énable: On the 8155 H , this pin is $\overline{C E}$ and is ACTIVE LOW. On the 8156 H , this pin is CE and is ACTIVE HIGH. |
| $\overline{R D}$ | I | Read Control: Input low on this line with the Chip Enable active enables and $A D_{0-7}$ buffers. If $10 / \bar{M}$ pin is low, the RAM content will be read out to the AD bus. Otherwise the content of the selected I/O port or command/status registers will be read to the AD bus. |
| $\overline{W R}$ | 1 | 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 IO/M. |
| ALE | 1 | Address Latch Enable: This control signal latches both the address on the $A D_{0-7}$ lines and the state of the Chip Enable and $\mathrm{IO} / \overline{\mathrm{M}}$ into the chip at the falling edge of ALE. |
| $10 / \bar{M}$ | I | I/O Memory: Selects memory if low and I/O and command/status registers if high. |
| $\mathrm{PA}_{0-7}(8)$ | 1/0 | Port A: These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the command register. |
| $\mathrm{PB}_{0-7}(8)$ | 1/0 | Port B: These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the command register. |
| $\mathrm{PC}_{0-5}(6)$ | I/O | Port C: 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: <br> $\mathrm{PC}_{0}-\mathrm{A}$ INTR (Port A Interrupt) <br> $\mathrm{PC}_{1}$ - ABF (Port A Buffer Full) <br> $\mathrm{PC}_{2}-\overline{\mathrm{ASTB}}$ (Port A Strobe) <br> $\mathrm{PC}_{3}$ - B INTR (Port B Interrupt) <br> $\mathrm{PC}_{4}-\mathrm{B} \mathrm{BF}$ (Port B Buffer Full) <br> $\mathrm{PC}_{5}$ - $\overline{\mathrm{BSTB}}$ (Port B Strobe) |
| TIMER IN | 1 | Timer Input: Input to the counter-timer. |
| TIMER OUT | 0 | Timer Output: This output can be either a square wave or a pulse, depending on the timer mode. |
| $\mathrm{V}_{\mathrm{CC}}$ |  | Voltage: +5 volt supply. |
| $\mathrm{V}_{\text {SS }}$ |  | Ground: Ground reference. |

## FUNCTIONAL DESCRIPTION

The $8155 \mathrm{H} / 8156 \mathrm{H}$ contains the following:

- $2 k$ Bit Static RAM organized as $256 \times 8$
- Two 8-bit I/O ports (PA \& PB) and one6-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.

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 3. $\mathbf{8 1 5 5 H} / \mathbf{8 1 5 6 H}$ Internal Registers


NOTE: FOR DETAILED TIMING INFORMATION, SEE FIGURE 12 AND A.C. CHARACTERISTICS.

Figure 4. 8155H/8156H On-Board Memory Read/Write Cycle

## PROGRAMMING OF THE COMMAND REGISTER

The command register consists of eight latches. Fcur 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 5. The contents of the command register may never be read.

## READING THE STATUS REGISTER

The status register consists of seven latches, one for each bit; six (0-5) for the status of the ports and one (6) for the status of the timer.
The status of the timer and the I/O section can be polled by reading the Status Register (Address XXXXX000). Status word format is shown in Figure 6. Note that you may never write to the status register since the command register shares the same I/O address and the command register is selected when a write to that address is issued.


Figure 5. Command Register Bit Assignment


Figure 6. Status Register Bit Assignment

## INPUT/OUTPUT SECTION

The I/O section of the $8155 \mathrm{H} / 8156 \mathrm{H}$ consists of five registers: (See Figure 7.)

- 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 $\mathrm{XXXXX010}$.
- PC Register - This register has the address XXXXX011 and contains only 6 bits. The 6 bits can be programmed to be either input ports, output ports or as control signals for 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 8155 H 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 2.)

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 Register |
| $x$ | $x$ | $x$ | X | $x$ | 0 | 0 | 1 | General Purpose 1/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 Contro! |
| $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.
$t$ : $I / O$ Address must be qualified by $C E=1(8156 H)$ or $\overline{C E}=0(8155 H)$ and $I O / \bar{M}=1$ in order to select the appropriate register.

Figure 7. I/O Port and Timer Addressing Scheme

Figure 8 shows how I/O PORTS A and B are structured within the 8155 H and 8156 H :


Figure 8. 8155H/8156H Port Functions

Table 2. 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 I/O ports are programmed to be output ports, the contents of the output ports can still be read by a READ operation when appropriately addressed.

The outputs of the $8155 \mathrm{H} / 8156 \mathrm{H}$ 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 $8155 \mathrm{H} / 56 \mathrm{H}$ 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 9 shows how the $8155 \mathrm{H} / 8156 \mathrm{H}$ I/O ports might be configured in a typical MCS-85 system.


Figure 9. Example: Command Register $\mathbf{= 0 0 1 1 1 0 0 1}$

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

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 10). The value loaded into the count length register can have any value from 2 H through 3 FFH in Bits 0-13.


Figure 10. Timer Format

There are four modes to choose from: M2 and M1 define the timer mode, as shown in Figure 11.


Figure 11. Timer Modes

Bits 6-7 ( $\mathrm{TM}_{2}$ and $\mathrm{TM}_{1}$ ) of command register contents are used to start and stop the counter. There are four commands to choose from:

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

Note that while the counter is counting, you may load 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 12.


Figure 12. Asymmetrical Square-Wave Output Resulting from Count of 9

The counter in the 8155H 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 $8155 \mathrm{H} / 8156 \mathrm{H}$ 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 8085AH 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 $8155 \mathrm{H} / 56 \mathrm{H}$ always counts out the right number of pulses in generating the TIMER OUT waveforms.

## 8085A MINIMUM SYSTEM CONFIGURATION

Figure 13a shows a minimum system using three chips, containing:

- 256 Bytes RAM
- 2 K Bytes ROM
- 38 I/O Pins
- 1 Interval Timer
- 4 Interrupt Levels


Figure 13a. 8085AH Minimum System Configuration (Memory Mapped I/O)

## 8088 FIVE CHIP SYSTEM

Figure 13b shows a five chip system containing:

- 1.25K Bytes RAM
- 2K Bytes ROM
- 38 I/O Pins
- 1 Interval Timer
- 2 Interrupt Levels


Figure 13b. 8088 Five Chip System Configuration

| ABSOLUTE MAXIMUM RATINGS* |  |
| :---: | :---: |
| Temperature Under Bias | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.5 V to +7 V |
| Power Dissipation |  |

*NOTICE: 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}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {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{lOL}^{\prime}=2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{lOH}^{\prime}=-400 \mu \mathrm{~A}$ |
| ILL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | 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 |  | 125 | mA |  |
| IIL (CE) | Chip Enable Leakage $\begin{aligned} & 8155 \mathrm{H} \\ & 8156 \mathrm{H} \end{aligned}$ |  | $\begin{aligned} & +100 \\ & -100 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |

A.C. CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

|  |  | 8155H/8156H |  | 8155H-2/8156H-2 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units |
| ${ }_{\text {t }}{ }_{\text {L }}$ | 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_{\text {LL }}$ | Latch Enable Width | 100 |  | 70 |  | ns |
| $t_{\text {RDF }}$ | Data Bus Float After READ | 0 | 100 | 0 | 80 | ns |
| ${ }^{\text {c }}$ CL | READ/WRITE Control to Latch Enable | 20 |  | 10 |  | ns |
| ${ }^{\text {t }}$ C | READ/WRITE Control Width | 250 |  | 200 |  | ns |
| tow | Data In to WRITE Set Up Time | 150 |  | 100 |  | ns |
| two | Data In Hold Time After WRITE | 25 |  | 25 |  | ns |
| $t_{R V}$ | Recovery Time Between Controls | 300 |  | 200 |  | ns |
| $t_{\text {w }}$ | WRITE to Port Output |  | 400 |  | 300 | ns |
| $t_{\text {PR }}$ | Port Input Setup Time | 70 |  | 50 |  | ns |
| $t_{\text {R }}$ | Port Input Hold Time | 50 |  | 10 |  | ns |
| ${ }_{\text {t }}^{\text {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 1 | Strobe to INTR On |  | 400 |  | 300 | ns |

A.C. CHARACTERISTICS (Continued) ( $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

|  |  | 8155H/8156H |  | 8155H-2/8156H-2 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units |
| $\mathrm{t}_{\text {RDI }}$ | READ to INTR Off |  | 400 |  | 300 | ns |
| tPSS | Port Setup Time to Strobe Strobe | 50 |  | 0 |  | ns |
| tpHS | Port Hold Time After Strobe | 120 |  | 100 |  | ns |
| ${ }^{\text {t }}$ SBE | Strobe to Buffer Empty |  | 400 |  | 300 | ns |
| twbF | WRITE to Buffer Full |  | 400 |  | 300 | ns |
| ${ }_{\text {twi }}$ | WRITE to INTR Off |  | 400 |  | 300 | ns |
| ${ }_{\text {t }}$ L | TIMER-IN to TIMER-OUT Low | .... | 400 |  | 300 | ns |
| ${ }^{\text {t }}$ H | TIMER-IN to 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 |
| $t_{2}$ | TIMER-IN High Time | 120 |  | 70 |  | ns |

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT


$C_{L}=150 \mathrm{pF}$
C INCLUDES JIG CAPACITANCE

## WAVEFORMS



WAVEFORMS (Continued)


## STROBED INPUT



## WAVEFORMS (Continued)



BASIC OUTPUT


## TIMER OUTPUT COUNTDOWN FROM 5 TO 1

 RELOAD MODE (M, MODE BIT: $=1$ )

## 8155/8156/8155-2/8156-2 <br> 2048 BIT STATIC MOS RAM WITH I/O PORTS AND TIMER

```
256 Word x }8\mathrm{ 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
- Compatible with 8085A and 8088 CPU
- Multiplexed Address and Data Bus
- 40 Pin DIP

The 8155 and 8156 are RAM and I/O chips to be used in the 8085A and 8088 microprocessor systems. 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 and the 5 MHz 8088 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.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias ................ $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin |  |
| With Respect to Ground | -0.5V to +7 V |
| Power Dissipation | 1.5 W |

*NOTICE: 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 $\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 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {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 |  |
| VOL | Output Low Voltage | , | 0.45 | V | $\mathrm{BL}=2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{OHH}=-400 \mu \mathrm{~A}$ |
| ILL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| Icc | Vcc Supply Current |  | 180 | mA |  |
| IIL (CE) | Chip Enable Leakage $\begin{aligned} & 8155 \\ & 8156 \end{aligned}$ |  | $\begin{aligned} & +100 \\ & -100 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\mathrm{OV} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |

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)$

|  | \% | 8155/8156 |  | 8155-2/8156-2 |  | $\cdots$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 |
| $\mathrm{t}_{\mathrm{RD}}$ | Valid Data Out Delay from READ Control |  | 170 |  | 140 | ns |
| ${ }^{\text {t }}$ AD | Address Stable to Data Out Valid |  | 400 |  | 330 | ns |
| ${ }^{\text {t LL }}$ | Latch Enable Width | 100 |  | 70 |  | ns |
| $\mathrm{t}_{\text {RDF }}$ | Data Bus Float After READ | 0 | 100 | 0 | 80 | ns |
| ${ }^{\text {che }}$ | READNRITE Control to Latch Enable | 20 |  | 10 |  | ns |
| ${ }_{\text {t }} \mathbf{C}$ | READ/WRITE Control Width | 250 |  | 200 |  | ns ${ }^{\text {²}}$ |
| $t_{\text {DW }}$ | Data In to WRITE Set Up Time | 150 |  | 100 |  | ns |
| twD | Data In Hold Time After WRITE | 25 |  | 25 |  | ns |
| $t_{\text {R }} \mathrm{V}$ | Recovery Time Between Controls | 300 |  | 200 |  | ns |
| $t_{\text {WP }}$ | WRITE to Port Output |  | 400 |  | 300 | ns |
| $\mathrm{t}_{\text {PR }}$ | Port Input Setup Time | 70 |  | 50 | . | ns |
| $t_{\text {R }}$ | Port Input Hold Time | 50 |  | 10 |  | ns |
| ${ }_{\text {t }}^{\text {SBF }}$ | Strobe to Buffer Full |  | 400 |  | 300 | ns |
| ${ }_{\text {tss }}$ | Strobe Width | 200 |  | 150 |  | ns |
| $\mathrm{t}_{\text {RBE }}$ | READ to Buffer Empty |  | 400 |  | 300 | ns |
| ${ }_{\text {t }}^{\text {S }}$ I | Strobe to INTR On |  | 400 |  | 300 | ns |
| $\mathrm{t}_{\text {RDI }}$ | READ to INTR Off |  | 400 |  | 300 | ns |
| tpSS | Port Setup Time to Strobe Strobe | 50 |  | 0 |  | ns |
| tPHS | Port Hold Time After Strobe | 120 |  | 100 |  | ns |
| ${ }^{\text {t }}$ SBE | Strobe to Buffer Empty |  | 400 |  | 300 | ns |
| $t_{\text {WBF }}$ | WRITE to Buffer Full |  | 400 |  | 300 | ns |
| $t_{\text {WI }}$ | WRITE to INTR Off |  | 400 |  | 300 | ns |
| ${ }^{\text {t }}$ L | TIMER-IN to TIMER-OUT Low |  | 400 |  | 300 | ns |
| ${ }_{\text {th }}$ | TIMER-IN to TIMER-OUT High |  | 400 |  | 300 | ns |
| $\mathrm{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 |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING: INPUTS ARE DRIVEN AT 2.4 V FOR A LOGIC " 1 " AND 0.45 V FOR A LOGIC "0." TIMING MEASUREMENTS ARE MADE AT 2.0 V FOR A LOGIC " 1 "
AND 0.8 V FOR A LOGIC " 0 ."

## A.C. TESTING LOAD CIRCUIT


$\quad 8185 / 8185-2$
$1024 \times 8$-BIT STATIC RAM FOR MCS-85

## - Multiplexed Address and Data Bus <br> - Directly Compatible with 8085A and IAPX 88 Microprocessors <br> Low Operating Power Dissipation

Low Standby Power Dissipation
Single +5 V Supply
High Density 18-Pin Package


#### Abstract

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 and IAPX 88 microprocessors 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 that is compatible with the $5 \mathrm{MHz} 8085 \mathrm{~A}-2$ and the 5 MHz iAPX 88.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## FUNCTIONAL 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 $A D_{0-7}, A_{8}$ and $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{\mathrm{WR}}$ 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 $\mathrm{CE}_{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} \overline{1}_{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{\mathrm{CE}}_{\mathbf{1}}$ | $\mathbf{C E}_{\mathbf{2}}$ | $\overline{\mathrm{CS}}$ | $\left(\mathbf{C S}^{*}\right)^{[2]}$ | 8185 Status |
| :---: | :---: | :---: | :---: | :--- |
| 1 | X | X | 0 | Power Down and <br> Function Disable $[1]$ |
| X | 0 | X | 0 | Power Down and <br> Function Disable $[1]$ |
| 0 | 1 | 1 | 0 | Powered Up and <br> Function Disable $[1]$ |
| 0 | 1 | 0 | 1 | Powered Up and <br> 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(\mathrm{CE}_{2}=1\right) \cdot(\overline{\mathrm{CS}}=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{\text { RD }}$ | $\overline{\text { WR }}$ | AD <br> AD-7 D 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 3. 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

## iAPX 88 FIVE CHIP SYSTEM:

- 1.25 K Bytes RAM
- 2 K Bytes ROM
- 38 I/O Pins
- 1 Internal Timer
- 2 Interrupt Levels


Figure 4. iAPX 88 Five Chip System Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias |  |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin with Respect to Ground | -0.5 V to +7V |
| ower Dissipation | ........ 1.5W |

*NOTICE: 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 | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{H}}$ | Input High Voltage | 2.0 | Vcc+0.5 | V |  |
| VOL | Output Low Voltage |  | 0.45 | V | $1 \mathrm{LL}=2 \mathrm{~mA}$ |
| VoH | Output High Voltage | 2.4 |  |  | $1 \mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | OV $\leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq$ VOUT $^{5} \mathrm{~V}$ CC |
| Icc | Vcc Supply Current Powered Up Powered Down |  | 100 | mA |  |

## 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 | 8185 |  | 8185-2 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | 30 |  | ns |
| tLA | Address Hold Time After Latch | 80 |  | 30 |  | ns |
| tic | 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 |
| talce | Chip Enable Set Up to ALE Falling | 30 |  | 10 |  | ns |
| tlace | Chip Enable Hold Time After ALE | 50 |  | 30 |  | ns |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORM



# 8205 <br> HIGH SPEED 1 OUT OF 8 BINARY DECODER 

- I/O Port or Memory Selector
- Simple Expansion - Enable Inputs
- High Speed Schottky Bipolar Technology - 18ns Max. Delay
- Directly Compatible with TTL Logic Circuits
- Low Input Load Current - . 25 mA max., 1/6 Standard TTL Input Load
- Minimum Line Reflection - Low Voltage Diode Input Clamp
- Outputs Sink 10 mA min.
- 16-Pin Dual-In-Line Ceramic or Plastic Package

The Intel ${ }^{(8)} 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 8 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 8 other decoders for arbitrary memory expansions.
The 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 diffussion process.


| ADDRESS |  |  | ENABLE |  |  | $\cdots$ OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0}$ | $A_{1}$ | $\mathrm{A}_{2}$ | $\mathrm{E}_{1}$ | $\mathrm{E}_{2}$ | $E_{3}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 1 |
| L | L | L | L | L | H | L | H | H | H | H | H | H | H |
| H | $L$ | 1 | L | L | H | H | 1 | H | H | H | H | H | H |
| L | H | 1 | L | 1 | H | H | H | L | H | H | H | H | H |
| H | H | 1 | L | L | H | H | H | H | L | H | H | H | H |
| L | L | H | L | L | H | H | H | H | H | L | H | H | H |
| H | L | H | L | L | H | H | H | H | H | H | L. | H | H |
| 1 | H | H | L | L | H | H | H | H | H | H | H | 1 | H |
| H | H | H | 1 | 1 | H | H | H | H | H | H | H | H | 1 |
| $x$ | x | $\times$ | L | $L$ | L | H | H | H | H | H | H | H | H |
| $x$ | X | $\times$ | H | L | L | H | H | H | H | H | H | H | H |
| $\times$ | $\times$ | $\times$ | L | H | $L$ | H | H | H | H | H | H | H | H |
| X | X | $\times$ | H | H | L | H | H | H | H | H | H | H | H |
| x | x | $\times$ | H | 1 | H | H | H | H | H | H | H | H | H |
| x | x | x | L | H | H | H | H | H | H | H | H | H | H |
| $\times$ | x | $\times$ | H | H | H | H | H | H | H | H | H | H | H |


| $A_{0} \cdot A_{2}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{E_{1}} \cdot \overline{E_{3}}$ | ENABLE INPUTS |
| $\overline{\sigma_{0}} \cdot \overline{\sigma_{7}}$ | DECODED OUTPUTS |

Figure 1. Logic Symbol
Figure 2. Pin Configuration

## FUNCTIONAL DESCRIPTION

## Decoder

The 8205 contains a one out of eight binary decoder. It accepts a three bit binary code and by gating this input, creates an exclusive output that represents the value of the input code.

For example, if a binary code of 101 was present on the AO, A1 and A2 address input lines, and the device was enabled, an active low signal would appear on the $\overline{05}$ output line. Note that all of the other output pins are sitting at a logic high, thus the decoded output is said to be exclusive. The decoders outputs will follow the truth table shown below in the same manner for all other input variations.

## Enable Gate

When using a decoder it is often necessary to gate the outputs with timing or enabling signals so that the exclusive output of the decoded value is synchronous with the overall system.
The 8205 has a built-in function for such gating. The three enable inputs ( $\overline{E 1}, \overline{E 2}, E 3$ ) are ANDed together and create a single enable signal for the decoder. The combination of both active "high" and active "low" device enable inputs provides the designer with a powerfully flexible gating function to help reduce package count in his system.


Figure 3. Enable Gate

| ADDRESS |  |  | ENABLE |  |  | OUTPUTS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{A}_{0}$ | $A_{1}$ | $\mathrm{A}_{2}$ | $E_{1}$ | $\mathrm{E}_{2}$ | $E_{3}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| L | L | L | L | L | H | L | H | H | H | H | H | H | H |
| H | L | L | L | L | H | H | L | H | H | H | H | H | H |
| L | H | L | L | L | H | H | H | L | H | H | H | H | H |
| H | H | L | L | L | H | H | H | H | L | H | H | H | H |
| L | L | H | L | L | H | H | H | H | H | L | H | H | H |
| H | L | H | L | L | H | H | H | H | H | H | L | H | H |
| L | H | H | L | L | H | H | H | H | H | H | H | L | H |
| H | H | H | L | L | H | H | H | H | H | H | H | H | L |
| X | X | 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$ | X | L | H | L | H | H | H | H | H | H | H | H |
| $x$ | X | X | H | H | L | H | H | H | H | H | H | H | H |
| $x$ | X | X | H | L | H | H | H | H | H | H | H | H | H |
| $x$ | x | $x$ | L | H | H | H | H | H | H | H | H | H | H |
| X | X | X | H | H | H | H | H | H | H | H | H | H | H |

## Applications of the $\mathbf{8 2 0 5}$

The 8205 can be used in a wide variety of applications in microcomputer systems. $1 / 0$ 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 (SO, 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 I/O ports or any other decoder related application.

Note that no external gating is required to decode up to 24 exclusive devices and that a simple addition of an inverter or two will allow expansion to even larger decoder networks.

## CHIP SELECT DECODER

Using a very similar circuit to the I/O port decoder, an ar-


Figure 4. 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. 2708s and 2114As are 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 8205s. 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).


Figure 5. 24K Memory Interface

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias:
Ceramic ............................... $-65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Plastic .................................. $-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
*NOTICE: 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 $+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ )

| Symbol | Parameter | Limit |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $I_{F}$ | INPUT LOAD CURRENT |  | -0.25 | mA | $\mathrm{V}_{C C}=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 | $\checkmark$ | $\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 |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| Isc | 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 @ HIGH CURRENT |  | 0.8 | v | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, 1_{0 x}=40 \mathrm{~mA}$ |
| ${ }^{\prime} \mathrm{CC}$ | POWER SUPPLY CURRENT |  | 70 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |

A.C. CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$; unless otherwise specified)

| Symbol | Parameter | Max. Limit | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: |
| $\dagger_{++}$ | ADDRESS OR ENABLE TO OUTPUT DELAY | 18 | ns |  |
| $\mathrm{t}_{-+}$ |  | 18 | ns |  |
| $t_{+}$ |  | 18 | ns |  |
| t- |  | 18 | ns |  |
| $\mathrm{CIN}^{1{ }^{(1)}}$ | INPUT CAPACITANCE $\frac{\text { P8205 }}{\text { C8205 }}$ | 4(typ.) | pF | $\begin{aligned} & f=1 \mathrm{MHZ}, V_{C C}=0 \mathrm{~V} \\ & V_{B I 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



## TYPICAL CHARACTERISTICS (Continued)



## SWITCHING CHARACTERISTICS

TEST LOAD


WAVEFORMS


# 8212 <br> 8-BIT INPUT/OUTPUT PORT 

Fully Parallel 8-Bit Data Register and Buffer<br>- Service Request Flip-Flop for Interrupt Generation<br>■ Low Input Load Current - . 25mA Max.<br>- Three State Outputs<br>■ Outputs Sink 15 mA

3.65V Output High Voltage for Direct Interface to 8008, 8080A, or 8085A CPU<br>■ Asynchronous Register Clear<br>- Replaces Buffers, Latches and Multiplexers in Microcomputer Systems<br>- 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.


Figure 1. Logic Diagram


| DIt. d $_{4}$ | DATA IN |
| :---: | :---: |
| $\mathrm{DO}_{1} \cdot \mathrm{DO}_{8}$ | DATA OUT |
| $\mathrm{DS}_{1}-\mathrm{DS}_{2}$ | DEVICE SELECT |
| MD | MODE |
| STB | STROBE |
| INT | INTERRUPT (ACTIVE LOW) |
| CLR | CLEAR (ACTIVE LOW) |

Figure 2. Pin Configuration

## 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 (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{DS} 1} \cdot \mathrm{DS} 2$ ).
When MD is low (input mode) the output buffer state is determined by the device selection logic ( $\overline{\mathrm{DS} 1} \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 CLR 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 ( $\overline{\mathrm{DS} 1}$. DS2). The output of the "NOR" gate (INT) is active low (interrupting state) for connection to active low input priority generating circuits.


## 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
*NOTICE: 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.+75^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{Cc}}=+5 \mathrm{~V} \pm 5 \%\right)$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| If | Input Load Current, ACK, DS2, CR, DIt-Dls Inputs |  |  | -. 25 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| IF | Input Load Current MD Input |  |  | -. 75 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current DS1 Input |  |  | -1.0 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| IR | Input Leakage Current, ACK, DS, CR, Dli-Dlı Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IR | 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 | IC $=-5 \mathrm{~mA}$ |
| VIL | Input "Low" Voltage |  |  | . 85 | V |  |
| VIH | Input "High" Voltage | 2.0 |  |  | V |  |
| Vol | Output "Low" Voltage |  |  | . 45 | V | $\mathrm{IOL}=15 \mathrm{~mA}$ |
| V OH | 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{Vcc}=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 |  |

CAPACITANCE* $\quad\left(F=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}\right.$,
$V_{C C}=+5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

| Symbol | Test | Limits |  |
| :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |
| CIN | DS1 MD Input Capacitance | 9pF | 12pF |
| CIN | $\mathrm{DS}_{2}, \overline{\mathrm{CLR}}, \mathrm{STB}, \mathrm{DI}_{1}-\mathrm{DI}_{8}$ <br> Input Capacitance | 5 pF | 9pF |
| Cout | DO1-DO8 Output Capacitance | 8pF | 12pF |

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

## A.C. TESTING LOAD CIRCUIT

## SWITCHING CHARACTERISTICS

## Conditions of Test

Input Pulse Amplitude $=2.5 \mathrm{~V}$
Input Rise and Fall Times 5ns
Between 1V and 2V Measurements made at 1.5V with 15 mA and 30 pF Test Load

NOTE:

| Test | $C_{L}{ }^{*}$ | $\mathrm{R}_{1}$ | $\mathrm{R}_{2}$ |
| :---: | :---: | :---: | :---: |
| tpd, twe, tr, ts, tc | 30pF | $300 \Omega$ | $600 \Omega$ |
| $t E, ~ E N A B L E \dagger$ | 30pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| te, ENABLE \ | 30pF | $300 \Omega$ | $600 \Omega$ |
| te, DISABLE $\dagger$ | 5pF | $300 \Omega$ | $600 \Omega$ |
| te, DISABLE | 5pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

*Includes probe and jig capacitance.

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

## APPLICATIONS

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


Figure 3. Basic Schematic Symbols

## 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 $\overline{\text { 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.


Figure 4. Gated Buffer

## Bi-Directional Bus Driver

A pair of 8212's wired (back-to-back) can be used as a symmetrical drive, bi-directional bus driver. The devices are controlled by the data bus input control which is connected to $\overline{\mathrm{DS1}}$ on the first 8212 and to DS2 on the second. One device is active, and acting as a straight through buffer the other is in 3-state mode. This is a very useful circuit in small system design.


Figure 5. Bidirectional Bus Driver

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


Figure 6. Interrupting Input Port

## 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{S} 1}$ could be used to multiplex a variety of interrupt instruction ports onto a common bus).


Figure 7. Interrupt Instruction Port

## 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}} \cdot \mathrm{DS} 2)$


Figure 8. Output Port

8212

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

## TYPICAL CHARACTERISTICS



WAVEFORMS


## 8216/8226 <br> 4-BIT PARALLEL BIDIRECTIONAL BUS DRIVER

Data Bus Buffer Driver for $\mathbf{8 0 8 0}$ 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

\author{

- 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{l}_{\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.


Figure 1. Block Diagrams
Figure 2. Pin Configuration

## 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{\text { CS }}$

The $\overline{\mathrm{CS}}$ input is actually a device select. When it is "high" the output drivers are all forced to their high-impedance state. When it is at "zero" the device is selected (enabled) and the direction of the data flow is determined by the $\overline{\text { DIEN }}$ input.

The DIEN input controls the direction of data flow (see Figure 3) 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.


Figure 3a. 8216 Logic Diagram


Figure 3b. 8226 Logic Diagram

8216/8226

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ All Output and Supply Voltages . . . . . . . -0.5 V to +7 V All Input Voltages . . . . . . . . . . . . . . . -1.0 V to $\mathbf{+ 5 . 5 \mathrm { V }}$
Output Currents $\qquad$
*NOTICE: 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}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%\right)$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $l_{\text {F }} 1$ | Input Load Current $\overline{\text { DIEN, }} \overline{\text { CS }}$ |  | -0.15 | -. 5 | mA | $\mathrm{V}_{\mathrm{F}}=0.45$ |
| $\mathrm{I}_{\text {F } 2}$ | Input Load Current All Other Inputs |  | -0.08 | -. 25 | mA | $V_{F}=0.45$ |
| $\mathrm{I}_{\mathbf{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 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | . 95 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| 1101 | Output Leakage Current DO <br> (3-State) DB |  |  | $\begin{gathered} 20 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=0.45 \mathrm{~V} / 5.25 \mathrm{~V}$ |
| Icc | Power Supply Current |  | 95 | 130 | mA |  |
|  |  |  | 85 | 120 | mA |  |
| $\mathrm{V}_{\text {OLI }}$ | Output "Low" Voltage |  | 0.3 | . 45 | V | DO Outputs $\mathrm{IOL}_{\mathrm{O}}=15 \mathrm{~mA}$ <br> DB Outputs $I_{\mathrm{OL}}=25 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output "Low" Voltage |  | 0.5 | . 6 | V | DB Outputs $\mathrm{l}_{\mathrm{OL}}=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}^{\text {a }}=-10 \mathrm{~mA}$ |
| los | Output Short Circuit Current | $\begin{aligned} & -15 \\ & -30 \end{aligned}$ | $\begin{aligned} & -35 \\ & -75 \end{aligned}$ | $\begin{gathered} -65 \\ -120 \end{gathered}$ | $\begin{aligned} & m A \\ & m A \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 $\mathrm{T}_{\mathrm{A}}=\mathbf{2 5}{ }^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.

8216/8226

CAPACITANCE ${ }^{[5]} \quad\left(\mathrm{V}_{\text {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}\right)$

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. 11 ] | Max. |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 4 | 8 | pF |
| Couti | Output Capacitance |  | 6 | 10 | pF |
| Cout2 | Output Capacitance |  | 13 | 18 | pF |

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 | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max. |  |  |
| TPD1 | Input to Output Delay DO Outputs |  | 15 | 25 | ns | $\begin{aligned} & C_{L}=30 \mathrm{pF}, \mathrm{R}_{1}=300 \Omega \\ & R_{2}=600 \Omega \end{aligned}$ |
| TPD2 | Input to Output Delay DB Outputs 8216 |  | 19 | 30 | ns | $\begin{aligned} & C_{L}=300 p F, R_{1}=90 \Omega \\ & R_{2}=180 \Omega \end{aligned}$ |
|  | 8226 |  | 16 | 25 | ns. |  |
| $\mathrm{T}_{\mathrm{E}}$ | Output Enable Time $\begin{array}{r} \\ \\ \\ \hline 8216\end{array}$ | , | 42 | $65$ | ns | (Note 2) |
|  |  |  | 36 | 54 | ns | (Note 3) |
| TD | Output Disable Time |  | 16 | 35 | ns | (Note 4) |

NOTE:
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.

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}$.
2. DO Outputs, $C_{L}=30 p F, R_{1}=300 / 10 \mathrm{~K} \Omega, R_{2}=180 / 1 \mathrm{~K} \Omega ; D B$ Outputs, $C_{L}=300 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}$; DB 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.

## A.C. TESTING LOAD CIRCUIT



WAVEFORM


## 8218/8219 <br> BIPOLAR MICROCOMPUTER BUS CONTROLLERS FOR MCS-80 ${ }^{\circledR}$ AND MCS-85 ${ }^{\circledR}$ FAMILIES

- 8218 for Use in MCS-80 ${ }^{\circledR}$ Systems
- 8219 for Use inMCS-85 ${ }^{\circledR}$ Systems
- 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 I/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.


Figure 1. Block Diagram


|  | 8218 | 8219 |
| :---: | :---: | :---: |
| (A) | $\overline{\text { IOWR }}$ | $10 / \bar{M}$ |
| (B) | MWTR | WR |
| (C) | $\overline{\text { IORR }}$ | $\overline{\mathrm{RD}}$ |
| (D) | $\overline{\text { MRDR }}$ | $\overline{\text { ASRO }}$ |
| (E) | $\overline{B C R 2}$ | BCR2 |

N.C. = NO CONNECT

Figure 2. Pin Configuration

Table 1. Pin Description

| Signals Interfaced Directly to the System Bus |  |  |
| :---: | :---: | :---: |
| Symbol | Type | Name and Function |
| $\overline{\text { BREQ }}$ | 0 | Bus Request: 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. |
| BUSY | I/O | Bus Busy: 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 }}$ | 1 | Bus Clock: The negative edge of Bus Clock is used to synchronize the bus contention resolution circuit asynchronously to the CPU clock. It has 100 ns min. period, $35 \%-$ $65 \%$ duty cycle. It may be slowed, single stepped or stopped. |
| $\overline{\text { BPRN }}$ | 1 | Bus Priority In: 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 }}$ | 0 | Bus Priority Out: The Bus Priority Out is used with serial priority resolution circuits. Priority may be transferred to the next lower in priority as BPRN. |
| INIT | 1 | Initialize: The Initialize resets the 8218/ 8219 to a known internal state. |
| $\overline{\text { MRDC }}$ | 0 | Memory Read Control: The Memory Read Control indicates that the Master is requesting a read operation from the addressed location. It is asynchronous to the Bus Clock. |
| $\overline{\text { MWTC }}$ | 0 | Memory Write Control: 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 { ORC }}$ | 0 | I/O Read Control: 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 | 0 | I/O Write Control: The I/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. It is asynchronous to the Bus Clock. |
| Signals Generated or Received by the Bus Master |  |  |
| $\frac{\text { BCR1/ }}{\text { BCR2 }}$ | 1 | Bus Control Request: 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{B C R 2}$ ). BCR2 is active high in the 8219. |
| RSTB | 1 | Request Strobe: Request Strobe latches the status of BCR1 and BCR2 into the $8218 / 8219$. The strobe is active low in the 8218 and negative edge triggered in the 8219. |


| Signals Generated or Recelved by the Bus Master (Continued) |  |  |
| :---: | :---: | :---: |
| Symbol | Type | Name and Function |
| ADEN | $\bigcirc$ | Address and Data Enable: 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 | 0 | Read Data: 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 | 1 | Override: 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 | 1 | Transfer Start Request: 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}$ | 1 | Transfer Complete: 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{X C Y}$ | 0 | Data Transfer: Indicates that a data transfer is in progress. It is asynchronous to the Bus Clock. |
| $\overline{\mathrm{WR}}, \overline{\mathrm{RD}},$ $10 / \overline{\bar{M}}$ | 1 | Write, Read, IO/Memory: WRITE, READ, IO/Memory are the control request inputs used by the 8085 and are internally decoded by the 8219 to produce the request signals $\overline{\text { MRDR }}, \overline{\text { MWTR, IORR, }} \overline{\text { IOWR. }}$. They are asynchronous to the Bus Clock. (8219 only) |
| $\overline{\text { ASRQ }}$ | 1 | Asynchronous Bus Request: 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. (8219 only) |
| $\overline{\text { MRDR }}$, <br> MWTR, <br> IORR, <br> $\overline{\text { IOWR }}$ | 1 | Memory Read Request, Memory Write Request, I/O Read Request, or I/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 synchronous to the Bus Clock. (8218 only) |
| ANYR | 0 | Any Request: 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 | 1 | Delay Adjust: 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. |

## 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 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{B P R O}$ 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 BPRN 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 3a.


Figure 3a. 8218 Bus Arbitration Logic


Figure 3b. 8219 Bus Arbitration Logic

## Timing Logic

Timing Logic activity begins with the rising edge of XSTR (Transfer Start Request) or with $\overline{A D E N}$ going active, whichever occurs second. This action causes $\overline{\mathrm{XCY}}$ (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{X C P}$ (Transfer Complete) will cause the Control Outputs (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 4 a and 4 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 4a. 8218 Control Logic


Figure 4b. 8219 Control Logic

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots \ldots .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
*NOTICE: 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. | Max. |  |  |
| VC | Input Clamp Voltage |  |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=0.0 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| IF | $\begin{aligned} & \text { Input Load Current } \\ & \overline{M R D R} / \overline{\overline{N T A} / \overline{M W T R} / \overline{W R}} \\ & \overline{\text { IORR} / R D}, \text { IOWR/IO/ } \bar{M} \end{aligned}$ |  |  | -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}_{\mathrm{cc}}=5 \mathrm{~V}$ |
| Icc | Power Supply Current |  | 200 | 240 | mA | $\mathrm{V}_{\mathrm{cc}}=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 | $1 \mathrm{OL}=32 \mathrm{~mA}$ |
|  |  |  |  | 0.45 | V | $1 \mathrm{OL}=20 \mathrm{~mA}$ |
|  |  |  |  | 0.45 | V | $\mathrm{lOL}=16 \mathrm{~mA}$ |
|  |  |  |  | 0.45 | V | $\mathrm{IOL}=3.2 \mathrm{~mA}$ |
| V OH | Output High Voltage <br> $\overline{M R D C}, \overline{M W T C}, \overline{I O R C}, \overline{\text { IOWC }}$ <br> All Other Outputs |  |  |  |  | $\mathrm{V}_{\mathrm{cc}}=4.75 \mathrm{~V}$ |
|  |  | 2.4 |  |  |  | $1 \mathrm{OH}=-2 \mathrm{~mA}$ |
|  |  | 2.4 |  |  |  | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| los | Short Circuit Output Current | -10 |  | -90 | mA | $\mathrm{Vcc}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0 \mathrm{~V}$ |
| Io (OFF) | Tri-State Output Current |  |  | -100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{cc}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=0.45 \mathrm{~V}$ |
|  |  |  |  | +100 | $\mu \mathrm{A}$ | $\mathrm{Vcc}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{O}}=5.25 \mathrm{~V}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance Except Busy |  | 10 | 20 | pF |  |
| $\mathrm{C}_{10}$ | Input Capacitance Busy |  | 25 | 35 | pF |  |


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. |  |  |
| $\mathrm{t}_{\mathrm{BCY}}$ | Bus Clock Cycle Time | 100 |  |  | ns | 35\% to 65\% Duty Cycle |
| tpw | Bus Clock Puise Width | 35 |  | 0.65 tBCY | ns |  |
| tras | $\overline{\mathrm{RSTB}}$ to $\overline{\mathrm{BCLK}}$ Set-Up Time | 25 |  |  | ns |  |
| tcss | $\mathrm{BCR}_{1}$ and $\overline{\mathrm{BCR}}_{2}$ to $\overline{\mathrm{RSTB}}$ Set-Up Time | 15 |  |  | ns |  |
| tcser | $\mathrm{BCR}_{1}$ and $\overline{\mathrm{BCR}}_{2}$ to $\overline{\mathrm{RSTB}}$ Hold Time | 15 |  |  | ns |  |
| trad | $\overline{\text { BCLK }}$ to $\overline{B R E Q}$ 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 |  |
| tBYD | $\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{\text { MRDC }}, \overline{M W T C}, \overline{I O R C}$, IOWC Delay | 50 |  | 200 | ns | Adjustable by External R/C |
| txsw | XSTR Pulse Width | 30 |  |  | ns |  |
| txCD | $\overline{\mathrm{XCP}}$ to $\overline{\mathrm{MRDC}}, \overline{\mathrm{MWTC}}, \overline{\mathrm{IORC}}$, IOWC Delay |  |  | 50 | ns |  |
| txcw | $\overline{\mathrm{XCP}}$ Pulse Width | 35 |  |  | ns |  |
| tcCD | $\overline{\mathrm{XCP}}$ to $\overline{\mathrm{XCY}}$ Delay | 50 |  | 200 | ns | Adjustable by External R/C |
| tCMD | $\overline{\text { MRDR }}, \overline{\text { MWTR }}, \overline{\text { IORR }}, \overline{\text { IOWR }}$ to $\overline{M R D C}, \overline{M W T C}, \overline{\text { IORC, }} \overline{\text { IOWC }}$ |  |  | 35 | ns |  |
| tcro | $\overline{\text { MRDR, }} \overline{\text { MWTR }}, \overline{\text { IORR }}, \overline{\text { IOWR }}$ to RDD Delay |  |  | 25 | ns |  |
| $t_{\text {RW }}$ | $\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 |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

SYNCHRONOUS BUS TIMING (System Bus Previously Not In Use)


CONTROL CYCLE (System Bus Previously Not In Use)


WAVEFORMS (Continued)

BUS CONTROL EXCHANGE (Master No. 1 Leaving Bus And Master No. 2 Getting On Bus)



MCS-80® CPU With 8218



MCS-85 ${ }^{\circledR}$ CPU With 8219 Using Local Memory


Two Methods of Connecting Multiple 8218/8219's To Resolve Bus Contention Among Multiple Masters

# 8224 <br> CLOCK GENERATOR AND DRIVER FOR 8080A CPU 

\author{

- Single Chip Clock Generator/Driver for 8080A CPU <br> - Power-Up Reset for CPU <br> Ready Synchronizing Flip-Flop <br> Advanced Status Strobe
}
- Oscillator Output for External System Timing
- Crystal Controlled for Stable System Operation
- Reduces System Package Count

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


Figure 1. Block Diagram
Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ Supply Voltage, $\mathrm{V}_{\mathrm{CC}}$. . . . . . . . . . . . . . . . -0.5 V to +7 V Supply Voltage, $\mathrm{V}_{\text {DD }}$. . . . . . . . . . . . . . -0.5 V to +13.5 V Input Voltage . . . . . . . . . . . . . . . . . . . . . . -1.5 V to +7 V Output Current
*NOTICE: 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}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 5 \%\right)$

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Current Loading |  |  | -. 25 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Clamp Voltage |  |  | 1.0 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IL }}$ | Input "Low" Voltage |  |  | . 8 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input "High" Voltage | $\begin{aligned} & 2.6 \\ & 2.0 \end{aligned}$ |  |  | V | Reset Input All Other Inputs |
| $\mathrm{V}_{\text {IH }}-\mathrm{V}_{\text {IL }}$ | 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{IOL}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ <br> All Other Outputs $\mathrm{IOL}_{\mathrm{OL}}=15 \mathrm{~mA}$ |
| V OH | Output "High" Voltage $\phi_{1}, \phi_{2}$ <br> READY, RESET <br> All Other Outputs | $\begin{aligned} & 9.4 \\ & 3.6 \\ & 2.4 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{ISC}^{[1]}$ | Output Short Circuit Current (All Low Voltage Outputs Only) | -10 |  | -60 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \end{aligned}$ |
| 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: $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 $\quad\left(V_{C C}=+5.0 \mathrm{~V} \pm 5 \%, V_{D D}=+12.0 \mathrm{~V} \pm 5 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Limits |  |  | Units | TestConditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $t_{\phi 1}$ | $\phi_{1}$ Pulse Width | $\frac{2 \mathrm{tcy}}{9}-20 \mathrm{~ns}$ |  |  | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ to 50 pF |
| $\mathrm{t}_{\boldsymbol{\phi} \mathbf{2}}$ | $\phi_{2}$ Pulse Width | $\frac{5 t c y}{9}-35 n s$ |  |  |  |  |
| $t_{\text {D1 }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | 0 |  |  |  |  |
| $\mathrm{t}_{\mathrm{D} 2}$ | $\phi_{2}$ to $\phi_{1}$ Delay | $\frac{2 \mathrm{tcy}}{9}-14 \mathrm{~ns}$ |  |  |  |  |
| tD3 | $\phi_{1}$ to $\phi_{2}$ Delay | $\frac{2 \mathrm{tcy}}{9}$ |  | $\frac{2 \mathrm{tcy}}{9}+20 \mathrm{~ns}$ |  |  |
| $\mathrm{t}_{\mathrm{R}}$ | $\phi_{1}$ and $\phi_{2}$ Rise Time |  |  | 20 |  |  |
| $\mathrm{t}_{\mathrm{F}}$ | $\phi_{1}$ and $\phi_{2}$ Fall Time |  |  | 20 |  |  |
| $t_{\text {d }{ }^{\text {2 }} \text { ( }}$ | $\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 \\ & \hline \end{aligned}$ |
| ${ }^{\text {t }}$ SS | $\phi_{2}$ to STSTB Delay | $\frac{6 \mathrm{tcy}}{9}-30 \mathrm{~ns}$ |  | $\frac{6 \mathrm{tcy}}{9}$ |  | $\begin{aligned} & \overline{\text { STSTB }, C L=15 p F} \\ & R_{1}=2 K \\ & R_{2}=4 K \end{aligned}$ |
| tpw | STSTB Pulse Width | $\frac{\text { tcy }}{9}-15 \mathrm{~ns}$ |  |  |  |  |
| ${ }^{\text {t }}$ SRS | RDYIN Setup Time to Status Strobe | $50 \mathrm{~ns}-\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| ${ }_{\text {t }}$ ( ${ }^{\text {H }}$ | RDYIN Hold Time After STSTB | $\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| $t_{\text {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 }}$ LK | 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_{\mathrm{CC}}=+5.0 \mathrm{~V} \\ & V_{D D}=+12 \mathrm{~V} \\ & V_{\mathrm{BIAS}}=2.5 \mathrm{~V} \\ & f=1 \mathrm{MHz} \end{aligned}$ |

## A.C. CHARACTERISTICS (Continued) (For $\left.\mathrm{t}_{\mathrm{CY}}=488.28 \mathrm{~ns}\right)\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 5 \%$, $V_{D D}=+12 \mathrm{~V} \pm 5 \%$ )

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{t}_{\phi 1}$ | $\phi_{1}$ Pulse Width | 89 |  |  | ns | ${ }^{\mathrm{t}} \mathrm{CY}=488.28 \mathrm{~ns}$ |
| $\mathrm{t}_{\phi 2}$ | $\phi_{2}$ Pulse Width | 236 | . |  | ns |  |
| $\mathrm{t}_{\mathrm{D} 1}$ | Delay $\phi_{1}$ to $\phi_{2}$ | 0 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{D} 2}$ | Delay $\phi_{2}$ to $\phi_{1}$ | 95 |  |  | ns | $\phi_{1} \& \phi_{2}$ Loaded to |
| $t_{\text {d }}$ | Delay $\phi_{1}$ to $\phi_{2}$ Leading Edges | 109 |  | 129 | ns | $\mathrm{C}_{\mathrm{L}}=20$ to 50 pF |
| $\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 |  |
| ${ }^{\text {t }}{ }_{\text {d } 22}$ | $\phi_{2}$ to $\phi_{2}$ (TTL) Delay | -5 |  | +15 | ns |  |
| tpw | Status Strobe Pulse Width | 40 |  |  | ns |  |
| t ${ }_{\text {DRS }}$ | RDYIN Setup Time to STSTB | -167 |  |  | ns | to $2 \mathrm{~mA} / 10 \mathrm{pF}$ |
| ${ }^{\text {t }}$ DRH | RDYIN Hold Time after STSTB | 217 |  |  | ns | All measurements |
| ${ }^{\text {t }}$ DR | READY or RESET to $\phi_{2}$ Delay | 192 |  |  | ns | referenced to 1.5 V unless specified otherwise. |
| $f_{\text {MAX }}$ | Oscillator Frequency |  |  | 18.432 | MHz |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



C INCLUDES JIG CAPACITANCE

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

# SYSTEM CONTROLLER AND BUS DRIVER FOR 8080A CPU 

## - Single Chip System Control for MCS-80 ${ }^{\circledR}$ 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 Had Advanced IOW/MEMW for Large System Timing Control

The Intel 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.

Note: The specifications for the $\mathbf{3 2 2 8 / 3 2 3 8}$ are identical with those for the $\mathbf{8 2 2 8 / 8 2 3 8}$


| D7.D0 | DATA BUS (8980 SIDE) |
| :--- | :--- |
| DB7.DB0 | DATA BUS (SYSTEM SIDE) |
| $\overline{\overline{I O R}}$ | I/O READ |
| $\overline{\overline{I O W}}$ | I/O WRITE |
| $\overline{\text { MEMR }}$ | MEMORY READ |
| $\overline{\text { MEMW }}$ | MEMORY WRITE |
| DBIN | DBIN (FROM 8080) |
|  |  |


| INTA | INTERRUPT ACKNOWLEDGE |
| :--- | :--- |
| HLDA | HLDA (FROM BO80) |
| WR | WR (FROM 8080) |
| BUSEN | BUS ENABLE INPUT |
| STSTB | STATUS STROBE (FROM B224) |
| VCC | +5V |
| GND | OVOLTS |

Figure 1. Block Diagram
Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . . $-0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $150^{\circ} \mathrm{C}$ Supply Voltage, $\mathrm{V}_{\text {Cc }}$. . . . . . . . . . . . . . . . . . -0.5 V to +7 V Input Voltage. . . . . . . . . . . . . . . . . . . . . . . . - 1.5 V to +7 V
Output Current. . . . . . . . . . . . . . . . . . . . . . . . . . . . 100 mA
*NOTICE: 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 limited. 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 | 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{l}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current, STSTB |  |  | 500 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=5.25 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
|  | $\mathrm{D}_{2}$ \& $\mathrm{D}_{6}$ |  |  | 750 | $\mu \mathrm{A}$ |  |
|  | $\begin{aligned} & D_{0}, D_{1}, D_{4}, D_{5} \\ & \& D_{7} \end{aligned}$ |  |  | 250 | $\mu \mathrm{A}$ |  |
|  | All Other Inputs |  |  | 250 | $\mu \mathrm{A}$ |  |
| $I_{R}$ | Input Leakage Current $\overline{\text { STSTB }}$ |  |  | 100 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{C C}=5.25 \mathrm{~V} \\ & V_{R}=5.25 \mathrm{~V} \end{aligned}$ |
|  | $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ |  |  | 20 | $\mu \mathrm{A}$ |  |
|  | All Other Inputs |  |  | - 100 | $\mu \mathrm{A}$ |  |
| $\mathrm{V}_{\text {TH }}$ | Input Threshold Voltage, All Inputs | 0.8 |  | 2.0 | V | $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 140 | 190 | mA | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage, $D_{0}-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, $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 3.6 | 3.8 |  | V | $V_{C C}=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}$ |
| lo(off) | Off State Output Current, All Control Outputs |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} ; \mathrm{V}_{\mathrm{O}}=5.25$ |
|  |  |  |  | -100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ |
| IINT | INTA Current |  |  | 5 | mA | (See INTA Test Circuit) |

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

CAPACITANCE ( $\left.\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}\right)$
This parameter is periodically sampled and not $100 \%$ tested.

| Symbol | Parameter | Limits |  |  | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  | Min. | Typ. ${ }^{[1]}$ | Max. | pF |  |
| CIN $^{2}$ | 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 |

A.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 | Limits |  | Units | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $t_{\text {PW }}$ | Width of Status Strobe | 22 |  | ns |  |
| $\mathrm{t}_{\text {SS }}$ | Setup Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 8 |  | ns |  |
| ${ }_{\text {t }} \mathrm{H}$ | Hold Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 5 |  | ns |  |
| $\mathrm{t}_{\mathrm{DC}}$ | Delay from $\overline{\text { 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 | $C_{L}=100 \mathrm{pF}$ |
| $t_{\text {RE }}$ | Delay from DBIN to Enable/Disable 8080 Bus |  | 45 | n's | $\mathrm{C}_{\mathrm{L}}=25 \mathrm{pF}$ |
| $t_{\text {RD }}$ | Delay from System Bus to 8080 Bus during Read |  | 30 | ns | $C_{L}=25 \mathrm{pF}$ |
| twR | Delay from $\overline{W R}$ to Control Outputs | 5 | 45 | ns | $C_{L}=100 \mathrm{pF}$ |
| tWE | Delay to Enable System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ after STSTB | . | 30 | ns | $C_{L}=100 \mathrm{pF}$ |
| ${ }^{\text {twD }}$ | 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}$ |
| $\mathrm{t}_{\mathrm{E}}$ | Delay from System Bus Enable to System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ |  | 30 | ns | $C_{L}=100 \mathrm{pF}$ |
| ${ }^{\text {thD }}$ | HLDA to Read Status Outputs |  | 25 | ns |  |
| ${ }^{\text {t }}$ D | Setup Time, System Bus Inputs to HLDA | 10 |  | ns |  |
| ${ }^{\text {toH }}$ | Hold Time, System Bus Inputs to HLDA | 20 |  | ns | $C_{L}=100 \mathrm{pF}$ |

## A.C. TESTING LOAD CIRCUIT




INTA Test Circuit (for RST 7)

## WAVEFORM



## 8237A/8237A-4/8237A-5 <br> HIGH PERFORMANCE PROGRAMMABLE DMA CONTROLLER

## Enable/Disable Control of Individual DMA Requests

\author{

- Four Independent DMA Channels
}
- Independent Autoinitialization of all Channels


## Memory-to-Memory Transfers

## Memory Block Initialization

## Address Increment or Decrement

# - High performance: Transfers up to 1.6M Bytes/Second with 5 MHz 8237A-5 

## - Directly Expandable to any Number of Channels

## - End of Process Input for Terminating Transfers

\author{

- Software DMA Requests
}


## - Independent Polarity Control for DREQ and DACK Signals

The 8237A Multimode Direct Memory Access (DMA) Controller is a peripheral interface circuit for microprocessor systems. It is designed to improve system performance by allowing external devices to directly transfer information from the system memory. Memory-to-memory transfer capability is also provided. The 8237A offers a wide variety of programmable control features to enhance data throughput and system optimization and to allow dynamic reconfiguration under program control.
The 8237A is designed to be used in conjunction with an external 8 -bit address register such as the 8282. It contains four independent channels and may be expanded to any number of channels by cascading additional controller chips.
The three basic transfer modes allow programmability of the types of DMA service by the user. Each channel can be individually programmed to Autoinitialize to its original condition following an End of Process (EOP).
Each channel has a full 64 K address and word count capability.
The 8237A-4 and 8237A-5 are 4 MHz and 5 MHz selected versions of the standard 3 MHz 8237 A respectively.


Figure 1. Block Diagram
Figure 2.
Pin Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $V_{\text {cc }}$ |  | Power: + 5 volt supply. |
| $V_{\text {SS }}$ |  | Ground: Ground. |
| CLK | 1 | Clock Input: Clock Input controls the internal operations of the 8237A and its rate of data transfers. The input may be driven at up to 3 MHz for the standard 8237A and up to 5 MHz for the 8237A-5. |
| CS | 1 | Chip Select: Chip Select is an active low input used to select the 8237A as an I/O device during the Idle cycle. This allows CPU communication on the data bus. |
| RESET | I | Reset: Reset is an active high input which clears the Command, Status, Request and Temporary registers. It also clears the first/last flip/flop and sets the Mask register. Following a Reset the device is in the idle cycle. |
| READY | 1 | Ready: Ready is an input used to extend the memory read and write pulses from the 8237A to accommodate slow memories or I/O peripheral devices. Ready must not make transitions during its specified setup/hold time. |
| HLDA | 1 | Hold Acknowledge: The active high Hold Acknowledge from the CPU indicates that it has relinquished control of the system busses. |
| DREQ0-DREQ3 | 1 | DMA Request: The DMA Request lines are individual asynchronous channel request inputs used by peripheral circuits to obtain DMA service. In fixed Priority, DREQO has the highest priority and DREQ3 has the lowest priority. A request is generated by activating the DREQ line of a channel. DACK will acknowledge the recognition of DREQ signal. Polarity of DREQ is programmable. Reset intializes these lines to active high. DREQ must be maintained until the corresponding DACK goes active. |
| DB0-DB7 | 1/0 | Data Bus: The Data Bus lines are bidirectional three-state signals connected to the system data bus. The outputs are enabled in the Program condition during the I/O Read to output the contents of an Address register, a Status register, the Temporary register or a Word Count register to the CPU. The outputs are disabled and the inputs are read during an I/O Write cycle when the CPU is programming the 8237A control registers. During DMA cycles the most significant 8 bits of the address are output onto the data bus to be strobed into an external latch by ADSTB. In mem- |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
|  |  | ory-to-memory operations, data from the memory comes into the 8237A on the data bus during the read-from-memory transfer. In the write-to-memory transfer, the data bus outputs place the data into the new memory location. |
| $\overline{\text { IOR }}$ | 110 | I/O Read: I/O Read is a bidirectional active low three-state line. In the Idle cycle, it is an input control signal used by the CPU to read the control registers. In the Active cycle, it is an output control signal used by the 8237A to access data from a peripheral during a DMA Write transfer. |
| $\overline{\text { 10W }}$ | 110 | I/O Write: I/O Write is a bidirectional active low three-state line. In the Idle cycle, it is an input control signal used by the CPU to load in formation into the 8237A. In the Active cycle, it is an output control signal used by the 8237A to load data to the peripheral during a DMA Read transfer. |
| $\overline{\text { EOP }}$ | 1/0 | End of Process: End of Process is an active low bidirectional signal. Information concerning the completion of DMA services is avail able at the bidirectional $\overline{\text { EOP }}$ pin. The 8237A allows an external sig. nal to terminate an active DMA service. This is accomplished by pulling the $\overline{E O P}$ input low with an external $\overline{E O P}$ signal. The 8237A also generates a pulse when the terminal count (TC) for any channel is reached. This generates an EOP signal which is output through the $\overline{E O P}$ Line. The reception of EOP, either internal or external, will cause the 8237A to terminate the service, reset the request, and, if Autoinitialize is enabled, to write the base registers to the current registers of that channel. The mask bit and TC bit in the status word will be set for the currently active channel by EOP unless the channel is programmed for Autoinitialize. In that case, the mask bit remains clear. During memory-to-memory transfers, $\overline{E O P}$ will be output when the TC for channel 1 occurs. EOP should be tied high with a pull-up resistor if it is not used to prevent erroneous end of process inputs. |
| A0-A3 | 1/0 | Address: The four least significant address lines are bidirectional three-state signals. In the Idle cycle they are inputs and are used by the 8237A to address the control register to be loaded or read. In the Active cycle they are outputs and provide the lower 4 bits of the output address. |

Table 1. Pin Description (Continued)

| Symbol | Type | Name and Function |
| :--- | :---: | :---: |
| A4-A7 | O | $\begin{array}{l}\text { Address: The four most significant } \\ \text { address lines are three-state out- } \\ \text { puts and provide 4 bits of address. } \\ \text { These lines are enabled only during } \\ \text { the DMA service. }\end{array}$ |
| HRQ | O | $\begin{array}{l}\text { Hold Request: This is the Hold Re- } \\ \text { quest to the CPU and is used to re- } \\ \text { quest control of the system bus. If } \\ \text { the corresponding mask bit is } \\ \text { clear, the presence of any valid } \\ \text { DREQ causes 8237A to issue the } \\ \text { HRQ. After HRQ goes active at }\end{array}$ |
| least one clock cycle (TCY) must |  |  |
| occur before HLDA goes active. |  |  |$\}$

## FUNCTIONAL DESCRIPTION

The 8237A block diagram includes the major logic blocks and all of the internal registers. The data interconnection paths are also shown. Not shown are the various control signals between the blocks. The 8237A contains 344 bits of internal memory in the form of registers. Figure 3 lists these registers by name and shows the size of each. A detailed description of the registers and their functions can be found under Register Description.

| Name | Size | Number |
| :--- | :---: | :---: |
| Base Address Registers | 16 bits | 4 |
| Base Word Count Registers | 16 bits | 4 |
| Current Address Registers | 16 bits | 4 |
| Current Word Count Registers | 16 bits | 4 |
| Temporary Address Register | 16 bits | 1 |
| Temporary Word Count Register | 16 bits | 1 |
| Status Register | 8 bits | 1 |
| Command Register | 8 bits | 1 |
| Temporary Register | 8 bits | 1 |
| Mode Registers | 6 bits | 4 |
| Mask Register | 4 bits | 1 |
| Request Register | 4 bits | 1 |

Figure 3. 8237A Internal Registers
The 8237A contains three basic blocks of control logic. The Timing Control block generates internal timing and external control signals for the 8237A. The Program Command Control block decodes the various commands given to the 8237A by the microprocessor prior to servicing a DMA Request. It also decodes the Mode Control word used to select the type of DMA during the servicing. The Priority Encoder block resolves priority contention between DMA channels requesting service simultaneously.

The Timing Control block derives internal timing from the clock input. In 8237A systems this input will usually

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| AEN | 0 | $\begin{array}{l}\text { Address Enable: Address Enable } \\ \text { enables the 8-bit latch containing } \\ \text { the upper 8 address bits onto the } \\ \text { system address bus. AEN can also } \\ \text { be used to disable other system bus } \\ \text { drivers during DMA transfers. AEN } \\ \text { is active HIGH. }\end{array}$ |
| ADSTB | O | $\begin{array}{l}\text { Address Strobe: The active high, } \\ \text { Address Strobe is used to strobe the } \\ \text { upper address byte into an external } \\ \text { latch. }\end{array}$ |
| MEMR | O | $\begin{array}{l}\text { Memory Read: The Memory Read } \\ \text { signal is an active low three-state } \\ \text { output used to access data from the } \\ \text { selected memory location during a } \\ \text { DMA Read or a memory-to-memory } \\ \text { transfer. }\end{array}$ |
| MEMW | O | $\begin{array}{l}\text { Memory Write: The Memory Write } \\ \text { is an active low three-state output }\end{array}$ |
| used to write data to the selected |  |  |$\}$| memory location during a DMA |
| :--- |
| Write or a memory-to-memory |
| transfer. |

be the $\phi 2$ TTL clock from an 8224 or CLK from an 8085AH or 8284A. For 8085AH-2 systems above 3.9 MHz , the 8085 CLK(OUT) does not satisfy $8237 \mathrm{~A}-5$ clock LOW and HIGH time requirements. In this case, an external clock should be used to drive the 8237A-5.

## DMA Operation

The 8237A is designed to operate in two major cycles. These are called Idle and Active cycles. Each device cycle is made up of a number of states. The 8237A can assume seven separate states, each composed of one full clock period. State $\mathrm{I}(\mathrm{SI})$ is the inactive state. It is entered when the 8237A has no valid DMA requests pending. While in SI , the DMA controller is inactive but may be in the Program Condition, being programmed by the processor. State $\mathrm{SO}(\mathrm{SO})$ is the first state of a DMA service. The 8237A has requested a hold but the processor has not yet returned an acknowledge. The 8237A may still be programmed until it receives HLDA from the CPU. An acknowledge from the CPU will signal that DMA transfers may begin. S1, S2, S3 and S4 are the working states of the DMA service. If more time is needed to complete a transfer than is available with normal timing, wait states (SW) can be inserted between S2 or S3 and S4 by the use of the Ready line on the 8237A. Note that the data is transferred directly from the I/O device to memory (or vice versa) with $\overline{\text { IOR }}$ and $\overline{\text { MEMW }}$ (or $\overline{M E M R}$ and IOW) being active at the same time. The data is not read into or driven out of the 8237A in I/O-tomemory or memory-to-I/O DMA transfers.
Memory-to-memory transfers require a read-from and a write-to-memory to complete each transfer. The states, which resemble the normal working states, use two digit numbers for identification. Eight states are required for a single transfer. The first four states (S11, $\mathrm{S} 12, \mathrm{~S} 13, \mathrm{~S} 14$ ) are used for the read-from-memory half
and the last four states (S21, S22, S23, S24) for the write-to-memory half of the transfer.

## IDLE CYCLE

When no channel is requesting service, the 8237A will enter the Idle cycle and perform "SI" states. In this cycle the 8237A will sample the DREQ lines every clock cycle to determine if any channel is requesting a DMA service. The device will also sample $\overline{C S}$, looking for an attempt by the microprocessor to write or read the internal registers of the 8237A. When $\overline{\mathrm{CS}}$ is low and HLDA is low, the 8237A enters the Program Condition. The CPU can now establish, change or inspect the internal definition of the part by reading from or writing to the internal registers. Address lines A0-A3 are inputs to the device and select which registers will be read or written. The $\overline{I O R}$ and $\overline{\mathrm{IOW}}$ lines are used to select and time reads or writes. Due to the number and size of the internal registers, an internal flip-flop is used to generate an additional bit of address. This bit is used to determine the upper or lower byte of the 16 -bit Address and Word Count registers. The flip-flop is reset by Master Clear or Reset. A separate software command can also reset this flip-flop.

Special software commands can be executed by the 8237A in the Program Condition. These commands are decoded as sets of addresses with the $\overline{\mathrm{CS}}$ and $\overline{\mathrm{IOW}}$. The commands do not make use of the data bus. Instructions include Clear First/Last Flip-FLop and Master Clear.

## ACTIVE CYCLE

When the 8237A is in the Idle cycle and a non-masked channel requests a DMA service, the device will output an HRQ to the microprocessor and enter the Active cycle. It is in this cycle that the DMA service will take place, in one of four modes:

Single Transfer Mode - In Single Transfer mode the device is programmed to make one transfer only. The word count will be decremented and the address decremented or incremented following each transfer. When the word count "rolls over" from zero to FFFFH, a Terminal Count (TC) will cause an Autoinitialize if the channel has been programmed to do so.

DREQ must be held active until DACK becomes active in order to be recognized. If DREQ is held active throughout the single transfer, HRQ will go inactive and release the bus to the system. It will again go active and, upon receipt of a new HLDA, another single transfer will be performed, in 8080A, 8085AH, 8088, or 8086 system this will ensure one full machine cycle execution between DMA transfers. Details of timing between the 8237A and other bus control protocols will depend upon the characteristics of the microprocessor involved.

Block Transfer Mode - In Block Transfer mode the device is activated by DREQ to continue making transfers during the service until a TC, caused by word count going to FFFFH, or an external End of Process ( $\overline{\mathrm{EOP}})$ is encountered. DREQ need only be held active until DACK
becomes active. Again, an Autoinitialization will occur at the end of the service if the channel has been programmed for it.

Demand Transfer Mode - In Demand Transfer mode the device is programmed to continue making transfers until a TC or external $\overline{E O P}$ is encountered or until DREQ goes inactive. Thus transfers may continue until the I/O device has exhausted its data capacity. After the I/O device has had a chance to catch up, the DMA service is re-established by means of a DREQ. During the time between services when the microprocessor is allowed to operate, the intermediate values of address and word count are stored in the 8237A Current Address and Current Word Count registers. Only an EOP can cause an Autoinitialize at the end of the service. $\overline{E O P}$ is generated either by TC or by an external signal.

Cascade Mode - This mode is used to cascade more than one 8237A together for simple system expansion. The HRQ and HLDA signals from the additional 8237A are connected to the DREQ and DACK signals of a channel of the initial 8237A. This allows the DMA requests of the additional device to propagate through the priority network circuitry of the preceding device. The priority chain is preserved and the new device must wait for its turn to acknowledge requests. Since the cascade channel of the initial 8237A is used only for prioritizing the additional device, it does not output any address or control signals of its own. These could conflict with the outputs of the active channel in the added device. The 8237A will respond to DREQ and DACK but all other outputs except HRQ will be disabled.

Figure 4 shows two additional devices cascaded into an initial device using two of the previous channels. This forms a two level DMA system. More 8237As could be added at the second level by using the remaining channels of the first level. Additional devices can also be added by cascading into the channels of the second level devices, forming a third level.


Figure 4. Cascaded 8237As

## TRANSFER TYPES

Each of the three active transfer modes can perform three different types of transfers. These are Read, Write and Verify. Write transfers move data from an I/O device to the memory by activating MEMW and $\overline{\text { IOR. Read }}$ transfers move data from memory to an I/O device by activating MEMR and IOW. Verify transfers are pseudo transfers. The 8237A operates as in Read or Write transfers generating addresses, and responding to EOP, etc. However, the memory and I/O control lines all remain inactive. Verify mode is not permitted during memory to memory operation.

Memory-to-Memory - To perform block moves of data from one memory address space to another with a minimum of program effort and time, the 8237A includes a memory-to-memory transfer feature. Programming a bit in the Command register selects channels 0 and 1 to operate as memory-to-memory transfer channels. The transfer is initiated by setting the software DREQ for channel 0 . The 8237A requests a DMA service in the normal manner. After HLDA is true, the device, using eightstate transfers in Block Transfer mode, reads data from the memory. The channel 0 Current Address register is the source for the address used and is decremented or incremented in the normal manner. The data byte read from the memory is stored in the 8237A internal Temporary register. Channel 1 then writes the data from the Temporary register to memory using the address in its Current Address register and incrementing or decrementing it in the normal manner. The channel 1 Current Word Count is decremented. When the word count of channel 1 goes to FFFFH, a TC is generated causing an $\overline{\mathrm{EOP}}$ output terminating the service.

Channel 0 may be programmed to retain the same address for all transfers. This allows a single word to be written to a block of memory.

The 8237A will respond to external $\overline{E O P}$ signals during memory-to-memory transfers. Data comparators in block search schemes may use this input to terminate the service when a match is found, The timing of memory-to-memory transfers is found in Figure 12. Memory-to-memory operations can be detected as an active AEN with no DACK outputs.

Autoinitialize - By programming a bit in the Mode register, a channel may be set up as an Autoinitialize channel. During Autoinitialize initialization, the original values of the Current Address and Current Word Count registers are automatically restored from the Base Address and Base Word count registers of that channel following EO'P. The base registers are loaded simultaneously with the current registers by the microprocessor and remain unchanged throughout the DMA service. The mask bit is not set when the channel is in Autoinitialize. Following Autoinitialize the channel is ready to perform another DMA service, without CPU intervention, as soon as a valid DREQ is detected.
Priority - The 8237A has two types of priority encoding available as software selectable options. The first is Fixed Priority which fixes the channels in priority order
based upon the descending value of their number. The channel with the lowest priority is 3 followed by 2,1 and the highest priority channel, 0 . After the recognition of any one channel for service, the other channels are prevented from interferring with that service until it is completed.

The second scheme is Rotating Priority. The last channel to get service becomes the lowest priority channel with the others rotating accordingly.

|  | 1st Service | 2nd Service | 3rd Service |
| :---: | :---: | :---: | :---: |
| highest | 0 |  | 3 |
|  | $1<$ | 3 |  |
|  | 2 |  |  |
| lowest | 3 |  | 2 |

With Rotating Priority in a single chip DMA system, any device requesting service is guaranteed to be recognized after no more than three higher priority services have occurred. This prevents any one channel from monopolizing the system.

Compressed Timing - In order to achieve even greater throughput where system characteristics permit, the 8237A can compress the transfer time to two clock cycles. From Figure 11 it can be seen that state S3 is used to extend the access time of the read pulse. By removing state S3, the read pulse width is made equal to the write pulse width and a transfer consists only of state S 2 to change the address and state S 4 to perform the read/write. S1 states will still occur when A8-A15 need updating (see Address Generation). Timing for compressed transfers is found in Figure 14.

Address Generation - In order to reduce pin count, the 8237A multiplexes the eight higher order address bits on the data lines. State S1 is used to output the higher order address bits to an external latch from which they may be placed on the address bus. The falling edge of Address Strobe (ADSTB) is used to load these bits from the data lines to the latch. Address Enable (AEN) is used to enable the bits onto the address bus through a threestate enable. The lower order address bits are output by the 8237A directly. Lines A0-A7 should be connected to the address bus. Figure 11 shows the time relationships between CLK, AEN, ADSTB, DB0-DB7 and A0-A7.

During Block and Demand Transfer mode services, which include multiple transfers, the addresses generated will be sequential. For many transfers the data held in the external address latch will remain the same. This data need only change when a carry or borrow from A7 to A8 takes place in the normal sequence of addresses. To save time and speed transfers, the 8237A executes S1 states only when updating of A8-A15 in the latch is necessary. This means for long services, S1 states and Address Strobes may occur only once every 256 transfers, a savings of 255 clock cycles for each 256 transfers.

## REGISTER DESCRIPTION

Current Address Register - Each channel has a 16-bit Current Address register. This register holds the value of the address used during DMA transfers. The address is automatically incremented or decremented after each transfer and the intermediate values of the address are stored in the Current Address register during the transfer. This register is written or read by the microprocessor in successive 8 -bit bytes. It may also be reinitialized by an Autoinitialize back to its original value. Autoinitialize takes place only after an EOP.

Current Word Register - Each channel has a 16-bit Current Word Count register. This register determines the number of transfers to be performed. The actual number of transfers will be one more than the number programmed in the Current Word Count register (i.e., programming a count of 100 will result in 101 transfers). The word count is decremented after each transfer. The intermediate value of the word count is stored in the register during the transfer. When the value in the register goes from zero to FFFFH, a TC will be generated. This register is loaded or read in successive 8 -bit bytes by the microprocessor in the Program Condition. Following the end of a DMA service it may also be reinitialized by an Autoinitialization back to its original value. Autoinitialize can occur only when an EOP occurs. If it is not Autoinitialized, this register will have a count of FFFFH after TC.

Base Address and Base Word Count Registers - Each channel has a pair of Base Address and Base Word Count registers. These 16 -bit registers store the original value of their associated current registers. During Autoinitialize these values are used to restore the current registers to their original values. The base registers are written simultaneously with their corresponding current register in 8 -bit bytes in the Program Condition by the microprocessor. These registers cannot be read by the microprocessor.

Command Register - This 8-bit register controls the operation of the 8237A. It is programmed by the microprocessor in the Program Condition and is cleared by Reset or a Master Clear instruction. The following table lists the function of the command bits. See Figure 6 for address coding.

Mode Register - Each channel has a 6-bit Mode register associated with it. When the register is being written to by the microprocessor in the Program Condition, bits 0 and 1 determine which channel Mode register is to be written.

Request Register - The 8237A can respond to requests for DMA service which are initiated by software as well as by a DREQ. Each channel has a request bit associated with it in the 4-bit Request register. These are nonmaskable and subject to prioritization by the Priority Encoder network. Each register bit is set or reset sepa-

## Command Register



## Mode Register



Request Register

rately under software control or is cleared upon generation of a TC or external EOP. The entire register is cleared by a Reset. To set or reset a bit, the software loads the proper form of the data word. See Figure 5 for register address coding. In order to make a software request, the channel must be in Block Mode.

Mask Register - Each channel has associated with it a mask bit which can be set to disable the incoming DREQ. Each mask bit is set when its associated channel produces an EOP if the channel is not programmed for Autoinitialize. Each bit of the 4-bit Mask register may also be set or cleared separately under software control. The entire register is also set by a Reset. This disables all DMA requests until a clear Mask register instruction allows them to occur. The instruction to separately set or clear the mask bits is similar in form to that used with the Request register. See Figure 5 for instruction addressing.


All four bits of the Mask register may also be written with a single command.


| Register | Operation | Signals |  |  |  |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\overline{\text { CS }}$ | $\overline{\text { IOR }}$ | $\overline{\text { IOW }}$ | A3 | A2 | A1 | A0 |
| Command |  | 0 | 1 | 0 | 1 | 0 | 0 | 0 |
| Mode |  | 0 | 1 | 0 | 1 | 0 | 1 | 1 |
| Request |  | 0 | 1 | 0 | 1 | 0 | 0 | 1 |
| Mask |  | 0 | 1 | 0 | 1 | 0 | 1 | 0 |
| Mask |  | 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| Temporary |  | 0 | 0 | 1 | 1 | 1 | 0 | 1 |
| Status | Read | 0 | 0 | 1 | 1 | 0 | 0 | 0 |

Figure 5. Definition of Register Codes

Status Register - The Status register is available to be read out of the 8237A by the microprocessor. It contains information about the status of the devices at this point. This information includes which channels have reached a terminal count and which channels have pending DMA requests. Bits 0-3 are set every time a TC is reached by that channel or an external EOP is applied. These bits are cleared upon Reset and on each Status Read. Bits 4-7 are set whenever their corresponding channel is requesting service.


Temporary Register - The Temporary register is used to hold data during memory-to-memory transfers. Following the completion of the transfers, the last word moved can be read by the microprocessor in the Program Condition. The Temporary register always contains the last byte transferred in the previous memory-to-memory operation, unless cleared by a Reset.
Software Commands - These are additional special software commands which can be executed in the Program Condition. They do not depend on any specific bit pattern on the data bus. The two software commands are:

Clear First/Last Flip-Flop: This command is executed prior to writing or reading new address or word count information to the 8237A. This initializes the flip-flop to a known state so that subsequent accesses to register contents by the microprocessor will address upper and lower bytes in the correct sequence.

Master Clear: This software instruction has the same effect as the hardware Reset. The Command, Status, Request, Temporary, and Internal First/Last Flip-Flop registers are cleared and the Mask register is set. The 8237A will enter the Idle cycle.

Clear Mask Register: This command clears the mask bits of all four channels, enabling them to accept DMA requests.
Figure 6 lists the address codes for the software commands:

| Signals |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| A3 | A2 | A1 | AO | $\overline{\text { IOR }}$ | $\overline{\mathrm{OW}}$ |  |
| 1 | 0 | 0 | 0 | 0 | 1 | Read Status Register |
| 1 | 0 | 0 | 0 | 1 | 0 | Write Command Register |
| 1 | 0 | 0 | 1 | 0 | 1 | Illegal |
| 1 | 0 | 0 | 1 | 1 | 0 | Write Request Register |
| 1 | 0 | 1 | 0 | 0 | 1 | Illegal |
| 1 | 0 | 1 | 0 | 1 | 0 | Write Single Mask Register Bit |
| 1 | 0 | 1 | 1 | 0 | 1 | Illegal |
| 1 | 0 | 1 | 1 | 1 | 0 | Write Mode Register |
| 1 | 1 | 0 | 0 | 0 | 1 | Illegal |
| 1 | 1 | 0 | 0 | 1 | 0 | Clear Byte Pointer Flip/Flop |
| 1 | 1 | 0 | 1 | 0 | 1 | Read Temporary Register |
| 1 | 1 | 0 | 1 | 1 | 0 | Master Clear |
| 1 | 1 | 1 | 0 | 0 | 1 | Illegal |
| 1 | 1 | 1 | 0 | 1 | 0 | Clear Mask Register |
| 1 | 1 | 1 | 1 | 0 | 1 | Illegal |
| 1 | 1 | 1 | 1 | 1 | 0 | Write All. Mask Register Bits |

Figure 6. Software Command Codes

| Channel | Register | Operation | Signals |  |  |  |  |  |  | Internal Flip-Flop | Data Bus DB0-DB7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CS | $\overline{\text { IOR }}$ | IOW | A3 | A2 | A1 | AO |  |  |
| 0 | Base and Current Address | Write | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | A8-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | W)0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | W8-W15 |
| 1 | Base and Current Address | Write | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | A8-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | W8-W15 |
| 2 | Base and Current Address | Write | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | A8-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | W8-W15 |
| 3 | Base and Current Address | Write | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | A8-A15 |
|  | Current Address | Read | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | A0-A7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | A8-A15 |
|  | Base and Current Word Count | Write | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | W0-W7 |
|  |  |  | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | W8-W15 |
|  | Current Word Count | Read | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | W)0-W7 |
|  |  |  | 0 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | W8-W15 |

Figure 7. Word Count and Address Register Command Codes

## PROGRAMMING

The 8237A will accept programming from the host processor any time that HLDA is inactive; this is true even if HRQ is active. The responsibility of the host is to assure that programming and HLDA are mutually exclusive. Note that a problem can occur if a DMA request occurs, on an unmasked channel while the 8237A is being programmed. For instance, the CPU may be starting to reprogram the two byte Address register of channel 1 when channel 1 receives a DMA request. If the 8237A is enabled (bit 2 in the command register is 0 ) and channel 1 is unmasked, a DMA service will occur after only one byte of the Address register has been reprogrammed. This can be avoided by disabling the controller (setting bit 2 in the command register) or masking the channel before programming any other registers. Once the programming is complete, the controller can be enabled/unmasked.

After power-up it is suggested that all internal locations, especially the Mode registers, be loaded with some valid value. This should be done even if some channels are unused.

## APPLICATION INFORMATION

Figure 8 shows a convenient method for configuring a DMA system with the 8237A controller and an 8080A/ 8085AH microprocessor system. The multimode DMA controller issues a HRQ to the processor whenever there is at least one valid DMA request from a peripheral device. When the processor replies with a HLDA signal, the 8237A takes control of the address bus, the data bus and the control bus. The address for the first transfer
operation comes out in two bytes - the least significant 8 bits on the eight address outputs and the most significant 8 bits on the data bus. The contents of the data bus are then latched into the 82828 -bit latch to complete the full 16 bits of the address bus. The 8282 is a high speed, 8 -bit, three-state latch in a 20-pin package. After the initial transfer takes place, the latch is updated only after a carry or borrow is generated in the least significant address byte. Four DMA channels are provided when one 8237A is used.


Figure 8. 8237A System 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 to $7 V$
Power Dissipation
1.5 Watt
*NOTICE: 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 $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min. | Typ. ${ }^{(1)}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.4 |  |  | V | $\mathrm{IOH}^{\text {O }}=-200 \mu \mathrm{~A}$ |
|  |  | 3.3 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ (HRQ Only) |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ (data bus) <br> $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ (other outputs) |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{I}_{\text {LI }}$ | Input Load Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ILO | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |
| ICC | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 65 | 130 | mA | $\mathrm{T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$ |
|  |  |  | 75 | 150 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |
| $\mathrm{C}_{0}$ | Output Capacitance |  | 4 | 8 | pF | $\mathrm{fc}=1.0 \mathrm{MHz}$, Inputs $=0 \mathrm{~V}$ |
| $\mathrm{C}_{1}$ | Input Capacitance |  | 8 | 15 | pF |  |
| $\mathrm{C}_{10}$ | I/O Capacitance |  | 10 | 18 | pF |  |

## NOTES:

1. Typical values are for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, nominal supply voltage and nominal processing parameters.
2. Input timing parameters assume transition times of 20 ns or less. Waveform measurement points for both input and output signals are 2.0 V for HIGH and 0.8 V for LOW, unless otherwise noted.
3. Output loading is 1 THL gate plus 50 pF capacitance, unless otherwise noted.
4. The net $\overline{\mathrm{OW}}$ or MEMW Pulse width for normal write will be TCY-100 ns and for extended write will be 2 TCY-100 ns. The net $\overline{\mathrm{IOR}}$ or $\overline{M E M R}$ pulse width for normal read will be 2 TCY- 50 ns and for compressed read will be TCY- 50 ns .
5. TDQ is specified for two different output HIGH levels. TDQ1 is measured at 2.0 V . TDQ2 is measured at 3.3 V . The value for TDQ2 assumes an external $3.3 \mathrm{k} \Omega$ pull-up resistor connected from HRQ to $\mathrm{V}_{\mathrm{CC}}$.
6. DREQ should be held active until DACK is returned.
7. DREQ and DACK signals may be active high or active low. Timing diagrams assume the active high mode.
8. Output loading on the data bus is 1 TTL gate plus 100 pF capacitance.
9. Successive read and/or write operations by the external processor to program or examine the controller must be timed to allow at least 600 ns for the 8237 A , at least 500 ns for the $8237 \mathrm{~A}-4$ and at least 400 ns for the $8237 \mathrm{~A}-5$, as recovery time between active read or write pulses.
10. Parameters are listed in alphabetical order.
11. Pin 5 is an input that should always be at a logic high level. An internal pull-up resistor will establish a logic high when the pin is left floating. Alternatively, pin 5 may be tied to $\mathrm{V}_{\mathrm{CC}}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## A.C. CHARACTERISTICS—DMA (MASTER) MODE $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$, $\left.\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | 8237A |  | 8237A-4 |  | 8237A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| TAEL | AEN HIGH from CLK LOW (S1) Delay Time |  | 300 |  | 225 |  | 200 | ns |
| TAET | AEN LOW from CLK HIGH (S1) Delay Time |  | 200 |  | 150 |  | 130 | ns |
| TAFAB | ADR Active to Float Delay from CLK HIGH |  | 150 |  | 120 |  | 90 | ns |
| TAFC | $\overline{\text { READ }}$ or $\overline{\text { WRITE }}$ Float from CLK HIGH |  | 150 |  | 120 |  | 120 | ns |
| TAFDB | DB Active to Float Delay from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TAHR | ADR from READ HIGH Hold Time | TCY-100 |  | TCY-100 |  | TCY-100 |  | ns |
| TAHS | DB from ADSTB LOW Hold Time | 50 |  | 40 |  | 30 |  | ns |
| TAHW | ADR from WRITE HIGH Hold Time | TCY-50 |  | TCY-50 |  | TCY-50 |  | ns |
| TAK | DACK Valid from CLK LOW Delay Time (Note 7) |  | 250 |  | 220 |  | 170 | ns |
|  | $\overline{\text { EOP HIGH from CLK HIGH Delay Time }}$ |  | 250 |  | 190 |  | 170 | ns |
|  |  |  | 250 |  | 190 |  | 100 | ns |
| TASM | ADR Stable from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TASS | DB to ADSTB LOW Setup Time | 100 |  | 100 |  | 100 |  | ns |
| TCH | Clock High Time (Transitions $\leqslant 10 \mathrm{~ns}$ ) | 120 |  | 100 |  | 80 |  | ns |
| TCL | Clock LOW Time (Transitions $\leqslant 10 \mathrm{~ns}$ ) | 150 |  | 110 |  | 68 |  | ns |
| TCY | CLK Cycle Time | 320 |  | 250 |  | 200 |  | ns |
| TDCL | CLK HIGH to $\overline{\text { READ }}$ or $\overline{\text { WRITE }}$ LOW Delay (Note 4) |  | 270 |  | 200 |  | 190 | ns |
| TDCTR | $\overline{\text { READ HIGH from CLK HIGH (S4) Delay Time }}$ (Note 4) |  | 270 |  | 210 |  | 190 | ns |
| TDCTW | WRITE HIGH from CLK HIGH (S4) Delay Time (Note 4) |  | 200 |  | 150 |  | 130 | ns |
| $\begin{aligned} & \text { TDQ1 } \\ & \text { TDQ2 } \end{aligned}$ | HRQ Valid from CLK HIGH Delay Time (Note 5) |  | 160 |  | 120 |  | 120 | ns |
|  |  |  | 250 |  | 190 |  | 120 | ns |
| TEPS | $\overline{\text { EOP }}$ LOW from CLK LOW Setup Time | 60 |  | 45 |  | 40 |  | ns |
| TEPW | $\overline{\text { EOP Pulse Width }}$ | 300 |  | 225 |  | 220 |  | ns |
| TFAAB | ADR Float to Active Delay from CLK HIGH |  | 250 |  | 190 |  | 170 | ns |
| TFAC | $\overline{\text { READ }}$ or WRITE Active from CLK HIGH |  | 200 |  | 150 |  | 150 | ns |
| TFADB | DB Float to Active Delay from CLK HIGH |  | 300 | - | 225 |  | 200 | ns |
| THS | HLDA Valid to CLK HIGH Setup Time | 100 |  | 75 |  | 75 |  | ns |
| TIDH | Input Data from MEMR HIGH Hold Time | 0 |  | 0 |  | 0 |  | ns |
| TIDS | Input Data to $\overline{\text { MEMR HIGH Setup Time }}$ | 250 |  | 190 |  | 170 |  | ns |
| TODH | Output Data from प्MEMW HIGH Hold Time | 20 |  | 20 |  | 10 |  | ns |
| TODV | Output Data Valid to $\overline{\text { MEMW }}$ HIGH | 200 |  | 125 |  | 125 |  | ns |
| TQS | DREQ to CLK LOW (SI, S4) Setup Time (Note 7) | 0 |  | 0 |  | 0 |  | ns |
| TRH | CLK to READY LOW Hold Time | 20 |  | 20 |  | 20 |  | ns |
| TRS | READY to CLK LOW Setup Time | 100 |  | 60 |  | 60 |  | ns |
| TSTL | ADSTB HIGH from CLK HIGH Delay Time |  | 200 |  | 150 |  | 130 | ns |
| TSTT | ADSTB LOW from CLK HIGH Delay Time |  | 140 |  | 110 |  | 90 | ns |

8237A/8237A-4/8237A-5
A.C. CHARACTERISTICS—PERIPHERAL (SLAVE) MODE ( $T_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$, GND $=0 \mathrm{~V}$ )

| Symbol | Parameter | 8237A |  | 8237A-4 |  | 8237A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| TAR | ADR Valid or $\overline{\mathrm{CS}}$ LOW to $\overline{\text { READ }}$ LOW | 50 |  | 50 |  | 50 |  | ns |
| TAW | ADR Valid to WRITE HIGH Setup Time | 200 |  | 150 |  | 150 |  | ns |
| TCW | CS LOW to WRITE HIGH Setup Time | 200 |  | 150 |  | 150 |  | ns |
| TDW | Data Valid to WRITE HIGH Setup Time | 200 |  | 150 |  | 150 |  | ns |
| TRA | ADR or CS Hold from READ HIGH | 0 |  | 0 |  | 0 |  | ns |
| TRDE | Data Access from $\overline{\text { READ }}$ LOW (Note 8) |  | 200 |  | 200 |  | 140 | ns |
| TRDF | DB Float Delay from $\overline{\text { READ }}$ HIGH | 20 | 100 | 20 | 100 | 0 | 70 | ns |
| TRSTD | Power Supply HIGH to RESET LOW Setup Time | 500 |  | 500 |  | 500 |  | ns |
| TRSTS | ,RESET to First $\overline{\text { OWR }}$ | 2 TCY |  | 2TCY |  | 2TCY |  | ns |
| TRSTW | RESET Pulse Width | 300 |  | 300 |  | 300 |  | ns |
| TRW | READ Width | 300 |  | 250 |  | 200 |  | ns |
| TWA | ADR from $\overline{\text { WRITE }}$ HIGH Hold Time | 20 |  | 20 |  | 20 |  | ns |
| TWC | CS HIGH from WRITE HIGH Hold Time | 20 |  | 20 |  | 20 |  | ns |
| TWD | Data from $\overline{\text { WRITE }}$ HIGH Hold Time | 30 |  | 30 |  | 30 |  | ns |
| TWWS | Write Width | 200 |  | 200 |  | 160 |  | ns |

## WAVEFORMS

## SLAVE MODE WRITE TIMING



Figure 9. Slave Mode Write


## WAVEFORMS (Continued)

DMA TRANSFER TIMING


Figure 11. DMA Transfer

## WAVEFORMS (Continued)

## MEMORY-TO-MEMORY TRANSFER TIMING



Figure 12. Memory-to-Memory Transfer

## READY TIMING



Figure 13. Ready

## WAVEFORMS (Continued)

## COMPRESSED TRANSFER TIMING



Figure 14. Compressed Transfer

RESET TIMING


Figure 15. Reset

## 8257/8257-5 <br> PROGRAMMABLE DMA CONTROLLER

MCS-85 ${ }^{\text {® }}$ Compatible 8257-5<br>4.Channel DMA Controller<br>- Priority DMA Request Logic<br>- Channel Inhibit Logic

The Intel ${ }^{\text {a }} 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 ${ }^{\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 8257 has priority logic that resolves the peripherals requests and issues a composife 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.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## FUNCTIONAL DESCRIPTION

## General

The 8257 is a programmable, Direct Memory Access (DMA) device which, when coupled with a single Intel© 8212 I/O port device, provides a complete four-channel DMA controller for use in Intel ${ }^{\star}$ 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 $A_{8} \cdot A_{15}$ ), 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 $\mathrm{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 3. 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 Cycle |
| 1 | 1 | (Illegal) |



Figure 4. 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 (I/OR) or I/O Write (I/OW) signal, decodes the least significant four address bits, ( $A_{0}-A_{3}$ ), and either writes the contents of the data bus into the addressed register (if $\overline{1 O W}$ is true) or places the contents of the addressed re:jister 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{/ / 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{IOW}}$ 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 ${ }^{\circ} 8224$ Clock Generator device. ( $\phi 2 \mathrm{TTL}$ ) or Intel ${ }^{\circledR}$ 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{\mathrm{CS}}$ is automatically disabled to prevent the chip from selecting itself while performing the DMA 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.


Figure 5. 8257 Block Diagram Showing Read/Write Logic Function

## ( $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. READY must conform to specified setup and hold times.
(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. HRQ must conform to specified setup and hold times.

## (HLDA)

Hold Acknowledge: This input from the CPU indicates that the 8257 has acquired control of the system bus.

## (MEMR)

Memory Read: This active-low three-state output is used to read data from the addressed memory location during DMA Read cycles.

## (MEMW)

Memory Write: This active-low three-state output is used to write data into the addressed memory location during DMA Write cycles.

## (ADSTB)

Address Strobe: This output strobes the most significant byte of the memory address into the 8212 device from the data bus.

## (AEN)

Address Enable: This output is used to disable (float) the System Data Bus and the System Control Bus. It may also be used to disable (float) the System Address Bus by use of an enable on the Address Bus drivers in systems to inhibit non-DMA devices from responding during DMA cycles. It may be further used to isolate the 8257 data bus from the System Data Bus to facilitate the transfer of the 8 most significant DMA address bits over the 8257 data I/O pins without subjecting the System Data Bus to any timing constraints for the transfer. When the 8257 is used in an I/O device structure (as opposed to memory mapped), this AEN output should be used to disable the selection of an I/O device when the DMA address is on the address bus. The I/O device selection should be determined by the DMA acknowledge outputs for the 4 channels.

## (TC)

Terminal Count: This output notifies the currently selected peripheral that the present DMA cycle should be the last cycle for this data block. If the TC STOP bit in the Mode Set register is set, the selected channel will be automatically disabled at the end of that DMA cycle. TC is activated when the 14 -bit value in the selected channel's terminal count register equals zero. Recall that the loworder 14-bits of the terminal count register should be loaded with the values ( $n-1$ ), where $n=$ the desired number of the DMA cycles.

## (MARK)

Modulo 128 Mark: This output notifies the selected peripheral that the current DMA cycle is the 128th cycle since the previous MARK output. MARK always occurs at 128 (and all multiples of 128) cycles from the end of the data block. Only if the total number of DMA cycles $(n)$ is evenly divisable by 128 (and the terminal count register was loaded with $n-1$ ), will MARK occur at 128 (and each succeeding multiple of 128) cycles from the beginning of the data block.


Figure 6. 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 $\rightarrow$ JUST SERVICED | $\mathrm{CH}-\mathrm{O}$ | $\mathrm{CH}-1$ | CH-2 | CH-3 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Priority $\longrightarrow$ <br> Assignments | Highest: | CH-1 | CH-2 | CH-3 | CH-0 |
|  |  | CH-2 | CH-3 | CH-O | CH-1 |
|  |  | CH-3 | CH-0 | CH-1 | CH-2 |
|  |  | CH-O | CH-1 | CH-2 | CH- |

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{/ O W}$ 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{\overline{/ 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.


Figure 7. Autoload Timing

## 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, $A_{0}-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{\mathbf{1 / O W}}$ | $\overline{\mathrm{I} / \mathrm{OR}}$ | A3 |
| :--- | :---: | :---: | :---: | :---: |
| 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 ( $\mathrm{F} / \mathrm{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{\text { IOR }}$ or $\overline{1 / 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

| REGISTER | BYTE | ADDRESS INPUTS |  |  |  | F/L | *BI-DIRECTIONAL DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $A_{3}$ | $A_{2}$ | $\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}$ |
| CH-O DMA Address | $\begin{aligned} & \text { LSB } \\ & \text { MSB } \end{aligned}$ | 0 | 0 | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{gathered} \mathbf{A}_{7} \\ \mathbf{A}_{15} \end{gathered}$ | $\begin{gathered} \mathbf{A}_{6} \\ \mathbf{A}_{14} \end{gathered}$ | $\begin{gathered} \mathbf{A}_{5} \\ \mathbf{A}_{13} \end{gathered}$ | $\begin{gathered} \mathbf{A}_{4} \\ \mathbf{A}_{12} \end{gathered}$ | $\begin{gathered} \mathbf{A}_{3} \\ \mathbf{A}_{11} \end{gathered}$ | $\begin{aligned} & \mathbf{A}_{\mathbf{2}} \\ & \mathbf{A}_{11} \end{aligned}$ | $\begin{aligned} & \mathbf{A}_{1} \\ & \mathbf{A}_{0} \end{aligned}$ | $\mathbf{A}_{0}$ $\mathbf{A B}_{8}$ |
| CH-O Terminal Count | $\begin{aligned} & \text { LSB } \\ & \text { MSB } \end{aligned}$ | 0 | 0 | 0 | 1 | 0 | $\begin{aligned} & \mathbf{C}_{7} \\ & \mathbf{R d}^{2} \end{aligned}$ | $\begin{aligned} & \mathbf{c}_{6} \\ & \mathbf{W r}_{\mathbf{r}} \end{aligned}$ | $\begin{aligned} & \mathbf{c}_{5} \\ & \mathbf{C}_{13} \end{aligned}$ | $\begin{aligned} & \mathbf{c}_{4} \\ & \mathbf{c}_{12} \end{aligned}$ | $\begin{aligned} & \mathbf{c}_{3} \\ & \mathbf{c}_{11} \end{aligned}$ | $\begin{gathered} \mathbf{c}_{2} \\ \mathbf{C}_{10} \end{gathered}$ | $\begin{aligned} & \mathbf{c}_{1} \\ & \mathbf{c}_{9} \end{aligned}$ | c $\mathrm{C}_{8}$ |
| CH-1 DMA Address | $\begin{aligned} & \text { LSB } \\ & \text { MSB } \end{aligned}$ | 0 | 0 | 1 | 0 | 0 | Same as Channel 0 |  |  |  |  |  |  |  |
| CH-1 Terminal Count | $\begin{aligned} & \text { LSB } \\ & \text { MSB } \end{aligned}$ | 0 | 0 | 1 | 1 | 0 |  |  |  |  |  |  |  |  |
| 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 1 | Same as Channel 0 |  |  |  |  |  |  |  |
| 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}$ | 0 |  |  |  |  |  |  |  |  |
| 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 as Channel 0 |  |  |  |  |  |  |  |
| CH-3 Terminal Count | $\begin{aligned} & \text { LSB } \\ & \text { MSB } \end{aligned}$ | 0 | 1 | 1 | 1 | 0 |  |  |  |  |  |  |  |  |
| MODE SET (Program only) | - | 1 | 0 | 0 | 0 | 0 | AL | tcs | EW | RP | EN3 | EN2 | EN1 | ENO |
| StATUS (Read only) | - | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | UP | TC3 | TC2 | TC1 | TCO |

${ }^{*} \mathrm{~A}_{0}-\mathrm{A}_{15}$ : DMA Starting Address, $\mathrm{C}_{0}-\mathrm{C}_{13}$ : Terminal Count value ( $\mathrm{N}-1$ ), Rd and Wr: DMAVerify (00), Write (01) or Read (10) cycle selection, AL:Auto Load, TCS: TC STOP, EW: EXTENDED WRITE, RP: ROTATING PRIORITY, EN3-ENO: CHANNEL ENABLE MASK, UP: UPDATE FLAG, TC3-TCO: TERMINAL COUNT STATUS BITS.


Figure 8. 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 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 I/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 500 K bytes/second.

## Memory Mapped IIO 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 9. System Interface for Memory Mapped I/O

## SYSTEM APPLICATION EXAMPLES

| BIT 15 | BIT 14 |  |
| :---: | :---: | :---: |
| READ | WRITE |  |
| 0 | 0 | DMA Verify Cycle |
| 0 | 1 | DMA Read Cycle |
| 1 | 0 | DMA Write Cycle |
| 1 | 1 | Illegal |

Figure 10. TC Register for Memory Mapped I/O Only


Figure 11. Floppy Disk Controller (4 Drives)


Figure 12. High-Speed Communication Controller

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## Tracking Parameters

Signals labeled as Tracking Parameters (footnotes 1 and 5-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

## WAVEFORMS—PERIPHERAL MODE




## WAVEFORMS—DMA

CONSECUTIVE CYCLES AND BURST MODE SEQUENCE


## WAVEFORMS (Continued)

## CONTROL OVERRIDE SEQUENCE



NOT READY SEQUENCE


TC/MARK


Figure 13. Detailed System Interface Schematic

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

(8257: $\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}$ )
(8257-5: $\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. | 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 |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | Volts | $\mathrm{l} \mathrm{OL}=1.6 \mathrm{~mA}$ |
| V OH | Output High Voltage | 2.4 | $\mathrm{V}_{\mathrm{Cc}}$ | Volts | $I_{O H}=-150 \mu A \text { for } A B,$ <br> DB and AEN $\mathrm{I}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ for others |
| $\mathrm{V}_{\mathrm{HH}}$ | HRQ Output High Voltage | 3.3 | $\mathrm{V}_{\mathrm{Cc}}$ | Volts | $\mathrm{l}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ |
| $I_{\text {CC }}$ | $V_{\text {cc }}$ Current Drain |  | 120 | mA |  |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| IOFL | Output Leakage During Float |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |

CAPACITANCE $\left(T_{A}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=\mathrm{OV}\right)$

| 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 <br> returned to GND |

## A.C. CHARACTERISTICS-PERIPHERAL (SLAVE) MODE

(8257: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{C}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}$ )
(8257-5: $\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}$ )

## 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 |  |
| $\mathrm{T}_{\text {RD }}$ | Data Access from $\overline{\mathrm{RD}} \downarrow$ | 0 | 300 | 0 | 220 | ns |  |
| TDF | $\mathrm{DB} \rightarrow$ Float Delay from $\overline{\mathrm{RD}} \uparrow$. | 20 | 150 | 20 | 120 | 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 |  |
| Tow | Data Setup to $\overline{W R} \uparrow$ | 200 |  | 200 |  | ns |  |
| TWD | Data Hold from $\overline{W R} \uparrow$ | 0 |  | 0 |  | ns |  |
| $T_{\text {WW }}$ | $\overline{\text { WR Width }}$ | 200 |  | 200 |  | ns |  |

OTHER TIMING

| Symbol | Parameter | 8257 |  | 8257.5 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| T RSTW | Reset Pulse Width | 300 |  | 300 |  | ns |  |
| T RSTD | Power Supply $\uparrow\left(V_{\text {CC }}\right.$ ) Setup to Reset $\downarrow$ | 500 |  | 500 |  | $\mu \mathrm{s}$ |  |
| $\mathrm{T}_{\mathrm{r}}$ | Signal Rise Time |  | 20 |  | 20 | ns |  |
| $\mathrm{T}_{\text {f }}$ | Signal Fall Time |  | 20 |  | 20 | ns |  |
| TRSTS | Reset to First $\overline{1 / O W R}$ | 2 |  | 2 |  | ${ }^{\text {t }} \mathrm{CY}$ |  |

## A.C. CHARACTERISTICS-DMA (MASTER) MODE

(8257: $\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}$ )
(8257-5: $\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}$ )

## 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 |
| Tos | DRQ1 Setup to CLKI (SI, S4) | 120 |  | 120 |  | ns |
| $\mathrm{T}_{\text {QH }}$ | DRQ 1 Hold from HLDA ${ }^{[1]}$ | 0 |  | 0 |  | ns |
| $\mathrm{T}_{\mathrm{HS}}$ | HLDAI or ISetup to CLK!(SI, S4) | 100 |  | 100 |  | ns |
| $\mathrm{T}_{\text {RS }}$ | READY Setup Time to CLKI(S3, Sw) | 30 |  | 30 |  | ns |
| $\mathrm{T}_{\text {RH }}$ | READY Hold Time from CLK $1(\mathrm{~S} 3, \mathrm{Sw}$ ) | 20 |  | 20 |  | ns |

## A.C. CHARACTERISTICS-DMA (MASTER) MODE

(8257: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$, GND $=0 \mathrm{~V}$ )
(8257-5: $\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}$ )
TIMING RESPONSES

| Symbol | Parameter | 8257 |  | 8257-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{T}_{\mathrm{DQ}}$ | HRQ $\uparrow$ or $\downarrow$ Delay from CLK $\uparrow$ (SI, S4) (measured at 2.0V) |  | 160 |  | 160 | ns |
| TDQ1 | HRQ $\uparrow$ or $\downarrow$ Delay from CLK $\uparrow$ (SI, S4) (measured at 3.3V) ${ }^{[3]}$ |  | 250 |  | 250 | ns |
| TAEL | AEN $\uparrow$ Delay from CLK $\downarrow$ (S1) |  | 300 |  | 300 | ns |
| $\mathrm{T}_{\text {AET }}$ | AEN $\downarrow$ Delay from CLK $\uparrow$ (SI) |  | 200 |  | 200 | ns |
| TAEA | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Active) Delay from AEN $\uparrow(\mathrm{S} 1)^{[1]}$ | 20 |  | 20 |  | ns |
| $\mathrm{T}_{\text {FAAB }}$ | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Active) Delay from CLK $\uparrow(\mathrm{S} 1)^{[2]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\text {AFAB }}$ | $\operatorname{Adr}(\mathrm{AB})$ (Float) Delay from CLK $\uparrow(\mathrm{SI})^{[2]}$ |  | 150 |  | 150 | ns |
| $\mathrm{T}_{\text {ASM }}$ | $\operatorname{Adr}$ (AB) (Stable) Delay from CLK $\uparrow(\mathrm{S} 1)^{[2]}$ |  | 250 |  | 250 | ns |
| $\mathrm{T}_{\text {AH }}$ | Adr (AB) (Stable) Hold from CLK $\uparrow(\mathrm{S} 1)^{[2]}$ | TASM ${ }^{\text {-50 }}$ |  | TASM ${ }^{\text {-50 }}$ |  | ns |
| $\mathrm{T}_{\text {AHR }}$ | Adr (AB) (Valid) Hold from $\overline{\mathrm{RD}} \uparrow(\mathrm{S} 1, \mathrm{SI})^{[1]}$ | 60 |  | 60 |  | ns |
| TAHW | $\operatorname{Adr}(\mathrm{AB})$ (Valid) Hold from $\overline{\mathrm{Wr}} \uparrow(\mathrm{S} 1, \mathrm{SI})^{[1]}$ | 300 |  | 300 |  | ns |
| T FADB | Adr (DB) (Active) Delay from CLK $\uparrow(\mathrm{S1})^{[2]}$ |  | 300 |  | 300 | ns |
| TAFDB | Adr (DB) (Float) Delay from CLK $\uparrow$ (S2) ${ }^{[2]}$ | $\mathrm{T}_{\text {STT }}+20$ | 250 | TSTT+20 | 170 | ns |
| $\mathrm{T}_{\text {ASS }}$ | Adr (DB) Setup to Adr Stb $\downarrow$ (S1-S2) ${ }^{[1]}$ | 100 |  | 100 |  | ns |
| $\mathrm{T}_{\text {AHS }}$ | Adr (DB) (Valid) Hold from Adr Stbl (S2) ${ }^{[1]}$ | 20 |  | 20 |  | ns |
| $\mathrm{T}_{\text {STL }}$ | Adr Stb $\uparrow$ Delay from CLK $\uparrow$ (S1) |  | 200 |  | 200 | ns |
| TSTT | Adr Stbl Delay from CLK $\uparrow$ (S2) |  | 140 |  | 140 | ns |
| TSW | Adr Stb Width (S1-S2) ${ }^{[1]}$ | $T_{C Y}-100$ |  | $\mathrm{T}_{\text {CY - }} 100$ |  | ns |
| TASC | $\overline{\operatorname{Rd} d} \downarrow$ or $\overline{\mathrm{Wr}}(E x t) \downarrow$ Delay from Adr Stb $\downarrow$ (S2) ${ }^{[1]}$ | 70 |  | 70 |  | ns |
| TDBC | $\overline{\mathrm{RD}} \downarrow$ or $\overline{\mathrm{WR}}(\mathrm{Ex}) \downarrow$ Delay from Adr (DB) (Float) (S2) ${ }^{\text {11] }}$ | 20 |  | 20 |  | ns |
| $\mathrm{T}_{\text {AK }}$ | DACK $\uparrow$ or $\downarrow$ Delay from CLK $\downarrow$ (S2, S1) and TC/Mark $\uparrow$ Delay from CLK $\uparrow$ (S3) and TC/Mark $\downarrow$ Delay from CLK $\uparrow$ (S4) ${ }^{[4]}$ |  | 250 |  | 250 | ns |
| TDCL | $\overline{\mathrm{RD}} \downarrow$ or $\overline{\mathrm{Wr}}(\mathrm{Ext}) \downarrow$ Delay from CLK $\uparrow(\mathrm{S} 2)$ and $\mathrm{W} \downarrow \downarrow$ Delay from CLK $\uparrow(\mathrm{S} 3)^{[2,5]}$ |  | 200 |  | 200 | ns |
| $T_{\text {DCT }}$ | Rd $\uparrow$ Delay from CLK $\downarrow(\mathrm{S} 1, \mathrm{SI})$ and $W r \uparrow$ Delay from CLK $\uparrow(S 4)^{[2,6]}$ |  | 200 |  | 200 | ns |
| T FAC | $\overline{\mathrm{Rd}}$ or Wr (Active) from CLK $\uparrow$ (S1) ${ }^{[2]}$ |  | 300 |  | 300 | ns |
| $\mathrm{T}_{\text {AFC }}$ | $\overline{\mathrm{Rd}}$ or $\overline{\mathrm{Wr}}$ (Active) from CLK $\uparrow(S 1)^{[2]}$ |  | 150 |  | 150 | ns |
| TRWM | $\overline{\mathrm{Rd}}$ Width (S2-S1 or SI$)^{[1]}$ | $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) }}{ }^{[1]}$ | TCY-50 |  | TCY-50 |  | ns |
| TWWME | $\overline{\text { WR (Ext) Width (S2-S4) }}{ }^{[1]}$ | ${ }^{2} \mathrm{~T}_{\mathrm{CY}}-50$ |  | $2 \mathrm{~T}_{\mathrm{CY}}-50$ |  | ns |

## NOTES:

1. Tracking Parameter.
2. Load $=\mathrm{VOH}_{\mathrm{OH}}=3.3 \mathrm{~V}$.
3. $\Delta \mathrm{T}_{\mathrm{DCL}}<50 \mathrm{~ns}$.
4. Load $=+50 \mathrm{pF}$.
5. $\Delta \mathrm{T}_{\mathrm{AK}}<50 \mathrm{~ns}$.
6. $\triangle T_{D C T}<50 \mathrm{~ns}$.

# 8259A/8259A-2/8259A-8 PROGRAMMABLE INTERRUPT CONTROLLER 

\author{

- IAPX 86, iAPX 88 Compatible <br> - MCS-80 ${ }^{\circledR}$, MCS-85 ${ }^{\circledR}$ Compatible <br> - Eight-Level Priority Controller <br> - Expandable to 64 Levels
}

The Intel ${ }^{(1)}$ 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 handing 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 ${ }^{\oplus}$ 8259. Software originally written for the 8259 will operate the 8259A in all 8259 equivalent modes (MCS-80/85, Non-Buffered, Edge Triggered).


Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ | 28 | 1 | Supply: +5V Supply. |
| GND | 14 | 1 | Ground. |
| $\overline{\text { CS }}$ | 1 | 1 | Chip Select: A low on this pin enables $\overline{\mathrm{RD}}$ and $\overline{W R}$ communication between the CPU and the 8259A. INTA functions are independent of CS. |
| $\overline{\text { WR }}$ | 2 | 0 | Write: A low on this pin when CS is low enables the 8259A to accept command words from the CPU. |
| $\overline{\mathrm{RD}}$ | 3 | I | Read: A low on this pin when CS is low enables the 8259A to release status onto the data bus for the CPU. |
| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | 4-11 | 1/0 | Bidirectional Data Bus: Control, status and interrupt-vector information is transferred via this bus. |
| $\mathrm{CAS}_{0}-\mathrm{CAS}_{2}$ | 12,13,15 | 1/0 | Cascade Lines: The CAS lines form a private 8259A bus to control a multiple 8259A structure. These pins are outputs for a master 8259A and inputs for a slave 8259A. |
| $\overline{\text { SP/EN }}$ | 16 | 1/0 | Slave Program/Enable Buffer: This is a dual function pin. When in the Buffered Mode it can be used as an output to control buffer transceivers (EN). When not in the buffered mode it is used as an input to designate a master $(S P=1)$ or slave $(S P=0)$. |
| INT | 17 | 0 | Interrupt: This pin goes high whenever a valid interrupt request is asserted. It is used to interrupt the CPU, thus it is connected to the CPU's interrupt pin. |
| $\underline{I R}-1 R_{7}$ | 18-25 | 1 | Interrupt Requests: Asynchronous inputs. An interrupt request is executed by raising an IR input (low to high), and holding it high until it is acknowledged (Edge Triggered Mode), or just by a high level on an IR input (Level Triggered Mode). |
| $\overline{\text { INTA }}$ | 26 | 1 | Interrupt Acknowledge: This pin is used to enable 8259A interrupt-vector data onto the data bus by a sequence of interrupt acknowledge pulses issued by the CPU. |
| $A_{0}$ | 27 | I | AO Address Line: This pin acts in conjunction with the $\overline{C S}, \overline{W R}$, and $\overline{\mathrm{RD}}$ pins. It is used by the 8259A to decipher various Command Words the CPU writes and status the CPU wishes to read. It is typically connected to the CPU AO address line (A1 for iAPX 86, 88). |

## FUNCTIONAL DESCRIPTION

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

## The 8259A

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.


Figure 3a. Polled Method


Figure 3b. 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 $\mathrm{V}_{\mathrm{OH}}$ level on this line is designed to be fully compatible with the 8080A, 8085A and 8086 input levels.

## $\overline{\text { 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.

## READ/WRITE CONTROL LOGIC

The function of this block is to accept OUTput commands from the CPU. It contains the Initialization Command Word (ICW) registers and Operation Command Word (OCW) registers which store the various control formats for device operation. This function block also allows the status of the 8259A to be transferred onto the Data Bus.

## $\overline{\text { CS }}$ (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.


Figure 4a. 8259A Block Diagram


Figure 4b. 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 $\overline{\mathbb{N T A}}$ pulses to be sent to the 8259A from the CPU group.
6. These two IINTA 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{I N T A}$ pulse and and the higher 8 -bit address is released at the second $\overline{\mathrm{NTA}}$ 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 IAPX 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 iAPX $86 / 10$ will initiate a second $\overline{\text { 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 $\overline{\text { NTA }}$ 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.


Figure 4c. 8259A Block Diagram


Figure 5. 8259A Interface to Standard System Bus

## INTERRUPT SEQUENCE OUTPUTS

## MCS-80®, MCS-85 ${ }^{\circledR}$

This sequence is timed by three $\overline{\text { INTA }}$ pulses. During the first INTA pulse the CALL opcode is enabled onto the data bus.

## Content of First Interrupt <br> Vector Byte

|  | 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 Interval = 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 | D6 | 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 |


| 18 | Interval $=8$ |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | D7 | 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 <br> Vector Byte

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 |

## iAPX 86, iAPX 88

iAPX 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 IAPX 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 iAPX 86 mode):

## Content of Interrupt Vector Byte for IAPX 86 System Mode

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IR7 | T7 | T6 | T5 | T4 | T3 | $\mathbf{1}$ | $\mathbf{1}$ | $\mathbf{1}$ |
| IR6 | T7 | T6 | T5 | T4 | T3 | 1 | 1 | 0 |
| IR5 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 1 |
| IR4 | T7 | T6 | T5 | T4 | T3 | 1 | 0 | 0 |
| IR3 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 1 |
| IR2 | T7 | T6 | T5 | T4 | T3 | 0 | 1 | 0 |
| IR1 | T7 | T6 | T5 | T4 | T3 | 0 | 0 | 1 |
| IR0 | T7 | T6 | T5 | T4 | T3 | 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.
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 COMMAND WORDS (ICWS)

## 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 edge sense circuit is reset, which means that following initialization, an interrupt request (IR) input must make a low-to-high transition to generate an interrupt.
b. The Interrupt Mask Register is cleared.
c. IR7 input is assigned priority 7.
d. The slave mode address is set to 7 .
e. Special Mask Mode is cleared and Status Read is set to IRR.
f. If IC4 $=0$, then all functions selected in ICW4 are set to zero. (Non-Buffered mode*, no Auto-EOI, MCS-80, 85 system).

[^19]
## 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 $\left(A_{0}-A_{15}\right)$. 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 $\mathbf{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 iAPX 86 system $\mathrm{A}_{15}-\mathrm{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 $S N G L=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 iAPX 86 only byte 2 ) through the cascade lines.
b. In the slave mode (either when $\overline{\mathbf{S P}}=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 iAPX 86 are released by it on the Data Bus.

## INITIALIZATION COMMAND WORD 4 (ICW4)

SFNM: If $\mathrm{SFNM}=1$ the special fully nested mode is programmed.
BUF: If BUF = 1 the buffered mode is programmed. In buffered mode $\overline{\text { SP/EN }}$ becomes an enable output 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 AEOI = 1 the automatic end of interrupt mode is programmed.
$\mu$ PM: Microprocessor mode: $\mu \mathrm{PM}=0$ sets the 8259A for MCS-80, 85 system operation, $\mu$ PM $=1$ sets the 8259A for iAPX 86 system operation.


Figure 6. Initialization Sequence


Figure 7. Initialization Command Word Format

## 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 |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A0 | D7 | D8 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| 1 |  | M7 | M6 | M5 | M4 | M3 | M2 | M1 | M0 |


| OCW2 |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| R | SL | EOI | 0 | 0 | L2 | L1 | LO |


| OCW3 |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | ESMM | SMM | 0 | 1 | P | RR |

## 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, SL, 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 SL 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 SMM $=0$ the 8259A will revert to normal mask mode. When ESMM $=0$, SMM has no effect.


Figure 8. Operation Command Word Format

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

## 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 if in the Cascade mode, once for the master and once for the corresponding slave.
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 fully nested mode the highest IS level was necessarily the last level acknowledged and serviced. A non-specific EOI can be issued with OCW2 ( $E O I=1, S L=0, R=0$ ).

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 must be issued which includes as part of the command the IS level to be reset. A specific EOI can be issued with OCW2 ( $E O$ I $=1, S L=1, R=0$, and LO-L2 is the binary level of the IS bit to be reset).

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

The AEOI mode can only be used in a master 8259A and not a slave.

## AUTOMATIC ROTATION (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)


There are two ways to accomplish Automatic Rotation using OCW2, the Rotation on Non-Specific EOI Command ( $\mathrm{R}=1, \mathrm{SL}=0, \mathrm{EOI}=1$ ) and the Rotate in Automatic EOI Mode which is set by $(R=1, S L=0, E O I=0)$ and cleared by ( $R=0, S L=0, E O I=0$ ).

## SPECIFIC ROTATION

## (Specific Priority)

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 Set Priority command is issued in OCW2 where: $R=1, S L=1$; LO-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 by using the Rotate on Specific EOI command in OCW2 $(R=1, S L=1, E O I=1$ and $L O-L 2=I R$ level to receive bottom priority).

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

## POLL COMMAND

In this mode the INT output is not used or the microprocessor internal Interrupt Enable flip-flop is reset, disabling its interrupt input. Service to devices is achieved by software 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{R D}=0, \overline{C S}=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.


Figure 9. Priority Cell-Simplified Logic Diagram

## 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 via OCW3 (IRR and ISR or OCW1 [IMR]).

Interrupt Request Register (IRR): 8-bit register which contains the levels requesting an interrupt to be acknowledged. The highest request level is reset from the IRR when an interrupt is acknowledged. (Not affected by IMR.)
In-Service Register (ISR): 8-bit register which contains the priority levels that are being serviced. The ISR is updated when an End of Interrupt Command is issued.

Interrupt Mask Register: 8-bit register which contains the interrupt request lines which are masked.

The IRR can be read when, prior to the RD pulse, a Read Register Command is issued with OCW3 ( $R R=1, R I S=0$.)

The ISR can be read when, prior to the RD pulse, a Read Register Command is issued with OCW3 ( $R$ R $=1$, RIS $=1$ ).

There is no need to write an OCW3 before every status read operation, as long as the status read corresponds with the previous one; i.e., the 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 O=1$ (OCW1).
Polling overrides status read when $P=1, R R=1$ in $O C W 3$.

## EDGE AND LEVEL TRIGGERED MODES

This mode is programmed using bit 3 in ICW1.
If LTIM = ' 0 ', an interrupt request will be recognized by a low to high transition on an IR input. The IR input can remain high without generating another interrupt.

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 priority cell diagram shows a conceptual circuit 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.

In both the edge and level triggered modes the IR inputs must remain high until after the falling edge of the first INTA. If the IR input goes low before this time a DEFAULT IR7 will occur when the CPU acknowledges the interrupt. This can be a useful safeguard for detecting interrupts caused by spurious noise glitches on the IR inputs. To implement this feature the IR7 routine is used for "clean up" simply executing a return instruction, thus ignoring the interrupt. If IR7 is needed for other purposes a default IR7 can still be detected by reading the ISR. A normal IR7 interrupt will set the corresponding ISR bit, a default IR7 won't. If a default IR7 routine occurs during a normal IR7 routine, however, the ISR will remain set. In this case it is necessary to keep track of whether or not the IR7 routine was previously entered. If another IR7 occurs it is a default.


Figure 10. IR Triggering Timing Requirements

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

## 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 SP/EN to enable the buffers. In this
mode, whenever the 8259A's data bus outputs are enabled, the SP/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.

## CASCADE MODE

The 8259A can be easily interconnected in a system of one master with up to eight slaves to handle up to 64 priority levels.
The master controls the slaves through the 3 line cascade bus. The cascade bus acts like chip selects to the slaves during the INTA sequence.
In a cascade configuration, 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 8086/8088).
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. 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 (CS) input of each 8259A.
The cascade lines of the Master 8259A are activated only for slave inputs, non slave inputs leave the cascade line inactive (low).


Figure 11. Cascading the 8259A

## 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
*NOTICE: 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 $\quad\left[T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%(8259 \mathrm{~A}-8), \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%(8259 \mathrm{~A}, 8259 \mathrm{~A}-2)\right]$

| 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}_{\text {cc }}+0.5 \mathrm{~V}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output High Voltage |  | 0.45 | V | $1 \mathrm{OL}=2.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}^{\text {O }}$ - $-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} \text { (INT) }}$ | Interrupt Output High Voltage | 3.5 |  | V | $\mathrm{l}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
|  |  | 2.4 |  | V | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |
| $\mathrm{l}_{\mathrm{LI}}$ | Input Load Current | -10 | +10 | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILOL | Output Leakage Current | -10 | +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 |  | 85 | mA |  |
| ILIR | IR Input Load Current |  | -300 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0$ |
|  |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |

CAPACITANCE $\left(T_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| 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 $\left[T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%(8259 \mathrm{~A}-8), \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%(8259 \mathrm{~A}, 8259 \mathrm{~A}-2)\right]$ TIMING REQUIREMENTS

| Symbol | Parameter | 8259A-8 |  | 8259A |  | 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TAHRL | AO/CS Setup to $\overline{\mathrm{RD}} / / \overline{\mathrm{NTA}} \downarrow$ | 50 |  | 0 |  | 0 |  | ns |  |
| TRHAX | AO/ $\overline{C S}$ Hold after $\overline{\mathrm{RD}} / \mathrm{INTA} \uparrow$ | 5 |  | 0 |  | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | 420 |  | 235 |  | 160 |  | ns |  |
| TAHWL | AO/ $\overline{C S}$ Setup to $\overline{W R} \downarrow$ | 50 |  | 0 |  | 0 |  | ns |  |
| TWHAX | AO/ $\overline{C S}$ Hold after $\overline{W R} \uparrow$ | 20 |  | 0 |  | 0 |  | ns |  |
| TWLWH | $\overline{\text { WR Pulse Width }}$ | 400 |  | 290 |  | 190 |  | ns |  |
| TDVWH | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 300 |  | 240 |  | 160 |  | ns |  |
| TWHDX | Data Hold after $\overline{W R} \uparrow$ | 40 |  | 0 |  | 0 |  | ns |  |
| TJLJH | Interrupt Request Width (Low) | 100 |  | 100 |  | 100 |  | ns | See Note 1 |
| TCVIAL | Cascade Setup to Second or Third INTA $\downarrow$ (Slave Only) | 55 |  | 55 |  | 40 |  | ns |  |
| TRHRL | End of $\overline{\mathrm{RD}}$ to next $\overline{\mathrm{RD}}$ End of $\overline{\text { INTA }}$ to next INTA within an INTA sequence only | $160$ |  | 160 |  | 160 | . | ns | $\therefore$. ${ }^{\text {a }}$ |
| TWHWL | End of $\overline{W R}$ to next $\overline{W R}$ | 190 |  | 190 |  | 190 |  | ns | : |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | 8259A-8 |  | 8259A |  | 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| *TCHCL | End of Command to next Command (Not same command type) | 500 |  | 500 |  | 500 |  | ns |  |
|  | End of $\overline{\text { NTA }}$ sequence to next INTA sequence. |  |  |  |  |  |  |  |  |

*Worst case timing for TCHCL in an actual microprocessor system is typically much greater than 500 ns (i.e. $8085 \mathrm{~A}=1.6 \mu \mathrm{~s}$, $8085 \mathrm{~A}-2=1 \mu \mathrm{~s}, 8086=1 \mu \mathrm{~s}, 8086-2=625 \mathrm{~ns}$ )
NOTE: This is the low time required to clear the input latch in the edge triggered mode.

TIMING RESPONSES

| Symbol | Parameter | 8259A-8 |  | 8259A |  | 8259A-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TRLDV | Data Valid from $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \downarrow$ |  | 300 |  | 200 |  | 120 | ns | ```C of Data Bus= 100 pF``` |
| TRHDZ | Data Float after $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}}\rceil$ | 10 | 200 | 10 | 100 | 10 | 85 | ns | C of Data Bus |
| TJHIH | Interrupt Output Delay |  | 400 |  | 350 |  | 300 | ns | Max text C = 100 pF <br> Min. test $\mathrm{C}=15 \mathrm{pF}$ |
| TIALCV | Cascade Valid from First $\overline{\operatorname{INTA}} \downarrow$ (Master Only) |  | 565 |  | 565 |  | 360 | ns | $\mathrm{C}_{\mathbb{N T}}=100 \mathrm{pF}$ |
| TRLEL | Enable Active from $\overline{\mathrm{RD}}\rfloor$ or $\overline{\mathrm{NTA}}\rfloor$ |  | 160 |  | 125 |  | 100 | ns | $\mathrm{C}_{\text {CASCADE }}=100 \mathrm{pF}$ |
| TRHEH | Enable Inactive from $\overline{\mathrm{RD}} \uparrow$ or $\overline{\mathrm{INTA}} \uparrow$ |  | 325 |  | 150 |  | 150 | ns |  |
| TAHDV | Data Valid from Stable Address |  | 350 |  | 200 |  | 200 | ns |  |
| TCVDV | Cascade Valid to Valid Data |  | 300 | . | 300 |  | 200 | ns |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## WAVEFORMS (Continued)

READ/INTA


OTHER TIMING


## WAVEFORMS (Continued)



NOTES: Interrupt output must remain HIGH at least until leading edge of first INTA. 1. Cycle 1 in iAPX 86, iAPX 88 systems, the Data Bus is not active.

## 8355/8355-2 <br> 16,384-BIT ROM WITH I/O

## 2048 Words $\times 8$ Bits

- Single + 5V Power Supply


## - Directly Compatible with 8085A

 and IAPX 88 Microprocessors2 General Purpose 8-Bit I/O Ports

## - Each I/O Port Line Individually Programmable as Input or Output <br> - Multiplexed Address and Data Bus <br> - Internal Address Latch <br> - 40-Pin DIP

The Intel ${ }^{\circledR} 8355$ is a ROM and I/O chip to be used in the 8085A and IAPX 88 microprocessor systems. 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 lines and each I/O port line is individually programmable as input or output.
The 8355-2 has a 300 ns access time for compatibility with the $8085 \mathrm{~A}-2$ and 5 MHz iAPX 88 microprocessors.


Figure 1. Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| ALE | I | Address Latch Enable: When high, $A D_{0-7}, 10 / M, A_{8-10}$, $C E$, and CE enter address latched. The signals ( $A D, 10 / \mathrm{M}$, $\left.A_{8-10}, C E, C E\right)$ are latched in at the trailing edge of ALE. |
| $A D_{0-7}$ | I | Address/Data Bus (Bidirectional): The lower 8-bits of the ROM or I/O address are applied to the bus lines when ALE is high. During an I/O cycle, Port A or $B$ is selected based on the latched value of $A D_{0}$. If RD or IOR is low when the latched chip enables are active, the output buffers present data on the bus. |
| A8-10 | 1 | Address Bus: High order bits of the ROM address. They do not affect I/O operations. |
| $\begin{aligned} & C E_{1} \\ & C E_{2} \end{aligned}$ | 1 | Chip Enable: 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 $A D_{0-7}$ and READY outputs will be in a high impedance state. |
| 10/M | I | I/O Memory: If the latched IO/M is high when RD is low, the output data comes from an I/O port. If it is low, the output data comes from the ROM. |
| RD | I | Read: If the latched Chip Enables are active when RD goes low, the $A D_{0-7}$ output buffers are enabled and output either the selected ROM location or I/O port. When both RD and IOR are high, the $A D_{0}-7$ output buffers are 3-state. |
| 10W | 1 | I/O Write: 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 $I O / M$ is ignored. |
| CLK | 1 | Clock: Used to force the READY into its high impedance state after it has been forced low by CE low, CE high and ALE high. |
| READY | 0 | READY: A 3-state output controlied by $\mathrm{CE}_{1}, \mathrm{CE}_{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. |
| $\mathrm{PA}_{0-7}$ | 1/0 | Port A: General purpose I/O pins. Their input/output direction is determined by the contents of Data Direction Register (DDR). Port A is selected for write operations when the Chip Enables are active and IOW is low and a 0 was previously latched from $A D_{0}$. <br> Read operation is selected by either IOR low and active Chip Enables and $A D_{0}$ low, or IO/M high, RD low, active chip enables, and $A D_{0}$ low. |
| $\mathrm{PB}_{0-7}$ | 1/0 | Port B: This general purpose I/O port is identical to Port A except that it is selected by a 1 latched from $A D_{0}$. |
| RESET | 1 | Reset: An input high causes all pins in Port $A$ and $B$ to assume input mode. |
| IOR | 1 | I/O Read: When the Chip Enables are active, a low on IOR will output the selected I/O port onto the AD bus. IOR low performs the same function as the combination IO/M high and RD low. When IOR is not used in a system, IOR should be tied to $\mathrm{V}_{\mathrm{CC}}$ ("1"). |
| $\mathrm{V}_{\mathrm{CC}}$ |  | Voltage: +5 volt supply. |
| $\mathrm{V}_{\text {SS }}$ |  | Ground: Ground Reference. |

## FUNCTIONAL DESCRIPTION

## ROM Section

The 8355 contains an 8-bit address latch which allows it to interface directly to MCS-48, MCS-85, and IAPX 88 Microcomputers without additional hardware.
The ROM section of the chip is addressed by an 11-bit address and the Chip Enables. The address and levels on the Chip Enable pins are latched into the address latches on the falling edge of ALE. If the latched Chip Enables are active and $I O / \bar{M}$ is low when $\overline{R D}$ goes low, the contents of the ROM location addressed by the latched address are püt out through AD0-7 output buffers.

## I/O Section

The I/O section of the chip is addressed by the latched value of $A D_{0-1}$. Two 8-bit Data Direction Registers (DDR) in 8355 determine the input/output status of each pin in the corresponding ports. A " 0 " in a particular bit position of a DDR signifies that the corresponding I/O port bit is in the input mode. A " 1 " in a particular bit position signifies that the corresponding I/O port bit is in the output mode. In this manner the I/O ports of the 8355 are bit-bybit programmable as inputs or outputs. The table summarizes port and DDR designation. DDR's cannot be read.

| $A D_{1}$ | $A D_{0}$ | Selection |
| :---: | :---: | :--- |
| 0 | 0 | Port A |
| 0 | 1 | Port B |
| 1 | 0 | Port A Data Direction Register (DDR A) |
| 1 | 1 | Port B Data Direction Register (DDR B) |

When $\overline{\text { IOW }}$ goes low and the Chip Enables are active, the data on the $\mathrm{AD}_{0-7}$ is written into $1 / \mathrm{O}$ port selected by the latched value of $A D_{0-1}$. During this operation all I/O bits of the selected port are affected, regardless of their I/O mode and the state of $10 / \bar{M}$. The actual output level does not change until IOW returns high (glitch free output).
A port can be read out when the latched Chip Enables are active and either $\overline{R D}$ goes low with $10 / \bar{M}$ high, or $\overline{I O R}$ goes low. Both input and output mode bits of a selected port will appear on lines AD0-7.

To clarify the function of the I/O ports and Data Direction Registers, the following diagram shows the configuration of one bit of PORT A and DDR A. The same logic applies to PORT B and DDR B.

Note that hardware RESET or writing a zero to the DDR latch will cause the output latch's output buffer to be disabled, preventing the data in the output latch from being passed through to the pin. This is equivalent to putting the port in the input mode. Note also that the data can be written to the Output Latch even though the Output Buffer has been disabled. This enables a port to be initialized with a value prior to enabling the output.
The diagram also shows that the contents of PORT A and PORT B can be read even when the ports are configured as outputs.


Figure 3. 8355 One Bit of Port A and DDR A

## System Interface with 8085A and IAPX 88

A system using the 8355 can use either one of the two I/O Interface techniques:

- Standard I/O
- Memory Mapped I/O

If a standard I/O technique is used, the system can use the feature of both CE and $\overline{C E}$. By using a combination of unused address lines $A_{11-15}$ and the Chip Enable inputs, the system can use up to 5 each 8355's without requiring a CE decoder. See Figure 5a and 5b.
If a memory mapped I/O approach is used the 8355 will be selected by the combination of both the Chip Enables and $I O / \bar{M}$ using the $A D_{8-15}$ address lines. See Figure 4.


Figure 4. 8355 in 8085A System (Memory-Mapped I/O)

## iAPX 88 FIVE CHIP SYSTEM:

- 1.25 K Bytes RAM
- 2 K Bytes ROM
- 38 I/O Pins
- 1 Internal Timer
- 2 Interrupt Levels


Figure 5a. IAPX 88 Five Chip System Configuration


NOTE: Use CE $\mathbf{1}_{1}$ for the first 8355 in the system, and $C_{2}$ for the other 8355's. Permits up to 5-8355's in a system without CE decoder.

Figure 5b. 8355 in 8085A System (Standard I/0)

| ABSOLUTE MAXIMUM RATINGS* |  |
| :---: | :---: |
| Temperature Under Bias | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Storage Temperature | $6^{6}{ }^{\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 |

D.C. CHARACTERISTICS $\quad\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. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V | $\mathrm{~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{l}_{\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}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\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 | 8355 |  | 8355-2 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| tcyc | Clock Cycle Time | 320 |  | 200 |  | ns |
| T1 | CLK Pulse Width | 80 |  | 40 |  | ns |
| T2 | CLK Pulse Width | 120 |  | 70 |  | ns |
| $\mathrm{t}_{\mathrm{f}, \mathrm{tr}_{\mathrm{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 |
| tRD | Valid Data Out Delay from READ Control |  | 170 |  | 140 | ns |
| $t_{\text {AD }}$ | 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 |
| $\mathrm{t}_{\mathrm{RP}}$ | Port Input Hold Time | 50 |  | 50 |  | ns |
| try | 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 |

A.C. TESTING INPUT, OUTPUT WAVEFORM


## A.C. TESTING LOAD CIRCUIT


$C_{L}=150 \mathrm{pF}$
$C_{L}$ INCLUDES JIG CAPACITANCE

## WAVEFORMS

ROM READ AND I/O READ AND WRITE


8355 CLOCK SPECIFICATIONS


## WAVEFORMS (Continued)

INPUT MODE

## OUTPUT MODE


*DATA BUS TIMING IS SHOWN IN FIGURE 4.

WAIT STATE


NOTE: Ready $=0$.

# 8755A /8755A-2 16,384-BIT EPROM WITH I/O 

2048 Words $\times 8$ Bits<br>- Single +5V Power Supply ( $\mathrm{V}_{\mathrm{cc}}$ )

## - Directly Compatible with 8085A and 8088 Microprocessors

U.V. Erasable and Electrically Reprogrammable

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

\author{

- Internal Address Latch
}

The Intel ${ }^{\oplus}$ 8755A is an erasable and electrically reprogrammable ROM (EPROM) and I/O chip to be used in the 8085A and 8088 microprocessor systems. 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.
The $8755 \mathrm{~A}-2$ is a high speed selected version of the 8755 A compatible with the $5 \mathrm{MHz} 8085 \mathrm{~A}-2$ and the 5 MHz 8088.


Figure 1. Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| ALE | 1 | Address Latch Enable: When Address Latch Enable goes high, $\mathrm{AD}_{0-7}, 10 / \mathrm{M}$, $\mathrm{A}_{8-10}, \mathrm{CE}_{2}$, and $\overline{\mathrm{CE}}_{1}$ enter the address latches. The signals ( $A D, 1 O / M, A_{8-10}$, $C E)$ are latched in at the trailing edge of ALE. |
| $\mathrm{AD}_{0-7}$ | 1 | 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. <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{O R}$ is low when the latched Chip Enables are active, the output buffers present data on the bus. |
| A8-10 | I | Address: 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} \end{aligned}$ | 1 | Chip Enable Inputs: $\overline{\mathrm{CE}_{1}}$ is active low and $\mathrm{CE}_{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 $A D_{0-7}$ and READY outputs will be in a high impedance state. $\mathrm{CE}_{1}$ is also used as a programming pin. (See section on programming.) |
| $10 / \bar{M}$ | 1 | I/O Memory: If the latched $10 / \bar{M}$ is high when $\overline{\mathrm{RD}}$ is low, the output data comes from an I/O port. If it is low the output data comes from the PROM. |
| $\overline{\mathrm{RD}}$ | I | Read: If the latched Chip Enables are active when RD goes low, the $A D_{0-7}$ output buffers are enabled and output either the selected PROM location or I/O port. When both $\overline{R D}$ and $\overline{\mathrm{OR}}$ are high, the $A D_{0-7}$ output buffers are 3-stated. |
| IOW | 1 | I/O Write: 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 $I O / M$ is ignored. |
| CLK | 1 | Clock: The CLK is used to force the READY into its high impedance state after it has been forced low by $\overline{\mathrm{CE}_{1}}$ low, $\mathrm{CE}_{2}$ high, and ALE high. |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| READY | 0 | Ready is a 3-state output controlled by $\mathrm{CE}_{2}, \mathrm{CE}_{1}, \mathrm{ALE}$ and CLK. READY is forced low when the Chip Enables are actove during the time ALE is high, and remains low until the rising edge of the next CLK. (See Figure 6.) |
| $\mathrm{PA}_{0-7}$ | 1/0 | Port A: These are general purpose I/O pins. Their input/output direction is determined by the contents of Data Direction Register (DDR). Port A is selected for write operations when the Chip Enables are active and $\overline{\mathrm{IOW}}$ is low and a 0 was previously latched from $A D_{0}, A D_{1}$. <br> Read Operation is selected by either $\overline{O R}$ low and active Chip Enables and $A_{0}$ and $A D_{1}$ low, or $10 / \bar{M}$ high, $\overline{R D}$ low, active Chip Enables, and $A D_{0}$ and $A D_{j}$ low. |
| $\mathrm{PB}_{0-7}$ | 1/0 | Port B: This general purpose I/O port is identical to Port A except that it is selected by a 1 latched from $A D_{0}$ and a 0 from $A D_{1}$. |
| RESET | 1 | Reset: In normal operation, an input high on RESET causes all pins in Ports A and $B$ to assume input mode (clear DDR register). |
| $\overline{\overline{O R}}$ | 1 | I/O Read: When the Chip Enables are active, a low on $\overline{O R}$ will output the selected I/O port onto the AD bus. $\overline{\mathrm{IOR}}$ low performs the same function as the combination of $10 / \bar{M}$ high and $\overline{R D}$ low. When $\overline{O R}$ is not used in a system, $\overline{I O R}$ should be tied to $\mathrm{V}_{\mathrm{C}}$ (" 1 "). |
| $\mathrm{V}_{\text {cc }}$ |  | Power: +5 volt supply. |
| $\mathrm{V}_{\text {SS }}$ |  | Ground: Reference. |
| $V_{D D}$ |  | Power Supply: $\mathrm{V}_{\mathrm{DD}}$ is a programming voltage, and must be tied to $V_{C c}$ when the 8755A is being read. <br> For programming, a high voltage is supplied with $\mathrm{V}_{\mathrm{DD}}=25 \mathrm{~V}$, typical. (See section on programming.) |

## FUNCTIONAL DESCRIPTION

## PROM Section

The 8755A contains an 8-bit address latch which allows it to interface directly to MCS-48, MCS-85 and iAPX 88/10 Microcomputers without additional hardware.
The PROM section of the chip is addressed by the 11-bit address and CE . The address, $\mathrm{CE}_{1}$ and $\mathrm{CE}_{2}$ are latched into the address latches on the falling edge of ALE. If the latched Chip Enables are active and $I O / \bar{M}$ is low when $\overline{R D}$ goes low, the contents of the PROM location addressed by the latched address are put out on the $A D_{0-7}$ lines (provided that $V_{D D}$ is tied to $V_{C C}$.)

## I/O Section

The I/O section of the chip is addressed by the latched value of $A D_{0-1}$. Two 8-bit Data Direction Registers (DDR) in 8755A determine the input/output status of each pin in the corresponding ports. A " 0 " in a particular bit position of a DDR signifies that the corresponding I/O port bit is in the input mode. $A$ " 1 " in a particular bit position signifies that the corresponding I/O port bit is in the output mode. In this manner the I/O ports of the 8755A are bit-bybit programmable as inputs or outputs. The table summarizes port and DDR designation. DDR's cannot be read.

| $\mathbf{A D}$ | $\mathbf{A D}_{0}$ | Selection |
| :---: | :---: | :--- |
| 0 | 0 | Port A |
| 0 | 1 | Port B |
| 1 | 0 | Port A Data Direction Register (DDR A) |
| 1 | 1 | Port B Data Direction Register (DDR B) |

When $\overline{\text { IOW }}$ goes low and the Chip Enables are active, the data on the AD is written into I/O port selected by the latched value of $\mathrm{AD}_{0-1}$. During this operation all I/O bits of the selected port are affected, regardless of their I/O mode and the state of $10 / \bar{M}$. The actual output level does not change until IOW returns high. (glitch free output)
A port can be read out when the latched Chip Enables are active and either $\overline{R D}$ goes low with $10 / \bar{M}$ high, or $\overline{\text { IOR goes }}$ low. Both input and output mode bits of a selected port will appear on lines $A_{0-7}$.
To clarify the function of the I/O Ports and Data Direction Registers, the following diagram shows the configuration of one bit of PORT A and DDR A. The same logic applies to PORT B and DDR B.

8755A
ONE BIT OF PORT A AND DDR A:


WRITE DDR $A=(\overline{10 W}=0) \cdot($ CHIP ENABLES ACTIVE) - (DDR A ADDRESS SELECTED) READ PA $=\{[(I O / \bar{M}=1) \bullet(\overline{\operatorname{RD}}=0)]+(\overline{I O R}=0)\} \bullet($ CHIP ENABLES ACTIVE) • (PORT A ADDRESS SELECTEO) NOTE: WRITE PA IS NOT QUALIFIED BY $10 / \bar{M}$.

Note that hardware RESET or writing a zero to the DDR latch will cause the output latch's output buffer to be disabled, preventing the data in the Output Latch from being passed through to the pin. This is equivalent to putting the port in the input mode. Note also that the data can be written to the Output Latch even though the Output Buffer has been disabled. This enables a port to be initialized with a value prior to enabling the output.

The diagram also shows that the contents of PORT A and PORT B can be read even when the ports are configured as outputs.

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. 13-34 of 1978 Data Catalog.
2. Special adaptor socket.
3. Described on p. 13-39 of 1978 Data Catalog.
4. Described on p. 13-71 of 1978 Data Catalog.

## 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® Universal PROM Programmer (UPP), and the PROMPT ${ }^{\text {Tm }} 80 / 85$ and PROMPT-48 ${ }^{\text {™ }}$ 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) 'VDD' should be at +5 V .

Preliminary timing diagrams and parameter values pertaining to the 8755A programming operation are contained in Figure 7.

## SYSTEM APPLICATIONS

## System Interface with 8085A and 8088

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 $\mathrm{I} / \mathrm{O}$ technique is used, the system can use the feature of both $\mathrm{CE}_{3}$ and $\overline{\mathrm{CE}}_{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. See Figure 2a and 2b.

If a memory mapped I/O approach is used the 8755A will be selected by the combination of both the Chip Enables and $10 / \bar{M}$ using the $A D_{8-15}$ address lines. See Figure 1.


Figure 3. 8755A in 8085A System (Memory-Mapped I/O)

## iAPX 88 FIVE CHIP SYSTEM

Figure 4 shows a five chip system containing:

- 1.25K Bytes RAM
- 2K Bytes ROM
- 38 I/O Pins
- 1 Interval Timer
- 2 Interrupt Levels


Figure 4. iAPX 88 Five Chip System Configuration

Note: Use $\overline{C E}_{1}$ for the first 8755A in the system, and CE $_{2}$ for the other 8755A's. Permits up to 5-8755A's in a system without CE decoder.

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

D.C. CHARACTERISTICS

$$
\begin{aligned}
& \left(T_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ}, V_{C C}=V_{D D}=5 \mathrm{~V} \pm 5 \% ;\right. \\
& \left.V_{C C}=V_{D D}=5 \mathrm{~V} \pm 10 \% \text { for } 8755 \mathrm{~A}-2\right)
\end{aligned}
$$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V | $\mathrm{~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}_{\mathrm{SS}} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\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 |  |
| $\mathrm{I}_{\mathrm{DD}}$ | V $_{\text {DD }}$ Supply Current |  | 30 | mA | $\mathrm{~V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Capacitance of Input Buffer |  | 10 | pF | $\mathrm{f}_{\mathrm{C}}=1 \mu \mathrm{~Hz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | Capacitance of I/O Buffer |  | 15 | pF | $\mathrm{f}_{\mathrm{C}}=1 \mu \mathrm{~Hz}$ |

$$
\begin{array}{ll}
\text { D.C. CHARACTERISTICS — PROGRAMMING } & \left(T_{A}=0^{\circ} \mathrm{C} \text { to } 70^{\circ}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=25 \mathrm{~V} \pm 1 \mathrm{~V} ;\right. \\
& \left.\mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{D D}=5 \mathrm{~V} \pm 10 \% \text { for } 8755 \mathrm{~A}-2\right)
\end{array}
$$

| 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. CHARACTERISTICS <br> $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ}, V_{C C}=5 \mathrm{~V} \pm 5 \%$; <br> $V_{C C}=V_{D D}=5 V \pm 10 \%$ for $8755 A-2$ )

| Symbol | Parameter | 8755A |  | $\begin{gathered} 8755 A-2 \\ \text { (Preliminary) } \\ \hline \end{gathered}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| tcyc | Clock Cycle Time | 320 |  | 200 |  | ns |
| T1 | CLK Pulse Width | 80 |  | 40 |  | ns |
| $\mathrm{T}_{2}$ | CLK Pulse Width | 120 |  | 70 |  | ns |
| $\mathrm{t}_{\mathrm{f}, \mathrm{tr} \text { }}$ | CLK Rise and Fall Time |  | 30 |  | 30 | ns |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | 30 |  | ns |
| tLA | Address Hold Time after Latch | 80 |  | 45 |  | ns |
| tLC | Latch to READ/WRITE Control | 100 |  | 40 |  | ns |
| tro | Valid Data Out Delay from READ Control* |  | 170 |  | 140 | ns |
| $t_{A D}$ | Address Stable to Data Out Valid** |  | 450 |  | 300 | 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 | 30 |  | 10 |  | ns |
| twp | WRITE to Port Output |  | 400 |  | 300 | ns |
| tPR | Port Input Set Up Time | 50 |  | 50 |  | ns |
| $t_{\text {R } P}$ | Port Input Hold Time to Control | 50 |  | 50 |  | ns |
| try | READY HOLD Time to Control | 0 | 160 | 0 | 160 | ns |
| tary | ADDRESS (CE) to READY |  | 160 |  | 160 | ns |
| trv | Recovery Time Between Controls | 300 |  | 4 200 |  | ns |
| trde | READ Control to Data Bus Enable | 10 |  | - 10 |  | ns |

## NOTE:

$C_{\text {LOAD }}=150 \mathrm{pF}$.
*Or $T_{A D}-\left(T_{A L}+T_{L C}\right)$, whichever is greater.
**Defines ALE to Data Out Valid in conjunction with $\mathrm{T}_{\text {AL }}$.
A.C. CHARACTERISTICS - PROGRAMMING $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}=25 \mathrm{~V} \pm 1 \mathrm{~V}$; $V_{C C}=V_{D D}=5 V \pm 10 \%$ for $8755 A-2$ )

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: | :---: |
| tps | Data Setup Time | 10 |  |  | ns |
| tpD | Data Hold Time | 0 |  |  | ns |
| ts | Prog Pulse Setup Time | 2 |  |  | $\mu \mathrm{~s}$ |
| tH | Prog Pulse Hold Time | 2 |  |  | $\mu \mathrm{~s}$ |
| tPR | Prog Pulse Rise Time | 0.01 | 2 |  | $\mu \mathrm{~s}$ |
| tPF | Prog Pulse Fall Time | 0.01 | 2 |  | $\mu \mathrm{~s}$ |
| tPRG | Prog Pulse Width | 45 | 50 |  | msec |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

## CLOCK SPECIFICATION FOR 8755A



PROM READ, I/O READ AND WRITE


## WAVEFORMS (Continued)

I/O PORT

B. OUTPUT MODE


WAIT STATE (READY $=\mathbf{0}$ )


WAVEFORMS (Continued)


# iAPX 86/10 <br> 16-BIT HMOS MICROPROCESSOR 

8086/8086-2/8086-1

## - Direct Addressing Capability to 1 MByte of Memory

- Architecture Designed for Powerful Assembly Language and Efficient High Level Languages.
- 14 Word, by 16-Bit Register Set with Symmetrical Operations


## - 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
- Range of Clock Rates: 5 MHz for 8086, 8 MHz for 8086-2, 10 MHz for 8086-1
- MULTIBUS ${ }^{\text {™ }}$ System Compatible Interface

The Intel iAPX 86/10 high performance 16 -bit CPU is available in three clock rates: 5,8 and 10 MHz . The CPU is implemented in N-Channel, depletion load, silicon gate technology (HMOS), and packaged in a 40-pin CerDIP package. The iAPX 86/10 operates in both single processor and multiple processor configurations to achieve high performance levels.


Figure 1. iAPX 86/10 CPU Block Diagram


40 LEAD

Figure 2. iAPX 86/10 Pin Configuration

## Table 1. Pin Description

The following pin function descriptions are for IAPX 86 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).


Table 1. Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| NMI | 17 | 1 | Non-maskable interrupt: an edge triggered inpút 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 | 21 | 1 | 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 | 19 | 1 | Clock: provides the basic timing for the processor and bus controller. It is asymmetric with a $33 \%$ duty cycle to provide optimized internal timing. |
| $\mathrm{V}_{\text {CC }}$ | 40 |  | $\mathbf{V C C}^{\text {c }}+5 \mathrm{~V}$ power supply pin. |
| GND | 1,20 |  | Ground |
| MN/ $\overline{M X}$ | 33 | 1 | Minimum/Maximum: indicates what mode the processor is to operate in. The two modes are discussed in the following sections. |

The following pin function descriptions are for the $8086 / 8288$ system in maximum mode (i.e., $M N / \overline{M X}=V_{S S}$ ). Only the pin functions which are unique to maximum mode are described; all other pin functions are as described above.


Table 1. Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
|  |  |  | If the local bus is idle when the request is made the two possible events will follow: <br> 1. Local bus will be released during the next clock. <br> 2. A memory cycle will start within 3 clocks. Now the four rules for a currently active memory cycle apply with condition number 1 already satisfied. |
| $\overline{\text { LOCK }}$ | 29 | 0 | $\overline{\text { LOCK: }}$ output indicates that other system bus masters are not to gain control of the system bus while $\overline{L O C K}$ is active LOW. The $\overline{L O C K}$ 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." |
| $\mathrm{QS}_{1}, \mathrm{QS}_{0}$ | 24, 25 | 0 | Queue Status: The queue status is valid during the CLK. cycle after which the queve operation is performed. <br> $\mathrm{QS}_{1}$ and $\mathrm{QS}_{0}$ provide status to allow external tracking of the internal 8086 instruction queue. |

The following pin function descriptions are for the 8086 in 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/IO | 28 | 0 | Status line: logically equivalent to $\mathrm{S}_{2}$ in the maximum mode. It is used to distinguish a memory access from an I/O access. M/ $\overline{\mathrm{O}}$ becomes valid in the $T_{4}$ preceding a bus cycle and remains valid until the final $T_{4}$ of the cycle ( $M=H I G H, I O=L O W$ ). M/IO floats to 3-state OFF in local bus "hold acknowledge." |
| :---: | :---: | :---: | :---: |
| $\overline{W R}$ | 29 | 0 | Write: indicates that the processor is performing a write memory or write I/O cycle, depending on the state of the $\mathrm{M} / \overline{\mathrm{O}}$ signal. $\overline{\mathrm{WR}}$ is active for $\mathrm{T}_{2}, \mathrm{~T}_{3}$ and $\mathrm{T}_{\mathrm{W}}$ of any write cycle. It is active LOW, and floats to 3 -state OFF in local bus "hold acknowledge." |
| $\overline{\text { INTA }}$ | 24 | 0 | $\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. |
| ALE | 25 | 0 | Address Latch Enable: 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/ $\bar{R}$ | 27 | 0 | Data Transmit/Receive: needed in minimum system that desires to use an 8286/8287 data bus transceiver. It is used to control the direction of data flow through the transceiver. Logically $D T / \bar{R}$ is equivalent to $\bar{S}_{1}$ in the maximum mode, and its timing is the same as for M/IO. ( $T=H I G H, R=L O W$.) This signal floats to 3 -state OFF in local bus "hold acknowledge." |
| $\overline{\text { DEN }}$ | 26 | 0 | Data Enable: provided as an output enable for the $8286 / 8287$ in a minimum system which uses the transceiver. $\overline{\text { 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 $\mathrm{T}_{4}$, while for a write cycle it is active from the beginning of $\mathrm{T}_{2}$ until the middle of $T_{4}$. $\overline{\text { DEN }}$ floats to 3 -state OFF in local bus "hold acknowledge." |
| HOLD, HLDA | 31, 30 | 1/0 | 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 a $T_{4}$ or $T_{1}$ clock cycle. 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. <br> The same rules as for $\overline{R Q I} \overline{G T}$ apply regarding when the local bus will be released. <br> HOLD is not an asynchronous input. External synchronization should be provided if the system cannot otherwise guarantee the setup time. |

## FUNCTIONAL DESCRIPTION

## GENERAL OPERATION

The internal functions of the iAPX 86/10 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 organized as a linear array of up to 1 million bytes, addressed as $\mathbf{0 0 0 0 0}(\mathrm{H})$ to $\operatorname{FFFFF}(\mathrm{H})$. The memory is logically divided into code, data, extra data, and stack segments of up to 64 K bytes each, with each segment falling on 16-byte boundaries. (See Figure 3a.)

All memory references are made relative to base addresses contained in high speed segment registers. The segment types were chosen based on the addressing needs of programs. The segment register to be selected is automatically chosen according to the rules of the following table. All information in one segment type share the same logical attributes (e.g. code or data). By structuring memory into relocatable areas of similar characteristics and by automatically selecting segment registers, programs are shorter, faster, and more structured.

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 ( $\mathrm{D}_{15}-\mathrm{D}_{8}$ ) and a low bank ( $\mathrm{D}_{7}-\mathrm{D}_{0}$ ) of 512K 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 $\mathrm{D}_{7}-\mathrm{D}_{0}$ bus lines while odd addressed byte data ( $\mathrm{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.

| Memory <br> Reference Need | Segment Register <br> Used | Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | CODE (CS) | Automatic with all instruction prefetch. |
| Stack | STACK (SS) | All stack pushes and pops. Memory references relative to BP <br> base register except data references. |
| Local Data | Data references when: relative to stack, destination of string <br> operation, or explicitly overridden. |  |
| External (Global) Data (DS) | EXTRA (ES) | Destination of string operations: Explicitly selected using a <br> segment override. |



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 FFFFOH through FFFFFFH 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 003 FFH 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 iAPX 86/10 systems are sufficiently different that they cannot be done efficiently with 40 uniquely defined pins. Consequently, the 8086 is equipped with a strap pin ( $M N / \overline{M X}$ ) which defines the system configuration. The definition of a certain subset of the pins changes dependent on the condition of the strap pin. When MN/MX 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 ${ }^{\text {TM }}$ architecture. 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 IAPX 86/10 Typical Configuration


Figure 4b. Maximum Mode iAPX 86/10 Typical Configuration

## BUS OPERATION

The 86/10 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 $\mathrm{T}_{1}$ and data transfer occurs on the bus during $\mathrm{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 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 MN/MX 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}_{1}}$ | $\overline{\mathbf{S}_{0}}$ | CHARACTERISTICS |
| :--- | :---: | :--- | :--- |
| $0($ LOW ) | 0 | 0 | Interrupt Acknowledge |
| 0 | 0 | 1 | Read I/O |
| 0 | 1 | 0 | Write I/O |
| 0 | 1 | 1 | Halt |
| $1(\mathrm{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 $\mathrm{S}_{3}$ through $\mathrm{S}_{7}$ are multiplexed with highorder address bits and the 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}}$ | CHARACTERISTICS |
| :--- | :--- | :--- |
| 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.

## I/O ADDRESSING

In the 86/10, I/O operations can address up to a maximum of 64 K I/O byte registers or 32 K I/O word registers. The $\mathrm{I} / \mathrm{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.


Figure 5. Basic System Timing
iAPX 86/10

## 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 Family User's 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.

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 (NMI)

The processor provides a single non-maskable interrupt pin (NMI) which has higher priority than the maskable interrupt request pin (INTR). A typical use would be to activate 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 86/10 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 $\overline{\mathrm{S}}_{2} \overline{\mathrm{~S}}_{1} \overline{\mathrm{~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{\mathrm{LOCK}}$ is active a request on a RQ/GT pin will be recorded and then honored at the end of the 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 re-executed repeatedly until that time. This activity does not consume bus cycles. The processor remains in an idle 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.

## 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 $\mathrm{MN} / \overline{\mathrm{MX}}$ pin is strapped to $\mathrm{V}_{\mathrm{SS}}$ and the processor emits coded status information which the 8288 bus controller uses to generate MULTIBUS compatible bus control signals. Figure 5 illustrates the signal timing relationships.


Figure 7. iAPX 86/10 Register Model

## 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 M/IO 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 / \bar{O}$ signal is again asserted to indicate a memory or I/O write operation. In the $\mathrm{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/IO word to be read or written according to the following table:

| $\overline{\text { BHE }}$ | AO | CHARACTERISTICS |
| :---: | :---: | :--- |
| 0 | 0 | Whole word <br> 0 |
| 1 | 0 | Upper byte from/ <br> to odd address <br> 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 acknowledge cycle and a read cycle is that the interrupt 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 SIZE SYSTEMS

For medium size systems the $M N / \overline{M X}$ pin is connected to $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/ $\overline{\mathrm{R}}$ are generated by the 8288 instead of the processor in this configuration although their timing remains relatively the same. The 8086 status outputs ( $\overline{\mathrm{S}}_{2}, \overline{\mathrm{~S}}_{1}$, and $\overline{\mathrm{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 OE 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".

## 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 . . . . . . . . . . . . . . . . . - 1.0 to +7V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 2.5 Watt
*NOTICE: 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: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V} \pm 10 \%$ )
(8086-1: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%$ )
(8086-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. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | 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}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Power Supply Current: 8086 <br> $8086-1$ <br> $8086-2$ |  | $\begin{aligned} & 340 \\ & 360 \\ & 350 \end{aligned}$ | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $I_{L I}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {cc }}$ |
| Lo | 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.\mathrm{AD}_{0}-\mathrm{AD}_{15}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{10}$ | Capacitance of I/O Buffer $\left(\mathrm{AD}_{0}-\mathrm{AD}_{15}, \overline{\mathrm{RQ}} / \overline{\mathrm{GT}}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS (8086: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$ )
(8086-1: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V} \pm 5 \%$ )
(8086-2: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, V_{C C}=5 \mathrm{~V} \pm 5 \%$ )

## MINIMUM COMPLEXITY SYSTEM <br> TIMING REQUIREMENTS

| Symbol | Parameter | 8086 |  | 8086-1 (Preliminary) |  | 8086-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 100 | 500 | 125 | 500 | ns |  |
| TCLCH | CLK Low Time | 118 |  | 53. |  | 68 | $\cdots$ | ns |  |
| TCHCL | CLK High Time | 69 |  | 39 |  | 44 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | - 10 |  | 10 | ns | From 1.0 V to 3.5V |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 3.5 \mathrm{~V} \text { to } \\ & 1.0 \mathrm{~V} \end{aligned}$ |
| TDVCL | Data in Setup Time | 30 |  | 5 |  | 20 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TRIVCL | RDY Setup Time into 8284A (See Notes 1, 2) | 35 |  | 35 |  | 35 |  | ns | , |
| TCLR1X | RDY Hold Time into 8284A (See Notes 1, 2) | $0$ |  | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup <br> Time into 8086 | 118 |  | 53 |  | 68 |  | ns |  |
| TCHRYX | READY Hold Time into 8086 | 30 |  | 20 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 3) | -8 | - | -10 |  | : -8 |  | ns |  |
| THVCH | HOLD Setup Time | 35 |  | 20 |  | 20 |  | ns |  |
| TINVCH | INTR, NMI, TEST <br> Setup Time (See <br> Note 2) | 30 |  | 15 |  | 15 | . | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 |  | 20 | ns | From 0.8 V to $2.0 \mathrm{~V}$ |
| TIHIL | Input Fall Time (Except CLK) |  | 12 | , | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. CHARACTERISTICS (Continued)

timing responses

| Symbol | Parameter | $8086$ |  | 8086-1 (Prellminary) |  | 8086-2 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 50 | 10 | 60 | ns | ${ }^{*} \mathrm{C}_{\mathrm{L}}=20-100 \mathrm{pF}$ for all 8086 Outputs (In addition to $\mathbf{8 0 8 6}$ selfload) |
| TCLAX | Address Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | 10 | 40 | TCLAX | 50 | ns |  |
| TLHLL | ALE Width | TCLCH-20 |  | TCLCH-10 |  | TCLCH-10 |  | ns |  |
| TCLLH | ALE Active Delay |  | 80 |  | 40 |  | 50 | ns |  |
| TCHLL | ALE Inactive Delay |  | 85 |  | 45 |  | 55 | ns |  |
| tLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | TCHCL-10 |  | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 50 | 10 | 60 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TWHDX | Data Hold Time After WR | TCLCH-30 | . | TCLCH-25 |  | TCLCH-30 |  | ns . |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | 10 | 50 | 10 | 70 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 110 | 10 | 45 | 10 | 60 | ns |  |
| TCVCTX | Control Inactive Delay | 10 | 110 | 10 | 50 | - 10 | 70 | ns |  |
| TAZRL | Address Float to READ Active | 0 | ' | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 165 | 10 | 70 | 10 | 100 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 150 | 10 | 60 | 10 | 80 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-45 |  | TCLCL-35 | . | TCLCL-40 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | 10 | 60 | 10 | 100 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-75 |  | 2TCLCL-40 |  | 2TCLCL-50 |  | ns |  |
| TWLWH | $\overline{\text { WR Width }}$ | 2TCLCL-60 |  | 2TCLCL-35 |  | 2TCLCL-40 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-60 |  | TCLCH-35 |  | TCLCH-40 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2.0 \mathrm{~V} \end{aligned}$ |
| TOHOL | Output Fall Time |  | 12 |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Signal at 8284A shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to T2 state. ( 8 ns into T3).

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## WAVEFORMS (Continued)

MINIMUM MODE (Continued)


## NOTES:

1. All signals switch between $V_{O H}$ and $V_{O L}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Two INTA cycles run back-to-back. The 8086 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control signals shown for second INTA cycle.
4. Signals at 8284A are shown for reference only.
5. All timing measurements are made at 1.5 V unless otherwise noted.

## A.C. CHARACTERISTICS

MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| Symbol | Parameter | 8086 |  | 8086-1 (Preliminary) |  | 8086-2 (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | MIn. | Max. |  |  |
| TCLCL | CLK Cycle Period | 200 | 500 | 100 | 500 | 125 | 500 | ns |  |
| TCLCH | CLK Low Time | 118 |  | 53 |  | 68 |  | ns |  |
| TCHCL | CLK High Time | 69 |  | 39 |  | 44 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 |  | 10 | ns | $\begin{aligned} & \text { From } 1.0 \mathrm{~V} \text { to } \\ & 3.5 \mathrm{~V} \end{aligned}$ |
| TCL2CL1 | CLK Fall Time |  | 10 |  | 10 |  | 10 | ns | From 3.5V to 1.0V |
| TDVCL | Data in Setup Time | 30 |  | 5 |  | 20 |  | ns |  |
| TCLDX | Data In Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into 8284A (See Notes 1, 2) | 35 |  | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into 8284A (See Notes 1, 2) | 0 |  | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup Time into 8086 | 118 |  | 53 |  | 68 |  | ns |  |
| TCHRYX | READY Hold Time into 8086 | 30 |  | 20 |  | 20 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 4) | -8 |  | -10 |  | -8 |  | ns |  |
| TINVCH | Setup Time for Recognition (INTR, NMI, TEST) (See Note 2) | 30 |  | 15 |  | 15 |  | ns |  |
| TGVCH | $\overline{\mathrm{RO}} / \overline{\mathrm{GT}}$ Setup Time | 30 |  | 12 |  | 15 |  | ns |  |
| TCHGX | $\overline{R Q}$ Hold Time into 8086 | 40 |  | 20 |  | 30 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 |  | 20 | ns | $\begin{aligned} & \text { From } 0.8 \mathrm{~V} \text { to } \\ & 2.0 \mathrm{~V} \end{aligned}$ |
| TIHIL | Input Fall Time (Except CLK) |  | 12 |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Signal at 8284A or 8288 shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK.
3. Applies only to T 3 and wait states.
4. Applies only to T 2 state ( 8 ns into T 3 ).

IAPX 86/10

## A.C. CHARACTERISTICS (Continued)

## TIMING RESPONSES

| Symbol | Parameter | 8086 |  | 8086-1 (Prellminary) |  | 8086-2 (Preliminary) |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| TCLML | Command Active <br> Delay (See Note 1) | 10 | 35 | 10 | 35 | 10 | 35 | ns | $\mathrm{C}_{\mathrm{L}}=20-100 \mathrm{pF}$ for all 8086 Outputs (In addition to 8086 selfload) |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | 10 | 35 | 10 | 35 | ns |  |
| TRYHSH | READY Active to Status Passive (See Note 3) | : | 110 |  | 45 |  | 65 | ns |  |
| TCHSV | Status Active Delay | 10 | 110 | 10 | 45 | 10 | 60 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 130 | 10 | 55 | 10 | 70 | ns |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 50 | 10 | 60 | ns |  |
| TCLAX | Address Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | 10 | 40 | TCLAX | 50 | ns |  |
| TSVLH | Status Valid to ALE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TSVMCH | Status Valid to MCE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLLH | CLK Low to ALE Valid (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLMCH | CLK Low to MCE High (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCHLL | ALE Inactive Delay. (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLMCL | MCE Inactive Delay (See Note 1) |  | 15 |  | 15 |  | 15 | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 50 | 10 | 60 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | 10 |  | ns |  |
| TCVNV | Control Active <br> Delay (See Note 1) | 5 | 45 | 5 | 45 | 5 | 45 | ns |  |
| TCVNX | Control Inactive Delay (See Note 1) | 10 | 45 | 10 | 45 | 10 | 45 | ns |  |
| TAZRL | Address Float to Read Active | 0 |  | 0 |  | 0 |  | ns |  |
| TCLRL | RD Active Delay | 10 | 165 | 10 | 70 | 10 | 100 | ns |  |
| TCLRH | RD Inactive Delay | 10 | 150 | 10 | 60 | 10 | 80 | ns |  |
| TRHAV | RD Inactive to Next Address Active | TCLCL-45 |  | TCLCL-35 |  | TCLCL-40 | ' | ns |  |
| TCHDTL | Direction Control <br> Active Delay (See <br> Note 1) |  | 50 |  | 50 |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 |  | 30 |  | 30 | ns |  |
| TCLGL | GT Active Delay | 0 | 85 | 0 | 45 | 0 | 50 | ns |  |
| TCLGH | GT Inactive Delay | 0 | 85 | 0 | 45 | 0 | 50 | ns |  |
| TRLRH | RD Width | 2TCLCL- 75 |  | 2TCLCL-40 |  | 2TCLCL-50 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

## WAVEFORMS



WAVEFORMS (Continued)


## NOTES:

1. All signals switch between $V_{O H}$ and $V_{O L}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Cascade address is valid between first and second INTA cycle.
4. Two INTA cycles run back-to-back. The 8086 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control for pointer address is shown for second INTA cycle.
5. Signals at 8284 A or 8288 are shown for reference only.
6. The issuance of the 8288 command and control signals ( $\overline{M R D C}, \overline{M W T C}, \overline{A M W C}, \overline{I O R C}, \overline{I O W C}, \overline{A I O W C}, \overline{I N T A}$ and DEN) lags the active high 8288 CEN.
7. All timing measurements are made at 1.5 V unless otherwise noted.
8. Status inactive in state just prior to $T_{4}$.

## WAVEFORMS (Continued)

## ASYNCHRONOUS SIGNAL RECOGNITION



NOTE: 1. SETUP REQUIREMENTS FOR ASYNCHRONOUS SIGNALS ONLY TO GUARANTEE RECOGNITION AT NEXT CLK

## BUS LOCK SIGNAL TIMING (MAXIMUM MODE ONLY)



## RESET TIMING



## REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)



NOTES: $\quad$ 1. THE COPROCESSOR MAY NOT DRIVE THE BUSES OUTSIDE THE REGION
SHOWN WITHOUT RISKING CONTENTION.

HOLD/HOLD ACKNOWLEDGE TIMING (MINIMUM MODE ONLY)


Table 2. Instruction Set Summary


Mnemonics ©Intel, 1978

Table 2. Instruction Set Summary (Continued)


## Footnotes:

$\mathrm{AL}=8$-bit accumulator
$A X=16$-bit accumulator
CX = 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 $\mathrm{d}=1$ then "to" reg; if $\mathrm{d}=0$ then "from" reg
if $\mathbf{w}=\mathbf{1}$ then word instruction; if $\mathbf{w}=0$ then byte instruction
if $\mathrm{mod}=11$ then $\mathrm{r} / \mathrm{m}$ is treated as a REG field
if $\bmod =00$ then DISP $=0^{*}$, disp-low and disp-high are absent
if mod $=01$ then DISP $=$ disp-low sign-extended to 16 -bits, disp-high is absent
if mod $=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)+$ DISP
if $\mathrm{r} / \mathrm{m}=010$ then $E A=(B P)+(\mathrm{SI})+$ DISP
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 $r / m=110$ then $E A=(B P)+D I S P^{*}$
if $r / 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 $r / 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 $\mathrm{s}: \mathrm{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\|$ |  |
| :---: | :---: |
| 000 | AX |
| 001 | CX |
| $010^{-1}$ | DX |
| 011 | BX |
| 100 | SP |
| 101 | BP |
| 110 | SI |
| 111 | DI |


| $8-$-Bit $(\mathbf{w}=\mathbf{0})$ |  |
| :---: | :---: |
| 000 | AL |
| 001 | CL |
| 010 | DL |
| 011 | BL |
| 100 | AH |
| 101 | CH |
| 110 | DH |
| 111 | BH |

Segment
00 ES
01 CS
10 SS
11 DS

# iAPX 88/10 8-BIT HMOS MICROPROCESSOR 8088/8088-2 

- 8-Bit Data Bus Interface
- 16-Bit Internal Architecture
- Direct Addressing Capability to 1 Mbyte of Memory
- Direct Software Compatibility with iAPX 86/10 (8086 CPU)
- 14-Word by 16-Bit Register Set with Symmetrical Operations

■ 24 Operand Addressing Modes

- Byte, Word, and Block Operations


## - 8-Blt and 16-Blt Signed and Unsigned Arithmetic in Binary or Decimal, Including Multiply and Divide

- Compatible with 8155-2, 8755A-2 and 8185-2 Multiplexed Peripherals
- Two Clock Rates:

5 MHz for 8088
8 MHz for 8088-2

The Intel ${ }^{\circledR}$ iAPX 88/10 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 is directly compatible with iAPX 86/10 software and 8080/8085 hardware and peripherals.


Figure 1. iAPX 88/10 CPU Functional Block Diagram


Figure 2. IAPX 88/10 Pin Configuration

Table 1. Pin Description
The following pin function descriptions are for 8088 systems in either minimum or maximum mode. The "local bus" in these descriptions is the direct multiplexed bus interface connection to the 8088 (without regard to additional bus buffers).

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| AD7-AD0 | 9-16 | I/O | Address Data Bus: These lines constitute the time multiplexed memory/IO address (T1) and data (T2, T3, Tw, and T4) bus. These lines are active HIGH and float to 3-state OFF during interrupt acknowledge and local bus "hold acknowledge". |
| A15-A8 | 2-8, 39 | 0 | Address Bus: These lines provide address bits 8 through 15 for the entire bus cycle (T1-T4). These lines do not have to be latched by ALE to remain valid. A15-A8 are active HIGH and float to 3-state OFF during interrupt acknowledge and local bus "hold acknowledge". |
| A19/S6, A18/S5, A17/S4, A16/S3 | 34-38 | 0 | Address/Status: During T1, 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 T2, T3, Tw, and T4. S6 is always low. The status of the interrupt enable flag bit (S5) is updated at the beginning of each clock cycle. S4 and S3 are encoded as shown. <br> This information indicates which segment register is presently being used for data accessing. <br> These lines float to 3 -state OFF during local bus "hold acknowledge". |
| $\overline{\mathrm{RD}}$ | 32 | 0 | Read: Read strobe indicates that the processor is performing a memory or I/O read cycle, depending on the state of the IO/M pin or S2. This signal is used to read devices which reside on the 8088 local bus. $\overline{R D}$ is active LOW during T2, T3 and Tw of any read cycle, and is guaranteed to remain HIGH in T2 until the 8088 local bus has floated. <br> This signal floats to 3-state OFF in "hold acknowledge". |
| READY | 22 | 1 | READY: is the acknowledgement from the addressed memory or I/O device that it will complete the data transfer. The RDY signal from memory or I/O is synchronized by the 8284 clock generator to form READY. This signal is active HIGH. The 8088 READY input is not synchronized. Correct operation is not guaranteed if the set up and hold times are not met. |
| INTR | 18 | 1 | 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. |
| $\overline{\text { TEST }}$ | 23 | 1 | 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 | 17 | 1 | 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. |

iAPX 88/10

Table 1. Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :--- | :---: | :---: | :--- |
| RESET | 21 | 1 | RESET: causes the processor to immediately terminate its present activity. The <br> signal must be active HIGH for at least four clock cycles. It restarts execution, as <br> described in the instruction set description, when RESET returns LOW. RESET <br> is internally synchronized. |
| CLK | 19 | I | Clock: provides the basic timing for the processor and bus controller. It is <br> asymmetric with a 33\% duty cycle to provide optimized internal timing. |
| $V_{\text {CC }}$ | 40 |  | VCC: is the $+5 \mathrm{~V} \pm 10 \%$ power supply pin. |
| GND | 1,20 |  | GND: are the ground pins. |
| MN/ $\overline{M X}$ | 33 | I | Minimum/Maximum: indicates what mode the processor is to operate in. The <br> two modes are discussed in the following sections. |

The following pin function descriptions are for the 8088 minimum mode (i.e., $M N / 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.

| $10 / \bar{M}$ | 28 | 0 | Status Line: is an inverted maximum mode $\overline{\mathbf{S 2}}$. It is used to distinguish a memory access from an I/O access. IO/M becomes valid in the T4 preceding a bus cycle and remains valid until the final T4 of the cycle ( $/ / O=H I G H, M=L O W$ ). IO/ $\bar{M}$ floats to 3-state OFF in local bus "hold acknowledge". |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{W R}$ | 29 | 0 | Write: strobe indicates that the processor is performing a write memory or write $\mathrm{I} / \mathrm{O}$ cycle, depending on the state of the IO/M signal. WR is active for T2, T3, and Tw of any write cycle. It is active LOW, and floats to 3-state OFF in local bus "hold acknowledge". |  |  |  |  |
| INTA | 24 | 0 | INTA: is used as a read strobe for interrupt acknowledge cycles. It is active LOW during T2, T3, and Tw of each interrupt acknowledge cycle. |  |  |  |  |
| ALE | 25 | 0 | 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 clock low of T1 of any bus cycle. Note that ALE is never floated. |  |  |  |  |
| DT/ $\bar{R}$ | 27 | 0 | Data Transmit/Receive: is needed in a minimum system that desires to use an 8286/8287 data bus transceiver. It is used to control the direction of data flow through the transceiver. Logically, DT/ $\overline{\mathrm{R}}$ is equivalent to $\overline{\mathrm{S} 1}$ in the maximum mode, and its timing is the same as for $1 O / \bar{M}(T=H I G H, R=L O W)$. This signal floats to 3-state OFF in local "hold acknowledge". |  |  |  |  |
| $\overline{\text { DEN }}$ | 26 | 0 | Data Enable: is provided as an output enable for the 8286/8287 in a minimum system which uses the transceiver. 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 T2 until the middle of T4, while for a write cycle, it is active from the beginning of T2 until the middle of T4. $\overline{\text { DEN }}$ floats to 3 -state OFF during local bus "hold acknowledge". |  |  |  |  |
| HOLD, HLDA | 30,31 | I, 0 | 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 a T4 or Tl clock cycle. 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 lowers HLDA, and when the processor needs to run another cycle, it will again drive the local bus and control lines. <br> Hold is not an asynchronous input. External synchronization should be provided if the system cannot otherwise guarantee the set up time. |  |  |  |  |
| $\overline{\text { SSO }}$ | 34 | 0 | Status line: is logically equivalent to $\overline{\mathrm{SO}}$ in the maximum mode. The combination of $\overline{S S O}, I O / \bar{M}$ and $\mathrm{DT} / \overline{\mathrm{R}}$ allows the system to completely decode the current bus cycle status. |  | Or\| | S50 0 0 0 0 0 | CHMAACrenlistics |

## Table 1. Pin Description (Continued)

The following pin function descriptions are for the 8088,8228 system in maximum mode (i.e., MN/MX=GND.) Only the pin functions which are unique to maximum mode are described; all other pin functions are as described above.

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 0}$ | 26-28 | $0$ | Status: is active during clock high of T4, T1, and T2, and is returned to the passive state $(1,1,1)$ during T3 or during Tw 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{\mathbf{S 2}}, \overline{\mathrm{S} 1}$, or $\overline{\mathbf{S O}}$ during T4 is used to indicate the beginning of a bus cycle, and the return to the passive state in T3 or Tw is used to indicate the end of a bus cycle. <br> These signals float to 3-state OFF during "hold acknowledge". During the first clock cycle after RESET becomes active, these signals are active HIGH. After this first clock, they float to 3-state OFF.$\overline{\mathbf{8 2}}$ $\overline{\mathbf{8 1}}$ $\overline{\mathbf{8 0}}$ CHARACTERISTICB <br> 0 (LOW) 0 0 Interrupt Acknowledge <br> 0 0 1 Read IVO port <br> 0 1 0 Write //O port <br> 0 1 1 Hatt <br> $1(\mathrm{HIIGH})$ 0 0 Code access <br> 1 0 1 Read memory <br> 1 1 0 Write memory <br> 1 1 1 Passive OF. |
| $\overline{R Q} / \overline{G T O}$, <br> RQ/GT1 | 30, 31 | I/O | 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{R Q} / \overline{G T O}$ having higher priority than $\overline{R Q} / \overline{G T 1} . \overline{R Q} / \overline{G T}$ has an internal pull-up resistor, so may be left unconnected. The request/grant sequence is as follows (See Figure 8): <br> 1. A pulse of one CLK wide from another local bus master indicates a local bus request ("hold") to the 8088 (pulse 1). <br> 2. During a T4 or TI clock cycle, a pulse one clock wide from the 8088 to the requesting master (pulse 2), indicates that the 8088 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".'. The same rules as for HOLD/HOLDA apply as for when the bus is released. <br> 3. A pulse one CLK wide from the requesting master indicates to the 8088 (pulse 3) that the "hold" request is about to end and that the 8088 can reclaim the local bus at the next CLK. The CPU then enters T4. <br> Each master-master exchange of the local bus is a sequence of three pulses. There must be one idle CLK cycle after each bus exchange. Pulses are active LOW. <br> If the request is made while the CPU is performing a memory cycle, it will release the local bus during T4 of the cycle when all the following conditions are met: <br> 1. Request occurs on or before T2. <br> 2. Current cycle is not the low bit of a word. <br> 3. Current cycle is not the first acknowledge of an interrupt acknowledge sequence. <br> 4. A locked instruction is not currently executing. <br> If the local bus is idle when the request is made the two possible events will follow: <br> 1. Local bus will be released during the next clock. <br> 2. A memory cycle will start within 3 clocks. Now the four rules for a currently active memory cycle apply with condition number 1 already satisfied. |

Table 1. Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\overline{\text { LOCK }}$ | 29 | 0 | $\overline{\text { LOCK: }}$ indicates that other system bus masters are not to gain control of the system bus while $\overline{\text { LOCK }}$ is active (LOW). The 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". |  |  |
| QS1, QS0 | 24, 25 | 0 | Queue Status: provide status to allow external tracking of the internal 8088 instruction queue. <br> The queue status is valid during the CLK cycle after which the queue operation is performed. |  |  |
| - | 34 | 0 | Pin 34 is always hig |  |  |

## FUNCTIONAL DESCRIPTION

## Memory Organization

The processor provides a 20-bit address to memory which locates the byte being referenced. The memory is organized as a linear array of up to 1 million bytes, addressed as $00000(\mathrm{H})$ to $\operatorname{FFFFF}(\mathrm{H})$. The memory is logically divided into code, data, extra data, and stack segments of up to 64 K bytes each, with each segment falling on 16-byte boundaries. (See Figure 3.)
All memory references are made relative to base addresses contained in high speed segment registers. The segment types were chosen based on the addressing needs of programs. The segment register to be selected is automatically chosen according to the rules of the following table. All information in one segment type share the same logical attributes (e.g. code or data). By structuring memory into relocatable areas of similar characteristics and by automatically selecting segment registers, programs are shorter, faster, and more structured.

Word (16-bit) operands can be located on even or odd address boundaries. 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


Figure 3. Memory Organization
the next higher address location. The BIU will automatically execute two fetch or write cycles for 16-bit operands.
Certain locations in memory are reserved for specific CPU operations. (See Figure 4.) Locations from addresses FFFFOH through FFFFFH are reserved for operations including a jump to the initial system initialization routine. Following RESET, the CPU will always begin execution at location FFFFOH where the jump must be located. Locations 00000 H through 003FFH are reserved for interrupt operations. Four-byte pointers consisting of a 16 -bit segment address and a 16 -bit offset address direct program flow to one of the 256 possible interrupt service routines. The pointer elements are assumed to have been stored at their respective places in reserved memory prior to the occurrence of interrupts.

## Minimum and Maximum Modes

The requirements for supporting minimum and maximum 8088 systems are sufficiently different that they cannot be done efficiently with 40 uniquely defined pins. Consequently, the 8088 is equipped with a strap pin (MN/MX) which defines the system configuration. The definition of a certain subset of the pins changes, dependent on the condition of the strap pin. When the MN/MX pin is strapped to GND, the 8088 defines pins 24 through 31 and 34 in maximum mode. When the MN/MX pin is strapped to $\mathrm{V}_{\mathrm{CC}}$, the 8088 generates bus control signals itself on pins 24 through 31 and 34.


Figure 4. Reserved Memory Locations

| Memory <br> Reference Need | Segment Register <br> Used | Segment <br> Selection Rule |
| :--- | :--- | :--- |
| Instructions | CODE (CS) | Automatic with all instruction prefetch. |
| Stack | STACK (SS) | All stack pushes and pops. Memory references relative to BP <br> base register except data references. |
| Local Data | Data references when: relative to stack, destination of string <br> operation, or explicitly overridden. |  |
| External (Global) Data | EXTRA (ES) | Destination of string operations: Explicitly selected using a <br> segment override. |

The minimum mode 8088 can be used with either a multiplexed or demultiplexed bus. The multiplexed bus configuration is compatible with the MCS $85^{\mathrm{TM}}$ multiplexed bus peripherals ( $8155,8156,8355,8755 \mathrm{~A}$, and 8185). This configuration (See Figure 5) provides the user with a minimum chip count system. This architecture provides the 8088 processing power in a highly integrated form.
The demultiplexed mode requires one latch (for 64 K addressability) or two latches (for a full megabyte of addressing). A third latch can be used for buffering if the address bus loading requires it. An 8286 or 8287 transceiver can also be used if data bus buffering is required. (See Figure 6.) The 8088 provides $\overline{\mathrm{DEN}}$ and DT/ $\stackrel{\vec{R}}{ }$ to con-
trol the transceiver, and ALE to latch the addresses. This configuration of the minimum mode provides the standard demultiplexed bus structure with heavy bus buffering and relaxed bus timing requirements.

The maximum mode employs the 8288 bus controller. (See Figure 7.) The 8288 decodes status lines $\overline{\mathrm{S} 0}, \overline{\mathrm{~S} 1}$, and $\overline{\mathrm{S} 2}$, and provides the system with all bus control signals. Moving the bus control to the 8288 provides better source and sink current capability to the control lines, and frees the 8088 pins for extended large system features. Hardware lock, queue status, and two request/ grant interfaces are provided by the 8088 in maximum mode. These features allow co-processors in local bus and remote bus configurations.


Figure 5. Multiplexed Bus Configuration


Figure 6. Demultiplexed Bus Configuration


Figure 7. Fully Buffered System Using Bus Controller

## Bus Operation

The 8088 address/data bus is broken into three parts the lower eight address/data bits (AD0-AD7), the middle eight address bits (A8-A15), and the upper four address bits (A16-A19). The address/data bits and the highest four address bits are time multiplexed. This technique provides the most efficient use of pins on the processor, permitting the use of a standard 40 lead package. The middle eight address bits are not multiplexed, i.e. they remain valid throughout each bus cycle. In addi-
tion, the bus can be demultiplexed at the processor with a single address latch 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 T1, T2, T3, and T4. (See Figure 8). The address is emitted from the processor during T1 and data transfer occurs on the bus during T3 and T4. T2 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.


Figure 8. Basic System Timing
"wait" states (Tw) are inserted between T3 and T4. Each inserted "wait" state is of the same duration as a CLK cycle. Periods can occur between 8088 driven bus cycles. These are referred to as "idle" states (Ti), or inactive CLK cycles. The processor uses these cycles for internal housekeeping.
During T1 of any bus cycle, the ALE (address latch enable) signal is emitted (by either the processor or the 8288 bus controller, depending on the MN/ $\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 by the bus controller, in maximum mode, 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}}}$ | CHARACTERISTICS |
| :--- | :--- | :--- | :--- |
| 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 S3 through S6 are multiplexed with high order address bits and are therefore valid during T2 through T4. S3 and S4 indicate which segment register was used for this bus cycle in forming the address according to the following table:

| $\mathbf{S}_{\mathbf{4}}$ | $\mathbf{S}_{\mathbf{3}}$ | CHARACTERISTICS |
| :--- | :--- | :--- |
| 0 (LOW) | 0 | Alternate Data (extra segment) |
| 0 | 1 | Stack |
| 1 (HIGH) | 0 | Code or None |
| 1 | 1 | Data |

S5 is a reflection of the PSW interrupt enable bit. S6 is always equal to 0 .

## I/O Addressing

In the 8088, I/O operations can address up to a maximum of 64 K I/O registers. The I/O address appears in the same format as the memory address on bus lines A15-A0. The address lines A19-A16 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.

Designers familiar with the 8085 or upgrading an 8085 design should note that the 8085 addresses I/O with an 8 -bit address on both halves of the 16 -bit address bus. The 8088 uses a full 16-bit address on its lower 16 address lines.

## EXTERNAL INTERFACE

## Processor Reset and Initialization

Processor initialization or start up is accomplished with activation (HIGH) of the RESET pin. The 8088 RESET is required to be HIGH for greater than four clock cycles. The 8088 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 7 clock cycles. After this interval the 8088 operates normally, beginning with the instruction in absolute location FFFFOH. (See Figure 4.) 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$ s after power up, to allow complete initialization of the 8088.

If INTR is asserted sooner than nine clock cycles after the end of RESET, the processor may execute one instruction before responding to the interrupt.

All 3-state outputs float to 3-state OFF during RESET. Status is active in the idle state for the first clock after RESET becomes active and then floats to 3 -state OFF.

## 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 in the IAPX 88 Book or the iAPX 86, 88 User's Manual. Hardware interrupts can be classified as nonmaskable 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 4), 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 (NMI)

The processor provides a single non-maskable interrupt (NMI) pin which has higher priority than the maskable interrupt request (INTR) pin. A typical use would be to activate 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.

NMI is required to have a duration in the HIGH state of greater than two clock cycies, but is not required to be synchronized to the clock. Any higher going transition of NMI is latched on-chip and will be serviced at the end of the current instruction or between whole moves ( 2 bytes in the case of word 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 8088 provides a single interrupt request input (INTR) which can be masked internally by software with the resetting of the interrupt enable (IF) flag 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 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 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 (See Figure 9), the processor executes two successive (back to back) interrupt acknowledge cycles. The 8088 emits the LOCK signal (maximum mode only) from T2 of the first bus cycle until T2 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 ALE, delayed by one clock cycle, to allow the system to latch the halt status. Halt status is available on $10 / \bar{M}, D T / \bar{R}$, and $\overline{\mathrm{SSO}}$. In maximum mode, the processor issues appropriate HALT status on $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}$, and $\overline{\mathrm{S} 0}$, and the 8288 bus controller issues one ALE. The 8088 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 at the end of the local bus hold. An interrupt request or RESET will force the 8088 out of the HALT state.

## Read/Modify/Write (Semaphore) Operations via LOCK

The LOCK status information is provided by the processor when consecutive bus cycles are required during the execution of an instruction. This allows the processor to perform read/modify/write operations on memory (via the "exchange register with memory" instruction), without 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 (LOW) in the clock cycle following decoding of the LOCK prefix instruction. It is deactivated at the end of the last bus cycle of the instruction following the LOCK prefix. While $\overline{L O C K}$ is active, a request on a $\overline{R Q} / \overline{G T}$ pin will be recorded, and then honored at the end of the LOCK.


Figure 9. Interrupt Acknowledge Sequence

## External Synchronization via TEST

As an alternative to interrupts, the 8088 provides a single software-testable input pin (TEST). This input is utilized by executing a WAIT instruction. The single WAIT instruction is repeatedly executed until the TEST input goes active (LOW). The execution of WAIT does not consume bus cycles once the queue is full.
If a local bus request occurs during WAIT execution, the 8088 3-states all output drivers. If interrupts are enabled, the 8088 will recognize interrupts and process them. The WAIT instruction is then refetched, and reexecuted.

## Basic System Timing

In minimum mode, the $M N / \overline{M X}$ pin is strapped to $V_{C C}$ and the processor emits bus control signals compatible with the 8085 bus structure. In maximum mode, the $\mathrm{MN} / \overline{\mathrm{MX}}$ pin is strapped to GND and the processor emits coded status information which the 8288 bus controller uses to generate MULTIBUS compatible bus control signals.

## System Timing - Minimum System

(See Figure 8.)
The read cycle begins in T1 with the assertion of the address latch enable (ALE) signal. The trailing (low going) edge of this signal is used to latch the address information, which is valid on the address/data bus (AD0-AD7) at this time, into the $8282 / 8283$ latch. Address lines A8 through A15 do not need to be latched because they remain valid throughout the bus cycle. From T1 to T4 the $10 / \bar{M}$ signal indicates a memory or I/O operation. At T2 the address is removed from the address/data bus and the bus goes to a high impedance state. The read control signal is also asserted at T2. 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 8088 local bus, signals $D T / \bar{R}$ and $\overline{D E N}$ are provided by the 8088.

A write cycle also begins with the assertion of ALE and the emission of the address. The IO/M signal is again asserted to indicate a memory or I/O write operation. In T2, immediately following the address emission, the processor emits the data to be written into the addressed location. This data remains valid until at least the middle of T4. During T2, T3, and $\mathrm{T}_{\mathrm{W}}$, the processor asserts the write control signal. The write ( $\overline{\mathrm{WR}})$ signal becomes active at the beginning of T2, as opposed to the read, which is delayed somewhat into T2 to provide time for the bus to float.

The basic difference between the interrupt acknowledge cycle and a read cycle is that the interrupt acknowledge (INTA) signal is asserted in place of the read ( $\overline{\mathrm{RD}})$ signal and the address bus is floated. (See Figure 9.) In the second of two successive INTA cycles,
a byte of information is read from the data bus, 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 the interrupt vector lookup table, as described earlier.

## Bus Timing - Medium Complexity Systems

## (See Figure 10.)

For medium complexity systems, the MN/ $\overline{M X}$ pin is connected to GND and the 8288 bus controller is added to the system, as well as an 8282/8283 latch for latching the system address, and an 8286/8287 transceiver to allow for bus loading greater than the 8088 is capable of handling. Signals ALE, $\overline{D E N}$, and $D T / \bar{R}$ are generated by the 8288 instead of the processor in this configuration, although their timing remains relatively the same. The 8088 status outputs ( $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}$, and $\overline{\mathrm{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 is not 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/R and $\overline{D E N}$ outputs.

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 8289A 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".

## The $\mathbf{8 0 8 8}$ Compared to the $\mathbf{8 0 8 6}$

The 8088 CPU is an 8-bit processor designed around the 8086 internal structure. Most internal functions of the 8088 are identical to the equivalent 8086 functions. The 8088 handles the external bus the same way the 8086 does with the distinction of handling only 8 bits at a time. Sixteen-bit operands are fetched or written in two consecutive bus cycles. Both processors will appear identical to the software engineer, with the exception of execution time. The internal register structure is identical and all instructions have the same end result. The differences between the 8088 and 8086 are qutlined below. The engineer who is unfamiliar with the 8086 is referred to the iAPX 86, 88 User's Manual, Chapters 2 and 4 , for function description and instruction set information. Internally, there are three differences between the 8088 and the 8086 . All changes are related to the 8 -bit bus interface.

- The queue length is 4 bytes in the 8088, whereas the 8086 queue contains 6 bytes, or three words. The queue was shortened to prevent overuse of the bus by the BIU when prefetching instructions. This was required because of the additional time necessary to fetch instructions 8 bits at a time.
- To further optimize the queue, the prefetching algorithm was changed. The 8088 BIU will fetch a new instruction to load into the queue each time there is a 1 byte hole (space available) in the queue. The 8086 waits until a 2-byte space is available.
- The internal execution time of the instruction set is affected by the 8 -bit interface. All 16 -bit fetches and writes from/to memory take an additional four clock cycles. The CPU is also limited by the speed of instruction fetches. This latter problem only occurs when a series of simple operations occur. When the more sophisticated instructions of the 8088 are being used, the queue has time to fill and the execution proceeds as fast as the execution unit will allow.

The 8088 and 8086 are completely software compatible by virture of their identical execution units. Software that is system dependent may not be completely transferable, but software that is not system dependent will operate equally as well on an 8088 or an 8086.

The hardware interface of the 8088 contains the major differences between the two CPUs. The pin assignments are nearly identical, however, with the following functional changes:

- A8-A15 - These pins are only address outputs on the 8088. These address lines are latched internally and remain valid throughout a bus cycle in a manner similar to the 8085 upper address lines.
- $\overline{\mathrm{BHE}}$ has no meaning on the 8088 and has been eliminated.
- $\overline{\text { SSO }}$ provides the $\overline{\mathrm{SO}}$ status information in the minimum mode. This output occurs on pin 34 in minimum mode only. DT/ $\bar{R}, I O / \bar{M}$, and $\overline{S S O}$ provide the complete bus status in minimum mode.
- $10 / \bar{M}$ has been inverted to be compatible with the MCS-85 bus structure.
- ALE is delayed by one clock cycle in the minimum mode when entering HALT, to allow the status to be latched with ALE.


Figure 10. Medium Complexity System Timing

## 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. . . . . . . . . . . . . . . . . . - 1.0 to + 7 V
Power Dissipation 2.5 Watt
*NOTICE: 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

(8088: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )
(8088-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. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voitage | 2.0 | $\mathrm{V}_{\mathrm{cc}}+0.5$ | v |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | v | $\mathrm{IOL}^{2}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| Icc | $\text { Power Supply Current: }{ }_{8088-2}^{8088}$ |  | $\begin{aligned} & 340 \\ & 350 \end{aligned}$ | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| ILI | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| Lo | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & 0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \\ & \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{V}_{\text {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{CIN}_{\text {IN }}$ | Capacitance if Input Buffer (All input except <br> $A D_{0}-A D_{7}, R Q / G T$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{10}$ | Capacitance of I/O Buffer $\left(A D_{0}-A D_{7}, R Q / G T\right.$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS (8088: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )
( $8088-2: T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ )

## MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

|  |  | 8088 |  | 8088-2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test Conditions |
| TCLCL | CLK Cycle Period | 200 | 500 | 125 | 500 | ns |  |
| TCLCH | CLK Low Time | (2/3 TCLCL) -15 |  | (2/3 TCLCL) -15 |  | ns |  |
| TCHCL | CLK High Time | (113 TCLCL)+2 |  | (1/3 TCLCL) +2 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 |  | 10 | ns | $\text { From } 1.0 \mathrm{~V}$ $\text { to } 3.5 \mathrm{~V}$ |
| TCL2CL1 | CLK Fall Time | * | 10 | . | 10 | ns | $\begin{aligned} & \text { From } 3.5 \mathrm{~V} \\ & \text { to } 1.0 \mathrm{~V} \end{aligned}$ |
| TDVCL | Data in Setup Time | 30 |  | 20 |  | ns |  |
| TCLDX | Data in Hold Time | 10 |  | 10 |  | ns |  |
| TR1VCL | RDY Setup Time into 8284 (See Notes 1, 2) | 35 |  | 35 |  | ns |  |
| TCLR1X | RDY Hold Time into 8284 (See Notes 1, 2) | 0 |  | 0 |  | ns |  |
| TRYHCH | READY Setup <br> Time into 8088 | (2/3 TCLCL)-15 |  | (2/3 TCLCL)-15 |  | ns |  |
| TCHRYX | READY Hold Time into 8088 | 30 |  | 20 | ... | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 3) | '-8 |  | -8 |  | ns |  |
| THVCH | HOLD Setup Time | 35 |  | 20 |  | ns |  |
| TINVCH | INTR, NMI, TEST Setup Time (See Note 2) | 30 |  | 15 | , | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 |  | 20 | ns | From 0.8V $\text { to } 2.0 \mathrm{~V}$ |
| TIHIL | Input Fall Time (Except CLK) | - . | 12 | $\because$ | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \\ & \text { to } 0.8 \mathrm{~V} \end{aligned}$ |

## A.C. CHARACTERISTICS (Continued) <br> timing responses

|  |  | 8088 |  | 8088-2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test Conditions |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | ns | $C_{L}=20-100 \mathrm{pF}$ for all 8088 Outputs in addition to internal loads |
| TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | ns |  |
| TLHLL | ALE Width | TCLCH-20 |  | TCLCH-10 |  | ns |  |
| TCLLH | ALE Active Delay |  | 80 |  | 50 | ns |  |
| TCHLL | ALE Inactive Delay |  | 85 |  | 55 | ns |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 10 |  | ns |  |
| TWHDX | Data Hold Time After $\overline{W R}$ | TCLCH-30 |  | TCLCH-30 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | 10 | 70 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 110 | 10 | 60 | ns |  |
| TCVCTX | Control Inactive Delay | 10 | 110 | 10 | 70 | ns |  |
| TAZRL | Address Float to READ Active | 0 |  | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{RD}}$ Active Delay | 10 | 165 | 10 | 100 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 150 | 10 | 80 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-45 |  | TCLCL-40 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | 10 | 100 | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Width | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |  |
| TWLWH | $\overline{\text { WR Width }}$ | 2TCLCL-60 |  | 2TCLCL-40 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-60 |  | TCLCH-40 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. TESTING INPUT, OUTPUT WAVEFORM



A C. TESTING. INPUTS ARE DRIVEN AT 24 V FOR A LOGIC $1^{\prime \prime}$ AND 0.45V FOR A LOGIC 0. THE CLOCK IS DRIVEN AT 4.3 V AND 0.25 V . TIMING MEASUREMENTS ARE MADE AT 15 V FOR BOTH A LOGIC 1 " AND 0
A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

## BUS TIMING—MINIMUM MODE SYSTEM



## WAVEFORMS (Continued)

BUS TIMING-MINIMUM MODE SYSTEM (Continued)


## A.C. CHARACTERISTICS

## MAX MODE SYSTEM (USING 8288 BUS CONTROLLER)

TIMING REQUIREMENTS


## 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 T 2 state ( 8 ns into T 3 state).
4. Applies only to T 2 state ( 8 ns into T 3 state).

IAPX 88/10

## A.C. CHARACTERISTICS

 TIMING RESPONSES|  | Parameter | 8088 |  | 8088-2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Units | Test Conditions |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | 10 | 35 | ns |  |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | 10 | 35 | ns |  |
| TRYHSH | READY Active to Status Passive (See Note 3) | : | 110 | $\because$ | 65 | ns |  |
| TCHSV | Status Active Delay | 10 | 110 | 10 | 60 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 130 | 10 | 70 | ns |  |
| TCLAV | Address Valid Delay | 10 | 110 | 10 | 60 | ns |  |
| TCLAX | Address Hold Time | 10 |  | 10 |  | ns |  |
| TCLAZ | Address Float Delay | TCLAX | 80 | TCLAX | 50 | ns |  |
| TSVLH | Status Valid to ALE High (See Note 1) | . | 15 |  | 15 | ns |  |
| TSVMCH | Status Valid to MCE High (See Note 1) |  | 15 |  | 15 | ns |  |
| TCLLH | CLK Low to ALE Valid (See Note 1) |  | 15 |  | 15 | ns |  |
| TCLMCH | CLK Low to MCE High (See Note 1) |  | 15 |  | 15 | ns |  |
| TCHLL | ALE Inactive Delay (See Note 1) |  | 15 |  | 15 | ns |  |
| TCLMCL | MCE Inactive Delay (See Note 1) |  | 15 |  | 15 | ns | $C_{L}=20-100 \mathrm{pF}$ for |
| TCLDV | Data Valid Delay | 10 | 110 | 10 | 60 | ns | all 8088 Outputs |
| TCHDX | Data Hold Time | 10 |  | 10 |  | ns | internal loads |
| TCVNV | Control Active Delay (See Note 1) | 5 | 45 | 5 | 45 | ns | $\because$ |
| TCVNX | Control Inactive Delay (See Note 1) | 10 | 45 | 10 | 45 | ns |  |
| TAZRL | Address Float to Read Active | 0 |  | 0 |  | ns |  |
| TCLRL | RD Active Delay | 10 | 165 | 10 | 100 | ns |  |
| TCLRH | RD Inactive Delay | 10 | 150 | 10 | 80 | ns | - . |
| TRHAV | RD Inactive to Next Address Active | TCLCL-45 |  | TCLCL-40 |  | ns |  |
| TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 |  | 30 | ns |  |
| TCLGL | GT Active Delay |  | 110 |  | 50 | ns |  |
| TCLGH | GT Inactive Delay |  | 85 |  | 50 | ns |  |
| TRLRH | RD Width | 2TCLCL-75 |  | 2TCLCL-50 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 |  | 20 | ns | $\begin{array}{\|l} \text { From } 0.8 \mathrm{~V} \text { to } \\ 2.0 \mathrm{~V} \\ \hline \end{array}$ |
| TOHOL | Output Fall Time |  | 12 |  | 12 | ns | $\begin{aligned} & \text { From } 2.0 \mathrm{~V} \text { to } \\ & 0.8 \mathrm{~V} \end{aligned}$ |

## WAVEFORMS



WAVEFORMS (Continued)


## WAVEFORMS (Continued)



## BUS LOCK SIGNAL TIMING (MAXIMUM MODE ONLY)



REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)


[^20]HOLD/HOLD ACKNOWLEDGE TIMING (MINIMUM MODE ONLY)


IAPX 88/10

## IAPX 86/10, 88/10 <br> INSTRUCTION SET SUMMARY

| data tramsfer |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Mov = Meve: | 76543210 | 76543210 | 78543210 | 78543210 |
| Register/memoty to/from register | 100010 dm | mod reg $1 / \mathrm{m}$ |  |  |
| Immediate to register/memory | 1100011 w | mod $000 \mathrm{l} / \mathrm{m}$ | data | data 1 w 1 |
| 1 mmediate to register | 1011 w reg | data | data it w |  |
| Memory to accumulator | 1010000 w | addr-low | addr.high |  |
| Accumulator to memory | 1010001 w | addr. 10 w | addi figh |  |
| Register/memory to segment register Segment register to register / memory | 10001110 | mod 0 reg $1 / \mathrm{m}$ |  |  |
|  | 10001100 | modoreg $\mathrm{t} / \mathrm{m}$ |  |  |
| PUSM - Puah: |  |  |  |  |
| Register/memoty | 111111111 | mod 110 tm |  |  |
| Registet | 01010 reg |  |  |  |
| Segment register | 000 reg 110 |  |  |  |
| POP = Pop: |  |  |  |  |
| Register/memory | 10001111 | $\bmod 000 \mathrm{l} / \mathrm{m}$ |  |  |
| - Register | 01011 reg |  |  |  |
| Segment register | 000 reg 111 |  |  |  |
| XCH6 = Exchange: |  |  |  |  |
| Register/memory with register | 1000011w | mod reg $1 / \mathrm{m}$ |  |  |
| Register with accumulator | 10010 reg |  |  |  |
| IN=Input from: |  |  |  |  |
| Fixed port | 1110010w | port |  |  |
| Variable port | 1410110 w |  |  |  |
| OUT $=$ Output to: |  |  |  |  |
| Fixed port | 1110011 w | port |  | , |
| Variable port | 1110111m |  |  |  |
| XLaT- Translate byte to AL | 11010111 |  |  |  |
| LEA = Load EA to register | 10001101 | mod teg $\mathrm{l} / \mathrm{m}$ |  |  |
| L08 = Load pointer to DS | 11000101 | mod reg 11 m |  |  |
| LEE = Load pointer to ES | 11000100 | mod reg $\mathrm{r} / \mathrm{m}$ |  |  |
| LaMF =Load AH with llags | 10011111 |  |  |  |
| samf = Store AH into flags | 10011110 |  |  |  |
| Puswe = Push flags | 10011100 |  |  |  |
| PepF=Pop llags | 10011101 |  |  |  |





| String mamipulation |  |
| :---: | :---: |
| REP $=$ Repeat | 11110012 |
| MOVS $=$ Move byte/word | 1010010 w |
| CMPS $=$ Compare byte/word | 1010011 w |
| SCAS=Scan byte/word | 1010111 w |
| LODS $=$ Load byte/wd to AL/AX | 1010110 w |
| 8TOs = Stor byte/wd from AL/A | 1010101 w |

INSTRUCTION SET SUMMARY (Continued)


## Fectnotes:

$A L=8$-bit accumulator
$A X=16$-bit accumulator
CX = 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 " $t 0$ " reg; if $d=0$ then "from" reg
if $w=1$ then word instruction; if $w=0$ then byte instruction
if $\mathrm{s}: \mathbf{w}=01$ then 16 bits of immediate data form the operand.
if $\mathrm{s}: \mathbf{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-8it (w = 1) |  | 8 8-Bit $(\mathrm{w}=0$ ) |  | Segment |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 000 | $A X$ | 000 | AL | 00 | ES |
| 001 | CX | 001 | CL | 01 | CS |
| 010 | DX | 010 | DL |  | SS |
| 011 | $B X$ | 011 | BL |  |  |
| 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)$

## 8089 <br> 8 \& 16-BIT HMOS I/O PROCESSOR

## - High Speed DMA Capabilities Including I/O to Memory, Memory to I/O, Memory to Memory, and I/O to I/O

- iAPX 86, 88 Compatible: Removes I/O Overhead from CPU in iAPX 86/11 or 88/11 Configuration
- Allows Mixed Interface of 8- \& 16-Bit Peripherals, to 8-\& 16-Bit Processor Busses
- 1 Mbyte Addressability
- Memory Based Communication with CPU
- Supports LOCAL or REMOTE I/O Processing
- Flexible, Intelligent DMA Functions Including Translation, Search, Word Assembly/Disassembly
- MULTIBUS ${ }^{\text {™ }}$ Compatible System Interface

The Intel ${ }^{\circledR} 8089$ is a revolutionary concept in microprocessor input/output processing. Packaged in a 40-pin DIP package, the 8089 is a high performance processor implemented in N -channel, depletion load silicon gate technology (HMOS). The 8089's instruction set and capabilities are optimized for high speed, flexible and efficient I/O handling. It allows easy interface of Intel's 16 -bit IAPX 86 and 8 -bit iAPX 88 microprocessors with 8 - and 16 -bit peripherals. In the REMOTE configuration, the 8089 bus is user definable allowing it to be compatible with any 8/16-bit Intel microprocessor, interfacing easily to the Intel multiprocessor system bus standard MULTIBUS ${ }^{\text {M }}$.

The 8089 performs the function of an intelligent DMA controller for the Intel iAPX 86, 88 family and with its processing power, can remove I/O overhead from the IAPX 86 or IAPX 88. It may operate completely in parallel with a CPU, giving dramatically improved performance in I/O intensive applications. The 8089 provides two I/O channels, each supporting a transfer rate up to $1.25 \mathrm{mbyte} / \mathrm{sec}$ at the standard clock frequency of 5 MHz . Memory based communication between the IOP and CPU enhances system flexibility and encourages software modularity, yielding more reliable, easier to develop systems.


Figure 1. 8089 I/O Processor Block Diagram


Figure 2.
8089 Pin Configuration

[^21]Table 1. Pin Description

| Symbol | Type | $\quad$Name and Function |
| :--- | :--- | :--- |
| A0-A15/ | I/O | Multiplexed Address and Data Bus: The <br> D0-D15 <br> function of these lines are defined by the <br> state of So, S1 and S2 lines. The pins are <br> floated after reset and when the bus is not <br> acquired. A8-A15 are stable on transfers to a <br> physical 8-bit data bus (same bus as 8088), <br> and are multiplexed with data on transfers to <br> a 16-bit physical bus. |


| Symbol' | Type | Name and Function |
| :---: | :---: | :---: |
| LOCK | 0 | Lock: The lock output signal indicates to the bus controller that the bus is needed for more than one contiguous cycle. It is set via the channel control register, and during the TSL instruction. The pin floats after reset and when the bus is not acquired. This output is active low. |
| RESET | 1 | Reset: The receipt of a reset signal causes the IOP to suspend all its activities and enter an idle state until a channel attention is received. The signal must be active for at least four clock cycles. |
| CLK | 1 | Clock: Clock provides all timing needed for internal IOP operation. |
| CA | 1 | Channel Attention: Gets the attention of the IOP. Upon the falling edge of this signal, the SEL input pin is examined to determine Master/Slave or $\mathrm{CH} 1 / \mathrm{CH} 2$ information. This input is active high. |
| SEL | 1 | Select: The first CA received after system reset informs the IOP via the SEL line, whether it is a Master or Slave ( $0 / 1$ for Master/Slave respectively) and starts the initialization sequence. During any other CA the SEL line signifies the selection of $\mathrm{CH} 1 / \mathrm{CH} 2$. (0/1 respectively.) |
| DRQ1-2 | 1 | Data Request: DMA request inputs which signal the IOP that a peripheral is ready to transfer/receive data using channels 1 or 2 respectively. The signals must be held active high until the appropriate fetch/stroke is initiated. |
| $\overline{\text { RQ/GT }}$ | 1/0 | Request Grant: Request Grant implements the communication dialogue required to arbitrate the use of the system bus (between IOP and CPU, LOCAL mode) or I/O bus when two IOPs share the same bus (REMOTE mode). The $\overline{R Q} / \overline{G T}$ signal is active low. An internal pull-up permits $\overline{R Q} / \overline{G T}$ to be left floating if not used. |
| SINTR1-2 | 0 | Signal Interrupt: Signal Interrupt outputs from channels 1 and 2 respectively. The interrupts may be sent directly to the CPU or through the 8295A interrupt controller. They are used to indicate to the system the occurrence of user defined events. |
| EXT1-2 | 1 | External Terminate: External terminate inputs for channels 1 and 2 respectively. The EXT signals will cause the termination of the current DMA transfer operation if the channel is so programmed by the channel control register. The signal must be held active high until termination is complete. |
| $\mathrm{V}_{\text {cc }}$ |  | Voltage: +5 volt power input. |
| $\mathrm{V}_{\text {Ss }}$ |  | Ground. |

## FUNCTIONAL DESCRIPTION

The 8089 IOP has been designed to remove I/O processing, control and high speed transfers from the central processing unit. Its major capabilities include that of initializing and maintaining peripheral components and supporting versatile DMA. This DMA function boasts flexible termination conditions (such as external terminate, mask compare, single transfer and byte count expired). The DMA function of the 8089 IOP uses a two cycle approach where the information actually flows through the 8089 IOP. This approach to DMA vastly simplifies the bus timings and enhances compatibility with memory and peripherals; in addition to allowing operations to be performed on the data as it is transferred. Operations can include such constructs as translate, where the 8089 automatically vectors through a lookup table and mask compare, both on the "fly".

The 8089 is functionally compatible with Intel's iAPX 86, 88 family. It supports any combination of $8 / 16$-bit busses. In the REMOTE mode it can be used to complement other Intel processor families. Hardware and communication architecture are designed to provide simple mechanisms for system upgrade.

The only direct communication between the IOP and CPU is handled by the Channel Attention and Interrupt lines. Status information, parameters and task programs are passed via blocks of shared memory, simplifying hardware interface and encouraging structured programming.

The 8089 can be used in applications such as file and buffer management in hard disk or floppy disk control. It can also provide for soft error recovery routines and scan
control. CRT control, such as cursor control and auto scrolling, is simplified with the 8089. Keyboard control, communication control and general I/O are just a few of the typical applications for the 8089.

## Remote and Local Modes

Shown in Figure 3 is the 8089 in a LOCAL configuration. The iAPX 86 (or IAPX 88) is used in its maximum mode. The 8089 and IAPX 86 reside on the same local bus, sharing the same set of system buffers. Peripherals located on the system bus can be addressed by either the IAPX 86 or the 8089. The 8089 requests the use of the LOCAL bus by means of the RQ/GT line. This performs a similar function to that of HOLD and HLDA on the Intel 8085A, 8080A and iAPX 86 minimum mode, but is implemented on one physical line. When the iAPX 86 relinquishes the system bus, the 8089 uses the same bus control, latches and transceiver components to generate the system address, control and data lines. This mode allows a more economical system configuration at the expense of reduced CPU thruput due to IOP bus utilization.

A typical REMOTE configuration is shown in Figure 4. In this mode, the IOP's bus is physically separated from the system bus by means of system buffers/latches. The IOP maintains its own local bus and can operate out of local or system memory. The system bus interface contains the following components:

- Up to three 8282 buffer/latches to latch the address to the system bus.
- Up to two 8286 devices bidirectionally buffer the system data bus.


Figure 3. Typical iAPX 86/11, 88/11 Configuration with 8089 in LOCAL Mode, 8088, 8086 in MAX Mode

- An 8288 bus controller supplies the control signals necessary for buffer operation as well as MRDC (Memory Read) and MWTC (Memory Write) signals.
- An 8289 bus arbiter performs all the functions necessary to arbitrate the use of the system bus. This is used in place of the $\overline{R Q} / \overline{G T}$ logic in the LOCAL mode. This arbiter decodes type of cycle information from the 8089 status lines to determine if the IOP desires to perform a transfer over the "common" or system bus.
The peripheral devices PER1 and PER2 are supported on their own data and address bus. the 8089 communicates with the peripherals without affecting system bus operation. Optional buffers may be used on the local bus when capacitive loading conditions so dictate. I/O programs and RAM buffers may also reside on the local bus to further reduce system bus utilization.


## COMMUNICATION MECHANISM

Fundamentally, communication between the CPU and IOP is performed through messages prepared in shared memory. The CPU can cause the 8089 to execute a program by placing it in the 8089's memory space and/or directing the 8089's attention to it by asserting a hardware Channel Attention (CA) signal to the IOP, activating the proper I/O channel. The SEL Pin indicates to
the IOP which channel is being addressed. Communication from the IOP to the processor can be performed in a similar manner via a system interrupt (SINTR 1,2), if the CPU has enabled interrupts for this purpose. Additionally, the 8089 can store messages in memory regarding its status and the status of any peripherals. This communication mechanism is supported by a hierarchial data structure to provide a maximum amount of flexibility of memory use with the added capability of handling multiple IOP's.

Illustrated in Figure 5 is an overview of the communication data structure hierarchy that exists for the $80891 / 0$ processor. Upon the first CA from RESET, if the IOP is initialized as the BUS MASTER, 5 bytes of information are read into the 8089 starting at location FFFF6 (FFFF6, FFFF8-FFFFB) where the type of system bus (16-bit or 8bit) and pointers to the system configuration block are obtained. This is the only fixed location the 8089 accesses. The remaining addresses are obtained via the data structure hierarchy. The 8089 determines addresses in the same manner as does the iAPX 86; i.e., a 16-bit relocation pointer is offset left 4 bits and added to the 16-bit address offset, obtaining a 20 -bit address. Once these 20 -bit addresses are formed, they are stored as such, as all the 8089 address registers are 20 bits long. After the system configuration pointer address is formed, the 8089 IOP accesses the system configuration block.


Figure 4. Typical REMOTE Configuration

8089


Figure 5. Communication Data Structure Hierarchy
The System Configuration Block (SCB), used only during startup, points to the Control Block (CB) and provides IOP system configuration data via the SOC byte. The SOC byte initializes IOP I/O bus width to $8 / 16$, and defines one of two IOP $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ operating modes. For $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ mode 0, the IOP is typically initialized as SLAVE and has its $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ line tied to a MASTER CPU (typical LOCAL configuration). In this mode, the CPU normally has control of the bus, grants control to the IOP as needed, and has the bus restored to it upon IOP task completion (IOP request-CPU grant-IOP done). For RQ/GT mode 1, useful only in remote mode between two IOPs, MASTER/SLAVE designation is used only to initialize bus control: from then on, each IOP requests and grants as the bus is needed (IOP1 request-IOP2 grant-IOP2 request-IOP1 grant). Thus, each IOP retains bus control until the other requests it. The completion of initialization is signalled by the IOP clearing the BUSY flag in the CB. This type of startup allows the user to have the startup pointers in ROM with the SCB in RAM. Allowing the SCB to be in RAM gives the user the flexibility of being able to initialize multiple IOPs.

The Control Block furnishes bus control Initialization for the IOP operation (CCW or Channel Control Word) and provides pointers to the Parameter Block or "data" memory for both channels 1 and 2. The CCW is retrieved and analyzed upon all CA's other than the first after a reset. The CCW byte is decoded to determine channel operation.

The Parameter Block contains the address of the Task Block and acts as a messge center between the IOP and CPU. Parameters or variable information is passed from the CPU to its IOP in this block to customize the software interface to the peripheral device. It is also used for transferring data and status information between the IOP and CPU.

The Task Block contains the instructions for the respective channel. This block can reside on the local bus of
the IOP, allowing the IOP to operate concurrently with the CPU, or reside in system memory.
The advantage of this type of communication between the processor, IOP and peripheral, is that it allows for a very clean method for the operating system to handle I/O routines. Canned programs or "Task Blocks" allow for execution of general purpose I/O routines with the status and peripheral command information being passed via the Parameter Block ("data" memory). Task Blocks (or "program" memory) can be terminated or restarted by the CPU, if need be. Clearly, the flexibility of this communication lends itself to modularity and applicability to a large number of peripheral devices and upward compatibility to future end user systems and microprocessor families.

## Register Set

The 8089 maintains separate registers for its two $1 / 0$ channels as well as some common registers (see Figure 6). There are sufficient registers for each channel to sustain its own DMA transfers, and process its own instruction stream. The basic DMA pointer registers (GA, GB 20 bits each), can point to either the system bus or local bus, DMA source or destination, and can be autoincremented. A third register set (GC) can be used to allow translation during the DMA process through a lookup table it points to. Additionally, registers are provided for a masked compare during the data transfer and can be set up to act as one of the termination conditions. Other registers are also provided. Many of these registers can be used as general purpose registers during program execution, when the IOP is not performing DMA cycles.


Figure 6. Register Model

## Bus Operation

The 8089 utilizes the same bus structure as the iAPX 86, 88 in their maximum mode configurations (see Figure 7). The address is time multiplexed with the data on the first 16/8 lines. A16 through A19 are time multiplexed with four status lines S3-S6. For 8089 cycles, S4 and S3 determine what type of cycle (DMA versus nonDMA) is being performed on channels 1 or 2. S5 and S6
are a unique code assigned to the 8089 IOP, enabling the user to detect which processor is performing a bus cycle in a multiprocessing environment.

The first three status lines, S0-S2, are used with an 8288 bus controller to determine if an instruction fetch or data transfer is being performed in I/O or system memory space.
DMA transfers require at least two bus cycles with each bus cycle requiring a minimum of four clock cycles. Additional clock cycles are added if wait states are required. This two cycle approach simplifies considerably the bus timings in burst DMA. The 8089 optimizes the transfer between two different bus widths by using three bus cycles versus four to transfer 1 word. More than one read (write) is performed when mapping an 8 -bit bus onto a 16 -bit bus (vice versa). For example, a data transfer from an 8-bit peripheral to a 16-bit physical location in memory is performed by first doing two reads, with word assembly within the IOP assembly register file and then one write.

As can be expected, the data bandwidth of the IOP is a function of the physical bus width of the system and I/O busses. Table 2 gives the bandwidth, latency and bus utilization of the 8089. The system bus is assumed to be

16-bits wide with either an 8-bit peripheral (under byte column) or 16-bit peripheral (word column) being shown.

The latency refers to the worst case response time by the IOP to a DMA request, without the bus arbitration times. Notice that the word transfer allows $50 \%$ more bandwidth. This occurs since three bus cycles are required to map 8-bit data into a 16-bit location, versus two for a 16-bit to 16 -bit transfer. Note that it is possible to fully saturate the system bus in the LOCAL mode whereas in the REMOTE mode this is reduced to a maximum of $50 \%$.

Table 2. Achievable 5 MHz 8089 Operations with a 16-Bit System Bus

|  | Local |  | Remote |  |
| :--- | :---: | :---: | :---: | :---: |
|  | Byte | Word | Byte | Word |
| Bandwidth | $830 \mathrm{~KB} / \mathrm{S}$ | $1250 \mathrm{~KB} / \mathrm{S}$ | $830 \mathrm{~KB} / \mathrm{S}$ | $1250 \mathrm{~KB} / \mathrm{S}$ |
| Latency | $1.0 / 2.4 \mu \mathrm{sec} *$ | $1.0 / 2.4 \mu \mathrm{sec}^{*}$ | $1.0 / 2.4 \mu \mathrm{sec}^{*}$ | $1.0 / 2.4 \mu \mathrm{sec}^{*}$ |
| System Bus <br> Utilization | $2.4 \mu \mathrm{sec}$ <br> PER <br> TRANSFER | $1.6 \mu \mathrm{sec}$ <br> PER <br> TRANSFER | $0.8 \mu \mathrm{sec}$ <br> PER <br> TRANSFER | $0.8 \mu \mathrm{sec}$ <br> PER <br> TRANSFER |

*2.4 $\mu \mathrm{sec}$ if interleaving with other channel and no wait states. $1 \mu \mathrm{sec}$ if channel is waiting for request.


Figure 7. 8089 Bus Operation

## 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. . . . . . . . . . . . . . . . . - 1.0 to + 7V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . 2.5 Watt
*NOTICE: 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 10 \%$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 | + 0.8 | V |  |
| $V_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+1.0$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}^{\text {a }}$ - $400 \mu \mathrm{~A}$ |
| $I_{\text {cc }}$ | Power Supply Current |  | 350 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{I}_{\text {LI }}$ | Input Leakage Current ${ }^{(1)}$ |  | $\pm 10$ | $\mu \mathrm{A}$ | OV $<$ VIN $<\mathrm{V}_{\text {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{CIN}_{\text {IN }}$ | Capacitance of Input Buffer (All input except $\mathrm{AD}_{0}-\mathrm{AD} \mathrm{D}_{15}, \overline{\mathrm{RQ}} / \overline{\mathrm{G}}$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{ClO}_{10}$ | Capacitance of I/O Buffer $\left(A D_{0}-A D_{15}, \overline{R Q} / \overline{\mathrm{GT}}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS ( $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

8089/8086 MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 200 | 500 | 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.5V to 1.0 V |
| TDVCL | Data In Setup Time | 30 |  | ns |  |
| TCLDX | 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 8089 | (2/3TCLCL) - 15 |  | ns |  |
| TCHRYX | READY Hold Time into 8089 | 30 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 4) | -8 |  | ns |  |
| TINVCH | Setup Time Recognition (DRQ 1,2 RESET, Ext 1,2) (See Note 2) | 30 |  | ns |  |
| TGVCH | $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}}$ Setup Time | 30 |  | ns |  |
| TCAHCAL | CA Width | 95 |  | ns |  |
| TSLVCAL | SEL Setup Time | 75 |  | ns |  |
| TCALSLX | SEL Hold Time | 0 |  | ns |  |
| TCHGX | GT Hold Time into 8089 | 40 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time (Except CLK) |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. CHARACTERISTICS (Continued)

## TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | ns | $\mathrm{C}_{\mathrm{L}}=80 \mathrm{pF}$ |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | ns | $C_{L}=150 \mathrm{pF}$ |
| 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 | 10 | 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 |  |
| TCLLH | CLK Low to ALE Valid (See Note 1) |  | 15 | ns |  |
| TCHLL | ALE Inactive Delay (See Note 1) |  | 15 | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | ns |  |
| TCHDX | Data Hold Time | 10 |  | ns |  |
| TCVNV | Control Active Delay (See Note 1) | 5 | 45 | ns |  |
| TCVNX | Control Inactive Delay (See Note 1) | 10 | 45 | ns |  |
| TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 | ns |  |
| TCLGL | $\overline{\mathbf{R Q}}$ Active Delay | 0 | 85 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| TCLGH | $\overline{\bar{Q}}$ Inactive Delay |  | 85 | ns | Note 5: $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |
| TCLSRV | SINTR Valid Delay |  | 150 | ns | $C_{L}=100 \mathrm{pF}$ |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

NOTES: 1. Signal at $\mathbf{8 2 8 4}$ or $\mathbf{8 2 8 8}$ shown for reference only.
2. Setup requirement for asynchronous signal only to guarantee recognition at next CLK
3. Aplies only to T3 and TW states.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45V FOR A LOGIC " 0 ". THE CLOCK IS DRIVEN AT 4.3 V AND 0.25 V . TIMING MEASUREALOGIC ${ }^{\text {MENTS ARE MADE AT } 15 V}$ FOR BOTH A LOGIC $\cdots 1 "$ AND $\cdots 0$

## A.C. TESTING LOAD CIRCUIT

## WAVEFORMS

8089 BUS TIMING USING 8288


NOTES:

1. ALL SIGNALS SWITCH BETWEEN VOH AND VO UNLESS OTHERWISE SPECLFIED.
2. ROY II SAMPLED NEAR THE END OF T, T, T, TW TO DETERMINE IF TW MACHINE STATES ARE TO BE INSERTED

FOLLOWING A WRITE CYCLE DATA REMAINS VALD ON THE BOBG LOCAL BUS UNTLL A LOCAL BUS MASTER DECIDES TO RUN ANOTHER OUS
4. CICLE THE LOCAL BUS IS FLOATEO BY THE BO99 WHEN THE BO89 ENTERS A REOUEST BUS ACKNOWLLDOGE STATE

6. ALL TIMING MEASUREMENTS ARE MADE AT 1 SV UNLESS OTHERWISE NOTED.

OATA ON A WRITE TO AN B BIT PHYSICAL BUS BHE IS STABLE INON
MULTIPLEXED) FOR ALL TAANSFERS

8089

## WAVEFORMS (Continued)

ASYNCHRONOUS SIGNAL RECOGNITION


NOTES:

1. SETUP REQUIREMENTS FOR ASYNCHRONOUS SIGNALS ONLY TO GUARANTEE - AECOGNITION AT NEXT CLK.
2. ALL INPUTS EXCEPT CA ARE LATCHED ON A CLK EdGE. THE CA INPUT IS

Bgative edge trigaered.
3. DRQ BECOMING ACTIVE GREATER THAN 30 ns AFTER THE RISING EDGE OF CLK WILL GUARANTEE NON.RECOGNITION UNTIL THE NEXT RISING CLOCK EDGE.

## BUS LOCK SIGNALTIMING AND SINTR TIMING



## REQUEST/GRANT SEQUENCE TIMINGS



[^22]
## WAVEFORMS (Continued)



8089

## 8089 INSTRUCTION SET SUMMARY

Data Transfers

| POINTER INSTRUCTIONS | OPCODE |  |
| :---: | :---: | :---: |
| Load Pointer PPP from Addressed Location <br> Load Pointer PPP Immediate 4 Bytes <br> Store Contents of Pointer PPP in Addressed Location Restore Pointer | 70 | 70 |
|  | PPPO OAA1 | 100010 MM |
|  | PPPP1100011 | 000001000 |
|  | PPP0 0 A A 1 | 100110 MM |
|  | PPP0 OAA1 | 100011 MM |
| MOVE DATA | OPCODE |  |
| Move from Source to Destination <br> Source- <br> Destination- <br> Load Register RRR from Addressed Location <br> Store Contents of Register RRR in Addressed Location Load Register RRR Immediate (Byte) Sign Extend Move Immediate to Addressed Location | 0 0 0 0 0 A A W | 10001000 MM |
|  |       <br>  0 0 0 0 A AW | 1100011 MM |
|  | R R R 0 0 A AW | 1000000 MM |
|  | RRRR0 OAAW | 1000001 MM |
|  | RRRR Wb 0 O W | 0 0 1 1 0 0 0 0 |
|  | 000 wb A AW | 0100011 Mm |

Control Transfer


Arithmetic and Logic Instructions


Arithmetic and Logic Instructions


## Bit Manipulation and Test Instructions



## Control

| Control |  | OPCODE |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 7 | $7 \quad 07$ |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 |
| HLT | Halt Channel Execution | 0 |  | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 |
| SINTR | Set Interrupt Service Flip Flop | 0 |  | 10 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| NOP | No Operation | 0 |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| XFER | Enter DMA Transfer |  |  | 11 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| WID | Set Source, Destination Bus Width; S,D 0=8,1=16 |  |  | S | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

*AAField in call instruction can be $00,01,10$ only. **OPCODE is second byte fetched.

All instructions consist of at least 2 bytes, while some instructions may use up to 3 additional bytes to specify literals and displacement data. The definition of the various fields within each instruction is given below:


| MM | Base Pointer Select |
| :--- | :--- |
| 00 | GA |
| 01 | GB |
| 10 | GC |
| 11 | PP |

## RRR Register Field

The RRR field specifies a 16 -bit register to be used in the instruction. If GA, GB, GC or TP, are referenced by the RRR field, the upper 4 bits of the registers are loaded with the sign bit (Bit 15). PPP registers are used as 20-bit address pointers.

| RRR |  |  |  |
| :--- | :--- | :--- | :--- |
| 000 | rO | GA |  |
| 001 | r 1 | GB |  |
| 010 | r 2 | GC |  |
| 011 | r 3 | BC | ; byte count |
| 100 | r 4 | TP | ; task block |
| 101 | r 5 | IX | ; index register |
| 110 | r 6 | CC | ; channel control (mode) |
| 111 | r 7 | MC | ; mask/compare |


| PPP |  |  |  |
| :--- | :--- | :--- | :--- |
| 000 | p0 | GA | $;$ |
| 001 | p1 GB | ; |  |
| 010 | p2 GC | : |  |
| 100 | p 4 | TP | ; task block pointer |

## NOTES:

## BBB Bit Select Field

The bit select field replaces the RRR field in bit manipulation instructions and is used to select a bit to be oper. ated on by those instructions. Bit 0 is the least significant bit.

## wb

011 byte literal
102 byte (word) literal
dd
011 byte displacement
102 byte (word) displacement.

## AA Field

00 The selected pointer contains the operand address.
01 The operand address is formed by adding an 8-bit, unsigned, offset contained in the instruction to the selected pointer. The contents of the pointer are unchanged.
10 The operand address is formed by adding the contents of the Index register to the selected pointer. Both registers remain unchanged.
11 Same as 10 except the Index register is post autoincremented (by 1 for 8 -bit transfer, by 2 for 16 -bit transfer).

## W Width Field

0 The selected operand is 1 byte long.
1 The selected operand is 2 bytes long.

## Additional Bytes

OFFSET : 8-bit unsigned offset.
SDISP : 8/16-bit signed displacement.
LITERAL: 8/16-bit literal. ( 32 bits for LDPI).
The order in which the above optional bytes appear in IOP instructions is given below:


Offsets are treated as unsigned numbers̀. Literals and displacements are sign extended (2's complement).

## iAPX 86/20 iAPX 88/20 NUMERIC DATA PROCESSOR

## - High Performance 2-Chip Numeric Data Processor

- Standard iAPX 86/10, 88/10 Instruction Set Plus Arithmetic, Trigonometric, Exponential, and Logarithmic Instructions For All Data Types
- All 24 iAPX 86/10, 88/10 Addressing Modes Available
- Conforms To Proposed IEEE Floating Point Standard
- Support 8 Data Types: 8-, 16-, 32-, 64Bit Integers, 32-, 64-, 80-Bit Floating Point, and 18-Digit BCD Operands
- 8x80-Bit Individually Addressable Register Stack plus 14 General Purpose Registers
- 7 Built-in Exception Handling Functions
- MULTIBUS System Compatible Interface

The Intel iAPX 86/20 and iAPX 88/20 are two-chip numeric data processors (NDP's). They provide the instructions and data types needed for high-performance numeric applications. The NDP provides 100 times the performance of an IAPX 86/10, 88/10 CPU alone for numeric processing. The iAPX 86/20 consists of an iAPX $86 / 10$ (16-bit 8086 CPU) and a numeric processor extension (NPX), the 8087. The iAPX 88/20 consists of the NPX in conjunction with the iAPX 88/10 (8-bit 8088 CPU). The NDP conforms to the proposed IEEE Floating Point Standard.

Both components of the iAPX 86/20 and iAPX 88/20 are implemented in N-channel, depletion load, silicon gate technology (HMOS), housed in two 40-pin packages. The iAPX 86/20, 88/20 adds 68 numeric processing instructions to the iAPX 86/10, 88/10 instruction set and eight 80-bit registers to the register set.


Figure 1. iAPX 86/20, 88/20 Block Diagram
Figure 2. IAPX 86/20, 88/20 Pin Configuration

IAPX 86/20, 88/20

Table 1. 8087 Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| AD15-AD0 | I/O | Address Data: These lines constitute the time multiplexed memory address ( $T_{1}$ ) and data ( $T_{2}$, $\mathrm{T}_{3}, \mathrm{~T}_{\mathrm{W}}, \mathrm{T}_{4}$ ) bus. AO is analogous to $\overline{\mathrm{BHE}}$ for the lower byte of the data bus, pins D7-D0. It is LOW during $T_{1}$ when a byte is to be transferred on the lower portion of the bus in memory operations. Eight-bit oriented devices tied to the lower half of the bus would normally use AO to condition chip select functions. These lines are active HIGH. They are input/output lines for 8087 driven bus cycles and are inputs which the 8087 monitors when the 8086/8088 is in control of the bus. A15-A8 do not require an address latch in an IAPX 88/20. The 8087 will supply an address for the $T_{1}-T_{4}$ period. |
| A19/S6, <br> A18/S5, <br> A17/S4, <br> A16/S3 | 1/0 | Address Memory: During $\mathrm{T}_{1}$ these are the four most significant address lines for memory operations. During memory operations, status information is available on these lines during $T_{2}, T_{3}, T_{W}$, and $T_{4}$. For 8087 controlled bus cycles, S6, S4, and S3 are reserved and currently one (HIGH), while S5 is always LOW. These lines are inputs which the 8087 monitors when the $8086 / 8088$ is in control of the bus. |
| BHE/S7 | 1/0 | Bus High Enable: 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 D15-D8. Eight-bit oriented devices tied to the upper half of the bus would normally use $\overline{\mathrm{BHE}}$ to condition chip select functions. $\overline{\mathrm{BHE}}$ is LOW during $T_{1}$ for read and write cycles when a byte is to be transferred on the high portion of the bus. The $S 7$ status information is available during $T_{2}, T_{3}, T_{W}$, and $T_{4}$. The signal is active LOW. S7 is an input which the 8087 monitors during 8086/8088 controlled bus cycles. |
| $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~s} 0}$ | 1/0 | Status: For 8087 driven bus cycles, these status lines are encoded as follows: <br> Status is driven active during $T_{4}$, remains valid during $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 access control signals. Any change in $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}$, or $\overline{\mathrm{SO}}$ 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 are monitored by the 8087 when the $8086 / 8088$ is in control of the bus. |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ | 1/0 | Request/Grant: This request/grant pin is used by the NPX to gain control of the local bus from the CPU for operand transfers or on behalf of another bus master. It must be connected to one of the two processor request/grant pins. The request grant sequence on this pin is as follows: <br> 1. A pulse one clock wide is passed to the CPU to indicate a local bus request by either the 8087 or the master connected to the $8087 \overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$ pin. <br> 2. The 8087 waits for the grant pulse and when it is received will either initiate bus transfer activity in the clock cycle following the grant or pass the grant out on the $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ pin in this clock if the initial request was for another bus master. <br> 3. The 8087 will generate a release pulse to the CPU one clock cycle after the completion of the last 8087 bus cycle or on receipt of the release pulse from the bus master on $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$. |

Table 1. 8087 Pin Description (Continued)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\overline{\mathrm{RQ}} / \overline{\mathrm{GT}} 1$ | I/O | Request/Grant:This request/grant pin is used by another local bus master to force the 8087 to request the local bus. If the 8087 is not in control of the bus when the request is made the request/grant sequence is passed through the 8087 on the $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$ pin one cycle later. Subsequent grant and release pulses are also passed through the 8087 with a two and one clock delay, respectively, for resynchronization. $\overline{R Q} / G T 1$ has has an internal pullup resistor, and so may be left unconnected. If the 8087 has control of the bus the request/grant sequence is as follows: <br> 1. A pulse 1 CLK wide from another local bus master indicates a local bus request to the 8087 (pulse 1). <br> 2. During the 8087's next $T_{4}$ or $T_{1}$ a pulse 1 CLK wide from the 8087 to the requesting master (pulse 2) indicates that the 8087 has allowed the local bus to float and that it will enter the "RQ/GT acknowledge" state at the next CLK. The 8087's control unit is disconnected logically from the local bus during "RQ/GT acknowledge." <br> 3. A pulse 1 CLK wide from the requesting master indicates to the 8087 (pulse 3) that the "RQ/GT" request is about to end and that the 8087 can reclaim the local bus at the next CLK. <br> Each master-master exchange of the local bus is a sequence of 3 pulses. There must be one dead CLK cycle after each bus exchange. Pulses are active LOW. |
| $\begin{aligned} & \text { QS1, } \\ & \text { QS0 } \end{aligned}$ | 1 | QS1, QSO: QS1 and QS0 provide the 8087 with status to allow tracking of the CPU instruction queue. |
| INT | 0 | Interrupt: This line is used to indicate that an unmasked exception has occurred during numeric instruction execution when 8087 interrupts are enabled. This signal is typically routed to an 8259A. INT is active HIGH. |
| BUSY | 0 | Busy: This signal indicates that the 8087 NEU is executing a numeric instruction. It is connected to the CPU's TEST pin to provide synchronization. In the case of an unmasked exception BUSY remains active until the exception is cleared. BUSY is active HIGH. |
| READY | 1 | Ready: READY is the acknowledgment from the addressed memory device that it will complete the data transfer. The RDY signal from memory is synchronized by the 8284A Clock Generator to form READY. This signal is active HIGH. |
| RESE'I | 1 | Reset: RESETcauses the processor to immediately terminate its present activity. The signal must be active HIGH for at least four clock cycles. RESET is internally synchronized. |
| CLK | 1 | Clock: 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. |
| $\mathrm{V}_{\mathrm{Cc}}$ |  | Power: $\mathrm{V}_{\mathrm{CC}}$ is the +5 V power supply pin. |
| GND |  | Ground: GND are the ground pins. |

NOTE:
For the pin descriptions of the 8086 and 8088 CPU's reference those respective data sheets (iAPX 86/10, iAPX 88/10).

## APPLICATION AREAS

The iAPX 86/20 and iAPX 88/20 provide functions meant specifically for high performance numeric processing requirements. Trigonometric, logarithmic, and exponential functions are built into the processor hardware. These functions are essential in scientific, engineering, navigational, or military applications.

The NDP also has capabilities meant for business or commercial computing. An iAPX 86/20, 88/20 can process Binary Coded Decimal (BCD) numbers up to 18 digits without roundoff errors. It can also perform arithmetic on integers as large as 64 bits $\left( \pm 10^{18}\right)$.

## PROGRAMMING LANGUAGE SUPPORT

Programs for the iAPX 86/20 and iAPX 88/20 can be written in ASM-86, the iAPX 86,88 assembly language, PL/M-86, FORTRAN-86, and PASCAL-86, Intel's high-level languages for iAPX 86, 88 systems.

## Details

The remainder of the data sheet will concentrate on the numeric processor extension (refered to as NPX or 8087). For iAPX 86/10 or iAPX 88/10 CPU details refer to those respective data sheets.

## FUNCTIONAL DESCRIPTION

The iAPX 86/20, 88/20 Numeric Data Processor's architecture is designed for high performance numeric computing in conjunction with general purpose processing.

The 8087 is a numeric processor extension that provides arithmetic and logical instruction support for a variety of numeric data types in iAPX 86/20, $88 / 20$ systems. It also executes numerous built-in transcendental functions (e.g., tangent and log functions). The 8087 executes instructions as a coprocessor to a maximum mode 8086 or 8088 . It effectively extends the register and instruction set of an iAPX 86/10 or 88/10 based system and adds several new data types as well. Figure 3 presents the registers of the iAPX 86/20. Table 2 shows the range of data types supported by the NDP. The 8087 is treated as an extension to the iAPX 86/10 or 88/10, providing register, data types, control, and instruction capabilities at the hardware level. At the programmers level the iAPX 86/20, 88/20 is viewed as a single unified processor.

## iAPX 86/20, 88/20 System Configuration

As a coprocessor to an 8086 or 8088 , the 8087 is wired in parallel with the CPU as shown in Figure 4. The CPU's status ( $\overline{\mathrm{SO}}-\overline{\mathrm{S} 2}$ ) and queue status lines (QS0-QS1) enable the 8087 to monitor and decode


Figure 3. IAPX 86/20 Architecture

Table 2. IAPX 86/20, 88/20 Data Types



Figure 4. NDP System Configuration
instructions in synchronization with the CPU and without any CPU overhead. Once started the 8087 can process in parallel with and independent of the host CPU. For resynchronization, the NPX's BUSY signal informs the CPU that the NPX is executing an instruction and the CPU WAIT instruction tests this signal to insure that the NPX is ready to execute subsequent instructions. The NPX can interrupt the CPU when it detects an error or exception. The 8087's interrupt request line is typically routed to the CPU through an 8259A Programmable Interrupt Controller. (See Figure 2 for 8087 pinout information.)

The 8087 uses one of the request/grant lines of the iAPX 86, 88 architecture (typically RQ/GT1) to obtain control of the local bus for data transfers. The other request/grant line is available for general system use (for instance by an I/O processor in LOCAL mode). A bus master can also be connected to the 8087's $\overline{\mathrm{RQ}} / \overline{\mathrm{GT} 1}$ line. In this configuration the 8087 will pass the request/grant handshake signals between the CPU and the attached master when the 8087 is not in control of the bus and will relinquish the bus to the master directly when the 8087 is in control. In this way two additional masters can be configured in an iAPX 86/20, 88/20 system; one will share the 8086 bus with the 8087 on a first come first served basis, and the second will be guaranteed to be higher in priority than the 8087.

As Figure 4 shows, all processors utilize the same clock generator and system bus interface components (bus controller, latches, transceivers and bus arbiter).

## Bus Operation

The 8087 bus structure, operation and timing are identical to all other processors in the iAPX 86, 88 series (maximum mode configuration). The address is time multiplexed with the data on the first $16 / 8$ lines of the address/data bus. A16 through A19 are time multiplexed with four status lines S3-S6. S3, S4 and S6 are always one (high) for 8087 driven bus cycles while 55 is always zero (low). When the 8087 is monitoring CPU bus cycles (passive mode) S 6 is also monitored by the 8087 to differentiate 8086/8088 activity from that of a local I/O processor or any other local bus master. (The 8086/8088 must be the only processor on the local bus to drive S6 low.) S 7 is multiplexed with and has the same value as $\overline{B H E}$ for all 8087 bus cycles.

The first three status lines, $\overline{\mathbf{s} 0}-\overline{\mathrm{S} 2}$, are used with an 8288 bus controller to determine the type of bus
cycle being run:

| $\overline{\mathbf{S 2}}$ | $\overline{\mathbf{S 1}}$ | $\overline{\mathbf{S 0}}$ |  |
| :---: | :---: | :---: | :--- |
| 0 | X | X | Unused |
| 1 | 0 | 0 | Unused |
| 1 | 0 | 1 | Memory Data Read |
| 1 | 1 | 0 | Memory Data Write <br> 1 |
|  | 1 | 1 | Passive (no bus <br> cycle) |

## Programming Interface

The NDP includes the standard iAPX 86/10, 88/10 instruction set for general data manipulation and program control. It also includes 68 numeric instructions for extended precision integer, floating point, trigonometric, logarithmic, and exponential tunctions. Sample execution times for several NDP functions are shown in Figure 4. Overall iAPX 86/20 system performance is 100 times that of an IAPX 86/10 class processor for numeric instructions.

Any instruction executed by the NDP is the combined result of the CPU and NPX activity. The CPU and the NPX have specialized functions and registers providing fast concurrent operation. The CPU controls overall program execution while the NPX uses the coprocessor interface to recognize and perform numeric operations.

Table 2 lists the eight data types the iAPX 86/20, $88 / 20$ supports and presents the format for each type. Internally, the NPX holds all numbers in the temporary real format. Load and store instructions automatically convert operands represented in memory as 16 -, 32 -, or 64 -bit integers, 32 - or 64 -bit floating point numbers or 18 -digit packed BCD numbers into temporary real format and vice versa. The NDP also provides the capability to control round off, underflow, and overflow errors in each calculation.

Computations in the NPX use the processor's register stack. These eight 80 -bit registers provide the equivalent capacity of 2032 -bit registers. The NPX register set can be accessed as a stack, with instructions operating on the top one or two stack elements, or as a fixed register set, with instructions operating on explicitly designated registers.

Table 5 lists the 8087's instructions by class. All appear as ESCAPE instructions to the host. Assembly language programs are written in ASM-86, the IAPX 86, 88 assembly language. Table 3 gives the execution times of some typical numeric instructions.

Table 3. Execution Times for Selected IAPX 86/20 Numeric Instructions and Corresponding iAPX 86/10 Emulation

| Floating Point Instruction | Approximate Execution Time ( $\mu \mathrm{s}$ ) |  |
| :---: | :---: | :---: |
|  | $\begin{aligned} & \text { IAPX 86/20 } \\ & \text { (5 MHz } \\ & \text { Clock) } \end{aligned}$ | iAPX 86/10 <br> Emulation |
| Add/Subtract | 17 | 1,600 |
| Multiply (single precision) | 19 | 1,600 |
| Multiply (extended precision) | 27 | 2,100 |
| Divide | 39 | 3,200 |
| Compare | 9 | 1,300 |
| Load (double precision) | 10 | 1,700 |
| Store (double precision) | 21 | 1,200 |
| Square Root | 36 | 19,600 |
| Tangent | 90 | 13,000 |
| Exponentiation | 100 | 17,100 |

## NUMERIC PROCESSOR EXTENSION ARCHITECTURE

As shown in Figure 5, the 8087 is internally divided into two processing elements, the control unit (CU) and the numeric execution unit (NEU). The NEU executes all numeric instructions, while the CU receives and decodes instructions, reads and writes memory operands and executes NPX control instructions. The two elements are able to operate independently of one another, allowing the CU to maintain synchronization with the CPU while the NEU is busy processing a numeric instruction.

## Control Unit

The CU keeps the 8087 operating in synchronization with its host CPU. 8087 instructions are intermixed with CPU instructions in a single instruction stream. The CPU fetches all instructions from memory; by monitoring the status signals ( $\overline{\mathrm{SO}}-\mathbf{S 2}, \mathrm{S} 6$ ) emitted by the CPU, the NPX control unit determines when an


Figure 5. 8087 Block Diagram

8086 instruction is being fetched. The CU monitors the Data bus in parallel with the CPU to obtain instructions that pertain to the 8087.

The CU maintains an instruction queue that is identical to the queue in the host CPU. The CU automatically determines if the CPU is an 8086 or an 8088 immediately after reset (by monitoring the $\overline{\mathrm{BHE} / \mathrm{S} 7}$ line) and matches its queue length accordingly. By monitoring the CPU's queue status lines (QSO, QS1), the CU obtains and decodes instructions from the queue in synchronization with the CPU.

A numeric instruction appears as an ESCAPE instruction to the 8086 or 8088 CPU. Both the CPU and NPX decode and execute the ESCAPE instruction together. The 8087 only recognizes the numeric instructions shown in Table 5. The start of a numeric operation is accomplished when the CPU executes the ESCAPE instruction. The instruction may or may not identify a memory operand.

The CPU does, however, distinguish between ESC instructions that reference memory and those that do not. If the instruction refers to a memory operand, the CPU calculates the operand's address using any one of its available addressing modes, and then performs a "dummy read" of the word at that location. (Any location within the 1 M byte address space is allowed.) This is a normal read cycle except that the CPU ignores the data it receives. If the ESC instruction does not contain a memory reference (e.g. an 8087 stack operation), the CPU simply proceeds to the next instruction.

An 8087 Instruction can have one of three memory reference options; (1) not reference memory; (2) load an operand word from memory into the 8087; or (3) store an operand word from the 8087 into memory. If no memory reference is required, the 8087 simply executes its instruction. If a memory reference is required, the CU uses a "dummy read" cycle initiated by the CPU to capture and save the address that the CPU places on the bus. If the instruction is a load, the CU additionally captures the data word when it becomes available on the local data bus. If data required is longer than one word, the CU immediately obtains the bus from the CPU using the request/grant protocol and reads the rest of the information in consecutive bus cycles. In a store operation, the CU captures and saves the store address as in a load, and ignores the data word that follows in the "dummy read" cycle. When the 8087 is ready to perform the store, the CU obtains the bus from the CPU and writes the operand starting at the specified address.

## Numeric Execution Unit

The NEU executes all instructions that involve the register stack; these include arithmetic, logical, transcendental, constant and data transfer instructions. The data path in the NEU is 84 bits wide ( 68 fraction bits, 15 exponent bits and a sign bit) which allows internal operand transfers to be performed at very high speeds.

When the NEU begins executing an instruction, it activates the 8087 BUSY signal. This signal can be used in conjunction with the CPU WAIT instruction to resynchronize both processors when the NEU has completed its current instruction.

## Register Set

The iAPX 86/20 register set is shown in Figure 3. Each of the eight data registers in the 8087's register stack is 80 bits wide and is divided into "fields" corresponding to the NDP's temporary real data type.

At a given point in time the TOP field in the control word identifies the current top-of-stack register. A "push" operation decrements TOP by 1 and loads a value into the new top register. A "pop" operation stores the value from the current top register and then increments TOP by 1 . Like iAPX 86/10, 88/10 stacks in memory, the 8087 register stack grows "down" toward lower-addressed registers.

Instructions may address the data registers either implicitly or explicitly. Many instructions operate on the register at the top of the stack. These instructions implicitly address the register pointed to by the TOP. Other instructions allow the programmer to explicitly specify the register which is to be used. Explicit register addressing is "top-relative."

## Status Word

The status word shown in Figure 6 reflects the overall state of the 8087; it may be stored in memory and then inspected by CPU code. The status word is a 16-bit register divided into fields as shown in Figure 6. The busy bit (bit 15) indicates whether the NEU is either executing an instruction or has an interrupt request pending ( $B=1$ ), or is idle ( $B=0$ ). Several instructions which store and manipulate the status word are executed exclusively by the CU, and these do not set the busy bit themselves.


Figure 6. $\mathbf{8 0 8 7}$ Status Word

The four numeric condition code bits $\left(\mathrm{C}_{0}-\mathrm{C}_{3}\right)$ are similar to the flags in a CPU: various instructions update these bits to reflect the outcome of NDP operations. The effect of these instructions on the condition code bits is summarized in Table 4.

Bits 14-12 of the status word point to the 8087 register that is the current top-of-stack (TOP) as described above.

Bit 7 is the interrupt request bit. This bit is set if any unmasked exception bit is set and cleared otherwise.

Bits 5-0 are set to indicate that the NEU has detected an exception while executing an instruction.

## Tag Word

The tag word marks the content of each register as shown in Figure 7. The principal function of the tag word is to optimize the NDP's performance. The tag word can be used, however, to interpret the contents of 8087 registers.

## Instruction and Data Pointers

The instruction and data pointers (see Figure 8) are provided for user-written error handlers. Whenever the 8087 executes an NEU instruction, the CU saves the instruction address, the operand address (if present) and the instruction opcode. 8087 instructions can store this data into memory.

Table 4. Condition Code Interpretation

| Instruction | $\mathrm{C}_{3}$ | $\mathrm{C}_{2}$ | $C_{1}$ | $\mathrm{C}_{0}$ | Interpretation |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Compare, Test | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & A>B \\ & A<B \\ & A=B \\ & A ? B \text { (not comparable) } \\ & \hline \end{aligned}$ |
| Remainder | $\begin{aligned} & Q_{1} \\ & Q_{1} \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & Q_{0} \\ & Q_{0} \end{aligned}$ | $\begin{aligned} & Q_{2} \\ & Q_{2} \end{aligned}$ | Complete reduction Incomplete reduction |
| Examine | $\begin{aligned} & \hline 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | Valid, positive, unnormalized Invalid, positive, exponent $\neq 0$ <br> Valid, negative, unnormalized <br> Invalid, negative, exponent $\neq 0$ <br> Valid, positive, normalized <br> Infinity, positive <br> Valid, negative, normalized <br> Infinity, negative <br> Zero, positive <br> Empty <br> Zero, negative <br> Empty <br> Invalid, positive, exponent $=0$ <br> Empty <br> Invalid, negative, exponent $=0$ <br> Empty |

$X=$ value is not affected by instruction.
$Q=C_{0}, C_{3}, C_{1}$ hold 3 LSBs of the quotient generated during a remainder operation.


Figure 7. 8087 Tag Word


Figure 8. 8087 Instruction and Data Pointers

## Control Word

The 8087 provides several processing options which are selected by loading a word from memory into the control word. Figure 9 shows the format and encoding of the fields in the control word.

The low order byte of this control word configures 8087 interrupts and exception masking. Bits 5-0 of the control word contain individual masks for each of the six exceptions that the 8087 recognizes and bit 7 contains a general mask bit for all 8087 interrupts. The high order byte of the control word configures the 8087 operating mode including precision, rounding, and infinity controls. The precision control bits (bits 9-8) can be used to set the 8087 internal operating precision at less than the default of temporary real precision. This can be useful in providing compatibility with earlier generation arithmetic processors of smaller precision than the 8087. The rounding control bits (bits $11-10$ ) provide for directed rounding and true chop as well as the unbiased round to nearest mode specified in the proposed IEEE standard. Control over closure of the number space at infinity is also provided (either affine closure, $\pm \infty$, or projective closure, $\infty$, is treated as unsigned, may be specified).

## Exception Handling

The 8087 detects six different exception conditions that can occur during instruction execution. Any or all exceptions will cause an interrupt if unmasked and interrupts are enabled.

If interrupts are disabled the 8087 will simply continue execution regardless of whether the host clears the exception. If a specific exception class is masked and that exception occurs, however, the 8087 will post the exception in the status register and perform an on-chip default exception handling procedure, thereby allowing processing to continue. The exceptions that the 8087 detects are the following:

1. INVALID OPERATION: Stack overflow, stack underflow, indeterminate form ( $0 / 0, \infty-\infty$, etc.) or the use of a Non-Number (NAN) as an operand. An exponent value is reserved and any bit pattern with this value in the exponent field is termed a Non-Number and causes this exception. If this exception is masked, the 8087's default response is to generate a specific NAN called INDEFINITE, or to propagate already existing NANs as the calculation result.


Figure 9. 8087 Control Word
2. OVERFLOW: The result is too large in magnitude to fit the specified format. The 8087 will generate an encoding for infinity if this exception is masked.
3. ZERO DIVISOR: The divisor is zero while the dividend is a non-infinite, non-zero number. Again, the 8087 will generate an encoding for infinity if this exception is masked.
4. UNDERFLOW: The result is non-zero but too small in magnitude to fit in the specified format. If this exception is masked the 8087 will denormalize (shift right) the fraction until the exponent is in range. This process is called gradual underflow.
5. DENORMALIZED OPERAND: At least one of the operands or the result is denormalized; it has the smallest exponent but a non-zero significand. Normal processing continues if this exception is masked off.
6. INEXACT RESULT: If the true result is not exactly representable in the specified format, the result is rounded according to the rounding mode, and this flag is set. If this exception is masked, processing will simply continue.

## 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
Power Dissipation
1.0 V to +7 V
D.C. CHARACTERISTICS
$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{C}} \mathrm{C}=+5 \mathrm{~V} \pm 10 \%\right)$

| 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.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}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| I'c | Power Supply Current |  | 475 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| ILI | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {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{CIN}_{\text {N }}$ | Capacitance of Inputs |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{ClO}_{10}$ | Capacitance of I/O Buffer (AD0-15, $\mathrm{A}_{16}-\mathrm{A}_{19}$, BHE, S2-S0, RQ/GT) and CLK |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| Cout | Capacitance of Outputs BUSY, INT |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS $\left(T_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 200 | 500 | ns |  |
| TCLCH | CLK Low Time | $(2 / 3$ TCLCL) -15 |  | ns |  |
| TCHCL | CLK High Time | $(1 / 3$ TCLCL) +2 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 | ns | From 1.0V to 3.5V |
| TCL2CL1 | CLK Fall Time |  | 10 | ns | From 3.5V to 1.0V |
| TDVCL | Data In Setup Time | 30 |  | ns |  |
| TCLDX | Data In Hold Time | 10 |  | ns |  |
| TRYHCH | READY Setup Time | $(2 / 3$ TCLCL) -15 |  | ns |  |
| TCHRYX | READY Hold Time | 30 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 3) | -8 |  | ns |  |
| TGVCH | RQ/GT Setup Time | 30 |  | ns |  |
| TCHGX | RQ/GT Hold Time | 40 |  | ns |  |
| TQVCL | QS0-1 Setup Time | 30 |  | ns |  |
| TCLQX | QS0-1 Hold Time | 10 |  | ns |  |
| TSACH | Status Active Setup Time | 30 |  | ns |  |
| TSNCL | Status Inactive Setup Time | 30 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 | ns | From 0.8V to 2.0V |
| TIHIL | Input Fall Time (Except CLK) |  | 12 | ns | From 2.0V to 0.8V |

## A.C. CHARACTERISTICS (Continued)

## timing responses

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | ns | $C_{L}=20-100 \mathrm{pF}$ for all 8087 Outputs (in addition to 8087 self-load) |
| TCLMH | Command Inactive Delay (See Note 1) | 10 | 35 | ns |  |
| TRYHSH | Ready Active to Status Passive (See Note 2) |  | 110 | ns |  |
| TCHSV | Status Active Delay | 10 | 110 | ns |  |
| TCLSH | Status Inactive Delay | 10 | 130 | ns |  |
| TCLAV | Address Valid Delay | 10 | 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 |  |
| TCLLH | CLK Low to ALE Valid (See Note 1) |  | 15 | ns |  |
| TCHLL | ALE Inactive Delay (See Note 1) |  | 15 | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | ns |  |
| TCHDX | Data Hold Time | 10 |  | ns |  |
| TCVNV | Control Active Delay (See Note 1) | 5 | 45 | ns |  |
| TCVNX | Control Inactive Delay (See Note 1) | 10 | 45. | ns |  |
| TCHBV | BUSY and INT Valid Delay | 10 | 150 | ns |  |
| TCHDTL | Direction Control Active Delay (See Note 1) |  | 50 | ns |  |
| TCHDTH | Direction Control Inactive Delay (See Note 1) |  | 30 | ns |  |
| TCLGL | RQ/GT Active Delay | 0 | 85 | ns | $\mathrm{C}_{\mathrm{L}}=40 \mathrm{pF}$ (in |
| TCLGH | RQ/GT Inactive Delay | 0 | 85 | ns | addition to 8087 self-load) |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Signal at 8284A or 8288 shown for reference only.
2. Applies only to $T_{3}$ and wait states.
3. Applies only to $T_{2}$ state ( 8 ns into $T_{3}$ ).

## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT
A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "1"AND 0.45V FOR
ALOGIC " 0 ." THE CLOCK IS DRIVEN AT 4.3V AND 0.25V. TIMING MEASURE-
MENTS ARE MADE AT 1.5V FOR BOTH A LOGIC "1" AND "0."

## A.C. TESTING LOAD CIRCUIT



WAVEFORMS


## NOTES:

1. ALL SIGNALS SWITCH BETWEEN $V_{O L}$ AND $V_{O H}$ UNLESS OTHERWISE SPECIFIED.
2. READY IS SAMPLED NEAR THE END OF $T_{2}, T_{3}$ AND $T_{W}$ TO DETERMINE IF $T_{W}$ MACHINE STATES ARE TO BE INSERTED.
3. THE LOCAL BUS FLOATS ONLY IF THE 8087 IS RETURNING CONTROLTO THE 8086/8088.
4. ALE RISES AT LATER OF (TSVLH, TCLLLH).
5. STATUS INACTIVE IN STATE JUST PRIOR TOT $T_{4}$.
6. SIGNALS AT 8284A OR 8288 ARE SHOWN FOR REFERENCE ONLY.
7. THE ISSUANCE OF 8288 COMMAND AND CONTROL SIGNALS ( $\overline{M R D C}, \overline{M W T C}, \overline{A M W C}$ AND DEN) LAGS THE ACTIVE HIGH 8288 CEN.
8. ALL TIMING MEASUREMENTS ARE MADE AT 1.5 V UNLESS OTHERWISE NOTED

## WAVEFORMS (Continued)



RESET TIMING


## REQUEST/GRANT ${ }_{0}$ TIMING



NOTE: THE CPU PROVIDES ACTIVE PULLUP OF $\overline{\mathrm{RQ}} / \overline{\mathrm{GTO}}$, SEE TCLGH SPEC.

## WAVEFORMS (Continued)

## REQUEST/GRANT ${ }_{1}$ TIMING



NOTE: ALTERNATE MASTER MAY NOT DRIVE THE buSES OUTSIDE OF THE REGION SHOWN WITHOUT RISKING BUS CONTENTION.

## BUSY AND INTERRUPT TIMING



Table 5. 8087 Extensions to the $\mathbf{8 0 8 6 / 8 0 8 8}$ Instruction Set

## 

## Data Transfer

$F L D=L O A D$
Integer/Real Memory to ST(0)
Long Integer Memory to ST(0)
Temporary Real Memory to ST(0)
BCD Memory to ST(0)
ST (i) to $\mathrm{ST}(0)$

| ESCAPE | M |  | 1 | MOD | 0 | 0 | 0 | R/M | (DISP-LO) | (DISP-HI) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ESCAPE | 1 | 1 | 1 | MOD | 1 | 0 | 1 | R/M | (DISP-LO) | (DISP-HI) |
| ESCAPE | 0 | 1 | 1 | MOD | 1 | 0 | 1 | R/M | (DISP-LO) | (DISP-HI) |
| ESCAPE | 1 | 1 | 1 | MOD | 1 | 0 | 0 | R/M | (DISP-LO) | (DISP-HI) |
| ESCAPE | 0 | 0 | 1 | 11 | 0 | 0 | 0 | ST(i) |  |  |

FST $=$ STORE
ST(0) to Integer/Real Memory
$\mathrm{ST}(0)$ to ST (i)

| ESCAPE | MF | 1 | MOD | 0 | 1 | 0 | R/M | (DISP-LO) | (DISP-HI) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ESCAPE 1 0 1 1 1 0 1 0 $S T(i)$  |  |  |  |  |  |  |  |  |  |.

FSTP = STORE AND POP
ST(0) to Integer/Real Memory
ST(0) to Long Integer Memory
ST(0) to Temporary Real Memory
$\mathrm{ST}(0)$ to BCD Memory
ST(0) to ST (i)

| ESCAPE | MF |  | 1 | MOD | 0 | 1 | 1 | R/M | (DISP-LO) | (DISP-HI) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ESCAPE | 1 | 1 | 1 | MOD | 1 | 1 | 1 | R/M | (DISP-LO) | (DISP-HI) |
| ESCAPE | 0 | 1 | 1 | MOD | 1 | 1 | 1 | R/M | (DISP-LO) | (DISP-HI) |
| ESCAPE | 1 | 1 | 1 | MOD | 1 | 1 | 0 | R/M | (DISP-LO) | (DISP-HI) |
| ESCAPE | 1 | 0 | 1 | 11 | 0 | 1 | 1 | ST(i) |  |  |

$\mathrm{FXCH}=$ Exchange $\mathrm{ST}(\mathrm{i})$ and $\mathrm{ST}(0)$

| ESCAPE | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | ST(i) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

## Comparison

FCOM = Compare
Integer/Real Memory to ST(0)
ST(i) to ST(0)

| ESCAPE | MF | 0 | MOD | 0 | 1 | 0 | $R / M$ | (DISP-LO) | (DISP-HI) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| ESCAPE | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | ST(i) |

FCOMP = Compare and Pop
Integer/Real Memory to ST( 0 )
ST(i) to ST(0)

| ESCAPE | MF | 0 | MOD | 0 | 1 | 1 | R/M | (DISP-LO) | (DISP-HI) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ESCAPE | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | ST $(i)$ |

FCOMPP = Compare ST(1) to ST(0)
Pop Twice

FXAM $=$ Examine $\mathrm{ST}(0)$

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

Table 5. $\mathbf{8 0 8 7}$ Extensions to the 8086/8088 Instruction Set (Continued)


FSUB $=$. Subtraction
Integer/Real Memory with ST(0)
ST(i) and ST(0)

| ESCAPE | MF | 0 | $M O D$ | 1 | 0 | $R$ | $R / M$ | (DISP-LO) | (DISP-HI) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ESCAPE | d | $P$ | 0 | 1 | 1 | 1 | 0 | $R$ | $R / M$ |  |

FMUL $=$ Multiplication
Integer/Real Memory with ST(0) $\mathrm{ST}(\mathrm{i})$ and $\mathrm{ST}(0)$

| ESCAPE | MF | 0 | MOD | 0 | 0 | 1 | $R / M$ | (DISP-LO) | (DISP-HI) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ESCAPE | d | P | 0 | 1 | 1 | 0 | 0 | 1 | $R / M$ |

FDIV $=$ Division
Integer/Real Memory with ST(0) ST(i) and ST(0)

| ESCAPE | MF | 0 | MOD | 1 | 1 | $R$ | $R / M$ | (DISP-LO) | (DISP-HI) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ESCAPE | d | $P$ | 0 | 1 | 1 | 1 | 1 | $R$ | $R / M$ |

FSQRT = Square Root of ST(0)
FSCALE $=$ Scale $\mathrm{ST}(0)$ by $\mathrm{ST}(1)$

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

FPREM = Partial Remainder of $\mathrm{ST}(0) \div \mathrm{ST}(1)$

FRNDINT = Round ST(0)
to integer

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

FXTRACT $=$ Extract Components of ST(0)

FABS $=$ Absolute Value of $\mathrm{ST}(0)$
FCHS = Change Sign of ST(0)

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

## Transcendental

FPTAN = Partial Tangent of ST(0)
FPATAN $=$ Partial Arctangent of
$S T(0) \div S T(1)$
F2XM1 $=2^{S T(0)}-1$
FYL2X $=\mathrm{ST}(1) \cdot \log _{2}[\mathrm{ST}(0)]$
$\mathbf{F Y L 2 X P 1}=\mathrm{ST}(1) \cdot \log _{2}[\mathrm{ST}(0)+1]$

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

## Constants

FLDZ $=$ LOAD +0.0 into $S T(0)$
FLD1 = LOAD + 1.0 into $S T(0)$
FLDPI $=$ LOAD $\pi$ into $S T(0)$
FLDL2T $=$ LOAD $\log _{2} 10$ into $S T(0)$
FLDL2E $=$ LOAD $\log _{2}$ e into $S T(0)$
FLDLG2 $=$ LOAD $\log _{10} 2$ into $S T(0)$ FLDLN2 $=$ LOAD $\log e 2$ into $S T(0)$

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

Table 5. $\mathbf{8 0 8 7}$ Extensions to the 8086/8088 Instruction Set (Continued)


## FOOTNOTES:

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 $\bmod =11$ then $\mathrm{r} / \mathrm{m}$ is treated as an $\mathrm{ST}(\mathrm{i})$ field

$$
\begin{aligned}
& \text { if } \mathrm{r} / \mathrm{m}=000 \text { then } E A=(B X)+(S I)+D I S P \\
& \text { if } \mathrm{r} / \mathrm{m}=001 \text { then } E A=(B X)+(D I)+D I S P \\
& \text { if } \mathrm{r} / \mathrm{m}=010 \text { then } E A=(B P)+(S I)+D I S P \\
& \text { if } \mathrm{r} / \mathrm{m}=011 \text { then } E A=(B P)+(D I)+D I S P \\
& \text { if } \mathrm{r} / \mathrm{m}=100 \text { then } E A=(S I)+D I S P \\
& \text { if } \mathrm{r} / \mathrm{m}=101 \text { then } E A=(D I)+D I S P \\
& \text { if } \mathrm{r} / \mathrm{m}=110 \text { then } E A=(B P)+D I S P^{\star} \\
& \text { if } \mathrm{r} / \mathrm{m}=111 \text { then } E A=(B X)+D I S P
\end{aligned}
$$

*except if $\bmod =000$ and $r / m=110$ then $E A=$ disp-high: disp-low.

## MF = Memory Format

00 - 32-bit Real
01 - 32-bit Integer
10-64-bit Real
11-16-bit Integer

ST(0) = Current stack top
$S T(i)=i^{\text {th }}$ register below stack top
$d=\quad$ Destination
0 - Destination is ST(0)
1 - Destination is $S T(i)$
$P=\quad P o p$
0 - No pop
1 - Pop ST(0)
$R=\quad$ Reverse: When $d=1$ reverse the sense of $R$.
0 - Destination (op) Source
1 - Source (op) Destination

For FSQRT: $\quad-0 \leq \mathrm{ST}(0) \leq+\infty$
For FSCALE: $\quad-2^{15} \leq S T(1)<+2^{15}$ and $\mathrm{ST}(1)$ integer

For F2XM1:
For FYL2X:

$$
0<S T(0)<\infty
$$

For FYL2XP1:
For FPTAN:

$$
0 \leq \mathrm{ST}(0) \leq 2^{-1}
$$

$$
\begin{aligned}
& -\infty<\operatorname{ST}(1)<+\infty \\
& 0 \leq|S T(0)|<(2-\sqrt{2}) / 2
\end{aligned}
$$

$$
-\infty<\mathrm{ST}(1)<\infty
$$

For FPATAN:
For FPATAN: $\quad 0 \leq S T(0)<\pi / 4$

$$
0 \leq \mathrm{ST}(0)<\mathrm{ST}(1)<+\infty
$$

# iAPX 86/30 <br> iAPX 88/30 <br> OPERATING SYSTEM PROCESSORS 

- High-Performance 2-Chip Data Processors Containing Operating System Primitives
- Standard iAPX 86/10, 88/10 Instruction Set Plus Task Management, Interrupt Management, Message Passing, Synchronization and Memory Allocation Primitives
- Fully Extendable To and Compatible With iRMX 86
- Supports Five Operating System Data Types: Jobs, Tasks, Segments, Mailboxes, Regions
- 35 Operating System Primitives
- Built-In Operating System Timers and Interrupt Control Logic Expandable From 8 to 57 Interrupts
- 8086/8087/8088 Compatible At Up To 8 MHz Without Wait States
- MULTIBUS System Compatible Interface

The Intel iAPX 86/30 and iAPX 88/30 are two-chip microprocessors offering general-purpose CPU (8086) instructions combined with real-time operating system support. They provide a foundation for multiprogramming and multitasking applications. The iAPX 86/30 consists of an iAPX 86/10 (16-bit 8086 CPU) and an Operating System Firmware (OSF) component (80130). The 88/30 consists of the OSF and an iAPX 88/10 (8-bit 8088 CPU).

Both components of the $86 / 30$ and $88 / 30$ are implemented in N -channel, depletion-load, silicon-gate technology (HMOS), and are housed in 40-pin packages. The $86 / 30$ and $88 / 30$ provide all the functions of the iAPX $86 / 10$, $88 / 10$ processors plus 35 operating system primitives, hardware support for eight interrupts, a system timer, a delay timer and a baud rate generator.


Figure 1. iAPX 86/30, 88/30 Block Diagram

[^23]

Figure 2. iAPX 86/30, 88/30 Pin Configuration

Table 1. 80130 Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $A D_{15}-A D_{0}$ | I/O | Address Data: These pins constitute the time multiplexed memory address ( $\mathrm{T}_{1}$ ) and data ( $T_{2}, T_{3}, T_{W}, T_{4}$ ) bus. These lines are active HIGH. The address presented during $T_{1}$ of a bus cycle will be latched internally and interpreted as an 80130 internal address if MEMCS or IOCS is active for the invoked primitives. The 80130 pins float whenever it is not chip selected, and drive these pins only during $T_{2}-T_{4}$ of a read cycle and $T_{1}$ of an INTA cycle. |
| $\overline{\mathrm{BHE}} / \mathrm{S}_{7}$ |  | Bus High Enable: The 80130 uses the $\overline{\mathrm{BHE}}$ signal from the processor to determine whether to respond with data on the upper or lower data pins, or both. The signal is active LOW. $\overline{B H E}$ is latched by the 80130 on the trailing edge of ALE. It controls the 80130 output data as shown. |
| $\overline{\mathbf{s}_{2}}, \overline{\mathbf{s}_{1}}, \overline{\mathbf{s}_{0}}$ | 1 | Status: For the 80130, the status pins are used as inputs only. 80130 encoding follows: |

Table 1. 80130 Pin Description (Continued)

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| CLK | 1 | Clock: The system clock provides the basic timing for the processor and bus controller. It is asymmetric with a $33 \%$ duty cycle to provide optimized internal timing. The 80130 uses the system clock as an input to the SYSTICK and BAUD timers and to synchronize operation with the host CPU. |
| INT | 0 | Interrupt: INT is HIGH whenever a valid interrupt request is asserted. It is normally used to interrupt the CPU by connecting it to INTR. |
| $\mathrm{IR}_{7}-\mathrm{IR}_{0}$ | 1 | Interrupt Requests: An interrupt request can be generated by raising an IR input (LOW to HIGH) and holding it HIGH until it is acknowledged (Edge-Triggered Mode), or just by a HIGH level on an IR input (Level-Triggered Mode). |
| $\overline{\text { ACK }}$ | 0 | Acknowledge: This line is LOW whenever an 80130 resource is being accessed. It is also LOW during the first INTA cycle and second INTA cycle if the 80130 is supplying the interrupt vector information. This signal can be used as a bus ready acknowledgement and/or bus transceiver control. |
| $\overline{\text { MEMCS }}$ | 1 | Memory Chip Select: This input must be driven LOW when a kernel primitive is being fetched by the CPU. $A D_{13}-A D_{0}$ are used to select the instruction. |
| $\overline{\text { OCS }}$ | 1 | Input/Output Chip Select: When this input is low, during an IORD or IOWR cycle, the 80130's kernel primitives are accessing the appropriate peripheral function as specified by the following table: |
| $\overline{\text { LIR }}$ | 0 | Local Bus Interrupt Request: This signal is LOW when the interrupt request is for a non-slave input or slave input programmed as being a local slave. |
| $\mathrm{V}_{\mathrm{CC}}$ |  | Power: $\mathrm{V}_{\text {CC }}$ is the +5 V supply pin. |
| $\mathrm{V}_{\text {SS }}$ |  | Ground: $\mathrm{V}_{\text {SS }}$ is the ground pin. |
| SYSTICK | 0 | System Clock Tick: Timer 0 Output. Operating System Clock Reference. SYSTICK is normally wired to IR2 to implement operating system timing interrupt. |
| DELAY | 0 | DELAY Timer: Output of timer 1. Reserved by Intel Corporation for future use. |
| BAUD | 0 | Baud Rate Generator: 8254 Mode 3 compatible output. Output of 80130 Timer 2. |

## FUNCTIONAL DESCRIPTION

The increased performance and memory space of iAPX 86/10 and 88/10 microprocessors have proven sufficient to handle most of today's single-task or single-device control applications with performance to spare, and have led to the increased use of these microprocessors to control multiple tasks or devices in real-time. This trend has created a new challenge to designers-development of real-time, multitasking application systems and software. Examples of such systems include control systems that monitor and react to external events in real-time, multifunction desktop and personal computers, PABX equip-
ment which constantly controls the telephone traffic in a multiphone office, file servers/disk subsystems controlling and coordinating multiple disks and multiple disk users, and transaction processing systems such as electronics funds transfer.

## The iAPX 86/30, 88/30 Operating System Processors

The Intel ${ }^{\circledR}$ iAPX 86/30, 88/30 Operating System Processors (OSPs) were developed to help solve this


Figure 3. OSF Internal Block Diagram
problem. Their goal is to simplify the design of multitasking application systems by providing a welldefined, fully debugged set of operating system primitives implemented directly in the hardware, thereby removing the burden of designing multitasking operating system primitives from the application programmer.

Both the $86 / 30$ and the $88 / 30$ OSPs are two-chip sets consisting of a main processor, an 8086 or 8088 CPU, and the Intel 80130, Operating System Firmware component (OSF) (see Figure 1). The 80130 provides a set of multitasking kernel primitives, kernel control storage, and the additional support hardware, including system timers and interrupt control, required by these primitives. From the application programmer's viewpoint, the OSF extends the base iAPX 86, 88 architecture by providing 35 operating system primitive instructions, and supporting five new system data types, making the OSF a logical and
easy-to-use architectural extension to iAPX 86, 88 system designs.

## The OSP Approach

The OSP system data types (SDTs) and primitive instructions allocate, manage and share low-level processor resources in an efficient manner. For example, the OSP implements task context management (managing a task state image consisting of both hardware register set and software control information) for either the basic 86/10 context or the extended $86 / 20(8086+8087)$ numerics context. The OSP manages the entire task state image both while the task is actively executing and while it is inactive. Tasks can be created, put to sleep for specified periods, suspended, executed to perform their functions, and dynamically deleted when their functions are complete.

The Operating System Processors support eventoriented systems designs. Each event may be processed by an individual responding task or along with other closely related events in a common task. External events and interrupts are processed by the OSP interrupt handler primitives using its built-in interrupt controller subsystem as they occur in realtime. The multiple tasks and the multiple events are coordinated by the OSP integral scheduler whose preemptive, priority-based scheduling algorithm and system timers organize and monitor the processing of every task to guarantee that events are processed as they occur in order of relative importance. The 86/30 also provides primitives for intertask communication (by mailboxes) and for mutual exclusion (by regions), essential functions for multitasking applications.

## Programming Language Support

Programs for the OSP can be written in ASM 86/88 or PL/M 86/88, Intel's standard system languages for iAPX 86,88 systems.

The Operating System Processor Support Package (iOSP 86) provides an interface library for application programs written in any model of $\mathrm{PL} / \mathrm{M}-86$. This library also provides 80130 configuration and initialization support as well as complete user documentation.

## OSF PROGRAMMING INTERFACE

The OSF provides 35 operating system kernel primitives which implement multitasking, interrupt management, free memory management, intertask communication and synchronization. Table 4 shows each primitive, and Table 5 gives the execution performance of typical primitives.

OSP primitives are executed by a combination of CPU and OSF (80130) activity. When an OSP primitive is called by an application program task, the iAPX CPU registers and stacks are used to perform the appropriate functions and relay the results to the application programs.

## OSP Primitive Calling Sequences

A standard, stack-based, calling sequence is used to invoke the OSF primitives. Before a primitive is called, its operand parameters must be pushed on the task stack. The SI register is loaded with the offset of the last parameter on the stack. The entry code for the primitive is loaded into AX. The primitive invocation call is made with a CPU software interrupt
(Table 4). A representative ASM86 sequence for calling a primitive is shown in Figure 4. In PL/M the OSP programmer uses a call to invoke the primitive.

| SAMPLE ASSEMBLY LANGUAGE PRIMITIVE CALL |  |
| :---: | :---: |
| PUSH $\mathrm{P}_{1}$ PUSH $\mathrm{P}_{2}$ | ;PUSH PARAMETER 1 ;PUSH PARAMETER 2 |
|  |  |
|  |  |
| PUSH $\mathrm{P}_{\mathrm{N}}$ | ;PUSH PARAMETER N |
| PUSH BP | ;STACK CALLING CONVENTION |
| LEA SI,SS:NUM BYTES PARAM - 2[BP] |  |
|  | ;SS:SI POINTS TO FIRST ;PARAMETER ON STACK |
| MOVAX, ENTRY CODE INT 184 | ;AX SETS PRIMITIVE ENTRY CODE ;OSF INTERRUPT |
| OSP PRIMITIVE INVOKED |  |
| POP BP |  |
| RET NUM BYTES PARAMS | ;POP PARAMETERS <br> ;CX CONTAINS EXCEPTION CODES <br> ;DL CONTAINS PARAMETER NUMBER THAT CAUSED EXCEPTION (IF CX IS NON ZERO) <br> ;AX CONTAINS WORD RETURN VALUE ;ES:BX CONTAINS POINTER return value |

Figure 4. ASM/86 OSP Calling Convention

## OSP Functional Description

Each major function of the OSP is described below. These are:

Job and Task Management Interrupt Management Free Memory Management Intertask Communication Intertask Synchronization Environmental Control

The system data Types (or SDTs) supported by the OSP are capitalized in the description. A short description of each SDT appears in Table 2.

## JOB and TASK Management

Each OSP JOB is a controlled environment in which the applications program executes and the OSF system data types reside. Each individual application program is normally a separate OSP JOB, whether it has one initial task (the minimum) or multiple tasks. JOBs partition the system memory into pools. Each memory pool provides the storage areas in which the OSP will allocate TASK state images and other system data types created by the executing TASKs, and free memory for TASK working space. The OSP supports multiple executing TASKs within a JOB by managing the resources used by each, including the CPU registers, NPX registers, stacks, the system data types, and the available free memory space pool.

When a TASK is created, the OSP allocates memory (from the free memory of its JOB environment) for the TASK's stack and data area and initializes the additional TASK attributes such as the TASK priority level and its error handler location. (As an option, the caller of CREATE TASK may assign previously defined stack and data areas to the TASK.) Task priorities are integers between 0 and 255 (the lower the priority number the higher the scheduling priority of the TASK). Generally, priorities up to 128 will be assigned to TASKs which are to process interrupts. Priorities above 128 do not cause interrupts to be disabled, these priorities ( 129 to 255 ) are appropriate for non-interrupt TASKs. If an 8087 Numerics Processor Extension is used, the error recovery interrupt level assigned to it will have a higher priority than a TASK executing on it, so that error handling is performed correctly.

## EXECUTION STATUS

A TASK has an execution status or execution state. The OSP provides five execution states: RUNNING, READY, ASLEEP, SUSPENDED, and ASLEEPSUSPENDED.

- A TASK is RUNNING if it has control of the processor.
- A TASK is READY if it is not asleep, suspended, or asleep-suspended. For a TASK to become the running (executing) TASK, it must be the highest priority TASK in the ready state.
- A TASK is ASLEEP if it is waiting for a request to be granted or a timer event to occur. A TASK may put itself into the ASLEEP state.
- A TASK is SUSPENDED if it is placed there by another TASK or if it suspends itself. A TASK may have multiple suspensions, the count of suspensions is managed by the OSP as the TASK suspension depth.
- A TASK is ASLEEP-SUSPENDED if it is both waiting and suspended.

TASK attributes, the CPU register values, and the 8087 register values (if the 8087 is configured into the application) are maintained by the OSP in the TASK state image. Each TASK will have a unique TASK state image.

## SCHEDULING

The OSP schedules the processor time among the various TASKs on the basis of priority. A TASK has an execution priority relative to all other TASKs in the system; which the OSP maintains for each TASK in its TASK state image. When a TASK of higher priority than the executing TASK becomes ready to execute,
the OSP switches the control of the processor to the higher priority TASK. First, the OSP saves the outgoing (lower priority) TASK's state including CPU register values in its TASK state image. Then, it restores the CPU registers from the TASK state image of the incoming (higher priority) TASK. Finally, it causes the CPU to start or resume executing the higher priority TASK.

TASK scheduling is performed by the OSP. The OSP's priority-oriented preemptive scheduler determines which TASK executes by comparing their relative priorities. The scheduler insures that the highest priority TASK with a status of READY will execute. A TASK will continue to execute until an interrupt with a higher priority occurs, or until it requests unavailable resources, for which it is willing to wait, or until it makes specific resources available to a higher priority TASK waiting for those resources.

TASKs can become READY by receiving a message, receiving control, receiving an interrupt, or by timing out. The OSP always monitors the status of all the TASKs (and interrupts) in the system. Preemptive scheduling allows the system to be responsive to the external environment while only devoting CPU resources to TASKs with work to be performed.

## TIMED WAIT

The OSP timer hardware facilities support timed waits and timeouts. Thus, in many primitives, a TASK can specify the length of time it is prepared to wait for an event to occur, for the desired resources to become available or for a message to be received at a MAILBOX. The timing interval (or System Tick) can be adjusted, with a lower limit of 1 millisecond.

## APPLICATION CONTROL OF TASK EXECUTION

Programs may alter TASK execution status and priority dynamicaily. One TASK may suspend its own execution or the execution of another TASK for a period of time, then resume its execution later. Multiple suspensions are provided. A suspended TASK may be suspended again.

The eight OSP Job and TASK management primitives are:
CREATE JOB Partitions system resources and creates a TASK execution environment.
CREATE TASK Creates a TASK state image. Specifies the location of the TASK code instruction stream, its execution priority, and the other TASK attributes.

| DELETE TASK | Deletes the TASK state image, <br> removes the instruction stream <br> from execution and deallocates <br> stack resources. Does not delete |
| :--- | :--- |
| INTERRUPT TASKS. |  |

## Interrupt Management

The OSP supports up to 256 interrupt levels organized in an interrupt vector, and up to 57 external interrupt sources of which one is the NMI (NonMaskable Interrupt). The OSP manages each interrupt level independently. The OSF INTERRUPT SUBSYSTEM provides two mechanisms for interrupt management: INTERRUPT HANDLERs and INTERRUPT TASKs. INTERRUPT HANDLERs disable all maskable interrupts and should be used only for servicing interrupts that require little processing time. Within an INTERRUPT HANDLER only certain OSF Interrupt Management primitives (DISABLE, ENTER INTERRUPT, EXIT INTERRUPT, GET LEVEL, SIGNAL INTERRUPT) and basic CPU instructions can be used, other OSP primitives cannot be. The INTERRUPT TASK approach permits all OSP primitives to be issued and masks only lower priority interrupts.

Work flow between an INTERRUPT HANDLER and an INTERRUPT TASK assigned to the same level is regulated with the SIGNAL INTERRUPT and WAIT INTERRUPT primitives. The flow is asynchronous. When an INTERRUPT HANDLER signals an INTERRUPT TASK, the INTERRUPT HANDLER becomes immediately available to process another interrupt. The number of interrupts (specified for the level) the

INTERRUPT HANDLER can queue for the INTERRUPT TASK can be limited to the value specified in the SET INTERRUPT primitive. When the INTERRUPT TASK is finished processing, it issues a WAIT INTERRUPT primitive, and is immediately ready to process the queue of interrupts that the INTERRUPT HANDLER has built with repeated SIGNAL INTERRUPT primitives while the INTERRUPT TASK was processing. If there were no interrupts at the level, the queue is empty and the INTERRUPT TASK is SUSPENDED. See the Example (Figure 5) and Figures 6 and 7 .

OSP external INTERRUPT LEVELs are directly related to internal TASK scheduling priorities. The OSP maintains a single list of priorities including both tasks and INTERRUPT LEVELs. The priority of the executing TASK automatically determines which interrupts are masked. Interrupts are managed by INTERRUPT LEVEL number. The OSP supports eight levels directly and may be extended by means of slave 8259As to a total of 57 .

The nine Interrupt Management OSP primitives are: DISABLE Disables an external INTERRUPT LEVEL.
ENABLE Enables an external INTERRUPT LEVEL.

ENTER INTERRUPT Gives an Interrupt Handler its own data segment, separate from the data segment of the interrupted task.
EXIT INTERRUPT Performs an "END of INTERRUPT" operation. Used by an INTERRUPT HANDLER which does not invoke an INTERRUPT TASK. Reenables interrupts, when the INTERRUPT HANDLER gives up control.
GET LEVEL

RESET INTERRUPT Cancels the previous assignment made to an interrupt level by SET INTERRUPT primitive request. If an INTERRUPT TASK has been assigned, it is also deleted. The interrupt level is disabled.
SET INTERRUPT Assigns an INTERRUPT HANDLER to an interrupt level and, optionally, an $\operatorname{IN}$ TERRUPT TASK.

```
/* CODE EXAMPLE A INTERRUPT TASK TO KEEP TRACK OF TIME-OF-DAY
DECLARE SECOND$COUNT BYTE,
    MINUTESCOUNT BYTE,
    HOURS$COUNT BYTE;
TIME$TASK: PROCEDURE;
    DECLARE TIME$EXCEPT$CODE WORD;
    AC$CYCLE$COUNT=0;
    CALL RQ$SET$INTERRUPT(ACSINTERRUPT$LEVEL, 01H),
        @AC$HANDLER,0,@TIME$EXCEPT$CODE);
    CALL RQ$RESUME$TASK(INIT$TASK$TOKEN,@TIME$EXCEPT$CODE);
    DO HOUR$COUNT=0 TO 23;
            DO MINUTE$COUNT=0 TO 59;
            DO SECOND$COUNT=0 TO 59;
                    CALL RQ$WAIT$INTERRUPT(AC$INTERRUPT$LEVEL,
                    @TIMESEXCEPT$CODE);
                    IF SECONDSCOUNT MOD 5=0
                    THEN CALL PROTECTED$CRT$OUT(BEL);
                    END; / /* SECOND LOOP */
                END; /* MINUTE LOOP */
            END; l* HOUR LOOP *
    CALL RQ$RESET$INTERRUPT(AC$INTERRUPT$LEVEL,@TIME$EXCEPT$CODE);
    END TIME$TASK;
/* CODE EXAMPLE B INTERRUPT HANDLER TO SUBDIVIDE A.C. SIGNAL BY 60. *
DECLARE AC$CYCLESCOUNT BYTE;
AC$HANDLER: PROCEDURE INTERRUPT 59;
    DECLARE AC$EXCEPT$CODE WORD;
    AC$CYCLE$COUNT = AC$CYCLE$COUNT +1;
    IF AC$CYCLESCOUNT > = 60 THEN DO;
            ACSCYCLESCOUNT=0;
            CALL RQSSIGNALSINTERRUPT(AC$INTERRUPT$LEVEL,@AC$EXCEPT$CODE);
            END;
    END AC$HANDLER;
```

Figure 5. OSP Examples


Figure 6. Interrupt Handling Flowchart


Figure 7. Multiple Buffer Example

SIGNAL INTERRUPT

WAIT INTERRUPT

Used by an INTERRUPT HANDLER to activate an Interrupt Task.
Suspends the calling Interrupt Task until the INTERRUPT HANDLER performs a SIGNAL INTERRUPT to invoke it. If a SIGNAL INTERRUPT for the task has occurred, it is processed.

## FREE MEMORY MANAGEMENT

The OSP Free Memory Manager manages the memory pool which is allocated to each JOB for its execution needs. (The CREATE JOB primitive allocates the new JOB's memory pool from the memory pool of the parent JOB.) The memory pool is part of the JOB resources but is not yet allocated between the tasks of the JOB. When a TASK, MAILBOX, or REGION system data type structure is created within that JOB, the OSP implicitly allocates memory for it from the JOB's memory pool, so that a separate call to allocate memory is not required. OSP primitives that use free memory management implicitly include CREATE JOB, CREATE TASK, DELETE TASK, CREATE MAILBOX, DELETE MAILBOX, CREATE REGION, and DELETE REGION. The

CREATE SEGMENT primitive explicitly allocates a memory area when one is needed by the TASK. For example, a TASK may explicitly allocate a SEGMENT for use as a memory buffer. The SEGMENT length can be any multiple of 16 bytes between 16 bytes and 64 K bytes in length. The programmer may specify any number of bytes from 1 byte to 64 KB , the OSP will transparently round the value up to the appropriate segment size.

The two explicit memory allocation/deallocation primitives are:
CREATE SEGMENT Allocates a SEGMENT of specified length (in 16-byte-long paragraphs) from the JOB Memory Pool.
DELETE SEGMENT
Deallocates the SEGMENT's memory area, and returns it to the JOB memory pool.

## Intertask Communication

The OSP has built-in intertask synchronization and communication, permitting TASKs to pass and share information with each other. OSP MAILBOXes contain controlled handshaking facilities which guarantee that a complete message will always be sent from a sending TASK to a receiving TASK. Each MAILBOX consists of two interlocked queues, one of TASKs
and the other of Messages. Four OSP primitives for intertask synchronization and communication are provided:
CREATE MAILBOX Creates intertask message exchange.
DELETE MAILBOX Deletes an intertask message exchange.
RECEIVE MESSAGE Calling TASK receives a message from the MAILBOX.
SEND MESSAGE Calling TASK sends a message to the MAILBOX.

The CREATE MAILBOX primitive allocates a MAILBOX for use as an information exchange between TASKs. The OSP will post information at the MAILBOX in a FIFO (First-In First-Out) manner when a SEND MESSAGE instruction is issued. Similarily, a message is retrieved by the OSP if a TASK issues a RECEIVE MESSAGE primitive. The TASK which creates the MAILBOX may make it available to other TASKs to use.

If no message is available, the TASK attempting to receive a message may choose to wait for one or continue executing.

The queue management method for the task queue (FIFO or PRIORITY) determines which TASK in the MAILBOX TASK queue will receive a message from the MAILBOX. The method is specified in the CREATE MAILBOX primitive.

## Intertask Synchronization and Mutual Exclusion

Mutual exclusion is essential to multiprogramming and multiprocessing systems. The REGION system data type implements mutual exclusion. A REGION is represented by a queue of TASKS waiting to use a resource which must be accessed by only one TASK at a time. The OSP provides primitives to use REGIONs to manage mutually exclusive data and resources. Both critical code sections and shared data structures can be protected by these primitives from simultaneous use by more than one task. REGIONs support both FIFO (First-In First-Out) or Priority queueing disciplines for the TASKS seeking to enter the REGION. The REGION SDT can also be used to implement software locks.

Multiple REGIONs are allowed, and are automatically exited in the reverse order of entry. While in a REGION, a TASK cannot be suspended by itself or any other TASK, and thereby avoids deadlock.

There are five OSP primitives for mutual exclusion:
CREATE REGION Create a REGION (lock).
SEND CONTROL Give up the REGION.
ACCEPT CONTROL Request the REGION, but do not wait if it is not available.
RECEIVE CONTROL Request a REGION, wait if not immediately available.
DELETE REGION Delete a REGION.
The OSP also provides dynamic priority adjustment for TASKs within priority REGIONs: If a higherpriority TASK issues a RECEIVE CONTROL primitive, while a (lower-priority) TASK has the use of the same REGION, the lower-priority TASK will be transparently, and temporarily, elevated to the waiting TASK's priority until it relinquishes the REGION via SEND CONTROL. At that point, since it is no longer using the critical resource, the TASK will have its normal priority restored.

## OSP Control Facilities

The OSP also includes system primitives that provide both control and customization capabilities to a multitasking system. These primitives are used to control the deletion of SDTs and the recovery of free memory in a system, to allow interrogation of operating system status, and to provide uniform means of adding user SDTs and type managers.

## DELETION CONTROL

Deletion of each OSP system data type is explicitly controlled by the applications programmer by setting a deletion attribute for that structure. For example, if a SEGMENT is to be kept in memory until DMA activity is completed, its deletion attribute should be disabled. Each TASK, MAILBOX, REGION, and SEGMENT SDT is created with its deletion attribute enabled (i.e., they may be deleted). Two OSP primitives control the deletion attribute: ENABLE DELETION and DISABLE DELETION.

## ENVIRONMENTAL CONTROL

The OSP provides inquiry and control operations which help the user interrogate the application environment and implement flexible exception handling. These features aid in run-time decision making and in application error processing and recovery. There are five OSP environmental control primitives.

## OS EXTENSIONS

The OSP architecture is defined to allow new userdefined System Data Types and the primitives to manipulate them to be added to OSP capabilities
provided by the built-in System Data Types. The type managers created for the user-defined SDTs are called user OS extensions and are installed in the system by the SET OS EXTENSION primitive. Once installed, the functions of the type manager may be invoked with user primitives conforming to the OSP interface. For well-structured extended architectures, each OS extension should support a separate user-defined system data type, and every OS extension should provide the same calling sequence and program interface for the user as is provided for a built-in SDT. The type manager for the extension would be written to suit the needs of the application. OSP interrupt vector entries (224-255) are reserved for user OS extensions and are not used by the OSP. After assigning an interrupt number to the extension, the extension user may then call it with the standard OSP call sequence (Figure 4), and the unique software interrupt number assigned to the extension.

ENABLE DELETION

DISABLE DELETION Prevents a specific SEGMENT, TASK, MAILBOX, or REGION SDT from being deleted.
GET TYPE

GET TASK TOKENS

GET EXCEPTION HANDLER

SET EXCEPTION HANDLER

SET OS EXTENSION
Modifies one of the interrupt vector entries reserved for OS extensions (224-255) to point to a user OS extension procedure.
SIGNAL EXCEPTION For use in OS extension error processing.

## EXCEPTION HANDLING

The OSP supports exception handlers. These are similar to CPU exception handlers such as OVERFLOW and ILLEGAL OPERATION. Their purpose is to
allow the OSP primitives to report parameter errors in primitive calls, and errors in primitive usage. Exception handling procedures are flexible and can be individually programmed by the application. In general, an exception handler if called will perform one or more of the following functions:
-Log the Error.
-Delete/Suspend the Task that caused the exception.
-Ignore the error, presumably because it is not serious.

An EXCEPTION HANDLER is written as a procedure. If PLM/86 is used, the "compact," "medium" or "large" model of computation should be specified for the compilation of the program. The mode in which the EXCEPTION HANDLER operates may be specified in the SET EXCEPTION HANDLER primitive. The return information from a primitive call is shown in Figure 4. CX is used to return standard system error conditions. Table 7 shows a list of these conditions, using the default EXCEPTION HANDLER of the OSP.

## HARDWARE DESCRIPTION

The 80130 operates in a closely coupled mode with the iAPX $86 / 10$ or $88 / 10 \mathrm{CPU}$. The 80130 resides on the CPU local multiplexed bus (Figure 8). The main processor is always configured for maximum mode operation. The 80130 automatically selects between its $88 / 30$ and $86 / 30$ operating modes.

The 80130 used in the 86/30 configuration, as shown in Figure 8 (or a similar 88/30 configuration), operates at both 5 and 8 MHz without requiring processor wait states. Wait state memories are fully supported, however. The 80130 may be configured with both an 8087 NDX and an 8089 IOP, and provides full context control over the 8087.

The 80130 (shown in Figure 3) is internally divided into a control unit (CU) and operating system unit (OSU). The OSU contains facilities for OSP kernel support including the system timers for scheduling and timing waits, and the interrupt controller for interrupt management support.

## iAPX 86/30, iAPX 88/30 System Configuration

The 80130 is both I/O and memory mapped to the local CPU bus. The CPU's status $\left(\mathrm{S}_{0}-\mathrm{S}_{2}\right)$ is decoded along with IOCS (with BHE and $\mathrm{A}_{3}-\mathrm{A}_{0}$ ) or MEMCS (with $A_{13}-A_{0}$ ). The pins are internally latched. See Table 1 for the decoding of these lines.

## Memory Mapping

Address lines $\mathrm{A}_{19}-\mathrm{A}_{14}$ can be used to form MEMCS/ since the 80130's memory-mapped portion is aligned along a 16 K -byte boundry. The 80130 can reside on any 16 K -byte boundry excluding the highest (FCOOOH-FFFFFH) and lowest ( $00000 \mathrm{H}-003 \mathrm{FFH}$ ). The 80130 control store code is position-independent except as limited above, in order to make it compatible with many decoding logic designs. $A_{13}-A_{0}$ are decoded by the 80130's kernel control store.

## I/O Mapping

The I/O-mapped portion of the 80130 must be aligned along a 16 -byte boundry. Address lines $\mathrm{A}_{15}-\mathrm{A}_{4}$ should be used to form IOCS/.

## System Performance

The approximate performance of representitive OSP primitives is given in Table 5. These times are shown for a typical IAPX 86/30 implementation with an 8 MHz clock. These execution times are very comparable to the execution times of similar functions in minicomputers (where available) and are an order of magnitude faster than previous generation microprocessors.

## Initialization

Both application system initialization and OSPspecific initialization/configuration are required to use the OSP. Configuration is based on a "database" provided by the user to the iOSP 86 support package. The OSP-specific initialization and configuration information area is assigned to a user memory address adjacent to the 80130's memory-mapped location. (See Application Note 130 for further details.) The configuration data defines whether 8087 support is configured in the system, specifies if slave 8259A interrupt controllers are used in addition to the 80130, and sets the operating system time base (Tick Interval). Also located in the configuration area are the exception handler control parameters, the address location of the (separate) application system configuration area and the OSP extensions in use. The OSP application system configuration area may be located anywhere in the user memory and must include the starting address of the application instruction code to be executed, plus the locations of the RAM memory blocks to be managed by the OSP free memory manager. Complete application system support and the required 80130 configuration support are provided by the iAPX 86/30 and iAPX 88/30 OPERATING SYSTEM PROCESSOR SUPPORT PACKAGE (OSP 86).

## RAM Requirements

The OSP manages its own interrupt vector, which is assigned to low RAM memory. Working RAM storage is required as stack space and data area. The memory space must be allocated in user RAM.

OSP interrupt vector memory locations OH-3FFH must be RAM based. The OSP requires 2 bytes of allocated RAM. The processor working storage is dynamically allocated from free memory. Approximately 300 bytes of stack should be allocated for each OSP task.

## TYPICAL SYSTEM CONFIGURATION

Figure 8 shows the processing cluster of a "typical" iAPX 86/30 or iAPX 88/30 OSP system. Not shown are subsystems likely to vary with the application. The configuration includes an 8086 (or 8088) operating in maximum mode, an 8284A clock generator and an 8288 system controller. Note that the 80130 is located on the CPU side of any latches or transceivers. See Intel Application Note 130 for further details on configuration.

## OSP Timers

The OSP Timers are connected to the lower half of the data bus and are addressed at even addresses. The timers are read as two successive bytes, always LSB followed by MSB. The MSB is always latched on a read operation and remains latched until read. Timers are not gatable.

## Baud Rate Generator

The baud rate generator is 8254 compatible (square wave mode 3). Its output, BAUD, is initially high and remains high until the Count Register is loaded. The first falling edge of the clock after the Count Register is loaded causes the transfer of the internal counter to the Count Register. The output stays high for N/2 $[(N+1) / 2$ if $N$ is odd] and then goes low for $N / 2$ [ $(\mathrm{N}-1) / 2$ if N is odd]. On the falling edge of the clock which signifies the final count for the output in low state, the output returns to high state and the Count Register is transferred to the internal counter. The whole process is then repeated. Baud Rates are shown in Table 6.

The baud rate generator is located at 0 CH (12), relative to the 16 -byte boundary in the I/O space in which the 80130 component is located ("OSF" in the following example), the timer control word is located at


Figure 8. Typical OSP Configuration
relative address, $0 \mathrm{EH}(14)$. Timers are addressed with IOCS $=0$. Timers 0 and 1 are assigned to the use by the OSP, and should not be altered by the user.

For most baud-rate generator applications, the command byte

## OB6H Read/Write Baud-Rate Delay Value

will be used. A typical sequence to set a baud rate of 9600 using a count value of 833 follows (see Table 6):

| MOV AX, 086 H | Prepare to Write Delay to <br> Timer 3. |
| :--- | :--- |
| OUT OSF +14, AX | Control Word. |
| MOV AX, 833 |  |
| OUT OSF+12,AL | LSB written first. |
| SCHG AL,AH |  |
| OUT OSF+12,AL | MSB written after. |

The 80130 timers are subset compatible with 8254 timers.

## Interrupt Controller

The Programmable Interrupt Controller (PIC), is also an integral unit of the 80130 . Its eight input pins handle eight vectored priority interrupts. One of these pins must be used for the SYSTICK time function in timing waits, using an external connection as shown. During the 80130 initialization and configuration sequence, each 80130 interrupt pin is individually programmed as either level or edge sensitive. External slave 8259A interrupt controllers can be used to expand the total number of OSP external interrupts to 57 .

In addition to standard PIC funtions, 80130 PIC unit has an LIR output signal, which when low indicates an interrupt acknowledge cycle. $\overline{\mathrm{LIR}}=0$ is provided to control the 8289 Bus Arbiter SYSB/RESB pin. This will avoid the need of requesting the system bus to acknowledge local bus non-slave interrupts. The user defines the interrupt system as part of the configuration.

## INTERRUPT SEQUENCE

The OSP interrupt sequence is as follows:

1. One or more of the interrupts is set by a low-tohigh transition on edge-sensitive IR inputs or by a high input on level-sensitive IR inputs.
2. The 80130 evaluates these requests, and sends an INT to the CPU, if appropriate.
3. The CPU acknowledges the INT and responds with an interrupt acknowledge cycle which is encoded in $\overline{\mathrm{S}_{2}}-\overline{\mathrm{S}}_{0}$.
4. Upon receiving the first interrupt acknowledge from the CPU, the highest-priority interrupt is set by the 80130 and the corresponding edge detect latch is reset. The 80130 does not drive the address/data bus during this bus cycle but does acknowledge the cycle by making $\overline{\mathrm{ACK}}=0$ and sending the LIR value for the IR input being acknowledged.
5. The CPU will then initiate a second interrupt acknowledge cycie. During this cycle, the 80130 will supply the cascade address of the interrupting input at $T_{1}$ on the bus and also release an 8-bit pointer onto the bus if appropriate, where it is read by the CPU. If the 80130 does supply the pointer, then ACK will be low for the cycle. This cycle also has the value $\overline{\text { LIR }}$ for the IR input being acknowledged.
6. This completes the interrupt cycle. The ISR bit remains set until an appropriate EXIT INTERRUPT primitive (EOI command) is called at the end of the Interrupt Handler.

## OSP APPLICATION EXAMPLE

Figure 5 shows an application of the OSP primitives to keep track of time of day in a simplified example. The system design uses a 60 Hz A.C. signal as a time base. The power supply provides a TTL-compatible
signal which drives one of 80130 edge-triggered interrupt request pins once each A.C. cycle. The Interrupt Handler responds to the interrupts, keeping track of one second's A.C. cycles. The Interrupt Task counts the seconds and after a day deletes itself. In typical systems it might perform a data logging operation once each day. The Interrupt Handler and Interrupt Task are written as separate modular programs.

The Interrupt Handler will actually service interrupt 59 when it occurs. It simply counts each interrupt, and at a count of 60 performs a SIGNAL INTERRUPT to notify the Interrupt Task that a second has elapsed. The Interrupt Handler (ACS HANDLER) was assigned to this level by the SET INTERRUPT primitive. After doing this, the Interrupt Task performed the Primitive RESUME TASK to resume the application task (INITS TASKS TOKEN).

The main body of the task is the counting loop. The Interrupt Task is signaled by the SIGNAL INTERRUPT primitive in the Interrupt Handler (at interrupt level ACS INTERRUPTS LEVEL). When the task is signalled by the Interrupt Handler it will execute the loop exactly one time, increasing the time count variables. Then it will execute the WAIT INTERRUPT primitive, and wait until awakened by the Interrupt Handler. Normally, the task will now wait some period of time for the next signal. However, since the interface between the Handler and the Task is asynchronous, the handler may have already queued the interrupt for servicing, the writer of the task does not have to worry about this possibility.

At the end of the day, the task will exit the loop and execute RESET INTERRUPT, which disables the interrupt level, and deletes the interrupt task. The OSP now reclaims the memory used by the Task and schedules another task. If an exception occurs, the coded value for the exception is available in TIMES EXCEPTS CODE after the execution of the primitive.

A typical PL/M-86 calling sequence is illustrated by the call to RESET INTERRUPT shown in Figure 5.

Table 2. OSP System Data Type Summary

| Job | Jobs are the means of organizing the program environment and resources. An application consists of one or more jobs. Each iAPX 86/30 system data type is contained in some job. Jobs are independent of each other, but they may share access to resources. Each job has one or more tasks, one of which is an initial task. Jobs are given pools of memory, and they may create subordinate offspring jobs, which may borrow memory from their parents. |
| :---: | :---: |
| Task | Tasks are the means by which computations are accomplished. A task is an instruction stream with its own execution stack and private data. Each task is part of a job and is restricted to the resources provided by its job. Tasks may perform general interrupt handling as well as other computational functions. Each task has a set of attributes, which is maintained for it by the iAPX 86/30, which characterize its status. These attributes are: <br> its containing job <br> its register context <br> its priority (0-255) <br> its execution state (asleep, suspended, ready, running, asleep/suspended). <br> its suspension depth <br> its user-selected exception handler <br> its optional 8087 extended task state |
| Segment | Segments are the units of memory allocation. A segment is a physically contiguous sequence of 16-byte, 8086 paragraph-length, units. Segments are created dynamically from the free memory space of a Job as one of its Tasks requests memory for its use. A segment is deleted when it is no longer needed. The iAPX 86/30 maintains and manages free memory in an orderly fashion, it obtains memory space from the pool assigned to the containing job of the requesting task and returns the space to the job memory pool (or the parent job pool) when it is no longer needed. It does not allocate memory to create a segment if sufficient free memory is not available to it, in that case it returns an error exception code. |
| Mailbox | Mailboxes are the means of intertask communication. Mailboxes are used by tasks to send and receive message segments. The iAPX $86 / 30$ creates and manages two queues for each mailbox. One of these queues contains message segments sent to the mailbox but not yet received by any task. The other mailbox queue consists of tasks that are waiting to receive messages. The iAPX 86/30 operation assures that waiting tasks receive messages as soon as messages are available. Thus at any moment one or possibly both of two mailbox queues will be empty. |
| Region | Regions are the means of serialization and mutual exclusion. Regions are familiar as "critical code regions." The iAPX 86/30 region data type consists of a queue of tasks. Each task waits to execute in mutually exclusive code or to access a shared data region, for example to update a file record. |
| Tokens | The OSP interface makes use of a 16-bit TOKEN data type to identify individual OSF data structures. Each of these (each instance) has' its own unique TOKEN. When a primitive is called, it is passed the TOKENs of the data structures on which it will operate. |

Table 3. System Data Type Codes and Attributes

| S.D.T. | Code | Attributes |
| :---: | :---: | :---: |
| Jobs | 1 | Tasks <br> Memory Pool <br> S.D.T. Directory |
| Tasks | 2 | Priority <br> Stack <br> Code <br> State <br> Exception Handler |
| Mailboxes | 3 | Queue of S.D.T.s <br> (generally segments) <br> Queue of Tasks <br> waiting for S.D.T.s |
| Region | 5 | Queue of Tasks <br> waiting for mutually <br> exclusive code or <br> data |
| Segments | 6 | Buffer <br> Length |

Table 4. OSP Primitives

| Class | OSP <br> Primitive | Interrupt Number | Entry Code in $A X$ | Parameters On Caller's Stack |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{J} \\ & \mathrm{O} \\ & \mathrm{~B} \end{aligned}$ | CREATE JOB | 184 | 0100H | *See 80130 User Manual |
| $\begin{aligned} & \mathrm{T} \\ & \mathrm{~A} \\ & \mathrm{~S} \\ & \mathrm{~K} \end{aligned}$ | CREATE TASK <br> DELETE TASK SUSPEND TASK RESUME TASK SET PRIORITY SLEEP | $\begin{aligned} & 184 \\ & \\ & 184 \\ & 184 \\ & 184 \\ & 184 \\ & 184 \end{aligned}$ | $\begin{aligned} & 0200 \mathrm{H} \\ & 0201 \mathrm{H} \\ & 0202 \mathrm{H} \\ & 0203 \mathrm{H} \\ & 0209 \mathrm{H} \\ & 0204 \mathrm{H} \end{aligned}$ | Priority, IP Ptr, Data Segment, Stack Seg, Stack Size Task Information, ExcptPtr <br> TASK, ExcptPtr <br> TASK, ExcptPtr <br> TASK, ExcptPtr <br> TASK, Priority, ExcptPtr <br> Time Limit, ExcptPtr |
| $\begin{aligned} & I \\ & N \\ & T \\ & \mathrm{E} \\ & \mathrm{R} \\ & \mathrm{R} \\ & \mathrm{U} \\ & \mathrm{P} \\ & \mathrm{~T} \end{aligned}$ | DISABLE <br> ENABLE <br> ENTER INTERRUPT <br> EXIT INTERRUPT <br> GET LEVEL <br> RESET INTERRUPT <br> SET INTERRUPT <br> SIGNAL INTERRUPT WAIT INTERRUPT | 190 <br> 184 <br> 184 <br> 186 <br> 188 <br> 184 <br> 184 <br> 185 <br> 187 | 0705H <br> 0704H <br> 0703H <br> NONE <br> 0702H <br> 0706H <br> 0701H <br> NONE <br> NONE | Level, ExcptPtr <br> Level \#, ExcptPtr <br> Level \#, ExcptPtr <br> Level \#,ExcptPtr <br> Level \#, ExcptPtr <br> Level \#, ExcptPtr <br> Level, Interrupt Task Flag Interrupt <br> Handler Ptr, Interrupt Handler DataSeg <br> ExcptPtr <br> Level, ExcptPtr <br> Level, ExcptPtr |
| $\begin{gathered} \mathrm{S} \\ \mathrm{E} \\ \mathrm{G} \\ \mathrm{M} \\ \mathrm{E} \\ \mathrm{~N} \\ \mathrm{~T} \end{gathered}$ | CREATE SEGMENT DELETE SEGMENT | $\begin{aligned} & 184 \\ & 184 \end{aligned}$ | $\begin{aligned} & 0600 \mathrm{H} \\ & 0603 \mathrm{H} \end{aligned}$ | Size, ExcptPtr <br> SEGMENT, ExceptPtr |

Table 4. OSP Primitives (Continued)

| Class | OSP <br> Primitive | Interrupt Number | Entry Code in $\mathbf{A X}$ | Parameters On Caller's Stack |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \mathrm{M} \\ \mathrm{~A} \\ \mathrm{I} \\ \mathrm{~L} \\ \mathrm{~B} \\ \mathrm{O} \\ \mathrm{X} \end{gathered}$ | CREATE MAILBOX DELETE MAILBOX RECEIVE MESSAGE <br> SEND MESSAGE | $\begin{aligned} & 184 \\ & 184 \\ & 184 \\ & \\ & 184 \end{aligned}$ | $\begin{aligned} & 0300 \mathrm{H} \\ & 0301 \mathrm{H} \\ & 0303 \mathrm{H} \\ & 0302 \mathrm{H} \end{aligned}$ | Mailbox flags, ExcptPtr <br> MAILBOX, ExcptPtr <br> MAILBOX, Time Limit ResponsePtr, <br> ExcptPtr <br> MAILBOX,Message Response, ExcptPtr |
| $\begin{gathered} \mathrm{R} \\ \mathrm{E} \\ \mathrm{G} \\ \mathrm{I} \\ \mathrm{O} \\ \mathrm{~N} \end{gathered}$ | ACCEPT CONTROL CREATE REGION DELETE REGION RECEIVE CONTROL SEND CONTROL | $\begin{aligned} & 184 \\ & 184 \\ & 184 \\ & 184 \\ & 184 \end{aligned}$ | $\begin{aligned} & 0504 \mathrm{H} \\ & 0500 \mathrm{H} \\ & 0501 \mathrm{H} \\ & 0503 \mathrm{H} \\ & 0502 \mathrm{H} \end{aligned}$ | REGION, ExcptPtr Region Flags, ExcptPtr REGION, ExcptPtr REGION, ExcptPtr ExcptPtr |
| $\begin{aligned} & \mathrm{E} \\ & \mathrm{~N} \\ & \mathrm{~V} \\ & \mathrm{I} \\ & \mathrm{R} \\ & \mathrm{O} \\ & \mathrm{~N} \\ & \mathrm{M} \\ & \mathrm{E} \\ & \mathrm{~N} \\ & \mathrm{~T} \\ & \mathrm{~A} \\ & \mathrm{~L} \end{aligned}$ | DISABLE DELETION <br> ENABLE DELETION <br> GET EXCEPTION <br> HANDLER <br> GET TYPE <br> GET TASK TOKENS <br> SET EXCEPTION <br> HANDLER <br> SET OS EXTENSION <br> SIGNAL <br> EXCEPTION | 184 <br> 184 <br> 184 <br> 184 <br> 184 <br> 184 <br> 184 <br> 184 | 0001 H 0002 H 0800 H 0800 H 0206 H 0801 H 0700 H 0802 H | TOKEN, ExcptPtr <br> TOKEN, ExcptPtr <br> Ptr,ExcptPtr TOKEN,ExcptPtr <br> Request, ExcptPtr <br> Ptr, ExcptPtr <br> Code,InstPtr, ExcptPtr <br> Exception Code, Parameter Number, <br> StackPtr,0,0, ExcptPtr |

NOTES:
All parameters are pushed onto the OSP stack. Each parameter is one word. See Figure 3 for Call Sequence.

| Explanation of the Symbols |  |
| :---: | :---: |
| JOB | OSP JOB SDT Token |
| TASK | OSP TASK SDT Token |
| REGION | OSP REGION SDT Token |
| mailibox | OSP MAILBOX SDT Token |
| SEGMENT | OSP SEGMENT SDT Token |
| TOKEN | Any SDT Token |
| Level | Interrupt Level Number |
| ExcptPtr | Pointer to Exception Code |
| Message | Message Token |
| Ptr | Pointer to Code,Stack etc. Address |
| Seg | Value Loaded into appropriate Segment Register |
|  | Value Parameter. |

Table 5. OSP Primitive Performance Examples

| Datatype Class | Primitive Execution Speed ${ }^{\star}$ <br> (microseconds) |  |
| :---: | :--- | ---: |
| JOB | CREATE JOB | 2950 |
| TASK | CREATE TASK (no preemption) | 1360 |
| SEGMENT | CREATE SEGMENT | 700 |
| MAILBOX | SEND MESSAGE (with task switch) | 475 |
|  | SEND MESSAGE (no task switch) | 265 |
|  | RECEIVE MESSAGE (task waiting) | 540 |
|  | RECEIVE MESSAGE (message waiting) | 260 |
| REGION | SEND CONTROL | 170 |
|  | RECEIVE CONTROL | 205 |

* 8 MHz iAPX 86/30 OSP Configuation.

Table 6. Baud Rate Values

| Baud Rate | $\mathbf{8} \mathbf{~ M H z}$ | $\mathbf{5} \mathbf{M H z}$ |
| :---: | :---: | :---: |
| 300 | 26667 | 16667 |
| 600 | 13333 | 8333 |
| 1200 | 6667 | 4166 |
| 2400 | 3333 | 2083 |
| 4800 | 1667 | 1042 |
| 9600 | 833 | 521 |

Table 7a. Mnemonic Codes for Unavoidable Exceptions

| E\$OK | Exception Code Value $=0$ <br> the operation was successful |
| :--- | :--- |
| E\$TIME | Exception Code Value $=1$ <br> the specified time limit expired before completion of the operations was possible |
| E\$MEM | Exception Code Value $=2$ <br> insufficient nucleus memory is available to satisfy the request |
| E\$BUSY | Exception Code Value $=3$ <br> specified region is currently busy |
| E\$LIMIT | Exception Code Value $=4$ <br> attempted violation of a job, semaphore, or system limit |
| E\$CONTEXT | Exception Code Value $=5$ <br> the primitive was called in an illegal context (e.g., call to enable for an already enabled <br> interrupt) |
| E\$EXIST | Exception Code Value $=6$ <br> a token argument does not currently refer to any object; note that the object could have <br> been deleted at any time by its owner |
| E\$STATE | Exception Code Value $=7$ <br> attempted illegal state transition by a task |
| E\$NOT\$CONFIGURED | Exception Code Value $=8$ <br> the primitive called is not configured in this system |
| E\$INTERRUPT\$SATURATION | Exception Code Value $=9$ <br> The interrupt task on the requested level has reached its user specified saturation point <br> for interrupt service requests. No further interrupts will be allowed on the level until the <br> interrupt task executes a WAIT\$INTERRUPT. (This error is only returned, in line, to <br> interrupt handlers.) |
| E\$INTERRUPT\$OVERFLOW | Exception Code Value $=10$ <br> The interrupt task on the requested level previously reached its saturation point and <br> caused an E\$INTERRUPT\$SATURATION condition. It subsequently executed an <br> ENABLE allowing further interrupts to come in and has received another SIG- <br> NAL\$INTERRUPTcall, bringing it over its specified saturation point for interrupt service <br> requests. (This error is only returned, in line, to interrupt handlers). |

Table 7b. Mnemonic Codes for Avoidable Exceptions

| E\$ZERO\$DIVIDE | Exception Code Value $=8000 \mathrm{H}$ <br> divide by zero interrupt occurred |
| :--- | :--- |
| E\$OVERFLOW | Exception Code Value $=8001 \mathrm{H}$ <br> overflow interrupt occurred |
| E\$TYPE | Exception Code Value $=800 \mathrm{H}$ <br> a token argument referred to an object tha was not of required type |
| E\$BOUNDS | Exception Code Value $=8003 \mathrm{H}$ <br> an offset argument is out of segment bounds |
| E\$PARAM | Exception Code Value $=8004 \mathrm{H}$ <br> a (non-token, non-offset) argument has an illegal value |
| E\$BAD\$CALL | Exception Code Value $=8005 \mathrm{H}$ <br> an entry code for which there is no corresponding primitive was passed |
| E\$ARRAY\$BOUNDS $=8006 \mathrm{H}$ | Hardware or Language has detected an array overflow <br> E\$NDP\$ERRORException Code Value $=8007 \mathrm{H}$ <br> an 8087 (Numeric data Processor) error has been detected; (the 8087 status information <br> is contained in a parameter to the exception handler) |

## ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature Under Bins ........ $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 | 1.0 V to +7 V |
| ower Dissipation | 1.0 Watts |

Storage Temperature
1.0
*NOTICE: 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 period may affect device reliability.
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5$ to 5.5 V )

| 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}}+.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 |  | 300 | mA | $\mathrm{~T}_{\mathrm{A}}=25 \mathrm{C}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current |  | 10 | $\mu \mathrm{~A}$ | $0=\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LR}}$ | IR Input Load Current |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
|  |  |  | -300 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=0$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current |  | 10 | $\mu \mathrm{~A}$ | $.45=\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{CLI}}$ | Clock Input Low |  | 0.6 | V |  |
| $\mathrm{~V}_{\mathrm{CHI}}$ | Clock Input High |  |  | V |  |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF |
| $\mathrm{C}_{\mathrm{IO}}$ | I/O Capacitance |  | 15 | pF |  |

A.C. CHARACTERISTICS $\left(T_{A}=0-70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=4.5-5.5\right.$ Volt, $\left.\mathrm{V}_{\mathrm{SS}}=\mathrm{Ground}\right)$

| Symbol | Parameter | Min. | Max. | Units | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $T_{\text {CLCL }}$ | CLK Cycle Period | 125 | - | ns | $\mathrm{C}_{\mathrm{L}}=20-200 \mathrm{pF}$ |
| $\mathrm{T}_{\text {CLCH }}$ | CLK Low Time | 57 | - | ns |  |
| $T_{\text {CHCL }}$ | CLK High Time | 44 | 2000 | ns |  |
| $T_{\text {SVCH }}$ | Status Active Setup Time | 65 | - | ns |  |
| $T_{\text {CHSV }}$ | Status Active Hold Time | 10 | - | ns |  |
| $T_{\text {SHCL }}$ | Status Inactive Setup Time | 55 | - | ns |  |
| $T_{\text {CLSH }}$ | Status Inactive Hold Time | 10 | - | ns |  |
| $T_{\text {ASCH }}$ | Address Valid Setup Time | 8 | - | ns |  |
| $T_{\text {CLAH }}$ | Address Hold Time | 10 | - | ns |  |
| $T_{\text {CSCL }}$ | Chip Select Setup Time | 20 | - | ns |  |
| $T_{\text {CHCS }}$ | Chip Select Hold Time | 0 | - | ns |  |
| $T_{\text {DSCL }}$ | Write Data Setup Time | 60 | - | ns |  |
| $T_{\text {CHDH }}$ | Write Data Hold Time | 10 | - | ns |  |
| $T_{\text {JLJH }}$ | IR Low Time | 100 | - | ns |  |
| $T_{\text {ACC }}$ | Read Data from Address | $3 T_{C L C L}-\mathrm{T}_{\mathrm{DVCL}}-\mathrm{T}_{\mathrm{CLCH}}-20$ | ns |  |  |
| $T_{\text {CLDV }}$ | Read Data Valid Delay | - | 100 | ns |  |
| $T_{\text {CLDH }}$ | Read Data Hold Time | 10 | - | ns |  |
| $T_{\text {CLDX }}$ | Read Data to Floating | 10 | - | ns |  |
| $T_{\text {CLCA }}$ | Cascade Address Delay Time | - | 50 | ns |  |
| $T_{\text {IACA }}$ | INTA Status to Cascade | - | 50 | ns |  |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | Min. | Max. | Units | Notes |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $T_{\text {CLCF }}$ | Cascade Address Hold Time | 10 | - | ns |  |
| $\mathrm{T}_{\text {CLVE }}$ | Acknowledge Delay Time | - | 100 | ns |  |
| $\mathrm{~T}_{\text {IAVE }}$ | INTA Status to Acknowledge | - | 80 | ns |  |
| $\mathrm{~T}_{\text {CHEH }}$ | Acknowledge Hold Time | 10 | - | ns |  |
| $\mathrm{T}_{\text {CSAK }}$ | Chip Select to ACK | - | 110 | ns |  |
| $\mathrm{~T}_{\text {SACK }}$ | Status to ACK | - | 140 | ns |  |
| $\mathrm{~T}_{\text {CHAK }}$ | Clock to ACK | - | 140 | ns |  |
| $T_{\text {CLOD }}$ | Timer Output Delay Time | - | 200 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $\mathrm{T}_{\text {CLOD1 }}$ | Timer1 Output Delay Time | - | $200+\mathrm{T}_{\mathrm{CLCL}}$ | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $\mathrm{T}_{\text {JHIH }}$ | INT Output Delay | - | $\mathrm{T}_{\mathrm{CLCL}}+100$ | ns |  |

## WAVEFORMS



WAVEFORMS
D.C.


## NOTES:

1. CASCADE ADDRESS PRESENTED ON AD8, AD9 AND AD10 CORRESPONDING TO CASO, CAS1 and CAS2 RESPECTIVELY. ALL OTHER AD1 LINES ARE ACTIVE AND HAVE UN KNOWN-VALUES.
2. POINTER VALUE IS ACTIVE ONLY IF POINTER IS GENERATED FROM THE 80130 AND NOT FROM EXTERNAL SLAVE UNIT.
. ACTIVE LOW ONLY WHEN POINTER DATA IS BEING SUPPLIED BY THE 80130.
3. LOW ONLY FOR LOCAL INTERRUPT

- Address Latch for iAPX 86, 88, MCS-80 ${ }^{\oplus}$, MCS-85 ${ }^{\circledR}$, MCS-48® ${ }^{\text {® }}$ Families
- High Output Drive Capability for Driving System Data Bus


## - Fully Parallel 8-Bit Data Register and Buffer

- Transparent during Active Strobe
- 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.


Figure 1. Logic Diagrams

Table 1. Pin Description

| Pin | Description |
| :---: | :---: |
| STB | STROBE (Input). STB is an input control pulse used to strobe data at the data input pins ( $A_{0}-A_{7}$ ) into the data latches. This signal is active HIGH to admit input data. The data is latched at the HIGH to LOW transition of STB. |
| $\overline{O E}$ | OUTPUT ENABLE (Input). $\overline{O E}$ is an input control signal which when active LOW enables the contents of the data latches onto the data output pin ( $\mathrm{B}_{0}-\mathrm{B}_{7}$ ). OE being inactive HIGH forces the output buffers to their high impedance state. |
| $\mathrm{DI}_{0}-\mathrm{DI}_{7}$ | DATA INPUT PINS (Input). Data presented at these pins satisfying setup time requirements when STB is strobed and latched into the data input latches. |
| $\left\lvert\, \begin{aligned} & \mathrm{DO}_{0}-\mathrm{DO}_{7} \\ & (8282) \\ & \mathrm{DO}_{0}-\mathrm{DO}_{7} \\ & (8283) \end{aligned}\right.$ | DATA OUTPUT PINS (Output). When $\overline{O E}$ is true, the data in the data latches is presented as inverted (8283) or non-inverted (8282) data onto the data output pins. |

## FUNCTIONAL 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{\mathrm{OE}}$ 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.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias
. . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature
e. ........ $-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


#### Abstract

*NOTICE: 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 $\quad\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{C}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 160 | mA |  |
| $I_{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 |  | . 45 | $V$ | $\mathrm{l}_{\mathrm{OL}}=32 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{IOH}=-5 \mathrm{~mA}$ |
| loff | Output Off Current |  | $\pm 50$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OFF }}=0.45$ to 5.25 V |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V | $\mathrm{V}_{\text {CC }}=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}$ |

NOTE:

1. Output Loading $\mathrm{l}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF} .^{*}$
A.C. CHARACTERISTICS
$\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$
Loading: Outputs- $\mathrm{l}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{l}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}^{*}$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TIVOV | Input to Output Delay -Inverting <br> -Non-Inverting | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | $\begin{aligned} & 22 \\ & 30 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | (See Note 1) |
| TSHOV | STB to Output Delay - Inverting <br> -Non-Inverting | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | $\begin{aligned} & 40 \\ & 45 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| TEHOZ | Output Disable Time | 5 | 18 | ns |  |
| TELOV | Output Enable Time | 10 | 30 | ns |  |
| TIVSL | Input to STB Setup Time | 0 |  | ns |  |
| TSLIX | Input to STB Hold Time | 25 |  | ns |  |
| TSHSL | STB High Time | 15 |  | ns |  |
| TILIH, TOLOH | Input, Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL, TOHOL | Input, Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTE:

${ }^{*} \mathrm{C}_{\mathrm{L}}=200 \mathrm{pF}$ for plastic 8282/8283.

[^24]
## A.C. TESTING INPUT, OUTPUT WAVEFORM

> INPUT/OUTPUT

A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "1" AND 0.45V FOR A LOGIC " 0 ." TIMING MEASUREMENTS ARE MADE AT 1.5 V FOR BOTH A LOGIC "1" AND "0.

## OUTPUT TEST LOAD CIRCUITS


*200 pF for plastic 8282/8283.

## WAVEFORMS



NOTE: 1. OUTPUT MAY BE MOMENTARILY INVALID FOLLOWING THE HIGH GOING STB TRANSITION.
2. ALL TIMING MEASUREMENTS ARE MADE AT 1.5V UNLESS OTHERWISE NOTED.


## 8284A/8284A-1 <br> CLOCK GENERATOR AND DRIVER FOR iAPX 86, 88 PROCESSORS

■ Generates the System Clock for the iAPX 86, 88 Processors:
$5 \mathrm{MHz}, 8 \mathrm{MHz}$ with 8284A
10 MHz with 8284A-1

- Uses a Crystal or a TTL Signal for Frequency Source
- Provides Local READY and Multibus ${ }^{\text {TM }}$ READY Synchronization
- 18-Pin Package
- Single +5V Power Supply
- Generates System Reset Output from Schmitt Trigger Input
- Capable of Clock Synchronization with Other 8284As


Figure 2. 8284A/8284A-1 Pin Configuration
Figure 1. 8284A/8284A-1 Block Diagram

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\overline{\overline{\mathrm{AEN} 1}} \overline{\mathrm{AEN} 2}$ | 1 | Address Enable: $\overline{\text { AEN }}$ is an active LOW signal. AEN serves to qualify its respective Bus Ready Signal (RDY1 or RDY2). $\overline{A E N 1}$ validates RDY1 while $\overline{\text { AEN2 }}$ validates RDY2. Two AEN signal inputs are useful in system configurations which permit the processor to access two Multi-Master System Busses. In non Multi-Master configurations the $\overline{\text { AEN }}$ signal inputs are tied true (LOW). |
| RDY1, <br> RDY2 | 1 | Bus Ready: (Transfer Complete). RDY is an active HIGH signal which is an indication from a device located on the system data bus that data has been received, or is available. RDY1 is qualified by $\overline{A E N 1}$ while RDY2 is qualified by AEN2. |
| $\overline{\text { ASYNC }}$ | 1 | Ready Synchronization Select: $\overline{\text { ASYNC }}$ is an input which defines the synchronization mode of the READY logic. When ASYNC is low, two stages of READY synchronization are provided. When $\overline{A S Y N C}$ is left open (internal pull-up resistor is provided) or HIGH a single stage of READY synchronization is provided. |
| READY | 0 | Ready: READY is an active HIGH signal which is the synchronized RDY signal input. READY is cleared after the guaranteed hold time to the processor has been met. |
| X1, X2 | 1 | Crystal In: X1 and X2 are the pins to which a crystal is attached. The crystal frequency is 3 times the desired processor clock frequency. |
| F/C] | 1 | Frequency/Crystal Select: F/C is a strapping option. When strapped LOW, F/C्C permits the processor's clock to be generated by the crystal. When F/C̄ is strapped HIGH, CLK is generated from the EFI input. |
| EFI | 1 | External Frequency: When $F / \overline{\mathrm{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. |

## FUNCTIONAL DESCRIPTION

## General

The 8284A is a single chip clock generator/driver for the iAPX 86, 88 processors. The chip contains a crystalcontrolled oscillator, a divide-by-three counter, complete MULTIBUSTM "Ready" synchronization and reset logic. Refer to Figure 1 for Block Diagram and Figure 2 for Pin Configuration.

## Oscillator

The oscillator circuit of the 8284A is designed primarily for use with an external series resonant, fundamental mode, crystal from which the basic operating frequency is derived.

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| CLK | O | Processor Clock: CLK is the clock output <br> used by the processor and all devices which <br> directly connect to the processor's local bus <br> (i.e., the bipolar support chips and other MOS <br> devices). CLK has an output frequency which <br> is $1 / 3$ of the crystal or EFI input frequency and a <br> 1/3 duty cycle. An output HIGH of 4.5 volts <br> (Vcc=5V) is provided on this pin to driveMOS <br> devices. |
| PCLK | O | Peripheral Clock: PCLK is a TTL level pe- <br> ripheral clock signal whose output frequency <br> is $1 / 2$ that of CLK and has a 50\% duty cycle. |
| OSC | O | Oscillator Output: OSC is the TTL level out- <br> put of the internal oscillator circuitry. Its fre- <br> quency is equal to that of the crystal. |
| RES | I | Reset In: $\overline{\text { RES is an active LOW signal which }}$ <br> is used to generate RESET. The 8284A <br> provides a Schmitt trigger input so that an RC <br> connection can be used to establish the <br> power-up reset of proper duration. |
| RESET | 0 | Reset: RESET is an active HIGH signal which <br> is used to reset the 8086 family processors. Its <br> timing characteristics are determined by |
| RES. |  |  |

The crystal frequency should be selected at three times the required CPU clock. X1 and X2 are the two crystal input crystal connections. For the most stable operation of the oscillator (OSC) output circuit, two series resistors ( $\mathrm{R}_{1}=\mathrm{R}_{2}=510 \Omega$ ) as shown in the waveform figures are recommended. 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.

For systems which have a $\mathrm{V}_{\mathrm{CC}}$ ramp time $\geqslant 1 \mathrm{~V} / \mathrm{ms}$ and/or have inherent board capacitance between X1 or X2, exceeding 10 pF (not including 8284A pin capacitance), the two $510 \Omega$ resistors should be used. This circuit provides optimum stability for the oscillator in such extreme conditions. It is advisable to limit stray capacitances to less than 10 pF on X1 and X2 to minimize deviation from operating at the fundamental frequency.

## 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 8284A clock). It is necessary to synchronize the CSYNC input to the EFI clock external to the 8284A. This is accomplished with two Schottky flipflops. The counter output is a $33 \%$ duty cycle clock at one-third the input frequency.
The F/ $\bar{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.

## Clock Outputs

The CLK output is a $33 \%$ duty cycle MOS clock driver designed to drive the iAPX 86, 88 processors 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 8284A.

## READY Synchronization

Two READY inputs (RDY1, RDY2) are provided to accommodate two Multi-Master system busses. Each input has a qualifier ( $\overline{\mathrm{AEN}} 1$ and $\overline{\mathrm{AEN}}$, respectively). The $\overline{\mathrm{AEN}}$ signals validate their respective RDY signals. If a Multi-

Master system is not being used the $\overline{\text { AEN }}$ pin should be tied LOW.

Synchronization is required for all asynchronous activegoing edges of either RDY input to guarantee that the RDY setup and hold times are met. Inactive-going edges of RDY in normally ready systems do not require synchronization but must satisfy RDY setup and hold as a matter of proper system design.

The $\overline{\text { ASYNC }}$ input defines two modes of READY synchronization operation.

When $\overline{\text { ASYNC }}$ is LOW, two stages of synchronization are provided for active READY input signals. Positivegoing asynchronous READY inputs will first be synchronized to flip-flop one at the rising edge of CLK and then synchronized to flip-flop two at the next falling edge of CLK, after which time the READY output will go active (HIGH). Negative-going asynchronous READY inputs will be syrichronized directly to flip-flop two at the falling edge of CLK, after which time the READY output will go inactive. This mode of operation is intended for use by asynchronous (normally not ready) devices in the system which cannot be guaranteed by design to meet the required RDY setup timing, $\mathrm{T}_{\text {R1VCL }}$, on each bus cycle.

When $\overline{A S Y N C}$ is high or left open, the first READY flipflop is bypassed in the READY synchronization logic. READY inputs are synchronized by flip-flop two on the falling edge of CLK before they are presented to the processor. This mode is available for synchronous devices that can be guaranteed to meet the required RDY setup time.
$\overline{\text { ASYNC }}$ can be changed on every bus cycle to select the appropriate mode of synchronization for each device in the system.


Figure 3. CSYNC Synchronization


## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to + 150 C
All Input Voltages . . . . . . . . . . . . . . . . . . . . -1.0 V to +5.5 V
Power Dissipation
1 Watt
*NOTICE: 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}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current (ASYNC) Other Inputs |  | $\begin{aligned} & -1.3 \\ & -0.5 \end{aligned}$ | $\begin{gathered} \mathrm{mA} \\ \mathrm{~mA} \end{gathered}$ | $\begin{aligned} & V_{F}=0.45 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
| $I_{R}$ | Reverse Input Current ( $\overline{\text { ASYNC }}$ ) Other Inputs |  | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathbf{A}$ | $\begin{aligned} & V_{R}=V_{C C} \\ & V_{R}=5.25 V \end{aligned}$ |
| $\mathrm{V}_{\mathrm{c}}$ | Input Forward Clamp Voltage |  | -1.0 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 162 | mA |  |
| $V_{\text {IL }}$ | Input LOW Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 |  | V |  |
| $\mathrm{V}_{1 \mathrm{H}_{\mathrm{R}}}$ | Reset Input HIGH Voltage | 2.6 |  | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage |  | 0.45 | V | 5 mA |
| V OH | Output HIGH Voltage CLK Other Outputs | $\begin{gathered} 4 \\ 2.4 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & -1 \mathrm{~mA} \\ & -1 \mathrm{~mA} \\ & \hline \end{aligned}$ |
| $\mathrm{V}_{\text {IHR }}-\mathrm{V}_{\text {ILR }}$ | $\overline{\mathrm{RES}}$ Input Hysteresis | 0.25 |  | 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 10 \%$ )

TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {EHEL }}$ | External Frequency HIGH Time | 13 |  | ns | 90\% -90\% V $\mathrm{V}_{\mathrm{IN}}$ |
| $\mathrm{t}_{\text {ELEH }}$ | External Frequency LOW Time | 13 |  | ns | 10\%-10\% VIN |
| $\mathrm{t}_{\text {ELEL }}$ | EFI Period | 33 |  | ns | (Note 1) |
|  | XTAL Frequency | 12 | 25 | MHz |  |
| $\mathrm{t}_{\text {R1VCL }}$ | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=\mathrm{HIGH}$ |
| $\mathrm{t}_{\text {RIVCH }}$ | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=$ LOW |
| $\mathrm{t}_{\text {R1VCL }}$ | RDY1, RDY2 Inactive Setup to CLK | 35 |  | ns |  |
| $\mathrm{t}_{\text {CLR1X }}$ | RDY1, RDY2 Hold to CLK | 0 |  | ns |  |
| $t_{\text {AYVCL }}$ | $\overline{\text { ASYNC Setup to CLK }}$ | 50 |  | ns |  |
| ${ }^{\text {C CLAYX }}$ | ASYNC Hold to CLK | 0 |  | ns |  |
| $\mathrm{t}_{\text {A1VR1V }}$ | AEN1, $\overline{\text { AEN2 }}$ Setup to RDY1, RDY2 | 15 |  | ns |  |
| $t_{\text {CLA1X }}$ | AEN1, AEN2 Hold to CLK | 0 |  | ns |  |
| $\mathrm{t}_{\text {YHEH }}$ | CSYNC Setup to EFI | 20 |  | ns |  |
| $t_{\text {EHYL }}$ | CSYNC Hold to EFI | 10 |  | ns |  |
| $\mathrm{t}_{\text {YHYL }}$ | CSYNC Width | $2 \cdot t_{\text {ELEL }}$ |  | ns |  |
| $\mathrm{t}_{\text {I1HCL }}$ | RES Setup to CLK | 65 |  | ns | (Note 1) |
| $\mathrm{t}_{\text {CLIIH }}$ | $\overline{\text { RES }}$ Hold to CLK | 20 |  | ns | (Note 1) |
| tILIH | Input Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| tILIL | Input Fall Time | $\cdots$ | 12 | ns | From 2.0 V to 0.8 V |

## A.C. CHARACTERISTICS (Continued)

 TIMING RESPONSES| Symbol | Parameter | Min. 8284A | Min. 8284A-1 | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CLCL}}$ | CLK Cycle Period | 125 | 100 |  | ns |  |
| $\mathrm{t}_{\mathrm{CHCL}}$ | CLK HIGH Time | $\left(1 / 3 \mathrm{t}_{\text {cLCL }}\right)+2$ | 39 |  | ns |  |
| $\mathrm{t}_{\mathrm{CLCH}}$ | CLK LOW Time | $\left(2 / 3 \mathrm{t}_{\text {cLCL }}\right)-15$ | 53 |  | ns |  |
| $\mathrm{t}_{\mathrm{CH} 1 \mathrm{CH} 2}$ $\mathrm{t}_{\mathrm{CL} 2 \mathrm{CL}}$ | CLK Rise or Fall Time |  |  | 10 | ns | 1.0 V to 3.5 V |
| $\mathrm{t}_{\text {PHPL }}$ | PCLK HIGH Time | $t_{\text {clel-20 }}$ | $\mathrm{t}_{\text {clcl }}-20$ |  | ns |  |
| $\mathrm{t}_{\text {PLPH }}$ | PCLK LOW Time | $\mathrm{t}_{\text {clcl }} \mathbf{2 0}$ | $\mathrm{t}_{\text {cLCL }}-20$ |  | ns |  |
| $\mathrm{t}_{\text {RYLCL }}$ | Ready Inactive to CLK (See Note 3) | -8 | -8 |  | ns |  |
| $\mathrm{t}_{\text {RYHCH }}$ | Ready Active to CLK (See Note 2) | $\left(2 / 3 \mathrm{t}_{\text {CLCL }}\right)-15$ | 53 |  | ns |  |
| $\mathrm{t}_{\text {CLIL }}$ | CLK to Reset Delay |  |  | 40 | ns |  |
| $\mathrm{t}_{\text {CLPH }}$ | CLK to PCLK HIGH DELAY |  |  | 22 | ns |  |
| $\mathrm{t}_{\text {CLPL }}$ | CLK to PCLK LOW Delay |  |  | 22 | ns |  |
| $\mathrm{t}_{\mathrm{OLCH}}$ | OSC to CLK HIGH Delay | -5 | -5 | 22 | ns |  |
| $\mathrm{t}_{\mathrm{OLCL}}$ | OSC to CLK LOW Delay | 2 | 2 | 35 | ns |  |
| $\mathrm{t}_{\mathrm{OLOH}}$ | Output Rise Time (except CLK) |  |  | 20 | ns | From 0.8V to 2.0 V |
| $\mathrm{t}_{\mathrm{OHOL}}$ | Output Fall Time (except CLK) |  |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. Setup and hold necessary only to guarantee recognition at next clock.
2. Applies only to T 3 and TW states.
3. Applies only to T2 states.

## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT

## A.C. TESTING LOAD CIRCUIT


$C_{L}=100 \mathrm{pF}$ FOR CLK
$C_{L}=30 \mathrm{pF}$ FOR READY

## WAVEFORMS



READY SIGNALS (FOR ASYNCHRONOUS DEVICES)


## WAVEFORMS (Continued)

## READY SIGNALS (FOR SYNCHRONOUS DEVICES)



Clock High and Low Time (Using X1, X2)



Ready to Clock (Using X1, X2)


NOTES:
Ready to Clock (Using EFI)

1. $C_{L}=100 \mathrm{pF}$
2. $C_{L}=30 \mathrm{pF}$

## 8286/8287 <br> OCTAL BUS TRANSCEIVER

## - Data Bus Buffer Driver for iAPX 86,88, 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.


Figure 1. Logic Diagrams


Figure 2. Pin Configurations

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| T | 1 | Transmit: $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{\mathrm{OE}}$ | 1 | Output Enable: $\overline{\mathrm{OE}}$ 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}$ | 1/0 | Local Bus Data Pins: 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. |
| $\begin{aligned} & B_{0}-B_{7}(8286) \\ & \bar{B}_{0}-B_{7}(8287) \end{aligned}$ | 1/0 | System Bus Data Pins: These pins serve to either present data to or accept data from the system bus depending upon the state of the $T$ pin. |

## FUNCTIONAL DESCRIPTION

The 8286 and 8287 transceivers are 8-bit transceivers with high impedance outputs. With T active HIGH and $\overline{\mathrm{OE}}$ 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{\mathrm{OE}}$ active LOW, data at the
$\mathrm{B}_{0}-\mathrm{B}_{7}$ pins is driven onto the $\mathrm{A}_{0}-\mathrm{A}_{7}$ pins. No output low glitching will occur whenever the transceivers are entering or leaving the high impedance state.

## TEST LOAD CIRCUITS


*200 pF for plastic 8286/8287

## 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
*NOTICE: Stresses above those listed under "Absolute Maximum Ratings". may cause permanent damage to the device. This is a stress rating only ahd 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(V_{C C}=+5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| Icc | Power Supply Current-8287 -8286 |  | $\begin{aligned} & 130 \\ & 160 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| $I_{F}$ | Forward Input Current |  | -0.2 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $I_{\text {R }}$ | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage - B Outputs |  | $.45$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOL}=32 \mathrm{~mA} \\ & \mathrm{IOL}=16 \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}$ |
| $\begin{aligned} & \text { IOFF } \\ & \text { IOFF } \end{aligned}$ | Output Off Current Output Off Current |  | $\begin{aligned} & I_{F} \\ & I_{R} \end{aligned}$ |  | $\begin{aligned} & V_{\text {OFF }}=0.45 \mathrm{~V} \\ & V_{\text {OFF }}=5.25 \mathrm{~V} \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage—A Side <br> —B Side |  | $\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} \\ & \hline \end{aligned}$ |

## NOTE:

1. B Outputs- $\mathrm{O}_{\mathrm{OL}}=32 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$ : A Outputs-l $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.

## A.C. CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \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{l}_{\mathrm{OL}}=16 \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 | $\begin{aligned} & 5 \\ & 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & 22 \\ & 30 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ | (See Note 1) |
| TEHTV | Transmit/Receive Hold Time | 5 |  | ns |  |
| TTVEL | Transmit/Receive Setup | 10 |  | ns |  |
| TEHOZ | Output Disable Time | 5 | 18 | ns |  |
| TELOV | Output Enable Time | 10 | 30 | ns |  |
| $\begin{aligned} & \text { TILIH, } \\ & \text { TOLOH } \end{aligned}$ | Input, Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL, TOHOL | Input, Output Fall Time |  | 12 | ns | From 2.0 V to 8.0 V |

${ }^{*} \mathrm{C}_{\mathrm{L}}=200 \mathrm{pF}$ for plastic 8286/8287

## NOTE:

1. See waveforms and test load circuit on following page.

## WAVEFORMS



## NOTE:

1. All timing measurements are made at 1.5 V unless otherwise noted.


Output Delay versus Capacitance

# 8288 <br> BUS CONTROLLER FOR iAPX 86, 88 PROCESSORS 

## Bipolar Drive Capability <br> Provides Advanced Commands <br> - 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 ${ }^{\top} 8288$ Bus Controller is a 20 -pin bipolar component for use with medium-to-large iAPX 86, 88 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.


Figure 1. Block Diagram


Figure 2.
Pin Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ |  | Power: +5V supply. |
| GND |  | Ground. |
| $\overline{\mathrm{S}_{0}}, \overline{\bar{S}_{1}}, \overline{\mathrm{~S}_{2}}$ | 1 | Status Input PIns: These pins are the status input pins from the 8086, 8088 or 8089 processors. The 8288 decodes these inputs to generate command and control signals at the appropriate time. When these pins are not in use (passive) 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 control 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 | 0 | Data Enable: This signal serves to enable data transceivers onto either the local or system data bus. This signal is active HIGH. |
| DT/R | 0 | 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). |
| $\overline{\text { AEN }}$ | 1 | Address Enable: $\overline{\text { AEN }}$ enables command outputs of the 8288 Bus Controller at least 115 ns after it becomes active (LOW). $\overline{\text { AEN }}$ going inactive immediately 3 -states the command output drivers. AEN does not affect the $1 / O$ command lines if the 8288 is in the I/O Bus mode (IOB tied HIGH). |
| CEN | 1 | Command Enable: When this signal is LOW all 8288 command outputs and the DEN and PDEN control outputs are forced to their inactive state. When this signal is HIGH, these same outputs are enabled. |
| IOB | 1 | 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). |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| AIOWC | 0 | Advanced I/O Write Command: The AIOWC issues an I/O Write Command earlier in the machine cycle to give //O devices an early indication of a write instruction. Its timing is the same as a read command signal. 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 $1 / 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{\mathrm{AMWC}}$ 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{A M W C}$ 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. |
| 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 that DEN performs for the system bus. PDEN is active LOW. |

## FUNCTIONAL DESCRIPTION

## Command and Control Logic

The command logic decodes the three 8086, 8088 or 8089 CPU status lines $\left(\overline{\mathbf{S}_{0}} ; \overline{\mathbf{S}_{1}}, \overline{\mathbf{S}_{2}}\right)$ to determine what command is to be issued.
This chart shows the meaning of each status "word".

| $\begin{array}{llll}\overline{\mathbf{S}_{2}} & \overline{\mathbf{S}_{1}} & \overline{\mathbf{S}_{0}}\end{array}$ | Processor State | 8288 Command |
| :---: | :---: | :---: |
| $0 \quad 00$ | Interrupt Acknowledge | INTA |
| 0 0 01 | Read I/O Port | IORC |
| $0 \quad 10$ | Write I/O Port | IOWC,AIOWC |
| 0 | Halt | None |
| 100 | Code Access | $\overline{\text { MRDC }}$ |
| 100 | Read Memory | MRDC |
| 110 | Write Memory | $\overline{M W T C}, \overline{A M W C}$ |
|  | 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{\overline{O R C}, \overline{I O W C}}, \overline{\mathrm{AIOWC}}, \overline{\mathrm{NTA}})$ are always enabled (i.e., not dependent on $\overline{A E N}$ ). When an I/O command is initiated by the processor, the 8288 immediately activates the command lines using $\overline{P D E N}$ and $D T / \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{A E N}$ 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 115 ns after the $\overline{\text { AEN }}$ Line is activated (LOW). This mode assumes bus arbitration logic will inform the bus controller (on the $\overline{\mathrm{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 processor from entering an unnecessary wait state.
The command outputs are:

| $\overline{\text { MRDC }}$ - Memory Read Command |
| :--- |
| $\overline{\text { MWTC }}$ - Memory Write Command |
| $\overline{\text { IORC }}$ - I/O Read Command |
| IOWC $-1 / O$ Write Command |
| $\overline{\text { AMWC }}$ - Advanced Memory Write Command |
| $\overline{\text { AIOWC }}$ - Advanced I/O Write Command |
| $\overline{\text { INTA }}$ - Interrupt Acknowledge |

$\overline{\text { INTA }}$ (Interrupt Acknowledge) acts as an I/O read during an interrupt cycle. Its purpose is to inform an interrupting device that its interrupt is being acknowledged 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 (DT//̄) 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 the current address into the address latches. ALE also serves to strobe the status ( $\overline{\mathrm{S}_{0}}$, $\overline{\mathrm{S}_{1}}, \overline{\mathrm{~S}_{2}}$ ) into a latch for halt state decoding.

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

## 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.5 Watt
*NOTICE: 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(V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{C}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 230 | mA |  |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.7 | mA | $V_{F}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{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} \\ & \hline \end{aligned}$ | $\begin{aligned} \mathrm{IOL} & =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 \\ & \hline \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}$ |
| $V_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V |  |
| loff | Output Off Current |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OFF }}=0.4$ to 5.25 V |

A.C. CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 100 |  | ns |  |
| TCLCH | CLK Low Time | 50 |  | ns |  |
| TCHCL | CLK High Time | 30 |  | ns |  |
| TSVCH | Status Active Setup Time | 35 |  | ns |  |
| TCHSV | Status Active Hold Time | 10 |  | ns |  |
| TSHCL | Status Inactive Setup Time | 35 |  | ns |  |
| TCLSH | Status Inactive Hold Time | 10 |  | ns |  |
| TILIH | Input, Rise Time |  | 20 | ns | From 0.8V to 2.0V |
| TIHIL | Input, Fall Time |  | 12 | ns | From 2.0V to 0.8V |

## A.C. CHARACTERISTICS (Continued)

## TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCVNV | Control Active Delay | 5 | 45 | ns | $\overline{\text { MRDC }}$ <br> $\overline{\text { IORC }}$ <br> $\overline{\text { MWTC }}$ <br> $\overline{\text { IOWC }}$ <br> $\overline{\text { INTA }}$ <br> $\overline{\text { AMWC }}$ <br> $\overline{\text { AIOWC }}$$\left\{\begin{array}{l} \\ \mathrm{I}_{\mathrm{LL}}=32 \mathrm{~mA} \\ \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA} \\ \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF} \\ \text { Other }\end{array}\left\{\begin{array}{l}\mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \\ \mathrm{I}_{O H}=-1 \mathrm{~mA} \\ C_{L}=80 \mathrm{pF}\end{array}\right.\right.$ |
| TCVNX | Control Inactive Delay | 10 | 45 | ns |  |
| TCLLH, TCLMCH | ALE MCE Active Delay (from CLK) |  | 20 | ns |  |
| TSVLH, TSVMCH | ALE MCE Active Delay (from Status) |  | 20 | ns |  |
| TCHLL | ALE Inactive Delay | 4 | 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 | 115 | 200 | ns |  |
| TAEVNV | AEN to DEN |  | 20 | ns |  |
| TCEVNV | CEN to DEN, PDEN |  | 25 | ns |  |
| TCELRH | CEN to Command |  | TCLML | ns |  |
| TOLOH | Output, Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output, Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT

## TEST LOAD CIRCUITS-3-STATE COMMAND OUTPUT TEST LOAD


3.STATE TO LOW



CONTROL OUTPUT

WAVEFORMS

wOTEs:

1. ADDRESSIDATA BUS IS SHOWN ONLY FOR REEERENCE PURPOSES.
2. LEADING EDGE OF ALE AND MCE IS DETERMINED BY THE FALLING EDGE OF CLK OR STATUS GOING ACTIVE, WHICHEVER OCCURS LAST 3. ALL TIMING MEASUPQEMENTS ARE MADE AT $1.5 V$ UNLESS SPECIFIED OTHERWISE.

## WAVEFORMS (Continued)

## DEN, PDEN QUALIFICATION TIMING



ADDRESS ENABLE (AEN) TIMING (3-STATE ENABLE/DISABLE)


NOTE: CEN must be low or valid prior to T2 to prevent the command from being generated.

## 8289 <br> BUS ARBITER

## - Provides Multi-Master System Bus Protocol

- Synchronizes iAPX 86, 88 Processors with Multi-Master Bus
- Provides Simple Interface with 8288 Bus Controller


## - Four Operating Modes for Flexible System Configuration

- Compatible with Intel Bus Standard MULTIBUS ${ }^{\text {™ }}$


## - Provides System Bus Arbitration for 8089 IOP in Remote Mode

The Intel 8289 Bus Arbiter is a 20 -pin, 5 -volt-only bipolar component for use with medium to large iAPX 86,88 multimaster/multiprocessing systems. The 8289 provides system bus arbitration for systems with multiple bus masters, such as an 8086 CPU with 8089 IOP in its REMOTE mode, while providing bipolar buffering and drive capability.


Figure 1. Block Diagram


Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{Cc}}$ |  | Power: +5 V supply $\pm 10 \%$. |
| GND |  | Ground. |
| $\overline{\mathbf{S 0}}, \overline{\mathbf{5} 1, \mathrm{~s} 2}$ | 1 | Status Input Pins: The status input pins from an 8086, 8088 or 8089 processor. The 8289 decodes these pins to initiate bus request and surrender actions. (See Table 2.) |
| CLK | 1 | Clock: From the 8284 clock chip and serves to establish when bus arbiter actions are initiated. |
| $\overline{\text { LOCK }}$ | 1 | Lock: A processor generated signal which when activated (low) prevents the arbiter from surrendering the multi-master system bus to any other bus artiter, regardless of its priority. |
| $\overline{\text { CRQLCK }}$ | 1 | Common Request Lock: An active low signal which prevents the arbiter from surrendering the multi-master system bus to any other bus arbiter requesting the bus through the CBRQ input pin. |
| RESB | 1 | Resident Bus: A strapping option to configure the arbiter to operate in systems having both a multi-master system bus and a Resident Bus. Strapped high, the multimaster system bus is requested or surrendered as a function of the SYSB/RESB input pin. Strapped low, the SYSB/RESB input is ignored. |
| ANYRQST | 1 | Any Request: A strapping option which permits the multi-master system bus to be surrendered to a lower priority arbiter as if it were an arbiter of higher priority (i.e., when a lower priority arbiter requests the use of the multi-master system bus, the bus is surrendered as soon as it is possible). When ANYRQST is strapped low, the bus is surrendered according to Table 2. If ANYRQST is strapped high and $\overline{C B R Q}$ is activated, the bus is surrendered at the end of the present bus cycle. Strapping CBRQ low and ANYRQST high forces the 8289 arbiter to surrender the multi-master system bus after each transfer cycle. Note that when surrender occurs BREQ is driven false (high). |
| $\overline{10 B}$ | 1 | 10 Bus: A strapping option which configures the 8289 Arbiter to operate in systems having both an 10 Bus (Peripheral Bus) and a multi-master system bus. The arbiter requests and surrenders the use of the multi-master system bus as a function of the status line, $\overline{\mathbf{S 2}}$. The multi-master system bus is permitted to be surrendered while the processor is performing 10 commands and is requested whenever the processor performs a memory command. Interrupt cycles are assumed as coming from the peripheral bus and are treated as an 10 command. |


| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| $\overline{\text { AEN }}$ | 0 | Address Enable: The output of the 8289 Arbiter to the processor's address latches, to the 8288 Bus Controller and 8284A Clock Generator. $\overline{\text { AEN }}$ serves to instruct the Bus Controller and address latches when to tri-state their output drivers. |
| $\frac{\mathrm{SYSB} /}{\text { RESB }}$ | 1 | System.Bus/Resident Bus: An input signal when the arbiter is configured in the S.R. Mode (RESB is strapped high) which determines when the multi-master system bus is requested and multi-master system bus surrendering is permitted. The signal is intended to originate from a form of address-mapping circuitry, as a decoder or PROM attached to the resident address bus. Signal transitions and glitches are permitted on this pin from $\phi 1$ of T4 to $\phi 1$ of T2 of the processor cycle. During the period from $\phi 1$ of T2 to $\phi \cdot 1$ of T4, only clean transitions are permitted on this pin (no glitches). If a glitch occurs, the arbiter may capture or miss it, and the multi-master system bus may be requested or surrendered, depending upon the state of the glitch. The arbiter requests the multimaster system bus in the S.R. Mode when the state of the SYSB/RESB $p$ in is high and permits the bus to be surrendered when this pin is low. |
| $\overline{\text { CBRQ }}$ | I/O | Common Bus Request: An input signal which instructs the arbiter if there are any other arbiters of lower priority requesting the use of the multi-master system bus. <br> The CBRQ pins (open-collector output) of all the 8289 Bus Arbiters which surrender to the multi-master system bus upon request are connected together. <br> The Bus Arbiter running the current transfer cycle will not itself pull the CBRQ line low. Any other arbiter connected to the $\overline{C B R Q}$ line can request the multi-master system bus. The arbiter presently running the current transfer cycle drops its $\overline{B R E Q}$ signal and surrenders the bus whenever the proper surrender conditions exist. Strapping $\overline{C B R Q}$ low and ANYRQST high allows the multi-master system bus to be surrendered after each transfer cycle. See the pin definition of ANYRQST. |
| $\overline{\text { INIT }}$ | 1 | Initialize: An active low multi-master system bus input signal used to reset all the bus arbiters on the multi-master system bus: After initialization, no arbiters have the use of the multi-master system bus. |

Table 1. Pin Descriptions (Continued)

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| $\overline{\text { BCLK }}$ | I | Bus Clock: The multi-master system bus <br> clock to which all multi-master system bus <br> interface signals are synchronized. |
| $\overline{\text { BREQ }}$ | O | Bus Request: An active low output signal <br> in the parallel Priority Resolving Scheme <br> which the arbiter activates to request the <br> use of the multi-master system bus. |
| $\overline{\text { BPRN }}$ | I | Bus Priority In: The active low signal re- <br> turned to the arbiter to instruct it that it may <br> acquire the multi-master system bus on the <br> next falling edge of BCLK. BPRN indicates <br> to the arbiter that it is the highest priority <br> requesting arbiter presently on the bus. <br> The loss of BPRN instructs the arbiter that <br> it has lost priority to a higher priority <br> arbiter. |

## FUNCTIONAL DESCRIPTION

The 8289 Bus Arbiter operates in conjunction with the 8288 Bus Controller to interface iAPX 86,88 processors to a multi-master system bus (both the iAPX 86 and iAPX 88 are configured in their max mode). The processor is unaware of the arbiter's existence and issues commands as though it has exclusive use of the system bus. If the processor does not have the use of the multi-master system bus, the arbiter prevents the Bus Controller (8288), the data transceivers and the address latches from accessing the system bus (e.g. all bus driver outputs are forced into the high impedance state). Since the command sequence was not issued by the 8288, the system bus will appear as "Not Ready" and the processor will enter wait states. The processor will remain in Wait until the Bus Arbiter acquires the use of the multi-master system bus whereupon the arbiter will allow the bus controller, the data transceivers, and the address latches to access the system. Typically, once the command has been issued and a data transfer has taken place, a transfer acknowledge (XACK) is returned to the processor to indicate "READY" from the accessed slave device. The processor then completes its transfer cycle. Thus the arbiter serves to multiplex a processor (or bus master) onto a multi-master system bus and avoid contention problems between bus masters.

## Arbitration Between Bus Masters

In general, higher priority masters obtain the bus when a lower priority master completes its present transfer cycle. Lower priority bus masters obtain the bus when a higher priority master is not accessing the system bus. A strapping option (ANYRQST) is provided to allow the arbiter to surrender the bus to a lower priority master as though it were a master of higher priority. If there are no other bus masters requesting the bus, the arbiter maintains the bus so long as its processor has not entered

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| $\overline{\text { BPRO }}$ | O | Bus Priority Out: An active low output <br> signal used in the serial priority resolving <br> scheme where $\overline{\text { BPRO }}$ is daisy-chained to <br> BPRN of the next lower priority arbiter. |
| $\overline{\text { BUSY }}$ | I/O | Busy: An active low open collector <br> multi-master system bus interface signal <br> used to instruct all the arbiters on the bus <br> when the multi-master system bus is avail- <br> able. When the multi-master system bus is <br> available the highest requesting arbiter <br> (determined by BPRN) seizes the bus and <br> pulls BUSY low to keep other arbiters off of <br> the bus. When the arbiter is done with the <br> bus, it releases the BUSY signal, permitting <br> it to go high and thereby allowing another <br> arbiter to acquire the multi-master system <br> bus. |

the HALT State. The arbiter will not voluntarily surrender the system bus and has to be forced off by another master's bus request, the HALT State being the only exception. Additional strapping options permit other modes of operation wherein the multi-master system bus is surrendered or requested under different sets of conditions.

## Priority Resolving Techniques

Since there can be many bus masters on a multi-master system bus, some means of resolving priority between bus masters simultaneously requesting the bus must be provided. The 8289 Bus Arbiter provides several resolving techniques. All the techniques are based on a priority concept that at a given time one bus master will have priority above all the rest. There are provisions for using parallel priority resolving techniques, serial priority resolving techniques, and rotating priority techniques.

## PARALLEL PRIORITY RESOLVING

The parallel priority resolving technique uses a separate bus request line (BREQ) for each arbiter on the multimaster system bus, see Figure 4. Each BREQ line enters into a priority encoder which generates the binary address of the highest priority $\overline{B R E Q}$ line which is active. The binary address is decoded by a decoder to select the corresponding $\overline{B P R N}$ (Bus Priority In) line to be returned to the highest priority requesting arbiter. The arbiter receiving priority ( $\overline{\mathrm{BPRN}}$ true) then allows its associated bus master onto the multi-master system bus as soon as it becomes available (i.e., the bus is no longer busy). When one bus arbiter gains priority over another arbiter it cannot immediately seize the bus, it must wait until the present bus transaction is complete.

Upon completing its transaction the present bus occupant recognizes that it no longer has priority and surrenders the bus by releasing BUSY. BUSY is an active low "OR" tied signal line which goes to every bus arbiter on the system bus. When BUSY goes inactive (high), the arbiter which presently has bus priority ( $\overline{\mathrm{BPRN}}$ true) then
seizes the bus and pulls $\overline{\mathrm{BUSY}}$ low to keep other arbiters off of the bus. See waveform timing diagram, Figure 5. Note that all multi-master system bus transactions are synchronized to the bus clock (BCLK). This allows the parallel priority resolving circuitry or any other priority resolving scheme employed to settle.


Figure 4. Parallel Priority Resolving Technique


Figure 5. Higher Priority Arbiter obtaining the Bus from a Lower Priority Arbiter

## SERIAL PRIORITY RESOLVING

The serial priority resolving technique eliminates the need for the priority encoder-decoder arrangement by daisy-chaining the bus arbiters together, connecting the higher priority bus arbiter's BPRO (Bus Priority Out) output to the $\overline{B P R N}$ of the next lower priority. See Figure 6.


Figure 6. Serial Priority Resolving

## ROTATING PRIORITY RESOLVING

The rotating priority resolving technique is similar to that of the parallel priority resolving technique except that priority is dynamically re-assigned. The priority encoder is replaced by a more complex circuit which rotates priority between requesting arbiters thus allowing each arbiter an equal chance to use the multi-master system bus, over time.

## Which Priority Resolving Technique To Use

There are advantages and disadvantages for each of the techniques described above. The rotating priority resolving technique requires substantial external logic to implement while the serial technique uses no external logic but can accommodate only a limited number of bus arbiters before the daisy-chain propagation delay exceeds the multi-master's system bus clock ( $\overline{B C L K}$ ). The parallel priority resolving technique is in general a good compromise between the other two techniques. It allows for many arbiters to be present on the bus while not requiring too much logic to implement.

[^25]
## 8289 MODES OF OPERATION

There are two types of processors in the iAPX 86 family. An Input/Output processor (the 8089 IOP) and the iAPX 86/10, 88/10 CPUs. Consequently, there are two basic operating modes in the 8289 bus arbiter. One, the IOB (I/O Peripheral Bus) mode, permits the processor access to both an I/O Peripheral Bus and a multi-master system bus. The second, the RESB (Resident Bus mode), permits the processor to communicate over both a Resident Bus and a multi-master system bus. An I/O Peripheral Bus is a bus where all devices on that bus, including memory, are treated as $1 / O$ devices and are addressed by $1 / O$ commands. All memory commands are directed to another bus, the multi-master system bus. A Resident Bus can issue both memory and $I / O$ commands, but it is a distinct and separate bus from the multi-master system bus. The distinction is that the Resident Bus has only one master, providing full availability and being dedicated to that one master.

The $\overline{\mathrm{OB}}$ strapping option configures the 8289 Bus Arbiter into the $\overline{\overline{O B}}$ mode and the strapping option RESB configures it into the RESB mode. It might be noted at this point that if both strapping options are strapped false, the arbiter interfaces the processor to a multimaster system bus only (see Figure 7). With both options strapped true, the arbiter interfaces the processor to a multi-master system bus, a Resident Bus, and an I/O Bus.

In the $\overline{\mathrm{IOB}}$ mode, the processor communicates and controls a host of peripherals over the Peripheral Bus. When the I/O Processor needs to communicate with system memory, it does so over the system memory bus. Figure 8 shows a possible I/O Processor system configuration.

The IAPX 86 and IAPX 88 processors can communicate with a Resident Bus and a multi-master system bus. Two bus controllers and only one Bus Arbiter would be needed in such a configuration as shown in Figure 9. In such a system configuration the processor would have access to memory and peripherals of both busses. Memory mapping techniques are applied to select which bus is to be accessed. The SYSB/RESB input on the arbiter serves to instruct the arbiter as to whether or not the system bus is to be accessed. The signal connected to SYSB/RESB also enables or disables commands from one of the bus controllers.

A summary of the modes that the 8289 has, along with its response to its status lines inputs, is summarized in Table 2.

Table 2. Summary of $\mathbf{8 2 8 9}$ Modes, Requesting and Relinquishing the Multi-Master System Bus

| Status Lines From $\mathbf{8 0 8 6}$ or $\mathbf{8 0 8 8}$ or $\mathbf{8 0 8 9}$ |  |  |  | $\frac{\text { IOB Mode }}{\text { Only }}$ | $\frac{\text { RESB (Mode) Only }}{I O B=\text { High RESB }=\text { High }}$ | IOB Mode RESB Mode IOB = Low RESB = High | $\begin{gathered} \text { Single } \\ \frac{\text { Bus Mode }}{\text { IOB }=\text { High }} \\ \text { RESB }=\text { Low } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| I/O <br> COMMANDS | $\overline{\mathbf{S 2}}$ 0 0 0 | $\overline{\mathbf{S 1}}$ 0 0 1 | $\overline{\text { So }}$ 0 1 0 | $\begin{gathered} \overline{\mathrm{IOB}}=\text { Low } \\ x \\ x \\ x \end{gathered}$ | $\begin{gathered} \text { SYSB/RESB }=\text { High SYSB } / \overline{\text { RESB }}=\text { Low } \\ x \\ x \\ x \end{gathered}$ | $\begin{array}{cc} \text { SYSB/ } \overline{\text { RESB }}=\text { High SYSB/ } \overline{\text { RESB }}=\text { Low } \\ x & \mathrm{x} \\ \mathrm{x} & \mathrm{x} \\ \mathrm{x} & \mathrm{x} \end{array}$ |  |
| HALT | 0 | 1 | 1 | $\times$ | $x \quad \mathrm{x}$ | $x$ x | x |
| MEM <br> COMMANDS | 1 1 1 | 0 0 1 | 0 1 0 |  | $x$ | $\mathbf{x}$ |  |
| IDLE | 1 | 1 | 1 | $\times$ | $x \quad x$ | $x$ x | x |

NOTES:

1. $X=$ Multi-Master System Bus is allowed to be Surrendered.
2. $r=$ Multi-Master System Bus is Requested.

| Mode | $\begin{gathered} \text { Pin } \\ \text { Strapping } \end{gathered}$ | Multi-Master System Bus |  |
| :---: | :---: | :---: | :---: |
|  |  | Requested** | Surrendered* |
| Single Bus Multi-Master Mode | $\begin{aligned} & \overline{\mathrm{OB}}=\text { High } \\ & \text { RESB }=\text { Low } \end{aligned}$ | Whenever the processor's status lines go active | $\mathrm{HLT}+\mathrm{TI} \cdot \mathrm{CBRQ}+\mathrm{HPBRQ}^{\dagger}$ |
| RESB Mode Only | $\begin{aligned} & \overline{\mathrm{OB}}=\mathrm{High} \\ & \text { RESB }=\text { High } \end{aligned}$ | SYSB/ $\overline{\operatorname{RESB}}=\mathrm{High} \cdot$ aCTIVE STATUS | $\begin{aligned} & (\mathrm{SYSB} / \overline{\text { RESB }}=\text { LOW }+ \text { TI) • } \\ & \text { CBRQ + HLT }+ \text { HPBRQ } \end{aligned}$ |
| IOB Mode Only | $\begin{aligned} & \overline{\mathrm{OB}}=\text { Low } \\ & \mathrm{RESB}=\text { Low } \end{aligned}$ | Memory Commands | $\begin{aligned} & (1 / O \text { Status + TI) } \cdot \mathrm{CBRQ}+ \\ & \mathrm{HLT}+\mathrm{HPBRQ} \end{aligned}$ |
| IOB Mode RESB Mode | $\begin{aligned} & \overline{\mathrm{IOB}}=\text { Low } \\ & \mathrm{RESB}=\mathrm{High} \end{aligned}$ | (Memory Command) • <br> (SYSB/RESB $=$ High $)$ | ((I/O Status Commands) + SYSB/ $\overline{\operatorname{RESB}}=\mathrm{LOW})$ ) $\operatorname{CBRQ}$ + HPBRQ $^{\dagger}+$ HLT |

## NOTES:

*LOCK prevents surrender of Bus to any other arbiter, $\overline{C R Q L C K}$ prevents surrender of Bus to any lower priority arbiter.
**Except for HALT and Passive or IDLE Status.


1. IOB Active Low.
2. RESB Active High.
3.     + is read as "OR" and • as "AND."
4. $\mathrm{Tl}=$ Processor Idle Status $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{~S} 0}=111$
5. HLT $=$ Processor Halt Status $\overline{\mathrm{S} 2}, \overline{\mathrm{~S} 1}, \overline{\mathrm{SO}}=011$


Figure 7. Typical Medium Complexity CPU System


Figure 8. Typical Medium Complexity IOB System


Figure 9. 8289 Bus Arbiter Shown in System-Resident Bus Configuration

## 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.5 Watt
*NOTICE: 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}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.50 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Forward Current |  | -0.5 | mA | $\mathrm{V}_{C C}=5.50 \mathrm{~V}, \mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Reverse Input Leakage Current |  | 60 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.50, \mathrm{~V}_{\mathrm{R}}=5.50$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage BUSY, CBRQ $\overline{A E N}$ $\overline{B P R O}, \overline{B R E Q}$ |  | $\begin{aligned} & 0.45 \\ & 0.45 \\ & 0.45 \end{aligned}$ | $\begin{aligned} & V \\ & v \\ & v \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage BUSY, CBRQ | Open Collector |  |  |  |
|  | All Other Outputs | 2.4 |  | V | $\mathrm{IOH}=400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{Cc}}$ | Power Supply Current |  | 165 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | . 8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V |  |
| Cin Status | Input Capacitance |  | 25 | pF |  |
| Cin (Others) | Input Capacitance |  | 12 | pF |  |

A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$ TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 |  | ns |  |
| TCLCH | CLK Low Time | 65 |  | ns |  |
| TCHCL | CLK High Time | 35 |  | ns |  |
| TSVCH | Status Active Setup | 65 | TCLCL-10 | ns |  |
| TSHCL | Status Inactive Setup | 50 | TCLCL-10 | ns |  |
| THVCH | Status Active Hold | 10 |  | ns |  |
| THVCL | Status Inactive Hold | 10 |  | ns |  |
| TBYSBL | BUSY $\uparrow$ Setup to BCLK $\downarrow$ | 20 |  | ns |  |
| TCBSBL | CBRQ $\downarrow$ Setup to BCLK $\downarrow$ | 20 |  | ns |  |
| TBLBL | BCLK Cycle Time | 100 |  | ns |  |
| TBHCL | BCLK High Time | 30 | $.65[$ TBLBL] | ns |  |
| TCLLL1 | LOCK Inactive Hold | 10 |  | ns |  |
| TCLLL2 | LOCK Active Setup | 40 |  | ns |  |
| TPNBL | BPRN $\downarrow \uparrow$ to BCLK Setup Time | 15 |  | ns |  |
| TCLSR1 | SYSB/RESB Setup | 0 |  | ns |  |
| TCLSR2 | SYSB/RESB Hold | 20 |  | ns |  |
| TIVIH | Initialization Pulse Width | 3 TBLBL+ |  | ns |  |
| TILIH |  | 3 TCLCL |  |  |  |
| TIHIL | Input Rise Time |  | 20 | ns | From 0.8 to 2.0V |

## A.C. CHARACTERISTICS (Continued)

## TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TBLBRL | BCLK to BREQ Delay $\downarrow \uparrow$ |  | 35 | ns |  |
| TBLPOH | BCLK to BPRO $\uparrow \uparrow$ (See Note 1) |  | 40 | ns |  |
| TPNPO | BPRN $\downarrow \uparrow$ to BPRO $\downarrow \uparrow$ Delay <br> (See Note 1) |  | 25 | ns |  |
| TBLBYL | BCLK to BUSY Low |  | 60 | ns |  |
| TBLBYH | BCLK to BUSY Float (See Note 2) |  | 35 | ns |  |
| TCLAEH | CLK to AEN High |  | 65 | ns |  |
| TBLAEL | BCLK to AEN Low | 40 | ns |  |  |
| TBLCBL | BCLK to CBRQ Low | 60 | ns |  |  |
| TRLCRH | BCLK to CBRQ Float (See Note 2) |  | 35 | ns |  |
| TOLOH | Output Rise Time | 20 | ns | From 0.8V to 2.0V |  |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0V to 0.8V |

$\downarrow \uparrow$ Denotes that spec applies to both transitions of the signal.

## NOTES:

1. BCLK generates the first BPRO wherein subsequent BPRO changes lower in the chain are generated through BPRON.
2. Measured at .5 V above GND.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS



## ADDITIONAL NOTES:

The signals related to CLK are typical processor signals, and do not relate to the depicted sequence of events of the signals referenced to $\overline{B C L K}$. The signals shown related to the $\overline{B C L K}$ represent a hypothetical sequence of events for illustration. Assume 3 bus arbiters of priorities 1, 2 and 3 configured in serial priority resolving scheme as shown in Figure 6. Assume arbiter 1 has the bus and is holding busy low. Arbiter \#2 detects its processor wants the bus and pulls low $\overline{\mathrm{BREQ}} \mathbf{2}$. If $\overline{\mathrm{BPRN} \mathrm{\# 2}}$ is high (as shown), arbiter \#2 will pull low $\overline{\mathrm{CBRQ}}$ line. $\overline{\mathrm{CBRQ}}$ signals to the higher priority arbiter \#1 that a lower priority arbiter wants the bus. [A higher priority arbiter would be granted BPRN when it makes the bus request rather than having to wait for another arbiter to release the bus through CBRQ.** Arbiter \#1 will relinquish the multi-master system bus when it enters a state not requiring it (see Table 1), by lowering its BPRO\#1 (tied to $\overline{B P R N \# 2})$ and releasing BUSY. Arbiter \#2 now sees that it has priority from $\overline{\text { BPRN\#2 }}$ being low and releases $\overline{C B R Q}$. As soon as BUSY signifies the bus is available (high), arbiter \#2 pulls BUSY low on next falling edge of BCLK. Note that if arbiter \#2 didn't want the bus at the time it received priority, it would pass priority to the next lower priority arbiter by lowering its BPRO \#2 [TPNPO].
**Note that even a higher priority arbiter which is acquiring the bus through $\overline{B P R N}$ will momentarily drop $\overline{C B R Q}$ until it has acquired the bus.

8041AH/8041AH-2/8641A/8741A 8-BIT MICROCOMPUTER

- 8041AH-2: 12 MHz 8041AH: 8 MHz
- 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-toMaster 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 iAPX-86,88 Microprocessor Families
- Interchangeable ROM and EPROM Versions
- Expandable I/O
- RAM Power-Down Capability
- Over 90 Instructions: 70\% Single Byte
- Single 5V Supply

The Intel ${ }^{\circledR} 8041 \mathrm{AH} / 8741 \mathrm{~A}$ 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 ${ }^{\text {TM }}$, MCS-80 ${ }^{\text {TM }}$, $\mathrm{iAPX}-85^{\mathrm{TM}}$, $\mathrm{iAPX}-86$, iAPX-88, and other 8 - or 16 -bit systems.
The UPI-41A ${ }^{\text {TM }}$ 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 8041 AH version or as UV-erasable EPROM in the 8741 A version. The 8741 A and the 8041 AH are fully pin compatible for easy transition from prototype to production level designs. The 8741A is a one-time programmable (at the factory) 8741A which can be ordered as the first 25 pieces of a new 8041 AH order. The substitution of 8641 As for 8041 AHs allows for very fast turnaround for initial code verification and evaluation results.
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 \mathrm{I} / \mathrm{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 8041AH), single-step mode for debug and dual working register banks.


Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \\ & \hline \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { TEST } 0, \\ & \text { TEST } 1 \end{aligned}$ | $\begin{array}{r} 1 \\ 39 \end{array}$ | 1 | Test Inputs: Input pins which can be directly tested using conditional branch instructions. <br> Frequency Reference: TEST 1 ( $\mathrm{T}_{1}$ ) also functions as the event timer input (under software control). TEST 0 $\left(T_{0}\right)$ is used during PROM programming and verification in the 8741A. |
| XTAL 1 , <br> XTAL 2 | $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | 1 | Inputs: Inputs for a crystal, LC or an external timing signal to determine the internal oscillator frequency. |
| $\overline{\text { RESET }}$ | 4 | 1 | Reset: Input used to reset status flipflops and to set the program counter to zero. <br> $\overline{\operatorname{RESET}}$ is also used during PROM programming and verification. |
| $\overline{\text { SS }}$ | 5 | 1 | Single Step: Single step input used in the 8741A in conjunction with the SYNC output to step the program through each instruction. |
| $\overline{\text { CS }}$ | 6 | 1 | Chip Select: Chip select input used to select one UPI-41A microcomputer out of several connected to a common data bus. |
| EA | 7 | 1 | External Access: External access input which allows emulation, testing and PROM/ROM verification. This pin should be tied low if unused. |
| $\overline{\mathrm{RD}}$ | 8 | 1 | Read: I/O read input which enables the master CPU to read data and status words from the OUTPUT DATA BUS BUFFER or status register. |
| $\mathrm{A}_{0}$ | 9 | 1 | Command/Data Select: Address input used by the master processor to indicate whether byte transfer is data ( $A_{0}=0, F_{1}$ is reset) or command ( $A_{0}=$ $1, F_{1}$ is set). |
| $\overline{\text { WR }}$ | 10 | 1 | Write: I/O write input which enables the master CPU to write data and command words to the UPI-41A INPUT DATA BUS BUFFER. |


| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| SYNC | 11 | 0 | Output Clock: 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. |
| $\begin{aligned} & D_{0}-D_{7} \\ & \text { (BUS) } \end{aligned}$ | 12-19 | 1/0 | Data Bus: Three-state, bidirectional DATA BUS BUFFER lines used to interface the UPI-41A microcomputer to an 8-bit master system data bus. |
| $\mathrm{P}_{10}-\mathrm{P}_{17}$ | 27-34 | 1/0 | Port 1: 8-bit, PORT 1 quasi-bidirectional I/O lines. |
| $\mathrm{P}_{20}-\mathrm{P}_{27}$ | $\left\lvert\, \begin{aligned} & 21-24 \\ & 35-38 \end{aligned}\right.$ | 1/0 | Port 2: 8-bit, PORT 2 quasi-bidirectional I/O lines. The lower 4 bits ( $\mathrm{P}_{20^{-}}$ $P_{23}$ ) interface directly to the $8243 \mathrm{I} / \mathrm{O}$ expander device and contain address and data information during PORT 4-7 access. The upper 4 bits $\left(\mathrm{P}_{24}-\mathrm{P}_{27}\right)$ can be programmed to provide interrupt Request and DMA Handshake capability. Software control can configure $\mathrm{P}_{24}$ as Output Buffer Full (OBF) interrupt, $\mathrm{P}_{25}$ as Input Buffer Full ( $\overline{\mathrm{IBF}}$ ) interrupt, $P_{26}$ as DMA Request (DRQ), and $P_{27}$ as DMA ACKnowledge ( $\overline{\text { DACK }}$ ). |
| PROG | 25 | 1/0 | Program: Multifunction pin used as the program pulse input during PROM programming. <br> During I/O expander access the PROG pin acts as an address/data strobe to the 8243. This pin should be tied high if unused. |
| $V_{c c}$ | 40 |  | Power: +5 V main power supply pin. |
| $V_{D D}$ | 26 |  | Power: +5 V during normal operation. +25 V during programming operation. Low power standby pin in ROM version. |
| $\mathrm{V}_{\mathrm{ss}}$ ' | 20 |  | Ground: Circuit ground potential. |

## UPI.41A ${ }^{\text {TM }}$ FEATURES AND ENHANCEMENTS

1. Two Data Bus Buffers, one for input and one for output. This allows a much cleaner Master/Slave protocol.

2. 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}_{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{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$.


During the time that the host CPU is reading the status register, the 8041 AH is prevented from updating this register or is 'locked out.'
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, $\mathrm{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 $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{\text { IBF }}$ (Input Buffer Full) pin. A "1" written to $\mathrm{P}_{25}$ enables the $\overline{\mathrm{IBF}}$ pin (the pin outputs the inverse of the IBF Status Bit). A " 0 " written to $\mathrm{P}_{25}$ disables the $\overline{\mathrm{BF}}$
pin (the pin remains low). This pin can be used to indicate that the UPI-41A 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, $\mathrm{P}_{27}$ becomes the $\overline{D A C K}$ (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

| 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $D_{1}$ |  |  |  |  |  |  |  |

8041AH ENHANCEMENTS OVER 8041A

1. The RESET input on the 8041 AH was changed to include a 2 stage synchronizer to support reliable reset operation for 12 MHz operation.
2. As noted in the status register description, during the time that the host CPU is reading the status register, the 8041AH is prevented from updating or is 'locked out.'
3. When EA is enabled on the 8041 A , the program counter is placed on Port 1 and the lower two bits of Port 2. On the 8041 AH , this information is multiplexed with PORT DATA (see port timing diagrams at end of this data sheet).
4. The 8041 AH additionally supports single step mode as described in the pin description section.

## APPLICATIONS



Figure 3. 8085AH-8041AH Interface


Figure 5. 8041AH-8243 Keyboard Scanner

## PROGRAMMING, VERIFYING, AND ERASING THE 8741A 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 |
| V DD $^{\text {PROG }}$ | Programming Power Supply |



Figure 4. 8048AH-8041AH Interface


Figure 6. 8041AH Matrix Printer Interface $\qquad$

WARNING:
An attempt to program a missocketed 8741 A will result in severe damage to the part. An indication of a properly socketed part is the appearance of the SYNC clock output. The lack of this clock may be used to disable the programmer.

The Program/Verify sequence is:

1. $\mathrm{A}_{0}=0 \mathrm{~V}, \overline{\mathrm{CS}}=5 \mathrm{~V}, \mathrm{EA}=5 \mathrm{~V}, \overline{\mathrm{RESET}}=0 \mathrm{~V}, \mathrm{TESTO}=5 \mathrm{~V}$, $V_{D D}=5 \mathrm{~V}$, clock applied or internal oscillator operating, BUS and PROG floating.
2. Insert 8741A in programming socket
3. TEST $0=0 \mathrm{v}$ (select program mode)
4. $E A=23 V$ (activate program model) $^{1}$
5. Address applied to BUS and P20-1
6. $\overline{\text { RESET }}=5 v$ (latch address)
7. Data applied to BUS ${ }^{2}$
8. $\quad V_{D D}=25 v$ (programming power) ${ }^{2}$
9. $\mathrm{PROG}=0 \mathrm{v}$ followered by one 50 ms pulse to $23 \mathrm{~V}^{2}$
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}}=\mathrm{Ov}$ and repeat from step 5
15. Programmer should be at conditions of step 1 when 8741 A is removed from socket.

## NOTE:

1. When verifying $R O M, E A=12 V$.
2. Not used in verify ROM procedure.

## 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 A is exposure to shortwave ultraviolet light which has a wavelength of $2537 \AA \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 8741A 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.

## 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
*NOTICE: 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}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | $\begin{aligned} & \text { 8041AH/ } \\ & \text { 8041AH-2 } \end{aligned}$ |  | 8641A/8741A |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $V_{\text {IL }}$ | Input Low Voltage (Except XTAL1, XTAL2, RESET | -0.5 | 0.8 | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\text {ILI }}$ | Input Low Voltage (8XTAL1, XTAL2, RESET) | -0.5 | 0.6 | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (Except XTAL1, XTAL2, RESET | 2.0 | $\mathrm{V}_{\mathrm{cc}}$ | 2.0 | $\mathrm{V}_{\mathrm{Cc}}$ |  |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage (XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 3.8 | $\mathrm{V}_{\mathrm{CC}}$ | 3.8 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) |  | 0.45 |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\mathrm{P}_{10} \mathrm{P}_{17}, \mathrm{P}_{20} \mathrm{P}_{27}$, Sync) |  | 0.45 |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage (Prog) |  | 0.45 |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (All Other Outputs) | 2.4 |  | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| IL | Input Leakage Current ( $T_{0}, T_{1}, \overline{R D}, \overline{W R}$, $\left.\overline{\mathrm{CS}}, \mathrm{A}_{0}, \mathrm{EA}\right)$ |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\text {IN }} \geqslant \mathrm{V}_{\text {CC }}$ |
| lofl | Output Leakage Current ( $D_{0}-D_{7}$, High Z State) |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \\ & \leqslant \mathrm{~V}_{\mathrm{OUT}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{l}_{\mathrm{LI}}$ | Low Input Load Current ( $\mathrm{P}_{10} \mathrm{P}_{17}, \mathrm{P}_{20} \mathrm{P}_{27}$ ) |  | 0.5 |  | 0.5 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| ILI1 | Low Input Load Current ( $\overline{\mathrm{RESET}}$, $\overline{\mathrm{SS}}$ ) |  | 0.2 |  | 0.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| IDD | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 15 |  | 15 | mA | Typical $=5 \mathrm{~mA}$ |
| $\begin{aligned} & \mathrm{I}_{\mathrm{CC}}+ \\ & \mathrm{I}_{\mathrm{DD}} \\ & \hline \end{aligned}$ | Total Supply Current |  | 125 |  | 125 | mA | Typical $=60 \mathrm{~mA}$ |
| $\mathrm{IIH}^{\text {H }}$ | Input Leakage Current |  | 100 |  | 100 | NA | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 10 |  | 10 | pF |  |
| $\mathrm{Cl}_{1} \mathrm{O}$ | I/O Capacitance |  | 20 |  | 20 | pF |  |

## D.C. CHARACTERISTICS—PROGRAMMING $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=25 \mathrm{~V} \pm 1 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| V DOH | VDD Program Voltage High Level | 24.0 | 26.0 | V |  |
| VODL | 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 | 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 |  |

A.C. CHARACTERISTICS ( $T_{C C}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{S S}=0 \mathrm{~V}, \mathrm{~V}_{C C}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%$ )

## DBB READ

| Symbol | Parameter | 8041AH |  | 8041AH-2 |  | 8641A/8741A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {AR }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 | " | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After $\overline{\mathrm{RD}} \uparrow$ | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RR }}$ | $\overline{\mathrm{RD}}$ Pulse Width | 160 |  | 160 |  | 250 |  | ns |
| ${ }^{\text {t }}$ AD | $\overline{C S}, A_{0}$ to Data Out Delay |  | 130 |  | 130 |  | 225 | $n s^{[1]}$ |
| trD | $\overline{\mathrm{RD}} \downarrow$ to Data Out Delay |  | 130 |  | 130 |  | 225 | $n s^{[1]}$ |
| $t_{\text {DF }}$ | $\overline{\mathrm{RD}} \uparrow$ to Data Float Delay |  | 85 |  | 85 |  | 100 | ns |
| ${ }_{t}{ }_{C r}$ | Cycle Time (Except 8741A-8) | 2 | 15 | 1.25 | 15 | 2.5 | 15 | $\mu \mathrm{s}^{[2]}$ |
| ${ }^{t} \mathrm{CY}$ | Cycle Time (8741A-8) |  |  |  |  | 4.17 | 15 | $\mu \mathrm{s}^{[3]}$ |

DBB WRITE

| Symbol | Parameter | Min. | Max. | Min. | Max. | Min. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{WR}} \downarrow$ | 0 |  | 0 |  | 0 |  | ns |
| $t_{W A}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {WW }}$ | $\overline{W R} \uparrow$ Pulse Width | 160 |  | 160 |  | 250 |  | ns |
| $t_{\text {DW }}$ | Data Setup to $\overline{W R} \uparrow$ | 130 |  | 130 |  | 150 |  | ns |
| $t_{\text {WD }}$ | Data Hold After $\overline{W R} \uparrow$ | 0 |  | 0 |  | 0 |  | ns |

## NOTES:

1. $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
2. $8,12,6 \mathrm{MHz} \mathrm{XTAL}$ respectively.
3. 3.6 MHz XTAL .

## A.C. CHARACTERISTICS—PROGRAMMING $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=25 \mathrm{~V} \pm 1 \mathrm{~V}\right)$

| 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 }} 1$. | 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 | $\mathrm{V}_{\text {DD }}$ Setup Time to PROG 1 | 4tcy |  |  |  |
| tVODH | VDD Hold Time After PROG ! | 0 |  |  |  |
| tpw | Program Pulse Width | 50 | 60 | mS |  |
| tiw | 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}}$ | 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 | RESET Setup Time Before EA 1. | 4tcy |  |  |  |

Note: If TEST 0 is high, t ${ }_{\text {DO }}$ can be triggered by $\overline{\text { RESET } 1 . ~}$

## A.C. CHARACTERISTICS <br> DMA

|  | Parameter | 8041AH |  | 8041AH-2 |  | 8641A/8741A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{ACC}}$ | $\overline{\text { DACK }}$ to $\overline{W R}$ or $\overline{\mathrm{RD}}$ | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{t}$ CAC | $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ to $\overline{\mathrm{DACK}}$ | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }}$ ACD | $\overline{\text { DACK }}$ to Data Valid |  | 130 |  | 130 |  | 225 | ns |
| ${ }^{\text {t }}$ CRQ | $\overline{\mathrm{RD}}$ or $\overline{W R}$ to DRQ Cleared |  | 90 |  | 90 |  | 200 | $n \mathrm{~s}^{[1]}$ |

## A.C. CHARACTERISTICS

PORT 2
$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | 8041AH |  | 8041AH-2 |  | 8641A/8741A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ${ }^{t} \mathrm{CP}$ | Port Control Setup Before Falling Edge of PROG | 100 |  | 80. |  | 110 |  | $n s^{[1]}$ |
| $t_{\text {PC }}$ | Port Control Hold After Falling Edge of PROG |  |  | 60 |  | 100 |  | $n s^{[2]}$ |
| $t_{\text {PR }}$ | PROG to Time P2 Input Must Be Valid |  | 650 |  | 650 |  | 810 | $n s^{[1]}$ |
| tpF | Input Data Hold Time | 0 | 150 | 0 | 150 | 0 | 150 | $n s^{[2]}$ |
| ${ }^{\text {t }}$ PP | Output Data Setup time |  |  | 200 |  | 250 |  | $n s^{[1]}$ |
| tPD | Output Data Hold Time |  |  |  |  | 65 |  | $n s^{[2]}$ |
| tpp | PROG Pulse Width |  |  | 700 |  | 1200 |  | ns |

NOTES: 1. $C_{L}=80 \mathrm{pF}$ 2. $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$.
A.C. TESTING INPUT, OUTPUT WAVEFORM


## CRYSTAL OSCILLATOR MODE


A.C. TESTING LOAD CIRCUIT


DRIVING FROM EXTERNAL SOURCE

LC OSCILLATOR MODE


EACH C SHOULD BE APPROXIMATELY 20 pF. INCLUDING STRAY CAPACITANCE.

## WAVEFORMS

READ OPERATION-DATA BUS BUFFER REGISTER


## WAVEFORMS (Continued)

WRITE OPERATION—DATA BUS BUFFER REGISTER


## WAVEFORMS (Continued)



The 8741A 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.


## WAVEFORMS (Continued)



## PORT TIMING DURING EA



ON THE RISING EDGE OF SYNC AND EA IS ENABLED, PORT DATA IS VALID AND CAN BE
STROBED. ON THE TRAILING EDGE OF SYNC THE PROGRAM COUNTER CONTENTS ARE
available.

Table 2. UPI ${ }^{\text {TM }}$ Instruction Set

| Mnemonic | Description | Bytes | Cycles |
| :---: | :---: | :---: | :---: |
| ACCUMULATOR |  |  |  |
| ADD A, Rr | Add register to A | 1 | 1 |
| ADD A, @Rr | Add data memory to A | 1 | 1 |
| ADD A, \#data | Add immediate to $A$ | 2 | 2 |
| ADDC A, Rr | Add register to A with carry | 1 | 1 |
| ADDC A, @Rr | Add data memory to A with carry | 1 | 1 |
| ADDC A, \#data | Add immediate to A with carry | 2 | 2 |
| ANL A, Rr | AND register to A | 1 | 1 |
| ANL A, @Rr | AND data memory to A | 1 | 1 |
| ANL A, \#data | AND immediate to A | 2 | 2 |
| ORL A, Rr | OR register to A | 1 | 1 |
| ORL A, @Rr | OR data memory to $A$ | 1 | 1 |
| ORL A, \#data | OR immediate to A | 2 | 2 |
| XRL A, Rr | Exclusive OR register to A | 1 | 1 |
| XRL A, @Rr | Exclusive OR data memory to A | 1 | 1 |
| XRL A, \#data | Exclusive OR immediate to A | 2 | 2 |


| Mnemonic | Description | Bytes | Cycles |
| :---: | :---: | :---: | :---: |
| 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 |

Table 2. UPI ${ }^{\text {TM }}$ Instruction Set (Continued)

| Mnemonic | Description | Bytes | Cycles |
| :---: | :---: | :---: | :---: |
| ACCUMULATOR |  |  |  |
| 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 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 |
| INPUT/OUTPUT |  |  |  |
| IN A, Pp | Input port toA | 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 |
| MOV STS, A | $A_{4}-A_{7}$ to Bits 4-7 of Status | 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 |
| TIMER/COUNTER |  |  |  |
| MOV A, T | Read Timer/Counter | 1 | 1 |
| MOV T, A | Load Timer/Counter | 1 | 1 |
| STRT T | Start Timer | 1 |  |
| STRT CNT | start Counter |  | 1 |
| STOP TCNT | Stop Timer/Counter | 1 | 1 |
| EN TCNTI | Enable Timer/ Counter Interrupt | 1 | 1 |
| DIS TCNTI | Disable Timer/ Counter Interrupt | 1 | 1 |
| CONTROL |  |  |  |
| EN DMA | Enable DMA Handshake Lines | 1 | 1 |
| EN I | Enable IBF Interrupt | 1 | 1 |
| DIS I | Disable IBF Interrupt | 1 | 1 |
| EN FLAGS | Enable Master Interrupts | 1 | 1 |
| SEL RB0 | Select register bank 0 | 1 | 1 |
| SEL RB1 | Select register bank 1 | 1 | 1 |
| NOP | No Operation | 1 | 1 |


| Mnemonic | Description | Bytes | Cycles |
| :---: | :---: | :---: | :---: |
| REGISTERS |  |  |  |
| INC Rr | Increment register | 1 | 1 |
| INC@Rr | Increment data memory | 1 | 1 |
| DEC Rr | Decrement register | 1 | 1 |
| SUBROUTINE |  |  |  |
| CALL addr | Jump to subroutine | 2 | 2 |
| RET | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |
| FLAGS |  |  |  |
| 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 F1 Flag | 1 | 1 |
| CPL F1 | Complement F1 Flag | 1 | 1 |
| BRANCH |  |  |  |
| JMP addr | Jump unconditional | 2 | 2 |
| JMPP @A | Jump indirect | 1 | 2 |
| DJNZ Rr, addr | Decrement register and jump | 2 | 2 |
| JC addr | Jump on Carry $=1$ | 2 | 2 |
| JNC addr | Jump on Carry $=0$ | 2 | 2 |
| $J Z$ addr | Jump on A Zero | 2 | 2 |
| JNZ addr | Jump on A not Zero | 2 | 2 |
| JT0 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 FO Flag $=1$ | 2 | 2 |
| JF1 addr | Jump on F1 Flag=1 | 2 | 2 |
| JTF addr | Jump on Timer Flag $=1$, Clear Flag | 2 | 2 |
| JNIBF addr | Jump on IBF Flag $=0$ | 2 | 2 |
| JOBF addr | Jump on OBF Flag $=1$ | 2 | 2 |
| JBb addr | Jump on Accumulator Bit | 2 | 2 |

# 8042/8742 <br> UNIVERSAL PERIPHERAL INTERFACE 8-BIT MICROCOMPUTER 

## - 8042/8742: 12 MHz

- Pin, Software and Architecturally Compatible with 8041A/8741A/8041AH
- 8-Bit CPU plus ROM, RAM, I/O, Timer and Clock in a Single Package
- $2048 \times 8$ ROM/EPROM, $128 \times 8$ RAM, 8 -Bit Timer/Counter, 18 Programmable I/O Pins
- One 8-Bit Status and Two Data Registers for Asynchronous Slave-to-Master Interface
- DMA, Interrupt, or Polled Operation Supported
- Fully Compatible with MCS-48™, MCS-51 ${ }^{\text {TM }}$, MCS-80™, MCS-85 ${ }^{\text {TM }}$, and iAPX-86, 88 Microprocessor Families


## - Interchangeable ROM and EPROM Versions

- Expandable I/O
- RAM Power-Down Capability
- Over 90 Instructions: 70\% Single Byte

\author{

- Single 5V Supply
}

The Intel $8042 / 8742$ is a general-purpose Universal Peripheral Interface that allows the designer to grow his own customized solution for peripheral device control. It contains a low-cost microcomputer with 2K of program memory, 128 bytes of data memory, 8 -bit CPU, I/O ports, 8 -bit timer/counter, and clock generator in a single 40 -pin package. Interface registers are included to enable the UPI device to function as a peripheral controller in the MCS-48 ${ }^{\mathrm{TM}}$,


The 8042/8742 is software, pin, and architecturally compatible with the $8041 \mathrm{AH}, 8741 \mathrm{~A}$. The $8042 / 8742$ doubles the onchip memory space to allow for additional features and performance to be incorporated in upgraded 8041AH/8741A designs. For new designs, the additional memory and performance of the 8042/8742 extends the UPI concept to more complex motor control tasks, 80 -column printers and process control applications as examples.
To allow full user flexibility, the program memory is available as ROM in the 8042 version or as UV-erasable EPROM in the 8742 version. The 8742 and the 8042 are fully pin compatible for easy transition from prototype to production level designs. The 8642 is a one-time programmable (at the factory) 8742 which can be ordered as the first 25 pieces of a new 8042 order. The substitution of 8642 's for 8042 's allows for very fast turnaround for initial code verification and evaluation results.

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 8042), single-step mode for debug, and dual working register banks.


Figure 1. Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| TEST 0 , TEST 1 | $\begin{array}{r} 1 \\ 39 \end{array}$ | 1 | Test Inputs: Input pins which can be directly tested using conditional branch instructions. <br> Frequency Reference: TEST $1\left(T_{1}\right)$ also functions as the event timer input (under software control). TEST 0 ( $\mathrm{T}_{0}$ ) is used during PROM programming and verification in the 8742. |
| XTAL 1 , <br> XTAL 2 | $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | 1 | Inputs: Inputs for a crystal, LC or an external timing signal to determine the internal oscillator frequency. |
| $\overline{\text { RESET }}$ | 4 | 1 | Reset: Input used to reset status flipflops and to set the program counter to zero. <br> $\overline{\text { RESET }}$ is also used during PROM programming and verification. |
| $\overline{\text { SS }}$ | 5 | 1 | Single Step: Single step input used in conjunction with the SYNC output to step the program through each instruction. |
| $\overline{\mathrm{CS}}$ | 6 | 1 | Chip Select: Chip select input used to select one UPI microcomputer out of several connected to a common data bus. |
| EA | 7 | 1 | External Access: External access input which allows emulation, testing and PROM/ROM verification. This pin should be tied low if unused. |
| $\overline{\mathrm{RD}}$ | 8 | 1 | Read: I/O read input which enables the master CPU to read data and status words from the OUTPUT DATA BUS BUFFER or status register. |
| $\mathrm{A}_{0}$ | 9 | 1 | Command/Data Select: Address input used by the master processor to indicate whether byte transfer is data ( $A_{0}=0, F 1$ is reset) or command ( $A_{0}=1, F 1$ is set). |
| $\overline{W R}$ | 10 | 1 | Write: I/O write input which enables the master CPU to write data and command words to the UPI INPUT DATA BUS BUFFER. |


| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| SYNC | 11 | 0 | Output Clock: Output signal which occurs once per UPI-42 instruction cycle. SYNC can be used as a strobe for external circuitry; it is also used to synchronize single step operation. |
| $\begin{aligned} & \mathrm{D}_{0}-\mathrm{D}_{7} \\ & \text { (BUS) } \end{aligned}$ | 12-19 | 1/0 | Data Bus: Three-state, bidirectional DATA BUS BUFFER lines used to interface the UPI-42 microcomputer to an 8-bit master system data bus. |
| $\mathrm{P}_{10}-\mathrm{P}_{17}$ | 27-34 | 1/0 | Port 1: 8-bit, PORT 1 quasi-bidirectional I/O lines. |
| $\mathrm{P}_{20}-\mathrm{P}_{27}$ | $\begin{aligned} & 21-24 \\ & 35-38 \end{aligned}$ | 1/0 | Port 2: 8-bit, PORT 2 quasi-bidirectional I/O lines. The lower 4 bits ( $\mathrm{P}_{20^{-}}$ $\mathrm{P}_{23}$ ) interface directly to the 8243 I/O expander device and contain address and data information during PORT 4-7 access. The upper 4 bits $\left(\mathrm{P}_{24}-\mathrm{P}_{27}\right)$ can be programmed to provide interrupt Request and DMA Handshake capability. Software control can configure $P_{24}$ as Output Buffer Full (OBF) interrupt, $\mathrm{P}_{25}$ as Input Buffer Full ( $\overline{\mathrm{IBF}}$ ) interrupt, $P_{26}$ as DMA Request (DRQ), and $P_{27}$ as DMA ACKnowledge ( $\overline{\mathrm{DACK}}$ ). |
| PROG | 25 | 1/0 | Program: Multifunction pin used as the program pulse input during PROM programming. <br> During I/O expander access the PROG pin acts as an address/data strobe to the 8243. This pin should be tied high if unused. |
| $\mathrm{V}_{C c}$ | 40 |  | Power: +5 V main power supply pin. |
| $V_{D D}$ | 26 |  | Power: +5 V during normal operation. +21 V during programming operation. Low power standby pin in ROM version. |
| $\mathrm{V}_{\mathrm{ss}}$ | 20 |  | Ground: Circuit ground potential. |

## UPI-42 FEATURES

1. Two Data Bus Buffers, one for input and one for output. This allows a much cleaner Master/Slave protocol.

2. 8 Bits of Status

| $\mathrm{ST}_{7}$ | $\mathrm{ST}_{6}$ | $\mathrm{ST}_{5}$ | $\mathrm{ST}_{4}$ | $\mathrm{~F}_{1}$ | $\mathrm{~F}_{0}$ | $\mathrm{IBF}^{\prime}$ | 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}_{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{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$.


During the time that the host CPU is reading the status register, the $8042 / 8742$ is prevented from updating this register or is 'locked out.'
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 $P_{24}$ disables the OBF pin (the pin remains low). This pin can be used to indicate that valid data is available from the UPI. 41A (in Output Data Bus Buffer).

If "EN FLAGS" has been executed, $P_{25}$ becomes the $\overline{\text { IBF }}$ (Input Buffer Full) pin. A "1" written to $P_{25}$ enables the $\overline{\mathrm{IBF}}$ pin (the pin outputs the inverse of the IBF Status Bit). A " 0 " written to $\mathrm{P}_{25}$ disables the $\overline{\mathrm{BF}}$
pin (the pin remains low). This pin can be used to indicate that the UPI-42 is ready for data.


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, $\mathrm{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

6. The RESET input on the $8042 / 8742$ includes a 2-stage synchronizer to support reliable reset operation for 12 MHz operation.
7. When EA is enabled on the $8042 / 8742$, the program counter is placed on Port 1 and the lower three bits of Port $2\left(M S B=P_{22}, L S B=P_{10}\right)$. On the 8042/8742 this information is multiplexed with PORT DATA (see port timing diagrams at end of this data sheet).
8. The $8042 / 8742$ supports single step mode as described in the pin description section.

## APPLICATIONS



Figure 3. 8085AH-8042/8742 Interface


Figure 5. 8042/8742-8243 Keyboard Scanner


Figure 4. $\mathbf{8 0 4 8 \mathrm { H }}$-8042/8742 Interface


PROGRAMMING, VERIFYING, AND ERASING THE 8742 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 12MHz) |
| $\overline{\text { Reset }}$ | Initialization and Address Latching |
| Test 0 | Selection of Program or Verify Mode |
| EA | Activation of Program/Verify Modes |
| BUS | Addreṣs 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 8742 will result in severe damage to the part. An indication of a properly socketed part is the appearance of the SYNC clock output. The lack of this clock may be used to disable the programmer.

The Program/Verify sequence is:

1. $A_{0}=0 \mathrm{~V}, \overline{\mathrm{CS}}=5 \mathrm{~V}, \mathrm{EA}=5 \mathrm{~V}, \overline{\mathrm{RESET}}=0 \mathrm{~V}, \mathrm{TESTO}=5 \mathrm{~V}$, $V_{D D}=5 \mathrm{~V}$, clock applied or internal oscillator operating, BUS and PROG floating.
2. Insert 8742 in programming socket
3. TEST $0=0 \mathrm{v}$ (select program mode)
4. $E A=18 \mathrm{~V}$ (active program mode)*
5. Address applied to BUS and $P_{20-22}$
6. $\overline{\text { RESET }}=5 v$ (latch address)
7. Data applied to BUS**
8. $V_{D D}=21 \mathrm{~V}$ (programming power)**
9. $\mathrm{PROG}=0 \mathrm{v}$ followed by one 50 ms pulse to 21 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 8742 is removed from socket
*When verifying ROM, EA $=12 \mathrm{~V}$.
**Not used in verifying ROM procedure.

## 8742 Erasure Characteristics

The erasure characteristics of the 8742 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 8742 in approximately 3 years while it would take ap-
proximately one week to cause erasure when exposed to direct sunlight. If the 8742 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 8742 window to prevent unintentional erasure.

The recommended erasure procedure for the 8742 is exposure to shortwave ultraviolet light which has a wavelength of $2537 \AA \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 8742 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.

## 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
$\qquad$ -0.5 V to +7 V
Power Dissipation 1.5 Watt
*NOTICE: 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}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | 8042 |  | 8742/8642 |  | Units | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (Except XTAL1, XTAL2, RESET) | -0.5 | 0.8 | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\text {IL } 1}$ | Input Low Voltage (XTAL1, XTAL2, RESET) | -0.5 | 0.6 | $-0.5$ | 0.6 | V |  |
| $\mathrm{V}_{1 \text { H }}$ | Input High Voltage (Except XTAL1, XTAL2, RESET) | 2.2 | $\mathrm{V}_{\mathrm{cc}}$ | 2.2 | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{H} 1}$ | Input High Voltage (XTAL1, XTAL2, RESET) | 3.8 | $\mathrm{V}_{\mathrm{Cc}}$ | 3.8 | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage ( $\mathrm{Do}_{0} \mathrm{D}_{7}$ ) |  | 0.45 |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\mathrm{P}_{10} \mathrm{P}_{17}, \mathrm{P}_{20} \mathrm{P}_{27}$, Sync) |  | 0.45 |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage (PROG) |  | 0.45 |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  | 2.4 |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (All Other Outputs) | 2.4 |  | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| IIL | Input Leakage Current ( $\mathrm{T}_{0}, \mathrm{~T}_{1}$, RD, WR, CS, $\mathrm{A}_{0}, \mathrm{EA}$ ) |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \geq \mathrm{V}_{\text {CC }}$ |
| lofl | Output Leakage Current ( $\mathrm{D}_{0}-\mathrm{D}_{7}$, High Z State) |  | $\pm 10$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \\ & \leq \mathrm{V}_{\mathrm{OUT}} \leq \mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Low Input Load Current ( $\mathrm{P}_{10} \mathrm{P}_{17}, \mathrm{P}_{20} \mathrm{P}_{27}$ ) |  | 0.5 |  | 0.5 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{l}_{\text {LI1 }}$ | Low Input Load Current (RESET, SS) |  | 0.2 |  | 0.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 15 |  | 15 | mA | Typical $=5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{CC}}+\mathrm{I}_{\text {DD }}$ | Total Supply Current |  | 125 |  | 125 | mA | Typical $=60 \mathrm{~mA}$ |
| $\mathrm{IIH}^{\text {r }}$ | Input Leakage Current |  | 100 |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 10 |  | 10 | pF |  |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance |  | 20 |  | 20 | pF |  |

## D.C. CHARACTERISTICS—PROGRAMMING $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=21 \mathrm{~V} \pm 1 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{D O H}$ | VDD Program Voltage High Level | 20.0 | 21.0 | V |  |
| $V_{D D L}$ | VDD Voltage Low Level | 475 | 5.25 | V |  |
| $V_{P H}$ | PROG Program Voltage High Level | 17.5 | 18.5 | V |  |
| $V_{P L}$ | PROG Voltage Low Level |  | 02 | V |  |
| $V_{E A H}$ | EA Program or Verify Voltage High Level | 17.5 | 18.5 | V |  |
| $V_{E A L}$ | EA Voltage Low Level |  | 5.25 | V |  |
| IDD $^{\text {ID }}$ | 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 |  |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{S S}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%\right)$ DBB READ

| Symbol | Parameter | 8042 |  | 864218742 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {AR }}$ | CS, $A_{0}$ Setup to RD1 | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | CS, $\mathrm{A}_{0}$ Hold After RD1 | 0 |  | 0 |  | ns |
| $t_{\text {RR }}$ | RD Pulse Width | 160 |  | 160 |  | ns |
| $t_{\text {AD }}$ | CS, $A_{0}$ to Data Out Delay |  | 130 |  | 130 | ns ${ }^{[1]}$ |
| $\mathrm{t}_{\mathrm{RD}}$ | RDI to Data Out Delay |  | 130 |  | 130 | $n \mathrm{~s}^{[1]}$ |
| $t_{\text {dF }}$ | RDt to Data Float Delay |  | 85 |  | 85 | ns |
| $\mathrm{t}_{\mathrm{Cr}}$ | Cycle Time | 1.25 | 15 | 1.25 | 15 | $\mu \mathrm{S}^{[2]}$ |

DBB WRITE

| Symbol | Parameter | Min. | Max. | Min. | Max. | Units |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | CS, A Setup to WR | 0 |  | 0 |  | ns |
| $t_{\text {WA }}$ | CS, A A Hold After WR $t$ | 0 |  | 0 |  | ns |
| $t_{\text {WW }}$ | WR Pulse Width | 160 |  | 160 |  | ns |
| $t_{\text {DW }}$ | Data Setup to WR $t$ | 130 |  | 130 |  | ns |
| $t_{\text {WD }}$ | Data Hold After WR $t$ | 0 |  | 0 |  | ns |

## NOTES:

1. $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.
2. 12 MHzXTAL .

## A.C. CHARACTERISTICS—PROGRAMMING $\left(T_{A}=25^{\circ} \mathrm{C} \pm 5^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{DD}}=21 \mathrm{~V} \pm 1 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | Address Setup Time to $\overline{\text { RESET }}$ I | 4tcy |  |  |  |
| twa | Address Hold Time After $\overline{\text { RESET }} 1$ | 4tcy |  |  |  |
| tow | Data in Setup Time to PROG 1 | 4tcy |  |  |  |
| two | Data in Hold Time After PROG ! | 4tcy |  |  |  |
| tph | $\overline{\text { RESET }}$ Hold Time to Verify | 4icy |  |  |  |
| tVDDW | $\mathrm{V}_{\text {DD }}$ Setup Time to PROG 1 | 4tcy |  |  |  |
| tVODH | VDD Hold Time After PROG ! | 0 |  |  |  |
| tow | Program Pulse Width | 50 | 60 | mS |  |
| tiw | 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 |  |  |  |
| $t_{r}, t_{f}$ | VDD and PROG Rise and Fall Times | 0.5 | 2.0 | $\mu \mathrm{S}$ |  |
| tcy | CPU Operation Cycle Time | 5.0 |  | $\mu \mathrm{S}$ |  |
| tre | RESET Setup Time Before EA 1. | 4tcy |  |  |  |

Note: If TEST 0 is high, tDO can be triggered by $\overline{\text { RESET } 1 . ~}$

## A.C. CHARACTERISTICS DMA

| Symbol | Parameter | 8042 |  | 8642/8742 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {ACC }}$ | DACK to WR or RD | 0 |  | 0 |  | ns |
| $t_{\text {cac }}$ | RD or WR to DACK | 0 |  | 0 |  | ns |
| $t_{A C D}$ | DACK to Data Valid |  | 130 |  | 130 | ns |
| $t_{\text {cRQ }}$ | RD or WR to DRQ Cleared |  | 100 |  | 100 | $n s^{[1]}$ |

NOTE:

1. $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
A.C. CHARACTERISTICS PORT $2\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | 8042 |  | 8642/8742 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{C P}$ | Port Control Setup Before Falling Edge of PROG | 80 |  | 100 |  | $\mathrm{ns}{ }^{[1]}$ |
| $t_{\text {PC }}$ | Port Control Hold After Falling Edge of PROG | 60 |  | 60 |  | $\mathrm{ns}{ }^{[2]}$ |
| $t_{\text {PR }}$ | PROG to Time P2 Input Must Be Valid |  | 650 |  | 650 | $n \mathrm{~s}^{[1]}$ |
| $t_{\text {PF }}$ | Input Data Hold Time | 0 | 150 | 0 | 150 | $\mathrm{ns}{ }^{[2]}$ |
| $t_{\text {DP }}$ | Output Data Setup Time | 200 |  | 200 |  | $n \mathrm{~s}^{[1]}$ |
| $t_{\text {PD }}$ | Output Data Hold Time | 60 |  | 60 |  | $n \mathrm{n}^{[2]}$ |
| $t_{\text {PP }}$ | PROG Pulse Width | 700 |  | 700 |  | ns |

NOTES:

1. $C_{L}=80 \mathrm{pF}$.
2. $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$.
A.C. TESTING INPUT, OUTPUT WAVEFORM


CRYSTAL OSCILLATOR MODE

A.C. TESTING LOAD CIRCUIT


DRIVING FROM EXTERNAL SOURCE


LC OSCILLATOR MODE


## WAVEFORMS

## READ OPERATION—DATA BUS BUFFER REGISTER



WRITE OPERATION—DATA BUS BUFFER REGISTER


## WAVEFORMS (Continued)



VERIFY MODE (ROM/EPROM)


NOTES:

1. PROG MUST FLOAT IF EA IS LOW (i.e., $=21 \mathrm{~V}$ ) OR IF TEST $_{0}=5$ V FOR THE 8742 . FOR THE 8042 PROG MUST ALWAYS FLOAT.
2. $A_{0}$ MUST BE HELD LOW (i.e., $=0$ V) DURING PROGRAM/VERIFY MODES.
3. TEST 0 MUST BE HELD HIGH.

The 8742 EPROM can be programmed by the following Intel product:

1. Universal PROM Programmer (UPP series) peripheral of the Intellec ${ }^{\circledR}$ Development System with a UPP-549 Personality Card.

## WAVEFORMS (Continued)

## DMA



## PORT 2



## PORT TIMING DURING EA



ON THE RISING EDGE OF SYNC AND EA IS ENABLED, PORT DATA IS VALID AND CAN BE STROBED. ON THE TRAILING EDGE OF SYNC THE PROGRAM COUNTER CONTENTS ARE available.

Table 2. UPI ${ }^{\text {TM }}$ Instruction Set

| Mnemonic | Description | Bytes | Cycles |
| :---: | :---: | :---: | :---: |
| ACCUMULATOR |  |  |  |
| ADD A, Rr | Add register to $A$ | 1 | 1 |
| ADD A, @Rr | Add data memory to $A$ | 1 | 1 |
| ADD A, \#data | Add immediate to A | 2 | 2 |
| ADDC A, Rr | Add register to $A$ with carry | 1 | 1 |
| ADDC A, @Rr | Add data memory to A with carry | 1 | 1 |
| ADDC A, \#data | Add immediate to A with carry | 2 | 2 |
| ANL A, Rr | AND register to A | 1 | 1 |
| ANL A, @Rr | AND data memory to A | 1 | 1 |
| ANL A, \#data | AND immediate to A | 2 | 2 |
| ORL A, Rr | OR register to $A$ | 1 | 1 |
| ORL A, @Rr | OR data memory to A | 1 | 1 |
| ORL A, \#data | OR immediate to $A$ | 2 | 2 |
| XRL A, Rr | Exclusive OR register to A | 1 | 1 |
| XRL A, @Rr | 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 |
| INPUT/OUTPUT |  |  |  |
| IN A, Pp | Input port toA | 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 |
| MOV STS, A | $A_{4}-A_{7}$ to Bits 4-7 of Status | 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 |


| Mnemonic | Description | Bytes | Cycles |
| :---: | :---: | :---: | :---: |
| 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 |
| STRT T | Start Timer | 1 | 1 |
| STRT CNT | start Counter | 1 | 1 |
| STOP TCNT | Stop Timer/Counter |  | 1 |
| EN TCNTI | Enable Timer/ Counter Interrupt | 1 | 1 |
| DIS TCNTI | Disable Timer/ Counter Interrupt | 1 | 1 |
| CONTROL |  |  |  |
| EN DMA | Enable DMA Handshake Lines | 1 | 1 |
| EN I | Enable IBF Interrupt | 1 | , |
| DIS I | Disable IBF Interrupt | 1 | 1 |
| EN FLAGS | Enable Master Interrupts | 1 | 1 |
| SEL RB0 | Select register bank 0 | 1 | 1 |
| SEL RB1 | Select register bank 1 | 1 | 1 |
| NOP | No Operation | 1 | 1 |
| REGISTERS |  |  |  |
| INC Rr | Increment register | 1 | 1 |
| INC @Rr | Increment data memory | 1 | 1 |
| DEC Rr | Decrement register | 1 | 1 |
| SUBROUTINE |  |  |  |
| CALL addr | Jump to subroutine | 2 | 2 |
| RET | Return | 1 | 2 |
| RETR | Return and restore status | 1 | 2 |

Table 2. UPI ${ }^{\text {TM }}$ Instruction Set (Continued)

| Mnemonic | Description | Bytes | Cvcles |
| :---: | :---: | :---: | :---: |
| FLAGS |  |  |  |
| 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 F1 Flag | 1 | 1 |
| CPL F1 | Complement F1 Flag | 1 | 1 |
| BRANCH |  |  |  |
| JMP addr | Jump unconditional | 2 | 2 |
| JMPP @A | Jump indirect | 1 | 2 |
| DJNZ Rr, addr | Decrement register and jump | 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 T0=1 | 2 | 2 |
| JNTO addr | Jump on T0 $=0$ | 2 | 2 |
| JT1 addr | Jump on T1 $=1$ | 2 | 2 |
| JNT1 addr | Jump on $\mathrm{T} 1=0$ | 2 | 2 |
| JFO addr | Jump on FO Flag=1 | 2 | 2 |
| JF1 addr | Jump on F1 Flag=1 | 2 | 2 |
| JTF addr | Jump on Timer Flag $=1$, Clear Flag | 2 | 2 |
| JNIBF addr | Jump on IBF Flag $=0$ | 2 | 2 |
| JOBF addr | Jump on OBF Flag $=1$ | 2 | 2 |
| JBb addr | Jump on Accumulator Bit | 2 | 2 |

8231A

## ARITHMETIC PROCESSING UNIT

- Fixed Point Single and Double Precision (16/32 Bit)
- Floating Point Single Precision (32 Bit)
- Binary Data Formats
- Add, Subtract, Multiply and Divide
- Trigonometric and Inverse Trigonometric Functions
- Square Roots, Logarithms, Exponentiation
- Float to Fixed and Fixed to Float Conversions


## - Stack Oriented Operand Storage

- Compatible with MCS-80 ${ }^{\text {TM }}$ and MCS-85 ${ }^{\text {TM }}$ Microprocessor Families
- Direct Memory Access or Programmed I/O Data Transfers
- End of Execution Signal
- General Purpose 8-Bit Data Bus Interface
- Standard 24 Pin Package
- +12 Volt and +5 Volt Power Supplies
- Advanced N-Channel Silicon Gate HMOS Technology

The Intel ${ }^{\oplus}$ 8231A Arithmetic Processing Unit (APU) is a monolithic HMOS LSI device that provides high performance fixed and floating point arithmetic and floating point trigonometric operations. It may be used to enhance the mathematical capability of a wide variety of processor-oriented systems. Chebyshev polynomials are used in the implementation of the APU algorithms.

All transfers, including operand, result, status and command information, take place over an 8-bit bidirectional data bus. Operands are pushed onto an internal stack and commands are issued to perform operations on the data in the stack. Results are then available to be retrieved from the stack.

Transfers to and from the APU may be handled by the associated processor using conventional programmed I/O, or may be handled by a direct memory access controller for improved performance. Upon completion of each command, the APU issues an end of execution signal that may be used as an interrupt by the CPU to help coordinate program execution.
In January 1981 Intel will be converting from 8231 to 8231 A. The 8231A provides enhancements over the 8231 to allow use in both asynchronous and synchronous systems.


Figure 1. Block Diagram
Figure 2. Pin Configuration

## Table 1. Pin Description

| Symbol | $\operatorname{Pin}$ No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ | 2 |  | Power: +5 Volt power supply. |
| $V_{D D}$ | 16 |  | Power: +12 Volt power supply. |
| $\mathrm{V}_{\text {SS }}$ | 1 |  | Ground. |
| CLK | 23 | 1 | Clock: An external, TTL compatible, timing source is applied to the CLK pin. |
| RESET | 22 | 1 | Reset: The active high reset signal provides initialization for the chip. RESET also terminates any operation in progress. RESET clears the status register and places the 8231A into the idle state. Stack contents and command registers are not affected ( 5 clock cycles). |
| $\overline{\mathrm{CS}}$ | 18 | 1 | Chip Select: $\overline{C S}$ is an active low input signal which selects the 8231A and enables communication with the data bus. |
| $\mathrm{A}_{0}$ | 21 | 1 | Address: In conjunction with the $\overline{\mathrm{RD}}$ and WR signals, the $A_{0}$ control line establishes the type of communication that is to be performed with the 8231A as shown below: |
| $\mathrm{A}_{0}$ |  | $\overline{\text { RD }}$ | $\overline{\text { WR }}$ - Function |
| 0 0 1 1 1 |  | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 0 \\ & \hline \end{aligned}$ | 0 Enter data byte into stack <br> 1 Read data byte from stack <br> 0 Enter command <br> 1 Read status |
| $\overline{\mathrm{RD}}$ | 20 | 1 | Read: This active low input indicates that data or status is to be read from the 8231A if CS is low. |
| $\overline{W R}$ | 19 | 1 | Write: This active low input indicates that data or a command is to be written into the 8231A if CS is low. |
| $\overline{\text { EACK }}$ | 3 | 1 | End of Execution: This active low input clears the end of execution output signal (END). If EACK is tied low, the END output will be a pulse that is one clock period wide. |
| $\overline{\text { SVACK }}$ | 4 | 1 | Service Request: This active low input clears the service request output (SVREQ). |
| END | 24 | 0 | End: This active low, open-drain output indicates that execution of the previously entered command is complete. It can be used as an interrupt request and is cleared by EACK, RESET or any read or write access to the 8231 . |


| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :--- |$|$| SVREQ |
| :--- |
| S |
| READY |
| 17 |

## COMMAND STRUCTURE

Each command entered into the 8231A consists of a single 8 -bit byte having the format illustrated below:


Bits $0-4$ select the operation to be performed as shown in the table. Bits $5-6$ select the data format appropriate to the selected operation. If bit 5 is a 1 , a fixed point data format is specified. If bit 5 is a 0 , floating point format is specified. Bit 6 selects the precision of the data to be operated upon by fixed point commands only (if bit $5=0$, bit 6 must be 0 ). If bit 6 is a 1 , single-precision ( 16 -bit) operands are assumed. If bit 6 is a 0 , doubleprecision (32-bit) operands are indicated. Results are undefined for all illegal combinations of bits in the command byte. Bit 7 indicates whether a service request is to be issued after the command is executed. If bit 7 is a 1 , the service request output (SVREQ) will go high at the conclusion of the command and will remain high until reset by a low level on the service acknowledge pin (SVACK) or until completion of execution of the succeeding command where service request (bit 7 ) is 0. Each command issued to the 8231A requests post execution service based upon the state of bit 7 in the command byte. When bit 7 is a 0 , SVREQ remains low.

Table 2. 32-Bit Floating Point Instructions

| Instruction | Description | $\begin{aligned} & \text { Hex }{ }^{(1)} \\ & \text { Code } \end{aligned}$ |  | Stack Contents ${ }^{(2)}$ After Execution A B C D |  |  | Status Flags ${ }^{(4)}$ Affected |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ACOS | Inverse Cosine of A |  | 6 | R | U | $\cup \quad U$ | S, Z, E |
| ASIN | Inverse Sine of A | 0 | 5 | R |  | $\cup \cup$ | S, Z, E |
| ATAN | Inverse Tangent of $A$ | 0 | 7 | R | B | $\cup \mathrm{U}$ | S, Z |
| CHSF | Sign Change of $A$ | 1 | 5 | R | B | C D | S, Z |
| COS | Cosine of A (radians) | 0 | 3 | R | B | U U | S, Z |
| EXP | $e^{A}$ Function | 0 | A | R | B | $\cup \mathrm{U}$ | S, Z, E |
| FADD | Add A and B | 1 | 0 | R | C | D U | S, Z, E |
| FDIV | Divide B by A |  | 3 | R | C | D U | S, Z, E |
| FLTD | 32-Bit Integer to Floating Point Conversion | 1 | C | R | B | C U | S, Z |
| FLTS | 16-Bit Integer to Floating Point Conversion |  | D | R | B | C U | S, Z |
| FMUL | Multiply A and B | 1 | 2 | R | C | D U | S, Z, E |
| FSUB | Subtract A from B | 1 | 1 | R | C | D U | S, Z, E |
| LOG | Common Logarithm (base 10) of A | 0 | 8 | R | B | U U | S, Z, E |
| LN | Natural Logarithm of A | 0 | 9 | R | B | U U | S, Z, E |
| POPF | Stack Pop |  | 8 | B | C | D A | S, Z |
| PTOF | Stack Push |  | 7 | A | A | B C | S, Z |
| PUPI | Push $\pi$ onto Stack |  | A | R | A | B C | S, Z |
| PWR | $B^{\text {A }}$ Power Function | 0 | B | R | C | $\cup \cup$ | S, Z, E |
| SIN | Sine of A (radians) | 0 | 2 | R | B |  | S, Z |
| SQRT | Square Root of $A$ | 0 | 1 | R | B | $C$ U | S, Z, E |
| TAN | Tangent of A (radians) | 0 | 4 | R | B | $\cup \quad U$ | S, Z, E |
| XCHF | Exchange $A$ and $B$ |  | 9 | B | A | C D | S, Z |

Table 3. 32-Bit Integer Instructions

| Instruction | Description | $\begin{gathered} \text { Hex }{ }^{(1)} \\ \text { Code } \end{gathered}$ | Stack Contents ${ }^{(2)}$ After Execution A B C D | Status Flags ${ }^{(4)}$ Affected |
| :---: | :---: | :---: | :---: | :---: |
| CHSD | Sign Change of $A$ | 34 | R B C D | S, Z, O |
| DADD | Add A and B | 2 C | $R \quad C \quad D \quad A$ | S, Z, C, E |
| DDIV | Divide B by A | 2 F | $R \quad C \quad D \quad U$ | S, Z, E |
| DMUL | Multiply $A$ and $B$ ( $R=$ lower 32-bits) | 2 E | $R \quad C \quad D \quad U$ | S, Z, O |
| DMUU | Multiply $A$ and $B$ ( $R=$ upper 32-bits) | 36 | $R \quad C \quad D \quad U$ | S, Z, O |
| DSUB | Subtract A from B | 2 D | $R \quad C \quad D \quad A$ | S, Z, C, O |
| FIXD | Floating Point to Integer Conversion | 1 E | $R \quad B \quad C \quad U$ | S, Z, O |
| POPD | Stack Pop | 38 | B C D A | S, Z |
| PTOD | Stack Push | 37 | A A B C | S, Z |
| XCHD | Exchange A and B | 39 | B A C D | S, Z |

Table 4. 16-Bit Integer Instructions

| Instruction | Description | $\begin{aligned} & \text { Hex(1) } \\ & \text { Code } \end{aligned}$ | $\begin{gathered} \text { Stack Contents }{ }^{(3)} \\ \text { After Execution } \\ A_{U} A_{L} B_{U} B_{L} C_{U} \quad C_{L} D_{U} \quad D_{L} \end{gathered}$ | Status Flags ${ }^{(4)}$ Affected |
| :---: | :---: | :---: | :---: | :---: |
| CHSS | Change Sign of $A_{U}$ | 74 | $R \quad A_{L} \quad B_{U} B_{L} C_{U} C_{L} D_{U} D_{L}$ | S, Z, O |
| FIXS | Floating Point to Integer Conversion | 1 F | $R \quad B_{U} B_{L} C_{U} C_{L} \cup \cup U$ | S, Z, O |
| POPS | Stack Pop | 78 | $A_{L} B_{U} B_{L} C_{U} C_{L} D_{U} D_{L} A_{U}$ | S, Z |
| PTOS | Stack Push | 7 7 | $A_{U} A_{U} A_{L} B_{U} B_{L} C_{U} C_{L} D_{U}$ | S, Z |
| SADD | Add $A_{U}$ and $A_{L}$ | 6 C | $R B_{U} B_{L} C_{U} C_{L} D_{U} D_{L} A_{U}$ | S, Z, C, E |
| SDIV | Divide $A_{L}$ by $A_{U}$ | 6 F | $R \quad B_{U} B_{L} C_{U} C_{L} D_{U} \quad D_{L} U$ | S, Z, E |
| SMUL | Multiply $A_{L}$ by $A_{U}: R=$ lower 16 -bits) | 6 E | $R \quad B_{U} B_{L} C_{U} C_{L} D_{U} \quad D_{L} U$ | S, Z, E |
| SMUU | Multiply $A_{L}$ by $A_{U}$ ( $R=$ upper 16-bits) | 76 | $R B_{U} B_{L} C_{U} C_{L} D_{U} D_{L} U$ | S, Z, E |
| SSUB | Subtract $A_{U}$ from $A_{L}$ | 6 D | R. $B_{U} B_{L} C_{U} C_{L} D_{U} D_{L} A_{U}$ | S, Z, C, E |
| XCHS | Exchange $A_{U}$ and $A_{L}$ | 79 | $A_{L} A_{U} B_{U} B_{L} C_{U} C_{L} D_{U} D_{L}$ | S, Z |
| NOP | No Operation | 00 | $A_{U} A_{L} B_{U} B_{L} C_{U} C_{L} D_{U} D_{L}$ |  |

Notes: 1. In the hex code column, SVREQ is a 0.
2. The stack initially is composed of four 32-bit numbers ( $\mathrm{A}, \mathrm{B}, \mathrm{C}, \mathrm{D}$ ). A is equivalent to Top Of Stack (TOS) and B is Next On Stack (NOS). Upon completion of a command the stack is composed of: the result (R); undefined (U); or the initial contents (A, B, C, or D).
3. The stack initially is composed of eight 16 -bit numbers ( $A_{U}, A_{L}, B_{U}, B_{L}, C_{U}, C_{L}, D_{U}, D_{L}$ ). $A_{U}$ is the TOS and $A_{L}$ is NOS. Upon completion of a command the stack is composed of: the result (R); undefined ( $U$ ); or the initial contents ( $A_{U}, A_{L}, B_{U}, B_{L}, \ldots$ ).
4. Nomenclature: Sign (S); Zero (Z); Overflow (O); Carry (C); Error Code Field (E).

## DATA FORMATS

The 8231A arithmetic processing unit handles operands in both fixed point and floating point formats. Fixed point operands may be represented in either single (16-bit operands) or double precision (32-bit operands), and are always represented as binary, two's complement values.

## SINGLE PRECISION FIXED POINT FORMAT



DOUBLE PRECISION FIXED POINT FORMAT


The sign (positive or negative) of the operand is located in the most significant bit (MSB). Positive values are represented by a sign bit of zero $(S=0)$. Negative values are represented by the two's complement of the corresponding positive value with a sign bit equal to $1(S=1)$. The range of values that may be accommodated by each of these formats is $-32,768$ to $+32,767$ for single precision and $-2,147,483,648$ to $+2,147,483,647$ for double precision.
Floating point binary values are represented in a format that permits arithmetic to be performed in a fashion analogous to operations with decimal values expressed in scientific notation.

$$
\left(5.83 \times 10^{2}\right)\left(8.16 \times 10^{1}\right)=\left(4.75728 \times 10^{4}\right)
$$

In the decimal system, data may be expressed as values between 0 and 10 times 10 raised to a power that effectively shifts the implied decimal point right or left the number of places necessary to express the result in conventional form (e.g., 47,572.8). The value-portion of the data is called the mantissa. The exponent may be either negative or positive.
The concept of floating point notation has both a gain and a loss associated with it. The gain is the ability to represent the significant digits of data with values spanning a large dynamic range limited only by the capacity of the exponent field. For example, in decimal notation if the exponent field is two digits wide, and the mantissa is five digits, a range of values (positive or negative) from $1.0000 \times 10^{-99}$ to $9.9999 \times 10^{+99}$ can be accommodated. The loss is that only the significant digits of the value can be represented. Thus there is no distinction in this representation between the values 123451 and 123452, for example, since each would be expressed as: $1.2345 \times 10^{5}$. The sixth digit has been discarded. In most applications where the dynamic range of values to be represented is large, the loss of significance, and hence accuracy of results, is a minor consideration. For greater precision a fixed point format could be chosen, although with a loss of potential dynamic range.

The 8231A is a binary arithmetic processor and requires that floating point data be represented by a fractional mantissa value between .5 and 1 multiplied by 2 raised to an appropriate power. This is expressed as follows:

$$
\text { value }=\text { mantissa } \times 2^{\text {exponent }}
$$

For example, the value 100.5 expressed in this form is $0.11001001 \times 2^{7}$. The decimal equivalent of this value may be computed by summing the components (powers of two) of the mantissa and then multiplying by the exponent as shown below:

$$
\begin{aligned}
\text { value } & =\left(2^{-1}+2^{-2}+2^{-5}+2^{-8}\right) \times 2^{7} \\
& =0.5+0.25+0.03125+0.00290625) \times 128 \\
& =0.78515625 \times 128 \\
& =100.5
\end{aligned}
$$

## FLOATING POINT FORMAT

The format for floating point values in the 8231A is given below. The mantissa is expressed as a 24 -bit (fractional) value; the exponent is expressed as a two's complement 7 -bit value having a range of -64 to +63 . The most significant bit is the sign of the mantissa ( $0=$ positive, $1=$ negative), for a total of 32 bits. The binary point is assumed to be to the left of the most significant mantissa bit (bit 23). All floating point data values must be normalized. Bit 23 must be equal to 1 , except for the value zero, which is represented by all zeros.


The range of values that can be represented in this format is $\pm\left(2.7 \times 10^{-20}\right.$ to $\left.9.2 \times 10^{18}\right)$ and zero.

## FUNCTIONAL DESCRIPTION

## STACK CONTROL

The user interface to the 8231 A includes access to an 8 level 16 -bit wide data stack. Since single precision fixed point operands are 16 -bits in length, eight such values may be maintained in the stack. When using double precision fixed point or floating point formats four values may be stored. The stack in these two configurations can be visualized as shown below:


Data are written onto the stack, eight bits at a time, in the order shown (A1, A2, A3, . . ). Data are removed from the stack in reverse byte order (A4, A3, A2 ...). Data should be entered onto the stack in multiples of the number of bytes appropriate to the chosen data format.

## DATA ENTRY

Data entry is accomplished by bringing the chip select ( $\overline{\mathrm{CS}}$ ), the command/data line ( $\mathrm{A}_{0}$ ), and WR low, as shown in the timing diagram. The entry of each new data word "pushes down" the previously entered data and places the new byte on the top of stack (TOS). Data on the bottom of the stack prior to a stack entry are lost.

## DATA REMOVAL

Data are removed from the stack in the 8231A by bringing chip select ( $\overline{C S}$ ), command/data ( $A_{0}$ ), and $\overline{R D}$ low as shown in the timing diagram. The removal of each data word redefines TOS so that the next successive byte to be removed becomes TOS. Data removed from the stack rotates to the bottom of the stack.

## COMMAND ENTRY

After the appropriate number of bytes of data have been entered onto the stack, a command may be issued to perform an operation on that data. Commands which require two operands for execution (e.g., add) operate on the TOS and NOS values. Single operand commands operate only on the TOS.
Commands are issued to the 8231A by bringing the chip select ( $\overline{\mathrm{CS}}$ ) line low, command data ( $\mathrm{A}_{0}$ ) line high, and $\overline{W R}$ line low as indicated by the timing diagram. After a command is issued, the CPU can continue execution of its program concurrently with the 8231A command execution.

## COMMAND COMPLETION

The 8231A signals the completion of each command execution by lowering the End Execution line (END). Simultaneously, the busy bit in the status register is cleared and the Service Request bit of the command register is checked. If it is a " 1 " the service request output level (SVREQ) is raised. $\overline{\mathrm{END}}$ is cleared on receipt of an active low End Acknowledge (EACK) pulse. Similarly, the service request line is cleared by recognition of an active low Service Acknowledge (SVACK) pulse.

## READY OPERATION

An active high ready (READY) is provided. This line is high in its quiescent state and is pulled low by the 8231A under the following conditions:

1. A previously initiated operation is in progress (device busy) and Command Entry has been attempted. In this case, the READY line will be pulled low and remain low until completion of the current command execution. It will then go high, permitting entry of the new command.
2. A previously initiated operation is in progress and stack access has been attempted. In this case, the READY line will be pulled low, will remain in that state until execution is complete, and will then be raised to permit completion of the stack access.
3. The 8231 A is not busy, and data removal has been requested. READY will be pulled low for the length of time necessary to transfer the byte from the top of stack to the interface latch, and will then go high, indicating availability of the data.
4. The 8231A is not busy, and a data entry has been requested. READY will be pulled low for the length of time required to ascertain if the preceding data byte, if any, has been written to the stack. If so READY will immediately go high. If not, READY will remain low until the interface latch is free and will then go high.
5. When a status read has been requested, READY will be pulled low for the length of time necessary to transfer the status to the interface latch, and will then be raised to permit completion of the status read. Status may be read whether or not the 8231A is busy.
When READY goes low, the APU expects the bus control signals present at the time to remain stable until READY goes high.

## DEVICE STATUS

Device status is provided by means of an internal status register whose format is shown below:


BUSY: Indicates that 8231A is currently executing a command (1 = Busy)
SIGN: Indicates that the value on the top of stack is negative ( $1=$ Negative)
ZERO: Indicates that the value on the top of stack is zero ( $1=$ Value is zero)
ERROR CODE: This field contains an indication of the validity of the result of the last operation. The error codes are:
0000 - No error
1000 - Divide by zero
0100 - Square root or log of negative number
1100 - Argument of inverse sine, cosine, or
$e^{x}$ too large
XX10 - Underflow
XX01 - Overflow
CARRY: Previous operation resulted in carry or borrow from most significant bit. ( $1=$ Carry/Borrow, $0=$ No Carry/No Borrow.)
If the BUSY bit in the status register is a one, the other status bits are not defined; if zero, indicating not busy, the operation is complete and the other status bits are defined as given above.

## READ STATUS

The 8231A status register can be read by the CPU at any time (whether an operation is in progress or not) by bringing the chip select ( $\overline{\mathrm{CS}})$ low, the command/data line $\left(A_{0}\right)$ high, and lowering $\overline{R D}$. The status register is then gated onto the data bus and may be input by the CPU .

## EXECUTION TIMES

Timing for execution of the 8231A command set is contained below. All times are given in terms of clock cycles. Where substantial variation of execution times
is possible, the minimum and maximum values are quoted; otherwise, typical values are given. Variations are data dependent.
Total execution times may require allowances for operand transfer into the APU, command execution, and result retrieval from the APU. Except for command exe-
cution, these times will be heavily influenced by the nature of the data, the control interface used, the speed of memory, the CPU used, the priority allotted to DMA and Interrupt operations, the size and number of operands to be transferred, and the use of chained calculations, etc.

Table 5. Command Execution Times

| Command <br> Mnemonic | Clock <br> Cycles | Command <br> Mnemonic | Clock <br> Cycles | Command <br> Mnemonic | Clock <br> Cycles | Command <br> Mnemonic | Clock <br> Cycles |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SADD | 17 | FADD | $54-368$ | LN | $4298-6956$ | POPF | 12 |
| SSUB | 30 | FSUB | $70-370$ | EXP | $3794-4878$ | XCHS | 18 |
| SMUL | $84-94$ | FMUL | $146-168$ | PWR | $8290-12032$ | XCHD | 26 |
| SMUU | $80-98$ |  |  |  | 4 | XCHF | 26 |
| SDIV | $84-94$ | FDIV | $154-184$ | NOP | 4 | PUPI | 16 |
| DADD | 21 | SORT | 800 | CHSS | 23 |  |  |
| DSUB | 38 | SIN | 4464 | CHSD | 27 |  |  |
| DMUL | $194-210$ | COS | 4118 | CHSF | 18 |  |  |
| DMUU | $182-218$ |  |  |  |  | 16 |  |
| DDIV | 208 | TAN | 5754 | PTOS |  |  |  |
| FIXS | $92-216$ | ASIN | 7668 | PTOD | 20 |  |  |
| FIXD | $100-346$ | ACOS | 7734 | PTOF | 20 |  |  |
| FLTS | $98-186$ | ATAN | 6006 | POPS | 10 |  |  |
| FLTD | $98-378$ | LOG | $4474-7132$ | POPD | 12 |  |  |

## DERIVED FUNCTION DISCUSSION

Computer approximations of transcendental functions are often based on some form of polynomial equation, such as:
$F(X)=A_{0}+A_{1} X+A_{2} X^{2}+A_{3} X^{3}+A_{4} X^{4} \ldots$
The primary shortcoming of an approximation in this form is that it typically exhibits very large errors when the magnitude of $|X|$ is large, although the errors are small when $|X|$ is smail. With polynomials in this form, the error distribution is markedly uneven over any arbitrary interval.

A set of approximating functions exists that not only minimizes the maximum error but also provides an even distribution of errors within the selected data representation interval. These are known as Chebyshev Polynomials and are are based upon cosine functions. These functions are defined as follows:
$T_{n}(X)=\operatorname{Cos} n \theta$; where $n=0,1,2 \ldots$
$\theta=\operatorname{Cos}^{-1} X$
The various terms of the Chebyshev series can be computed as shown below:

$$
\begin{align*}
T_{0}(X) & =\operatorname{Cos}(0 \cdot \theta)=\operatorname{Cos}(0)=1  \tag{1-4}\\
T_{1}(X) & =\operatorname{Cos}\left(\operatorname{Cos}^{-1} X\right)=X  \tag{1-5}\\
T_{2}(X) & =\operatorname{Cos} 2 \theta=2 \operatorname{Cos}^{2} \theta-1=2 \operatorname{Cos}^{2}\left(\operatorname{Cos}^{-1} X\right)-1  \tag{1-6}\\
& =2 X^{2}-1
\end{align*}
$$

In general, the next term in the Chebyshev series can be recursively derived from the previous term as follows:
$T_{n}(X)=2 X\left[T_{n}-1(X)\right]-T_{n}-2(X) ; n \geqslant 2$
Common logarithms are computed by multiplication of the natural logarithm by the conversion factor 0.43429448 and the error function is therefore the same as that for natural logarithm. The power function is realized by combination of natural log and exponential functions according to the equation:
$X^{Y}=e^{y \operatorname{Ln} x}$.
The error for the power function is a combination of that for the logarithm and exponential functions.
Each of the derived functions is an approximation of the true function. Thus the result of a derived function will have an error. The absolute error is the difference between the function's result and the true result. A more useful measure of the function's error is relative error (absolute error/true result). This gives a measurement of the significant digits of algorithm accuracy. For the derived functions except LN, LOG, and PWR the relative error is typically $4 \times 10^{-7}$. For PWR the relative error is the summation of the EXP and LN errors, $7 \times 10^{-7}$. For LN and LOG, the absolute error is $2 \times 10^{-7}$.

## APPLICATION INFORMATION

The diagram in Figure 4 shows the interface connections for the APU with operand transfers handled by an 8237 DMA controller, and CPU coordination handled by an Interrupt Controller. The APU interrupts the CPU to indicate that a command has been completed. When the performance enhancements provided by the DMA and Interrupt operations are not required, the APU interface
can be simplified as shown in Figure 3. The 8231A APU is designed with a general purpose 8 -bit data bus and interface control so that it can be conveniently used with any general 8-bit processor.
In many systems it will be convenient to use the microcomputer system clock to drive the APU clock input. In the case of 8080A systems it would be the $\phi 2$ TTL signal. Its cycle time will usually fall in the range of 250 ns to 1000 ns , depending on the system speed.


Figure 3. Minimum Configuration Example


Figure 4. High Performance Configuration Example

## ABSOLUTE MAXIMUM RATINGS*

Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient Temperature Under Bias. . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ $\mathrm{V}_{\mathrm{DD}}$ with Respect to $\mathrm{V}_{\mathrm{SS}} \ldots . . . . . . .$.
$\mathrm{V}_{\mathrm{CC}}$ with Respect to $\mathrm{V}_{\mathrm{SS}} \ldots . . . . . . . .$.
All Signal Voltages with Respect

Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.0W
*NOTICE: 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 effect device reliability.

## D.C. AND OPERATING CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$, $\left.V_{D D}=+12 V \pm 10 \%\right)$

| Parameters | Description | Min. | Typ. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 3.7 |  |  | Volts | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage |  |  | 0.4 | Volts | $\mathrm{IOL}=3.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | Volts |  |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | -0.5 |  | 0.8 | Volts |  |
| ILL | Input Load Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| Iofl | Data Bus Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 50 | 95 | mA |  |
| $I_{\text {do }}$ | $\mathrm{V}_{\mathrm{DD}}$ Supply Current |  | 50 | 95 | mA |  |
| $\mathrm{C}_{0}$ | Output Capacitance |  | 8 |  | pF |  |
| $\mathrm{C}_{1}$ | Input Capacitance |  | 5 |  | pF | $\mathrm{fc}=1.0 \mathrm{MHz}$, Inputs $=0 \mathrm{~V}$ |
| $\mathrm{C}_{10}$ | 1/0 Capacitance |  | 10 |  | pF |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


8231A
PRRCGINONARY
A.C. CHARACTERISTICS $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{S S}=0 \mathrm{~V}, \mathrm{~V}_{C C}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%\right)$

## READ OPERATION

| Symbol | Parameter |  | 8231A-8 |  | 8231A-3 |  | 8231A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{A R}$ | $A_{0}, \overline{C S}$ Setup to $\overline{R D}$ |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | $A_{0}, \overline{\mathrm{CS}}$ Hold from $\overline{\mathrm{RD}}$ |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {R }}$ | READY $\downarrow$ from $\overline{\mathrm{RD}} \downarrow$ Delay ( Note 2) |  |  | 150 |  | 100 |  | 100 | ns |
| $t_{Y R}$ | READY $\uparrow$ to $\overline{\mathrm{RD}} \uparrow$ |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RRR }}$ | READY Pulse Width (Note 3) | Data | $\begin{gathered} 3.5 \mathrm{t}_{\mathrm{CY}} \\ +50 \end{gathered}$ |  | $\begin{gathered} 3.5 t_{\mathrm{CY}} \\ +50 \end{gathered}$ |  | $\begin{gathered} 3.5 \mathrm{tcy} \\ +50 \end{gathered}$ |  | ns |
|  |  | Status | $\begin{gathered} 1.5 \mathrm{t}_{\mathrm{CY}} \\ +50 \end{gathered}$ |  | $\begin{gathered} 1.5 \mathrm{t}_{\mathrm{CY}} \\ +50 \end{gathered}$ |  | $\begin{gathered} 1.5 \mathrm{t} \mathrm{CY} \\ +50 \end{gathered}$ |  | ns |
| $t_{\text {RDE }}$ | Data Bus Enable from $\overline{\mathrm{RD}} \downarrow$ |  | 50 |  | 50 |  | 50 |  | ns |
| ${ }^{\text {t }}$ DRY | Data Valid to READY $\uparrow$ |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {b }}{ }^{\text {b }}$ | Data Float after $\overline{\mathrm{RD}} \uparrow$ |  | 50 | 200 | 50 | 150 | 50 | 100 | ns |

## WRITE OPERATION

| Symbol | Parameter |  | 8231A-8 |  | 8231A-3 |  | 8231 A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {AW }}$ | $A_{0}, \overline{C S}$ Setup to $\overline{W R}$ |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {twa }}$ | $A_{0}, \overline{C S}$ Hold after $\overline{W R}$ |  | 60 |  | 30 |  | 25 |  | ns |
| ${ }^{\text {t }}$ WY | READY $\downarrow$ from $\overline{W R} \downarrow$ Delay (Note 2) |  |  | 150 |  | 100 |  | 100 | ns |
| $t_{Y W}$ | READY $\uparrow$ to $\overline{\mathrm{WR}} \uparrow$ |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RRW }}$ | READY Pulse Width (Note 4) |  |  | 50 |  | 50 |  | 50 | ns |
| ${ }^{\text {t }}$ WI | Write Inactive Time (Note 4) | Command | $4 t_{C Y}$ |  | $4 \mathrm{t}_{\mathrm{Cr}}$ |  | $4 \mathrm{t}_{\mathrm{Cr}}$ |  | ns |
|  |  | Data | $5 \mathrm{t}_{\mathrm{Cr}}$ |  | $5 \mathrm{t}_{\mathrm{Cr}}$ |  | $5 \mathrm{t}_{\mathrm{Cr}}$ |  | ns |
| ${ }^{\text {t }}$ DW | Data Setup to $\overline{W R}$ |  | 150 |  | 100 |  | 100 |  | ns |
| ${ }^{\text {w }}$ D | Data Hold after $\overline{W R}$ |  | 20 |  | 20 |  | 20 |  | ns |

## OTHER TIMINGS

| Symbol | Parameter | 8231A-8 |  | 8231A-3 |  | 8231A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ${ }^{t} \mathrm{CY}$ | Clock Period | 480 | 5000 | 320 | 3300 | 250 | 2500 | ns |
| ${ }^{\text {t }}$ CPH | Clock Pulse High Width | 200 |  | 140 |  | 100 |  | ns |
| $\mathrm{t}_{\mathrm{CPL}}$ | Clock Pulse Low Width | 240 |  | 160 |  | 120 |  | ns |
| ${ }^{\text {t }}$ EE | END Pulse Width (Note 5) | 400 |  | 300 |  | 200 |  | ns |
| $t_{\text {EAE }}$ | $\overline{\text { EACK }} \downarrow$ to $\overline{\text { END }} \uparrow$ Delay |  | 200 |  | 175 |  | 150 | ns |
| $t_{A A}$ | $\overline{\text { EACK }}$ Pulse Width | 100 |  | 75 |  | 50 |  | ns |
| $t_{\text {SA }}$ | $\overline{\text { SVACK }} \downarrow$ to SVREQ $\downarrow$ Delay |  | 300 |  | 200 |  | 150 | ns |
| $\mathrm{t}_{\text {SS }}$ | SVACK Pulse Width | 100 |  | 75 |  | 50 |  | ns |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$, nominal supply voltages and nominal processing parameters.
2. READY is pulled low for both command and data operations.
3. Minimum values shown assume no previously entered command is being executed for the data access. If a previously entered command is being executed, READY low pulse width is the time to complete execution plus the time shown. Status may be read at any time without exceeding the time shown.
4. READY low pulse width is less than 50 ns when writing into the data port or the control port as long as the duty cycle requirement ( $t$ wI) is observed and no previous command is being executed. $t_{W I}$ may be safely violated as long as the extended $t_{R R W}$ that results is observed. If a previously entered command is being executed, READY low pulse width is the time to complete execution plus the time shown. These timings refer specifically to the 8231A.
5. END low pulse width is specified for EACK tied to VSS. Otherwise $t_{\text {EAE }}$ applies.

## WAVEFORMS

READ OPERATION


## WRITE OPERATION



## INTERRUPT OPERATION



SVREQ


# 8232 <br> FLOATING POINT PROCESSING UNIT 

## - Compatible with Proposed IEEE Format and Existing Intel Floating Point Standard

- Single (32-Bit) and Double (64-Bit) Precision Capability


## Add, Subtract, Multiply and Divide Functions

Stack Oriented Operand Storage
General Purpose 8-Bit Data Bus Interface

- Standard 24-Pin Package
- 12V and 5V Power Supplies

■ Compatible with MCS-80™, MCS-85 ${ }^{\text {TM }}$ and MCS-86 ${ }^{\text {TM }}$ Microprocessor Families

- Error Interrupt
- Direct Memory Access or Programmed I/O Data Transfers
- End of Execution Signal
- Advanced N-Channel Silicon Gate HMOS Technology

The Intel 8232 is a high performance floating-point processor unit (FPU). It provides single precision (32-bit) and double precision ( $64-\mathrm{bit}$ ) add, subtract, multiply and divide operations. The 8232 's floating point arithmetic is a subset of the proposed IEEE standard. It can be easily interfaced to enhance the computational capabilities of the host microprocessor.
The operand, result, status and command information transfers take place over an 8 -bit bidirectional data bus. Operands are pushed onto an internal stack by the host processor and a command is issued to perform an operation on the data stack. The results of the operation are available to the host processor from the stack.

Information transfers between the 8232 and the host processor can be handled by using programmed I/O or direct memory access techniques. After completing an operation, the 8232 activates an "end of execution" signal that can be used to interrupt the host processor.


Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Description |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 2 |  | POWER SUPPLY: +5 V power supply |  |  |  |
| $V_{D D}$ | 16 |  | POWER SUPPLY: + 12V power supply |  |  |  |
| $\mathrm{V}_{\text {SS }}$ | 1 |  | GROUND |  |  |  |
| CLK | 23 | 1 | CLOCK: An external timing source connected to the CLK input provides the necessary clocking. |  |  |  |
| RESET | 22 | I | RESET: A HIGH level on this input causes initialization. Reset terminates any operation in progress, and clears the status register to zero. The internal stack pointer is initialized and the contents of the stack may be affected. After a reset the END output, the ERROR output and the SVREQ output will be LOW. For proper initialization, RESET must be HIGH for at least five CLK periods following stable power supply voltages and stable clock. |  |  |  |
| $\overline{\mathrm{CS}}$ | 18 | I | CHIP SELECT: input must be LOW to accomplish any read or write operation to the 8232. <br> To perform a write operation, appropriate data is presented on DB0 through DB7 lines, appropriate logic level on the $A_{0}$ input and the $\overline{C S}$ input is made LOW. Whenever $\overline{W R}$ and $\overline{R D}$ inputs are both HIGH and $\overline{\mathrm{CS}}$ is LOW, READY goes LOW. However, actual writing into the 8232 cannot start until $\overline{W R}$ is made LOW. After initiating the write operation by the HIGH to LOW transition on the $\overline{W R}$ input, the READY output will go HIGH, indicating the write operation has been acknowledged. The $\overline{W R}$ input can go HIGH after READY goes HIGH. The data lines, the $\mathrm{A}_{0}$ input and the $\overline{\mathrm{CS}}$ input can change when appropriate hold time requirements are satisfied. See write timing diagram for details. <br> To perform a read operation an appropriate logic level is established on the $A_{0}$ input and $\overline{\mathrm{CS}}$ is made LOW. The READY output goes LOW because $\overline{W R}$ and $\overline{R D}$ inputs are HIGH. The read operation does not start until the $\overline{R D}$ input goes LOW. READY will go HIGH indicating that read operation is complete and the required information is available on the DB0 through DB7 lines. This information will remain on the data lines as long as $\overline{R D}$ is LOW. The $\overline{R D}$ input can return HIGH anytime after READY goes HIGH. The $\overline{C S}$ input and $A_{0}$ input can change anytime after $\overline{\mathrm{RD}}$ retürns HIGH. See read timing diagram for details. If the $\overline{\mathrm{CS}}$ is tied LOW permanently, READY will remain LOW until the next 8232 read or write access. |  |  |  |
| $\mathrm{A}_{0}$ | 21 | 1 | ADDRESS: The $A_{0}$ input together with the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs determines the type of transfer to be performed on the data bus as follows: |  |  |  |
|  |  |  | $A_{0}$ | RD | WR | Function |
|  |  |  | 0 0 1 1 | 1 <br> 0 <br> 1 <br> 0 | 0 1 0 1 | Enter data byte into stack Read data byte from stack Enter command Read status |


| Symbol | Pin No. | Type | Name and Description |
| :--- | :---: | :---: | :--- |
| RD | 20 | I | READ: A LOW level on this input is used <br> to read information from an internal <br> location and gate that information onto <br> the data bus. The CS input must be LOW <br> to accomplish the read operation. The A0 <br> input determines what internal location is <br> to be read. See Ao, CS input descriptions <br> and read timing diagram for details. If the <br> END output was HIGH, performing any <br> read operation will make the END output <br> go LOW after the HIGH to LOW transition <br> of the RD input (assuming CS is LOW). If <br> the ERROR output was HIGH, performing <br> a status register read operation will make <br> the ERROR output LOW. This will happen <br> after the HIGH to LOW transition of the |
| RD input (assuming CS is LOW). |  |  |  |$|$

8232

Table 1. Pin Description (Continued)

| Symbol | Pin No. | Type | $\begin{array}{l}\text { Name and Description }\end{array}$ |
| :--- | :--- | :--- | :--- |
| SVREQ | 5 | 0 | $\begin{array}{l}\text { SERVICE REQUEST: A HIGH on this out- } \\ \text { put Indicates completion of a command. } \\ \text { In this sense this output is the same as the } \\ \text { END output. However, the SVREQ output } \\ \text { will go HIGH at the completion of a } \\ \text { command only when the Service Request } \\ \text { Enable bit was set to 1. The SVREQ can be } \\ \text { cleared (i.e., go LOW) by activating the }\end{array}$ |
| ERROR | 6 | $\begin{array}{l}\text { SVACK input LOW or initializing the } \\ \text { device using the RESET. Also, the SVREQ } \\ \text { will be automatically cleared after } \\ \text { completion of any command that has the } \\ \text { service request bit as 0. }\end{array}$ |  |
| O | $\begin{array}{l}\text { ERROR: Output goes HIGH to indicate that } \\ \text { the current command execution resulted } \\ \text { in an error condition. The error conditions } \\ \text { are: attempt to divide by zero, exponent } \\ \text { overflow and exponent underflow. The } \\ \text { ERROR output is cleared LOW on a status } \\ \text { register read operation or upon RESET. } \\ \text { The ERROR output is derived from the }\end{array}$ |  |  |
| error bits in the status register. These |  |  |  |
| error bits will be updated internally at an |  |  |  |
| appropriate time during a command exe- |  |  |  |
| cution. Thus, ERROR output going HIGH |  |  |  |
| may not coincide with the completion of a |  |  |  |
| command. Reading of the status register |  |  |  |
| can be performed while a command exe- |  |  |  |
| cution is in progress. However, it should |  |  |  |
| be noted that reading the status register |  |  |  |
| clears the ERROR output. Thus, reading |  |  |  |
| the status register while a command |  |  |  |
| execution is in progress may result in an |  |  |  |
| internal conflict with the ERROR output. |  |  |  |$\}$


| Symbol | Pin No. | Type | Name and Description |
| :---: | :---: | :---: | :---: |
| READY | 17 | 0 | READY: Output is a handshake signal used while performing read or write transactions with the 8232. If the $\overline{W R}$ and $\overline{\mathrm{RD}}$ inputs are both HIGH, the READY output goes LOW with the $\overline{C S}$ input in anticipation of a transaction. If $\overline{W R}$ goes LOW to initiate a write transaction with proper signals established on the DB0-DB7, $A_{0}$ inputs, the READY will return HIGH indicating that the write operation has been accomplished. The $\overline{W R}$ can be made HIGH after this event. On the other hand, if a read operation is desired, the $\overline{\mathrm{RD}}$ input is made LOW after activating $\overline{\mathrm{CS}}$ LOW and establishing proper $A_{0}$ input. (The READY will go LOW in response to $\overline{C S}$ going LOW.) The READY will return HIGH, indicating completion of read. The $\overline{R D}$ can return HIGH after this event. It should be noted that a read or write operation can be initiated without any regard to whether a command execution is in progress or not. Proper device operation is assured by obeying the READY output indication as described. |
| $\begin{aligned} & \text { DB0- } \\ & \text { DB7 } \end{aligned}$ | 8-15 | 1/O | DATA BUS: Bidirectional lines are used to transfer command, status and operand information between the device and the host processor. DBO is the least significant and DB7 is the most significant bit position. HIGH on a data bus line corresponds to 1 and LOW corresponds to 0 . <br> When pushing operands on the stack using the data bus, the least significant byte must be pushed first and the most significant byte last. When popping the stack to read the result of an operation, the most significant byte will be available on the data bus first and the least significant byte will be the last. Moreover, for pushing operands and popping results, the number of transactions must be equal to the proper number of bytes appropriate for the chosen format. Otherwise, the internal byte pointer will not be aligned properly. The single precision format requires 4 bytes and double precision format requires 8 bytes. |

## FUNCTIONAL DESCRIPTION

Major functional units of the 8232 are shown in the block diagram. The 8232 employs a microprogram controlled stack oriented architecture with 17-bit wide data paths.
The Arithmetic Unit receives one of its operands from the Operand Stack. This stack is an eight word by 17 -bit two port memory with last in-first out (LIFO) attributes. The second operand to the Arithmetic Unit is supplied by the internal 17 -bit bus. In addition to supplying the second operand, this bidirectional bus also carries the results from the output of the Arithmetic Unit when required. Writing into the Operand Stack takes place
from this internal 17-bit bus when required. Also connected to this bus are the Constant ROM and Working Registers. The ROM provides the required constants to perform the mathematical operations while the Working Registers provide storage for the intermediate values during command execution.
Communication between the external world and the 8232 takes place on eight bidirectional input/output lines, DB0 through DB7 (Data Bus). These signals are gated to the internal 8 -bit bus through appropriate interface and buffer circuitry. Multiplexing facilities exist for bidirectional communication between the internal eight
and 17-bit buses. The Status Register and Command Register are also located on the 8-bit bus.
The 8232 operations are controlled by the microprogram contained in the Control ROM. The Program Counter supplies the microprogram addresses and can be partially loaded from the Command Register. Associated with the Program Counter is the Subroutine Stack where return addresses are held during subroutine calls in the microprogram. The Microinstruction Register holds the current microinstruction being executed. The register facilitates pipelined microprogram execution. The Instruction Decode logic generates various internal control signals needed for the 8232 operation.

The Interface Control logic receives several external inputs and provides handshake related outputs to facilitate interfacing the 8232 to microprocessors.

## Command Format

The operation of the 8232 is controlled from the host processor by issuing instructions called commands. The command format is shown below.


The command consists of 8 bits; the least significant 7 bits specify the operation to be performed as detailed in Table 1. The most significant bit is the Service Request Enable bit. This bit must be a 1 if SVREQ is to go HIGH at the end of executing a command.

The commands fall into three categories: single precision arithmetic, double precision arithmetic and data manipulation. There are four arithmetic operations that can be performed with single precision (32-bit) or double precision (64-bit) floating-point numbers: add, subtract, multiply and divide. These operations require two operands. The 8232 assumes that these operands are located in the internal stack as Top of Stack (TOS) and Next on Stack (NOS). The result will always be returned to the previous NOS which becomes the new TOS. Results from an operation are of the same precision and format as the operands. The results will be rounded to preserve the accuracy. The actual data formats and rounding procedures are described in a later section. In addition to the arithmetic operations, the 8232 implements eight data manipulating operations. These include changing the sign of a double or single precision operand located in TOS, exchanging single precision operands located at TOS and NOS, as well as pushing and popping single or double precision operands. See also the sections on status register and operand formats.

The execution times of the commands are all data dependent. Table 3 shows one example of each command execution time.

## Operand Entry

The 8232 commands operate on the operands located at the TOS and NOS. Results are returned to the stack at NOS and then popped to TOS. The operands required for the 8232 are one of two formats - single precision floating-point ( 4 bytes) or double precision floatingpoint ( 8 bytes). The result of an operation has the same format as the operands. In other words, operations using single precision quantities always result in a single precision result, while operations involving double precision quantities will result in double precision result.
Operands are always entered into the stack least significant byte first and most significant byte last. The following procedure must be followed to enter operands into the stack:

1. The lower significant operand byte is established on the DB0-DB7 lines.
2. A LOW is established on the $A_{0}$ input to specify that data is to be entered into the stack.
3. The $\overline{\mathrm{CS}}$ input is made LOW. Whenever the $\overline{W R}$ and $\overline{R D}$ inputs are HIGH, the READY output will follow the $\overline{C S}$ input. Thus, READY output will become LOW.
4. After appropriate set up time (see timing diagrams), the WR input is made LOW.
5. Sometime after this event, READY will return HIGH to indicate that the write operation has been acknowledged.
6. Any time after the READY output goes HIGH, the $\overline{W R}$ input can be made HIGH. The DB0-DB7, $A_{0}$ and $\overline{C S}$ inputs can change after appropriate hold time requirements are satisfied (see timing diagrams).

The above procedure must be repeated until all bytes of the operand are pushed into the stack. It should be noted that for single precision operands 4 bytes should be pushed and 8 bytes must be pushed for double precision. Not pushing all the bytes of a quantity will result in byte pointer misalignment.

The 8232 stack can accommodate four single precision quantities or two double precision quantities. Pushing more quantities than the capacity of the stack will result in loss of data which is usual with any LIFO stack.
The stack can be visualized as shown below:


Table 2. 8232 Command Set

## Single Precision Instructions

| Instruction | Description | $\begin{aligned} & \text { Hex }{ }^{1} \\ & \text { Code } \end{aligned}$ | Stack Contents ${ }^{2}$ After Execution A B C D |  |  |  | Status Flags Affected ${ }^{4}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SADD | Add A and B | 01 | R | C | D | U | S, Z, U, V |
| SSUB | Subtract A from B | 02 | R | C | D | U | S, Z, U, V |
| SMUL | Multiply A by B | 03 | R | C | D | U | S, Z, U, V |
| SDIV | Divide $B$ by $A$. If $A$ exponent $=0$, then $\mathrm{R}=\mathrm{B}$. | 04 | R | C | D | U | S, Z, U, V, D |
| CHSS | Change sign of $A^{5}$ | 05 | R | B | C | D | S, Z |
| PTOS | Push stack ${ }^{5}$ | 06 | A* | A | B | C | S, Z |
| POPS | Pop stack | 07 | B | C | D | A | S, Z |
| XCHS | Exchange | 08 | B | A | C | D | S, Z |

Double Precision Instructions

| Instruction | Description | $\begin{aligned} & \text { Hex }{ }^{1} \\ & \text { Code } \end{aligned}$ | Stack Contents ${ }^{3}$ <br> After Execution A B | Status Flags Affected ${ }^{4}$ |
| :---: | :---: | :---: | :---: | :---: |
| DADD | Add A and B | 29 | $R \quad U$ | S, Z, U, V |
| DSUB | Subtract A from B | 2A | $R \quad U$ | S, Z, U, V |
| DMUL | Multiply A by B | 2B | $R \quad U$ | S, Z, U, V |
| DDIV | Divide $B$ by $A$. If $A=0$, then $R=B$. | 2 C | R U | S, Z, U, V, D |
| CHSD | Change sign of $\mathrm{A}^{5}$ | 2D | R B | S, Z |
| PTOD | Push stack ${ }^{5}$ | 2E | A* A | S, Z |
| POPD | Pop stack | 2 F | B A | S, Z |
| CLR | CLR status | 00 | A B |  |

## Notes:

1. In the hex code column, SVREQ bit is a 0 .
2. The stack initially is composed of four 32-bit numbers (A, B, C, D). A is equivalent to Top Of Stack (TOS) and B is Next on Stack (NOS). Upon completion of a command the stack is composed of: the result (R); undefined (U); or the initial contents (A,B,C, or D).
3. The stack initially is composed of two 64-bit numbers (A, B). A is equivalent to Top Of Stack (TOS) and B is Next On Stack (NOS). Upon completion of a command the stack is composed of: the result ( $R$ ); undefined (U); or the initial contents ( $A, B$ ).
4. Any status bit(s) not affected are set to 0 . Nomenclature: Sign (S); Zero (Z); Exponent Underflow (U); Exponent Overflow (V); Divide Exception (D).
5. If the exponent field of $A$ is zero, $R$ or $A^{*}$ will be zero.

Table 3. Execution Times

| Command | TOS | NOS | Result | Clock Periods |
| :---: | :---: | :---: | :---: | :---: |
| SADD | 3F800000 | 3F800000 | 40000000 | 58 |
| SSUB | 3F800000 | 3F800000 | 00000000 | 56 |
| SMUL | 40400000 | 3FC00000 | 40900000 | 198 |
| SDIV | 3F800000 | 40000000 | 3F000000 | 228 |
| CHSS | 3F800000 | - | BF800000 | 10 |
| PTOS | 3F800000 | - | - | 16 |
| POPS | 3F800000 | - | - | 14 |
| XCHS | 3F800000 | 40000000 | - | 26 |
| CHSD | 3FF00000 00000000 | - | BFF00000 00000000 | 24 |
| PTOD | 3FF00000 00000000 | - | - | 40 |
| POPD | 3FF00000 00000000 | - | - | 26 |
| CLR | 3FF00000 00000000 | - | - | 4 |
| DADD | 3FF00000 0A000000 | 3FF00000 00000000 | 3FF00000 0A000000 | 578 |
| DSUB | 3FF00000 A0000000 | 3FF00000 00000000 | 3FF00000 A0000000 | 578 |
| DMUL | BFF80000 00000000 | 3FF80000 00000000 | C0020000 00000000 | 1748 |
| DDIV | BFF80000 00000000 | 3FF80000 00000000 | BFF00000 00000000 | 4560 |

Note: TOS, NOS and result are in hexadecimal; clock period is in decimal.

## Command Initiation

After properly positioning the required operands in the stack, a command may be issued. The procedure for initiating a command execution is the same as that described above for operand entry, except that the $A_{0}$ input is HIGH.

An attempt to issue a new command while the current command execution is in progress is allowed. Under these circumstances, the READY output will not go HIGH until the current command execution is completed.

## Removing the Results

Result from an operation will be available at the TOS. Results can be transferred from the stack to the data bus by reading the stack.

When the stack is read for results, the most significant byte is available first and the least significant byte last.

A result is always of the same precision as the operands that produced it. Thus, when the result is taken from the stack, the total number of bytes popped out should be appropriate with the precision - single precision results are 4 bytes and double precision results are 8 bytes. The following procedure must be used for reading the result from the stack:

1. A LOW is established on the $A_{0}$ input.
2. The $\overline{C S}$ input is made LOW. When $\overline{W R}$ and $\overline{R D}$ inputs are both HIGH, the READY output follows the CS input, thus READY will be LOW.
3. After appropriate set up time (see timing diagrams), the $\overline{R D}$ input is made LOW.
4. Sometime after this, READY will return HIGH, indicating that the data is available on the DB0-DB7 lines. This data will remain on the DB0-DB7 lines as long as the $\overline{\mathrm{RD}}$ input remains LOW.
5. Any time after READY goes HIGH, the $\overline{R D}$ input can return HIGH to complete the transaction.
6. The $\overline{C S}$ and $A_{0}$ inputs can change after appropriate hold time requirements are satisfied (see timing diagram).
7. Repeat this procedure until all bytes appropriate for the precision of the result are popped out.
Reading of the stack does not alter its data; it only adjusts the byte pointer. Note data must be removed in even. byte multiples to avoid a byte pointer misalignment. If more data is popped than the capacity of the stack, the internal byte pointer will wrap around and older data will be read again, consistent with the LIFO stack.

## Reading Status Register

The 8232 status register can be read without any regard to whether a command is in progress or not. The only implication that has to be considered is the effect this might have on the END and ERROR outputs discussed in the signal descriptions.
The following procedure must be followed to accomplish status register reading:

1. Establish HIGH on the $A_{0}$ input.
2. Establish LOW on the $\overline{C S}$ input. Whenever $\overline{W R}$ and $\overline{\mathrm{RD}}$ inputs are HIGH, READY will follow the $\overline{\mathrm{CS}}$ input. Thus, READY will go LOW.
3. After appropriate set up time (see timing diagram), $\overline{R D}$ is made LOW.
4. Sometime after the HIGH to LOW transition of $\overline{R D}$, READY will become HIGH, indicating that status register contents are available on the DB0-DB7 lines. These lines will contain this information as long as $\overline{R D}$ is LOW.
5. The $\overline{\mathrm{RD}}$ input can be returned HIGH any time after READY goes HIGH.
6. The $A_{0}$ input and $\overline{C S}$ input can change after satisfying appropriate hold time requirements (see timing diagram).

## Status Register

The 8232 contains an 8 -bit status register with the following format:


All the bits are initialized to zero upon reset. Also, executing a CLR (Clear Status) command will result in all zero status register bits. A zero in bit 7 indicates that the 8232 is not busy and a new command may be initiated. As soon as a new command is issued, bit 7 becomes 1 to indicate the device is busy and remains 1 until the command execution is complete, at which time it will become 0 . As soon as a new command is issued, status register bits 0-6 are cleared to zero. The status bits will be set as required during the command execution. Hence, as long as bit 7 is 1 , the remainder of the status register bit indications should not be relied upon unless the ERROR occurs. The following is a detailed status bit description.

## Bit 0 Reserved.

Bit 1 Exponent overflow (V). When 1, this bit indicates that the result exponent is more positive than $+127(+1023)$. The exponent is "wrapped" into the negative exponent range, skipping the end values.
Bit 2 Exponent Underflow (U). When 1, this bit indicates that the result exponent is more negative than $-126(-1022)$. The exponent is "wrapped" into the positive range by the number of underflow bits, skipping $-127(-1023)$ and $+128(+1024)$.
Bit 3 Divide Exception (D). When 1, this bit indicates that an attempt to divide by zero is made. Cleared to zero otherwise.

## Bit 4 Reserved.

Bit 5 Zero ( Z ). When 1, this bit indicates that the result returned to TOS after a command is zero. Cleared to zero otherwise.

Bit 6 Sign (S). When 1, this bit indicates that the result returned to TOS is negative. Cleared to zero otherwise.

Bit 7 Busy. When 1, this bit indicates the 8232 is in the process of executing a command. It will become zero after the command execution is complete.

All other status register bits are valid when the Busy bit is zero.

## Data Formats

The 8232 handles floating-point quantities in two different formats - single precision and double precision. These formats are the same as those used by Intel in other products and those proposed by the IEEE Subcommittee on floating point arithmetic.
The single precision quantities are 32 bits long, as shown below:


## Bit 31:

$S=$ Sign of the mantissa. One represents negative and 0 represents positive.

## Bits 23-30:

$\mathrm{E}=$ These 8 bits represent a biased exponent. The bias is $2^{7}-1=127$.

## Bits 0-22:

$M=23$-bit mantissa. Together with the sign bit, the mantissa represents a signed fraction in sign-magnitude notation. There is an implied 1 beyond the most significant bit (bit 22) of the mantissa. In other words, the mantissa is assumed to be a 24 -bit normalized quantity and the most significant bit, which will always be a 1 due to normalization, is implied. The 8232 restores this implied bit internally before performing arithmetic, normalizes the result and strips the implied bit before returning the results to the external data bus. The binary point is between the implied bit and bit 22 of the mantissa.

The quantity N represented by the above notation is


Provided $\mathrm{E} \neq 0$ (reserved for 0 ) or all 1's (illegal). The approximate decimal range for this format is $\pm 1.17 \times 10^{-38}$ to $\pm 3.40 \times 10^{38}$. The format supports 7 significant decimal digits.

A double precision quantity consists of the mantissa sign bit, an 11 -bit biased exponent ( E ), and a 52 -bit mantissa (M). The bias for double precision quantities is $2^{10}-1$. The double precision format is illustrated below.


## Bit 63:

$\mathrm{S}=$ Sign of the mantissa. One represents negative and 0 represents positive.

## Bits 52-62:

$E=$ These 11 bits represent a biased exponent. The bias is $2^{10}-1=1023$.

## Bits 0-51:

$M=52$-bit mantissa. Together with the sign bit the mantissa represents a signed fraction in sign-magnitude notation. There is an implied 1 beyond the most significant bit (bit 51) of the mantissa. In other words, the mantissa is assumed to be a 53 -bit normalized quantity and the most significant bit, which will always be a 1 due to normalization, is implied. The 8232 restores this implied bit internally before performing arithmetic, normalizes the result and strips the implied bit before returning the result to the external data bus. The binary point is between the implied bit and bit 51 of the mantissa.
The quantity N represented by the above notation is

$$
\mathrm{N}=(-1)^{\mathrm{S}} 2^{\mathrm{E}-\overbrace{\left(2^{10}-1\right)}^{\sqrt{-}}(1 . \mathrm{M})} \text { BIAS} \text { BINARY POINT }
$$

Provided $E \neq 0$ (reserved for 0 ) or all 1s (illegal). The approximate decimal range is $\pm 2.22 \times 10^{-308}$ to $\pm 1.80$ $\times 10^{308}$. The format supports 16 significant decimal digits.
The following are some examples of single precision floating point representations:

| Decimal | $\mathbf{S}$ | $\mathbf{E}$ | $\mathbf{M}$ | Binary <br> Floating <br> Point |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 00000000 H |
| 1 | 0 | 127 | 0 | $3 F 800000 \mathrm{H}$ |
| -1 | 1 | 127 | 0 | BF80 0000H |
| 255 | 0 | 134 | .9922 | 437 F 0000 H |
| $\pi$ | 0 | 128 | .5708 | 4049 OFDBH |

## Rounding

One of the main objectives in choosing the 8232's Intel/ IEEE proposed floating point arithmetic was to provide maximum accuracy with no anomalies. This means that a mathematically unsophisticated user will not be "surprised" by some of the results. It is probably possible for a sophisticated user to obtain reliable results from almost any floating point arithmetic. However, in that case there will be an additional burden on the software.
The best example of what might be called the 8232's "safety factor" is the inclusion of guard bits for rounding. The absence of guard bits leads to the problem demonstrated by the following four-bit multiplication:

$$
\begin{aligned}
& .1111 \times 2^{0} \\
& .1000 \times 2^{1} \\
& \hline .01111000 \times 2^{1}
\end{aligned}
$$

Since the last four bits are lost, the normalized result is:

$$
.1110 \times 2^{0}
$$

and the identify function is not valid. In the past this problem has been avoided (hopefully) by relying on excess precision.

Instead the 8232 uses a form of rounding known as "round to even." There are other types of rounding provided for in the proposed IEEE standard, but "round to even," an unbiased rounding scheme, is required. "Round to even" comes into play when a result is exactly halfway between two floating point numbers. In this case the arithmetic produces the "even" number, the one whose last mantissa bit is zero. The 8232 uses three additional bits - the Guard bit (G), the Rounding bit (R), and the "Sticky" bit (S) - to do the rounding. These are bits which hold data shifted out (right) of the accumulator. Rounding is carried out by the following rules, as shown in the following figure, after the result is normalized.

| G | Bit <br> R | $\mathbf{S}$ | Rule |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | No Round |
| 0 | 0 | 1 |  |
| 0 | 1 | 0 | Round Down |
| 0 | 1 | 1 |  |
| 1 | 0 | 0 | Round to Even |
| 1 | 0 | 1 |  |
| 1 | 1 | 0 | Round Up |
| 1 | 1 | 1 |  |

## APPLICATIONS INFORMATION

The diagram in Figure 3 represents the minimum configuration of an 8232 system. The CPU transfers data to and from the 8232 Floating Point Processor using the READY line. The 8232 status is checked using polling by the CPU.

In a high performance configuration (Figure 4), interrupts are used in place of polling. The interrupts are generated for an error condition and to signal the end of execution. Operand transfers are handled by the DMA controller.


Figure 3. Minimum Configuration Example


Figure 4. High Performance Configuration Example

## ABSOLUTE MAXIMUM RATINGS*

Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Ambient Temperature Under Bias ...... $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$\mathrm{V}_{\mathrm{DD}}$ with Respect to $\mathrm{V}_{\mathrm{SS}} \ldots \ldots .$.
$\mathrm{V}_{\mathrm{CC}}$ with Respect to $\mathrm{V}_{\text {SS }} \ldots \ldots . .$.
All Signal Voltages with Respect
to $V_{\text {SS }} \ldots .$.
Power Dissipation. . . . . . . . . . . . . . . . . . . . . . . . . . . . 2.0W
*NOTICE: 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 $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{S S}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 3.7 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage |  |  | 0.4 | V | $\mathrm{l}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input LOW Voltage | -0.5 |  | 0.8 | V |  |
| 1 IL | Input Load Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| Iofl | Data Bus Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS },}+0.45 \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $I_{\text {cc }}$ | $V_{\text {cc }}$ Supply Current |  | 50 | 95 | mA |  |
| IDD | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 50 | 95 | mA |  |
| $\mathrm{C}_{0}$ | Output Capacitance |  | 8 |  | pF |  |
| $\mathrm{C}_{1}$ | Input Capacitance |  | 5 |  | pF | $\mathrm{f}_{\mathrm{C}}=1.0 \mathrm{MHz}$, Inputs $=0 \mathrm{~V}$ |
| $\mathrm{ClO}_{10}$ | I/O Capacitance |  | 10 |  | pF |  |

A.C. CHARACTERISTICS $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%\right)$
read operation

| Symbol | Parameter |  | 8232 |  | 8232-3 |  | 8232-8 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {AR }}$ | $A_{0}, \overline{C S}$ Setup to $\overline{\mathrm{RD}}$ |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | $A_{0}, \overline{C S}$ Hold from $\overline{R D}$ |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }}$ ARY | READY $\downarrow$ from $\mathrm{A}_{0}, \overline{\mathrm{CS}} \downarrow$ Delay ( | ote 2) |  | 100 |  | 100 |  | 150 | ns |
| $t_{Y R}$ | READY $\uparrow$ to $\overline{R D} \uparrow$ |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RRR }}$ | READY Pulse Width (Note 3) | Data | $\begin{aligned} & 3.5 \mathrm{t}_{\mathrm{CY}} \\ & +50 \end{aligned}$ |  | $\begin{aligned} & 3.5 \mathrm{t}_{\mathrm{CY}} \\ & +50 \end{aligned}$ |  | $\begin{aligned} & 3.5 \mathrm{t}_{\mathrm{CY}} \\ & +50 \end{aligned}$ |  | ns |
|  |  | Status | $\begin{gathered} 1.5 \mathrm{t}_{\mathrm{CY}} \\ +50 \end{gathered}$ |  | $\begin{gathered} 1.5 \mathrm{t}_{\mathrm{CY}} \\ +50 \end{gathered}$ |  | $\begin{aligned} & 1.5 \mathrm{t}_{\mathrm{CY}} \\ & +50 \end{aligned}$ |  | ns |
| $t_{\text {RDE }}$ | Data Bus Enable from $\overline{\mathrm{RD}} \downarrow$ |  | 50 |  | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\text {DRY }}$ | Data Valid to READY |  | 0 |  | 0 |  | 0 |  | ns |
| ${ }^{\text {t }}$ DF | Data Float after $\overline{\mathrm{RD}} \uparrow$ |  | 20 | 100 | 20 | 150 | 20 | 200 | ns |

## A.C. CHARACTERISTICS (Continued)

## WRITE OPERATION

| Symbol | Parameter | 8232 |  | $8232 \cdot 3$ |  | 8232.8 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {AW }}$ | $A_{0}, \overline{C S}$ Setup to $\overline{W R}$ | 25 |  | 25 |  | 25 |  | ns |
| ${ }_{\text {t }}$ WA | $A_{0}, \overline{C S}$ Hold after $\overline{W R}$ | 30 |  | 30 |  | 60 |  | ns |
| ${ }^{\text {tawr }}$ | READY $\downarrow$ from $A_{0}, \overline{C S} \downarrow$ Delay (Note 2) |  | 100 |  | 100 |  | 150 | ns |
| ${ }^{\text {Y }}$ W | READY ${ }^{\text {to }} \overline{\mathrm{WR}} \uparrow$ | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {RRW }}$ | READY Pulse Width |  | $\begin{aligned} & t_{\mathrm{AW}} \\ & +50 \end{aligned}$ |  | $\begin{aligned} & t_{\text {AW }} \\ & +50 \end{aligned}$ |  | $\begin{array}{r} t_{\mathrm{AW}} \\ +50 \\ \hline \end{array}$ | ns |
| ${ }^{\text {t }}$ WW | Data Setup to $\overline{W R} \uparrow$ | 100 |  | 100 |  | 150 |  | ns |
| ${ }^{\text {two }}$ | Data Hold after WR $\uparrow$ | 20 |  | 20 |  | 20 |  | ns |

## OTHER TIMINGS

|  | Parameter | 8232 |  | 8232-3 |  | 8232.8 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| ${ }^{t}{ }_{C Y}$ | Clock Period | 250 | 2500 | 320 | 3300 | 480 | 5000 | ns |
| ${ }^{\text {t }}$ CPH | Clock Pulse HIGH Width | 100 |  | 140 |  | 200 |  | ns |
| $\mathrm{t}_{\mathrm{CPL}}$ | Clock Pulse LOW Width | 120 |  | 160 |  | 240 |  | ns |
| $\mathrm{t}_{\mathrm{EE}}$ | END Pulse Width (Note 4) | 200 |  | 300 |  | 400 |  | ns |
| $t_{\text {EAE }}$ | $\overline{\text { EACK }} \downarrow$ to END $\downarrow$ Delay |  | 150 |  | 175. |  | 200 | ns |
| ${ }^{\text {t }}$ A ${ }_{\text {A }}$ | EACK Pulse Width | 50 |  | 75 |  | 100 |  | ns |
| ${ }^{\text {t }}$ SA | SVACK $\downarrow$ to SVREQ $\downarrow$ Delay |  | 100 |  | 200 |  | 300 | ns |
| ${ }^{\text {tss }}$ | $\overline{\text { SVACK Pulse Width }}$ | 50 |  | 75 |  | 100 |  | ns |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$, nominal supply voltages and nominal processing parameters.
2. READY is pulled low for both command and data operations.
3. Minimum values shown assume no previously entered command is being executed for the data access. If a previously entered command is being executed, READY low pulse width is the time to complete execution plus the time shown. Status may be read at any time without exceeding the time shown.
4. END high pulse width is specified for EACK tied to $\mathrm{V}_{\text {SS }}$. Otherwise $t_{\text {EAE }}$ applies.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS

## READ OPERATION



## WRITE OPERATION



INTERRUPT OPERATION


## 8294 <br> DATA ENCRYPTION UNIT

## - Certified by National Bureau of Standards

\author{

- 80 Byte/Sec Data Conversion Rate <br> - 64-Bit Data Encryption Using 56-Bit Kөу <br> - 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
- Periphoral to MCS-86TM, MCS-85 ${ }^{\text {Tm }}$, MCS-80 ${ }^{\mathrm{TM}}$ and MCS-48 ${ }^{\text {TM }}$ Processors
- Implements Federal Information Processing Data Encryption Standard
- Encrypt and Decrypt Modes Available

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 must be encrypted.



Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| NC | 1 |  | No Connection. |
| $\begin{aligned} & \mathrm{X} 1 \\ & \mathrm{X} 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | 1 | Crystal: Inputs for crystal, L-C or external timing signal to determine internal oscillator frequency. |
| $\overline{\text { RESET }}$ | 4 | 1 | Reset: A low signal to this pin resets the 8294. |
| NC | 5 |  | No Connection: No connection or tied high. |
| $\overline{\mathrm{CS}}$ | 6 | 1 | Chip Select: A low signal to this pin enables reading and writing to the 8294. |
| GND | 7 |  | Ground: This pin must be tied to ground. |
| $\overline{\mathrm{RD}}$ | 8 | 1 | Read: An active low read strobe at this pin enables the CPU to read data and status from the internal DEU registers. |
| $\mathrm{A}_{0}$ | 9 | 1 | Address: Address input used by the CPU to select DEU registers during read and write operations. |
| $\overline{W R}$ | 10 | 1 | Write: An active low write strobe at this pin enables the CPU to send data and commands to the DEU. |
| SYNC | 11 | 0 | Sync: High frequency (Clock $\div 15$ ) output. Can be used as a strobe for external circuitry. |
| $\begin{aligned} & \mathrm{D}_{0} \\ & \mathrm{D}_{1} \\ & \mathrm{D}_{2} \\ & \mathrm{D}_{3} \\ & \mathrm{D}_{4} \\ & \mathrm{D}_{5} \\ & \mathrm{D}_{6} \\ & \mathrm{D}_{7} \end{aligned}$ | $\begin{aligned} & 12 \\ & 13 \\ & 14 \\ & 15 \\ & 16 \\ & 17 \\ & 18 \\ & 19 \\ & \hline \end{aligned}$ | I/O | Data Bus: Three-state, bi-directional data bus lines used to transfer data between the CPU and the 8294. |
| GND | 20 |  | Ground: This pin must be tied to ground. |
| $\mathrm{V}_{\mathrm{cc}}$ | 40 |  | Power: +5 volt power input: $+5 \mathrm{~V} \pm$ 10\%. |


| Symbol | $\begin{array}{\|c\|} \hline \text { Pin } \\ \text { No. } \\ \hline \end{array}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| NC | 39 |  | No Connection. |
| $\overline{\text { DACK }}$ | 38 | 1 | DMA Acknowledge: Input signal from the 8257 DMA Controller acknowledging that the requested DMA cycle has been granted. |
| DRQ | 37 | 0 | DMA Request: Output signal to the 8257 DMA Controller requesting a DMA cycle. |
| SRQ | 38 | 0 | Service Request: Interrupt to the CPU indicating that the 8294 is awaiting data or commands at the input buffer. $S R Q=1$ implies $\mathrm{IBF}=0$. |
| OAV | 35 | 0 | Output Available: Interrupt to the CPU indicating that the 8294 has data or status available in its output buffer. $O A V=1$ implies $O B F=1$. |
| NC | 34 |  | No Connection. |
| P6 P5 P4 P3 P2 P1 P0 | $\begin{aligned} & 33 \\ & 32 \\ & 31 \\ & 30 \\ & 29 \\ & 28 \\ & 27 \end{aligned}$ | 0 | Output Port: User output port lines. Output lines available to the user via a CPU command which can assert selected port lines. These lines have nothing to do with the encryption function. At power-on, each line is in a 1 state. |
| $V_{D D}$ | 26 |  | Power: +5 V power input. ( $+5 \mathrm{~V} \pm 10 \%$ ) Low power standby pin. |
| $\mathrm{V}_{C C}$ | 25 |  | Power: Tied high. |
| CCMP | 24 | 0 | Conversion Complete: Interrupt to the CPU indicating that the encryption/ decryption of an 8 -byte block is complete. |
| NC | 23 |  | No Connection. |
| NC | 22 |  | No Connection. |
| NC | 21 |  | No Connection. |

## 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 |
| :---: | :---: | :---: | :---: | :--- |
| $\mathbf{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 $I B F=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 8 byte 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:


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 <br> OP CODE: <br> 

This command puts the 8294 into the decrypt mode.

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 at 8-byte blocks. to 10 convertod using DMA.

## 5 - Write to Output Port

OP CODE:

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 3. A flowchart showing the CPU software to accommodate this sequence is given in Figure 4.


Figure 3. Entering a New Key

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 (CF=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 invatid. 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 4, to flag the end of the new key entry. Then, CF is used to indicate a valid KPE flag.


Figure 4. Flowchart for Entering a New Key

## ENCRYPTING OR DECRYPTING DATA

Figure 5 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 $\mathrm{IBF}=0$ and $\mathrm{CF}=\mathrm{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 $C F=0$ to terminate the read mode. Also, the CCNP interrupt may be used to initiate a service routine which performs the next series of 8 data reads and 8 data writes.


Figure 5. Encrypting/Decrypting Data

Figure 6 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.


Figure 6. Data Conversion Flowcharts

## USING DMA

The timing sequence for data conversions using DMA is shown in Figure 7. This sequence can be better understood when considered in conjunction with the hardware DMA interface in Figure 8. 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-low $\overline{\mathrm{DACK}}$ inputs.


Figure 7. DMA Sequence


Figure 8. DMA Interface

To initiate a DMA transfer, the CPU must first initialize the two DMA channels as shown in the flowchart in Figure 9. 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 9. DMA Flowchart

## SINGLE BYTE COMMANDS

Figure 10 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 11). The CPU must wait until the command is accepted ( $\mathrm{IBF}=0$ ). A data read must then be issued to clear anything the preceding command sequence may have left in the Data Output Buffer.

## CPUDEU HNTERFACE8

Figures 12 through 15 illustrate four interface configurathons used in the CPMYDEU: data transfors. In all cases SRQ will te true (ifientibted) and tBE will beratse when the DEU iscready te ascept data or commands.


Figure 10. Single Byte Commands


Figure 11. Pacify Protocol


Figure 12. Polling Interface


Figure 13. Single Interrupt Interface


Figure 14. Dual Interrupt Interface


Figure 15. 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 16.


Figure 16. 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 17.


Figure 17. Recommended Crystal and L-C Connections

A recommended range of inductance and capacitance combinations is given below:

$$
\begin{aligned}
& \mathrm{L}=120 \mu \mathrm{H} \text { corresponds to } 3 \mathrm{MHz} \\
& \mathrm{~L}=45 \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.8 volts. The recommended connection is shown in Figure 18.


Figure 18. Recommended Connection for External Clock Signal

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\qquad$ $.0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature $\qquad$ $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage on Any Pin With

Respect to Ground . . . . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation 1.5 Watt
*NOTICE: 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 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage (All Except $X_{1}, X_{2}$, RESET) | -0.5 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IL } 1}$ | $\begin{aligned} & \text { Input Low Voltage }\left(\mathrm{X}_{1}, \mathrm{X}_{2},\right. \\ & \text { RESET } \end{aligned}$ | -0.5 |  | 0.6 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (All Except $\left.\mathrm{X}_{1}, \mathrm{X}_{2}, \overline{\mathrm{RESET}}\right)$ | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{H} 1}$ | $\text { Input High Voltage }\left(\mathrm{X}_{1}, \mathrm{X}_{2}\right.$ RESET) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage (All Other Outputs) |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | 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{\bar{A}_{0}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| Iofl | Output Leakage Current ( $D_{0}-D_{7}$, High Z State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | $V_{\text {DD }}$ Supply Current |  | 5 | 15 | mA |  |
| $\mathrm{I}_{\mathrm{DD}}+\mathrm{I}_{C C}$ | Total Supply Current |  | 60 | 125 | mA |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Low Input Load Current (Pins 24, 27-38) |  |  | 0.5 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\text {LI } 1}$ | Low Input Load Current (RESET) |  |  | 0.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{H}}$ | Input High Leakage Current (Pins 24, 27-38) |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  |  | 10 | pF |  |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF |  |

8294
A.C. CHARACTERISTICS $\quad \mathrm{T}_{\mathrm{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 |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{AR}}$ | $\mathrm{CS}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RA}}$ | $\mathrm{CS}, \mathrm{A}_{0}$ Hold After RD $\uparrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RR}}$ | RD Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{AD}}$ | $\overline{\mathrm{CS}, \mathrm{A}_{0} \text { to Data Out Delay }}$ |  | 225 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RD}}$ | $\mathrm{RD} \downarrow$ to Data Out Delay |  | 225 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | $\mathrm{RD} \uparrow$ to Data Float Delay |  | 100 | ns |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Cycle Time | 2.5 | 15 | $\mu \mathrm{~s}$ | 6 MHz Crystal |

DBB WRITE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{W R} \downarrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\text {WA }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{WW}}$ | $\overline{\mathrm{WR}}$ Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\text {DW }}$ | Data Setup to $\overline{W R} \uparrow$ | 150 |  | ns |  |
| $\mathrm{t}_{\text {WD }}$ | Data Hold to $\overline{W R} \uparrow$ | 0 |  | ns |  |

## DMA AND INTERRUPT TIMING

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{\mathrm{ACC}}$ | $\overline{\mathrm{DACK}}$ Setup to Control | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{CAC}}$ | $\overline{\mathrm{DACK}}$ Hold After Control | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{ACD}}$ | $\overline{D A C K}$ to Data Valid |  | 225 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{CRQ}}$ | Control L.E. to DRQ T.E. |  | 200 | ns |  |
| $\mathrm{t}_{\mathrm{Cl}}$ | Control T.E. to Interrupt T.E. |  | $\mathrm{t}_{\mathrm{CY}}+500$ | ns |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

READ OPERATION-OUTPUT BUFFER REGISTER


## WRITE OPERATION-INPUT BUFFER REGISTER



DMA AND INTERRUPT TIMING


## 8295 <br> DOT MATRIX PRINTER CONTROLLER

## - Interfaces Dot Matrix Printers to MCS-48 ${ }^{\text {TM }}$, MCS-80/85 ${ }^{\text {TM }}$, MCS-86 ${ }^{\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. In parallel mode, data transfers are based on polling, interrupts, or DMA. Furthermore, it provides internal buffering of up to 40 characters and contains a $7 \times 7$ matrix character generator accommodating 64 ASCII characters.


Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| PFEED | 1 | 1 | Paper Feed: Paper feed input switch. |
| $\begin{aligned} & \text { XTAL1 } \\ & \text { XTAL2 } \end{aligned}$ | $2$ | 1 | Crystal: Inputs for a crystal to set internal oscillator frequency, For proper operation use 6 MHz crystal. |
| $\overline{\text { RESET }}$ | 4 | 1 | Reset: Reset input, active low. After reset the 8295 will be set for 12 characters/inch single width printing, solenoid strobe at 320 msec . |
| NC | 5 |  | No Connection: No connection or tied high. |
| $\overline{\text { CS }}$ | 6 | 1 | Chip Select: Chip select input used to enable the RD and WR inputs except during DMA. |
| GND | 7 |  | Ground: This pin must be tied to ground: |
| $\overline{\mathrm{RD}}$ | 8 | 1 | Read: Read input which enables the master CPU to read data and status. In the serial mode this pin must be tied to $V_{\mathrm{cc}}$. |
| $\mathrm{V}_{\mathrm{cc}}$ | 9 |  | Power: +5 volt power input: $+5 \mathrm{~V} \pm$ $10 \%$. |
| $\overline{W R}$ | 10 |  | Write: 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 $V_{\text {ss }}$. |
| SYNC | 11 | 0 | Sync: $2.5 \mu \mathrm{~s}$ clock output. Can be used as a strobe for external circuitry. |
| $\begin{aligned} & \mathrm{D}_{0} \\ & \mathrm{D}_{1} \\ & \mathrm{D}_{2} \\ & \mathrm{D}_{3} \\ & \mathrm{D}_{4} \\ & \mathrm{D}_{5} \\ & \mathrm{D}_{6} \\ & \mathrm{D}_{7} \end{aligned}$ | $\begin{array}{r} 12 \\ 13 \\ 14 \\ 15 \\ 16 \\ 17 \\ 18 \\ 19 \end{array}$ | 1/0 | Data Bus: Three-state bidirectional data bus buffer lines used to interface the 8295 to the host processor in the parallel mode. In the serial mode $D_{0}-D_{2}$ sets up the baud rate. |
| GND | 20 |  | Ground: This pin must be tied to ground. |
| $\mathrm{V}_{\mathrm{cc}}$ | 40 |  | Power: +5 volt power input: $+5 \pm$ 10\%. |


| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| HOME | 39 | 1 | Home: Home input switch, used by the 8295 to detect that the print head is in the home position. |
| $\overline{\text { DACK/SIN }}$ | 38 | 1 | DMA Acknowledge/Serial Input: In the parallel mode used as DMA acknowledgment; in the serial mode, used as input for data. |
| DRQ/CTS | 37 | 0 | DMA Request/Clear to Send: In the parallel mode used as. DMA request output pin to indicate to the 8257 that a DMA transfer is requested; in the serial mode used as clear-to-send signal. |
| IRQ/ $\overline{\text { SER }}$ | 36 | 0 | Interrupt Request/Serial Mode: In parallel mode it is an interrupt request input to the master CPU; in serial mode it should be strapped to $\mathrm{V}_{\mathrm{ss}}$. |
| $\overline{\text { MOT }}$ | 35 | 0 | Motor: Main motor drive, active low. |
| STB | 34 | 0 | Solenoid Strobe: Solenoid strobe output. Used to determine duration of solenoids activation. |
| $\begin{aligned} & \overline{S_{7}} \\ & \frac{\mathrm{~S}_{6}}{} \\ & \frac{\mathrm{~S}_{5}}{} \\ & \frac{\mathrm{~S}_{4}}{3} \\ & \frac{\mathrm{~S}_{2}}{\mathrm{~S}_{1}} \end{aligned}$ | $\begin{aligned} & 33 \\ & 32 \\ & 31 \\ & 30 \\ & 29 \\ & 28 \\ & 27 \\ & \hline \end{aligned}$ | 0 | Solenoid: Solenoid drive outputs; active low. |
| $V_{D D}$ | 26 |  | Power: +5 V power input ( $+5 \mathrm{~V} \pm$ $10 \%$. Low power standby pin. |
| $\mathrm{V}_{\mathrm{CC}}$ | 25 |  | Power: Tied high. |
| $\begin{aligned} & \text { GP1 } \\ & \text { GP2 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 24 \\ & 23 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & \hline \end{aligned}$ | General Purpose: General purpose output pins. |
| $\overline{\text { TOF }}$ | 22 | 1 | Top of Form: Top of form input, used to sense top of form signal for type $T$ printer. |
| $\overline{\text { PFM }}$ | 21 | 0 | Paper Feed Motor Drive: Paper feed motor drive, active low. |

8295

## 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. It provides a modified $7 \times 7$ matrix character generator. The character set includes 64 ASCII characters.

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 | Set GP1. This command brings the GP1 pin <br> to a logic high state. After power on it is <br> automatically set high. |
| 02 | Set GP2. Same as the above but for GP2. <br> Clear GP1. Sets GP1 pin to logic low state, <br> inverse of command 00. <br> Clear GP2. Same as above but for GP2. In- <br> verse command 01. |
| 03 | 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. |
| 05 | Print 10 characters/in. density. <br> Print 12 characters/in. density. |
| 06 | 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. |
| 08 | Enable DMA mode; must be followed by <br> two bytes specifying the number of data <br> characters to be fetched. Least significant <br> byte accepted first. |

## Hex Code

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.

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

## PROGRAMMABLE PRINTING OPTIONS

## CHARACTER DENSITY

The character density is programmable at 10 or 12 characters/inch ( 32 or 40 characters/line). The 8295 is automatically set to 12 characters/inch at power-up. Invoking the Print Double-Width command halves the character density ( 5 or 6 characters/inch). The 10 char/in or 12 charlin command must be re-issued to cancel the Double-Width mode. Different character density modes may not be mixed within a single line of printing.

## PRINT INTENSITY

The intensity of the printed characters is determined by the amount of time during which the solenoid is on. This on-time is programmable via the Set Strobe-Width command. A byte following this command sets the solenoid on-time according to Table 2. Note that only the three least significant bits of this byte are important.

Table 2. Solenoid On-Time

| D7-D3 | D2 | D1 | D0 | Solenoid On <br> (microsec) |
| :---: | :---: | :---: | :---: | :---: |
| $\mathbf{x}$ | 0 | 0 | 0 | 200 |
| $\mathbf{x}$ | 0 | 0 | 1 | 240 |
| $\mathbf{x}$ | 0 | 1 | 0 | 280 |
| $\mathbf{x}$ | 0 | 1 | 1 | 320 |
| $\mathbf{x}$ | 1 | 0 | 0 | 360 |
| $\mathbf{x}$ | 1 | 0 | 1 | 400 |
| $\mathbf{x}$ | 1 | 1 | 0 | 440 |
| $\mathbf{x}$ | 1 | 1 | 1 | 480 |

## TABULATIONS

Up to three tabulation positions may be specified with the 8295. The column position of each tabulation is selected by issuing the Set Tab commands, each fol-
lowed by a byte specifying the column. The tab positions will then remain valid until new Set Tab commands are issued.

Sending a tab character (09H) will automatically fill the character buffer with blanks up to the next tab position. The character sent immediately after the tab character will thus be stored and printed at that position.

## CPU TO 8295 INTERFACE

Communication between the CPU and the 8295 may take place in either a serial or parallel mode. However, the selection of modes is inherent in the system hardware; it is not software programmable. Thus, the two modes cannot be mixed in a single 8295 application.

## PARALLEL INTERFACE

Two internal registers on the 8295 are addressable by the CPU: one for input, one for output. The following table describes how these registers are accessed.

| $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\overline{\mathbf{C S}}$ | Register |
| :---: | :---: | :---: | :---: |
| 1 | 0 | 0 | Input Data Register |
| 0 | 1 | 0 | Output Status Register |

Input Data Register-Data written to this register is interpreted in one of two ways, depending on how the data is coded.

1. A command to be executed ( $0 X H$ or 1 XH ).
2. A character to be stored in the character buffer for printing (2XH, 3XH, 4XH, or 5XH). See the character set, Table 2.
Output Status Register-8295 status is available in this register at all times.

STATUS BIT: FUNCTION:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| x | x | PA | DE | x | x | IBF | x |

PA—Parameter Required; PA = 1 indicates that a command requiring a parameter has been received. After the necessary parameters have been received by the 8295, the PA flag is cleared.
DE-DMA Enabled; DE $=1$ whenever the 8295 is in DMA mode. Upon completion of the required DMA transfers, the DE flag is cleared.
IBF-Input Buffer Full; IBF = 1 whenever data is written to the Input Data Register. No data should be written to the 8295 when $\mathrm{IBF}=1$.

A flow chart describing communication with the 8295 is shown in Figure 3.

The interrupt request output (IRQ, Pin 36) is available on the 8295 for interrupt driven systems. This output is asserted true whenever the 8295 is ready to receive data.
To improve bus efficiency and CPU overhead, data may be transferred from main memory to the 8295 via DMA cycles. Sending the Enable DMA command ( 08 H ) activates the DMA channel of the 8295 . This command must be followed by two bytes specifying the length of the data string to be transferred (least significant byte first). The 8295 will then assert the required DMA requests to
the 8257 DMA controller without further CPU intervention. Figure 4 shows a block diagram of the 8295 in DMA mode.


Figure 3. Host to 8295 Protocol Flowchart


Figure 4. Parallel System Interface
Data transferred in the DMA mode may be either commands or characters or a mixture of both. The procedure is as follows:

1. Set up the 8257 DMA controller channel by sending a starting address and a block length.
2. Set up the 8295 by issuing the "Enable DMA" command $(08 \mathrm{H})$ followed by two bytes specifying the block length (least significant byte first).
The DMA enabled flag (DE) will be true until the assigned data transfer is completed. Upon completion of the transfer, the flag is cleared and the interrupt request (IRQ) signal is asserted. The 8295 then returns to the non-DMA mode of operation.

## SERIAL INTERFACE

The 8295 may be hardware programmed to operate in a serial mode of communication. By connecting the IRQ/SER pin (pin 36) to logic zero, the serial mode is enabled immediately upon power-up. The serial Baud rate is also hardware programmable; by strapping pins 14,13 , and 12 according to Table 3, the rate is selected. $\overline{\mathrm{CS}}, \overline{\mathrm{RD}}$, and $\overline{\mathrm{WR}}$ must be strapped as shown in Figure 5.

Table 3. Serial Baud Rate

| Pin 14 | Pin 13 | Pin 12 | Baud Rate |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 110 |
| 0 | 0 | 1 | 150 |
| 0 | 1 | 0 | 300 |
| 0 | 1 | 1 | 600 |
| 1 | 0 | 0 | 1200 |
| 1 | 0 | 1 | 2400 |
| 1 | 1 | 0 | 4800 |
| 1 | 1 | 1 | 4800 |

The serial data format is shown in Figure 5. The CPU should wait for a clear to send signal ( $\overline{\mathrm{CTS}}$ ) from the 8295 before sending data.


Figure 5. Serial Interface to UART (8251A)

## 8295 TO PRINTER INTERFACE

The strobe output signal of the 8295 determines the duration of the solenoid outputs, which hold the data to the printer. These solenoid outputs cannot drive the printer solenoids directly. They should be buffered through solenoid drivers as shown in Figure 6. Recommended solenoid and motor driver circuits may be found in the printer manufacturer's interface guide.


Figure 6. 8295 To Printer Solenoid Interface

## OSCILLATOR AND TIMING CIRCUITS

The 8295's internal timing generation is controlled by a self-contained oscillator and timing circuit. A 6 MHz crystal is 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 7. The recommended crystal connection is shown in Figure 8.


Figure 7. Oscillator Configuration


Figure 8. Recommended Crystal Connection

8295 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 | 1 | 59 | Y |
| 2A | * | 3A | : | 5A | J | 5A | Z |
| 2B | + | 3B | ; | 4B | K | 5B | [ |
| 2 C | , | 3C | $<$ | 4 C | L | 5C | 1 |
| 2D | - | 3D | = | 4D | M | 5D | ] |
| 2E | . | 3E | > | 4E | N | 5E | $\uparrow$ |
| 2F | 1 | 3F | ? | 4F | 0 | 5F | - |

## ABSOLUTE MAXIMUM RATINGS*


*NOTICE: 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 $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}\right)$

| 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}_{\text {LL } 1}$ | Input Low Voltage ( $X_{1}, X_{2}$, RESET) | -0.5 |  | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (All Except $\mathrm{X}_{1}, \mathrm{X}_{2}$, RESET) | 2.2 |  | $\mathrm{V}_{\text {CC }}$ | V |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage ( $\mathrm{X}_{1}, \mathrm{X}_{2}$, RESET) | 3.8 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage (All Other Outputs) |  |  | 0.45 | V | $\mathrm{l}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | $\mathrm{IOH}_{\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}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| Iofl | Output Leakage Current ( $\mathrm{D}_{0}-\mathrm{D}_{7}$, High Z State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}$ Supply Current |  | 5 | 15 | mA |  |
| $\mathrm{I}_{\mathrm{DD}}+\mathrm{I}_{\mathrm{CC}}$ | Total Supply Current |  | 60 | 125 | mA |  |
| ILi | Low Input Load Current (Pins 24, 27-38) |  |  | 0.5 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| ${ }^{\text {LII }}$ | Low Input Load Current (RESET) |  |  | 0.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $I_{\text {IH }}$ | Input High Leakage Current (Pins 22, 38) |  |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |
| $\mathrm{CIN}^{\text {IN }}$ | Input Capacitance |  |  | 10 | pF |  |
| $\mathrm{C}_{1 / 0}$ | I/O Capacitance |  |  | 20 | pF |  |

## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ 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 |  | 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{DF}}$ | $\overline{\mathrm{RD}} \uparrow$ to Data Float Delay |  | 100 | ns |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Cycle Time | 2.5 | 15 | $\mu \mathrm{~s}$ |  |

DBB WRITE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{A W}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{WR}} \downarrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\text {WA }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After $\overline{W R} \uparrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{WW}}$ | $\overline{\mathrm{WR}}$ Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{DW}}$ | Data Setup to $\overline{W R} \uparrow$ | 150 |  | ns |  |
| $\mathrm{t}_{\text {WD }}$ | Data Hold to $\overline{W R} \uparrow$ | 0 |  | ns |  |

DMA AND INTERRUPT TIMING

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{A C C}$ | $\overline{D A C K}$ Setup to Control | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{CAC}}$ | $\overline{\text { DACK Hold After Control }}$ | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{CRQ}}$ | $\overline{W R}$ to DRQ Cleared |  | 200 | ns |  |
| $\mathrm{t}_{\mathrm{ACD}}$ | $\overline{D A C K}$ to Data Valid |  | 225 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



DMA AND INTERRUPT TIMING


## WAVEFORMS (Continued)

## PRINTER INTERFACE TIMING



| Symbol | Parameter | Typical |
| :---: | :--- | :---: |
| $P_{D H}$ | Print delay from <br> home inactive | 1.8 ms |
| $S_{D S}$ | Solenoid data <br> setup time before <br> strobe active | 25 ss |
| $\mathrm{S}_{\mathrm{HS}}$ | Solenoid data <br> hold after strobe <br> inactive | $>1 \mathrm{~ms}$ |
| $M_{H A}$ | Motor hold time <br> after home active | 3.2 ms |
| $P_{S P}$ | PFEED setup time <br> after PFM active | 58 ms |
| $P_{H P}$ | PFM hold time <br> after PFEED active | 9.75 ms |

# 8202A <br> DYNAMIC RAM CONTROLLER 

- Provides All Signals Necessary to Control 2104A, 2117, or 2118 Dynamic Memories
- Directly Addresses and Drives Up to 64K 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 <br> - Fully Compatible with Intel ${ }^{\circledR}$ 8080A, 8085A, iAPX 88, and iAPX 86 Family Microprocessors <br> - Decodes CPU Status for Advanced Read Capability <br> ■ Provides System Acknowledge and Transfer Acknowledge Signals <br> - Internal Clock Capability with the 8202A-1 or 8202A-3

The Intel ${ }^{\circledR}$ 8202A is a Dynamic Ram System Controller designed to provide all signals necessary to use 2104A, 2117, or 2118 Dynamic RAMs in microcomputer systems. The 8202A provides multiplexed addresses and address strobes, as well as refresh/access arbitration. The 8202A-1 or 8202A-3 support an internal crystal oscillator.


Figure 1. 8202A Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Descriptions

| Symbol | Pin <br> No. | Туре | Name and Function |
| :---: | :---: | :---: | :---: |
| ALO <br> $A L_{1}$ <br> $\mathrm{AL}_{2}$ <br> AL3 <br> $\mathrm{AL}_{4}$ <br> AL5 <br> $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ | $\begin{aligned} & 6 \\ & 8 \\ & 10 \\ & 12 \\ & 14 \\ & 16 \\ & 18 \end{aligned}$ |  | Address Low: CPU address inputs used to generate memory row address. <br> $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ used to select 4 K RAM mode. |
| $\mathrm{AH}_{0}$ $\mathrm{AH}_{1}$ $\mathrm{AH}_{2}$ $\mathrm{AH}_{3}$ $\mathrm{AH}_{4}$ $\mathrm{AH}_{5}$ $\mathrm{AH}_{6}$ | $\begin{array}{\|l\|} \hline 5 \\ 4 \\ 3 \\ 2 \\ 1 \\ 39 \\ 38 \end{array}$ |  | Address High: CPU address inputs used to generate memory column address. |
| $\begin{aligned} & \mathrm{BO} \\ & \mathrm{~B}_{1} / \mathrm{OP}_{1} \end{aligned}$ | $\begin{aligned} & 24 \\ & 25 \end{aligned}$ | $1$ | Bank Select Inputs: Used to gate the appropriate $\mathrm{RAS}_{0^{-}}$ RAS $_{3}$ output for a memory cycle. $\mathrm{B}_{1} / \mathrm{OP}_{1}$ option used to select the Advanced Read Mode. |
| $\overline{\text { PCS }}$ | 33 | 1 | Protected Chip Select: Used to enable the memory read and write inputs. Once a cycle is started, it will not abort even if $\overline{\mathrm{PCS}}$ goes inactive before cycle completion. |
| $\overline{W R}$ | 31 | I | Memory Write Request. |
| $\overline{R D} / \mathrm{S} 1$ | 32 | I | Memory Read Request: S 1 function used in Advanced Read mode selected by OP 1 (pin 25). |
| REFRQ/ <br> ALE | 34 | I | External Refresh Request: ALE function used in Advanced Read mode, selected by OP 1 (pin 25). |
| $\begin{aligned} & \overline{\mathrm{OUT}}_{0} \\ & \overline{\mathrm{OUT}}_{1} \\ & \mathrm{OUT}_{2} \\ & \mathrm{OUT}_{3} \\ & \mathrm{OUT}_{4} \\ & \overline{\mathrm{OUT}}_{5} \\ & \overline{\mathrm{OUT}}_{6} \end{aligned}$ | $\begin{aligned} & 7 \\ & 9 \\ & 11 \\ & 13 \\ & 15 \\ & 17 \\ & 19 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Output of the Multiplexer: These outputs are designed to drive the addresses of the Dynamic RAM array. For 4K RAM operation, $\overline{\mathrm{OUT}}_{6}$ is designed to drive the 2104A $\overline{C S}$ input. (Note that the $\overline{\mathrm{OUT}}_{0-6}$ pins do not require inverters or drivers for proper operation. |
| $\overline{W E}$ | 28 | 0 | Write Enable: Drives the Write Enable inputs of the Dynamic RAM array. |
| $\overline{\text { CAS }}$ | 27 | 0 | Column Address Strobe: This output is used to latch the Column Address into the Dynamic RAM array. |


| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \overline{\text { RAS }}_{0} \\ & \overline{\text { RAS }}_{1} \\ & \overline{\text { RAS }} 2^{\overline{\text { RAS }}_{3}} \end{aligned}$ | $\begin{aligned} & 21 \\ & 22 \\ & 23 \\ & 26 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Row Address Strobe: Used to latch the Row Address into the bank of dynamic RAMs, selected by the 8202A Bank Select pins ( $B_{0}, B_{1} / O P_{1}$ ). |
| $\overline{\text { XACK }}$ | 29 | 0 | Transfer Acknowledge: This output is a strobe indicating valid data during a read cycle or data written during a write cycle. $\overline{X A C K}$ can be used to latch valid data from the RAM array. |
| $\overline{\text { SACK }}$ | 30 | 0 | 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 $\overline{\text { XACK }}$ in the memory access cycle). |
| $\begin{aligned} & \left(x_{0}\right) O P_{2} \\ & \left(x_{1}\right) C L K \end{aligned}$ | $\begin{aligned} & 36 \\ & 37 \end{aligned}$ | $1 / 0$ | Oscillator Inputs: These inputs are designed for a quartz crystal to control the frequency of the oscillator. If $\mathrm{X}_{0} / \mathrm{OP}_{2}$ is connected to a $1 \mathrm{~K} \Omega$ resistor pulled to +12 V then $\mathrm{X}_{1}$ /CLK becomes a TTL input for an external clock. |
| N.C. | 35 |  | Reserved for future use. |
| $\mathrm{V}_{\text {CC }}$ | 40 |  | Power Supply:+5V. |
| GND | 20 |  | Ground. |

NOTE: Crystal mode for the 8202A-1 or 8202A-3 only.


Figure 3. Crystal Operation for the 8202A-1 and the 8202A-3

## Functional Description

The 8202A provides a complete dynamic RAM controller for microprocessor systems as well as expansion memory boards. All of the necessary control signals are provided for 2104A, 2117, and 2118 dynamic RAM's.

All 8202A timing is generated from a single reference clock. This clock is provided via an external oscillator or an on chip crystal oscillator. All output signal transitions are synchronous with respect to this clock reference, except for the CPU handshake signals $\overline{\text { SACK }}$ and XACK (trailing edge).

CPU memory requests normally use the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs. The advanced READ mode allows ALE and S1 to be used in place of the $\overline{\mathrm{RD}}$ input.

Failsafe refresh is provided via an internal refresh timer which generates internal refresh requests. Refresh requests can also be generated via the REFRQ input.

An on-chip synchronizer/arbiter prevents memory and refresh requests from affecting a cycle in progress. The READ, WRITE, and external REFRESH requests may be asynchronous to the 8202A clock; on-chip logic will synchronize the requests, and the arbiter will decide if the requests should be delayed, pending completion of a cycle in progress.

## Option Selection

The 8202A has three strapping options. When OP 1 is selected (16K mode only), pin 32 changes from a $\overline{R D}$ input to an S1 input, and pin 34 changes from a REFREQ input to an ALE input. See "Refresh Cycles" and "Read Cycles" for more detail. $\mathrm{OP}_{1}$ is selected by tying pin 25 to +12 V though a 5.1 K ohm resistor.

When $\mathrm{OP}_{2}$ is selected, by connecting pin 36 to +12 V through a 1 K ohm resistor, pin 37 changes from a crystal input $\left(X_{1}\right)$ to the CLK input for an external TTL clock.
$\mathrm{OP}_{3}$ is selected by connecting Pin 18 to +12 V through a 5.1K ohm resistor. The 8202A will change its internal refresh timer from 128 -row refresh $(2118,2117)$ to 64 -row refresh (2104A).

## Refresh Timer

The refresh timer is used to monitor the time since the last refresh cycle occurred. When the appropriate amount of time has elapsed, the refresh timer will request a refresh cycle. External refresh requests will reset the refresh timer.

## Refresh Counter

The refresh counter is used to sequentially refresh all of the memory's rows. The 8-bit counter is incremented after every refresh cycle.

## Address Multiplexer

The address multiplexer takes the address inputs and the refresh counter outputs, and gates them onto the address outputs at the appropriate time. The address outputs, in conjunction with the $\overline{\text { RAS }}$ and $\overline{\text { CAS }}$ outputs, determine the address used by the dynamic RAMs for read, write, and refresh cycles. During the first part of a read or write cycle, $\mathrm{AL}_{0}-\mathrm{AL}_{6}$ are gated to $\overline{\mathrm{OUT}}_{0}-\overline{\mathrm{OUT}}_{6}$, then $\mathrm{AH}_{0}-\mathrm{AH}_{6}$ are gated to the address outputs.

During a refresh cycle, the refresh counter is gated onto the address outputs. All refresh cycles are RAS-only refresh ( $\overline{\mathrm{CAS}}$ inactive, $\overline{\mathrm{RAS}}$ active).

To minimize buffer delay, the information on the address outputs is inverted from that on the address inputs.
$\overline{\text { OUT }}_{0}-$ OUT $_{6}$ do not need inverters or buffers unless additional drive is required.

## Synchronizer/Arbiter

The 8202A has three inputs, REFRQ/ALE (pin 34), $\overline{\mathrm{RD}}$ (pin 32) and $\overline{W R}$ (pin 31). The $\overline{R D}$ and $\overline{W R}$ inputs allow an external CPU to request a memory read or write cycle, respectively. The REFRQ/ALE allows refresh requests to be requested external to the 8202A.

All three of these inputs may be asynchronous with respect to the 8202A's clock. The arbiter will resolve conflicts between refresh and memory requests, for both pending cycles and cycles in progress. Read and write requests will be given priority over refresh requests.

## System Operation

The 8202A is always in one of the following states:
a) IDLE
b) TEST Cycle
c) REFRESH Cycle
d) READ Cycle
e) WRITE Cycle

The 8202A is normally in the IDLE state. Whenever one of the other cycles is requested, the 8202A will leave the IDLE state to perform the desired cycle. If no other cycles are pending, the 8202A will return to the IDLE state.

| Description | Pin \# | Normal Function | Option Function |
| :--- | :--- | :--- | :--- |
| $\mathrm{B}_{1} / \mathrm{OP}_{1}$ | 25 | Bank (RAS) Select | Advanced-Read Mode |
| $\mathrm{X}_{0} / \mathrm{OP}_{2}$ | 36 | Crystal Oscillator (8202A-10r 8202A-3) | External Oscillator |
| AL6/OP3 | 18 | Address Input | 64-ROW Refresh |

Figure 4. 8202A Option Selection

## Test Cycle

The TEST Cycle is used to check operation of several 8202A internal functions. TEST cycles are requested by activating the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs, independent of $\overline{P C S}$. The TEST Cycle will reset the refresh address counter and perform a WRITE Cycle. The TEST Cycle should not be used in normal system operation, since it would affect the dynamic RAM refresh.

## Refresh Cycles

The 8202A has two ways of providing dynamic RAM refresh:

1) Internal (failsafe) refresh
2) External (hidden) refresh

Both types of 8202A refresh cycles activate all of the $\overline{R A S}$ outputs, while $\overline{C A S}, \overline{W E}, \overline{S A C K}$, and $\overline{\text { XACK }}$ remain inactive.

Internal refresh is generated by the on-chip refresh timer. The timer uses the 8202A clock to ensure that refresh of all rows of the dynamic RAM occurs every 2 milliseconds. If REFRQ is inactive, the refresh timer will request a refresh cycle every 10-16 microseconds.

External refresh is requested via the REFRQ input (pin 34). External refresh control is not available when the Ad-vanced-Read mode is selected. External refresh requests are latched, then synchronized to the 8202A clock.

The arbiter will allow the refresh request to start a refresh cycle only if the 8202A is not in the middle of a cycle.

Simultaneous memory request and external refresh request will result in the memory request being honored first. This 8202A characteristic can be used to "hide" refresh cycles during system operation. A circuit similar to Figure 5 can be used to decode the CPU's instruction fetch status to generate an external refresh request. The refresh request is latched while the 8202A performs the instruction fetch; the refresh cycle will start immediately after the memory cycle is completed, even if the $\overline{R D}$ input has not gone inactive. If the CPU's instruction decode time is long enough, the 8202A can complete the refresh cycle before the next memory request is generated.

Certain system configurations require complete external refresh requests. If external refresh is requested faster than the minimum internal refresh timer (tREF), then, in effect, all refresh cycles will be caused by the external refresh request, and the internal refresh timer will never generate a refresh request.


Figure 5. Hidden Refresh

## Read Cycles

The 8202A can accept two different types of memory Read requests:

1) Normal Read, via the $\overline{R D}$ input
2) Advanced Read, using the S1 and ALE inputs

The user can select the desired Read request configuration via the B1/OP1 hardware strapping option on pin 25.

|  | Normal Read | Advanced Read |
| :--- | :--- | :--- |
| Pin 25 | B1 input | +12 Volt Option |
| Pin 32 | RD input | S1 input |
| Pin 34 | REFRQ input | ALE input |
| \# RAM banks | $4(\overline{\operatorname{RAS}} 0-3)$ | $2\left(\overline{R A S}_{2-3}\right)$ |
| Ext. Refresh | Yes | No |

Figure 6. 8202A Read Options
Normal Reads are requested by activating the $\overline{\mathrm{RD}}$ input, and keeping it active until the 8202A responds with an $\overline{\text { XACK }}$ pulse. The $\overline{R D}$ input can go inactive as soon as the command hold time (tCHS) is met.

Advanced Read cycles are requested by pulsing. ALE while S 1 is active; if S 1 is inactive (low) ALE is ignored. Advanced Read timing is similiar to Normal Read timing, except the falling edge of ALE is used as the cycle start reference.

If a Read cycle is requested while a refresh cycle is in progress, then the 8202A will set the internal delayedSACK latch. When the Read cycle is eventually started, the 8202A will delay the active $\overline{\text { SACK }}$ transition until $\overline{\text { XACK }}$ goes active, as shown in the AC timing diagrams. This delay was designed to compensate for the CPU's READY setup and hold times. The delayed-SACK latch is cleared after every READ cycle.

Based on system requirements, either $\overline{\mathrm{SACK}}$ or $\overline{\mathrm{XACK}}$ can be used to generate the CPU READY signal. $\overline{X A C K}$ will
normally be used; if the CPU can tolerate an advanced READY, then SACK can be used, but only if the CPU can tolerate the amount of advance provided by SACK. If $\overline{\text { SACK }}$ arrives too early to provide the appropriate number of WAIT states, then either XACK or a delayed form of $\overline{\text { SACK }}$ should be used.

## Write Cycles

Write cycles are similiar to Normal Read cycles, except for the WE output. WE is held inactive for Read cycles, but goes active for Write cycles. All 8202A Write cycles are "early-write" cycles; WE goes active before $\overline{\text { CAS }}$ goes active by an amount of time sufficient to keep the dynamic RAM output buffers turned off.

## General System Considerations

All memory requests (Normal Reads, Advanced Reads, Writes) are qualified by the $\overline{\text { PCS }}$ input. $\overline{\text { PCS }}$ should be stable, either active or inactive, prior to the leading edge of $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, or ALE. Systems which use battery backup should pullup $\overline{\text { PCS }}$ to prevent erroneous memory requests, and should also pullup $\overline{\mathrm{WR}}$ to keep the 8202A out of its test mode.

In order to minimize propagation delay, the 8202A uses an inverting address multiplexer without latches. The system must provide adequate address setup and hold times to guarantee $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ setup and hold times for the RAM. The 8202A tAD AC parameter should be used for this system calculation.

The BO-B1 inputs are similiar to the address inputs in that they are not latched. B0 and B1 should not be changed during a memory cycle, since they directly control which $\overline{\text { RAS }}$ output is activated.

The 8202A uses a two-stage synchronizer for the memory request inputs ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ ), and a separate two stage synchronizer for the external refresh input (REFRQ). As with any synchronizer, there is always a finite probability of metastable states inducing system errors. The 8202A synchronizer was designed to have a system error rate less than 1 memory cycle every three years based on the full operating range of the 8202A.

A microprocessor system is concerned with the time data is valid after $\overline{\mathrm{RD}}$ goes low. See Figure 7. In order to calculate memory read access times, the dynamic RAM's A.C. specifications must be examined, especially the RAS-access time (trAC) and the CAS-access time (tCAC). Most configurations will be CAS-access limited; i.e., the data from the RAM will be stable $t_{c c, \text { max }}(8202 A)+t_{C A C}$ (RAM) after a memory read cycle is started. Be sure to add any delays (due to buffers, data latches, etc.) to calculate the overall read access time.

Since the 8202A normally performs "early-write" cycles, the data must be stable at the RAM data inputs by the time $\overline{\text { CAS }}$ goes active, including the RAM's data setup time. If the system does not normally guarantee sufficient write data setup, you must either delay the $\overline{\mathrm{WR}}$ input signal or delay the 8202A $\overline{W E}$ output.

Delaying the $\overline{\mathrm{WR}}$ input will delay all 8202A timing, including the READY handshake signals, $\overline{\text { SACK }}$ and $\overline{X A C K}$, which may increase the number of WAIT states generated by the CPU.

If the $\overline{W E}$ output is externally delayed beyond the $\overline{C A S}$ active transition, then the RAM will use the falling edge of WE to strobe the write data into the RAM. This WE transition should not occur too late during the CAS active transition, or else the $\overline{W E}$ to $\overline{\text { CAS }}$ requirements of the RAM will not be met.


Figure 7. Read Access Time


Figure 8. Typical 8088 System

## ABSOLUTE MAXIMUM RATINGS*


*NOTE: 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 $\quad T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$ for $8202 \mathrm{~A}-3, \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}$ |
| ICC | Power Supply Current |  | 270 | mA |  |
| If | Forward Input Current CLK <br> All Other Inputs ${ }^{3}$ |  | $\begin{aligned} & -2.0 \\ & -320 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{F}=0.45 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
| IR | Reverse Input Current ${ }^{3}$ |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ ( Note 1) |
| VOL | Output Low Voltage $\overline{S A C K}, \overline{X A C K}$ <br> All Other Outputs |  | $\begin{aligned} & 0.45 \\ & 0.45 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA} \\ & \mathrm{IOL}=3 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{VOH}^{\text {O }}$ | Output High Voltage $\overline{\text { SACK, }} \overline{\text { XACK }}$ <br> All Other Outputs | $\begin{aligned} & 2.4 \\ & 2.6 \end{aligned}$ |  | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.65 \mathrm{~V} \\ & \mathrm{IOH}^{\prime}=-1 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ (Note 2) |
| $\mathrm{V}_{\text {IH1 }}$ | Input High Voltage | 2.0 |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathbf{1 H 2}}$ | Option Voltage |  |  | V | (Note 4) |
| CIN | 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} \end{aligned}$ |

## NOTES:

1. $I_{R}=200 \mathrm{~mA}$ for pin 37 (CLK) for external clock mode.
2. For test mode $\overline{R D} \& \overline{W R}$ must be held at GND.
3. Except for pin 36.
4. 



## A.C. CHARACTERISTICS

$T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ for $8202 \mathrm{~A}-3$
 other pins are measured at 1.5 V . All times are in nsec.

| Symbol | Parameter | Min | Max | Notes |
| :---: | :---: | :---: | :---: | :---: |
| $t_{P}$ | Clock Period | 40 | 54 |  |
| tPH | External Clock High Time | 20 | $\cdots$ | " $\quad$ : ${ }^{\text {a }}$ |
| tPL | External Clock Low Time-above ( $>$ ) 20 mHz | 17 | ... | $\cdots$ |
| $t_{\text {PL }}$ | External Clock Low Time-below ( $<$ ) 20 mHz | 20 |  |  |
| $t_{R C}$ | Memory Cycle Time | 10tp-30 | 12tp | 4, 5 |
| treF | Refresh Time ( 64 cycles-4K mode) | 548tp | 576tp |  |
| treF | Refresh Time ( 128 cycles-16K mode) | 264tp | 288tp |  |
| $\mathrm{t}_{\mathrm{BP}}$ | $\overline{\text { RAS Precharge Time }}$ | $4 \mathrm{tp}-30$ |  |  |
| trsh | $\overline{\text { RAS }}$ Hold After $\overline{\text { CAS }}$ | $5 \mathrm{t} p-30$ | - . | 3 |
| tASR | Address Setup to $\overline{\mathrm{RAS}}$ | tp - 30 | - | 3 |
| $t_{\text {RAH }}$ | Address Hold From $\overline{\mathrm{RAS}}$ | $t p-10$ | , | 3 |
| ${ }^{\text {t }}$ ASC | Address Setup to CAS | tp - 30 |  | 3 |
| ${ }^{\text {t }}$ CAH | Address Hold from CAS | $5 \mathrm{t} p-20$ |  | 3 |
| ${ }^{\text {t CAS }}$ | $\overline{\text { CAS Pulse Width }}$ | $5 t p-10$ |  |  |
| twCs | $\overline{\text { WE Setup to CAS }}$ | tp -40 |  |  |
| tWCH | $\overline{\text { WE }}$ Hold After $\overline{\text { CAS }}$ | $5 t p-35$ |  | 8 |
| tRS | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}, \mathrm{REFRQ}$ delay from $\overline{\mathrm{RAS}}$ | 5tp |  |  |
| $t_{\text {MRP }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ setup to $\overline{\mathrm{RAS}}$ | 0 |  | 5 |
| tRMS | REFRQ setup to $\overline{R D}$, $\overline{W R}$ | 2tp |  |  |
| trMP | REFRQ setup to $\overline{\text { RAS }}$ | 2tp |  | 5 |
| tPCS | $\overline{\text { PCS }}$ Setup to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ | 20 |  |  |
| ${ }^{\text {t }}$ AL | S1 Setup to ALE | 15 | \% |  |
| tLA | S1 Hold from ALE | 30 |  |  |
| ${ }^{\text {t }} \mathrm{CR}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ to $\overline{\mathrm{RAS}}$ Delay | tp +30 | $2 \mathrm{t} p+70$ | 2 |
| ${ }^{\text {t C C }}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ to $\overline{\mathrm{CAS}}$ Delay | $3 t p+25$ | $4 \mathrm{t} p+85$ | 2 |
| tsC | CMD Setup to Clock | 15 | \% | 1 |
| tMRS | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ setup to REFRQ | 5 | , |  |
| ${ }^{t} \mathrm{CA}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ to $\overline{\mathrm{SACK}}$ Delay |  | $2 \mathrm{p} p+47$ | 2 |
| ${ }^{\text {t }} \mathrm{CX}$ | $\overline{C A S}$ to $\overline{\text { XACK }}$ Delay | $5 \mathrm{t} p-25$ | $5 t p+20$ |  |
| tcs | $\overline{\text { CAS }}$ to $\overline{\text { SACK }}$ Delay | $5 \mathrm{tp}-25$ | $5 \mathrm{t} p+40$ | 2 |
| ${ }^{\text {t }}$ ACK | $\overline{\text { XACK }}$ to $\overline{\mathrm{CAS}}$ Setup | 10 |  |  |
| ${ }^{\text {t }}$ XW | $\overline{\text { XACK Pulse Width }}$ | tp - 25 |  | 7 |
| ${ }_{\text {t }}^{\text {CK }}$ | $\overline{\text { SACK, }}$ XACK turn-off Delay |  | 35 |  |
| ${ }^{\text {t }} \mathrm{KCH}$ | CMD Inactive Hold after $\overline{\text { SACK, }}$, XACK | 10 |  |  |
| tLL | REFRQ Pulse Width | 20 |  |  |
| ${ }^{\text {t }} \mathrm{CHS}$ | CMD Hold Time | 30 |  |  |
| ${ }^{\text {tr }}$ RFR | REFRQ to $\overline{\text { RAS }}$ Delay |  | $4 t p+100$ | 6 |
| tww | $\overline{W R}$ to $\overline{W E}$ Delay | 0 | 50 | 8 |
| ${ }^{\text {t }}$ AD | CPU Address Delay | 0 | 40 | 3 |

## WAVEFORMS

Normal Read or Write Cycle


## Advanced Read Mode



WAVEFORMS (cont'd)
Memory Compatibility Timing


## Write Cycle Timing



WAVEFORMS (cont'd)
Read or Write Followed By External Refresh


External Refresh Followed By Read or Write


WAVEFORMS (cont'd)
Clock And System Timing


Table 2 8202A Output Test Loading.

| Pin | Test Load |
| :---: | :---: |
| SACK, XACK | $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |
| OUT0-OUT6 | $C_{\text {L }}=160 \mathrm{pF}$ |
| $\overline{\mathrm{RAS}}_{0}-\overline{\mathrm{RAS}}_{3}$ | $\mathrm{C}_{\mathrm{L}}=60 \mathrm{pF}$ |
| $\overline{W E}$ | $\mathrm{C}_{\mathrm{L}}=224 \mathrm{pF}$ |
| $\overline{\text { CAS }}$ | $\mathrm{C}_{\mathrm{L}}=320 \mathrm{pF}$ |

NOTES:

1. $t_{s c}$ is a reference point only. ALE, $\overline{R D}, \overline{W R}$, and REFRQ inputs do not have to be externally synchronized to 8202A clock.
2. If $t_{R S} \min$ and $t_{M R S} \min$ are met then, $t_{C A}, t_{C R}$, and $t_{C C}$ are valid, otherwise tCS is valid.
3. $t_{\text {ASR }}, t_{\text {RAH }}, t_{A S C}, t_{C A H}$, and $t_{\text {RSH }}$ depend upon B0-B1 and CPU address remaining stable throughout the memory cycle. The address inputs are not latched by the 8202A.
4. For back-to-back refresh cycles, $t_{R C} \max =13$ tp
5. tre max is valid only if trMP min is met (READ, WRITE followed by REFRESH) or $\mathrm{t}_{\mathrm{MRP}} \mathrm{min}$ is met (REFRESH followed by READ, WRITE).
6. $t_{\text {RFR }}$ is valid only if $t_{R S} m i n$ and $t_{R M S} m i n$ are met.
7. ${ }^{\mathrm{t}} \times \mathrm{W}$ min applies when $\overline{R D}, \overline{W R}$ has already gone high. Otherwise $\overline{X A C K}$ follows $\overline{R D}, \overline{W R}$.
8. $\bar{W} E$ goes high according to tWCH or tWW, whichever occurs first.
A.C. TESTING LOAD CIRCUIT

$C_{\llcorner }$INCLUDES JIG CAPACITANCE

The typical rising and falling characteristic curves for the $\overline{O U T}, \overline{R A S}, \overline{\mathrm{CAS}}$ and $\overline{\text { WE }}$ output buffers can be used to determine the effects of capacitive loading on the A.C.

Timing Parameters. Using this design tool in conjunction with the timing waveforms, the designer can determine typical timing shifts based on system capacitive load.

## A.C. CHARACTERISTICS FOR DIFFERENT CAPACITIVE LOADS




## NOTE:

Use the Test Load as the base capacitance for estimating timing shifts for system critical timing parameters.

## MEASUREMENT CONDITIONS:

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \quad$ Pins not measured are loaded with the
$\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \quad$ Test Load capacitance.

Example: Find the effect on $t_{C R}$ and $t_{C C}$ using 64 2118 Dynamic RAMs configured in 4 banks.

1. Determine the typical RAS and CAS capacitance: From the data sheet RAS $=4 \mathrm{pF}$ and $\mathrm{CAS}=4 \mathrm{pF}$.
$\therefore$ RAS load $=64 \mathrm{pF}+$ board capacitance. CAS load $=256 \mathrm{pF}+$ board capacitance. Assume $2 \mathrm{pF} / \mathrm{in}$ (trace length) for board capacitance.
2. From the waveform diagrams, we determine that the falling edge timing is needed for $t_{C R}$ and $t_{C C}$. Next find the curve that best approximates the test load; i.e., 68 pF for RAS and 330 pF for CAS.
3. If we use 72 pF for RAS loading, then the $\mathrm{t}_{\mathrm{CR}}$ (max.) spec should be increased by about 1 ns . Similarly if we use 288 pF for CAS, then $\mathrm{t}_{\mathrm{Cc}}$ (min.) and (max.) should decrease about 1 ns.

## 8203 <br> 64K DYNAMIC RAM CONTROLLER

Provides All Signals Necessary to Control 64K (2164), 16K (2117, 2118) and 4K (2104A) Dynamic Memories

- Directly Addresses and Drives Up to 64 Devices Without External Drivers
- Provides Address Multiplexing and Strobes
- Provides a Refresh Timer and a Refresh Counter

■ Provides Refresh/Access Arbitration

- Internal Clock Capability with the 8203-1 and the 8203-3

Fully Compatible with Intel ${ }^{\circledR} 8080 \mathrm{~A}$, 8085A, iAPX 88, and iAPX 86 Family Microprocessors

- Decodes CPU Status for Advanced Read Capability in 16K mode
- Provides System Acknowledge and Transfer Acknowledge Signals
- Refresh Cycles May be Internally or Externally Requested (For Transparent Refresh)
- Internal Series Damping Resistors on All Outputs

The intel ${ }^{\otimes} 8203$ is a Dynamic Ram System Controller designed to provide all signals necessary to use 2164, 2118, 2117, or 2104A Dynamic RAMs in microcomputer systems. The 8203 provides multiplexed addresses and address strobes, refresh logic, refresh/access arbitration. Refresh cycles can be started internally or externally. The 8203-1 and the 82033 support an internal crystal oscillator. The 8203-3 is a $\pm 5 \%$ VCC part.


Figure 1. 8203 Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Descriptions

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| ALO <br> $\mathrm{AL}_{1}$ <br> $\mathrm{AL}_{2}$ <br> $\mathrm{AL}_{3}$ <br> $\mathrm{AL}_{4}$ <br> $\mathrm{AL}_{5}$ <br> $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ | $\begin{aligned} & 6 \\ & 8 \\ & 10 \\ & 12 \\ & 14 \\ & 16 \\ & 18 \end{aligned}$ |  | Address Low: CPU address inputs used to generate memory row address. <br> $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ used to select 4 K RAM mode. |
| $\mathrm{AH}_{0}$ <br> $\mathrm{AH}_{1}$ <br> $\mathrm{AH}_{2}$ <br> $\mathrm{AH}_{3}$ <br> $\mathrm{AH}_{4}$ <br> $\mathrm{AH}_{5}$ <br> $\mathrm{AH}_{6}$ | $\begin{aligned} & 5 \\ & 4 \\ & 3 \\ & 2 \\ & 1 \\ & 39 \\ & 38 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Address High: CPU address inputs used to generate memory column address. |
| $\begin{aligned} & \mathrm{B}_{0} / \mathrm{AL}_{7} \\ & \mathrm{~B}_{1} / \mathrm{OP}_{1} / \\ & \mathrm{AH}_{7} \end{aligned}$ | $\begin{aligned} & 24 \\ & 25 \end{aligned}$ | $1$ | Bank Select Inputs: Used to gate the appropriate RAS output for a memory cycle. $\mathrm{B}_{1} / \mathrm{OP}_{1}$ option used to select the Advanced Read Mode. (Not available in 64K mode.) See Figure 5. <br> When in 64K RAM Mode, pins 24 and 25 operate as the $\mathrm{AL}_{7}$ and $\mathrm{AH}_{7}$ address inputs. |
| $\overline{\text { PCS }}$ | 33 | 1 | Protected Chip Select: Used to enable the memory read and write inputs. Once a cycle is started, it will not abort even if $\overline{\text { PCS }}$ goes inactive before cycle completion. |
| $\overline{\text { WR }}$ | 31 | 1 | Memory Write Request. |
| $\overline{\mathrm{RD}} / \mathrm{S} 1$ | 32 | 1 | Memory Read Request: S 1 function used in Advanced Read mode selected by OP 1 (pin 25). |
| REFRQ/ <br> ALE | 34 | 1 | External Refresh Request: ALE function used in Advanced Read mode, selected by OP 1 (pin 25). |
| $\begin{aligned} & \overline{\mathrm{OUT}}_{0} \\ & \overline{\mathrm{OUT}}_{1} \\ & \mathrm{OUT}_{2} \\ & \mathrm{OUT}_{3} \\ & \mathrm{OUTT}_{4} \mathrm{OUT}^{\mathrm{OUT}}{ }^{\mathrm{OUT}_{5}} \\ & \overline{\mathrm{OUT}}_{6} \end{aligned}$ | $\begin{aligned} & 7 \\ & 9 \\ & 11 \\ & 13 \\ & 15 \\ & 17 \\ & 19 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | Output of the Multiplexer: These outputs are designed to drive the addresses of the Dynamic RAM array. (Note that the $\overline{\mathrm{OUT}}_{0-7}$ pins do not require inverters or drivers for proper operation.) |
| WE | 28 | 0 | Write Enable: Drives the Write Enable inputs of the Dynamic RAM array. |
| $\overline{\text { CAS }}$ | 27 | 0 | Column Address Strobe: This output is used to latch the Column Address into the Dynamic RAM array. |


| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \overline{\mathrm{RAS}}_{0} \\ & \overline{\mathrm{RAS}}_{1} \\ & \overline{\mathrm{RAS}}_{2} / \\ & \overline{\mathrm{OUT}}_{7} \\ & \overline{\mathrm{RAS}}_{3} / \mathrm{B}_{0} \end{aligned}$ | $\begin{aligned} & 21 \\ & 22 \\ & 23 \\ & 26 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 1 / 0 \end{aligned}$ | Row Address Strobe: Used to latch the Row Address into the bank of dynamic RAMs, selected by the 8203 Bank Select pins ( $\mathrm{B}_{0}, \mathrm{~B}_{1} / \mathrm{OP}_{1}$ ). In 64 K mode, only $\overline{\operatorname{RAS}}_{0}$ and $\overline{\mathrm{RAS}}_{1}$ are available; pin 23 operates as $\mathrm{OUT}_{7}$ and pin 26 operates as the $\mathrm{B}_{0}$ bank select input. |
| $\overline{\text { XACK }}$ | 29 | 0 | Transfer Acknowledge: This output is a strobe indicating valid data during a read cycle or data written dúring a write cycle. $\overline{\text { XACK can be used to latch valid }}$ data from the RAM array. |
| $\overline{\text { SACK }}$ | 30 | 0 | 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{\mathrm{SACK}}$ is delayed until $\overline{\text { XACK }}$ in the memory access cycle). |
| $\mathrm{X}_{0} / \mathrm{OP}_{2}$ <br> $X_{1}$ CLK | $\begin{aligned} & 36 \\ & 37 \end{aligned}$ | $\begin{aligned} & 1 / 0 \\ & 1 / 0 \end{aligned}$ | Oscillator Inputs: These inputs are designed for a quartz crystal to control the frequency of the oscillator. If $\mathrm{X}_{0} / \mathrm{OP}_{2}$ is shorted to pin $40\left(\mathrm{~V}_{\mathrm{CC}}\right)$ or if $\mathrm{X}_{0} / \mathrm{OP}_{2}$ is connected to +12 V through a $1 \mathrm{~K} \Omega$ resistor then $X_{1}$ /CLK becomes a TTL input for an external clock. (Note: Crystal mode for the 8203-1 and the 8203-3 only). |
| 16K/ $\overline{64 \mathrm{~K}}$ | 35 | 1 | Mode Select: This input selects 16 K mode $(2117,2118)$ or 64 K mode (2164). Pins 23-26 change function based on the mode of operation. |
| $\mathrm{V}_{\mathrm{CC}}$ | 40 |  | Power Supply: +5V. |
| GND | 20 |  | Ground. |

## Functional Description

The 8203 provides a complete dynamic RAM controller for microprocessor systems as well as expansion memory boards. All of the necessary control signals are provided for 2164, 2118, 2117, and 2104A dynamic RAM's.

The 8203 has three modes, one for 4K dynamic RAM's, one for 16K's and one for 64K's, controlled by pin 35 and pin 18.


Figure 3. Crystal Operation for the 8203-1 and 8203-3

All 8203 timing is generated from a single reference clock. This clock is provided via an external oscillator or an onchip crystal oscillator. All output signal transitions are synchronous with respect to this clock reference, except for the trailing edges of the CPU handshake signals SACK and $\overline{\text { XACK. }}$

CPU memory requests normally use the $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs. The Advanced-Read mode allows ALE and S1 to be used in place of the $\overline{\mathrm{RD}}$ input.

Failsafe refresh is provided via an internal timer which generates refresh requests. Refresh requests can also be generated via the REFRQ input.

An on-chip synchronizer/arbiter prevents memory and refresh requests from affecting a cycle in progress. The READ, WRITE, and external REFRESH requests may be asynchronous to the 8203 clock; on-chip logic will synchronize the requests, and the arbiter will decide if the requests should be delayed, pending completion of a cycle in progress.

## 16K/ $\overline{64 K}$ Option Selection

Pin 35 is a strap input that controls the two 8203 modes. Figure 4 shows the four pins that are multiplexed. In 16K mode (pin 35 tied to VCC or left open), the 8203 has two Bank Select inputs to select one of four $\overline{\mathrm{RAS}}$ outputs. In this mode, the 8203 is exactly compatible with the Intel 8202A Dynamic RAM Controller. In 64K mode (pin 35 tied to GND), there is only one Bank Select input (pin 26) to select the two $\overline{\text { RAS }}$ outputs. More than two banks of 64 K dynamic RAM's can be used with external logic.

## Other Option Selections

The 8203 has three strapping options. When $\mathrm{OP}_{1}$ is selected (16K mode only), pin 32 changes from a $\overline{R D}$ input to an S1 input, and pin 34 changes from a REFRQ input to an ALE input. See "Refresh Cycles" and "Read Cycles" for more detail. $\mathrm{OP}_{1}$ is selected by tying pin 25 to +12 V through a 5.1 K ohm resistor.

When $\mathrm{OP}_{2}$ is selected, the internal oscillator is disabled and pin 37 changes from a crystal input $\left(X_{1}\right)$ to a CLK input for an external TTL clock. $\mathrm{OP}_{2}$ is selected by shorting pin $36\left(\mathrm{X}_{0} / \mathrm{OP}_{2}\right)$ directly to pin $40\left(\mathrm{~V}_{\mathrm{CC}}\right)$. No current limiting resistor should be used. $\mathrm{OP}_{2}$ may also be selected by tying pin 36 to +12 V through a $1 \mathrm{~K} \Omega$ resistor.
$\mathrm{OP}_{3}$ is selected by connecting pin 18 to +12 V through a 5. 1 K ohm resistor, the 8203 will change its internal refresh timer from 128-row refresh $(2164,2118,2117)$ to 64 -row refresh (2104A).

## Refresh Timer

The refresh timer is used to monitor the time since the last refresh cycle occurred. When the appropriate amount of time has elapsed, the refresh timer will request a refresh cycle. External refresh requests will reset the refresh timer.

## Refresh Counter

The refresh counter is used to sequentially refresh all of the memory's rows. The 8-bit counter is incremented after every refresh cycle.

| Pin \# | 16K Function | 64K Function |
| :--- | :--- | :--- |
| 23 | $\overline{\mathrm{RAS}}_{2}$ | Address Output $\left(\overline{\mathrm{OUT}}_{7}\right)$ |
| 24 | ${\text { Bank Select }\left(\mathrm{B}_{0}\right)}^{\text {Address Input }\left(\mathrm{AL}_{7}\right)}$ |  |
| 25 | ${\text { Bank Select }\left(\mathrm{B}_{1}\right)}^{\text {Address Input }\left(\mathrm{AH}_{7}\right)}$ |  |
| 26 | $\overline{\mathrm{RAS}}_{3}$ | Bank Select $\left(\mathrm{B}_{0}\right)$ |

Figure 4. $16 \mathrm{~K} / \overline{64 \mathrm{~K}}$ Mode Selection

| Inputs |  |  | Outputs |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | B1 | Bo | $\overline{\mathbf{R A S}} \mathbf{0}$ | $\overline{\text { RAS }}_{1}$ | RAS 2 | $\overline{\text { RAS }}_{3}$ |
| 16K Mode | 0 | 0 | 0 | 1 | 1 | 1 |
|  | 0 | 1 | 1 | 0 | 1 | 1 |
|  | 1 | 0 | 1 | 1 | 0 | 1 |
|  | 1 | 1 | 1 | 1 | 1 | 0 |
| 64K | - | 0 | 0 | 1 | - | - |
| Mode | - | 1 | 1 | 0 | - | - |

Figure 5. Bank Selection

| Description | Pin \# | Normal Function | Option Function |
| :--- | :--- | :--- | :--- |
| $\mathrm{B}_{1} / \mathrm{OP}_{1}(16 \mathrm{~K}$ only)/AH7 | 25 | Bank (RAS) Select | Advanced-Read Mode |
| $\mathrm{X}_{0} / \mathrm{OP}_{2}$ | 36 | Crystal Oscillator (8203-1 and 8203-3) | External Oscillator |
| $\mathrm{AL}_{6} / \mathrm{OP}_{3}$ | 18 | Address Input | 64-Row Refresh |

Figure 6. 8203 Option Selection

## Address Multiplexer

The address multiplexer takes the address inputs and the refresh counter outputs, and gates them onto the address outputs at the appropriate time. The address outputs, in conjunction with the $\overline{\mathrm{RAS}}$ and $\overline{\mathrm{CAS}}$ outputs, determine the address used by the dynamic RAMs for read, write, and refresh cycles. During the first part of a read or write cycle, $\mathrm{AL}_{0}-\mathrm{AL}_{7}$ are gated to $\overline{\mathrm{OUT}}_{0}-\overline{\mathrm{OUT}}_{7}$, then $\mathrm{AH}_{0}-\mathrm{AH}_{7}$ are gated to the address outputs.

During a refresh cycle, the refresh counter is gated onto the address outputs. All refresh cycles are RAS-only refresh ( $\overline{\mathrm{CAS}}$ inactive, $\overline{\mathrm{RAS}}$ active).

To minimize buffer delay, the information on the address outputs is inverted from that on the address inputs.
$\overline{\mathrm{OUT}}_{\mathrm{O}}-\overline{\mathrm{OUT}}_{7}$ do not need inverters or buffers unless additional drive is required.

## Synchronizer/Arbiter

The 8203 has three inputs, REFRQ/ALE (pin 34), $\overline{\text { RD (pin }}$ 32) and $\overline{W R}$ (pin 31). The $\overline{R D}$ and $\overline{W R}$ inputs allow an external CPU to request a memory read or write cycle, respectively. The REFRQ / ALE input allows refresh requests to be requested external to the 8203.

All three of these inputs may be asynchronous with respect to the 8203's clock. The arbiter will resolve conflicts between refresh and memory requests, for both pending cycles and cycles in progress. Read and write requests will be given priority over refresh requests.

## System Operation

The 8203 is always in one of the following states:
a) IDLE
b) TEST Cycle
c) REFRESH Cycle
d) READ Cycle
e) WRITE Cycle

The 8203 is normally in the IDLE state. Whenever one of the other cycles is requested, the 8203 will leave the IDLE state to perform the desired cycle. If no other cycles are pending, the 8203 will return to the IDLE state.

## Test Cycle

The TEST Cycle is used to check operation of several 8203 internal functions. TEST cycles are requested by activating the $\overline{\mathrm{PCS}}, \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ inputs. The TEST Cycle will reset the refresh address counter and perform a WRITE Cycle. The TEST Cycle should not be used in normal system operation, since it would affect the dynamic RAM refresh.

## Refresh Cycles

The 8203 has two ways of providing dynamic RAM refresh:

1) Internal (failsafe) refresh
2) External (hidden) refresh

Both types of 8203 refresh cycles activate all of the $\overline{\text { RAS }}$ outputs, while $\overline{C A S}, \overline{W E}, \overline{S A C K}$, and $\overline{\text { XACK }}$ remain inactive.

Internal refresh is generated by the on-chip refresh timer. The timer uses the 8203 clock to ensure that refresh of all rows of the dynamic RAM occurs every 2 milliseconds ( 128 cycles) or every 4 milliseconds ( 256 cycles). If REFRQ is inactive, the refresh timer will request a refresh cycle every 10-16 microseconds.

External refresh is requested via the REFRQ input (pin 34). External refresh control is not available when the Ad-vanced-Read mode is selected. External refresh requests are latched, then synchronized to the 8203 clock.

The arbiter will allow the refresh request to start a refresh cycle only if the 8203 is not in the middle of a cycle.

When the 8203 is in the idle state a simultaneous memory request and external refresh request will result in the memory request being honored first. This 8203 characteristic can be used to "hide" refresh cycles during system operation. A circuit similar to Figure 7 can be used to decode the CPU's instruction fetch status to generate an external refresh request. The refresh request is latched while the 8203 performs the instruction fetch; the refresh cycle will start immediately after the memory cycle is completed, even if the $\overline{\mathrm{RD}}$ input has not gone inactive. If the CPU's instruction decode time is long enough, the 8203 can complete the refresh cycle before the next memory request is generated.

If the 8203 is not in the idle state then a simultaneous memory request and an external refresh request may result in the refresh request being honored first.


Figure 7. Hidden Refresh

Certain system configurations require complete external refresh requests. If external refresh is requested faster than the minimum internal refresh timer (tREF), then, in effect, all refresh cycles will be caused by the external refresh request, and the internal refresh timer will never generate a refresh request.

## Read Cycles

The 8203 can accept two different types of memory Read requests:

1) Normal Read, via the $\overline{R D}$ input
2) Advanced Read, using the S1 and ALE inputs (16K mode only)

The user can select the desired Read request configuration via the B1/OP1 hardware strapping option on pin 25.

|  | Normal Read | Advanced Read |
| :--- | :--- | :--- |
| Pin 25 | B1 input | $\mathrm{OP}_{1}(+12 \mathrm{~V})$ |
| Pin 32 | RD input | $\mathrm{S}_{1}$ input |
| Pin 34 | REFRQ input | ALE input |
| \# RAM banks | $4\left(\overline{R A S}_{0-3}\right)$ | $2\left(\overline{R A S}_{2-3}\right)$ |
| Ext. Refresh | Yes | No |

Figure 8. 8203 Read Options

Normal Reads are requested by activating the $\overline{\mathrm{RD}}$ input, and keeping it active until the 8203 responds with an $\overline{\mathrm{XACK}}$ pulse. The $\overline{\mathrm{RD}}$ input can go inactive as soon as the command hold time (tCHS) is met.

Advanced Read cycles are requested by pulsing ALE while $S 1$ is active; if $S 1$ is inactive (low) ALE is ignored. Advanced Read timing is similiar to Normal Read timing, except the falling edge of ALE is used as the cycle start reference.

If a Read cycle is requested while a refresh cycle is in progress, then the 8203 will set the internal delayedSACK latch. When the Read cycle is eventually started, the 8203 will delay the active $\overline{\text { SACK }}$ transition until $\overline{\text { XACK }}$ goes active, as shown in the AC timing diagrams. This delay was designed to compensate for the CPU's READY setup and hold times. The delayed-SACK latch is cleared after every READ cycle.

Based on system requirements, either $\overline{\mathrm{SACK}}$ or $\overline{\mathrm{XACK}}$ can be used to generate the CPU READY signal. $\overline{X A C K}$ will normally be used; if the CPU can tolerate an advanced READY, then $\overline{\text { SACK }}$ can be used, but only if the CPU can tolerate the amount of advance provided by $\overline{\text { SACK. If }}$ SACK arrives too early to provide the appropriate number of WAIT states, then either $\overline{\text { XACK }}$ or a delayed form of $\overline{\text { SACK }}$ should be used.

## Write Cycles

Write cycles are similiar to Normal Read cycles, except for the WE output. $\bar{W} E$ is held inactive for Read cycles, but goes active for Write cycles. All 8203 Write cycles are "early-write" cycles; $\overline{W E}$ goes active before $\overline{\mathrm{CAS}}$ goes active by an amount of time sufficient to keep the dynamic RAM output buffers turned off.

## General System Considerations

All memory requests (Normal Reads, Advanced Reads, Writes) are qualified by the $\overline{\mathrm{PCS}}$ input. $\overline{\mathrm{PCS}}$ should be stable, either active or inactive, prior to the leading edge of $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, or ALE. Systems which use battery backup should pullup $\overline{\mathrm{PCS}}$ to prevent erroneous memory requests.

In order to minimize propagation delay, the 8203 uses an inverting address multiplexer without latches. The system must provide adequate address setup and hold times to guarantee $\overline{R A S}$ and $\overline{C A S}$ setup and hold times for the RAM. The tAD AC parameter should be used for this system calculation.

The $\mathrm{B}_{0}-\mathrm{B}_{1}$ inputs are similiar to the address inputs in that they are not latched. $B_{0}$ and $B_{1}$ should not be changed during a memory cycle, since they directly control which $\overline{\text { RAS }}$ output is activated.

The 8203 uses a two-stage synchronizer for the memory request inputs ( $\overline{R D}, \overline{W R}, A L E$ ), and a separate two stage synchronizer for the external refresh input (REFRQ). As with any synchronizer, there is always a finite probability of metastable states inducing system errors. The 8203 synchronizer was designed to have a system error rate less than 1 memory cycle every three years based on the full operating range of the 8203 .

A microprocessor system is concerned when the data is valid after $\overline{\mathrm{RD}}$ goes low. See Figure 9. In order to calculate memory read access times, the dynamic RAM's A.C. specifications must be examined, especially the RAS-access time (trAC) and the CAS-access time (tCAC). Most configurations will be CAS-access limited; i.e., the data from the RAM will be stable $t_{c c, m a x}(8203)+t_{C A C}$ (RAM) after a memory read cycle is started. Be sure to add any delays (due to buffers, data latches, etc.) to calculate the overall read access time.

Since the 8203 normally performs "early-write" cycles, the data must be stable at the RAM data inputs by the time $\overline{\mathrm{CAS}}$ goes active, including the RAM's data setup time. If the system does not normally guarantee sufficient write data setup, you must either delay the $\overline{\mathrm{WR}}$ input signal or delay the $8203 \overline{\mathrm{WE}}$ output.

Delaying the $\overline{W R}$ input will delay all 8203 timing, including the READY handshake signals, $\overline{S A C K}$ and $\overline{\text { XACK }}$, which


Figure 9. Read Access Time
may increase the number of WAIT states generated by the CPU.

If the $\overline{\mathrm{WE}}$ output is externally delayed beyond the $\overline{\mathrm{CAS}}$ active transition, then the RAM will use the falling edge of $\overline{\text { WE }}$ to strobe the write data into the RAM. This WE transition should not occur too late during the CAS active transition, or else the $\overline{\text { WE }}$ to $\overline{C A S}$ requirements of the RAM will not be met.

The $\overline{\mathrm{RAS}}_{0-3}, \overline{\mathrm{CAS}} \overline{\mathrm{OUT}}_{0-6}$, and $\overline{\mathrm{WE}}$ outputs contain onchip series damping resistors (typically $20 \Omega$ ) to minimize overshoot.

Some dynamic RAMs require more than $2.4 \mathrm{~V} \mathrm{~V}_{\mathrm{IH}}$. Noise immunity may be improved for these RAMs by adding pullup resistors to the 8203's outputs. Intel RAMs do not require pull-up resistors.


Figure 10. Typical 8088 System


Figure 11. 8086/256K Byte System

## 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 \mathrm{~V}^{4}$
Power Dissipation .................................. . . 1.5 Watts
*NOTE: 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 10 \%(5.0 \mathrm{~V} \pm 5 \%$ for $8203-3) ; \mathrm{GND}=0 \mathrm{~V}$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1.0 | V | $\mathrm{IC}=-5 \mathrm{~mA}$ |
| Icc | Power Supply Current |  | 290 | mA |  |
| IF | Forward Input Current CLK, 64K/16K Mode select All Other Inputs ${ }^{3}$ |  | $\begin{array}{r} -2.0 \\ -320 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & V_{F}=0.45 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Current ${ }^{3}$ |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$; Note 1 |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage SACK, XACK <br> All Other Outputs |  | $\begin{aligned} & 0.45 \\ & 0.45 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=3 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage <br> $\overline{\text { SACK, }} \overline{\text { XACK }}$ <br> All Other Outputs | $\begin{aligned} & 2.4 \\ & 2.6 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.65 \mathrm{~V} \\ & \mathrm{IOH}_{\mathrm{OH}}=-1 \mathrm{~mA} \\ & \mathrm{IOH}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ (Note 2) |
| $\mathrm{V}_{\text {IH1 }}$ | Input High Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH} 2}$ | Option Voltage |  | $\mathrm{V}_{\mathrm{CC}}$ | V | (Note 4) |
| $\mathrm{CIN}^{\text {N }}$ | 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} \end{aligned}$ |

## NOTES:

1. $I_{R}=200 \mu \mathrm{~A}$ for pin 37 (CLK).
2. For test mode $\overline{R D} \& \overline{W R}$ must be held at GND.
3. Except for pin 36 in XTAL mode.
4. 



## 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 \%(5.0 \mathrm{~V} \pm 5 \%$ for $8203-3$ ); GND $=0 \mathrm{~V}$
 other pins are measured at 1.5 V . All times are in nsec.

| Symbol | Parameter | Min | Max | Notes |
| :---: | :---: | :---: | :---: | :---: |
| tp | Clock Period | 40 | 54 |  |
| tpH | External Clock High Time | 20 |  |  |
| tPL | External Clock Low Time-above ( $>$ ) 20 mHz | 17 |  |  |
| tpL | External Clock Low Time-below ( $\leq$ ) 20 mHz | 20 |  |  |
| $\mathrm{t}_{\mathrm{R}} \mathrm{C}$ | Memory Cycle Time | 10tp-30 | 12tp | 4, 5 |
| treF | Refresh Time ( 64 cycles-4K mode) | 548tp | 576tp |  |
| treF | Refresh Time ( 128 cycles) | 264tp | 288tp |  |
| trP | $\overline{\text { RAS }}$ Precharge Time | $4 t p-30$ |  |  |
|  | $\overline{\mathrm{R} A S}$ Hold After $\overline{\mathrm{CAS}}$ | $5 t p-30$ |  | 3 |
| ${ }^{\text {t ASR }}$ | Address Setup to $\overline{\mathrm{RAS}}$ | tp -30 |  | 3 |
| $t_{\text {t }}$ | Address Hold From RAS | tp - 10 |  | 3 |
| ${ }^{\text {t }}$ ASC | Address Setup to $\overline{\mathrm{CAS}}$ | tp - 30 |  | 3 |
| ${ }^{t} \mathrm{CAH}$ | Address Hold from CAS | $5 \mathrm{tp}-20$ |  | 3 |
| ${ }^{\text {t CAS }}$ | $\overline{\text { CAS Pulse Width }}$ | $5 t p-10$ |  |  |
| twCs | $\overline{\text { WE Setup to CAS }}$ | tp - 40 |  |  |
| ${ }^{\text {tWCH }}$ | $\overline{\text { WE Hold After } \overline{C A S}}$ | $5 \mathrm{tp}-35$ |  | 8 |
| tRS | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}, \mathrm{REFRQ}$ delay from $\overline{\mathrm{RAS}}$ | 5tp |  | 2, 6 |
| tMRP | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ setup to $\overline{\mathrm{RAS}}$ | 0 |  | 5 |
| trMS | REFRQ setup to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 2 tp |  | 6 |
| trMP | REFRQ setup to $\overline{\mathrm{RAS}}$ | 2tp |  | 5 |
| tPCS | $\overline{\text { PCS }}$ Setup to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ | 20 |  |  |
| ${ }^{\text {t }} \mathrm{AL}$ | S1 Setup to ALE | 15 |  |  |
| tha | S1 Hold from ALE | 30 |  |  |
| ${ }^{\text {t }} \mathrm{CR}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ to $\overline{\mathrm{RAS}}$ Delay | tp +30 | $2 \mathrm{tp}+70$ | 2 |
| tcc | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{ALE}$ to $\overline{\mathrm{CAS}}$ Delay | $3 \mathrm{tp}+25$ | $4 \mathrm{t} p+85$ | 2 |
| tsc | CMD Setup to Clock | 15 |  | 1 |
| tMRS | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ setup to REFRQ | 5 |  | 2 |
| ${ }^{t} \mathrm{CA}$ | $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, ALE to $\overline{\text { SACK }}$ Delay |  | $2 t p+47$ | 2 |
| tcx | $\overline{\mathrm{CAS}}$ to $\overline{\text { AACK }}$ Delay | $5 t p-25$ | $5 t p+20$ |  |
| tcs | $\overline{\text { CAS }}$ to $\overline{\text { SACK }}$ Delay | $5 \mathrm{tp}-25$ | $5 t p+40$ | 2 |
| ${ }^{\text {t }}$ ACK | $\overline{\text { XACK }}$ to $\overline{C A S}$ Setup | 10 |  |  |
| ${ }_{\text {t }}$ W w | $\overline{\text { XACK }}$ Pulse Width | tp-25 |  | 7 |
| ${ }_{\text {t }}$ CK | $\overline{\text { SACK }}$, $\overline{\text { XACK }}$ turn-off Delay |  | 35 |  |
| ${ }_{\text {t }} \mathrm{KCH}$ | CMD Inactive Hold after $\overline{\text { SACK, }} \overline{\text { XACK }}$ | 10 |  |  |
| tLL | REFRQ Pulse Width | 20 |  |  |
| ${ }^{\text {t }} \mathrm{CHS}$ | CMD Hold Time | 30 |  |  |
| trFR | REFRQ to $\overline{\mathrm{RAS}}$ Delay |  | $4 t p+100$ | 6 |
| twW | $\overline{\mathrm{WR}}$ to $\overline{\text { WE Delay }}$ | 0 | 50 | 8 |
| $\mathrm{t}_{\mathrm{AD}}$ | CPU Address Delay | 0 | 40 | 3 |

## WAVEFORMS

Normal Read or Write Cycle


Advanced Read Mode


WAVEFORMS (cont'd)
Memory Compatibility Timing


## Write Cycle Timing



WAVEFORMS (cont'd)
Read or Write Followed By External Refresh


External Refresh Followed By Read or Write


WAVEFORMS (cont'd)

## Clock And System Timing



Table 28203 Output Loading. All specifications are for the Test Load unless otherwise noted.

| Pin | Test Load |
| :---: | :---: |
| $\overline{\text { SACK, }} \overline{\text { XACK }}$ | $C_{L}=30 \mathrm{pF}$ |
| $\overline{\text { OUT }}_{0}$-OUT $_{6}$ | $C_{L}=160 \mathrm{pF}$ |
| $\overline{\mathrm{RAS}}_{0}-\overline{\mathrm{RAS}}_{3}$ | $\mathrm{C}_{\mathrm{L}}=60 \mathrm{pF}$ |
| $\overline{W E}$ | $\mathrm{C}_{\mathrm{L}}=224 \mathrm{pF}$ |
| $\overline{\text { CAS }}$ | $\mathrm{C}_{\mathrm{L}}=320 \mathrm{pF}$ |

## NOTES:

1. $\mathrm{t}_{\mathrm{sc}}$ is a reference point only. ALE, $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and REFRQ inputs do not have to be externally synchronized to 8203 clock.
2. If $t_{R S}$ min and $\mathrm{I}_{\mathrm{MRS}}$ min are met then $\mathrm{I}_{\mathrm{CA}}, \mathrm{t}_{\mathrm{CR}}$, and $\mathrm{t}_{\mathrm{C}}$ are valid, otherwise tcs is valid.
3. $t_{\text {ASR }}, t_{\text {RAH }}, t_{A S C}, t_{C A H}$, and $t_{\text {RSH }}$ depend upon BO-B1 and CPU address remaining stable throughout the memory cycle. The address inputs are not latched by the 8203.
4. For back-to-back refresh cycles, $t_{R C} \max =13$ tp
5. $t_{\text {RC }}$ max is valid only if $t_{\text {RMP }}$ min is met (READ, WRITE followed by REFRESH) or $\mathrm{t}_{\text {MRP }} \mathrm{min}$ is met (REFRESH followed by READ, WRITE).
6. $t_{\text {RFR }}$ is valid only if $t_{\text {RS }}$ min and $t_{R M S}$ min are met.
7. ${ }^{\mathrm{t}} \mathrm{XW}$ min applies when $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ has already gone high. Otherwise $\overline{X A C K}$ follows $\overline{R D}, \overline{W R}$.
8. WE goes high according to ${ }^{W} W C H$ or ${ }^{W} W W$, whichever occurs first.
A.C. TESTING LOAD CIRCUIT


NOTE: $C_{L}$ includes jig capacitance

The typical rising and falling characteristic curves for the $\overline{O U T}, \overline{R A S}, \overline{C A S}$ and $\overline{W E}$ output buffers can be used to determine the effects of capacitive loading on the A.C.

Timing Parameters. Using this design tool in conjunction with the timing waveforms, the designer can determine typical timing shifts based on system capacitive load.

## A.C. CHARACTERISTICS FOR DIFFERENT CAPACITIVE LOADS




## NOTE:

Use the Test Load as the base capacitance for estimating timing shifts for system critical timing parameters.

## MEASUREMENT CONDITIONS:

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$
$V_{C C}=+5 \mathrm{~V}$
$t_{p}=50 \mathrm{~ns}$

Pins not measured are loaded with the Test Load capacitance

Example: Find the effect on tCR and tCC using 322164 Dynamic RAMs configured in 2 banks.

1. Determine the typical RAS and CAS capacitance: From the data sheet RAS $=5 \mathrm{pF}$ and CAS $=5 \mathrm{pF}$. $\therefore$ RAS load $=80 \mathrm{pF}+$ board capacitance. CAS load $=160 \mathrm{pF}+$ board capacitance. Assume $2 \mathrm{pF} /$ in (trace length) for board capacitance and for this example 4 inches for RAS and 8 inches for CAS.
2. From the waveform diagrams, we determine that the falling edge timing is needed for tCR and tcC. Next find the curve that best approximates the test load; i.e., 68 pF for RAS and 330 pF for CAS.
3. If we use 88 pF for RAS loading, then tCR (min.) spec should be increased by about 1 ns , and tCR (max.) spec should be increased by about 2 ns. Similarly if we use 176 pF for CAS, then tCC ( min .) should decrease by 3 ns and tcC (max.) should decrease by about 7 ns .

# 8206 <br> ERROR DETECTION AND CORRECTION UNIT 

- Detects and Corrects All Single Bit Errors
- Detects All Double Bit and Most Multiple Bit Errors
- 52 ns Maximum for Detection; 67 ns Maximum for Correction (16 Bit System)
- Expandable to Handle 80 Bit Memories
- Syndrome Outputs for Error Logging
- Separate Input and Output Busses-No Timing Strobes Required
- Supports Reads With and Without Correction, Writes, Partial (Byte) Writes, and Read-Modify-Writes
- HMOS Technology for Low Power
- 68 Pin Leadless JEDEC Package
- Single +5V Supply

The HMOS 8206 Error Detection and Correction Unit is a high-speed device that provides error detection and correction for memory systems (static and dynamic) requiring high reliability and performance. Each 8206 handles 8 or 16 data bits and up to 8 check bits. 8206 's can be cascaded to provide correction and detection for up to 80 bits of data. Other 8206 features include the ability to handle byte writes, memory initialization, and error logging.


Figure 1. 8206 Block Diagram

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{DI}_{0-15}$ | $\begin{gathered} \hline 1,68-61, \\ 59-53 \end{gathered}$ | 1 | Data In: These inputs accept a 16 bit data word from RAM for error detection and/or correction. |
| CBI/SYIO <br> CBI/SYI 1 <br> $\mathrm{CBI} / \mathrm{SYI}_{2}$ <br> $\mathrm{CBI}^{\mathrm{SYY}}{ }_{3}$ <br> CBI/SYI 4 <br> CBI/SYI 5 <br> CBI/SYI 6 <br> CBI/SYI 7 | $\begin{array}{r} 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 9 \\ 10 \\ 11 \end{array}$ |  | Check Bits In/Syndrome In: In a single 8206 system, or in the master in a multi8206 system, these inputs accept the check bits (5 to 8) from the RAM. In a single 820616 bit system, $\mathrm{CBI}_{0-5}$ are used. In slave 8206's these inputs accept the syndrome from the master. |
| DO/WDlo <br> DO/WDI 1 <br> DO/WDI 2 <br> DO/WDI 3 <br> DO/WDI 4 <br> DO/WDI 5 <br> DO/WDI 6 <br> DO/WDI 7 <br> DO/WDI 8 <br> DO/WDI 9 <br> DO/WDI 10 <br> DO/WDI 11 <br> DO/WDI ${ }_{12}$ <br> DO/WDI 13 <br> DO/WDI 14 <br> DO/WDI ${ }_{15}$ | 51 50 49 48 47 46 45 44 42 41 40 39 38 37 36 35 | I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O <br> I/O | Data Out/Write Data In: In a read cycle, data accepted by $\mathrm{Dl}_{0-15}$ appears at these outputs corrected if $\overline{\mathrm{CRCT}}$ is low, or uncorrected if CRCT is high. The $\overline{\mathrm{BM}}$ inputs must be high to enable the output buffers during the read cycle. In a write cycle, data to be written into the RAM is accepted by these inputs for computing the write check bits. In a partial-write cycle, the byte not to be modified appears at either $\mathrm{DO}_{0-7}$ if $\mathrm{B} \overline{\mathrm{M}}_{0}$ is high, or $\mathrm{DO}_{8-15}$ if $\mathrm{B} \overline{\mathrm{M}}_{1}$ is high, for writing to the RAM. When $\overline{W Z}$ is active, it causes the 8206 to output all zeros at $\mathrm{DO}_{0-15}$, with the proper write check bits on CBO. |
| SYO/CBO/PPO SYO/CBO/PPO 1 SYO/CBO/PPO 2 SYO/CBO/PPO SYO/CBO/PPO 4 SYO/CBO/ $\mathrm{PPO}_{5}$ SYO/CBO/PPO 6 SYO/CBO/PPO ${ }_{7}$ | $\begin{aligned} & 23 \\ & 24 \\ & 25 \\ & 27 \\ & 28 \\ & 29 \\ & 30 \\ & 31 \end{aligned}$ | 0 0 0 0 0 0 0 0 | Syndrome Out/Check Bits Out/Partial Parity Out: In a single 8206 system, or in the master in a multi-8206 system, the syndrome appears at these outputs during a read. During a write, the write check bits appear. In slave 8206's the partial parity bits used by the master appear at these outputs. The syndrome is latched (during read-modify-writes) by R/W going low. |
| $\begin{aligned} & \mathrm{PPI}_{0} / \mathrm{POS}_{0} \\ & \mathrm{PPI}_{1} / \mathrm{POS}_{1} \end{aligned}$ | $\begin{aligned} & 13 \\ & 14 \end{aligned}$ | I | Partial Parity In/Position: In the master in a multi-8206 system, these inputs accept partial parity bits 0 and 1 from the slaves. In a slave 8206 these inputs inform it of its position within the system (1 to 4). Not used in a single 8206 system. |
| $\begin{aligned} & \mathrm{PPI}_{2} / \mathrm{NSL}_{0} \\ & \mathrm{PPl}_{3} / \mathrm{NSL}_{1} \end{aligned}$ | $\begin{aligned} & 15 \\ & 16 \end{aligned}$ | $1$ | Partial Parity In/Number of Slaves: In the master in a multi-8206 system, these inputs accept partial parity bits 2 and 3 from the slaves. In a multi-8206 system these inputs are used in slave number 1 to tell it the total number of slaves in the system (1 to 4). Not used in other slaves or in a single 8206 system. |
| $\mathrm{PPI}_{4} / \mathrm{CE}$ | 17 | I/O | Partial Parity In/Correctable Error: In the master in a multi-8206 system this pin accepts partial parity bit 4. In slave number 1 only, or in a single 8206 system, this pin outputs the correctable error flag. CE is latched by R/W going low. Not used in other slaves. |
| $\begin{aligned} & \mathrm{PPl}_{5} \\ & \mathrm{PPl}_{6} \\ & \mathrm{PPl}_{7} \end{aligned}$ | $\begin{aligned} & 18 \\ & 19 \\ & 20 \end{aligned}$ | $\begin{aligned} & 1 \\ & \text { I } \\ & \text { I } \end{aligned}$ | Partial Parity In: In the master in a multi-8206 system these pins accept partial parity bits 5 to 7 . The number of partial parity bits equals the number of check bits. Not used in single 8206 systems or in slaves. |
| ERROR | 22 | 0 | Error: This pin outputs the error flag in a single 8206 system or in the master of a multi-8206 system. It is latched by R/W going low. Not used in slaves. |
| $\overline{\text { CRCT }}$ | 52 | I | Correct: When low this pin causes data correction during a read or read-modify-write cycle. When high, it causes error correction to be disabled, although error checking is still enabled. |
| STB | 2 | 1 | Strobe: STB is an input control used to strobe data at the DI inputs and checkbits at the CBI/SYI inputs. The signal is active high to admit the inputs. The signals are latched by the high-to-low transition of STB. |

Table 1. Pin Description (Continued)

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \overline{B M}_{0} \\ & \overline{B M}_{1} \end{aligned}$ | $\begin{aligned} & 33 \\ & 32 \end{aligned}$ | I | Byte Marks: When high, the Data Out pins are enabled for a read cycle. When low, the Data Out buffers are tristated for a write cycle. $\overline{\mathrm{BM}}_{0}$ controls $\mathrm{DO}_{0-7}$, while $\overline{\mathrm{BM}}_{1}$ controls $\mathrm{DO}_{8-15}$. In partial (byte) writes, the byte mark input is low for the new byte to be written. |
| R/ $\bar{W}$ | 21 | 1 | Read/Write: When high this pin causes the 8206 to perform detection and correction (if CRCT is low). When low, it causes the 8206 to generate check bits. On the high-to-low transition the syndrome is latched internally for read-modify-write cycles. |
| $\bar{W} \mathbf{Z}$ | 34 | 1 | Write Zero: When low this input overrides the $\overline{\mathrm{BM}}_{0-1}$ and $\mathrm{R} / \overline{\mathrm{W}}$ inputs to cause the 8206 to output all zeros at $\mathrm{DO}_{0-15}$ with the corresponding check bits at $\mathrm{CBO}_{0-7}$. Used for memory initialization. |
| M/S | 4 | 1 | Master/Slave: Input tells the 8206 whether it is a master (high) or a slave (low). |
| $\overline{\text { SEDCU }}$ | 3 | 1 | Single EDC Unit: Input tells the master whether it is operating as a single 8206 (low) or as the master in a multi-8206 system (high). Not used in slaves. |
| $V_{\text {CC }}$ | 60 | 1 | Power Supply: +5V |
| $\mathrm{V}_{\text {SS }}$ | 26, 43 | 1 | Ground |

## FUNCTIONAL DESCRIPTION

The 8206 Error Detection and Correction Unit provides greater memory system reliability through its ability to detect and correct memory errors. It is a single chip device that can detect and correct all single bit errors and detect all double bit and some higher multiple bit errors. Some other odd multiple bit errors (e.g., 5 bits in error) are interpreted as single bit errors, and the CE flag is raised. While some even multiple bit errors (e.g., 4 bits in error) are interpreted as no error, most are detected as double bit errors. This error handling is a function of the number of check bits used by the 8206 (see Figure 2) and the specific Hamming code used. Errors in check bits are not distinguished from errors in a word.

For more information on error correction codes, see Intel Application Notes AP-46 and AP-73.

A single 8206 handles 8 or 16 bits of data, and up to 5 8206's can be cascaded in order to handle data paths of 80 bits. For a single 82068 bit system, the $\mathrm{DI}_{8-15}, \mathrm{DO} / \mathrm{WDI}_{8-15}$ and $\overline{\mathrm{BM}}_{1}$ inputs are grounded. See the Multi-Chip systems section for information on 24-80 bit systems.

The 8206 has a "flow through" architecture. It supports two kinds of error correction architecture: 1) Flow-through, or correct-always; and 2) Parallel, or check-only. There are two separate 16 -pin busses,

| DATA WORD BITS | CHECK BITS |
| :---: | :---: |
| 8 | 5 |
| 16 | 6 |
| 24 | 6 |
| 32 | 7 |
| 40 | 7 |
| 48 | 8 |
| 56 | 8 |
| 64 | 8 |
| 80 | 8 |

Figure 2. Number of Check Bits Used by 8206
one to accept data from the RAM (DI) and the other to deliver corrected data to the system bus (DO/ WDI). The logic is entirely combinatorial during a read cycle. This is in contrast to an architecture with only one bus, with bidirectional bus drivers that must first read the data and then be turned around to output the corrected data. The latter architecture typically requires additional hardware (latches and/or transceivers) and may be slower in a system due to timing skews of control signals.

## READ CYCLE

With the $R \bar{W}$ pin high, data is received from the RAM outputs into the DI pins where it is optionally latched by the STB signal. Check bits are generated from the data bits and compared to the check bits read from the RAM into the CBI pins. If an error is detected the ERROR flag is activated and the correctable error flag (CE) is used to inform the system whether the error was correctable or not. With the $\overline{\mathrm{BM}}$ inputs high, the word appears corrected at the DO pins if the error was correctable, or unmodified if the error was uncorrectable.

If more than one 8206 is being used, then the check bits are read by the master. The slaves generate a partial parity output (PPO) and pass it to the master. The master 8206 then generates and returns the syndrome to the slaves (SYO) for correction of the data.

The 8206 may alternatively be used in a "checkonly" mode with the CRCT pin left high. With the correction facility turned off, the propagation delay from memory outputs to 8206 outputs is significantly shortened. In this mode the 8206 issues an ERROR flag to the CPU, which can then perform one of several options: lengthen the current cycle for correction, restart the instruction, perform a diagnostic routine, etc.

A syndrome word, five to eight bits in length and containing all necessary information about the existence and location of an error, is made available to the system at the $\mathrm{SYO}_{0-7}$ pins. Error logging may be accomplished by latching the syndrome and the memory address of the word in error.

## WRITE CYCLE

For a full write, in which an entire word is written to memory, the data is written directly to the RAM, bypassing the 8206 . The same data enters the 8206 through the WDI pins where check bits are generated. The Byte Mark inputs must be low to tristate the DO drivers. The check bits, 5 to 8 in number, are then written to the RAM through the CBO pins for storage along with the data word. In a multi-chip system, the master writes the check bits using partial parity information from the slaves.

In a partial write, part of the data word is overwritten, and part is retained in memory. This is accomplished by performing a read-modify-write cycle. The complete old word is read into the 8206 and corrected,
with the syndrome internally latched by $R \bar{W}$ going low. Only that part of the word not to be modified is output onto the DO pins, as controlled by the Byte Mark inputs. That portion of the word to be overwritten is supplied by the system bus. The 8206 then calculates check bits for the new word, using the byte from the previous read and the new byte from the system bus, and writes them to the memory.

## READ-MODIFY-WRITE CYCLES

Upon detection of an error the 8206 may be used to correct the bit in error in memory. This reduces the probability of getting multiple-bit errors in subsequent read cycles. This correction is handled by executing read-modify-write cycles.

The read-modify-write cycle is controlled by the $\mathrm{R} / \overline{\mathrm{W}}$ input. After (during) the read cycle, the system dynamic RAM controller or CPU examines the 8206 ERROR and CE outputs to determine if a correctable error occurred. If it did, the dynamic RAM controller or CPU forces R $/ \bar{W}$ low, telling the 8206 to latch the generated syndrome and drive the corrected check bits onto the CBO outputs. The corrected data is available on the DO pins. The DRAM controller then writes the corrected data and corresponding check bits into memory.

The 8206 may be used to perform read-modifywrites in one or two RAM cycles. If it is done in two cycles, the 8206 latches are used to hold the data and check bits from the read cycle to be used in the following write cycle. The Intel 8207 Advanced Dynamic RAM controller allows read-modify-write cycles in one memory cycle. See the System Environment section.

## INITIALIZATION

A memory system.operating with ECC requires some form of initialization at system power-up in order to set valid data and check bit information in memory. The 8206 supports memory initialization by the write zero function. By activating the $\overline{W Z}$ pin, the 8206 will write a data pattern of zeros and the associated check bits in the current write cycle. By thus writing to all memory at power-up, a controller can set memory to valid data and check bits. Massive memory failure, as signified by both data and check bits all ones or zeros, will be detected as an uncorrectable error.

## MULTI-CHIP SYSTEMS

A single 8206 handles 8 or 16 bits of data and 5 or 6 check bits, respectively. Up to 5 8206's can be cascaded for 80 bit memories with 8 check bits.

When cascaded, one 8206 operates as a master, and all others as slaves. As an example, during a read cycle in a 32 bit system with one master and one slave, the slave calculates parity on its portion of the word-"partial parity"-and presents it to the master through the PPO pins. The master combines the partial parity from the slave with the parity it calculated from its own portion of the word to generate
the syndrome. The syndrome is then returned by the master to the slave for error correction. In systems with more than one slave the above description continues to apply, except that the partial parity outputs of the slaves must be XOR'd externally. Figure 3 shows the necessary external logic for multi-chip systems. Write and read-modify-write cycles are carried out analogously. See the System Operation section for multi-chip wiring diagrams.

There are several pins used to define whether the 8206 will operate as a master or a slave. Tables 2 and 3 illustrate how these pins are tied.

3a. 48 BIT SYSTEM


3b. 64 BIT SYSTEM


3c. 80 BIT SYSTEM


Figure 3. External Logic For Multi-Chip Systems

Table 2. Master/Slave Pin Assignments

| Pin No. | Pin Name | Master | Slave 1 | Slave 2 | Slave 3 | Slave 4 |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| 4 | $\mathrm{M} / \overline{\mathrm{S}}$ | +5 V | Gnd | Gnd | Gnd | Gnd |
| 3 | $\overline{\mathrm{SEDCU}}$ | +5 V | +5 V | +5 V | +5 V | +5 V |
| 13 | $\mathrm{PPI}_{0} / \mathrm{POS}_{0}$ | PPI | Gnd | +5 V | Gnd | +5 V |
| 14 | $\mathrm{PPI}_{1} / \mathrm{POS}_{1}$ | PPI | Gnd | Gnd | +5 V | +5 V |
| 15 | $\mathrm{PPI}_{2} / \mathrm{NSL}_{0}$ | PPI | $\star$ | +5 V | +5 V | +5 V |
| 16 | $\mathrm{PPI}_{3} / \mathrm{NSL}_{1}$ | PPI | $*$ | +5 V | +5 V | +5 V |

*See Table 3.
NOTE:
Pins 13, 14, 15, 16 have internal pull-up resistors and may be left as $\mathrm{N} . \mathrm{C}$. where specified as connecting to +5 V .
Table 3. NSL Pin Assignments for Slave 1

| Number of Slaves |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Pin | $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ | $\mathbf{4}$ |
| $\mathrm{PPI}_{2} / \mathrm{NSL}_{0}$ | Gnd | +5 V | Gnd | +5 V |
| $\mathrm{PPI}_{3} / \mathrm{NSL}_{1}$ | Gnd | Gnd | +5 V | +5 V |

The timing specifications for multi-chip systems must be calculated to take account of the external XOR gating in 3, 4, and 5 -chip systems. Let tXOR be the delay for a single external TTL XOR gate. Then the following equations show how to calculate the relevant timing parameters for 2-chip ( $n=0$ ), 3-chip ( $n=1$ ), 4-chip ( $n=2$ ), and 5-chip ( $n=2$ ) systems:

Data-in to corrected data-out (read cycle) $=$
TDVSV + TPVSV + TSVQV + ntXOR
Data-in to error flag (read cycle) $=$
TDVSV + TPVEV + ntXOR

Data-in to correctable error flag (read cycle) $=$ TDVSV + TPVSV + TSVCV + ntXOR

Write data to check-bits valid (full write cycle) = TQVQV + TPVSV + ntXOR

Data-in to check-bits valid (read-mod-write cycle) = TDVSV + TPVSV + TSVQV + TQVQV + TPVSV + 2ntXOR

Data-in to check-bits valid (non-correcting read-modify-write cycle) $=$
TDVQU + TQVQV + TPVSV + ntXOR

## HAMMING CODE

The 8206 uses a modified Hamming code which was optimized for multi-chip EDCU systems. The code is such that partial parity is computed by all 8206's in
parallel. No 8206 requires more time for propagation through logic levels than any other one, and hence no one device becomes a bottleneck in the parity operation. However, one or two levels of external TTL XOR gates are required in systems with three to five chips. The code appears in Table 4. The check bits are derived from the table by XORing or XNORing together the bits indicated by ' $X$ 's in each row corresponding to a check bit. For example, check bit 0 in the MASTER for data word 1000110101101011 will be " 0 ." It should be noted that the 8206 will detect the gross-error condition of all lows or all highs.

Error correction is accomplished by identifying the bad bit and inverting it. Table 4 can also be used as an error syndrome table by replacing the ' X 's with ' 1 's. Each column then represents a different syndrome word, and by locating the column corresponding to a particular syndrome the bit to be corrected may be identified. If the syndrome cannot be located then the error cannot be corrected. For example, if the syndrome word is 00110111, the bit to be corrected is bit 5 in the slave one data word (bit 21).

The syndrome decoding is also summarized in Table 5 , which can be used for error logging. By finding the appropriate syndrome word (starting with bit zero, the least significant bit), the result is either: 1) no error; 2) an identified (correctable) single bit error; 3) a double bit error; or 4) a multi-bit uncorrectable error.

Table 4. Modified Hamming Code Check Bit Generation
Check bits are generated by XOR'ing (except for the CB0 and CB1 data bits, which are XNOR'ed in the Master) the data bits in the rows corresponding to the check bits. Note there are 6 check bits in a 16-bit system, 7 in a 32-bit system, and 8 in 48-or-more-bit systems.


\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline BYTE NUMBER \& \& \& \& 4 \& \& \& \& \& \& \& 5 \& \& \& \& \& \& \& 6 \& \& \& \& \& \& \& 7 \& \& \& \& \& \& \& 8 \& \& \& \& \& \& 9 \& \& \& OPERATION <br>
\hline BIT NUMBER \& 0 \& 1 \& 2 \& 34 \& 5 \& 6 \& 7 \& 0 \& 1 \& 23 \& 4 \& 5 \& 6 \& 7 \& 0 \& 1 \& 23 \& 34 \& 5 \& 6 \& 7 \& 0 \& 1 \& 2 \& 4 \& 5 \& 6 \& 7 \& 0 \& 1 \& 2 \& 34 \& 5 \& 6 \& 7 \& 0 \& 2 \& 4 \& 6 \& \& OPERATION <br>
\hline CB0 $=$ \& $\times$ \& $x$ \& \& x \& x \& $x$ \& \& $x$ \& - - \& X \& \& $x$ \& - \& - \& x \& - $\times$ \& x \& - x \& x \& - \& - \& x \& - \& x \& \& \& x \& - \& \& x \& $x$ \& x - \& $x$ \& $\times$ \& $x-$ \& \& $x$ \& \& \& \& XOR <br>
\hline check ${ }^{\text {CB1 }}=$ \& \& - \& ${ }^{x}$ \& - - \& x \& - \& $x$ \& - \& $x$ \& $x$ \& x \& - \& x \& - \& - \& $x$ \& x \& - \& - \& $x$ \& $x$ \& x \& $x$ \& x \& - \& - \& $x$ \& - \& - \& $x$ \& $x$ \& - \& x \& $x$ \& $\times$ \& - \& $x$ \& - \& - \& \& XOR <br>
\hline CHECK CB2 = \& \& x \& $x$ \& $\times$ \& - \& $x$ \& $x$ \& - \& - ${ }^{\text {x }}$ \& $x$ \& x \& - \& - \& x \& - \& x \& $x$ \& $x$ \& $x$ \& $x$ \& \& - \& $x$ \& $\times$ \& \& $x$ \& - \& - \& $x$ \& - \& - \& $x$ \& x \& \& - \& - $\times$ \& $x$ \& - \& - \& \& XOR <br>
\hline BITS $\quad \begin{aligned} & \text { CB3 } \\ & \text { CB4 }\end{aligned}$ \& \& $x$ \& x \& $x \times$ \& - \& - \& \& $x$ \& $x$ \& $x$ \& - \& - \& - \& - \& x \& - \& $x$ \& - - \& $x$ \& $x$ \& - \& $x$ \& $x$ \& - \& X \& x \& - \& - \& - \& $x$ \& x \& $x \times$ \& - \& \& $x$ \& $x$ \& - \& x \& - \& \& XOR <br>
\hline BITS $\quad \begin{aligned} & \text { CB4 }\end{aligned}=$ \& - \& ${ }^{-}$ \& $x$ \& X
$\times$
$\times$

x \& X \& x \& x \& - \& - \& - - \& - \& x \& x \& x \& - \&  \& - \& $x$ x \& $x$ \& x \& $x$ \& - \& $\bar{x}$ \& \[
\bar{x}

\] \& - \& x \& \[

$$
\begin{aligned}
& \mathrm{x} \\
& \mathrm{x}
\end{aligned}
$$

\] \& \[

x

\] \& - \& $x$ \& x \& $\times$ \& \[

\bar{x}

\] \&  \& \[

$$
\begin{aligned}
& x \\
& x \\
& x
\end{aligned}
$$

\] \& $\times$ \& $x$ \& - \& \[

x
\] \& \& XOR <br>

\hline CB6 $=$ \& \& x \& x \& $\mathrm{x} \times$ \& x \& $\times$ \& $x$ \& $\bar{\square}$ \& \& \& - \& - \& - \& \& $x$ \& \& $x$ \& $x$ \& x \& $\times$ \& $x$ \& - \& - \& - \& \& \& - \& - \& x \& x \& \& - x \& x \& x \& x \& \& - \& $x$ \& x \& \& XOR <br>
\hline CB7 $=$ \& \& \& \& - - \& - \& \& \& $\times$ \& x $\times$ \& x \& x \& x \& x \& x \& - \& - \& \& \& \& - \& \& x \& x \& x $\times$ \& x \& $x$ \& x \& x \& \& \& \& \& \& \& \& $\times \times$ \& x \& $\times \mathrm{x}$ \& x \& \& XOR <br>
\hline \multirow[t]{2}{*}{DATA BITS} \& \& \& \& \& 3 \& \& 3 \& 4 \& 4 \& \& 4 \& \& \& 4 \& \& 4 \& 55 \& 55 \& 5 \& 5 \& 5 \& 5 \& 5 \& 5 \& \& 6 \& 6 \& 6 \& 6 \& \& 6 \& 6 \& 6 \& \& 7 \& \& 7 \& \& \& \& <br>
\hline \& 2 \& 3 \& 4 \& 56 \& 7 \& 8 \& 9 \& 0 \& 12 \& 23 \& 4 \& 5 \& 6 \& \& 8 \& 9 \& 0 \& 2 \& 3 \& 4 \& 5 \& 6 \& 7 \& 8 \& 0 \& 1 \& 2 \& 3 \& 4 \& 5 \& 6 \& 7 \& 9 \& 0 \& 1 \& 2 \& 4 \& 6 \& 8 \& \& <br>
\hline \& \multicolumn{13}{|c|}{SLAVE \#2} \& \& \multicolumn{14}{|c|}{SLAVE \#3} \& \multicolumn{12}{|c|}{SLAVE \#4} \& <br>
\hline
\end{tabular}

Table 5. Syndrome Decoding

| Syndrome Bits |  |  |  | $\begin{array}{ll} \hline 0 & 0 \\ 1 & 0 \\ 2 & 0 \\ 3 & 0 \\ \hline \end{array}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline 0 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | 1111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | N | CB0 | CB1 | D | CB2 | D | D | 18 | CB3 | D | D | 0 | D | 1 | 2 | D |
| 0 | 0 | 0 | 1 | CB4 | D | D | 5 | D | 6 | 7 | D | D | 3 | 16 | D | 4 | D | D | 17 |
| 0 | 0 | 1 | 0 | CB5 | D | D | 11 | D | 19 | 12 | D | D | 8 | 9 | D | 10 | D | D | 67 |
| 0 | 0 | 1 | 1 | D | 13 | 14 | D | 15 | D | D | 21 | 20 | D | D | 66 | D | 22 | 23 | D |
| 0 | 1 | 0 | 0 | CB6 | D | D | 25 | D | 26 | 49 | D | D | 48 | 24 | D | 27 | D | D | 50 |
| 0 | 1 | 0 | 1 | D | 52 | 55 | D | 51 | D | D | 70 | 28 | D | D | 65 | D | 53 | 54 | D |
| 0 | 1 | 1 | 0 | D | 29 | 31 | D | 64 | D | D | 69 | 68 | D | D | 32 | D | 33 | 34 | D |
| 0 | 1 | 1 | 1 | 30 | D | D | 37 | D | 38 | 39 | D | D | 35 | 71 | D | 36 | D | D | U |
| 1 | 0 | 0 | 0 | CB7 | D | D | 43 | D | 77 | 44 | D | D | 40 | 41 | D | 42 | D | D | U |
| 1 | 0 | 0 | 1 | D | 45 | 46 | D | 47 | D | D | 74 | 72 | D | D | U | D | 73 | U | D |
| 1 | 0 | 1 | 0 | D | 59 | 75 | D | 79 | D | D | 58 | 60 | D | D | 56 | D | U | 57 | D |
| 1 | 0 | 1 | 1 | 63 | D | D | 62 | D | $U$ | U | D | D | U | U | D | 61 | D | D | U |
| 1 | 1 | 0 | 0 | D | U | U | D | U | D | D | $\cup$ | 76 | D | D | U | D | U | U | D |
| 1 | 1 | 0 | 1 | 78 | D | D | U | D | U | U | D | D | U | U | D | U | D | D | U |
| 1 | 1 | 1 | 0 | U | D | D | U | D | U | U | D | D | U | U | D | U | D | D | U |
| 1 | 1 | 1 | 1 | D | U | U | D | U | D | D | U | U | D | D | U | D | U | U | D |

$\mathrm{N}=$ No Error
CBX $=$ Error in Check Bit $X$
$X=$ Error in Data Bit X
D = Double Bit Error
$\mathrm{U}=$ Uncorrectable Multi-Bit Error

## SYSTEM ENVIRONMENT

The 8206 interface to a typical 32 bit memory system is illustrated in Figure 4. For larger systems, the partial parity bits from slaves two to four must be


Figure 4. 32-Bit 8206 System Interface

XOR'ed externally, which calls for one level of XOR gating for three 8206's and two levels for four or five 8206's.

The 8206 is designed for direct connection to the Intel 8207 Advanced Dynamic RAM Controller, due to be sampled in the first quarter of 1982. The 8207 has the ability to perform dual port memory control,
and Figure 5 illustrates a highly integrated dual port RAM implementation using the 8206 and 8207. The 8206/8207 combination permits such features as automatic scrubbing (correcting errors in memory during refresh), extending RAS and CAS timings for Read-Modify-Writes in single memory cycles, and automatic memory initialization upon reset. Together these two chips provide a complete dualport, error-corrected dynamic RAM subsystem.


Figure 5. Dual Port RAM Subsystem with 8206/8207 (32-bit bus)

## MEMORY BOARD TESTING

The 8206 lends itself to straightforward memory board testing with a minimum of hardware overhead. The following is a description of four common test modes and their implementation.

Mode 0-Read and write with error correction. Implementation: This mode is the normal 8206 operating mode.

Mode 1-Read and write data with error correction disabled to allow test of data memory. Implementation: This mode is performed with $\overline{\text { CRCT }}$ deactivated.

Mode 2-Read and write check bits with error correction disabled to allow test of check bits memory.
Implementation: Any pattern may be written into the check bits memory by judiciously choosing the proper data word to generate the desired check bits, through the use of the 8206 Hamming code. To read out the check bits it is first necessary
to fill the data memory with all zeros, which may be done by activating $\overline{W Z}$ and incrementing memory addresses with $\overline{W E}$ to the check bits memory held inactive, and then performing ordinary reads. The check bits will then appear directly at the SYO outputs, with bits CBO and CB1 inverted.

Mode 3-Write data, without altering or writing check bits, to allow the storage of bit combinations to cause error correction and detection.
Implementation: This mode is implemented by writing the desired word to memory with $\overline{W E}$ to the check bits array held inactive.

## PACKAGE

The 8206 is packaged in a 68 -pin, leadless JEDEC type A hermetic chip carrier. Figure 6 illustrates the package, and Figure 7 is the pinout.


Figure 6. 8206 JEDEC Type A Package


Figure 7. 8206 Pinout 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 ................................. 2.5 Watts
*NOTE: 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}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=\mathrm{GND}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ICC | Power Supply Current <br> -Single 8206 or Slave \#1 <br> -Master in Multi-Chip or Slaves \#2, 3, 4 |  | $\begin{aligned} & 230 \\ & 190 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| $\mathrm{VIL}^{1}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}{ }^{1}$ | Input High Voltage | 2.0 | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}+ \\ 0.5 \mathrm{~V} \end{gathered}$ | V |  |
| VOL | $\begin{aligned} & \text { Output Low Voltage } \\ & \text {-DO } \\ & \text {-All Others } \end{aligned}$ |  | $\begin{aligned} & 0.4 \\ & 0.4 \end{aligned}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ | $\begin{aligned} \mathrm{lOL} & =8 \mathrm{~mA} \\ \mathrm{OL} & =2.0 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage <br> -DO, CBO <br> -All Other Outputs | $\begin{aligned} & 2.6 \\ & 2.4 \end{aligned}$ |  | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ | $\begin{aligned} & \mathrm{lOH}=-2 \mathrm{~mA} \\ & \mathrm{lOH}=-0.4 \mathrm{~mA} \end{aligned}$ |
| ILO | I/O Leakage Current $\begin{aligned} & \text { - } \mathrm{PPI}_{4} / \mathrm{CE} \\ & \text {-DO/WDI } \end{aligned}$ |  | $\begin{aligned} & \pm 20 \\ & \pm 10 \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{1} / \mathrm{O} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{ILI}^{\prime}$ | Input Leakage Current <br> $-\mathrm{PPI}_{0-3,5-7}, \mathrm{CBI}_{6-7}, \overline{\mathrm{SEDCU}}$ <br> -All Other Input Only Pins |  | $\begin{aligned} & \pm 20 \\ & \pm 10 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\mathrm{OV} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {cc }}$ |

## NOTES:

1. $\overline{\operatorname{SEDCU}}$ ( $\operatorname{pin} 3$ ) and $M / \overline{\mathrm{S}}(\operatorname{pin} 4)$ are device strapping options and should be tied to $\mathrm{V}_{\mathrm{CC}}$ or $G N D . V_{I H} \min =V_{C C}-0.5 \mathrm{~V}$ and $\mathrm{V}_{I L} \max =0.5 \mathrm{~V}$.
2. $\mathrm{PPI}_{0-7}$ (pins $13-20$ ) and $\mathrm{CBI}_{6-7}$ (pins 11,12 ) have internal pull-up resistors and if left unconnected will be pulled to $\mathrm{V}_{\mathrm{CC}}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$; all times are in nsec.)

| Symbol | Parameter | 8206 |  | 8206-8 |  | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| TRHEV |  |  | 25 |  | 34 |  |
| TRHCV | CE Valid from R/ $\overline{\mathrm{W} \uparrow}$ (Single 8206) |  | 44 |  | 59 |  |
| TRHQV | Corrected Data Valid from R//W $\uparrow$ |  | 49 |  | 66 | 1 |
| TRVSV | SYO/CBO/PPO Valid from R/W |  | 42 |  | 56 | 1 |
| TDVEV | ERROR Valid from Data/Check Bits In |  | 52 |  | 70 |  |
| TDVCV | CE Valid from Data/Check Bits in |  | 70 |  | 94 |  |
| TDVQV | Corrected Data Valid from Data/Check Bits In |  | 67 |  | 90 |  |
| TDVSV | SYO/PPO Valid from Data/Check Bits In |  | 55 |  | 74 |  |
| TBHQV | Corrected Data Access Time |  | 32 |  | 43 |  |
| TDXQX | Hold Time from Data/check Bits In | 0 |  | 0 |  | 1 |
| TBLQZ | Corrected Data Float Delay | 5 | 28 | 5 | 38 | 1 |
| TSHIV | STB High to Data Valid | 30 |  | 40 |  |  |
| TIVSL | Data/Check Bits In to STB $\downarrow$ Set-up | 0 |  | 0 |  |  |
| TSLIX | Data/Check Bits In from STB $\downarrow$ Hold | 20 |  | 30 |  |  |
| TPVEV |  |  | 30 |  | 40 |  |
| TPVQV | Corrected Data (Master) from Partial Parity In |  | 56 |  | 76 | 1 |
| TPVSV | Syndrome/Check Bits Out from Partial Parity In |  | 38 |  | 51 | 1 |
| TSVQV | Corrected Data (Slave) Valid from Syndrome |  | 51 |  | 69 |  |
| TSVCV | CE Valid from Syndrome (Slave number 1) |  | 48 |  | 65 |  |
| TQVQV | Check Bits/Partial Parity Out from Write Data In |  | 59 |  | 80 | 1 |
| TRHSX | Check Bits/Partial Parity Out from R/W, $\bar{W}$ Z Hold | 0 |  | 0 |  | 1 |
| TRLSX | Syndrome Out from R/W Hold | 0 |  | 0 |  |  |
| TQXQX | Hold Time from Write Data In | 0 |  | 0 |  | 1 |
| TSVRL | Syndrome Out to R/W $\downarrow$ Set-up | 17 |  | 22 |  |  |
| TDVRL | Data/Check Bits In to R/W Set-up | 34 |  | 46 |  | 1 |
| TDVQU | Uncorrected Data Out from Data In |  | 32 |  | 43 |  |
| TTVQV | Corrected Data Out from $\overline{\mathrm{CRCT}} \downarrow$ |  | 30 |  | 40 |  |
| TWLQL | WZ $\downarrow \downarrow$ to Zero Out |  | 30 |  | 40 |  |
| TWHQX | Zero Out from $\bar{W} \mathbf{Z} \uparrow$ Hold | 0 |  | 0 |  |  |

## NOTE

1. A.C. Test Levels for CBO and DO are 2.4 V and 0.8 V .

## WAVEFORMS

READ-16 BIT ONLY


## WAVEFORMS (Continued)



WAVEFORMS (Continued)
FULL WRITE-16 BIT ONLY


FULL WRITE-MASTER/SLAVE


## WAVEFORMS (Continued)

## READ MODIFY WRITE—16 BIT ONLY



## WAVEFORMS (Continued)

## READ MODIFY WRITE—MASTER/SLAVE



## WAVEFORMS (Continued)



# 8271/8271-6 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> - Internal CRC Generation and Checking <br> - Programmable Step Rate, Settle-Time, Head Load Time, Head Unload Index Count <br> - Fully MCS-80 ${ }^{\text {TM }}$ and MCS-85 ${ }^{\text {TM }}$ Compatible <br> - Single + 5V Supply <br> - Automatic Read/Write Head Positioning and Verification <br> - 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.


Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | 40 |  | +5V Supply. |
| GND | 20 |  | Ground. |
| Clock | 3 | 1 | Clock: A square wave clock. |
| Reset | 4 | 1 | Reset: 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 | Chip Select: The I/O Read and I/O Write inputs are enabled by the chip select signal. |
| $\mathrm{DB}_{7}-\mathrm{DB}_{0}$ | 19-12 | 1/0 | Data Bus: The Data Bus lines are bidirectional, three-state lines ( 8080 data bus compatible). |
| $\overline{W R}$ | 10 | 1 | Write: 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 | Read: 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 | $\bigcirc$ | Interrupt: The interrupt signal indicates that the 8271 requires service. |
| $\mathrm{A}_{1}-\mathrm{A}_{0}$ | 22-21 | 1 | Address Line: These two lines are CPU Interface Register select lines. |
| DRQ | 8 | 0 | Data Request: The DMA request signal is used to request a transfer of data between the 8271 and memory. |
| $\overline{\text { DACK }}$ | 7 | 1 | Data Acknowledge: 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} & 6 \\ & 2 \end{aligned}$ | 0 | Selected Drive: These lines are used to specify the selected drive. These lines are set by the command byte. |


| Sýmbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| Fault Reset/ OPO | 1 | 0 | Fault Reset: 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 | Write Enable: This signal enables the drive write logic. |
| Seek/Step | 36 | 0 | Seek/Step: This multifunction line is used during drive seeks. |
| Direction | 37 | 0 | Direction: 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 | Load Head: The load head line causes the drive to load the Read/Write head against the diskette. |
| Low Current | 39 | 0 | Low Current: This line notifies the drive that track 43 or greater is selected. |
| $\overline{\overline{\text { Ready } 1}} \overline{\text { Ready 0 }}$ | $\begin{gathered} 5 \\ 32 \end{gathered}$ | 1 | Ready 1: These two lines indicate that the specified drive is ready. |
| $\overline{\text { Fault }}$ | 28 | 1 | Fault: This line is used by the drive to specify a file unsafe condition. |
| Count/OPI | 30 | 1 | Count/OPI: If the optional seek/direction/coúnt 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. |
| Write Protect | 33 | 1 | Write Protect: This signal specifies that the diskette inserted is write protected. |
| $\overline{\text { TRKO }}$ | 31 | 1 | Track Zero: This signal indicates when the R/W head is positioned over track zero. |
| $\overline{\text { Index }}$ | 34 | 1 | Index: The index signal gives an indication of the relative position of the diskette. |

Table 1. Pin Description (Continued)

| Symbol | $\begin{array}{c}\text { Pin } \\ \text { No. }\end{array}$ | Type | Name and Function |
| :--- | :---: | :---: | :--- |
| PLO/SS | 25 | 1 | $\begin{array}{l}\text { Phase-Locked Oscillator/ } \\ \text { Single Shot: This pin is used } \\ \text { to specify the type of data } \\ \text { separator used. }\end{array}$ |
| Write Data | 29 | 0 | $\begin{array}{l}\text { Write Data: Composite write } \\ \text { data. }\end{array}$ |
| $\begin{array}{l}\text { Unseparated }\end{array}$ | 27 | 1 | $\begin{array}{l}\text { Unseparated Data: This } \\ \text { input is the unseparated data } \\ \text { and clocks. }\end{array}$ |
| Data Window | 26 | I | $\begin{array}{l}\text { Data Window: This is a data } \\ \text { window established by a } \\ \text { single-shot or phase-locked } \\ \text { oscillator data separator. }\end{array}$ |
| INSYNC | 23 | O | $\begin{array}{l}\text { Input Synchronization: This } \\ \text { Ine is high when 8271 has at- }\end{array}$ |
| tained input data synchroni- |  |  |  |$\}$

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

## 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) to the CPU. The standard Result byte format is:



Figure 3. 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.

DACK: DMA Acknowledge:
The DMA acknowledge signal notifies the 8271 that a DMA cycle has been granted.
$\overline{\text { RD, }} \overline{\text { 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 4. 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 Description section. The 8271 maintains the location of bad tracks 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.


## 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 phase-locked oscillator for soft and hard locking.


Figure 5. 8271 Disk Drive Interface

*FOR MINI-FLOPPY DATA WINDOW $=5.7 \mu \mathrm{sec}$

Figure 6. Single-Shot Data Separator Block Diagram


Figure 7. 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})$.


Figure 8. PLO Data Separator Block Diagram

*DATA WINDOW MAY BE $180^{\circ}$ OUT OF PHASE IN PLO DATA SEPARATION MODE.
Figure 9. 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.


Figure 10. 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 indicating the direction in which the R/W head is stepped. A logic high level on this line moves the head toward the spindle (step-in). A logic low level moves the head away from the spindle (step-out).


Figure 11. Seek Timing


Figure 12. 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 13. 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 14. 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 15. 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{\text { DACK }}$ | $\overline{\mathbf{C S}}$ | $\mathbf{A}_{1}$ | $\mathbf{A}_{\mathbf{0}}$ | $\overline{\mathrm{RD}}$ | $\overline{\mathrm{WR}}$ | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| $\mathbf{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 16. Passing the Command and Parameters to the $\mathbf{8 2 7 1}$

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


Figure 17. 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.

Table 2. Execution Phase Basic Characteristics

| COMMANDS | Deleted Data | Head |  |  |  |  |  | 8 <br> Completion <br> 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 DEL DATA | XFER | LOAD | $\checkmark$ | x | YES | YES | YES | YES |
| READ ID | $x$ | LOAD | $\checkmark$ | x | YES | NO | YES | YES |
| VERIFY DATA AND DEL DATA | 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 |

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 18. 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}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{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 valia 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 <br> 10 |
| System Error - recoverable errors; <br> operator intervention probably required <br> for recovery. |  |
| 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 Type

 00$00 \quad 01$
$00 \quad 10$
$00 \quad 11$
$01 \quad 00$

01
01
01
10
10
10
10
11
11
11
11

Completion
Code 00 01 10 11 00

Event
Good Completion/ Scan Not Met Scan Met Equal Scan Met Not Equal

Clock Error
Late DMA
ID CRC Error
Data CRC Error
Drive Not Ready
Write Protect
Track 0 Not Found
Write Fault
Sector Not Found
--
——

It is important to note the hierarchical 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 the 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).

Table 3. Completion Code Interpretation

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

## INITIALIZATION

## Reset Command

|  | $\mathrm{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}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 Specify Type

ODH
$10 \mathrm{H} \quad$ Load bad Tracks Surface ' 0 '
$18 \mathrm{H} \quad$ 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:

|  | $\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 | 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-\mathrm{D}_{7}-\mathrm{D}_{0}=$ Step Rate $(0-255 \mathrm{~ms}$ in 1 ms steps).
Parameter $2-D_{7}-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-\mathrm{D}_{7}-\mathrm{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

|  | $\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 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
| PAR: | 0 | 1 | 0 | 0 | 0 | 1 | 1/0 | 0 | 0 | 0 |
| PAR: | 0 | 1 | BAD TRACK No. 1 |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | BAD TRACK No. 2 |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | CURRENT TRACK |  |  |  |  |  |  |  |

Parameter 0: $10_{\mathrm{H}}=$ 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 $(\mathrm{FF})_{\mathrm{H}}$ 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).


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.

[^26]

Figure 19. 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 | $\begin{gathered} \text { SEL } \\ 1 \end{gathered}$ | $\begin{gathered} \text { SEL } \\ 0 \end{gathered}$ | COMMAND OPCODE |  |  |  |  |  |
| PAR: | 0 | 1 | REGISTER ADDRESS |  |  |  |  |  |  |  |

## Command code:

## 3DH Read Special Register

3Ан Write Specia! 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.

Table 4. Special Registers

| Description | Register Address <br> 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 |  |

## 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.
*Bits 0 and 1 are initialized to zero

## 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 7 rack
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 20. 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^{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 $\mathrm{X}^{16}+\mathrm{X}^{12}+\mathrm{X}^{5}+1$, normally initialized to (FF)H. 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:


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

|  | $\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} \hline \mathrm{SEL} \\ 1 \end{gathered}$ | $\begin{gathered} \hline \text { SEL } \\ 0 \end{gathered}$ | 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)_{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 specity 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 subtracted 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})_{\mathrm{H}}$. The Gap 1,3 and 5 count specified by the user are the number of bytes of $(F F)_{\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
This gap separates the index address mark of the index pulse from 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


This gap separates the ID field from 6 bytes 0's for sync he 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
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:
FF's only

Gap 5:
$N$ bytes FF's
6 bytes 0's for sync
This gap fills out the rest of the disk and is used for slack during formatting. During drive speed variations this gap will shrink or grow if the disk is re-formatted.

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


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 FIEL.D | 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


Figure 23. Mini-Diskette Track Format


Figure 24. 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} \mathrm{SEL} \\ 1 \end{gathered}$ | $\begin{gathered} \hline \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 | $\bigcirc 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® 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

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | D1 | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | $\begin{gathered} \mathrm{SEL} \\ 1 \end{gathered}$ | $\begin{gathered} \mathrm{SELL} \\ 0 \end{gathered}$ | COMMAND OPCODE |  |  |  |  |  |
| PAR: | 0 | 1 | TRACK ADDR 0.255 |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | SECTOR 0.255 |  |  |  |  |  |  |  |


| 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}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $D_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | $\begin{gathered} \hline \text { SEL } \\ 1 \\ \hline \end{gathered}$ | $\begin{gathered} \text { SEL } \\ 0 \end{gathered}$ | COMMAND OPCODE |  |  |  |  |  |
| PAR: | 0 | 1 | TRACK ADDR 0.255 |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | SECTOR 0.255 |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | LENGTH |  |  | NO. OF SECTORS |  |  |  |  |

$\mathrm{D}_{7}-\mathrm{D}_{5}$ of Parameter 2 determine the length of the diex record.

000128 Bytes
001256 Bytes
$010 \quad 512$ Bytes
0111024 Bytes
1002048 Bytes
1014096 Bytes
1108192 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



Command $\quad D_{2}=0$ Scan Data $D_{2}=1$ Scan Data and Deleted Data

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 EFH
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}: \quad$ 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, Field 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

$\underset{\text { (Hex) }}{\text { Parameter }} \quad$ Results

06 The sector number of the sector in which the specified scan data pattern was located.
14 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 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.

[^27]
## 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$ .00

| Command | Field Length | Starting Sector \# | \# of Sectors | Key ${ }^{[2]}$ | Completion Code ${ }^{[3]}$ | Special Registers ${ }^{\text {[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 | 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 $=\mathbf{2} \ell-\mathbf{1}$ <br> (Initialize at <br> Beginning of Record) |
| :---: | :---: | :---: |
| 000 | 128 Bytes | 0 |
| 001 | 256 Bytes | 1 |
| 010 | 512 Bytes | 3 |
| 011 | 1024 Bytes | 7 |
| $\bullet$ | $\bullet$ | $\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.
```

$\qquad$

``` \(.0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}^{1}\) 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
``` \(\qquad\)
``` 1 Watt
```

*NOTICE: 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 <br> $\left(V_{C C}=+5.0 \mathrm{~V} \pm 5 \%\right.$ <br> 8721 and 8271-8: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; 8271-6: \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ )

| 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{OLD}}$ | Output Low Voltage (Data Bus) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage (Interface Pins) |  | 0.5 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\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 0 V |
| $\mathrm{I}_{\mathrm{OZ}}$ | Off-State Output Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to 0.45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 180 | mA |  |

CAPACITANCE $\quad\left(T_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{t}_{\mathrm{c}}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{/ / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured Pins Returned to GND |

NOTE: 1. Ambient temperature under bias for $8271-6$ is $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$.

## A.C. CHARACTERISTICS $\quad\left(\mathrm{V}_{\mathrm{cc}}=+5.0 \mathrm{~V} \pm 5 \%\right)$

(8271 and 8271-8: $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C} ; 8271-6: \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ )

## READ CYCLE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{A C}$ | Select Setup to $\overline{R D}$ | 0 |  | ns | Note 2 |
| $t_{C A}$ | Select Hold from $\overline{R D}$ | 0 |  | ns | Note 2 |
| $t_{R R}$ | $\overline{R D}$ Pulse Width | 250 |  | ns |  |
| $t_{A D}$ | Data Delay from Address |  | 250 | ns | Note 2 |
| $t_{R D}$ | Data Delay from $\overline{R D}$ |  | 150 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$, Note 2 |
| $t_{D F}$ | Output Float Delay | 20 | 100 | ns | $C_{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 |  |

## A.C. CHARACTERISTICS (Continued)

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 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{\mathrm{CQ}}$ | Request Hold from $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ (for Non-Burst Mode) |  | 150 | ns |  |

OTHER TIMINGS

| Symbol | Parameter | 8271/8271-6 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $\mathrm{t}_{\text {RSTW }}$ | Reset Pulse Width | 10 |  | $\mathrm{t}_{\mathrm{CY}}$ |  |
| $\mathrm{t}_{\mathrm{r}}$ | Input Signal Rise Time |  | 20 | ns |  |
| $t_{f}$ | Input Signal Fall Time |  | 20 | ns |  |
| $t_{\text {RSTS }}$ | Reset to First IOWR | 2 |  | $\mathrm{t}_{\mathrm{CY}}$ |  |
| $\mathrm{t}_{\mathrm{CY}}$ | Clock Period | 250 |  |  | Note 3 |
| ${ }^{\text {t }}$ CL | Clock Low Period | 110 |  | ns |  |
| ${ }^{\text {ch }}$ | Clock High Period | 125 |  | ns |  |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Window Setup to Unseparated Clock and Data | 50 |  | ns |  |
| ${ }^{\text {t }}$ DH | Data Window Hold from Unseparated Clock and Data | 0 |  | ns |  |

NOTES:

1. All timing measurements are made at the reference voltages unless otherwise specified: Input " 1 " at 2.0 V , " 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}} \mathrm{F}=250 \mathrm{~ns} \pm 0.4 \% \quad$ Mini-Floppy: $\mathrm{t}_{\mathrm{C}} \mathrm{F}=500 \mathrm{~ns} \pm 0.4 \%$

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


[^28]
## WAVEFORMS

## READ



## WRITE



DMA


CHIP CLOCK


## WAVEFORMS (Continued)



## WRITE DATA



PULSE WIDTH PW $=t_{C Y} \pm 30 \mathrm{~ns}$
H (HALF BIT CELL) $=8$ t CY
$F(F U L L$ BIT CELL $)=16 \mathrm{t} \mathrm{CY}$
*'ty $=250 \mathrm{~ns} \pm 0.4 \% \quad$ **tCY $=500 \mathrm{~ns} \pm 0.4 \%$
$\begin{array}{ll}250 \mathrm{~ns} \pm 30 \mathrm{~ns} & 500 \mathrm{~ns} \pm 30 \mathrm{~ns} \\ 2.0 \mu \mathrm{~ns} \pm 8 \mathrm{~ns} & 4.0 \mu \mathrm{~s} \pm 16 \mathrm{~ns}\end{array}$
$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}$


# 8272 <br> SINGLE/DOUBLE DENSITY FLOPPY DISK CONTROLLER 

- IBM Compatible in Both Single and
- Programmable Data Record Lengths: 128, 256, 512, or 1024 Bytes/Sector
- Multi-Sector and Multi-Track Transfer Capability
- Drive Up to 4 Floppy Disks
- Data Scan Capability - Will Scan a Single Sector or an Entire Cylinder's Worth of Data Fields, Comparing on a Byte by Byte Basis, Data in the Processor's Memory with Data Read from the Diskette
- Data Transfers in DMA or Non-DMA Mode
- Parallel Seek Operations on Up to Four Drives
- Compatible with Most Microprocessors Including 8080A, 8085A, 8086 and 8088
- Single-Phase 8 MHz Clock
- Single +5 Volt Power Supply
- Available in 40-Pin Plastic Dual-in-Line Package

The 8272 is an LSI Floppy Disk Controller (FDC) Chip, which contains the circuitry and control functions for interfacing a processor to 4 Floppy Disk Drives. It is capable of supporting either IBM 3740 single density format (FM), or IBM System 34 Double Density format (MFM) including double sided recording. The 8272 provides control signals which simplify the design of an external phase locked loop, and write precompensation circuitry. The FDC simplifies and handles most of the burdens associated with implementing a Floppy Disk Drive Interface.


Figure 1. 8272 Internal Block Diagram


Figure 2. Pin Configuration

8272

Table 1. Pin Description

| Symbol | Pin <br> No. | Type | Connec- <br> tion To | Name and Function |
| :--- | :---: | :---: | :---: | :--- |
| RST | 1 | 1 | $\mu P$ | Reset: Places FDC in <br> idle state. Resets output <br> lines to FDD to "0"' <br> (low). |
| $\overline{\text { RD }}$ | 2 | $\left[^{[1]}\right.$ | $\mu \mathrm{P}$ | Read: Control signal <br> for transfer of data from <br> FDC to Data Bus, when <br> "0" (low). |
| $\overline{\text { WR }}$ | 3 | $\left[^{[1]}\right.$ | $\mu \mathrm{P}$ | Write: Control signal <br> for transfer of data to <br> FDC via Data Bus, when |
| "0" (low). |  |  |  |  |

Note 1: Disabled when $\overline{\mathrm{CS}}=1$.
Note 2: †c must be activated to terminate the Execution Phase of any command.

| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Connection To | Name and Function |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{cc}}$ | 40 |  |  | D.C. Power: +5V |
| / $\overline{\text { W/ } / \text { SEEK }}$ | 39 | 0 | FDD | Read Write/SEEK: When "1" (high) Seek mode selected and when " 0 " (low) Read/ Write mode selected. |
| LCT/DIR | 38 | 0 | FDD | Low Current/Direction: Lowers Write current on inner tracks in Read/Write mode, determines direction head will step in Seek mode. |
| FR/STP | 37 | 0 | FDD | Fault Reset/Step: Resets fault FF in FDD in Read/Write mode, provides step pulses to move head to another cylinder in Seek mode. |
| HDL | 36 | 0 | FDD | Head Load: Command which causes read/write head in FDD to contact diskette. |
| RDY | 35 | 1 | FDD | Ready: Indicates FDD is ready to send or receive data. |
| WP/TS | 34 | 1 | FDD | Write Protect / TwoSide: Senses Write Protect status in Read/ Write mode, and Two Side Media in Seek mode. |
| FLT/TRKO | 33 | 1 | FDD | Fault/Track 0: Senses FDD fault condition in Read/Write mode and Track 0 condition in Seek mode. |
| $\mathrm{PS}_{1}, \mathrm{PS}_{0}$ | 31,32 | 0 | FDD | Precompensation (preshift): Write precompensation status during MFM mode. Determines early, late, and normal times. |
| WR DATA | 30 | 0 | FDD | Write Data: Serial clock and data bits to FDD. |
| $\mathrm{DS}_{1}, \mathrm{DS}_{0}$ | 28,29 | 0 | FDD | Drive Select: Selects FDD unit. |
| HDSEL | 27 | 0 | FDD | Head Select: Head 1 selected when " 1 " (high) Head 0 selected when " 0 " (low). |

Table 1. Pin Description (Continued)

| Symbol | Pin <br> No. | Type | Connec- <br> tion To | Name and Function |
| :--- | :---: | :---: | :---: | :--- |
| MFM | 26 | 0 | PLL | MFM Mode: MFM mode <br> when "1," FM mode <br> when "0." |
| WE | 25 | 0 | FDD | Write Enable: Enables <br> write data into FDD. |
| VCO | 24 | 0 | PLL | VCO Sync: Inhibits VCO <br> in PLL when "0" (low), <br> enables VCO when "1." |
| RD DATA | 23 | 1 | FDD | Read Data: Read data <br> from FDD, containing <br> clock and data bits. |


| Symbol | Pin <br> No. | Type | Connec- <br> tion To | Name and Function |
| :--- | :---: | :---: | :---: | :--- |
| DW | 22 | 1 | PLL | Data Window: Gener- <br> ated by PLL, and used <br> to sample data from <br> FDD. |
| WR CLK | 21 | 1 |  | Write Clock: Write data <br> rate to FDD FM = 500 <br> kHz, MFM = MHZ, with <br> a pulse width of 250 ns <br> for both FM and MFM. <br> Must be enabled for all |

## 8272 SYSTEM BLOCK DIAGRAM



## DESCRIPTION

Hand-shaking signals are provided in the 8272 which make DMA operation easy to incorporate with the aid of an external DMA Controller chip, such as the 8237. The FDC will operate in either DMA or Non-DMA mode. In the Non-DMA mode, the FDC generates interrupts to the processor for every transfer of a data byte between the CPU and the 8272. In the DMA mode, the processor need only load a command into the FDC and all data transfers occur under control of the 8272 and DMA controller.

There are 15 separate commands which the 8272 will execute. Each of these commands require multiple 8 -bit
bytes to fully specify the operation which the processor wishes the FDC to perform. The following commands are available.
Read Data
Read ID
Read Deleted Data
Read a Track
Scan Equal
Scan High or Equal
Scan Low or Equal
Specify

Write Data
Format a Track
Write Deleted Data
Seek
Recalibrate (Restore to Track 0)
Sense Interrupt Status
Sense Drive Status

## FEATURES

Address mark detection circuitry is internal to the FDC which simplifies the phase locked loop and read electronics. The track stepping rate, head load time, and head unload time may be programmed by the user. The 8272 offers many additional features such as multiple sector transfers in both read and write modes with a single command, and full IBM compatibility in both single (FM) and double density (MFM) modes.

## 8272 REGISTERS - CPU INTERFACE

The 8272 contains two registers which may be accessed by the main system processor; a Status Register and a Data Register. The 8 -bit Main Status Register contains the status information of the FDC, and may be accessed at any time. The 8-bit Data Register (actually consists of several registers in a stack with only one register presented to the data bus at a time), stores data, commands, parameters, and FDD status information. Data bytes are read out of, or written into, the Data Register in order to program or obtain the results after execution of a command. The Status Register may only be read and is used to facilitate the transfer of data between the processor and 8272.

The relationship between the Status/Data registers and the signals $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, and $\mathrm{A}_{0}$ is shown below.

| $\mathbf{A}_{0}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | FUNCTION |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | Read Main Status <br> Register |
| 0 | 1 | 0 | Illegal |
| 0 | 0 | 0 | Illegal |
| 1 | 0 | 0 | Illegal |
| 1 | 0 | 1 | Read from Data Register |
| 1 | 1 | 0 | Write into Data Register |

The bits in the Main Status Register are defined as follows:

| BIT NUMBER | NAME | SYMBOL | DESCRIPTION |
| :---: | :--- | :---: | :--- |
| $\mathrm{DB}_{0}$ | FDD 0 Busy | $\mathrm{D}_{0} \mathrm{~B}$ | FDD number 0 is in the Seek <br> mode. |
| $\mathrm{DB}_{1}$ | FDD 1 Busy | $\mathrm{D}_{1} \mathrm{~B}$ | FDD number 1 is in the Seek <br> mode. |
| $\mathrm{DB}_{2}$ | FDD 2 Busy | $\mathrm{D}_{2} \mathrm{~B}$ | FDD number 2 is in the Seek <br> mode. |
| $\mathrm{DB}_{3}$ | FDD 3 Busy | $\mathrm{D}_{3} \mathrm{~B}$ | FDD number 3 is in the Seek <br> mode. |
| $\mathrm{DB}_{4}$ | FDC Busy | CB | A read or write command is <br> in process. |
| $\mathrm{DB}_{5}$ | Non-DMA mode | NDM | The FDC is in the non-DMA <br> mode. This bit is set only <br> during the execution phase <br> in non-DMA mode. Tran- <br> sition to "0" state indicates <br> execution phase has ended. |
| $\mathrm{DB}_{6}$ | Data Input/Output | DIO | Indicates direction of data <br> transfer between FDC and <br> Data Register. If DIO = "1" <br> then transfer is from Data <br> Register to the Processor. <br> If DIO= "0", then transfer <br> is from the Processor to <br> Data Register. |
| $\mathrm{DB}_{7}$ | Request for <br> Master | RQM | Indicates Data Register is <br> ready to send or receive <br> data to or from the Proc- <br> essor. Both bits DIO and <br> RQM should be used to <br> perform the handshaking <br> functions of "ready" and <br> "direction" to the <br> processor. |
|  |  |  |  |

The DIO and RQM bits in the Status Register indicate when Data is ready and in which direction data will be transferred on the Data Bus.


NOTES: [A - dATA REGISTER READY TO BE WRITTEN INTO BY PROCESSOR B - DATA REGISTER NOT READY TO BE WRITTEN INTO BY PROCESSOR [] - DATA REGISTER READY FOR NEXT DATA BYTE TO BE READ BY THE
PROCESSOR
[D] - dATA REGISTER NOT READY FOR NEXT DATA bYTE TO BE READ BY
status register timing

The 8272 is capable of executing 15 different commands. Each command is initiated by a multi-byte transfer from the processor, and the result after execution of the command may also be a multi-byte transfer back to the processor. Because of this multi-byte interchange of information between the 8272 and the processor, it is convenient to consider each command as consisting of three phases:

Command Phase: The FDC receives all information required to perform a particular operation from the processor.
Execution Phase: The FDC performs the operation it was instructed to do.
Result Phase: After completion of the operation, status and other housekeeping information are made available to the processor.
During Command or Result Phases the Main Status Register (described earlier) must be read by the processor before each byte of information is written into or read from the Data Register. Bits D6 and D7 in the Main Status Register must be in a 0 and 1 state, respectively, before each byte of the command word may be written into the 8272. Many of the commands require multiple bytes, and as a result the Main Status Register must be read prior to each byte transfer to the 8272. On the other hand, during the Result Phase, D6 and D7 in the Main Status Register must both be 1's (D6=1 and D7 = 1) before reading each byte from the Data Register. Note, this reading of the Main Status Register before each byte transfer to the 8272 is required in only the Command and Result Phases, and NOT during the Execution Phase.
During the Execution Phase, the Main Status Register need not be read. If the 8272 is in the Non-DMA Mode, then the receipt of each data byte (if 8272 is reading data from FDD) is indicated by an Interrupt signal on pin 18 (INT $=1$ ). The generation of a Read signal ( $\overline{\mathrm{RD}}=0$ ) will reset the Interrupt as well as output the Data onto the Data Bus. For example, if the processor cannot handle Interrupts fast enough (every $13 \mu \mathrm{~s}$ for MFM mode) then it may poll the Main Status Register and then bit D7 (RQM) functions just like the Interrupt signal. If a Write

Command is in process then the WR signal performs the reset to the Interrupt signal.

If the 8272 is in the DMA Mode, no Interrupts are generated during the Execution Phase. The 8272 generates DRQ's (DMA Requests) when each byte of data is available. The DMA Controller responds to this request. with both a $\overline{D A C K}=0$ (DMA Acknowledge) and a $\overline{R D}=0$ (Read signal). When the DMA Acknowledge signal goes low ( $\overline{\mathrm{DACK}}=0$ ) then the DMA Request is reset $(\mathrm{DRQ}=0)$. If a Write Command has been programmed then a WR signal will appear instead of RD. After the Execution Phase has been completed (Terminal Count has occurred) then an Interrupt will occur (INT=1). This signifies the beginning of the Result Phase. When the first byte of data is read during the Result Phase, the Interrupt is automatically reset (INT = 0).
It is important to note that during the Result Phase all bytes shown in the Command Table must be read. The Read Data Command, for example, has seven bytes of
data in the Result Phase. All seven bytes must be read in order to successfully complete the Read Data Command. The 8272 will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to be read during the Result Phase.
The 8272 contains five Status Registers. The Main Status Register mentioned above may be read by the processor at any time. The other four Status Registers (STO, ST1, ST2, and ST3) are only available during the Result Phase, and may be read only after successfully completing a command. The particular command which has been executed determines how many of the Status Registers will be read.
The bytes of data which are sent to the 8272 to form the Command Phase, and are read out of the 8272 in the Result Phase, must occur in the order shown in the Command Table. That is, the Command Code must be sent first and the other bytes sent in the prescribed sequence. No foreshortening of the Command or Result Phases are allowed. After the last byte of data in the Command Phase is sent to the 8272 the Execution Phase automatically starts. In a similar fashion, when
the last byte of data is read out in the Result Phase, the command is automatically ended and the 8272 is ready for a new command. A command may be aborted by simply sending a Terminal Count signal to pin 16 (TC=1). This is a convenient means of ensuring that the processor may always get the 8272's attention even if the disk system hangs up in an abnormal manner.

## POLLING FEATURE OF THE 8272

After the Specify command has been sent to the 8272, the Drive Select Lines DS0 and DS1 will automatically go into a polling mode. In between commands (and between step pulses in the SEEK command) the 8272 polls all four FDDs looking for a change in the Ready line from any of the drives. If the Ready line changes state (usually due to a door opening or closing) then the 8272 will generate an interrupt. When Status Register 0 (STO) is read (after Sense Interrupt Status is issued), Not Ready (NR) will be indicated. The polling of the Ready line by the 8272 occurs continuously between instructions, thus notifying the processor which drives are on or off line.

Table 2. 8272 Command Set


[^29]2. $A_{0}=1$ for all operations.
3. $X=$ Don't care, usually made to equal binary 0 .

Table 2. 8272 Command Set (Continued)


Table 3. Command Mnemonics

| SYMBOL | NAME | DESCRIPTION |
| :--- | :--- | :--- |
| $A_{0}$ | Address Line 0 | A0 controls selection of Main Status <br> Register ( $A_{0}=0$ ) or Data Register ( $A_{0}=1$ ). |
| C | Cylinder Number | C stands for the current selected Cylinder <br> track number 0 through 76 of the medium. |
| D | Data | D stands for the data pattern which is <br> going to be written into a Sector. |
| D7-D $^{-D_{0}}$ | Data Bus | 8-bit Data Bus where $D_{7}$ is the most <br> significant bit, and $D_{0}$ is the least signifi- <br> cant bit. |
| DS0, DS1 | Drive Select | DS stands for a selected drive number 0 <br> or 1. |
| DTL | Data Length | When $N$ is defined as 00, DTL stands for <br> the data length which users are going to <br> read out or write into the Sector. |
| EOT | End of Track | EOT stands for the final Sector number of <br> a Cylinder. |
| GPL | Gap Length | GPL stands for the length of Gap 3 <br> (spacing between Sectors excluding vCO <br> Sync Field). |
| HDS | Head Select | H stands for head number 0 or 1, as <br> specified in ID field. |
| HLT | Head Load Time | HDS stands for a selected head number 0 <br> or 1 (H = HDS in all command words). |
| HUT | HLT stands for the head load time in the <br> FDD (2 to 254 ms in 2 ms increments). |  |
| Head Unload Time | HUT stands for the head unioad time after <br> a read or write operation has occurred (16 <br> to 240 ms in 16 ms increments). |  |
| MFM | FM or MFM Mode | If MF is low, FM mode is selected and if <br> it is high, MFM mode is selected. |
| MT | Multi-Track | If MT is high, a multitrack operation is to <br> be performed (a cylinder under both HD0 <br> and HD1 will be read or written). |
|  | N stands for the number of data bytes <br> written in a Sector. |  |


| SYMBOL | NAME | DESCRIPTION |
| :--- | :--- | :--- |
| NCN | New Cylinder Number | NCN stands for a new Cylinder number, <br> which is going to be reached as a result <br> of the Seek operation. Desired position of <br> Head. |
| ND | Non-DMA Mode | ND stands for operation in the Non-DMA <br> Mode. |
| PCN | Present Cylinder <br> Number | PCN stands for the Cylinder number at <br> the completion of SENSE INTERRUPT <br> STATUS Command. Position of Head at <br> present time. |
| R | Record | R stands for the Sector number, which <br> will be read or written. |
| R/W | Read/Write | R/W stands for either Read (R) or Write <br> (W) signal. |
| SC | Sector | SC indicates the number of Sectors per <br> Cylinder. |
| SK | Skip | SK stands for Skip Deleted Data Address <br> Mark. |
| SRT | Step Rate Time | SRT stands for the Stepping Rate for the <br> FDD (1 to 16 ms in 1 ms increments). The |
| same Stepping Rate applies to all drives |  |  |
| (F=1 ms, E=2 ms, etc.). |  |  |

## COMMAND DESCRIPTIONS

During the Command Phase, the Main Status Register must be polled by the CPU before each byte is written into the Data Register. The DIO (DB6) and RQM (DB7) bits in the Main Status Register must be in the " 0 " and " 1 " states respectively, before each byte of the command may be written intathe 8272. The beginning of the execution phase for any of these commands will cause DIO and RQM to switch to " 1 " and " 0 " states respectively.

## READ DATA

A set of nine (9) byte words are required to place the FDC into the Read Data Mode. After the Read Data command has been issued the FDC loads the head (if it is in the inloaded state), waits the specified head settling time (defined in the Specify Command), and begins reading ID Address Marks and ID fields. When the current sector number ("R") stored in the ID Register (IDR)
compares with the sector number read off the diskette, then the FDC outputs data (from the data field) byte-bybyte to the main system via the data bus.

After completion of the read operation from the current sector, the Sector Number is incremented by one, and the data from the next sector is read and output on the data bus. This continuous read function is called a "Multi-Sector Read Operation." The Read Data Command may be terminated by the receipt of a Terminal Count signal. Upon receipt of this signal, the FDC stops outputting data to the processor, but will continue to read data from the current sector, check CRC (Cyclic Redundancy Count) bytes, and then at the end of the sector terminate the Read Data Command.
The amount of data which can be handled with a single command to the FDC depends upon MT (multi-track), MFM (MFM/FM), and $N$ (Number of Bytes/Sector). Table 4 below shows the Transfer Capacity.

Table 4. Transfer Capacity

| Multi-Track MT | MFM/FM MFM | Bytes/Sector N | Maximum Transfer Capacity (Bytes/Sector) (Number of Sectors) | Final Sector Read from Diskette |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(26)=3,328 \\ & (256)(26)=6,656 \end{aligned}$ | 26 at Side 0 or 26 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(52)=6,656 \\ & (256)(52)=13,312 \end{aligned}$ | 26 at Side 1 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & (256)(15)=3,840 \\ & (512)(15)=7,680 \end{aligned}$ | 15 at Side 0 or 15 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & (256)(30)=7,680 \\ & (512)(30)=15,360 \end{aligned}$ | 15 at Side 1 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} (512)(8) & =4,096 \\ (1024)(8) & =8,192 \end{aligned}$ | 8 at Side 0 or 8 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} (512)(16) & =8,192 \\ (1024)(16) & =16,384 \end{aligned}$ | 8 at Side 1 |

The "multi-track" function (MT) allows the FDC to read data from both sides of the diskette. For a particular cylinder, data will be transferred starting at Sector 1, Side 0 and completing at Sector L., Side 1 (Sector $L=$ last sector on the side). Note, this function pertains to only one cylinder (the same track) on each side of the diskette.

When $N=0$, then DTL defines the data length which the FDC must treat as a sector. If DTL is smaller than the actual data length in a Sector, the data beyond DTL in the Sector, is not sent to the Data Bus. The FDC reads (internally) the complete Sector performing the CRC check, and depending upon the manner of command termination, may perform a Multi-Sector Read Operation. When $N$ is non-zero, then DTL has no meaning and should be set to OFFH.

At the completion of the Read Data Command, the head is not unloaded until after Head Unload Time Interval (specified in the Specify Command) has elapsed. If the processor issues another command before the head unloads then the head settling time may be saved between subsequent reads. This time out is particularly valuable when a diskette is copied from one drive to another.

If the FDC detects the Index Hole twice without finding the right sector, (indicated in "R"), then the FDC sets the ND (No Data) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command. (Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.)

After reading the ID and Data Fields in each sector, the FDC checks the CRC bytes. If a read error is detected (incorrect CRC in ID field), the FDC sets the DE (Data Error) flag in Status Register 1 to a 1 (high), and if a CRC error occurs in the Data Field the FDC also sets the DD (Data Error in Data Field) flag in Status Register 2 to a 1 (high), and terminates the Read Data Command. (Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.)

If the FDC reads a Deleted Data Address Mark off the diskette, and the SK bit (bit D5 in the first Command Word) is not set (SK=0), then the FDC sets the CM (Control Mark) flag in Status Register 2 to a 1 (high), and terminates the Read Data Command, after reading all the data in the Sector. If SK=1, the FDC skips the sector with the Deleted Data Address Mark and reads the next sector.

During disk data transfers between the FDC and the processor, via the data bus, the FDC must be serviced by the processor every $27 \mu$ s in the FM Mode, and every $13 \mu \mathrm{~s}$ in the MFM Mode, or the FDC sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Read Data Command.

If the processor terminates a read (or write) operation in the FDC, then the ID Information in the Result Phase is dependent upon the state of the MT bit and EOT byte. Table 5 shows the values for $\mathrm{C}, \mathrm{H}, \mathrm{R}$, and N , when the processor terminates the Command.

## Table 5. ID Information When Processor Terminates Command

| MT | EOT | Final Sector Transferred to Processor | ID Information at Result Phase |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | c | H | R | N |
| 0 | 1A <br> OF <br> 08 | Sector 1 to 25 at Side 0 <br> Sector 1 to 14 at Side 0 <br> Sector 1 to 7 at Side 0 | NC | NC | $\mathrm{R}+1$ | NC |
|  | 1A OF 08 | Sector 26 at Side 0 <br> Sector 15 at Side 0 <br> Sector 8 at Side 0 | $c+1$ | NC | $\mathrm{R}=01$ | NC |
|  | 1A OF 08 | Sector 1 to 25 at Side 1 <br> Sector 1 to 14 at Side 1 <br> Sector 1 to 7 at Side 1 | NC | NC | $R+1$ | NC |
|  | 1A <br> OF <br> 08 | Sector 26 at Side 1 <br> Sector 15 at Side 1 <br> Sector 8 at Side 1 | $C+1$ | NC | $\mathrm{R}=01$ | NC |
| 1 | 1A <br> OF <br> 08 | Sector 1 to 25 at Side 0 <br> Sector 1 to 14 at Side 0 <br> Sector 1 to 7 at Side 0 | NC | NC | $R+1$ | NC |
|  | 1 A <br> OF <br> 08 | Sector 26 at Side 0 <br> Sector 15 at Side 0 <br> Sector 8 at Side 0 | NC | LSB | $\mathrm{R}=01$ | NC |
|  | 1A <br> OF <br> 08 | Sector 1 to 25 at Side 1 <br> Sector 1 to 14 at Side 1 <br> Sector 1 to 7 at Side 1 | NC | NC | $\mathrm{R}+1$ | NC |
|  | $\begin{aligned} & 1 A \\ & 0 F \\ & 08 \end{aligned}$ | Sector 26 at Side 1 <br> Sector 15 at Side 1 <br> Sector 8 at Side 1 | $C+1$ | LSB | $\mathrm{R}=01$ | NC |

Notes: 1. NC (No Change): The same value as the one at the beginning of command execution.
2. LSB (Least Significant Bit): The least significant bit of H is complemented.

## WRITE DATA

A set of nine (9) bytes are required to set the FDC into the Write Data mode. After the Write Data command has been issued the FDC loads the head (if it is in the unloaded state), waits the specified head settling time (defined in the Specify Command), and begins reading ID Fields. When the current sector number ("R"), stored in the ID Register (IDR) compares with the sector number read off the diskette, then the FDC takes data from the processor byte-by-byte via the data bus, and outputs it to the FDD.

After writing data into the current sector, the Sector Number stored in " $R$ " is incremented by one, and the next data field is written into. The FDC continues this "Multi-Sector Write Operation" until the issuance of a Terminal Count signal. If a Terminal Count signal is sent to the FDC it continues writing into the current sector to complete the data field. If the Terminal Count signal is received while a data field is being written then the remainder of the data field is filled with 00 (zeros).
The FDC reads the ID field of each sector and checks the CRC bytes. If the FDC detects a read error (incorrect CRC) in one of the ID Fields, it sets the DE (Data Error) flag of Status Register 1 to a 1 (high), and terminates the Write Data Command. (Status Register 0 also has bits 7 and 6 set to 0 and 1 respectively.)
The Write Command operates in much the same manner as the Read Command. The following items are the same; refer to the Read Data Command for details:

- Transfer Capacity
- EN (End of Cylinder) Flag
- ND (No Data) Flag
- Head Unload Time Interval
- ID Information when the processor terminates command (see Table 2)
- Definition of DTL when $\mathrm{N}=0$ and when $\mathrm{N} \neq 0$

In the Write Data mode, data transfers between the processor and FDC must occur every $31 \mu$ s in the FM mode, and every $15 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transfers is longer than this then the FDC sets the OR (Over Run) flag in Status Register 1 to a 1 (high), and terminates the Write Data Command.

## WRITE DELETED DATA

This command is the same as the Write Data Command except a Deleted Data Address Mark is written at the beginning of the Data Field instead of the normal Data Address Mark.

## READ DELETED DATA

This command is the same as the Read Data Command except that when the FDC detects a Data Address Mark at the beginning of a Data Field (and SK $=0$ (low)), it will read all the data in the sector and set the CM flag in Status Register 2 to a 1 (high), and then terminate the command. If SK = 1, then the FDC skips the sector with the Data Address Mark and reads the next sector.

## READ A TRACK

This command is similar to READ DATA Command except that the entire data field is read continuously from each of the sectors of a track. Immediately after encountering the INDEX HOLE, the FDC starts reading all data fields on the track as continuous blocks of data. If the FDC finds an error in the ID or DATA CRC check bytes, it continues to read data from the track. The FDC compares the ID information read from each sector with the value stored in the IDR, and sets the ND flag of Status Register 1 to a 1 (high) if there is no comparison. Multi-track or skip operations are not allowed with this command.
This command terminates when EOT number of sectors have been read. If the FDC does not find an ID Address Mark on the diskette after it encounters the INDEX HOLE for the second time, then it sets the MA (missing address mark) flag in Status Register 1 to a 1 (high), and terminates the command. (Status Register 0 has bits 7 and 6 set to 0 and 1 respectively.)

## READ ID

The READ ID Command is used to give the present position of the recording head. The FDC stores the values from the first ID Field it is able to read. If no proper ID Address Mark is found on the diskette, before the INDEX HOLE is encountered for the second time then the MA (Missing Address Mark) flag in Status Register 1 is set to a 1 (high), and if no data is found then the ND (No Data) flag is also set in Status Register 1 to a 1 (high) and the command is terminated.

## FORMAT A TRACK

The Format Command allows an entire track to be formatted. After the INDEX HOLE is detected, Data is written on the Diskette: Gaps, Address Marks, ID Fields and Data Fields, all per the IBM System 34 (Double Density) or System 3740 (Single Density) Format are recorded. The particular format which will be written is controlled by the values programmed into N (number of bytes/sector), SC (sectors/cylinder), GPL (Gap Length), and D (Data Pattern) which are supplied by the processor during the Command Phase. The Data Field is filled with the Byte of data stored in D. The ID Field for each sector is supplied by the processor; that is, four data requests per sector are made by the FDC for C (Cylinder Number), H (Head Number), R (Sector Number) and N (Number of Bytes/Sector). This allows the diskette to be formatted with nonsequential sector numbers, if desired.
After formatting each sector, the processor must send new values for C, H, R, and $N$ to the 8272 for each sector on the track. The contents of the $R$ register is incremented by one after each sector is formatted, thus, the $R$ register contains a value of $R+1$ when it is read during the Result Phase. This incrementing and formatting continues for the whole track until the FDC encounters the INDEX HOLE for the second time, whereupon it terminates the command.
If a FAULT signal is received from the FDD at the end of a write operation, then the FDC sets the EC flag of Status Register 0 to a 1 (high), and terminates the command after setting bits 7 and 6 of Status Register 0 to 0 and 1 respectively. Also the loss of a READY signal at the beginning of a command execution phase causes command termination.
Table 6 shows the relationship between N, SC, and GPL for various sector sizes:

Table 6. Sector Size Relationships

| FORMAT | SECTOR SIZE | N | SC | GPL ${ }^{1}$ | GPL ${ }^{2}$ | REMARKS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FM Mode | 128 bytes/Sector 256 <br> 512 | 00 <br> 01 <br> 02 | $\begin{gathered} 1 \mathrm{~A}_{(16)} \\ 0 \mathrm{~F}_{(16)} \\ 08 \end{gathered}$ | $\begin{gathered} 07_{(16)} \\ \mathrm{OE}_{(16)} \\ 1 \mathrm{~B}_{(16)} \\ \hline \end{gathered}$ | $\begin{aligned} & 1 B_{(16)} \\ & 2 A_{(16)} \\ & 3 A_{(16)} \\ & \hline \end{aligned}$ | IBM Diskette 1 IBM Diskette 2 |
| FM Mode | $\begin{aligned} & 1024 \text { bytes/Sector } \\ & 2048 \\ & 4096 \end{aligned}$ | $\begin{aligned} & 03 \\ & 04 \\ & 05 \end{aligned}$ | $\begin{aligned} & 04 \\ & 02 \\ & 01 \end{aligned}$ | $\begin{aligned} & - \\ & - \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ |  |
| MFM Mode | 256 512 1024 2048 4096 8192 | 01 <br> 02 <br> 03 <br> 04 <br> 05 <br> 06 | $\begin{gathered} 1 \mathrm{~A}_{(16)} \\ 0 \mathrm{~F}_{(16)} \\ 08 \\ 04 \\ 02 \\ 01 \end{gathered}$ | $\begin{gathered} \mathrm{OE}_{(16)} \\ 1 \mathrm{~B}_{(16)} \\ 35(16) \\ - \\ - \end{gathered}$ | $\begin{aligned} & 36_{(16)} \\ & 54_{(16)} \\ & 74(16) \end{aligned}$ | IBM Diskette 2D <br> IBM Diskette 2D |

Note: 1. Suggested values of GPL in Read or Write Commands to avoid splice point between data field and ID field of contiguous sections.
2. Suggested values of GPL in format command.

8272

## SCAN COMMANDS

The SCAN Commands allow data which is being read from the diskette to be compared against data which is being. supplied from the main system (Processor in NON-DMA mode, and DMA Controller in DMA mode). The FDC compares the data on a byte-by-byte basis, and looks for a sector of data which meets the conditions of $D_{F D D}=D_{\text {Processor }}, D_{\text {FDD }} \leqslant D_{\text {Processor }}$, or $D_{\text {FDD }} \geqslant D_{\text {Processor }}$. Ones complement arithmetic is used for comparison (FF = largest number, $00=$ smallest number). After a whole sector of data is compared, if the conditions are not met, the sector number is incremented ( $\mathrm{R}+\mathrm{STP} \rightarrow$ $R$ ), and the scan operation is continued. The scan operation continues until one of the following conditions occur; the conditions for scan are met (equal, low, or high), the last sector on the track is reached (EOT), or the terminal count signal is received.

If the conditions for scan are met then the FDC sets the SH (Scan Hit) flag of Status Register 2 to a 1 (high), and terminates the Scan Command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the cylinder (EOT), then the FDC sets the SN (Scan Not Satisfied) flag of Status Register 2 to a 1 (high), and terminates the Scan Command. The receipt of a TERMINAL COUNT signal from the Processor or DMA Controller during the scan operation will cause the FDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 7 shows the status of bits SH and SN under various conditions of SCAN.

Table 7. Scan Status Codes

| COMMAND | STATUS REGISTER 2 |  | COMMENTS |
| :---: | :---: | :---: | :---: |
|  | BIT $2=$ SN | BIT 3 = SH |  |
| Scan Equal | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=\text { D Processor } \\ & D_{\text {FDD }} \neq \text { DProcessor }^{\text {PP }} \end{aligned}$ |
| Scan Low or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{D}_{\mathrm{FDD}}=\mathrm{D}_{\text {Processor }} \\ & \mathrm{D}_{\mathrm{FDD}}<\mathrm{D}_{\text {Processor }} \\ & \mathrm{D}_{\mathrm{FDD}} \& \mathrm{D}_{\text {Processor }} \end{aligned}$ |
| Scan High or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ |  |

If the FDC encounters a Deleted Data Address Mark on one of the sectors (and SK=0), then it regards the sector as the last sector on the cylinder, sets CM (Control Mark) flag of Status Register 2 to a 1 (high) and terminates the command. If SK = 1, the FDC skips the sector with the Deleted Address Mark, and reads the next sector. In the second case ( $\mathrm{SK}=1$ ), the FDC sets the CM (Control Mark) flag of Status Register 2 to a 1 (high) in order to show that a Deleted Sector had been encountered.

When either the STP (contiguous sectors STP $=01$, or alternate sectors STP $=02$ sectors are read) or the MT (Multi-Track) are programmed, it is necessary to remember that the last sector on the track must be read. For example, if $\mathrm{STP}=02, \mathrm{MT}=0$, the sectors are numbered sequentially 1 through 26 , and we start the Scan Command at sector 21; the following will happen. Sectors 21, 23, and 25 will be read, then the next sector (26) will be skipped and the Index Hole will be encountered before the EOT value of 26 can be read. This will result in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the Scan Command would be completed in a normal manner.

During the Scan Command data is supplied by either the processor or DMA Controller for comparison against the data read from the diskette. In order to avoid having the OR (Over Run) flag set in Status Register 1, it is necessary to have the data available in less than $27 \mu \mathrm{~s}$ (FM Mode) or $13 \mu \mathrm{~s}$ (MFM Mode). If an Overrun occurs the FDC terminates the command.

## SEEK

The read/write head within the FDD is moved from cylinder to cylinder under control of the Seek Command. The FDC compares the PCN (Present Cylinder Number) which is the current head position with the NCN (New Cylinder Number), and performs the following operation if there is a difference:

PCN < NCN: Direction signal to FDD set to a 1 (high), and Step Pulses are issued. (Step In.)
PCN > NCN: Direction signal to FDD set to a 0 (low), and Step Pulses are issued. (Step Out.)

The rate at which Step Pulses are issued is controlled by SRT (Stepping Rate Time) in the SPECIFY Command. After each Step Pulse is issued NCN is compared against PCN, and when NCN = PCN, then the SE (Seek End) flag is set in Status Register 0 to a 1 (high), and the command is terminated.

During the Command Phase of the Seek operation the FDC is in the FDC BUSY state, but during the Execution Phase it is in the NON BUSY state. While the FDC is in the NON BUSY state, another Seek Command may be issued, and in this manner parallel seek operations may be done on up to 4 Drives at once.

If an FDD is in a NOT READY state at the beginning of the command execution phase or during the seek operation, then the NR (NOT READY) flag is set in Status Register 0 to a 1 (high), and the command is terminated.

## RECALIBRATE

This command causes the read/write head within the FDD to retract to the Track 0 position. The FDC clears the contents of the PCN counter, and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal is low, the Direction signal remains 1 (high) and Step Pulses are issued. When the Track 0 signal goes high, the SE (SEEK END) flag in Status Register 0 is set to a 1 (high) and the command is terminated. If the Track 0 signal is still low after 77 Step Pulses have been issued, the FDC sets the SE (SEEK END) and EC (EQUIP. MENT CHECK) flags of Status Register 0 to both 1 s (highs), and terminates the command.

The ability to overlap RECALIBRATE Commands to multiple FDDs, and the loss of the READY signal, as described in the SEEK Command, also applies to the RECALIBRATE Command.

## SENSE INTERRUPT STATUS

An Interrupt signal is generated by the FDC for one of the following reasons:

1. Upon entering the Result Phase of:
a. Read Data Command
b. Read a Track Command
c. Read ID Command
d. Read Deleted Data Command
e. Write Data Command
f. Format a Cylinder Command
g. Write Deleted Data Command
h. Scan Commands
2. Ready Line of FDD changes state
3. End of Seek or Recalibrate Command
4. During Execution Phase in the NON-DMA Mode

Interrupts caused by reasons 1 and 4 above occur during normal command operations and are easily discernible by the processor. However, interrupts caused by reasons 2 and 3 above may be uniquely identified with the aid of the Sense Interrupt Status Command. This command when issued resets the interrupt signal and via bits 5, 6, and 7 of Status Register 0 identifies the cause of the interrupt.

Table 8. Seek, Interrupt Codes

| SEEK END <br> BIT 5 | INTERRUPT CODE |  | CAUSE |
| :---: | :---: | :---: | :--- |
|  | BIT 6 | BIT 7 |  |
| 0 | 1 | 1 | Ready Line changed <br> state, either polarity |
| 1 | 0 | 0 | Normal Termination <br> of Seek or Recalibrate <br> Command |
| 1 | 1 | 0 | Abnormal Termination of <br> Seek or Recalibrate <br> Command |

Neither the Seek or Recalibrate Command have a Result Phase. Therefore, it is mandatory to use the Sense Interrupt Status Command after these commands to effectively terminate them and to provide verification of the head position (PCN).

## SPECIFY

The Specify Command sets the initial values for each of the three internal timers. The HUT (Head Unload Time) defines the time from the end of the Execution Phase of one of the Read/Write Commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of $16 \mathrm{~ms}(01=16 \mathrm{~ms}, 02=32 \mathrm{~ms} \ldots .0 \mathrm{OF}=$ 240 ms ). The SRT (Step Rate Time) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of 1 ms ( $F=1$ $\mathrm{ms}, \mathrm{E}=2 \mathrm{~ms}, \mathrm{D}=3 \mathrm{~ms}$, etc.). The HLT (Head Load Time) defines the time between when the Head Load signal goes high and when the Read/Write operation starts. This timer is programmable from 2 to 254 ms in increments of $2 \mathrm{~ms}(01=2 \mathrm{~ms}, 02=4 \mathrm{~ms}, 03=6 \mathrm{~ms} \ldots$ $F E=254 \mathrm{~ms})$.
The time intervals mentioned above are a direct function of the clock (CLK on pin 19). Times indicated above are for an 8 MHz clock, if the clock was reduced to 4 MHz (mini-floppy application) then all time intervals are increased by a factor of 2.

The choice of DMA or NON-DMA operation is made by the ND (NON-DMA) bit. When this bit is high (ND = 1) the NON-DMA mode is selected, and when ND $=0$ the DMA mode is selected.

## SENSE DRIVE STATUS

This command may be used by the processor whenever it wishes to obtain the status of the FDDs. Status Register 3 contains the Drive Status information.

## INVALID

If an invalid command is sent to the FDC (a command not defined above), then the FDC will terminate the command. No interrupt is generated by the 8272 during this condition. Bit 6 and bit 7 (DIO and RQM) in the Main Status Register are both high (" 1 ") indicating to the processor that the 8272 is in the Result Phase and the contents of Status Register 0 (STO) must be read. When the processor reads Status Register 0 it will find a 80 H indicating an invalid command was received.

A Sense Interrupt Status Command must be sent after a Seek or Recalibrate interrupt, otherwise the FDC will consider the next command to be an Invalid Command.

In some applications the user may wish to use this command as a No-Op command, to place the FDC in a standby or no operation state.

Table 9. Status Registers

| BIT |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NO. | NAME | SYMBOL |  |
| STATUS REGISTER 0 |  |  |  |
| $\mathrm{D}_{7}$ | Interrupt Code | IC | $D_{7}=0 \text { and } D_{6}=0$ <br> Normal Termination of Command, (NT). Command was completed and properly executed. |
| $\mathrm{D}_{6}$ |  |  | $D_{7}=0 \text { and } D_{6}=1$ <br> Abnormal Termination of Command, (AT). Execution of Command was started, but was not successfully completed. |
|  |  |  | $D_{7}=1 \text { and } D_{6}=0$ <br> Invalid Command issue, (IC). <br> Command which was issued was never started. |
|  |  |  | $D_{7}=1 \text { and } D_{6}=1$ <br> Abnormal Termination because during command execution the ready signal from FDD changed state. |
| $\mathrm{D}_{5}$ | Seek End | SE | When the FDC completes the SEEK Command, this flag is set to 1 (high). |
| $\mathrm{D}_{4}$ | Equipment Check | EC | If a fault Signal is received from the FDD, or if the Track 0 Signal fails to occur after 77 Step Pulses (Recalibrate Command) then this flag is set. |
| $\mathrm{D}_{3}$ | Not Ready | NR | When the FDD is in the not-ready state and a read or write command is issued, this flag is set. If a read or write command is issued to Side 1 of a single sided drive, then this flag is set. |
| $\mathrm{D}_{2}$ | Head <br> Address | HD | This flag is used to indicate the state of the head at Interrupt. |
| $\mathrm{D}_{1}$ | Unit Select 1 | US 1 | These flags are used to indicate a |
| $\mathrm{D}_{0}$ | Unit Select 0 | US 0 | Drive Unit Number at Interrupt |
| STATUS REGISTER 1 |  |  |  |
| $\mathrm{D}_{7}$ | End of Cylinder | EN | When the FDC tries to access a Sector beyond the final Sector of a Cylinder, this flag is set. |
| $\mathrm{D}_{6}$ |  |  | Not used. This bit is always 0 (low). |
| $\mathrm{D}_{5}$ | Data Error | DE | When the FDC detects a CRC error in either the ID field or the data field, this flag is set. |
| $\mathrm{D}_{4}$ | Over Run | OR | If the FDC is not serviced by the main-systems during data transfers, within a certain time interval, this flag is set. |
| $\mathrm{D}_{3}$ |  |  | Not used. This bit always 0 (low). |
| $\mathrm{D}_{2}$ | No Data | ND | During execution of READ DATA, WRITE DELETED DATA or SCAN Command, if the FDC cannot find the Sector specified in the IDR Register, this flag is set. |
|  |  |  | During èecuting the READ ID Command, if the FDC cannot read the ID field without an error, then this flag is set. |
|  |  |  | During the execution of the READ A Cylinder Command, if the starting sector cannot be found, then this flag is set. |


| BIT |  |  | DESCRIPTION |
| :---: | :---: | :---: | :---: |
| NO. | NAME | SYMBOL |  |
| STATUS REGISTER 1 (CONT.) |  |  |  |
| $\mathrm{D}_{1}$ | Not Writable | NW | During execution of WRITE DATA, WRITE DELETED DATA or Format A Cylinder Command, if the FDC detects a write protect signal from the FDD, then this flag is set. |
| $\mathrm{D}_{0}$ | Missing <br> Address Mark | MA | If the FDC cannot detect the ID Address Mark after encountering the index hole twice, then this flag is set. |
|  |  |  | If the FDC cannot detect the Data Address Mark or Deleted Data Address Mark, this flag is set. Also at the same time, the MD (Missing Address Mark in Data Field) of Status Register 2 is set. |
| STATUS REGISTER 2 |  |  |  |
| $\mathrm{D}_{7}$ |  |  | Not used. This bit is always 0 (low). |
| $\mathrm{D}_{6}$ | Control Mark | CM | During executing the READ DATA or SCAN Command, if the FDC encounters a Sector which contains a Deleted Data Address Mark, this flag is set. |
| $\mathrm{D}_{5}$ | Data Error in Data Field | DD | If the FDC detects a CRC error in the data field then this flag is set. |
| $\mathrm{D}_{4}$ | Wrong Cylinder | WC | This bit is related with the ND bit, and when the contents of $C$ on the medium is different from that stored in the IDR, this flag is set. |
| $\mathrm{D}_{3}$ | Scan Equal Hit | SH | During execution, the SCAN Command, if the condition of equal" is satisfied, this flag is set. |
| $\mathrm{D}_{2}$ | Scan Not Satisfied | SN | During executing the SCAN Command, if the FDC cannot find a Sector on the cylinder which meets the condition, then this flag is set. |
| $\mathrm{D}_{1}$ | Bad Cylinder | BC | This bit is related with the ND bit, and when the content of $C$ on the medium is different from that stored in the IDR and the content of $C$ is FF, then this flag is set. |
| $\mathrm{D}_{0}$ | Missing <br> Address <br> Mark in Data <br> Field | MD | When data is read from the medium, if the FDC cannot find a Data Address Mark or Deleted Data Address Mark, then this flag is set. |
| STATUS REGISTER 3 |  |  |  |
| $\mathrm{D}_{7}$ | Fault | FT | This bit is used to indicate the status of the Fault signal from the FDD. |
| $\mathrm{D}_{6}$ | Write Protected | WP | This bit is used to indicate the status of the Write Protected signal from the FDD. |
| $\mathrm{D}_{5}$ | Ready | RDY | This bit is used to indicate the status of the Ready signal from the FDD. |
| $\mathrm{D}_{4}$ | Track 0 | T0 | This bit is used to indicate the status of the Track 0 signal from the FDD. |
| $\mathrm{D}_{3}$ | Two Side | TS | This bit is used to indicate the status of the Two Side signal from the FDD. |
| $\mathrm{D}_{2}$ | Head <br> Address | HD | This bit is used to indicate the status of Side Select signal to the FDD. |
| $\mathrm{D}_{1}$ | Unit Select 1 | US 1 | This bit is used to indicate the status of the Unit Select 1 signal to the FDD. |
| $\mathrm{D}_{0}$ | Unit Select 0 | us 0 | This bit is used to indicate the status of the Unit Select 0 signal to the FDD. |

## ABSOLUTE MAXIMUM RATINGS*

Operating Temperature.............. $.0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
All Output Voltages . . . . . . . . . . . . . . . -0.5 to +7 Volts
All Input Voltages . . . . . . . . . . . . . . . . . -0.5 to +7 Volts
Supply Voltage VCC . . . . . . . . . . . . . . -0.5 to +7 Volts
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
${ }^{*} \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$

NOTICE: Stress above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. CHARACTERISTICS
$\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%\right)$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $\mathrm{V}_{1 \mathrm{~L}}$, | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{H}_{1}}$ | Input High Voitage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{V}_{\mathrm{IL}_{2}}$ | (CLK \& WR CLK) | -0.5 | 0.65 | V |  |
| $\mathrm{V}_{\mathrm{H}_{2}}$ | (CLK \& WR CLK) | 2.4 | $\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 | $\mathrm{V}_{\mathrm{CC}}$ | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| Icc | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 150 | mA |  |
| IIL | Input Load Current (All Input Pins) |  | $\begin{gathered} 10 \\ -10 \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \end{aligned}$ |
| ILOH | High Level Output Leakage Current |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ |
| Iofl | Output Float Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |

CAPACITANCE $\quad\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz}, \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $\mathrm{C}_{\mathrm{IN}(\Phi)}$ | Clock Input Capacitance |  | 20 | pF | All Pins Except Pin Under Test Tied to AC Ground |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 10 | pF |  |
| Cout | Output Capacitance |  | 20 | pF |  |

## A.C. CHARACTERISTICS $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%$ )

| Symbol | Parameter |  | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{t_{C O}}$ | Clock Period |  | 125 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CH}$ | Clock High Period |  | 40 |  | ns | Note 4 |
| $t_{\text {RST }}$ | Reset Width |  | 14 |  | ${ }^{\text {t }} \mathrm{CY}$ |  |
| Read Cycle |  |  |  |  |  |  |
| $t_{\text {AR }}$ | Select Setup to $\overline{\mathrm{RD}} \downarrow$ |  | 0 |  | ns |  |
| $t_{\text {RA }}$ | Select Hold from RD $\uparrow$ |  | 0 |  | ns |  |
| $t_{\text {RR }}$ | $\overline{R D}$ Pulse Width |  | 250 |  | ns |  |
| ${ }^{t_{R D}}$ | Data Delay from $\overline{\mathrm{RD}} \downarrow$ |  |  | 200 | ns |  |
| ${ }^{\text {t }}$ DF | Output Float Delay |  | 20 | 100 | ns |  |
| Write Cycle |  |  |  |  |  |  |
| ${ }^{\text {taw }}$ | Select Setup to $\overline{W R} \downarrow$ |  | 0 |  | ns |  |
| ${ }^{\text {t W }}$ W | Select Hold from $\overline{W R} \uparrow$ |  | 0 |  | ns |  |
| ${ }^{\text {tww }}$ | $\overline{\text { WR Pulse Width }}$ |  | 250 |  | ns |  |
| ${ }^{\text {tow }}$ | Data Setup to WR $\uparrow$ |  | 150 |  | ns |  |
| ${ }^{\text {tw }}$ | Data Hold from WR $\uparrow$ |  | 5 |  | ns |  |
| Interrupts |  |  |  |  |  |  |
| $t_{\text {RI }}$ | INT Delay from $\overline{\text { RD }} \uparrow$ |  |  | 500 | ns |  |
| ${ }^{t}$ WI | INT Delay from WR $\uparrow$ |  |  | 500 | ns |  |
| DMA |  |  |  |  |  |  |
| ${ }^{\text {t }}$ RQCY | DRQ Cycle Period |  | 13 |  | $\mu \mathrm{s}$ |  |
| $t_{\text {AKRQ }}$ |  |  |  | 200 | ns |  |
| ${ }^{\text {t }}$ RQR | DRQ ${ }^{\text {do }} \overline{\text { RD }} \downarrow$ |  | 800 |  | ns | 8 MHz clock |
| $t_{\text {RQW }}$ | DRQ to $\overline{\text { WR }} \downarrow$, |  | 250 |  | ns | 8 MHz clock |
| $t_{\text {RQRW }}$ | DRQ $\uparrow$ to $\overline{\mathrm{RD}} \uparrow$ or $\overline{\mathrm{WR} \uparrow}$ |  |  | 12 | $\mu \mathrm{s}$ | 8 MHz clock |
| FDD Interface TYP 1 |  |  |  |  |  |  |
| ${ }^{\text {twCy }}$ | WCK Cycle Time | $\begin{array}{r}2 \text { or } 4 \\ 1 \text { or } 2 \\ \hline\end{array}$ |  |  | $\mu \mathrm{s}$ | $\begin{aligned} & \mathrm{MFM}=0 \\ & \mathrm{MFM}=1 \end{aligned}$ |
| ${ }^{\text {twCH }}$ | WCK High Time | 250 | 100 | 350 | ns |  |
| ${ }^{\text {c }}$ CP | Pre-Shift Delay from WCK $\uparrow$ |  | 20 | 100 | ns |  |
| ${ }^{t} \mathrm{CD}$ | WDA Delay from WCK^ |  | 20 | 100 | ns |  |
| ${ }^{\text {t WDD }}$ | Write Data Width |  | ${ }^{\text {twCH-50 }}$ |  | ns |  |
| ${ }^{\text {twe }}$ | WE¢ to WCK^ or WE $\downarrow$ to WCK $\downarrow$ Delay | - | 20 | IVO | ns |  |
| ${ }^{\text {twwey }}$ | Window Cycle Time | $\begin{array}{r}2 \\ 1 \\ \hline\end{array}$ |  |  | $\mu \mathrm{S}$ | $\begin{aligned} & M F M=0 \\ & M F M=1 \end{aligned}$ |
| ${ }^{\text {t WRD }}$ | Window Setup to RDD $\uparrow$ |  | 15 |  | ns |  |
| ${ }^{\text {t }}$ RDW | Window Hold from RDD $\downarrow$ |  | 15 |  | ns |  |
| $t_{\text {RDD }}$ | RDD Active Time (HIGH) |  | 40 |  | ns |  |
| FDD |  |  |  |  |  |  |
| SEEKI |  |  |  |  |  |  |
| DIRECTION/ |  |  |  |  |  |  |
| STEP |  |  |  |  |  |  |
| tus | $\mathrm{US}_{0,1}$ Setup to $\overline{\mathrm{RW}} / \mathrm{SEEK} \uparrow$ |  | 12 |  | $\mu \mathrm{S}$ |  |
| ${ }^{\text {t }}$ SD | $\overline{\text { RWW }}$ /SEEK Setup to LCT/DIR |  | 6.8 |  | $\mu \mathrm{s}$ |  |
| ${ }^{t}{ }_{\text {DS }}$ | RW/SEEK Hold from LCT/DIR |  | 30 |  | $\mu \mathrm{S}$ |  |
| ${ }^{\text {t }}$ DST | LCT/DIR Setup to FRISTEP个 |  | 1 |  | $\mu \mathrm{S}$ |  |
| ${ }^{\text {t }}$ STD | LCT/DIR Hold from FR/STEP $\downarrow$ |  | 24 |  | $\mu \mathrm{S}$ | \} 8 MHz clock |
| ${ }^{\text {t }}$ STU | DS ${ }_{0,1}$ Hold from FR/Step $\downarrow$ |  | 5 |  | $\mu \mathrm{S}$ |  |
| ${ }^{\text {tstP }}$ | STEP Active Time (High) | 5 |  |  | $\mu \mathrm{S}$ | - |
| ${ }^{\text {t }} \mathrm{SC}$ | STEP Cycle Time |  | $33$ |  | $\mu \mathrm{S}$ | Note 3 |
| $t_{\text {FR }}$ | FAULT RESET Active Time (High) |  | 8 | 10 | $\mu \mathrm{S}$ | , |
| $\mathrm{t}_{\text {IDX }}$ | INDEX Pulse Width | 625 |  |  | $\mu \mathrm{s}$ | ) |
| ${ }^{\text {t }}$ C | Terminal Count Width |  | 1 |  | ${ }^{t} \mathrm{CY}$ |  |

## NOTES:

1. Typical values for $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ and nominal supply voltage.
2. The former values are used for standard floppy and the latter values are used for mini-floppies.
3. $t_{S C}=33 \mu \mathrm{~s} \mathrm{~min}$. is for different drive units. In the case of same unit, $\mathrm{t}_{\mathrm{SC}}$ can be ranged from 1 ms to 16 ms with 8 MHz clock period, and 2 ms to 32 ms with 4 MHz clock, under software control.
4. From $2.0 \mathrm{~V} \uparrow$ to $+2.0 \mathrm{~V} \downarrow$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

PROCESSOR READ OPERATION


WAVEFORMS (Continued)
PROCESSOR WRITE OPERATION


DMA OPERATION


WAVEFORMS (Continued)

## CLOCK TIMING



FDD WRITE OPERATION


|  | PRESHIFT 0 | PRESHIFT 1 |
| :--- | :---: | :---: |
| NORMAL | 0 | 0 |
| LATE | 0 | 1 |
| EARLY | 1 | 0 |
| INVALID | 1 | 1 |

WAVEFORMS (Continued)


WAVEFORMS (Continued)

## FDD READ OPERATION



## TERMINAL COUNT

TC


## RESET

RESET


- 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
- Compatible with an Extended Range of Intel Microprocessors
- 28-Pin DIP Package
- All Inputs and Outputs are TTL Compatible
■ Single +5 V Supply
- Single TTL Clock

The Intel ${ }^{\circledR}$ 8251A is the enhanced version of the industry standard, Intel 8251 Universal Synchronous/ Asynchronous Receiver/Transmitter (USART), designed for data communications with Intel's microprocessor families such as MCS-68, 80, 85, and iAPX-86, 88 . 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 USARTaccepts 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 fabricated using N -channel silicon gate technology.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## FEATURES AND ENHANCEMENTS

The 8251A is an advanced design of the industry standard USART, the Intel ${ }^{\circledR}$ 8251. The 8251A operates with an extended range of Intel microprocessors 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 $A C$ 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 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 8251 A 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 .


## FUNCTIONAL DESCRIPTION

## General

The 8251A is a Universal Synchronous/Asynchronous Receiver/Transmitter designed for a wide range of Intel microcomputers such as 8048,8080 , 8085, 8086 and 8088. Like other I/O devices in a microcomputer system, its functional configuration is programmed by the system's software for maximum flexibility. The 8251A can support most serial data techniques in use, including IBM "bi-sync."

In a communication environment an interface device must convert parallel format system data into serial format for transmission and convert incoming serial format data into parallel system data for reception. The interface device must also delete or insert bits or characters that are functionally unique to the communication technique. In essence, the interface should appear "transparent" to the CPU, a simple input or output of byte-oriented system data.

## Data Bus Buffer

This 3-state, bidirectional, 8-bit buffer is used to interface the 8251A to the system Data Bus. Data is transmitted or received by the buffer upon execution of INput or OUTput instructions of the CPU. Control words, Command words and Status information are also transferred through the Data Bu's Buffer. The Command Status, Data-In and Data-Out registers are separate, 8 -bit registers communicating with the system bus through the Data Bus Buffer.

This functional block accepts inputs from the system Control bus and generates control signals for overall device operation. It contains the Control Word Register and Command Word Register that store the various control formats for the device functional definition.

## RESET (Reset)

A "high" on this input forces the 8251A into an "Idle" mode. The device will remain at "Idle" until a new set of control words is written into the 8251A to program its functional definition. Minimum RESET pulse width is $6 \mathrm{t}_{\mathrm{CY}}$ (clock must be running).

A command reset operation also puts the device into the "Idle" state.

## CLK (Clock)

The CLK input is used to generate internal device timing and is normally connected to the Phase 2 (TTL) output of the Clock Generator. No external inputs or outputs are referenced to CLK but the frequency of CLK must be greater than 30 times the Receiver or Transmitter data bit rates.

## $\overline{\text { WR }}$ (Write)

A "low" on this input informs the 8251A that the CPU is writing data or control words to the 8251A.

## $\overline{\mathrm{RD}}$ (Read)

A "low" on this input informs the 8251A that the CPU is reading data or status information from the 8251A.


Figure 3. 8251A Block Diagram Showing Data Bus Buffer and Read/Write Logic Functions

| C/D | $\overline{\text { RD }}$ | $\overline{\text { WR }}$ | $\overline{\text { CS }}$ |  |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 1 | 0 | 8251A DATA $\Rightarrow$ DATA BUS |
| 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ 8251A DATA |
| 1 | 0 | 1 | 0 | STATUS $\Rightarrow$ DATA BUS |
| 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ CONTROL |
| X | 1 | 1 | 0 | DATA BUS $\Rightarrow$ 3-STATE |
| X | x | x | 1 | DATA BUS $\Rightarrow$ 3-STATE |

## C/D (Control/Data)

This input, in conjunction with the $\overline{W R}$ and $\overline{R D}$ inputs, informs the 8251A that the word on the Data Bus is either a data character, control word or status information.

1 = CONTROL/STATUS; 0 = DATA.

## $\overline{\mathbf{C S}}$ (Chip Select)

A "low" on this input selects the 8251A. No reading or writing will occur unless the device is selected. When $\overline{C S}$ is high, the Data Bus is in the float state and $\overline{R D}$ and $\overline{W R}$ have no effect on the chip.

## Modem Control

The 8251A has a set of control inputs and outputs that can be used to simplify the interface to almost any modem. The modem control signals are general purpose in nature and can be used for functions other than modem control, if necessary.

## $\overline{\text { DSR }}$ (Data Set Ready)

The $\overline{\mathrm{DSR}}$ input signal is a general-purpose, 1 -bit inverting input port. Its condition can be tested by the CPU using a Status Read operation. The $\overline{\mathrm{DSR}}$ input is normally used to test modem conditions such as Data Set Ready.

## DTR (Data Terminal Ready)

The $\overline{D T R}$ output signal is a general-purpose, 1 -bit inverting output port. It can be set "low" by programming the appropriate bit in the Command Instruction word. The DTR output signal is normally used for modem control such as Data Terminal Ready.

## RTS (Request to Send)

The $\overline{R T S}$ output signal is a general-purpose, 1 -bit inverting output port. It can be set "low" by programming the appropriate bit in the Command Instruction word. The RTS output signal is normally used for modem control such as Request to Send.

## CTS (Clear to Send)

A "low" on this input enables the 8251A to transmit serial data if the Tx Enable bit in the Command byte is set to a "one." If either a Tx Enable off or CTS off condition occurs while the Tx is in operation, the Tx will transmit all the data in the USART, written prior to Tx Disable command before shutting down.

## Transmitter Buffer

The Transmitter Buffer accepts parallel data from the Data Bus Buffer, converts it to a serial bit stream, inserts the appropriate characters or bits (based on the communication technique) and outputs a composite serial stream of data on the TxD output pin on the falling edge of $\overline{T x C}$. The transmitter will begin transmission upon being enabled if $\overline{\mathrm{CTS}}=0$. The TxD line will be held in the marking state immediately upon a master Reset or when Tx Enable or CTS is off or the transmitter is empty.

## Transmitter Control

The Transmitter Control manages all activities associated with the transmission of serial data. It accepts and issues signals both externally and internally to accomplish this function.

## TxRDY (Transmitter Ready)

This output signals the CPU that the transmitter is ready to accept a data character. The TxRDY output pin can be used as an interrupt to the system, since it is masked by TxEnable; or, for Polled operation, the CPU can check TxRDY using a Status Read operation. TxRDY is automatically reset by the leading edge of $\overline{W R}$ when a data character is loaded from the CPU.

Note that when using the Polled operation, the TxRDY status bit is not masked by TxEnable, but will only indicate the Empty/Full Status of the Tx Data Input Register.

## TxE (Transmitter Empty)

When the 8251A has no characters to send, the TxEMPTY output will go "high." It resets upon receiving a character from the CPU if the transmitter is enabled. TxEMPTY remains low when the transmitter is disabled even if it is actually empty. TxEMPTY can be used to indicate the end of a transmission mode, so that the CPU "knows" when to "turn the line around" in the half-duplex operational mode.

In the Synchronous mode, a "high" on this output indicates that a character has not been loaded and the SYNC character or characters are about to be or are being transmitted automatically as "fillers." TxEMPTY does not go low when the SYNC characters are being shifted out.


Figure 4. 8251A Block Diagram Showing Modem and Transmitter Buffer and Control Functions

## TxC (Transmitter Clock)

The Transmitter Clock controls the rate at which the character is to be transmitted. In the Synchronous transmission mode, the Baud Rate (1x) is equal to the $\overline{T x C}$ frequency. In Asynchronous transmission mode, the baud rate is a fraction of the actual $\overline{T x C}$ frequency. A portion of the mode instruction selects this factor; it can be $1,1 / 16$ or $1 / 64$ the $\overline{\mathrm{TxC}}$.

For Example:
If Baud Rate equals 110 Baud,
$\overline{\mathrm{TXC}}$ equals 110 Hz in the 1 x mode.
$\overline{T x C}$ equals 1.72 kHz in the $16 x$ mode.
$\overline{T x C}$ equals 7.04 kHz in the 64 x mode.
The falling edge of $\overline{T x C}$ shifts the serial data out of the 8251A.

## Receiver Buffer

The Receiver accepts serial data, converts this serial input to parallel format, checks for bits or characters that are unique to the communication technique and sends an "assembled" character to the CPU. Serial data is input to RxD pin, and is clocked in on the rising edge of $\overline{\mathrm{RxC}}$.

## Receiver Control

This functional block manages all receiver-related activities which consists of the following features.

The RxD initialization circuit prevents the 8251A from mistaking an unused input line for an active low data line in the "break condition." Before starting to receive serial characters on the RxD line, a valid " 1 " must first be detected after a chip master Reset. Once this has been determined, a search for a valid low (Start bit) is enabled. This feature is only active in the asynchronous mode, and is only done once for each master Reset.

The False Start bit detection circuit prevents false starts due to a transient noise spike by first detecting the falling edge and then strobing the nominal center of the Start bit (RxD = low).

Parity error detection sets the corresponding status bit.

The Framing Error status bit is set if the Stop bit is absent at the end of the data byte (asynchronous mode).

## RxRDY (Receiver Ready)

This output indicates that the 8251A contains a character that is ready to be input to the CPU. RxRDY can be connected to the interrupt structure of the CPU or, for polled operation, the CPU can check the condition of RxRDY using a Status Read operation.

RxEnable, when off, holds RxRDY in the Reset Condition. For Asynchronous mode, to set RxRDY, the Receiver must be enabled to sense a Start Bit and a complete character must be assembled and transferred to the Data Output Register. For Synchronous mode, to set RxRDY, the Receiver must be enabled and a character must finish assembly and be transferred to the Data Output Register.

Failure to read the received character from the Rx Data Output Register prior to the assembly of the next Rx Data character will set overrun condition error and the previous character will be written over and lost. If the Rx Data is being read by the CPU when the internal transfer is occurring, overrun error will be set and the old character will be lost.

## $\overline{\mathbf{R X C}}$ (Receiver Clock)

The Receiver Clock controls the rate at which the character is to be received. In Synchronous Mode, the Baud Rate (1x) is equal to the actual frequency of $\overline{\mathrm{RxC}}$. In Asynchronous Mode, the Baud Rate is a fraction of the actual $\overline{R x C}$ frequency. A portion of the mode instruction selects this factor: 1, 1/16 or $1 / 64$ the $\overline{R x C}$.

For example:
Baud Rate equals 300 Baud, if
$\overline{R x C}$ equals 300 Hz in the 1x mode;
$\overline{\mathrm{RxC}}$ equals 4800 Hz in the $16 x$ mode;
$\overline{\mathrm{RxC}}$ equals 19.2 kHz in the 64 x mode.
Baud Rate equals 2400 Baud, if
$\overline{R x C}$ equals 2400 Hz in the 1x mode;
$\overline{\mathrm{RxC}}$ equals 38.4 kHz in the 16 x mode;
$\overline{\mathrm{RxC}}$ equals 153.6 kHz in the 64 x mode.
Data is sampled into the 8251A on the rising edge of $\overline{R x C}$.

NOTE: In most communications systems, the 8251A will be handling both the transmission and reception operations of a single link. Consequently, the Receive and Transmit Baud Rates will be the same. Both $\overline{T x C}$ and $\overline{R x C}$ will require identical frequencies for this operation and can be tied together and connected to a single frequency source (Baud Rate Generator) to simplify the interface.


Figure 5. 8251A Block Diagram Showing Receiver Buffer and Control Functions

## SYNDET (SYNC Detect/ BRKDET Break Detect)

This pin is used in Synchronous Mode for SYNDET and may be used as either input or output, programmable through the Control Word. It is reset to output mode low upon RESET. When used as an output (internal Sync mode), the SYNDET pin will go "high" to indicate that the 8251A has located the SYNC character in the Receive mode. If the 8251A is programmed to use double Sync characters (bisync), then SYNDET will go "high" in the middle of the last bit of the second Sync character. SYNDET is automatically reset upon a Status Read operation.

When used as an input (external SYNC detect mode), a positive going signal will cause the 8251A to start assembling data characters on the rising edge of the next $\overline{\mathrm{RxC}}$. Once in SYNC, the "high" input signal can be removed. When External SYNC Detect is programmed, Internal SYNC Detect is disabled.

## BREAK (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 6. 8251A Interface to $\mathbf{8 0 8 0}$ 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 RxRDYoutput 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.


The second SYNC character is skipped if MODE instruction has programmed the 8251A to single character Internal SYNC Mode. Both SYNC characters are skipped if MODE instruction has programmed the 8251A to ASYNC mode or External SYNC mode.

Figure 7. Typical Data Block

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

## Command Instruction

This instruction defines a 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 (see Figure 7). The Mode Instruction must be written immediately following a Reset operation, prior to using the 8251A for data communication.

All control words written into the 8251A after the Mode Instruction will load the Command Instruction. Command Instructions can be written into the 8251A at any time in the data block during the operation of the 8251 A . To return to the Mode Instruction format, the master Reset bit in the Command Instruction word can be set to initiate an internal Reset operation which automatically places the 8251A back into the Mode Instruction format. Command Instructions must follow the Mode Instructions or Sync characters.

## Mode Instruction Definition

The 8251A can be used for either Asynchronous or Synchronous data communication. To understand how the Mode Instruction defines the functional operation of the 8251 A , the designer can best view the device as two separate components, one Asynchronous and the other Synchronous, sharing
the same package. The format definition can be changed only after a master chip Reset. For explanation purposes the two formats will be isolated.

NOTE: When parity is enabled it is not considered as one of the data bits for the purpose of programming the word length. The actual parity bit received on the Rx Data line cannot be read on the Data Bus. In the case of a programmed character length of less than 8 bits, the least significant Data Bus bits will hold the data; unused bits are "don't care" when writing data to the 8251A, and will be "zeros" when reading the data from the 8251A.

## Asynchronous Mode (Transmission)

Whenever a data character is sent by the CPU the 8251A automatically adds a Start bit (low level) followed by the data bits (least significant bit first), and the programmed number of Stop bits to each character. Also, an even or odd Parity bit is inserted prior to the Stop bit(s), as defined by the Mode Instruction. The character is then transmitted as a serial data stream on the TxD output. The serial data is shifted out on the falling edge of $\overline{T x C}$ at a rate equal to $1,1 / 16$, or $1 / 64$ that of the $\overline{T x C}$, as defined by the Mode Instruction. BREAK characters can be continuously sent to the TxD if commanded to do so.

When no data characters have been loaded into the 8251A the TxD output reamins "high" (marking) unless a Break (continuously low) has been programmed.


Figure 8. Mode Instruction Format, Asynchronous Mode

## Asynchronous Mode (Receive)

The RxD line is normally high. A falling edge on this line triggers the beginning of a START bit. The validity of this START bit is checked by again strobing this bit at its nominal center ( 16 X or 64 X mode only). If a low is detected again, it is a valid START bit, and the bit counter will start counting. The bit counter thus locates the center of the data bits, the parity bit (if it exists) and the stop bits. If parity error occurs, the parity error flag is set. Data and parity bits are sampled on the RxD pin with the rising edge of $\overline{\mathrm{RxC}}$. If a low level is detected as the STOP bit, the Framing Error flag will be set. The STOP bit signals the end of a character. Note that the receiver requires only one stop bit, regardless of the number of stop bits programmed. This character is then loaded into the parallel I/O buffer of the 8251A. The RxRDY pin is raised to signal the CPU that a character is ready to be fetched. If a previous character has not been fetched by the CPU, the present character replaces it in the I/O buffer, and the OVERRUN Error flag is raised (thus the previous character is lost). All of the error flags can be reset by an Error Reset Instruction. The occurrence of any of these errors will not affect the operation of the 8251A.


Figure 9. Asynchronous Mode

## 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 CTS line goes low, the first character is serially transmitted out. All characters are shifted out on the falling edge of $\overline{T x C}$. Data is shifted out at the same rate as the TxC.

Once transmission has started, the data stream at the TxD output must continue at the $\overline{T \times C}$ rate. If the CPU does not provide the 8251A with a data character before the 8251A Transmitter Buffers become empty, the SYNC characters (or character if in single SYNC character mode) will be automatically inserted in the TxD data stream. In this case, the TxEMPTY pin is raised high to signal that the 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 RxD pin is then sampled 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 USARTends 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.


Figure 10. Mode Instruction Format, Synchronous Mode

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 11. Data Format, Synchronous Mode

## COMMAND INSTRUCTION DEFINITION

Once the functional definition of the 8251A has been programmed by the Mode Instruction and the sync characters are loaded (if in Sync Mode) then the device is ready to be used for data communication. The Command Instruction controls the actual operation of the selected format. Functions such as: Enable Transmit/Receive, Error Reset and Modem Controls are provided by the Command Instruction.

Once the Mode Instruction has been written into the 8251A and Sync characters inserted, if necessary, then all further "control writes" ( $C / D=1$ ) will load a Command Instruction. A Reset Operation (internal or external) will return the 8251A to the Mode Instruction format.

Note: Internal Reset on Power-up

When power is first applied, the 8251A may come up in the Mode, Sync character or Command format. To guarantee that the device is in the Command Instruction format before the Reset command is issued, it is safest to execute the worst-case initialization sequence (sync mode with two sync characters). Loading three 00 H s consecutively into the device with $C / \bar{D}=1$ configures sync operation and writes two dummy 00 H sync characters. An Internal Reset command $(40 \mathrm{H})$ may then be issued to return the device to the "Idle" state.


Figure 12. Command Instruction Format

## STATUS READ DEFINITION

In data communication systems it is often necessary to examine the "status" of the active device to ascertain if errors have occurred or other conditions that require the processor's attention. The 8251A has facilities that allow the programmer to "read" the status of the device at any time during the functional operation. (Status update is inhibited during status read.)

A normal "read" command is issued by the CPU with $C / \bar{D}=1$ to accomplish this function.

Some of the bits in the Status Read Format have identical meanings to external output pins so that the 8251 A can be used in a completely polled or interrupt-driven environment. TxRDY is an exception.

Note that status update can have a maximum delay of 28 clock periods from the actual event affecting the status.


Note 1: TxRDY status bit has different meanings from the TxRDY output pin: The former is not conditioned by CTS and TXEN; the latter is conditioned by both $\overline{C T S}$ and TxEN.
i.e. $T \times R D Y$ status bit $=D B$ Buffer Empty

T×RDY pin out $=\mathrm{DB}$ Buffer Empty $\cdot(\overline{\mathrm{CTS}}-0)$. ( $T \times E N=1$ )

Figure 13. Status Read Format

## APPLICATIONS OF THE 8251A



Figure 14. Asynchronous Serial Interface to CRT Terminal, DC-9600 Baud


Figure 15. Synchronous Interface to Terminal or Peripheral Device


Figure 16. Asynchronous Interface to Telephone Lines


Figure 17. Synchronous Interface to Telephone Lines

## ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature Under Bias | $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 | W |

*NOTICE: 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}_{C C}=5.0 \mathrm{~V} \pm 5 \%$, $\mathrm{GND}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OL}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{OFL}}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ TO 0.45V |
| $\mathrm{I}_{\text {IL }}$ | Input Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ TO 0.45V |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 100 | mA | All Outputs $=$ High |

CAPACITANCE $\left(T_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I}} / \mathrm{O}$ | I/O Capacitance |  | 20 | pF | Unmeasured pins returned <br> to GND |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ 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_{\text {AR }}$ | Address Stable Before $\overline{\operatorname{READ}}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | 0 |  | ns | Note 2 |
| $t_{\text {RA }}$ | Address Hold Time for $\overline{\operatorname{READ}}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | 0 |  | ns | Note 2 |
| $\mathrm{t}_{\text {RR }}$ | $\overline{R E A D}$ Pulse Width | 250 |  | ns |  |
| $t_{\text {RD }}$ | Data Delay from $\overline{\operatorname{READ}}$ |  | 200 | ns | $3, C_{\mathrm{L}}=150 \mathrm{pF}$ |
| $t_{D F}$ | $\overline{R E A D}$ to Data Floating | 10 | 100 | ns |  |

## WRITE CYCLE

| Symbol | Parameter | Min. | Max. | Unit | Test Condtions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | Address Stable Before $\overline{\text { WRITE }}$ | 0 |  | ns |  |
| $t_{\text {WA }}$ | Address Hold Time for $\overline{\text { WRITE }}$ | 0 |  | ns |  |
| $t_{\text {WW }}$ | $\overline{\text { WRITE Pulse Width }}$ | 250 |  | ns |  |
| $t_{\text {DW }}$ | Data Set-Up Time for $\overline{\text { WRITE }}$ | 150 |  | ns |  |
| $t_{\text {WD }}$ | Data Hold Time for WRITE | 20 |  | ns |  |
| $t_{\text {RV }}$ | Recovery Time Between WRITES | 6 |  | $\mathrm{t}_{\mathrm{CY}}$ | Note 4 |

## A.C. CHARACTERISTICS (Continued)

## OTHER TIMINGS

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {try }}$ | Clock Period | 320 | 1350 | ns | Notes 5, 6 |
| $\mathrm{t}_{0}$ | Clock High Pulse Width | 120 | ${ }^{\mathrm{t}} \mathrm{CY}^{-90}$ | ns |  |
| tor | Clock Low Pulse Width | 90 |  | ns |  |
| $t_{R}, t_{F}$ | Clock Rise and Fall Time |  | 20 | ns |  |
| ${ }_{\text {t }{ }_{\text {T }} \text { ( }}$ | TxD Delay from Falling Edge of $\overline{T \times C}$ |  | 1 | $\mu \mathrm{s}$ |  |
| ${ }^{T} \mathbf{T} \times$ | Transmitter Input Clock Frequency 1x Baud Rate 16x Baud Rate 64x Baud Rate | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{gathered} 64 \\ 310 \\ 615 \end{gathered}$ | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{kHz} \\ & \mathrm{kHz} \end{aligned}$ |  |
| ${ }^{\text {t }}$ PW | Transmitter Input Clock Pulse Width 1x Baud Rate 16x and 64x Baud Rate | $\begin{gathered} 12 \\ 1 \end{gathered}$ |  | $\begin{aligned} & \text { toy } \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| ${ }^{\text {tTPD }}$ | Transmitter Input Clock Pulse Delay 1x Baud Rate 16x and 64x Baud Rate | $\begin{gathered} 15 \\ 3 \end{gathered}$ |  | $\begin{aligned} & \mathrm{t} \mathrm{ty} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| $\mathrm{f}_{\mathrm{Rx}}$ | Receiver Input Clock Frequency 1x Baud Rate 16x Baud Rate 64x Baud Rate | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \end{aligned}$ | $\begin{gathered} 64 \\ 310 \\ 615 \end{gathered}$ | $\begin{aligned} & \mathrm{kHz} \\ & \mathrm{kHz} \\ & \mathrm{kHz} \end{aligned}$ |  |
| $t_{\text {RPW }}$ | Receiver Input Clock Pulse Width 1x Baud Rate 16x and 64x Baud Rate | $\begin{gathered} 12 \\ 1 \end{gathered}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| ${ }_{\text {trpD }}$ | Receiver Input Clock Pulse Delay 1x Baud Rate 16x and 64x Baud Rate | $\begin{gathered} 15 \\ 3 \end{gathered}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{tr}} \\ & t_{\mathrm{Cr}} \\ & \hline \end{aligned}$ |  |
| ${ }^{t_{T X R D Y}}$ | TxRDY Pin Delay from Center of Last Bit |  | 8 | $\mathrm{t}_{\mathrm{Cr}}$ | Note 7 |
| ${ }^{\text {T }}$ XRRDY CLEAR | TXRDY $\downarrow$ from Leading Edge of $\overline{\mathrm{WR}}$ |  | 400 | ns | Note 7 |
| $\mathrm{t}_{\text {RXR }}$ | RxRDY Pin Delay from Center of Last Bit |  | 26 | $\mathrm{t}_{\mathrm{Cr}}$ | Note 7 |
| $\mathrm{t}_{\text {RXRDY }}$ CLEAR | RxRDY $\downarrow$ from Leading Edge of $\overline{\mathrm{RD}}$ |  | 400 | ns | Note 7 |
| $\mathrm{t}_{1}$ | $\begin{aligned} & \text { Internal SYNDET Delay from Rising } \\ & \text { Edge of } \overline{R \times C} \end{aligned}$ |  | 26 | ${ }_{\text {t }}^{\text {Cr }}$ | Note 7 |
| $t_{\text {ES }}$ | External SYNDET Set-Up Time After Rising Edge of $\overline{\mathrm{RxC}}$ | 18 |  | ${ }_{\text {t }}^{\text {Cr }}$ | Note 7 |
| ${ }^{\text {t }}$ TEMPTY | TXEMPTY Delay from Center of Last Bit | 20 |  | ${ }^{\text {t }} \mathrm{CY}$ | Note 7 |
| ${ }^{\text {twc }}$ | Control Delay from Rising Edge of WRITE (TxEn, $\overline{D T R}, \overline{R T S})$ | 8 |  | ${ }_{\text {t }} \mathrm{Cr}$ | Note 7 |
| ${ }^{\text {t }}$ CR | Control to READ Set-Up Time ( $\overline{\text { DSR, }}$, CTS ) | 20 |  | $\mathrm{t}_{\mathrm{CY}}$ | Note 7 |

## A.C. CHARACTERISTICS (Continued)

## NOTES:

1. AC timings measured $\mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V}_{\mathrm{OL}}=2.0, \mathrm{~V}_{\mathrm{OL}}=0.8$, and with load circuit of Figure 1 .
2. Chip Select (CS) and Command/Data (C/D) are considered as Addresses.
3. Assumes that Address is valid before $R_{\mathrm{D}} \downarrow$.
4. This recovery time is for Mode Initialization only. Write Data is allowed only when TxRDY $=1$. Recovery Time between Writes for Asynchronous Mode is $8 \mathrm{t}_{\mathrm{CY}}$ and for Synchronous Mode is $16 \mathrm{t}_{\mathrm{CY}}$.
5. The TxC and RxC frequencies have the following limitations with respect to CLK: For $1 \times$ Baud Rate, $f_{T x}$ or $f_{R x} \leqslant 1 /(30$ ${ }^{t} \mathrm{cy}$ ):
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{CY}}$ minimum; System Clock must be running during Reset.
7. Status update can have a maximum delay of 28 clock periods from the event affecting the status.

TYPICAL $\Delta$ OUTPUT DELAY VS. $\triangle$ CAPACITANCE (pF)


## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

## SYSTEM CLOCK INPUT

clock.


## TRANSMITTER CLOCK AND DATA



## RECEIVER CLOCK AND DATA



WRITE DATA CYCLE (CPU $\rightarrow$ USART)


READ DATA CYCLE (CPU $\leftarrow$ USART)


## WAVEFORMS (Continued)

WRITE CONTROL OR OUTPUT PORT CYCLE (CPU $\rightarrow$ USART)


## READ CONTROL OR INPUT PORT (CPU $\leftarrow$ USART)



NOTE \#1: $T_{\text {WC }}$ INCLUDES THE RESPONSE TIMING OF A CONTROL BYTE NOTE \#2: $T_{C R}$ INCLUDES THE EFFECT OF CTS ON THE TXENBL CIRCUITRY.

TRANSMITTER CONTROL AND FLAG TIMING (ASYNC MODE)


WAVEFORMS (Continued)
RECEIVER CONTROL AND FLAG TIMING (ASYNC MODE)


TRANSMITTER CONTROL AND FLAG TIMING (SYNC MODE)


EXAMPLE FORMAT $=5$ BIT CHARACTER WITH PARITY, 2 SYNC CHARACTERS

## RECEIVER CONTROL AND FLAG TIMING (SYNC MODE)

 ASYNCHRONOUS RECEIVER-TRANSMITTER (MUART)

## - Programmable Serial Asynchronous Communications Interface for 5-, 6-, 7-, or 8 -Bit Characters, 1, $1 \frac{1}{2}$, or 2 Stop Bits, and Parity Generation

- On-Board Baud Rate Generator Programmable for 13 Common Baud Rates up to 19.2K Bits/second, or an External Baud Clock Maximum of 1M Bit/second


## - Five 8-Bit Programmable Timerl <br> Counters; Four Can Be Cascaded to Two 16-Bit Timer/Counters

- Two 8-Bit Programmable Parallel I/O Ports; Port 1 Can Be Programmed for Port 2 Handshake Controls and Event Counter Inputs
- Eight-Level Priority Interrupt Controller Programmable for 8085 or iAPX 86, iAPX 88 Systems and for Fully Nested Interrupt Capability
- Programmable System Clock to $1 \times$, $2 \times, 3 \times$, or $5 \times 1.024 \mathrm{MHz}$

The Inte ${ }^{\circledR} 8256$ Multifunction Universal Asynchronous Receiver-Transmitter (MUART) combines five commonly used functions into a single 40-pin device. It is designed to interface to the 8048, 8085A, iAPX 86, and iAPX 88 to perform serial communications, parallel I/O, timing, event counting, and priority interrupt functions. All of these functions are fully programmable through nine internal registers. In addition, the five timer/counters and two parallel I/O ports can be accessed directly by the microprocessor.


Figure 1. MUART Block Diagram


Figure 2. MUART Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :--- |
| ADO-AD4 | $1-5$ | I/O | Address/Data: Three-State Address/Data <br> LB5-DB7 <br> lines which interface with the CPU lower <br> 8-bit address/data bus. The 5-bit address <br> is latched on the falling edge of ALE. In <br> 8048 and 8085 mode, AD0-AD3 are used <br> to select the proper register, while AD1- <br> AD4 are used in 8086 and 8088 mode. <br> The 8-bit bidirectional data bus is either <br> written into or read from the chip <br> depending on the latched CS and RD or |
| WR. |  |  |  |


| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 40 | PS | Power: +5V POWER supply. |
| P17-P10 | 32-39 | 1/0 | Paraliel I/O Port 1: Each pin can be programmed as an input or an output to perform general purpose I/O functions for the CPU under software control. In addition to general I/O, I/O Port 1 can be programmed to a variety of special functions for handshake control, counter inputs, and special communications functions. |
| P27-P20 | 24-31 | I/O | Paraliel I/O Port 2: Each nibble (4 bits) of this port can be either an input or an output. Also, this port can be used as a bidirectional 8 -bit port using handshake lines in Port 1. |
| TxD | 23 | 0 | Transmit Data: This output carries the serial data to the terminal or modem from the MUART. |
| $\overline{T x C}$ | 22 | I/O | Transmit Clock: If the baud rate is 0 , this input clocks data out of the transmitter on the falling edge. If a baud rate of 1 or 2 is selected, this input permits the user to provide a $32 \times$ or $64 \times$ clock which is used for the receiver and transmitter. If the baud rate is $3-0 \mathrm{~F}_{16}$, the internal transmitter clock is output. If $11 / 2$ stop bits are selected and characters are continuously transmitted, the internal baud rate generator will be reset at the end of the stop bits and the clock will have a small positive spike instead of a half clock. A high-tolow transition occurs at the beginning of each bit and a low-to-high transition at the center of each bit. |
| $\overline{\text { CTS }}$ | 21 | 1 | Clear to Send: This input enables the serial transmitter. If CTS is low, any character in the transmitter buffer will be sent. A single negative-going pulse causes the transmission of a single previously loaded character out of the transmitter buffer. If this pulse occurs when the buffer is empty or during the transmission of a character up to 0.5 of the first stop bit, it will be ignored. If a baud rate from $1-0 \mathrm{~F}_{16}$ is selected, CTS must be low for at least $1 / 32$ of a bit, or it will be ignored. |

8256

## FUNCTIONAL DESCRIPTION

The 8256 Multi-Function Universal Asynchronous Receiver-Transmitter (MUART) combines five commonly used functions onto a single 40-pin device. The MUART performs asynchronous serial communications, parallel I/O, timing, event counting, and interrupt control.

## Serial Communications

The serial communications portion of the MUART contains a full-duplex asynchronous receivertransmitter (UART). A programmable baud rate generator is included on the MUART to permit a variety of operating speeds without external components. The UART can be programmed by the CPU for a variety of character sizes, parity generation and detection, error detection, and start/stop bit handling. The receiver checks the start and stop bits in the center of the bit, and a break halts the reception of data. The transmitter can send breaks and can be controlled by an external enable pin.

## Parallel I/O

The MUART includes 16 bits of general purpose parallel I/O. Eight bits (Port 1) can be individually changed from input to output or used for special I/O functions. The other eight bits (Port 2) can be used as nibbles (4 bits) or as bytes. These eight bits also include a handshaking capability using two pins on Port 1.

## Counter/Timers

There are five 8-bit counter/timers on the MUART. The timers can be programmed to use either a 1 kHz or 16 kHz clock generated from the system clock. Four of the 8 -bit counter/timers can be cascaded to two 16-bit counter/timers, and one of the 8 -bit counter/timers can be reset to its initial value by an external signal.

## Interrupts

An eight-level priority interrupt controller can be configured for fully nested or normal interrupt priority. Seven of the eight interrupts service functions on the MUART (counter/timers, UART), and one external interrupt is provided which can be used for a particular function or for chaining interrupt controllers or more MUARTs. The MUART will support 8085 and $8086 / 88$ systems with direct interrupt vectoring, or the MUART can be polled to determine the cause of the interrupt.

## Command Register 1

| L1 | L0 | S1 | S0 | BRKI | BITI | 8086 | FRQ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (OR) |  |  |  |  |  |  |  |

## FRQ - Timer Frequency Select

This bit selects between two frequencies for the five timers. If $\mathrm{FRQ}=0$, the timer input frequency is 16 kHz $(62.5 \mu \mathrm{~s})$. If $\mathrm{FRQ}=1$, the timer input frequency is 1 kHz ( 1 ms ). The selected clock frequency is shared by all the counteritimers enabled for timing; thus, all timers must run with the same time base.

## 8086 - 8086 Mode Enable

This bit selects between $8048 / 8085$ mode and $8086 / 8088$ mode. In 8085 mode $(8086=0)$, AO to A3 are used to address the internal registers, and an RST instruction is generated in response to the first INTA. In 8086 mode $(8086=1)$, A1 to A4 are used to address the internal registers, and AO is used as an extra chip select (AO must equal zero to be enabled). The response to INTA is for 8086 interrupts where the first $\overline{\mathrm{NTA}}$ is ignored, and an interrupt vector $\left(40_{16}\right.$ to $\left.47{ }_{16}\right)$ is placed on the bus in response to the second INTA.

## BITI - Interrupt on Bit Change

This bit disables the Timer 2 interrupt and enables an interrupt when a low-to-high transition occurs on pin 7 of Port 1 (pin 32).

## BRKI - Break-in Detect Enable

This bit enables the break-in detect feature. A break-in is detected when pin 6 of Port 1 (pin 33) is low during the first stop bit of a transmitted character. This could be used to detect a break-in condition by connecting the serial transmission line to pin 33. A break-in detect is OR-ed with break detect in bit 3 of the Status Register. If $\overline{\mathrm{RxC}}$ and $\overline{\mathrm{TxC}}$ are used for the serial bit rates, break-in cannot be detected.

## S0, S1 - Stop Bit Length

| S1 | S0 | Stop Bit Length |
| :---: | :---: | :---: |
| 0 | 0 | 1 |
| 0 | 1 | 1.5 |
| 1 | 0 | 2 |
| 1 | 1 | 0.75 |

If 0.75 stop bits is selected, $\overline{\text { CTS }}$ becomes edge sensitive rather than level sensitive. A high-to-low transition of CTS immediately initiates the transmission of the next character. A high-to-low transition will be ignored if the transmit buffer is empty, or if it occurs before 0.75 of the first stop bit. It will shorten the stop

Table 2. MUART Registers
Read Registers
Read Registers
R
bit if it occurs after $3 / 4$ of the stop bit has been sent. If CTS is high or low or a low-to-high transition occurs, the transmitter remains idle.

## LO, L1 - Character Length

| L1 | LO | Character Length |
| :---: | :---: | :---: |
| 0 | 0 | 8 |
| 0 | 1 | 7 |
| 1 | 0 | 6 |
| 1 | 1 | 5 |

## Command Register 2

| PEN | EP | C1 | C0 | B3 | B2 | B1 | B0 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (1R) |  |  |  |  |  |  | (1W) |  |  |  |  |  |

B0, B1, B2, B3 - Baud Rate Select

| B3 | B2 | B1 | B0 | Baud Rate | Sampling Rate |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | $\overline{\overline{T x C}, \overline{R x C}}$ | 1 |
| 0 | 0 | 0 | 1 | $\overline{T \times C} / 64$ | 64 |
| 0 | 0 | 1 | 0 | $\overline{\overline{T x C} / 32}$ | 32 |
| 0 | 0 | 1 | 1 | 19200 | 32 |
| 0 | 1 | 0 | 0 | 9600 | 64 |
| 0 | 1 | 0 | 1 | 4800 | 64 |
| 0 | 1 | 1 | 0 | 2400 | 64 |
| 0 | 1 | 1 | 1 | 1200 | 64 |
| 1 | 0 | 0 | 0 | 600 | 64 |
| 1 | 0 | 0 | 1 | 300 | 64 |
| 1 | 0 | 1 | 0 | 200 | 64 |
| 1 | 0 | 1 | 1 | 150 | 64 |
| 1 | 1 | 0 | 0 | 110 | 64 |
| 1 | 1 | 0 | 1 | 100 | 64 |
| 1 | 1 | 1 | 0 | 75 | 64 |
| 1 | 1 | 1 | 1 | 50 | 64 |

If the baud rate is 0 , then both the transmitter and receiver operate from separate external clocks. If the baud rate is 1 or 2 , then both the transmitter and receiver divide the $\overline{T x C}$ by 64 or 32 , respectively.

C0, C1 - System Clock Divider

| C1 | C0 | Divider Ratio | System Clock Frequency |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 5 | 5.120 MHz |
| 0 | 1 | 3 | 3.072 MHz |
| 1 | 0 | 2 | 2.048 MHz |
| 1 | 1 | 1 | 1.024 MHz |

## EP - Even Parity

If parity is enabled, then even parity is enabled by a 1 and odd parity is enabled by a 0.

## PEN - Parity Enable

This enables parity detection and generation. The type of parity is determined by the EP bit.

## Command Register 3

| SET | RXE | IAE | NIE | END | SBRK | TBRK |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (2R) |  |  |  |  |  |  |  |  |

Command Register 3 is different from the first two registers because it has a bit set/reset capability. Writing a byte with bit 7 high sets any bits which were also high. Writing a byte with bit 7 low resets any bits which were high. If any bit 0-6 is low, no change occurs to that bit. When Command Register 3 is read; bits 0,3 , and 7 will always be zero.

## RST - Reset

If RST is set, the following events occur:

1. All bits in the Status Register except bits 4 and 5 are cleared, and bits 4 and 5 are set.
2. The Interrupt Enable, Interrupt Request, and Interrupt Service Registers are cleared.
3. The receiver and transmitter are reset. The transmitter goes idle (TxD is high), and the receiver enters start bit search mode.
4. If Port 2 is programmed for handshake mode, $\overline{\mathrm{IBF}}$ and $\overline{\mathrm{OBF}}$ are reset high.
RST does not alter ports, data registers or command registers, but it halts any operation in progress. RST is automatically cleared.

## TBRK - Transmit Break

This causes the transmitter data to be set low, and it stays low until TBRK is cleared. As long as break is active, data transfer from the Transmitter Buffer to the Transmitter Register will be inhibited.

## SBRK - Single Character Break

This causes the transmitter data to be set low for one character including start bit, data bits, parity bit, and stop bits. SBRK is automatically cleared when time for the last data bit has passed. It will start after the character in progress completes and will delay the next data transfer from the Transmitter Buffer to the Transmitter Register until TxD returns to an idle (marking) state. If both TBRK and SBRK are set, break will be sent as long as TBRK is set, but SBRK will be cleared after one character time of break. If SBRK is set again, it remains set for another character. The user can send a definite number of break characters in this manner by clearing TBRK after setting SBRK for the last character time.

## END - End of Interrupt

If fully nested interrupt mode is selected, this bit resets the currently served interrupt level in the Interrupt Service Register. This command must occur at the end of each interrupt service routine during fully nested
interrupt mode. END is automatically cleared when the Interrupt Service Register (internal) is cleared. See the NIE description for more information on nested interrupt servicing. END is ignored if nested interrupts are not enabled.

## NIE - Nested Interrupt Enable

This bit enables fully nested interrupts. In this mode, the service routine for a lower priority interrupt can be interrupted by a request from a higher priority task.
In fully nested interrupt mode, $\overline{\text { INTA }}$ or reading the Interrupt Address Register resets the highest priority interrupt bit in the Interrupt Register (internal), sets the corresponding bit in the Interrupt Service Register (internal), and resets INT. If an interrupt of higher priority than the currently served interrupt is requested or the END bit is set while another interrupt request is pending, the INT line will go high again. If an interrupt service routine is interrupted by an interrupt of higher priority, two or more bits in the Interrupt Service Register will be set.
If NIE is low, interrupt priority is used only when two interrupts occur at the same time. INT will be high as long as the CPU has not responded to all the interrupts in the Interrupt Register.

## IAE - Interrupt Acknowledge Enable

This bit enables an automatic response to $\overline{\mathrm{NTA}}$. The particular response is determined by the 8086 bit in Command Register 1.

## RxE - Receiver Enable

This bit enables the serial receiver. The Receiver Buffer and all receiver status information will be disabled except for the break detect status.

## SET - Bit Set/Reset

If this bit is high during a write to Command Register 3, then any bit marked by a high will be set. If this bit is low, then any bit marked by a high will be cleared.

## Mode Register



P2C2, P2C1, P2C0 - Port 2 Control

| P2C2 | P2C1 | P2C0 | Mode | Direction |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | nibper | Lower |  |
| 0 | 0 | 1 | nibble | input | input |
| 0 | 1 | 0 | output |  |  |
| 0 | 1 | 1 | nibble | output | input |
| 1 | 0 | 0 | byte handshake | output | output |
| 1 | 0 | 1 | byte handshake | output |  |
| 1 | 1 | 0 | DO NOT USE |  |  |
| 1 | 1 | 1 | test |  |  |

If test mode is selected and BRG of Port 1 Control Register is set, then the output from the internal baud rate generator is placed on pin 4 of Port 1 (pin 35).

## CT2, CT3 - Counter/Timer Mode

If CT2 or CT3 are high, then counter/timer 2 or 3 respectively is configured as an event counter on pin 2 or 3 respectively of Port 1 (pins 37 or 36 ). The event counter decrements the count by one on each low-to-high transition of the external input. If CT2 or CT3 is low, then the respective counter/timer is configured as a timer and the Port 1 pins are used for parallel I/O.

## T5C - Timer 5 Control

If T5C is set, then Timer 5 can be preset and started by an external signal. Writing to the Timer 5 Register loads the Timer 5 Save Register and stops the timer. A high-tolow transition on pin 5 of Port 1 (pin 34) loads the timer with the saved value and starts the timer. The next high-to-low transition on pin 5 retriggers the timer by reloading it with the initial value and continues timing.
When the timer reaches zero it issues an interrupt request, disables its interrupt level and continues counting. A subsequent high-to-low transition on pin 5 resets Timer 5 to its initial value. For another timer interrupt, the Timer 5 interrupt enable bit must be set again.

## T35, T24 - Cascade Timers

These two bits cascade Timers 3 and 5 or 2 and 4. Timers 2 and 3 are the lower bytes, while Timers 4 and 5 are the upper bytes. If T5C is set, then both Timers 3 and 5 can be preset and started by an external pulse. When a high-to-low transition occurs, Timer 5 is preset to its saved value, but Timer 3 is always preset to all ones. If either CT2 or CT3 is set, then the corresponding timer pair is a 16 -bit event counter.

## Port 1 Control Register

\[

\]

Each bit in the Port 1 Control Register configures the direction of the corresponding pin. If the bit is high, the pin is an output, and if it is low the pin is an input. Every Port 1 pin has another function which is controlled by other registers. If that special function is disabled, the pin functions as a general I/O pin as specified by this register. The special functions for each pin are described below.

## Port 10, 11 - Handshake Control

If byte handshake control is enabled for Port 2 by the Mode Register, then Port 10 is programmed as STB/ĀCK handshake control input and Port 11 is programmed as $\overline{\mathrm{IBF}} / \overline{\mathrm{OBF}}$ handshake control output.

If byte handshake mode is enabled for output on Port 2, $\overline{O B F}$ indicates that a character has been loaded into the

Port 2 output buffer. When an external device reads the data, it acknowledges this operation by driving $\overline{\mathrm{ACK}}$ low. $\overline{\mathrm{OBF}}$ is set low by writing to Port 2 and is reset high by $\overline{\text { ACK. }}$
If byte handshake mode is enabled for input on Port 2, STB is an input to the MUART to latch the data into Port 2. After the data is latched, $\overline{\mathrm{IBF}}$ is driven low. $\overline{\mathrm{IBF}}$ is reset high when Port 2 is read.

Port 12, 13 - Counter 2, 3 Input
If Timer 2 or Timer 3 is programmed as an event counter by the mode register, then Port 12 or 13 is the counter input for Event Counter 2 or 3, respectively.

## Port 14 - Baud Rate Generator Output Clock

If test mode is enabled by the Mode Register and Command Register 2 baud rate select is greater than 2, then Port 14 is an output from the internal baud rate generator.

## Port 15 - Timer 5 Trigger

If T5C is set in the Mode Register enabling a retriggerable timer, then Port 15 is the input which starts and reloads Timer 5.

## Port 16 - Break-in Detect

If break-in detect is enabled by BRKI in Command Register 1, then this input is used to sense a break-in. If Port 16 is low while the serial transmitter is sending the last stop bit, then a break-in condition is signaled.

## Port 17 - Port Interrupt Source

If BITI in Command Register 1 is set, then a low-to-high transition on Port 17 generates an interrupt request on priority level 1.

## Receiver and Transmitter Buffer



Both the transmitter and the receiver in the MUART are fully double buffered. The Receiver Buffer full flag is cleared when the character is read. If the character is not read before the next character's first stop bit, then an overrun error is generated. Bytes written to the Transmitter Buffer are held until the Transmitter Register (internal) is empty. If the Transmitter Register is empty, the byte is transferred immediately and the Transmitter Buffer empty flag is set. If a serial character length is less than 8 bits, then the unused most significant bits are set to zero on a read and are ignored on a write.

## Port 1



Writing to Port 1 sets the data in the Port 1 output latch. Writing to an input pin does not affect the pin, but the data is stored and will be output if the direction of the pin is changed later. If the pin is used as a control signal, the pin will not be affected, but the data is stored. Reading Port 1 transfers the data in Port 1 onto the data bus. Reading an output pin or a control pin puts the data in the output latch (not the control signal) onto the data bus.

## Interrupt Enable Register

| L7 | L6 | L5 | L4 | L3 | L2 | L1 | L0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| (5R) |  |  |  |  |  |  |  |

Interrupts are enabled by writing to the Set Interrupts Register (5W). Interrupts are disabled by writing to the Reset Interrupts Register (6W). Each bit set by the Set Interrupts Register (5W) will enable that level interrupt, and each bit set in the Reset Interrupts Register (6W) will disable that level interrupt. The user can determine which interrupts are enabled by reading the Interrupt Enable Register (5R).

Priority
Highest LO
L1
L2
L3
L4
L5
L6
Lowest L7

## Source

Timer 1
Timer 2 or Port Interrupt External Interrupt (EXTINT)

Timer 3 or Timers 3 \& 5
Receiver Interrupt
Transmitter Interrupt
Timer 4 or Timers $2 \& 4$
Timer 5 or
Port 2 Handshaking

## Port 2

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| (9R) |  |  |  |  |  |  |  |

Writing to Port 2 sets the data in the Port 2 output latch. Writing to an input pin does not affect the pin, but it does store the data in the latch. Reading Port 2 puts the input pins onto the bus or the contents of the output latch for output pins.

8256

## Timer 1-5

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\left(0 \mathrm{~A}_{16}-0 \mathrm{E}_{16} \mathrm{R}\right)$ |  |  |  |  |  |  |  |

Reading Timer N puts the contents of the timer onto the data bus. If the counter changes while $\overline{\mathrm{RD}}$ is low, the value on the data bus will not change. If two timers are cascaded, reading the high order byte will cause the low order byte to be latched. Reading the low order byte will unlatch them both. Writing to either timer or decascading them also clears the latch condition. Writing to a timer sets the starting value of that timer. If two timers are cascaded, writing to the high order byte presets the low order byte to all ones. Loading only the high order byte with a value of $X$ leads to a count of $X \cdot 256+255$. Timers count down continuously. If the interrupt is enabled, it occurs when the counter changes from 1 to 0 . When the interrupt is set in the Interrupt Register, interrupts are disabled in the Interrupt Mask Register.

## Status Register

| INT | RBF | TBE | TRE | BD | PE | OE | FE |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\left(0 F_{16} \mathrm{R}\right)$ |  |  |  |  |  |  |  |

## FE - Framing Error, Transmission Mode

If transmission mode is disabled (in Modification Register), then FE indicates a framing error. A framing error is detected during the first stop bit. The error is reset by reading the Status Register or by a chip reset. A framing error does not inhibit the loading of the Receiver Buffer. If RxD remains low, the receiver will assemble the next character. The false stop bit is treated as the next start bit, and no high-to-low transition on RxD is required to synchronize the receiver.
If transmission mode is enabled, then this bit is used to suggest the transmitter was sending. FE will be high if the transmitter is active during the reception of the parity bit (or last data bit for no-parity). It is reset if the transmitter is not active or by a chip reset. The bit is intended to imply that the received character is from the transmitter in half-duplex systems.

## OE - Overrun Error

If the user does not read the character in the Receiver Buffer before the next character is received and transferred to this register, then the OE bit is set. The OE flag is set during the reception of the first stop bit and is cleared when the Status Fegister is read or when a chip reset occurs.

## PE - Parity Error

A parity error is set during the first stop bit and is reset by reading the Status Register or by a chip reset.

## BD - Break Detect, Break-in Detect

If BRKI in Command Register 1 is set to enable break-in detect, then BD indicates a break-in condition. If Port 16 is low during the transmission of the last stop bit, then BD will be set near the end of the last stop bit. Break-in detect can only be detected if the internal baud rate generator is used. Break-in remains set until the Status Register is read or the chip is reset.
If BRKI is low, then BD indicates a break condition on the receiver. BD is set when the first stop bit of a break is sampled and will remain set until the Status Register is read or the chip is reset. The receiver will remain idle until the next high-to-low transition on RxD. A detected break inhibits the loading of the Receiver Buffer.

## TRE - Transmitter Register Empty

This status bit indicates that the Transmitter Register is busy. It is set by a chip reset and when the last stop bit has left the transmitter. It is reset when a character is loaded into the Transmitter Register. If CTS is low, the Transmitter Register will be loaded during the transmission of the start bit. If CTS is high at the end of a character, TRE will remain high and no character will be loaded into the Transmitter Register until CTS goes low. If the transmitter was inactive before a character is loaded into the Transmitter Buffer, the Transmitter Register will be empty temporarily while the buffer is full. However, the data in the buffer will be transferred to the transmitter register immediately and TRE will be cleared while TBE is set.

## TBE - Transmitter Buffer Empty

TBE indicates the Transmitter Buffer is empty and is ready to accept a character. TBE is set by a chip reset or the transfer of data to the Transmitter Register and is cleared when a character is written to the transmitter buffer.

## RBF - Receiver Buffer Full

RBF is set when the Receiver Buffer has been loaded with a new character during the sampling of the first stop bit. RBF is cleared by reading the receiver buffer or by a chip reset.

## INT - Interrupt Pending

The INT bit reflects the state of the INT pin (pin 15) and indicates an interrupt is pending in the Interrupt Register. It is reset by INTA or by reading the Interrupt Address Register if only one interrupt is pending and by a chip reset.

FE, OE, PE, RBF, and break detect all generate a level 4 interrupt when the receiver samples the first stop bit. TRE, TBE, and break-in detect generate a level 5 interrupt. TRE generates an interrupt when TBE is set and the Transmitter Register finishes transmitting. The
break-in detect interrupt is issued at the same time as TBE or TRE.

## Modification Register

| 0 | RS4 | RS3 | RS2 | RS1 | RS0 | TME | DSC |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\left(0 F_{16} \mathrm{~W}\right)$ |  |  |  |  |  |  |  |

DSC - Disable Start Bit Check
DSC disables the receiver's start bit check. In this state the receiver will not be reset if RxD is not low at the center of the start bit. This function is disabled by a chip reset.

TME - Transmission Mode Enable
TME enables transmission mode and disables framing error detection. A chip reset disables transmission mode and enables framing error detection.

RS0, RS1, RS2, RS3, RS4 - Receiver Sample Time
The number in RSn alters when the receiver samples RxD. A chip reset sets this value to 0 which is the center
of the bit (sample time $=16$ ). The receiver sample time can be modified only if the receiver is not clocked by $\overline{R x C}$.

|  |  |  | Sample Time |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| RS4 | RS3 | RS2 | RS1 | RS0 $=\mathbf{0}$ | RS0 $=\mathbf{1}$ |

# 8273, 8273-4, 8273-8 <br> PROGRAMMABLE HDLC/SDLC PROTOCOL CONTROLLER 

- CCITT X. 25 Compatible
- HDLC/SDLC Compatible
- Full Duplex, Half Duplex, or Loop SDLC Operation
- Up to 64K Baud Synchronous Transfers
- Automatic FCS (CRC) Generation and Checking
- Up to 9.6K Baud with On-Board Phase
Locked Loop
- Programmable NRZI Encode/Decode
- Two User Programmable Modem Control Ports
- Digital Phase Locked Loop Clock Recovery
- Minimum CPU Overhead

■ Fully Compatible with 8048/8080/8085/ 8088/8086 CPUs

- Single +5V Supply

The Intel ${ }^{\circledR} 8273$ Programmable HDLC/SDLC 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-88/86 ${ }^{T M}$. 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.



Figure 2. Pin Configuration

# A BRIEF DESCRIPTION OF HDLCISDLC 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 (I), 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, GA27-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

8273, 8273-4, 8273-8

Table 1. Pin Description

| Symbol | $\begin{array}{\|l\|} \hline \text { Pin } \\ \text { No. } \\ \hline \end{array}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $V_{\text {cc }}$ | 40 |  | Power Supply: +5 V Supply. |
| GND | 20 |  | Ground: Ground. |
| RESET | 4 | 1 | Reset: 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{\text { CS }}$ | 24 | 1 | Chip Select: The RD and WR inputs are enabled by the chip select input. |
| $\mathrm{DB}_{7}-\mathrm{DB}_{0}$ | $\begin{aligned} & 19- \\ & 12 \end{aligned}$ | 1/0 | Data Bus: The Data Bus lines are bidirectional three-state lines which interface with the system Data Bus. |
| $\overline{W R}$ | 10 | 1 | Write Input: The Write signal is used to control the transfer of either a command or data from CPU to the 8273. |
| RD | 9 | 1 | Read Input: The Read signal is used to control the transfer of either a data byte or a status word from the 8273 to the CPU. |
| TxINT | 2 | 0 | Transmitter Interrupt: The Transmitter interrupt signal indicates that the transmitter logic requires service. |
| RxINT | 11 | 0 | Receiver Interrupt: The Receiver interrupt signal indicates that the Receiver logic requires service. |
| TxDRQ | 6 | 0 | Transmitter Data Request: Requests a transfer of data between memory and the 8273 for a transmit operation. |
| RxRDQ | 8 | 0 | Receiver DMA Request: Requests a transfer of data between the 8273 and memory for a receive operation. |
| $\overline{\text { TxDACK }}$ | 5 | 1 | Transmitter DMA Acknowledge: The Transmitter DMA acknowledge signal notifies the 8273 that the TxDMA cycle has been granted. |
| $\overline{\text { RxDACK }}$ | 7 | 1 | Receiver DMA Acknowledge: The Receiver DMA acknowledge signal notifies the 8273 that the RxDMA cycle has been granted. |
| $\mathrm{A}_{1}-\mathrm{A}_{0}$ | $\begin{aligned} & 22- \\ & 21 \end{aligned}$ | 1 | Address: These two lines are CPU Interface Register Select lines. |
| TxD | 29 | 0 | Transmitter Data: This line transmits the serial data to the communication channel. |
| $\overline{\mathrm{TXC}}$ | 28 | 1 | Transmitter Clock: The transmitter clock is used to synchronize the transmit data. |
| R×D | 26 | 1 | Receiver Data: This line receives serial data from the communication channel. |
| $\overline{\mathrm{R} \times \mathrm{C}}$ | 27 | 1 | Receiver Clock: The Receiver Clock is used to synchronize the receive data. |


| Symbol | $\begin{array}{\|l\|} \hline \text { Pin } \\ \text { No. } \\ \hline \end{array}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{32 X ~ C L K}$ | 25 | 1 | 32X Clock: 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 1X clock by using the 32X CLK in conjunction with the DPLL output. (This pin must be grounded when not used.) |
| $\overline{\text { DPLL }}$ | 23 | 0 | Digital Phase Locked Loop: Digital Phase Locked Loop output can be tied to RxC and/or TxC when 1X clock is not available. DPLL is used with 32X CLK. |
| FLAG DET | 1 | 0 | Flag Detect: Flag Detect signals that a flag ( 01111110 ) has been received by an active receiver. |
| $\overline{\text { RTS }}$ | 35 | 0 | Request to Send: Request to Send signals that the 8273 is ready to transmit data. |
| $\overline{\text { CTS }}$ | 30 | 1 | Clear to Send: Clear to Send signals that the modem is ready to accept data from the 8273. |
| $\overline{C D}$ | 31 | 1 | Carrier Detect: Carrier Detect signals that the line transmission has started and the 8273 may begin to sample data on RxD line. |
| $\overline{\mathrm{PA}}_{2-4}$ | $\begin{aligned} & 32- \\ & 34 \end{aligned}$ | 1 | General purpose input ports: The logic levels on these lines can be Read by the CPU through the Data Bus Buffer. |
| $\overline{\mathrm{PB}}_{1-4}$ | $\begin{aligned} & 36- \\ & 39 \end{aligned}$ | 0 | General purpose output ports: The CPU can write these output lines through Data Bus Buffer. |
| CLK | 3 | 1 | Clock: A square wave TTL |

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

## CPU Interface

The CPU interface is optimized for the MCS-80/85 ${ }^{\text {™ }}$ 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{\mathrm{I} O W}$. The table shows the seven register select decoding:


Figure 4. 8273 Block Diagram Showing CPU Interface Functions

| $\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 |
| $\mathbf{X}$ | X | 0 | 1 | 1 | 1 | 0 | Transmit Data |
| X | X | 1 | 0 | 1 | 0 | 1 | Receive Data |

## Register Description

## Command

Operations are initiated by writing an appropriate 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.

## $\overline{\text { 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. Note: $\overline{\mathrm{RD}}$ must not be asserted while TxDACK is active.

## 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. Note: WR must not be asserted while RxDACK is active.

## $\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 D.MA 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{R T S}$ 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 CTS (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{C T S}$ 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 5. 8273 Block Diagram Showing Control Logic Functions

## Port B - Output Port

During normal operation, if the CPU sets $\overline{R T S}$ active, the 8273 will not change this pin; however, if the CPU sets $\overline{R T S}$ 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{(\overline{T x C})}$ and receive ( $\overline{\mathrm{RXC}}$ ) clocks. The leading edge of $\overline{\mathrm{TxC}}$ generates new transmit data and the trailing edge of $\overline{\mathrm{RxC}}$ 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{T \times C}$ pin for the $\overline{R x C}$ 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 $R \times D$ is sampled on the trailing edge, the selected clock allows bit synchronism.


Figure 6. 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 ( $\mathrm{R} \times \mathrm{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 DPLL 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 X ~ 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 A1, 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 DPLL 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 7. 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 8. 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 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.

$$
\begin{array}{c|c|ccc|c|c|c|c}
D_{7} & D_{6} & D_{5} & D_{4} & D_{3} & D_{2} & D_{1} & D_{0} \\
\hline \text { CBSY } & \mathrm{CBF} & \mathrm{CPBF} & \mathrm{CRBF} & \mathrm{Rx} \times \mathrm{NT} & \mathrm{Tx} \text { INT } & \text { Rx|RA } & \text { TxIRA }
\end{array}
$$

## 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 9. 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 enters into 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 in 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 10. Rx Interrupt Result Byte Format


Figure 11. 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{C T S}, \overline{C D}, \overline{R T S}$, 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.


Figure 12. Result Phase Flowchart—Interrupt Results

## IMMEDIATE RESULTS



Figure 13. (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 Lcop 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)

|  | $\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 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 |
| PAR: | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

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 Transfer Mode (CMD Code 97)

\(\left.\begin{array}{c|c|c|c|c|c|c|c|c|c|c|} \& A_{1} \& A_{0} \& D_{7} \& D_{6} \& D_{5} \& D_{4} \& D_{3} \& D_{2} \& D_{1} \& D_{0} <br>
\hline CMD: \& 0 \& 0 \& 1 \& 0 \& 0 \& 1 \& 0 \& 1 \& 1 \& 1 <br>

\hline \& PAR: \& 0 \& 1 \& 0 \& 0 \& 0 \& 0 \& 0 \& 0 \& 0\end{array}\right]\)| 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 ( TXIRA $=0$ ), the interrupt is a transmit data request. If a receive interrupt occurs and the status indicates that there is no receive result ( $\mathrm{RxIRA}=0$ ), the interrupt is a receive data request.

## Reset Data Transfer Mode (CMD Code 57)



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)

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ |  | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 |
| PAR: | 0 | 1 | 1 | 1 |  |  |  |  |  |  |

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 $T x$ commands are provided, a final interrupt will follow.

Note: In buffered mode, if a supervisory frame (no Information) Transmit command is sent in response to an early Transmit Interrupt, the 8273 will repeatedly transmit the same supervisory frame with one flag in between, until a non-supervisory transmit is issued.

Early transmitter interrupt can be used in buffered mode by waiting for a transmit complete interrupt instead of early Transmit Interrupt before issuing a transmit frame command for a supervisory frame. See Figure 14.


Figure 14.
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) $)_{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.

| TRANSMITTER STATE | ACTION |
| :--- | :--- |
| Idle | Send Flags immediately. |
| Transmit or Transmit- | Send Flags after the <br> transmission complete <br> Transparent Active <br> Loop Transmit Active <br> 1 Bit Delay Active | | Ignore command. |
| :--- |
| Ignore command. |

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- |  |
| Transparent Active |  |
| Loop Transmit Active | Send Idles after the transmission <br> is complete. <br> Ignore command. |
| 1 Bit Delay Active | Ignore command. |

## Set Serial I/O Mode (CMD Code AO)



## Reset Serial I/O Mode (CMD Code 60)

This command allows bits set in CMD code A0 to be reset by placing zeros in the appropriate positions.

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

## (D2) Loop Back

If this bit is set to a one, the transmit data is internally routed to the receive data circuitry.
(D1) $\mathrm{TxC} \rightarrow \mathrm{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).

## (DO) 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 | $\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}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 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.

|  | $A_{1}$ | $A_{0}$ | $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| PAR: | 0 | 1 | LEAST SIGNIFICANT BYTE OF THE <br> RECEIVE BUFFER LENGTH (B0) |  |  |  |  |  |  |  |
|  | PAR: | 0 | 1 | MOST SIGNIFICANT BYTE OF RECEIVE <br> BUFFER LENGTH (B1) |  |  |  |  |  |  |

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

|  | $\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 | 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)

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | ${ }^{2}$ | D | $\mathrm{D}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 |
| PAR: | 0 | 0 | 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 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}$ | $A_{0}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | D1 | $\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 L0, 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)

|  | $\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}$ | 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. If the flag stream mode is not active transmission will begin after a received EOP has been converted to a flag.
2. 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.
3. 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 C9)

|  | $\mathrm{A}_{1}$ | $A_{0}$ | D7 | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMD: | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 1 |
| PAR: | 0 | 1 | LEAST SIGNIFICANT BYTE OF FRAME LENGTH (LO) |  |  |  |  |  |  |  |
| PAR: | 0 | 1 | MOST SIGNIFICANT BYTE OF FRAME LENGTH (L1) |  |  |  |  |  |  |  |

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}$ output 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 ( $\mathrm{PB}_{4}-$ $\mathrm{PB}_{1}$ ).

## 8273 Command Summary

| Command Description | Command <br> (HEX) | Parameter | Results | Result <br> Port | Completion <br> 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 | A0 | 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,(A,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:

## 8273 Command Summary Key

B0 - Least significant byte of the receive buffer length.
B1 - Most significant byte of the receive buffer length.
LO - 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.
RXI/R - Receive interrupt result register.
TXI/R - Transmit interrupt result register.
RO - 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.


Figure 15. Typical Frame Reception

## NOTE:

In order to ensure proper operation to the maximum baud rate, Receive commands or Read/Write Port commands should be written only when either the transmitter or the receiver is inactive. In full duplex systems, it is recommended that these commands be issued after servicing a transmitter interrupt but before a new transmit command is issued.


Figure 16a. Typical Frame Transmission, Buffered Mode


Figure 16b. Typical Frame Transmission, Non-Buffered Mode


Figure 17. 8273 System Diagram

## ABSOLUTE MAXIMUM RATINGS*

| Am | $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 |

*NOTICE: 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 (8273, 8273-4, 8273-8) ( $\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 | $\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> $\mathrm{I}_{\mathrm{OL}}=1.0 \mathrm{~mA}$ for Output Port Pins <br> $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ for All Other Pins |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ for Data Bus Pins <br> $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ for All Other Pins |
| $\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 Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to .45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 180 | mA |  |

CAPACITANCE (8273, 8273-4, 8273-8) $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right.$ )

| 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}_{/ / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured Pins <br> Returned to GND |

## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%\right)$ <br> CLOCK TIMING (8273)

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CY}}$ | Clock | 250 |  | 1000 | ns | 64K Baud Max <br> Operating Rate |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock Low | 120 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock High | 120 |  |  | ns |  |

CLOCK TIMING (8273-4)

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CY}}$ | Clock | 286 |  | 1000 | ns | 56K Baud Max <br> Operating Rate |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock Low | 135 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock High | 135 |  |  | ns |  |

## CLOCK TIMING (8273-8)

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{t}_{\mathrm{CY}}$ | Clock | 330 |  | 1000 | ns | 48K Baud Max <br> Operating Rate |
| $\mathrm{t}_{\mathrm{CL}}$ | Clock Low | 150 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{CH}}$ | Clock High | 150 |  |  | ns |  |

A.C. CHARACTERISTICS $(8273,8273-4,8273-8)\left(T_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 5 \%\right)$

READ CYCLE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{t}_{\mathrm{AC}}$ | Select Setup to $\overline{\mathrm{RD}}$ | 0 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{CA}}$ | Select Hold from $\overline{\mathrm{RD}}$ | 0 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\mathrm{RD}}$ Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{AD}}$ | Data Delay from Address |  | 300 | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Delay from $\overline{\mathrm{RD}}$ |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$, Note 2 |
| $\mathrm{t}_{\mathrm{DF}}$ | Output Float Delay | 20 | 100 | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ for Minimum; <br> 150 pF for Maximum |
| $\mathrm{t}_{\mathrm{DC}}$ | DACK Setup to $\overline{\mathrm{RD}}$ | 25 |  | ns |  |
| $\mathrm{t}_{\mathrm{CD}}$ | DACK Hold from $\overline{\mathrm{RD}}$ |  |  | ns |  |
| $\mathrm{t}_{\mathrm{KD}}$ | Data Delay from DACK |  | 300 | 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{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{W R}$ or $\overline{\mathrm{RD}}$ <br> (for Non-Burst Mode) |  | ns |  |  |

## OTHER TIMING

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {RSTW }}$ | Reset Pulse Width | 10 |  | $\mathrm{t}_{\mathrm{CY}}$ |  |
| $\mathrm{t}_{\mathrm{r}}$ | Input Signal Rise Time |  | 20 | ns |  |
| $\mathrm{t}_{\mathrm{f}}$ | Input Signal Fall Time |  | 20 | ns |  |
| $\mathrm{t}_{\mathrm{RSTS}}$ | Reset to First IOWR | 2 |  | $\mathrm{t}_{\mathrm{CY}}$ |  |
| $\mathrm{t}_{\mathrm{CY} 32}$ | $32 X$ Clock Cycle Time | $9.7 \cdot \mathrm{t}_{\mathrm{CY}}$ |  | ns |  |
| $\mathrm{t}_{\mathrm{CL} 32}$ | $32 X$ Clock Low Time | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ |  | ns |  |
| $\mathrm{t}_{\mathrm{CH} 32}$ | $32 X$ Clock High Time | $4 \cdot \mathrm{t}_{\mathrm{CY}}$ |  | ns |  |
| $\mathrm{t}_{\mathrm{DPLL}}$ | $\overline{\text { DPLL Output Low }}$ | $1 \cdot \mathrm{t}_{\mathrm{CY}}-50$ |  | ns |  |
| $\mathrm{t}_{\mathrm{DCL}}$ | Data Clock Low | $1 \cdot \mathrm{t}_{\mathrm{CY}}-50$ |  | ns |  |
| $\mathrm{t}_{\mathrm{DCH}}$ | Data Clock High | $2 \cdot \mathrm{t}_{\mathrm{CY}}$ |  | ns |  |
| $\mathrm{t}_{\mathrm{DCY}}$ | Data Clock | $62.5 \cdot \mathrm{t}_{\mathrm{CY}}$ |  | ns |  |
| $\mathrm{t}_{\mathrm{TD}}$ | Transmit Data Delay |  | 200 | ns |  |
| $\mathrm{t}_{\mathrm{DS}}$ | Data Setup Time | 200 |  | ns |  |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold Time |  |  | ns |  |
| $t_{\mathrm{FLD}}$ | FLAG DET Output Low | $8 \cdot t_{\mathrm{CY}} \pm 50$ |  | ns |  |

NOTES:

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.0 V , " 0 " at 0.8 V .
2. $t_{A D}, t_{R D}, t_{A C}$, and $t_{C A}$ are not concurrent specs.
3. If receive commands or Read/Write Port commands are issued while both the transmitter and receiver are active, this specification will be $81.5 \mathrm{~T}_{\mathrm{CY}} \mathrm{min}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS

IREAD


WRITE


## WAVEFORMS (Continued)

DMA


32X CLOCK


## TRANSMIT



## RECEIVE



## WAVEFORMS (Continued)

DPLL OUTPUT
$\overline{\mathrm{DPLL}}$


FLAG DETECT OUTPUT
$\overline{\text { FLAG DET }}$


PRELCOMRNARY

## 8274 <br> MULTI-PROTOCOL SERIAL CONTROLLER (MPSC)

- Asynchronous, Byte Synchronous and Bit Synchronous Operation
- Two Independent Full Duplex Transmitters and Receivers
- Fully Compatible with $8048,8051,8085$, 8088, and 8086 CPU's; 8257 and 8237 DMA Controllers; and 8089 I/O Proc.
- 4 Independent DMA Channels
- Baud Rate: DC to 880K Baud -Future Selections to 1M Baud
- Asynchronous:
-5-8 Bit Character; Odd, Even, or No Parity; 1, 1.5 or 2 Stop Bits
-Error Detection: Framing, Overrun, and Parity
- Byte Synchronous:
- Character Synchronization, Int. or Ext.
- One or Two Sync Characters
- Automatic CRC Generation and Checking (CRC-16)
- IBM Bisync Compatible
- Bit Synchronous:
- SDLC/HDLC Flag Generation and Recognition
- 8 Bit Address Recognition
- Automatic Zero Bit Insertion and Deletion
- Automatic CRC Generation and Checking (CCITT-16)
- CCITT X. 25 Compatible

The Intel ${ }^{\circledR} 8274$ Multi-Protocol Series Controller (MPSC) is designed to interface High Speed Communications Lines using Asynchronous, IBM Bisync, and SDLC/HDLC protocol to Intel microcomputer systems. It can be interfaced with Intel's MCS-48, -85, -51 ; iAPX-86, and -88 families, the 8237 DMA Controller, or the 8089 I/O Processor in polled, interrupt driven, or DMA driven modes of operation.
The MPSC is a 40 pin device fabricated using Intel's High Performance HMOS Technology.


Figure 1. Block Diagram

Table 1. Pin Description

| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| CLK | 1 | 1 | Clock: System clock, TTL compatible. |
| RESET | 2 | 1 | Reset: A low signal on this pin will force the MPSC to an idle state. $T x D_{A}$ and $T x D_{B}$ are forced high. The modem interface output signals are forced high. The MPSC will remain idle until the control registers are initialized. Reset must be true for one complete CLK cycle. |
| $\overline{\mathrm{CD}}$ | 3 | 1 | Carrier Detect (Channel A): Carrier Detect (Channel A) signals that the line transmission has started. The MPSC will begin to sample data on the $R \times D_{A}$ line if modem enables are selected. |
| $\overline{\mathrm{RxC}}{ }_{\text {B }}$ | 4 | 1 | Receiver Clock: The Receiver Clock (Channel B) clocks in data on the RxD ${ }^{\mathrm{B}}$ pin. |
| $\overline{\mathrm{CD}_{\mathrm{B}}}$ | 5 | 1 | Carrier Detect (Channel B): Carrier Detect (Channel B) signals that the line transmission has started. The MPSC will begin to sample data on the $R x D_{B}$ line if modem enables are selected. |
| $\overline{\text { CTS }}$ | 6 | 1 | Clear To Send (Channel B): Clear To Send (Channel B) signals that the modem is ready to accept data from the MPSC. Clear To Send will enable Channel B transmitter if modem enables are selected, otherwise this pin may be used as a general purpose input. |
| $\overline{T x C_{B}}$ | 7 | 1 | Transmit Clock (Channel B): Transmit Clock (Channel B) for $\mathrm{TxD}_{\mathrm{s}}$ pin. |
| TxD ${ }_{\text {B }}$ | 8 | 0 | Transmit Data (Channel B): This line transmits the serial data to the communications channel (Channel B). |
| R×D ${ }_{\text {B }}$ | 9 | 1 | Receive Data (Channel B): This line receives serial data from the communications channel (Channel B). |
| $\overline{\overline{\text { SYNDET }_{\mathrm{B}} /}}$ | 10 | I/O | Synchronous Detection (Channel <br> B): This pin is used in byte synchronous mode as either an internal sync detect (output) or as a means to force external synchronization (input). In SDLC mode, this pin is an output indicating Flag detection. In asynchronous mode it is a general purpose input (Channel B). Request To Send (Channel B) is a general purpose output, generally used to signal that Channel B is ready to send data. |


| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $R_{D} Y_{B}$ $\mathrm{TxDRQ}_{\mathrm{A}}$ | 11 | 0 | Ready Transmit Data: In mode 0 this pin is used to synchronize data transfers for both Receive and Transmit of Channel B to the controlling processor's READY line (open collector). In modes 1 and 2 this pin requests a DMA transfer of data for a transmit operation (Channel A). |
| DB7 | 12 | 1/0 | Data Bus: The Data Bus lines are bi-directional three state lines which interface with the system's Data Bus. |
| DB6 | 13 |  |  |
| DB5 | 14 |  |  |
| DB4 | 15 |  |  |
| DB3 | 16 |  |  |
| DB2 | 17 |  |  |
| DB1 | 18 |  |  |
| DB0 | 19 |  |  |
| GND | 20 |  | Ground. |
| $\mathrm{V}_{\mathrm{cc}}$ | 40 |  | Power: +5V Supply. |
| $\overline{\mathrm{CTS}_{A}}$ | 39 | I | Clear To Send (Channel A): This signals that the modem is ready to accept data from the MPSC. Clear To Send will enable Channel A transmitter if modem enables are selected, otherwise this pin may be used as a general purpose input. |
| $\overline{\mathrm{RTS}_{\boldsymbol{A}}}$ | 38 | 0 | Request To Send (Channel A): Request To Send (Channel $A$ ) is a general purpose output generally used to signal that Channel $A$ is ready to send data. |
| TxD ${ }_{\text {A }}$ | 37 | 0 | Transmit Data (Channel A): This line transmits the serial data to the communications channel (Channel A). |
| $\overline{T x C A}$ | 36 | 1 | Transmitter Clock (Channel A): <br> The transmitter clock (Channel A) clocks out data on the $\mathrm{TxD}_{\mathrm{A}}$ pin. |
| $\overline{\mathrm{RxC}} \mathrm{A}$ | 35 | I | Receiver Clock (Channel A): The receiver clock (Channel A) clocks in data on the $\mathrm{RxD}_{\mathrm{A}}$ pin. |
| $\mathrm{RxD} \mathrm{A}_{\text {a }}$ | 34 | I | Receive Data (Channel A): This line receives serial data from the communications channel (Channel A). |
| $\overline{\text { SYNDET }_{\text {A }}}$ | 33 | 1/0 | Synchronous Detection (Channel <br> A): This pin is used in byte synchronous mode as either an internal sync detect (output) or as a means to force external synchronization (input). In SDLC mode, this pin is an output indicating flag detection. In asynchronous mode it is a general purpose input (Channel A). |

Table 1. Pin Description (Continued)

| Symbol | $\begin{array}{\|l\|} \hline \text { Pin } \\ \text { No. } \\ \hline \end{array}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| RDY ${ }^{\prime}$ $\mathrm{RxDRQ}_{A}$ | 32 | 0 | Ready: In mode 0 this pin is used to synchronize data transfers for both receive and transmit of Channel A to the controlling processor's READY line (open collector). In modes 1 and 2 RxDRQ $_{A}$ requests a DMA transfer of data for a receive operation for Channel A. |
| $\mathrm{DTR}_{\text {A }}$ | 31 | 0 | Data Terminal Ready: This pin is Data Terminal Ready (Channel A) which is a general purpose output. |
| $\begin{aligned} & \overline{\mathrm{POO}} \\ & \mathrm{TXDRQ}_{\mathrm{B}} \end{aligned}$ | 30 | 0 | Interrupt Priority Out: In modes 0 and 1, IPO is Interrupt Priority Out. It is used to establish a hardware interrupt priority scheme with IPI. It is low only if IPI is low and the controlling processor is not servicing an interrupt from this MPSC. In mode $2, \mathrm{TXDRQ}_{\mathrm{B}}$ requests a DMA transfer of data for a transmit operation for Channel B. |
| $\overline{\mathrm{PI} /}$ $\mathrm{RxDRQ}_{\mathrm{B}}$ | 29 | 1/0 | Interrupt Priority In: In modes 0 and 1, IPI is Interrupt Priority In. A low on IPI means that no higher priority device is being serviced by the controlling processor's interrupt service routine. In mode 2, $\mathrm{RxDRQ}_{\mathrm{B}}$ requests a DMA transfer of data for a receive operation for Channel B. |

## GENERAL DESCRIPTION

The Inte ${ }^{\circledR} 8274$ Multi-Protocol Serial Controller is a microcomputer peripheral device which supports Asynchronous (Start/Stop), Byte Synchronous (Monosync, IBM Bisync), and Bit Synchronous (ISO's HDLC, IBM's SDLC) protocols. This controller's flexible architecture allows easy implementation of many variations of these three protocols with low software and hardware overhead.

The Multi-Protocol Serial Controller (MPSC) implements two independent serial receiver/transmitter channels.

The MPSC supports several microprocessor interface options; Polled, Wait, Interrupt driven and DMA driven. The MPSC is designed to support Intel's ${ }^{\circledR}$ MCS-85 and iAPX 86, 88 families.

This data sheet will describe the serial protocol functions, the microprocessor interface, a detailed register and command description, general system operations, specifications, and waveforms.

| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { INT }}$ | 28 | 0 | Interrupt: The interrupt signal indicates that the highest priority internal interrupt requires service (open collector). Priority can be resolved via an external interrupt controller or a daisy-chain scheme. |
| $\overline{\text { INTA }}$ | 27 | 1 | Interrupt Acknowledge: This Interrupt Acknowledge allows the highest priority interrupting device to generate an interrupt vector. |
| $\overline{\mathrm{DTR}_{B}}$ | 26 | 0 | Data Terminal Ready (Channel B): <br> This is a general purpose output. |
| $\mathrm{A}_{0}$ | 25 | 1 | Address: This line selects Channel $A$ or $B$ during data or command transfers. A low selects Channel A. |
| $\mathrm{A}_{1}$ | 24 | 1 | Address: This line selects between data or command information transfer. A low means data. |
| $\overline{\mathrm{CS}}$ | 23 | 1 | Chip Select: Chip Select enables RD or WR. |
| $\overline{\mathrm{RD}}$ | 22 | 1 | Read: Read controls a data byte or status byte transfer from the MPSC to CPU. |
| $\overline{W R}$ | 21 | 1 | Write: Write controls transfer of data or commands to the MPSC. |

## FUNCTIONAL DESCRIPTION

This section of the data sheet describes how the Asynchronous and Synchronous protocols are implemented in the MPSC. It describes general considerations, transmit operation, and receive operation for Asynchronous, Byte Synchronous, and Bit Synchronous protocols.

## ASYNCHRONOUS OPERATIONS

## General

For operation in the asynchronous mode, the MPSC must be initialized with the following information: character length (WR3; D7, D6 and WR5; D6, D5), clock rate (WR4; D7, D6), number of stop bits (WR4; D3, D2), odd, even or no parity (WR4; D1, D0), interrupt mode (WR1, WR2), and receiver (WR3; D0) or transmitter (WR5; D3) enable. When loading these parameters into the MPSC, WR4 information must
be written before the WR1, WR3, WR5 parameters/ commands. (See Detailed Command Description Section).

For transmission via a modem or RS232C interface, the Request To Send (RTS) (WR5; D1) and Data Terminal Ready (DTR) (WR5; D7) bits must be set along with the Transmit Enable bit (WR5; D3). Setting the Auto Enables (WR3; D5) bit allows the programmer to send the first character of the message without waiting for a clear to send (CTS).

Both the Framing Error and Receive Overrun Error flags are latched and cause an interrupt, i.e., if status affects vector (WR1B; D2) is selected, the interrupt vector indicates a special Receive condition.

If the External/Status Interrupt bit (WR1; D0) is enabled, Break Detect (RR0; D7) and Carrier Detect (RRO; D3) will cause an interrupt. Reset External/ Status Interrupts (WRO; D5, D4, D3) will clear Break Detect and Carrier Detect bits if they are set.

A status read after a data read will include error status for the next word in the buffer. If the Interrupt on First Character (WR1; D4, D3) is selected, then data and error status are held until an Error Reset command (WRO; D5, D4, D3) is given.

If the Interrupt on Every Character Mode bit (WR1; D4, D3) is selected, the interrupt vector is different if there is an error status in RR1. When the character is read, the error status bit is set and the Special Receive Condition vector is returned if Status Affects vector (WR1B; D2) is selected.

In a polled environment, the Receive Character Available bit (RRO; DO) must be monitored so that the CPU can determine when data is available. The bit is reset automatically when the data is read.

If the X 1 clock mode is selected, the bit synchronization must be accomplished externally.

## Transmit

The transmit function begins when the Transmit Enable bit (WR5; D3) is set. The MPSC automatically adds the start bit, the programmed parity bit (odd, even or no parity) and the programmed number of stop bits ( $1,1.5$ or 2 bits) to the data character being transmitted.

The Serial data is shifted out from the Transmit Data (TxD) output on the falling edge of the Transmit Clock ( TxC ) input, at a rate programmable to $1,1 / 16$, $1 / 32$ nd, or $1 / 64$ th of the clock rate supplied to the TXC input.

The TxD output is held high when the transmitter has no data to send, unless, under program control, the Send Break (WR5; D4) command is issued to hold the TxD low.

If the External/STATUS Interrupt bit (WR1; D0) is set, the status of CD, CTS and SYNDET are monitored, and, if any changes occur for a period of time greater than the minimum specified pulse width, an interrupt is generated. CTS is usually monitored using this interrupt feature.

If the Auto Enables (WR; D5) option is selected the programmer need not wait for the CTS before sending the first character. The MPSC will automatically wait for the CTS pin to go active before the transmission begins.

The Transmit Buffer Empty bit (RRO; D2) is set by the MPSC when the data byte from the buffer is loaded in the transmit shift register. The data is written to the MPSC only when the Tx buffer becomes empty to prevent overwriting.

Asynchronous Mode Register Setup

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WR3 | 00 R× 5 b/char 01 Rx 7 b/char $10 \mathrm{Rx} 6 \mathrm{~b} / \mathrm{char}$ 11 Rx $8 \mathrm{~b} / \mathrm{char}$ |  | $\begin{gathered} \text { AUTO } \\ \text { ENABLES } \end{gathered}$ | 0 | 0 | 0 | 0 | $\begin{gathered} \text { Rx } \\ \text { ENABLE } \end{gathered}$ |
| WR4 | $00 \times 1$ Clock <br> 01 X16 Clock <br> $10 \times 32$ Clock <br> 11 X64 Clock |  | 0 | 0 | $\begin{aligned} & 00 \text { ENABLE SYNC } \\ & \text { MODES } \\ & 01 \text { 1STOP BIT } \\ & 1011 / 2 \text { STOP BITS } \\ & 112 \text { STOP BITS } \end{aligned}$ |  | $\begin{aligned} & \text { EVEN/ } \\ & \overline{\text { ODD }} \\ & \text { PRRITY } \end{aligned}$ | PARITY ENABLE |
| WR5 | DTR | $\begin{aligned} & 00 \\ & 01 \\ & 10 \\ & 11 \end{aligned}$ | b/char b/char b/char b/char | $\begin{aligned} & \text { SEND } \\ & \text { BREAK } \end{aligned}$ | $\begin{gathered} \mathrm{TX} \\ \text { ENABLE } \end{gathered}$ | 0 | RTS | 0 |

## Receive

The receive function begins when the Receive Enable (WR3; D0) bit is set. If the Auto Enables (WR3; D5) option is selected, then Carrier Detect (CD) must also be low. A valid start bit is detected if a low persists for at least $1 / 2$ bit time on the Receive Data ( RxD ) input.

The data is sampled at mid-bit time, on the rising edge of RxC, until the entire character is assembled. The receiver inserts 1's when a character is less than 8 bits. If parity (WR4; D1, D0) is enabled and the character is less than 8 bits the parity bit is not stripped from the character.

The receiver also stores error status for each of the 3 data characters in the data buffer. When a parity error is detected, the parity error flag (RR1; D4) is set and remains set until it is reset by the Error Reset command (WR0; D5, D4, D3).

When a character is assembled without a stop bit being detected, the Framing Error bit (RR1; D6) is set. The detection of a Framing Error adds an additional $1 / 2$ bit time to the character time so the Framing Error is not interpreted as a new start bit.

If the CPU fails to read a data character while more than three characters have been received, the Re ceive Overrun bit (RR1; D5) is set. Only the overwritten character is flagged with the Receive Overrun bit. When this occurs, the fourth character assembled replaces the third character in the receive buffers. The Receive Overrun bit (RR1; D5) is reset by the Error Reset command (WR0; D5, D4, D3).

## SYNCHRONOUS OPERATIONMONO SYNC, BI SYNC

## General

The MPSC must be initialized with the following parameters: odd or even parity (WR4; D1,D0), X1 clock mode (WR4; D7, D6), 8- or 16-bit sync character (WR4; D5, D4), CRC polynomial (WR5; D2), Transmitter Enable (WR5; D3), interrupt modes (WR1, WR2), transmit character length (WR5; D6, D5) and receive character length (WR3; D7, D6). WR4 parameters must be written before WR1, WR3, WR5, WR6 and WR7.

The data is transmitted on the falling edge of the Transmit Clock, (TxC) and is received on the rising edge of Receive Clock (RxC). The X1 clock is used for both transmit and receive operations for all three sync modes: Mono, Bi and External.

## Transmit Set-Up—Monosync, Bisync

Transmit data is held high after channel reset, or if the transmitter is not enabled. A break may be programmed to generate a spacing line that begins as soon as the Send Break (WR5; D4) bit is set. With the transmitter fully initialized and enabled, the default condition is continuous transmission of the 8 - or 16 -bit sync character.

Using interrupts for data transfer requires that the Transmit Interupt/DMA Enable bit (WR1; D1) be set. An interrupt is generated each time the transmit buffer becomes empty. The interrupt can be satisfied

Synchronous Mode Register Setup-Monosync, Bisync

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WR3 | 00 Rx 5 b/char 01 Rx 7 b/char 10 Rx 6 b/char 11 Rx 8 b/char |  | AUTO <br> ENABLES | ENTER HUNT MODE | Rx CRC ENABLE | 0 | SYNC <br> CHAR <br> LOAD <br> INHIBIT | Rx ENABLE |
| WR4 | 0 | 0 | 008 bit Sync 0116 bit Sync <br> 11 Ext Sync |  | 0 | 0 | $\begin{aligned} & \text { EVEN/ } \\ & \text { PDDD } \end{aligned}$ | PARITY <br> ENABLE |
| WR5 | DTR |  | $5 \mathrm{~b} / \mathrm{char}$ <br> 7 b/char <br> 6 b/char <br> $8 \mathrm{~b} / \mathrm{char}$ | SEND <br> BREAK | Tx ENABLE | $\begin{gathered} { }^{1} \\ \text { (SELECTS } \\ \text { CRC-16) } \end{gathered}$ | RTS | Tx CRC ENABLE |

either by writing another character into the transmitter or by resetting the Transmitter Interrupt/DMA Pending latch with a Reset Transmitter Interrupt/ DMA Pending Command (WR0; D5, D4, D3). If nothing more is written into the transmitter, there can be no further Transmit Buffer Empty interrupt, but this situation does cause a Transmit Underrun condition (RR0; D6).

Data Transfers using the RDY signal are for software controlled data transfers such as block moves. $\overline{\text { RDY }}$ tells the CPU that the MPSC is not ready to accept/ provide data and that the CPU must extend the output/input cycle. DMA data transfers use the TxDRQ A/B signals which indicate that the transmit buffer is empty, and that the MPSC is ready to accept the next data character. If the data character is not loaded into the MPSC by the time the transmit shift register is empty, the MPSC enters the Transmit Underrun condition.

The MPSC has two programmable options for solving the transmit underrun condition: it can insert sync characters, or it can send the CRC characters generated so far, followed by sync characters. Following a chip or channel reset, the Transmit Underrun/EOM status bit (RRO; D6) is in a set condition allowing the insertion of sync characters when there is no data to send. The CRC is not calculated on these automatically inserted sync characters. When the CPU detects the end of message, a Reset Transmit Underrun/EOM command can be issued. This allows CRC to be sent when the transmitter has no data to send.

In the case of sync insertion, an interrupt is generated only after the first automatically inserted sync character has been loaded in Transmit Shift Register. The status indicates the Transmit Underrun/ EOM bit and the Transmit Buffer Empty bit are set.

In the case of CRC insertion, the Transmit Underrun/EOM bit is set and the Transmit Buffer Empty bit is reset while CRC is being sent. When CRC has been completely sent, the Transmit Buffer Empty status bit is set and an interrupt is generated to indicate to the CPU that another message can begin (this interrupt occurs because CRC has been sent and sync has been loaded into the Tx Shift Register). If no more messages are to be sent, the program can terminate transmission by resetting RTS, and disabling the transmitter (WR5; D3).

Bisync CRC Generation. Setting the Transmit CRC enable bit (WR5; D0) indicates CRC accumulation when the program sends the first data character to
the MPSC. Although the MPSC automatically transmits up to two sync characters (16 bit sync), it is wise to send a few more sync characters ahead of the message (before enabling Transmit CRC) to ensure synchronization at the receiving end.

The Transmit CRC Enable bit can be changed on the fly any time in the message to include or exclude a particular data character from CRC accumulation. The Transmit CRC Enable bit should be in the desired state when the data character is loaded from the transmit shift register. To ensure this bit in the proper state, the Transmit CRC Enable bit must be issued before sending the data character to the MPSC.

Transmit Transparent Mode. Transparent mode (Bisync protocol) operation is made possible by the ability to change Transmit CRC Enable on the fly and by the additional capability of inserting 16 bit sync characters. Exclusion of DLE characters from CRC calculation can be achieved by disabling CRC calculation immediately preceding the DLE character transfer to the MPSC.

In the transmit mode, the transmitter always sends the programmed number of sync bits (8 or 16) (WR4; D5, D4). When in the Monosync mode, the transmitter sends from WR6 and the receiver compares against WR7. One of two CRC polynomials, CRC 16 or SDLC, may be used with synchronous modes. In the transmit initialization process, the CRC generator is initialized by setting the Reset Transmit CRC Generator command (WR0; D7, D6).

The External/Status interrupt (WR1; D0) mode can be used to monitor the status of the CTS input as well as the Transmit Underrun/EOM latch. Optionally, the Auto Enable (WR3; D5) feature can be used to enable the transmitter when CTS is active. The first data transfer to the MPSC can begin when the External/Status interrupt occurs (CTS (RR0; D5) status bit set) following the Transmit Enable command (WR5; D3).

## Receive

After a channel reset, the receiver is in the Hunt phase, during which the MPSC looks for character synchronization. The Hunt begins only when the receiver is enabled and data transfer begins only when character synchronization has been achieved. If character synchronization is lost, the hunt phase can be re-entered by writing the Enter Hunt Phase (WR3; D4) bit. The assembly of received data continues until the MPSC is reset or until the receiver is
disabled (by command or by $\overline{\mathrm{CD}}$ while in the Auto Enables mode) or until the CPU sets the Enter Hunt Phase bit. Under program control, all the leading sync characters of the message can be inhibited from loading the receive buffers by setting the Sync Character Load Inhibit (WR3; D1) bit. After character synchronization is achieved the assembled characters are transferred to the receive data FIFO.

Data may be transferred with or without interrupts. Transferring data without interrupts is used for a purely polled operation or for off-line conditions. There are three interrupt modes available for data transfer: Interrupt on First Character Only, Interrupt on Every Character, and Special Receive Conditions Interrupt.

Interrupt on First Character Only mode is normally used to start a polling loop, a block transfer sequence using RDY to synchronize the CPU to the incoming data rate or a DMA transfer using the RxDRQ signal. The MPSC interrupts on the first character and thereafter only interrupts after a Special Receive Condition is detected. This mode can be reinitialized using the Enable Interrupt On Next Receive Character (WR0; D5, D4, D3) command which allows the next character received to generate an interrupt. Parity Errors do not cause interrupts, but End of Frame (SDLC operation) and Receive Overrun do cause interrupts in this mode. If the external status interrupts (WR1; D0) are enabled an interrupt may be generated any time the $\overline{C D}$ changes state.

Interrupt On Every Character mode generates an interrupt whenever a character enters the receive buffer. Errors and Special Receive Conditions generate a special vector if the Status Affects Vector (WR1B; D2) is selected. Also the Parity Error may be
programmed (WR1; D4, D3) not to generate the special vector while in the Interrupt On Every Character mode.

The Special Receive Condition interrupt can only occur while in the Receive Interrupt On First Character Only or the Interrupt On Every Receive Character modes. The Special Receive Condition interrupt is caused by the Receive Overrun (RR1; D5) error condition. The error status reflects an error in the current word in the receive buffer, in addition to any Parity or Overrun errors since the last Error Reset (WR0; D5, D4, D3). The Receive Overrun and Parity error status bits are latched and can only be reset by the Error Reset (WR0; D5, D4, D3) command.

## SYNCHRONOUS OPERATION-SDLC

## General

Like the other synchronous operations the SDLC mode must be initialized with the following parameters: SDLC mode (WR4; D5, D4), SDLC polynomial (WR5; D2), Request to Send, Data Terminal Ready, transmit character length (WR5; D6, D5), interrupt modes (WR1; WR2), Transmit Enable (WR5; D3), Receive Enable (WR3; D0), Auto Enable (WR3; D5) and External/Status Interrupt (WR1; D0).WR4 parameters must be written before WR1, WR3, WR5, WR6 and WR7.

The Interrupt modes for SDLC operation are similar to those discussed previously in the synchronous operations section.

Synchronous Mode Register Setup-SDLC/HDLC

|  | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WR3 | 00 Rx 5b/char 01 Rx 7b/char $10 \mathrm{Rx} 6 \mathrm{~b} / \mathrm{char}$ 11 Rx 8b/char |  | AUTO ENABLES | ENTER HUNT mode | $\begin{gathered} \mathrm{Rx} \\ \mathrm{CRC} \\ \text { ENABLE } \end{gathered}$ | ADDRESS SEARCH MODE | 0 | $\begin{gathered} \mathrm{RX} \\ \text { ENABLE } \end{gathered}$ |
| WR4 | 0 | 0 | $\begin{array}{cc} 1 & 0 \\ \text { (SELECTS SDLC/ } \end{array}$HDLC MODE) |  | 0 | 0 | 0 | 0 |
| WR5 | DTR | $00 \mathrm{Tx} \leqslant 5 \mathrm{~b} /$ char 01 Tx 7b/char 10 Tx 6b/char 11 Tx 8b/char |  | 0 | $\begin{gathered} \mathrm{Tx} \\ \text { ENABLE } \end{gathered}$ | $\begin{gathered} 0 \\ \text { (SELECTS } \\ \text { SDLC/ } \\ \text { HDLC } \\ \text { CRC) } \\ \hline \end{gathered}$ | RTS | $\begin{gathered} \text { Tx } \\ \text { CRC } \\ \text { ENABLE } \end{gathered}$ |

## Transmit

After a channel reset, the MPSC begins sending SDLC flags.

Following the flags in an SDLC operation the 8-bit address field, control field and information field may be sent to the MPSC by the microprocessor. The MPSC transmits the Frame Check Sequence using the Transmit Underrun feature. The MPSC automatically inserts a zero after every sequence of 5 consecutive 1's except when transmitting Flags or Aborts.

SDLC—like protocols do not have provision for fill characters within a message. The MPSC therefore automatically terminates an SDLC frame when the transmit data buffer and output shift register have no more bits to send. It does this by sending the two bytes of CRC and then one or more flags. This allows very high-speed transmissions under DMA or CPU control without requiring the CPU to respond quickly to the end-of-message situation.

After a reset, the Transmit Underrun/EOM status bit is in the set state and prevents the insertion of CRC characters during the time there is no data to send. Flag characters are sent. The MPSC begins to send the frame when data is written into the transmit buffer. Between the time the first data byte is written, and the end of the message, the Reset Transmit Underrun/EOM (WR0; D5, D4, D1) command must be issued. The Transmit Underrun/EOM status bit (RR0; D6) is in the reset state at the end of the message which automatically sends the CRC characters.

The MPSC may be programmed to issue a send Abort command (WR0; D5, D4, D3). This command causes at least eight 1's but less than fourteen 1's to be sent before the line reverts to continuous flags.

## Receive

After initialization, the MPSC enters the Hunt phase, and remains in the Hunt phase until the first Flag is received. The MPSC never again enters the Hunt phase unless the microprocessor writes the Enter Hunt command.

The MPSC can be programmed to receive all frames or it can be programmed to the Address Search Mode. In the Address Search Mode, only frames with addresses that match the value in WR6 or the global address (OFFH) are received by the MPSC. Extended address recognition must be done by the microprocessor software.

The control and information fields are received as data.

SDLC/HDLC CRC calculation does not have an 8-bit delay, since all characters are included in the calculation, unlike Byte Synchronous Protocols.

Reception of an abort sequence ( 7 or more 1's) will cause the Break/Abort bit (RR0; D7) to be set and will cause an External/Status interrupt, if enabled. After the Reset External/Status Interrupts Command has been issued, a second interrupt will occur at the end of the abort sequence.

## MPSC

## Detailed Command Description

## GENERAL

The MPSC supports an extremely flexible set of serial and system interface modes.

The system interface to the CPU consists of 8 ports or buffers:

| $\overline{\mathbf{C S}}$ | $\mathbf{A}_{1}$ | $\mathbf{A}_{\mathbf{0}}$ | Read Operation | Write Operation |
| :---: | :---: | :---: | :--- | :--- |
| 0 | 0 | 0 | Ch. A Data Read | Ch. A Data Write |
| 0 | 1 | 0 | Ch. A Status Read | Ch. A Command/Parameter |
| 0 | 0 | 1 | Ch. B Data Read | Ch. B Data Write |
| 0 | 1 | 1 | Ch. B Status Read | Ch. B Command/Parameter |
| 1 | $x$ | $x$ | High Impedence | High Impedence |

Data buffers are addressed by $\mathrm{A}_{1}=0$, and Command ports are addressed by $A_{1}=1$.

Command, parameter, and status information is held in 22 registers within the MPSC ( 8 write registers and 3 read registers for each channel). They are all accessed via the command ports.

An internal pointer register selects which of the command or status registers will be read or written during a command/status access of an MPSC channel.


Figure 3. Command/Status Register Architecture (each serial channel)

After reset, the contents of the pointer register are zero. The first write to a command register causes the data to be loaded into Write Register 0 (WRO). The three least significant bits of WR0 are loaded
into the Command/Status Pointer. The next read or write operation accesses the read or write register selected by the pointer. The pointer is reset after the read or write operation is completed.

## COMMAND/STATUS DESCRIPTION

The following command and status bytes are used during initialization and execution phases of operation. All Command/Status operations on the two channels are identical, and independent, except where noted.

Write Register 0 (WRO):


## Detailed Register Description

## WRO

D2, D1, D0-Command/Status Register Pointer bits determine which write-register the next byte is to be written into, or which read-register the next byte is to be read from. After reset, the first byte written into either channel goes into WRO. Following a read or write to any register (except WRO) the pointer will point to WRO.

D5, D4, D3-Command bits determine which of the basic seven commands are to be performed.

Command 0 Null-has no effect.
Command 1 Send Abort-causes the generation of eight to thirteen 1's when in the SDLC mode.

Command 2 Reset External/Status Interruptsresets the latched status bits of RR0 and re-enables them, allowing interrupts to occur again.

Command 3 Channel Reset-resets the Latched Status bits of RRO, the interrupt prioritization logic and all control registers for the channel. Four extra system clock cycles should be allowed for MPSC reset time before any additional commands or controls are written into the channel.

Command 4 Enable Interrupt on Next Receive Character-if the Interrupt on First Receive Character mode is selected, this command reactivates that mode after each complete message is received to prepare the MPSC for the next message.

Command 5 Reset Transmitter Interrupt/DMA Pending-if The Transmit Interrupt/DMA Enable mode is selected, the MPSC automatically interrupts or requests DMA data transfer when the transmit buffer becomes empty. When there are no more characters to be sent, issuing this command prevents further transmitter interrupts or DMA requests until the next character has been completely sent.

Command 6 Error Reset-error latches, Parity and Overrun errors in RR1 are reset.

Command 7 End of Interrupt-resets the interrupt-in-service latch of the highest-priority internal device under service.

D7, D6
00
01

CRC Reset Code
Null-has no effect.
Reset Receive CRC Checkerresets the CRC checker to 0's. If in SDLC mode the CRC checker is initialized to all 1's.

Reset Transmit CRC Generator -resets the CRC generator to 0 's. If in SDLC mode the CRC generator's initialized to all 1's.

Reset Tx Underrun/End of Message Latch.

## Write Register 1 (WR1):



DO External/Status Interrupt Enable -allows interrupt to occur as the result of transitions on the $\overline{\mathrm{CD}}$, CTS or SYNDET inputs. Also allows interrupts as the result of a Break/Abort detection and termination, or at the beginning of CRC, or sync character transmission when the Transmit Underrun/EOM latch becomes set.

Transmitter Interrupt/DMA Enable -allows the MPSC to interrupt or request a DMA transfer when the transmitter buffer becomes empty.

Status Affects vector-(WR1, D2 active in channel B only.) If this bit is not set, then the fixed vector, programmed in WR2, is returned from an interrupt acknowledge sequence. If the bit is set then the vector returned from an interrupt acknowledge is variable as shown in the Interrupt Vector Table.

Receive Interrupt Mode
Receive Interrupts/DMA Disabled
Receive Interrupt on First Character Only or Special Condition
Interrupt on All Receive Characters or Special Condition (Parity Error is a Special Receive Condition)

Interrupt on All Receive Characters or Special Condition (Parity Error is not a Special Receive Condition).
Wait on Receive/Transmit-when the following conditions are met the RDY pin is activated, otherwise it is held in the High-Z state. (Conditions: Interrupt Enabled Mode, Wait Enabled, $\overline{C S}=0$, $\mathrm{A} 0=0 / 1$, and $\mathrm{A} 1=0$ ). The RDY pin is pulled low when the transmitter buffer is full or the receiver buffer is empty and it is driven High when the transmitter buffer is empty or the receiver buffer is full. The RDY $A$ and RDY $_{B}$ may be wired OR connected since only one signal is active at any one time while the other is in the High Z state.
Must be Zero
Wait Enable-enables the wait function.

WR2

| D1, D0 | System Configuration-These <br> specify the data transfer from <br> MPSC channels to the CPU, either <br> interrupt or DMA based. |  |
| :---: | :---: | :---: |
| 0 | 0 | Channel A and Channel B both use <br> interrupts |
| 0 | 1 | Channel A uses DMA, Channel B <br> uses interrupt |
| 1 | 0 | Channel A and Channel B both <br> use DMA |
| 1 | 1 | Illegal Code |
| D2Priority-this bit specifies the <br> relative priorities of the internal <br> MPSC interrupt/DMA sources. |  |  |
| 0 | (Highest) RxA, TxA, RxB, TxB <br> ExTA, ExTB (Lowest) |  |
| (Highest) RxA, RxB, TxA, TxB, |  |  |
| ExTA, ExTB (Lowest) |  |  |


| D5, D4, D3 | Interrupt Code-specifies the <br> behavior of the MPSC when it re- <br> ceives an interrupt acknowledge <br> sequence from the CPU. (See Inter- <br> rupt Vector Mode Table). |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 0 | $\times$ | $\times$ | Non-vectored interrupts-in- <br> tended for use with external DMA <br> CONTROLLER. The Data Bus re- <br> mains in a high impedence state <br> during INTA sequences. |
| 1 | 0 | 0 | 8085 Vector Mode 1-intended for <br> use as the primary MPSC in a daisy <br> chained priority structure. (See |
| 1 | 0 | 1 | System Interface section) <br> 8085 Vector Mode 2-intended for <br> use as any secondary MPSC in a <br> daisy chained priority structure. <br> (See System Interface section) |
| 1 | 1 | 0 | 8086/88 Vector Mode-intended <br> for use as either a primary or <br> secondary in a daisy chained <br> priority structure. (See System <br> Interface section) |
| Must be zero. |  |  |  |

D5, D4, D3 Interrupt Code-specifies the behavior of the MPSC when it receives an interrupt acknowledge sequence from the CPU. (See Interrupt Vector Mode Table).
-inCONTROLLER. The Data Bus remains in a high impedence state during INTA sequences.

8085 Vector Mode 1-intended for use as the primary MPSC in a daisy chained priority structure. (See System Inṭerface section)
8085 Vector Mode 2—intended for use as any secondary MPSC in a daisy chained priority structure. System interface section)

8086/88 Vector Mode—intended for use as either a primary or secondary in a daisy chained priority structure. (See System Interface section)
$\operatorname{Pin} 10=\overline{\operatorname{RTS}}_{B}$
Pin $10=$ SYNDET $_{B}$

Write Register 2 (WR2): Channel A


The following table describes the MPSC's response to an interrupt acknowledge sequence:

| D5 | D4 | D3 | $\overline{\text { IPI }}$ | MODE | INTA | Data Bus |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | X | X | X | Non-vectored | Any INTA | D7  <br> High Impedance D0 |  |  |  |  |
| 1 | 0 | 0 | 0 | 85 Mode 1 | 1st INTA <br> 2nd INTA <br> 3rd INTA | $\begin{array}{llll} 1 & 1 & 0 & 0 \\ \text { V7 } & \text { V6 } & \text { V5 } & \text { V4 } \\ 0 & 0 & 0 & 0 \end{array}$ | $\begin{aligned} & 1 \\ & \text { V3 }^{*} \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \mathrm{~V}^{*} \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & \text { V1 } \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & \text { Vo } \\ & 0 \end{aligned}$ |
| 1 | 0 | 0 | 1 | 85 Mode 1 | 1st INTA 2nd INTA 3rd INTA | High Impedance <br> High Impedance |  |  |  |  |
| 1 | 0 | 1 | 0 | 85 Mode 2 | 1st INTA <br> 2nd INTA <br> 3rd INTA | High Impedance    <br> V7 V6 V5 V4 <br> 0 0 0 0 | $\begin{aligned} & \text { V3* } \\ & 0 \end{aligned}$ |  | $\begin{aligned} & \text { V1 } \\ & 0 \end{aligned}$ | $\begin{aligned} & \text { Vo } \\ & 0 \end{aligned}$ |
| 1 | 0 | 1 | 1 | 85 Mode 2 | 1st INTA 2nd INTA 3rd INTA | High Impedance High Impedance High Impedance |  |  |  |  |
| 1 | 1 | 0 | 0 | 86 Mode | 1st INTA | High Impedance |  |  |  |  |
| 1 | 1 | 0 | 1 | 86 Mode | 1st INTA 2nd INTA | High Impedance High Impedance |  |  |  |  |

*These bits are variable if the "status affects vector" mode has been programmed, (WR1B, p.2).

Interrupt/DMA Mode, Pin Functions, and Priority

| Ch. A WR2 |  |  | Int/DMA Mode |  | $\begin{gathered} \operatorname{RDY}_{A} / \\ \operatorname{RxDRQ}_{\mathrm{A}} \\ \operatorname{Pin~} 32 \end{gathered}$ | Pin Functions |  |  | Priority |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | CH. A | CH. B |  | $\begin{gathered} \text { RDY }_{B} / \\ \text { TxDRQ }_{A} \\ \text { Pin } 11^{2} \end{gathered}$ | $\begin{gathered} \overline{I P \mid} / \\ \text { RxDRQ }_{\mathrm{B}} \\ \text { Pin } 29 \\ \hline \end{gathered}$ | $\begin{gathered} \overline{\mathrm{PPO} /} \\ \text { TxDRQ }_{\mathrm{B}} \\ \text { Pin } 30^{2} \\ \hline \end{gathered}$ | Highest <br> Lowest |
| 0 | 0 | 0 | INT | INT | $\mathrm{RDY}_{A}$ | $\mathrm{RDY}_{\mathrm{B}}$ | $\overline{\mathrm{P}}$ I | $\overline{\mathrm{PPO}}$ | RxA, TxA, RxB, TxB, EXT ${ }_{\text {A }}$, EXT $^{\text {a }}$ |
| 1 | 0 | 0 | INT | INT |  |  |  |  |  |
| 0 | 0 | 1 | DMA | INT | $R \times D R Q_{A}$ | $\mathrm{TxDRQ}_{\mathrm{A}}$ | $\overline{\|P\|}$ | $\overline{\mathrm{IPO}}$ | RxA, TxA (DMA) $\overline{\mathrm{RXA}}{ }^{\top}, \mathrm{RXB}, \overline{\mathrm{T}} \times \overline{\mathrm{B}}, \overline{E X T}_{\mathrm{A}}, \overline{\mathrm{EXT}_{B}} \overline{(\mathrm{INT})}$ |
| 1 | 0 | 1 | DMA | INT |  |  |  |  | RxA, TxA (DMA) $\overline{\mathrm{R} \times \mathrm{A}} \overline{\mathrm{A}}^{1}, \overline{\mathrm{R} \times \mathrm{B}}, \overline{\mathrm{T}} \times \overline{\mathrm{B}}, \overline{\mathrm{EXT}} \overline{\mathrm{T}}_{\mathbf{A}}, \overline{\mathrm{EXT}} \overline{\mathrm{B}}_{\mathrm{B}}(\mathrm{INT})$ |
| 0 | 1 | 0 | DMA | DMA | $R \times D R Q_{A}$ | $\mathrm{TXDRQ}_{\mathrm{A}}$ | ${ }^{R \times D R Q} Q_{B}$ | $\mathrm{TxDRQ}_{\mathrm{B}}$ | $R \times A, T \times A, R \times B, T \times B$ (DMA) $R \times A 1, R \times B=, E^{1} T_{A}, E X T_{B}(I N T)$ |
| 1 | 1 | 0 | DMA | DMA |  |  |  |  | R×A, RxB, TXA, TXB, (DMA) $R \times A^{1}$, RxB $^{1}$, EXT $_{A}$, EXT $_{B}$ (INT) |

[^30]Interrupt Vector Mode Table

| 8085 Modes 8086/88 Mode | $\begin{aligned} & v_{4} \\ & v_{2} \end{aligned}$ | $\begin{aligned} & \mathbf{v}_{3} \\ & \mathbf{v}_{1} \end{aligned}$ | $\begin{aligned} & v_{2} \\ & v_{0} \end{aligned}$ | Channel | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Note 1: Special <br> Receive Condition= <br> Parity Error, <br> Rx Overrun Error, <br> Framing Error, <br> End of Frame (SDLC) | 0 0 0 0 | 0 0 1 1 | $\begin{aligned} & \hline 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | B | Tx Buffer Empty Ext/Status Change Rx Char. Available Special Rx Condition (Note 1) |
|  | 1 1 1 1 | 0 0 1 1 | 0 1 0 1 | A | Tx Buffer Empty Ext/Status Change Rx Char. Available Special Rx Condition (Note 1) |

Write Register 2 (WR2): Channel B


## WR2 CHANNEL B

D7-D0 Interrupt vector-This register contains the value of the interrupt vector placed on the data bus during interrupt acknowledge sequences.

Write Register 3 (WR3):


WR3
Receiver Enable-A one enables the receiver to begin. This bit should be set only after the receiver has been initialized.

D1 Sync Character Load Inhibit-A one prevents the receiver from loading sync characters into the receive buffers.

D2 Address Search Mode—If the SDLC mode has been selected, the MPSC will receive all frames unless this bit is a 1. If this bit is a 1 , the MPSC will receive only frames with address bytes that match the global address (OFFH) or the value loaded into WR6. This bit must be zero in non-SDLC modes.

D3 Receive CRC Enable-A one in this bit enables (or re-enables) CRC calculation. CRC calculation starts with the last character placed in the Receiver FIFO. A zero in this bit disables, but does not reset, the Receiver CRC generator.

D4 Enter Hunt Phase-After initialization, the MPSC automatically enters the Hunt mode. If synchronization is lost, the Hunt phase can be re-entered by writing a one to this bit.

D5 Auto Enables-A one written to this bit causes $\overline{C D}$ to be automatic enable signal for the receiver and $\overline{\mathrm{CTS}}$ to be an automatic enable signal for the transmitter. A zero written to this bit limits the effect of $\overline{C D}$ and $\overline{\mathrm{CTS}}$ signals to setting/resetting their corresponding bits in the status register (RRO).

D7, D6 Receive Character length
00 Receive 5 Data bits/character

Receive 7 Data bits/character

10 Receive 6 Data bits/character

11
Receive 8 Data bits/character

Write Register 4 (WR4):


WR4
D0 Parity-a one in this bit causes a parity bit to be added to the programmed number of data bits per character for both the transmitted and received character. If the MPSC is programmed to receive 8 bits per character, the parity bit is not transferred to the microprocessor. With other receiver character lengths, the parity bit is transferred to the microprocessor.

D1 Even/Odd Parity-if parity is enabled, a one in this bit causes the MPSC to transmit and expect even parity, and a zero causes it to send and expect odd parity.

D3, D2 Stop bits/sync mode

00
Selects synchronous modes.
01 Async mode, 1 stop bit/character
10 Async mode, 1-1/2 stop bits/character
11 Async mode, 2 stop bits/character
D5, D4 Sync mode select
$0 \quad 0 \quad 8$ bit sync character
$\begin{array}{lll}0 & 16 \text { bit sync character }\end{array}$
10 SDLC mode (Flag sync)
11 External sync mode
D7, D6 Clock mode-selects the clock/data rate multiplier for both the receiver and the transmitter. 1x mode must be selected for synchronous modes. If the 1 x mode is selected, bit synchronization must be done externally.

0 O Clock rate $=$ Data rate $\times 1$
01 Clock rate $=$ Data rate $\times 16$
10 Clock rate $=$ Data rate $\times 32$
$1 \quad 1 \quad$ Clock rate $=$ Data rate $\times 64$

## Write Register 5 (WR5):



WR5
DO Transmit CRC Enable-a one in this bit enables the transmitter CRC generator. The CRC calculation is done when a character is moved from the transmit buffer into the shift register. A zero in this bit disables CRC calculations. If this bit is not set when a transmitter underrun occurs, the CRC will not be sent.

D1 Request to Send-a one in this bit forces the $\overline{\operatorname{RTS}}$ pin active (low) and zero in this bit forces the RTS pin inactive (high).

D2
CRC Select-a one in this bit selects the CRC -16 polynomial ( $\mathrm{X}^{16}+\mathrm{X}^{15}+\mathrm{X}^{2}+1$ ) and a zero in this bit selects the CCITT-CRC polynomial $\left(X^{16}+X^{12}+X^{5}+1\right)$.

D3 Transmitter Enable-a zero in this bit forces a marking state on the transmitter output. If this bit is set to zero during data or sync character transmission, the marking state is entered after the character has been sent. If this bit is set to zero during transmission of a CRC character, sync or flag bits are substituted for the remainder of the CRC bits.

D4 Send Break-a one in this bit forces the transmit data low. A zero in this bit allows normal transmitter operation.

D6, D5 Transmit Character length

00 Transmit 5 or less bits/character
01 Transmit 7 bits/character

10 Transmit 6 bits/character

11 Transmit 8 bits/character

Bits to be sent must be right justified least significant bit first, eg:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | B5 | B4 | B3 | B2 | B1 | B0 |

Five or less mode allows transmission of one to five bits per character. The microprocessor must format the data in the following way:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 1 | 1 | 1 | 0 | 0 | 0 | B0 | Sends one data bit |
| 1 | 1 | 1 | 0 | 0 | 0 | B1 | B0 | Sends two data bits |
| 1 | 1 | 0 | 0 | 0 | B2 | B1 | B0 | Sends three data bits |
| 1 | 0 | 0 | 0 | B3 | B2 | B1 | B0 | Sends four data bits |
| 0 | 0 | 0 | B4 | B3 | B2 | B1 | B0 | Sends five data bits |
| D7 |  | Data Terminal Ready-when set, this bit <br> forces the $\overline{\text { DTR pin active (low). When }}$ <br> reset, this bit forces the $\overline{\text { DTR pin inactive }}$ <br> (high). |  |  |  |  |  |  |

## Write Register 6 (WR6):



## WR6

D7-D0 Sync/Address-this register contains the transmit sync character in Monosync mode, the low order 8 sync bits in Bisync mode, or the Address byte in SDLC mode.

## Write Register 7 (WR7):



WR7
D7-D0 Sync/Flag-this register contains the receive sync character in Monosync mode, the high order 8 sync bits in Bisync mode, or the Flag character (01111110) in SDLC mode. WR7 is not used in External Sync mode.

Read Register $\mathbf{0}$ (RRO):


RRO
Receive Character Available-this bit is set when the receive FIFO contains data and is reset when the FIFO is empty.

D1 Interrupt Pending*-This Interrupt-Pending bit is reset when an EOI command is issued and there is no other interrupt request pending at that time.

Transmit Buffer Empty-This bit is set whenever the transmit buffer is empty except when CRC characters are being sent in a synchronous mode. This bit is reset when the transmit buffer is loaded. This bit is set after an MPSC reset.

D3
Carrier Detect-This bit contains the state of the CD pin at the time of the last change of any of the External/Status bits ( $\overline{C D}$, CTS, Sync/Hunt, Break/Abort, or Tx Underrun/EOM). Any change of state of the $\overline{C D}$ pin causes the CD bit to be latched and causes an External/Status interrupt. This bit indicates current state of the $\overline{C D}$ pin immediately following a Reset External/Status Interrupt command.
*In vector mode this bit is set at the falling edge of the second INTA in an INTA cycle for an internal interrupt request. In non-vector mode, this bit is set at the falling edge of RD input after pointer 2 is specified. This bit is always zero in Channel B.

Sync/Hunt-In asynchronous modes, the operation of this bit is similar to the CD status bit, except that Sync/Hunt shows the state of the SYNDET input. Any High-toLow transition on the SYNDET pin sets this bit, and causes an External/Status interrupt (if enabled). The Reset External/Status Interrupt command is issued to clear the interrupt. A Low-to-High transition clears this bit and sets the External/Status interrupt. When the External/Status interrupt is set by the change in state of any other input or condition, this bit shows the inverted state of the SYNDET pin at time of the change. This bit must be read immediately following a Reset External/Status Interrupt command to read the current state of the SYNDET input.

In the External Sync mode, the Sync/Hunt bit operates in a fashion similar to the Asynchronous mode, except the Enter Hunt Mode control bit enables the external sync detection logic. When the External Sync Mode and Enter Hunt Mode bits are set (for example, when the receiver is enabled following a reset), the SYNDET input must be held High by the external logic until external character synchronization is achieved. A High at the SYNDET input holds the Sync/Hunt status in the reset condition.

When external synchronization is achieved, SYNDET must be driven Low on the second rising edge of $\overline{\mathrm{RxC}}$ after the rising edge of $\overline{\mathrm{RxC}}$ on which the last bit of the sync character was received. In other words, after the sync pattern is detected, the external logic must wait for two full Receive Clock cycles to activate the $\overline{\mathrm{SYN}}$ $\overline{\text { DET input. Once SYNDET is forced Low, it }}$ is good practice to keep it Low until the CPU informs the external sync logic that synchronization has been lost or a new message is about to start. The High-to-Low transition of the SYNDET output sets the Sync/Hunt bit, which sets the External/ Status interrupt. The CPU must clear the interrupt by issuing the Reset External/ Status Interrupt Command.

When the SYNDET input goes High again, another External/Status interrupt is generated that must also be cleared. The Enter Hunt Mode control bit isset whenever character synchronization is lost or the end of message is detected. In this case, the MPSC again looks for a High-to-Low transition on the SYNDET input and the operation repeats as explained previously. This implies the CPU should also inform the external logic that character synchronization has been lost and that the MPSC is waiting for SYNDET to become active.

In the Monosync and Bisync Receive modes, the Sync/Hunt status bit is initially set to 1 by the Enter Hunt Mode bit. The Sync/Hunt bit is reset when the MPSC establishes character synchronization. The High-to-Low transition of the Sync/Hunt bit causes an External/Status interrupt that must be cleared by the CPU issuing the Reset External/Status Interupt command. This enables the MPSC to detect the next transition of other External/Status bits.

When the CPU detects the end of message or that character synchronization is lost, it sets the Enter Hunt Mode control bit, which sets the Sync/Hunt bit to 1. The Low-toHigh transition of the Sync/Hunt bit sets the External/Status Interrupt, which must also be cleared by the Reset External/Status Interrupt Command. Note that the SYNDET pin acts as an output in this mode, and goes low every time a sync pattern is detected in the data stream.

In the SDLC mode, the Sync/Hunt bit is initially set by the Enter Hunt mode bit, or when the receiver is disabled. In any case, it is reset to 0 when the opening flag of $t$ he first frame is detected by the MPSC. The External/Status interrupt is also generated, and should be handled as discussed previously.

Unlike the Monosync and Bisync modes, once the Sync/Hunt bit is reset in the SDLC mode, it does not need to be set when the end of message is detected. The MPSC automatically maintains synchronization. The only way the Sync/Hunt bit can be set again is by the Enter Hunt Mode bit, or by disabling the receiver.

Clear to Send-this bit contains the inverted state of the $\overline{\mathrm{CTS}}$ pin at the time of the last change of any of the External/Status bits (CD, CTS, Sync/Hunt, Break/Abort, or Tx Underrun/EOM). Any change of state of the $\overline{C T S}$ pin causes the CTS bit to be latched and causes an External/Status interrupt. This bit indicates the inverse of the current state of the CTS pin immediately following a Reset External/ Status Interrupt command.

Break/Abort—in the Asynchronous Receive mode, this bit is set when a Break sequence (null character plus framing error) is detected in the data stream. The External/Status interrupt, if enabled, is set when break is detected. The interrupt service routine must issue the Reset External/Status Interrupt command (WRO, Command 2) to the break detection logic so the Break sequence termination can be recognized.

SDLC Residue Code Table (I Field Bits in 2 Previous Bytes)

|  |  |  | 8 bits/char |  | 7 bits/char |  | 6 bits/char |  | 5 bits/char |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Previous Byte | 2nd Prev. Byte | Previous Byte | 2nd Prev. Byte | Previous Byte | 2nd Prev. Byte | Previous Byte | 2nd Prev. Byte |
| 1 | 0 | 0 | 0 | 3 | 0 | 2 | 0 | 1 | 0 | 5 |
| 0 | 1 | 0 | 0 | 4 | 0 | 3 | 0 | 2 | 0 | 1 |
| 1 | 1 | 0 | 0 | 5 | 0 | 4 | 0 | 3 | 0 | 2 |
| 0 | 0 | 1 | 0 | 6 | 0 | 5 | 0 | 4 | 0 | 3 |
| 1 | 0 | 1 | 0 | 7 | 0 | 6 | 0 | 5 | - | - |
| 0 | 1 | 1 | 0 | 8 | 0 | - | - | - | - | - |
| 1 | 1 | 1 | 1 | 8 | - | - | - | - | - | - |
| 0 | 0 | 0 | 2 | 8 | 1 | 7 | 0 | 6 | 0 | 4 |

The Break/Abort bit is reset when the termination of the Break sequence is detected in the incoming data stream. The termination of the Break sequence also causes the External/Status interrupt to be set. The Reset External/Status Interrupt command must be issued to enable the break detection logic to look for the next Break sequence. A single extraneous null character is present in the receiver after the termination of a break; it should be read and discarded.

In the SDLC Receive mode, this status bit is set by the detection of an Abort sequence (seven or more 1's). The External/Status interrupt is handled the same way as in the case of a Break. The Break/Abort bit is not used in the Synchronous Receive mode.

All sent-this bit is set when all characters have been sent, in asynchronous modes. It is reset when characters are in the transmitter, in asynchronous modes. In synchronous modes, this bit is always set.

D3, D2, D1 Residue Codes-bit synchronous protocols allow 1 -fields that are not an integral number of characters. Since transfers from the MPSC to the CPU are character oriented, the residue codes provide the capability of receiving leftover bits. Residue bits are right justified in the last two data bytes received.

D4 Parity Error-If parity is enabled, this bit is set for received characters whose parity does not match the programmed sense (Even/Odd). This bit is latched. Once an error occurs, it remains set until the Error Reset command is written.

Read Register 1 (RR1): (Special Receive Condition Mode)


Receive Overrun Error-this bit indicates that the receive FIFO has been overloaded by the receiver. The last character in the FIFO is overwritten and flagged with this error. Once the overwritten character is read, this error condition is latched until reset by the Error Reset command. If the MPSC is in the status affects vector mode, the overrun causes a special Receive Condition Vector.

CRC/Framing Error-In async modes, a one in this bit indicates a receive fram-
ing error. In synchronous modes, a one in this bit indicates that the calculated CRC value does not match the last two bytes received. It can be reset by issuing an Error Reset command.

D7 End of Frame-this bit is valid only in SDLC mode. A one indicates that a valid ending flag has been received. This bit is reset either by an Error Reset command or upon reception of the first character of the next frame.

## Read Register 2 (RR2):


*Variable in Status Affects Vector Mode (WR1; D2)

## RR2

## Channel B

D7-D0 Interrupt vector-contains the interrupt vector programmed into WR2. If the status affects vector mode is selected, it contains the modified vector. (See WR2) RR2 contains the modified vector for the highest priority interrupt pending. If no interrupts are pending, the variable bits in the vector are set to one.

## SYSTEM INTERFACE

## General

The MPSC to Microprocessor System interface can be configured in many flexible ways. The basic interface types are polled, wait, interrupt driven, or direct memory access driven.

Polled operation is accomplished by repetitively reading the status of the MPSC, and making decisions based on that status. The MPSC can be polled at any time.

Wait operation allows slightly faster data throughput for the MPSC by manipulating the Ready input to the microprocessor. Block Read or Write Operations to the MPSC are started at will by the microprocessor and the MPSC deactivates its RDY signal if it is not yet ready to transmit the new byte, or if reception of new byte is not completed.

Interrupt driven operation is accomplished via an internal or external interrupt controller. When the MPSC requires service, it sends an interrupt request signal to the microprocessor, which responds with an interrupt acknowledge signal. When the internal or external interrupt controller receives the acknowledge, it vectors the microprocessor to a service routine, in which the transaction occurs.

DMA operation is accomplished via an external DMA controller. When the MPSC needs a data transfer, it request a DMA cycle from the DMA controller. The DMA controller then takes control of the bus and simultaneously does a read from the MPSC and a write to memory or vice-versa.

The following section describes the many configurations of these basic types of system interface techniques for both serial channels.

## Polled Operation:

In the polled mode, the CPU must monitor the desired conditions within the MPSC by reading the appropriate bits in the read registers. All data available, status, and error conditions are represented by the appropriate bits in read registers 0 and 1 for channels $A$ and $B$.

There are two ways in which the software task of monitoring the status of the MPSC has been reduced. One is the "ORing" of all conditions into the Interrupt Pending bit. (RRO; D1 channel A only). This bit is set when the MPSC requires service, allowing the CPU to monitor one bit instead of four status registers. The other is available when the "status-affects-vector" mode is selected. By reading RR2 Channel B, the CPU can read a vector who's value will indicate that one or more of group of conditions has occurred, narrowing the field of possible conditions. See WR2 and RR2 in the Detailed Command Description section.

## Software Flow, Polled Operation



## Hardware Configuration, Polled Operation



## WAIT OPERATION:

Wait Operation is intended to facilitate data transmission or reception using block move operations. If a block of data is to be transmitted, for example, the CPU can execute a String I/O instruction to the MPSC. After writing the first byte, the CPU will attempt to write a second byte immediately as is the case of block move. The MPSC forces the RDY signal low which inserts wait states in the CPU's write cycle until the transmit buffer is ready to accept a new byte. At that time, the RDY signal is high allowing the CPU to finish the write cycle. The CPU then attempts the third write and the process is repeated.

Similar operation can be programmed for the receiver. During initialization, wait on transmit (WR2; $D 5=0$ ) or wait on receive (WR1; D5 =1) can be selected.The wait operation can be enabled/ disabled by setting/resetting the Wait Enable Bit (WR1; D7).

CAUTION: ANY CONDITION THAT CAN CAUSE THE TRANSMITTER TO STOP (EG, CTS GOES INACTIVE) OR THE RECEIVER TO STOP (EG, RX DATA STOPS) WILL CAUSE THE MPSC TO HANG THE CPU UP IN WAIT STATES UNTIL RESET. EXTREME CARE SHOULD BE TAKEN WHEN USING THIS FEATURE.

## INTERRUPT DRIVEN OPERATION:

The MPSC can be programmed into several interrupt modes: Non-Vectored, 8085 vectored, and 8088/86 vectored. In both vectored modes, multiple MPSC's can be daisy-chained.

In the vectored mode, the MPSC responds to an interrupt acknowledge sequence by placing a call instruction ( 8085 mode) and interrupt vector (8085
and $8088 / 86$ mode) on the data bus. In the nonvectored mode, the MPSC does not respond to INTA sequences and must rely on an external interrupt controller such as the 8259A.

The MPSC can be programmed to cause an interrupt due to up to 14 conditions in each channel. The status of these interrupt conditions is contained in Read Registers 0 and 1. These 14 conditions are all directed to cause 3 different types of internal interrupt request for each channel: receive/interrupts, transmit interrupts and external/status interrupts (if enabled).

This results in up to 6 internal interrupt request signals. The priority of those signals can be programmed to one of two fixed modes:

Highest Priority Lowest Priority

$$
\begin{array}{llll}
\text { RxA RxB TxA TxB ExTA } & \text { ExTB } \\
\text { RxA TxA RxB TxB } & \text { ExTA } & \text { ExTB }
\end{array}
$$

The interrupt priority resolution works differently for vectored and non-vectored modes.

## PRIORITY RESOLUTION: VECTORED MODE

Any interrupt condition can be accepted internally to the MPSC at any time, unless the MPSC's internal INTA signal is active, unless a higher priority interrupt is currently accepted, or if $\overline{\mathrm{PI}}$ is inactive (high). The MPSC's internal INTA is set on the leading (falling) edge of the first External INTA pulse and reset on the trailing (rising) edge of the second External INTA pulse. After an interrupt is accepted internally, an External INT request is generated and the $\overline{\mathrm{IPO}}$ goes inactive. $\overline{I P O}$ and $\overline{|P|}$ are used for daisychaining MPSC's together.

Interrupt Condition Grouping


The MPSC's internal INTA is set on the leading (falling) edge of the first external INTA pulse, and reset on the trailing (rising) edge of the second external INTA pulse. After an interrupt is accepted internally,
an external $\overline{\mathrm{INT}}$ request is generated and $\overline{\mathrm{PO}}$ goes inactive (high). $\overline{I P O}$ and IPI are used for daisychaining MPSC's together.

## In-Service Timing



Each of the six interrupt sources has an associated In-Service latch. After priority has been resolved, the
highest priority In-Service latch is set. After the InService latch is set, the INT pin goes inactive (high).

EOI Command Timing


Lower priority interrupts are not accepted internally while the In-Service latch is set. However, higher priority interrupts are accepted internally and a new external INT request is generated. If the CPU responds with a new INTA sequence, the MPSC will respond as before, suspending the lower priority interrupt.

After the interrupt is serviced, the End-of-Interrupt (EOI) command should be written to the MPSC. This command will cause an internal pulse that is used to reset the In-Service Latch which allows service for lower priority interrupts in the daisy-chain to resume, provided a new INTA sequence does not start for a higher priority interrupt (higher than the highest under service). If there is no interrupt pending internally, the $\overline{\mathrm{PPO}}$ follows $\overline{\mathrm{IPI}}$.

## Non-Vectored Interrupt Timing



## PRIORITY RESOLUTION: NON-VECTORED MODE

In non-vectored mode, the MPSC does not respond to interrupt acknowledge sequences. The MPSC should be programmed to the Status-Affects-Vector mode, and the CPU should read RR2 (Ch. B) in its service routine to determine which interrupt requires service.

In this case, the internal pointer being set to RR2 provides the same function as the internal INTA signal in the vectored mode. It inhibits acceptance of any additional internal interrupts and its leading edge starts the interrupt priority resolution circuit. The interrupt priority resolution is ended by the leading edge of the read signal used by the CPU to retrieve the modified vector. The leading edge of read sets the in-Service latch and forces the external INT output inactive (high). The internal pointer is reset to zero after the trailing edge of the read pulse.


Note that if RR2 is specified but not read, no internal interrupts, regardless of priority, are accepted.

## DAISY CHAINING MPSC:

In the vectored interrupt mode, multiple MPSC's can be daisy-chained on the same INT, INTA signals. These signals, in conjunction with the $\overline{\mathrm{IPI}}$ and $\overline{\mathrm{PO}}$ allow a daisy-chain-like interrupt resolution scheme. This scheme can be configured for either 8085 or $8086 / 88$ based system.

In either mode, the same hardware configuration is called for. The INT request lines are wire-OR'ed together at the input of a TTL inverter which drives the INT pin of the CPU. The INTA signal from the CPU drives all of the daisy-chained MPSC's.

The MPSC drives $\overline{\mathrm{PPO}}$ (Interrupt Priority Output) inactive (high) if $\overline{\mathrm{PI}}$ (Interrupt Priority Input) is inactive (high), or if the MPSC has an interrupt pending.

The $\overline{\mathrm{IPO}}$ of the highest priority MPSC is connected to the $\overline{\mathrm{PP}}$ of the next highest priority MPSC, and so on.

If $\overline{\mathrm{IPI}}$ is active (low), the MPSC knows that all higher priority MPSC's have no interrupts pending. The $\overline{\mathrm{PI}}$ pin of the highest priority MPSC is strapped active (low) to ensure that it always has priority over the rest.

MPSC's Daisy-chained on an 8088/86 CPU should be programmed to the 8088/86 Interrupt mode (WR2; D4, D3 (Ch. A). MPSC's Daisy-chained on an 8085 CPU should be programmed to 8085 interrupt mode 1 if it is the highest priority MPSC. In this mode, the highest priority MPSC issues the CALL instruction during the first INTA cycle, and the interrupting MPSC provides the interrupt vector during the following INTA cycles. Lower priority MPSC's should be programmed to 8085 interrupt mode 2.

MPSC's used alone in 8085 systems should be programmed to 8085 mode 1 interrupt operation.

## DMA Acknowledge Circuit



DMA Timing


## DMA OPERATION

Each MPSC can be programmed to utilize up to four DMA channels: Transmit Channel A, Receive Channel A, Transmit Channel B, Receive Channel B. Each DMA Channel has an associated DMA Request line. Acknowledgement of a DMA cycle is done via normal data read or write cycles. This is accomplished by encoding the $\overline{\mathrm{DACK}}$ signals to generate $\mathrm{A}_{0}, \mathrm{~A}_{1}$, and $\overline{C S}$ signals, and multiplexing them with the normal $A_{0}, A_{1}$, and $\overline{C S}$ signals.

## PERMUTATIONS

Channels $A$ and $B$ can be used with different system interface modes. In all cases it is impossible to poll the MPSC. The following table shows the possible
permútations of interupt, wait, and DAM modes for channels A and B. Bits $D_{1}, D_{0}$ of WR2 Ch. A determine these permutations.

| Permutation <br> WR2 Ch. A <br> $\mathbf{D}_{1} \mathbf{D}_{0}$ | Channel A | Channel B |
| :---: | :---: | :---: |
| 00 | Wait <br> Interrupt <br> Polled | Wait <br> Interrupt <br> Polled |
| 01 | DMA <br> Polled | Interrupt <br> Polled |
| 10 | DMA <br> Polled | DMA <br> Polled |

$D 1, D 0=1,1$ is illegal.


## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature
Under Bias $\ldots \ldots \ldots \ldots \ldots \ldots \ldots 0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
Storage Temperature
(Ceramic Package) $\ldots \ldots \ldots \ldots-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
(Plastic Package) $\ldots \ldots \ldots \ldots-40^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Voltage On Any Pin With
Respect to Ground $\ldots \ldots \ldots \ldots,-0.5 \mathrm{~V}$ to +7.0 V
Power Dissipation $\ldots \ldots \ldots \ldots \ldots \ldots \ldots \ldots .1 .5 \mathrm{~W}$
*NOTICE: 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}_{\mathrm{cc}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | +2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | +0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | +2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage Current |  | +10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{OL}}$ | Output Leakage Current |  | +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 |  | 180 | mA |  |

CAPACITANCE $\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{cc}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 10 | pF | $\mathrm{f}_{\mathrm{C}}=1 \mathrm{MHz} ;$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance |  | 15 | pF | Unmeasured |
| $\mathrm{C}_{\text {I/O }}$ | Input/Output Capacitance |  | 20 | pF | pins returned <br> to GND |

## A.C. CHARACTERISTICS $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{cc}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }} \mathrm{CY}$ | CLK Period | 250 | 4000 | ns |  |
| ${ }^{\text {t }} \mathrm{CL}$ | CLK Low Time | 105 | 2000 | ns |  |
| ${ }^{\text {t }} \mathrm{CH}$ | CLK High Time | 105 | 2000 | ns |  |
| $\mathrm{t}_{\mathrm{r}}$ | CLK Rise Time | 0 | 30 | ns |  |
| $t_{f}$ | CLK Fall Time | 0 | 30 | ns |  |
| ${ }^{\text {AR }}$ | A0, A1 Setup to $\overline{\mathrm{RD}} \downarrow$ | 0 |  | ns |  |
| ${ }_{t}{ }_{\text {A }}$ | A0, A1 to Data Output Delay |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pf}$ |
| ${ }_{\text {t }}^{\text {RA }}$ | A0. A1 Hold After $\overline{\mathrm{RD}} \uparrow$ | 0 |  | ns |  |
| ${ }^{\text {f }}$ RD | $\overline{\mathrm{RD}} \downarrow$ to Data Output Delay |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pf}$ |
| $t_{\text {RR }}$ | $\overline{\mathrm{RD}}$ Pulse Width | 250 |  | ns |  |
| ${ }_{\text {t }}^{\text {DF }}$ | Output Float Delay |  | 120 | ns |  |
| ${ }^{\text {t }}$ AW | $\overline{\mathrm{CS}}, \mathrm{AO}, \mathrm{A} 1$ Setup to $\overline{\mathrm{WR}} \downarrow$ | 0 |  | ns |  |
| ${ }^{\text {W WA }}$ | $\overline{\mathrm{CS}}, \mathrm{A} 0, \mathrm{~A} 1$ Hold after $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| $t_{\text {WW }}$ | $\overrightarrow{W R}$ Pulse Width | 250 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup to $\overline{W R} \uparrow$ |  | 150 | ns |  |
| ${ }^{\text {t WD }}$ | Data Hold After $\overline{W R} \uparrow$ | 0 |  | ns |  |
| $t_{\text {PI }}$ | $\overline{\mathrm{IPI}}$ Setup to $\overline{\text { ITAA }} \downarrow$ | 0 |  | ns |  |
| $\mathrm{t}_{\text {IP }}$ | $\overline{\text { IPI Hold after } \overline{\text { NTA }} \uparrow \sim}$ | 0 |  | ns |  |
| $t_{11}$ | $\overline{\text { INTA }}$ Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\text {IAPO }}$ | $\overline{\mathrm{NTA}} \downarrow$ to $\overline{\mathrm{PPO}}$ Delay |  | 200 | ns |  |
| ${ }^{\text {t PIPO }}$ | $\overline{\mathrm{IPI}} \downarrow$ to $\overline{\mathrm{PO}}$ Delay |  | 100 | ns |  |
| $\mathrm{t}_{1 \mathrm{D}}$ | $\widehat{\text { INTA }} \downarrow$ to Data Output Delay |  | 200 | ns |  |
| ${ }^{t} \mathrm{CQ}$ | $\overline{\mathrm{RD}}$ or $\overline{W R}$ to DRQ $\downarrow$, |  | 150 | ns |  |
| ${ }^{\text {t }}$ RV | Recovery Time Between Controls | 300 |  | ns | * |
| ${ }^{\text {t }} \mathrm{CW}$ | $\overline{\mathrm{CS}}, \mathrm{AO}, \mathrm{A} 1$ to $\overline{\mathrm{RDY}} \mathrm{A}$ or $\overline{\mathrm{RDY}_{B}}$ Delay |  | 120 | ns |  |
| ${ }^{\text {t }}$ DCY | Data Clock Cycle | $4.5 \mathrm{t}_{\mathrm{CY}}$ |  | ns |  |
| ${ }^{\text {t }}$ DCL | Data Clock Low Time | 180 |  | ns |  |
| ${ }^{t}$ DCH | Data Clock High Time | 180 |  | ns |  |
| ${ }^{\text {T }}$ D | $\overline{T \times C}$ to TxD Delay |  | 300 | ns |  |
| ${ }_{t}$ DS | $R \times D$ Setup to $\overline{R \times C} \uparrow$ | 0 |  | ns |  |
| ${ }^{\text {d }}$ DH | RxD Hold after $\overline{\mathrm{RxC}} \uparrow$ | 140 | $\cdots$ | ns |  |
| $t_{\text {ITD }}$ | $\overline{\mathrm{TXC}}$ to INT Delay | 4 | 6 | tcy |  |
| ${ }^{\prime}$ IRD | RxC to $\overline{\text { INT }}$ Delay | 7 | 10 | tcy |  |
| ${ }^{\text {P PL }}$ | $\overline{\mathrm{CTS}}, \overline{\mathrm{CD}}$, $\overline{\text { SYNDET }}$ Low Time | 200 |  | ns |  |
| ${ }^{\text {PH }}$ | $\overline{C T S}, \overline{C D}, \overline{\text { SYNDET }}$ High Time | 200 |  | ns |  |
| $t_{\text {IPD }}$ | External $\overline{\mathrm{NT}}$ from $\overline{\mathrm{CTS}}, \overline{\mathrm{CD}}, \overline{\text { SYNDET }}$ |  | 500 | ns |  |

A.C. TESTING INPUT, OUTPUT WAVEFORM

A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

## CLOCK CYCLE



## READ CYCLE



## WAVEFORMS (Continued)



NOTES:

1. INTA signal acts as RD signal.
2. IPI signal acts as $C S$ signal.

## WAVEFORMS (Continued)



## 8291A <br> GPIB TALKER/LISTENER

- Designed to Interface Microprocessors (e.g., 8048/49, 8051, 8080/85, 8086/88) 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 Non-Inverting 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 8291A is an enhanced version of the 8291 GPIB Talker/Listener designed to interface microprocessors to an IEEE Standard 488 Instrumentation Interface Bus. It implements all of the Standard's interface functions except for the controller. The controller function can be added with the 8292 GPIB Controller, and the 8293 GPIB Transceiver performs the electrical interface for Talker/Listener and Talker/Listener/Controller configurations.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## 8291A FEATURES AND IMPROVEMENTS

The 8291A is an improved design of the 8291 GPIB Talker/Listener. Most of the functions are identical to the 8291, and the pin configuration is unchanged.

The 8291A offers the following improvements to the 8291:

1. $\overline{\mathrm{EOI}}$ is active with the data as a ninth data bit rather than as a control bit. This is to comply with some additions to the 1975 IEEE-488 Standard incorporated in the 1978 Standard.
2. The BO interrupt is not asserted until RFD is true. If the Controller asserts $\overline{\text { ATN }}$ synchronously, the data is guaranteed to be transmitted. If the Controller asserts ATN asynchronously, the SH (Source Handshake) will return to SIDS (Source Idle State), and the output data will be cleared. The, if $\overline{\text { ATN }}$ is released while the 8291A is addressed to talk, a new $B O$ interrupt will be generated. This change fixes 8291 problems which caused data to be lost or repeated and a problem with the RQS bit (sometimes cannot be asserted while talking).
3. LLOC and REMC interrupts are setting flipflops rather than toggling flipflops in the interrupt backup register. This ensures that the CPU knows that these state changes have occurred. The actual state can be determined by checking the LLO and REM status bits in the upper nibble of the Interrupt Status 2 Register.
4. DREQ is cleared by $\overline{\mathrm{DACK}}(\overline{\mathrm{RD}}+\overline{\mathrm{WR}})$. DREQ on the 8291 was cleared only by $\overline{\text { DACK }}$ which is not compatible with the 8089 I/O Processor.
5. The INT bit in Interrupt Status 2 Register is duplicated in bit 7 of the Address 0 Register. If software polling is used to check for an interrupt, INT in the Address 0 Register should be polled rather than the Interrupt Status 2 Register. This ensures that no interrupts are lost due to asynchronous status reads and interrupts.
6. The 8291A's Send EOI Auxiliary Command works on any byte including the first byte of a message. The 8291 did not assert $\overline{E O I}$ after this command for a one byte message nor on two consecutive bytes.
7. To avoid confusion between holdoff on DAV versus RFD if a device is readdressed from a talker to a listener role or vice-versa during a holdoff, the "Holdoff on Source Handshake" has been eliminated. Only "Holdoff on Acceptor Handshake" is available.
8. The rsv local message is cleared automatically upon exit from SPAS if (APRS.STRS.SPAS) occurred. The automatic resetting of the bit after the serial poll is complete simplifies the service request software.
9. The SPASC interrupt on the 8291 has been replaced by the SPC (Serial Poll Complete) interrupt on the 8291A. SPC interrupt is set on exit from SPAS if APRS.STRS.SPAS occurred, indicating that the controller has read the bus status byte after the 8291A requested service. The SPASC interrupt was ambiguous because a controller could enter SPAS and exit SPAS generating two SPASC interrupts without reading the serial poll status byte. The SPC interrupt also simplifies the CPU's software by eliminating the interrupt when the serial poll is half way done.
10. The rtl Auxiliary Command in the 8291 has been replaced by Set and Clear rtl Commands in the 8291A. Using the new commands, the CPU has the flexibility to extend the length of local mode or leave it as a short pulse as in the 8291.
11. A holdoff RFD on GET, SDC, and DCL feature has been added to prevent additional bus activity while the CPU is responding to any of these commands. The feature is enabled by a new bit $\left(B_{4}\right)$ in the Auxiliary Register $B$.
12. On the 8291, BO could cease to occur upon IFC going false if $\overline{I F C}$ occurred asynchronously. On the 8291A, BO continues to occur after IFC has gone false even if it arrived asynchronously.
13. User's software can distinguish between the 8291 and the 8291A as follows:
a) pon $(00 \mathrm{H}$ to register 5$)$
b) RESET $(02 \mathrm{H}$ to register 5)
c) Read Interrupt Status 1 Register. If BO interrupt is set, the device is the 8291. If BO is clear, it is the 8291A.

This can be used to set a flag in the user's software which will permit special routines to be executed for each device. It could be included as part of a normal initialization procedure as the first step after a chip reset.

Table 1. Pin Description

| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 12-19 | 1/O | Data Bus Port: To be connected to microprocessor data bus. |
| $\mathrm{RS}_{0}-\mathrm{RS}_{2}$ | 21-23 | 1 | Register Select: Inputs, to be connected to three nonmultiplexed 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}}$ (WR.) |
| $\overline{\mathrm{CS}}$ | 8 | 1 | Chip Select: When Iow, enables reading from or writing into the register selected by $\mathrm{RS}_{0}-\mathrm{RS}_{2}$. |
| $\overline{\mathrm{RD}}$ | 9 | 1 | Read Strobe: When low with $\overline{C S}$ or DACK low, selected register contents are read. |
| $\overline{\mathrm{WR}}$ | 10 | 1 | Write Strobe: When Iow with $\overline{C S}$ or DACK low, data is written into the selected register. |
| INT (INT) | 11 | 0 | 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. |
| DREQ | 6 | 0 | DMA Request: Normally low, set high to indicate byte output or byte input in DMA mode; reset by DACK. |
| $\overline{\text { DACK }}$ | 7 | I | DMA Acknowledge: When low, resets DREQ and selects data in/data out register for DMA data transfer (actual transfer done by RD/WR pulse). <br> Must be high if DMA is not used. |
| TRIG | 5 | 0 | Trigger Output: Normally low; generates a triggering pulse with $1 \mu \mathrm{sec} \mathrm{min}$. width in response to the GET bus command or Trigger uuxillary command. |
| CLOCK | 3 | 1 | External Clock: Input, used only for $T_{1}$ delay generator. May be any speed in $1-8 \mathrm{MHz}$ range. |


| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| RESET | 4 | 1 | Reset Input: When high, forces the device into an "idle" (initialization) mode. The device will remain at "idle" until released by the microprocessor, with the "Immediate Execute pon" local message. |
| $\overline{\mathrm{DIO}}_{1}-\overline{\mathrm{DIO}}_{8}$ | 28-35 | 1/0 | 8-Bit GPIB Data Port: Used for bidirectional data byte transfer between 8291A and GPIB via non-inverting external line transceivers. |
| $\overline{\text { DAV }}$ | 36 | 1/0 | Data Valid: GPIB handshake control line. Indicates the availability and validity of information on the $\overline{\mathrm{DIO}}_{1}-\overline{\mathrm{DIO}}_{8}$ and $\overline{\mathrm{EOI}}$ lines. |
| $\overline{\text { NRFD }}$ | 37 | 1/0 | Not Ready for Data: GPIB handshake control line. Indicates the condition of readiness of device(s) connected to the bus to accept data. |
| $\overline{\text { NDAC }}$ | 38 | 1/0 | Not Data Accepted: GPIB handshake control line. Indicates the condition of acceptance of data by the device(s) connected to the bus. |
| $\overline{\text { ATN }}$ | 26 | I | Attention: GPIB command line. Specifies how data on $\overline{\mathrm{DIO}}$ lines are to be interpreted. |
| $\overline{\text { IFC }}$ | 24 | 1 | Interface Clear: GPIB command line. Places the interface functions in a known quiescent state. |
| $\overline{\text { SRQ }}$ | 27 | 0 | Service Request: GPIB command line. Indicates the need for attention and requests an interruption of the current sequence of events on the GPIB. |
| $\overline{\text { REN }}$ | 25 | 1 | Remote Enable: GPIB command line. Selects (in conjunction with other messages) remote or local control of the device. |
| $\overline{\text { EOI }}$ | 39 | 1/0 | End or Identify: GPIB command line. Indicates the end of a multiple byte transfer sequence or, in conjunction with ATN, addresses the device during a polling sequence. |

Table 1. Pin Description (Continued)

| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| T/R1 | 1 | 0 | External Transceivers Control Line: Set high to indicate output data/ signals on the $\mathrm{DIO}_{1}-\overline{\mathrm{DIO}}_{8}$ and DAV lines and input signals on the NRFD and $\overline{\text { NDAC }}$ lines (active source handshake). Set low to indicate input data/signals on the $\overline{\mathrm{DIO}}_{1}-\overline{\mathrm{DIO}}_{8}$ and $\overline{\mathrm{DAV}}$ lines and output signals on the NRFD and NDAC lines (active acceptor handshake). |


| Symbol | Pin <br> No. | Type | Name and Function |
| :--- | :---: | :---: | :--- |
| T//̄2 | 2 | O | External Transceivers <br> Control Line: Set to indi- <br> cate output signals on the <br> EOI line. Set low to indicate <br> expected input signal on <br> the EOI line during parallel <br> poll. |
| $\mathrm{V}_{\mathrm{Cc}}$ | 40 | P.S. | Positive Power Supply: <br> (5V $\pm 10 \%)$. |
| GND | 20 | P.S. | Circuit Ground Potential. |

NOTE:
All signals on the 8291A pins are specified with positive logic. However, IEEE 488 specifies negative logic on its 16 signal lines. Thus, the data is inverted once from $\mathrm{D}_{0}-\mathrm{D}_{7}$ to $\overline{\mathrm{DIO}}_{0}-\overline{\mathrm{DIO}}_{8}$ and non-inverting bus transceivers should be used.


Figure 3. 8291A System Diagram

## THE GENERAL PURPOSE INTERFACE BUS (GPIB)

The General Purpose Interface Bus (GPIB) is defined in the IEEE Standard 488-1978 "Digital Interface for Programmable Instrumentation." Although a knowledge of this standard is assumed, Figure 4 provides the bus structure for quick reference. Also, Tables 2 and 3 reference the interface state mnemonics and the interface messages respectively. Modified state diagrams for the 8291A are presented in Appendix A.

## General Description

The 8291A is a microprocessor-controlled device designed to interface microprocessors, e.g., 8048/49, 8051, 8080/85, 8086/88 to the GPIB. It implements all of the interface functions defined in the

IEEE-488 Standard except for the controller function. If an implementation of the Standard's Controller is desired, it can be connected with an Intel ${ }^{\circledR} 8292$ to form a complete interface.

The 8291A handles communication between a mi-croprocessor-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 parallèl polling. In most procedures, it does not disturb the microprocessor unless a byte has arrived (input buffer full) or has to be sent out (output buffer empty).

The 8291A 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.

## 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 8291A implementation of the GPIB offers the user three alternative addressing modes for 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 ten-bit address ( 5 low-order bits of each of two bytes). 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.


Figure 4. Interface Capabilities and Bus Structure

Table 2. 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 $\sim_{\text {* }}$ |
| - $\overline{\text { CACS }}$ | Controller Active State |
| CADS | Controller Addressed State I |
| 1 CAWS | Controller Active Wait State |
| 1 CIDS | Controller Idle State |
| 1 CPPS | Controller Parallel Poll State |
| 1 CPWS | Controller Parallel Poll Wait State |
| 1 CSBS | Controller Standby State |
| CSNS | Controller Service Not Requested State , |
| , CSRS | Controller Service Requested State I |
| 1 CSWS | Controller Synchronous Wait State |
| L 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 | Systém 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 ${ }^{\circledR} 8292$.

Table 3. IEEE 488 Interface Message Reference List

| Mnemonic | Message | Interface Function(s) |
| :---: | :---: | :---: |
| LOCAL. MESSAGES RECEIVED (By Interface Functions) |  |  |
| ${ }^{1} \mathrm{gts}$ | go to standby | C |
| ist | individual status | PP |
| Ion | listen only | L, LE |
| Ipe | 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 |
| ${ }^{1} \mathrm{rpp}$ | request parallel poll | C |
| ${ }^{1} \mathrm{rsc}$ | request system control | C |
| rsv | request service | SR |
| rtI | return to local | RL |
| ${ }^{1}$ sic | send interface clear | C |
| ${ }^{1}$ sre | send remote enable | C |
| ${ }^{1}$ tra | take control asynchronously | C |
| ${ }^{1} \mathrm{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 |
| ${ }^{2}$ PPPC | Parallel Poll Configure | PP |
| ${ }^{2}$ [PPD] | Parallel Poll Disable | PP |
| ${ }^{2}$ [PPE] | Parallel Poll Enable | PP |
| ${ }^{1} \mathrm{PPR}_{N}$ | Parallel Poll Response N | (via C) |
| ${ }^{2} \mathrm{PPPU}$ | 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 |
| ${ }^{1}$ SQR | Service Request | (via C) |
| STB | Status Byte | (via L, LE) |
| ${ }^{1}$ TCT or [TCT] | Take Control | C |
| UNL | Unlisten | L, LE |

## NOTE:

1. These messages are handled only by Intel's 8292.
2. Undefined commands which may be passed to the microprocessor.

Table 3. (Cont'd)
IEEE 488 Interface Message Reference List

| Mnemonic | Message | Interface Function(s) |
| :--- | :--- | :--- |
| REMOTE MESSAGES SENT |  |  |
| ATN | Attention | C |
| DAB | Data Byte | (via T, TE) |
| DAC | Data Accepted | AH |
| DAV | Data Valid | SH |
| DCL | Device Clear | (via C) |
| END | End | (via T) |
| GET | Group Execute Trigger | (via C) |
| GTL | Go to Local | (via C) |
| IDY | Identify | C |
| IFC | Interface Clear | C |
| LLO | Local Lockout | (via C) |
| MLA or [MLA] | My Listen Address | (via C) |
| MSA or [MSA] | My Secondary Address | (via C) |
| MTA or [MTA] | My Talk Address | (via C) |
| OSA | Other Secondary Address | (via C) |
| OTA | Other Talk Address | (via C) |
| PCG | Primary Command Group | (via C) |
| PPC | Parallel Poll Configure | (via C) |
| [PPD] | Parallel Poll Disable | (via C) |
| [PPE] | Parallel Poll Enable | (via C) |
| PPRN | Parallel Poll Response N | PP |
| PPU | Parallel Poll Unconfigure | (via C) |
| REN | Remote Enable | C |
| RFD | Ready for Data | AH |
| RQS | Request Service | T, TE |
| ISDC] | Selected Device Clear | (via C) |
| SPD | Serial Poll Disable | (via C) |
| SPE | Serial Poll Enable | (via C) |
| SRQ | Service Request | SR |
| STB | Status Byte | (via T, TE) |
| TCT | Take Control | (via C) |
| UNL | Unlisten | (via C) |

NOTE:
3. All Controller messages must be sent via Intel's 8292.

## 8291A Registers

A bit-by-bit map of the 16 registers on the 8291A is presented in Figure 5. 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{\mathrm{CS}}$, $\overline{R D}, \overline{W R}$, and $\mathrm{RS}_{0}-\mathrm{RS}_{2}$ pins.

| Register | $\overline{\mathbf{C S}}$ |  | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathbf{R S}_{0}-\mathbf{R S}_{2}$ |  |  |  |
| All Read Registers | 0 | 0 |  | 1 |  |
| CCC |  |  |  |  |  |
| All Write Registers | 0 | 1 |  | 0 |  |
| CCC |  |  |  |  |  |
| High Impedance | 1 | $d$ |  | $d$ | ddd |

## Data Registers



The Data-In Register is used to move data from the GPIB to the microprocessor or to memory when the 8291A 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 8291A then completes the handshake automatically. In RFD holdoff mode (see Auxiliary Register A), the handshake is not finished until a command is sent telling the 8291A to release the holdoff. In this way, the same byte may be read seveal times, or an over anxious talker may be held off until all available data has been processed.

When the 8291A is addressed to talk, it uses the data-out register to move data onto the GPIB. After the BO interrupt is received and a byte is written to this register, the 8291A initiates and completes the handshake while sending the byte out over the bus. In the BO interrupt disable mode, the user should wait until BO is active before writing to the register. (In the DMA mode, this will happen automatically.) A read of the Data-In Register does not destroy the information in the Data-Out Register.

## Interrupt Registers

| CPT | APT | GET | END | DEC | ERR | BO | BI |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

INTERRUPT STATUS 1 (1R)


INTERRUPT STATUS 2 (2R)


INTERRUPT ENABLE 1 (1W)


INTERRUPT ENABLE 2 (2W)


ADDRESS 0 REGISTER

Figure 5. 8291A Registers


The 8291A 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 enable bit in the interrupt enable registers. These enable 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 generate an interrupt. Bits in the Interrupt Status Registers are set regardless of the states of the enable 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 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 tables also indicates how each of the interrupt bits is set.

NOTE: The INT bit in the Address 0 Register is a duplicate of the INT bit in the Interrupt Status 2 Register. It is only a status bit. It does not generate interrupts and thus does not have a corresponding enable bit.

The BO and BI interrupts enable the user to perform data transfer cycles. BO indicates that a data byte should be written to the Data Out Register. It is set by TACS • (SWNS + SGNS) • RFD. It is reset when the data byte is written, ATN is asserted, or the 8291A exits TACS. Data should never be written to the Data Out Register before BO is set. Similarly, BI is set when an input byte is accepted into the 8291A 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

Table 4. Interrupt Bits


NOTE: ${ }^{1}$ In ton (talk-only) and lon (listen-only) modes, no ADSC interrupt is generated.

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 disabled; BO and BI will automatically reset after each byte is transferred.

If the 8291 A is used in the interrupt mode, the INT and DREQ pins can be dedicated to data input and output interrupts respectively by enabling BI and DMAO, provided that no other interrupts are enabled. This eliminates the need to read the interrupt status registers if a byte is received or transmitted.

The ERR bit is set to indicate the bus error condition when the 8291A is an active talker and tries to send 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 8291A is an active listener (LACS) and either EOS (provided the End on EOS Received feature is enabled in the Auxiliary Register A) 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 on EOI.

The GET interrupt bit is used by the microprocessor to detect that DTAS has occurred. It is set by the 8291A when the GET message is received while it is addressed to listen. The TRIG output pin of the 8291A fires when the GET message is received. Thus, the basic operation of device trigger may be started without microprocessor software intervention.

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 automatically on the 8291A. 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. Any message not decoded by the 8291A (not included in the state diagrams in Appendix B) becomes an undefined command. Note that any addressed command is automatically ignored when the 8291A is not addressed.

Undefined commands are read by the CPU from the Command Pass Through register of the 8291A. This register reflects the logic levels present on the data lines at the time it is read. If the CPT feature is enabled, the 8291A will hold off the handshake until this register is read.

An especially useful feature of the 8291 A is its ability to generate interrupts from state transitions in the interface functions. In particular, the lower 3 bits of the Interrupt Status 2 Register, if enabled by the corresponding enable bits, will cause an interrupt upon changes in the following states as defined in the IEEE 488 Standard.

| Bit 0 | ADSC | change in LIDS or TIDS or MJMN |
| :--- | :--- | :--- |
| Bit 1 | REMC | change in LOCS or REMS |
| Bit 2 | LLOC | change in LWLS or RWLS |

The upper 4 bits of the Interrupt Status 2 Register are available to the processor as status bits. Thus, if one of the bits 0-2 generates an interrupt indicating a state change has taken place, the corresponding status bit (bits 3-5 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. The SPC interrupt (bit 3 in Interrupt Status 2) is set upon exit from SPAS if APRS:STRS:SPAS occurred which indicates that the GPIB controller has read the bus serial poll status byte after the 8291A requested service (asserted SRQ). The SPC interrupt occurs once after the controller reads the status byte if service was requested.

The controller may read the status byte later, and the byte will contain the last status the 8291A's CPU wrote to the Serial Poll Mode Register, but the SRQS bit will not be set and no interrupt will be generated. Finally, bit 7 monitors the state of the 8291A INT pin. Logically, it is an OR of all enabled interrupt status bits. One should note that bits 3-6 of the Interrupt Status 2 Register do not generate interrupts, but are available only to be read as status bits by the processor. Bit 7 in Interrupt Status 2 is duplicated in Address 0 Register, and the latter should be used when polling for interrupts to avoid losing one of the interrupts in Interrupt Status 2 Register.

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 DREQ (DMA request) pin of the 8291A to be asserted upon the occurrence of BI. Similarly, DMAO (DMA out) enables the DREQ pin to be asserted upon the occurrence of BO. One might note that the DREQ pin may be used as a second interrupt output pin, monitoring Bl and/or BO and enabled by DMAI and DMAO. One should note that the DREQ 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 8291A implements a special interrupt handling procedure. When an enabled 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 8291A stores all new interrupts in a temporary register and transfers them to the appropriate Interrupt Status Register after the interrupt has been reset. This transfer takes place only if the corresponding bits were read as zeroes.

## Serial Poll Registers

| S8 | SRQS | S6 | S5 | S4 | S3 | S2 | S1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

SERIAL POLL STATUS (3R)

| S 8 | rsv | S 6 | S 5 | S 4 | S 3 | S 2 | S 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

SERIAL POLL MODE (3W)

The Serial Poll Mode Register determines the status byte that the 8291A sends out on the GPIB data lines when it receives the SPE (Serial Poll Enable) message. Bit 6 of this register is reserved for the rsv (request service) local message. Setting this bit to 1 causes the 8291A to assert its $\overline{S R Q}$ line, indicating its need for attention from the controller-in-charge of the GPIB. The other bits of this register are available for sending status information over the GPIB. Sometime after the microprocessor initiates a request for service by setting bit 6 , the controller of the GPIB sends the SPE message and then addresses the 8291A to talk. At this point, one byte of status is returned by the 8291A via the Serial Poll Mode Register. After the status byte is read by the controller, rsv is automatically cleared by the 8291A and an SPC interrupt is generated. The CPU may request service again by writing another byte to the Serial Poll Mode Register with the rsv bit set. If the controller performs a serial poll when the rsv bit is clear, the last status byte written will be read, but the $\overline{S R Q}$ line will not be driven by the 8291A and the SRQS bit will be clear in the status byte.

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-incharge reads the status byte, the SRQS bit is cleared. The $\overline{S R Q}$ line and the rsv bit are tied together.

## Address Registers

| ton | Ion | EOI | LPAS | TPAS | LA | TA | MJMN |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

ADDRESS STATUS (4R)


ADDRESS 0 (6R)


ADDRESS 1 (7R)

| TO | LO | 0 | 0 | 0 | 0 | ADM1 | ADM0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

ADDRESS MODE (4W)

| ARS | DT | DL | AD5 | AD4 | AD3 | AD2 | AD1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

ADDRESS 0/1 (6W)

The Address Mode Register is used to select one of the five modes of addressing available on the 8291A. It determines the way in which the 8291A 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 address 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 8291A 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 8291A can handle all addressing sequences without processor intervention.
-In Mode 3, the 8291A 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 8291A is in TPAS or LPAS (talker/listener primary addressed 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 TO bit generates the local ton (talkonly) message and sets the 8291A to a talk-only mode. This mode allows the device to operate as a talker in an interface system without a controller.

Setting the LO bit generates the local lon (listenonly) message and sets the 8291A to a listen-only mode. This mode allows the device to operate as a listener in an interface system without a controller. The above bits may also be used by a controller-incharge to set itself up for remote command or data communication.

The mode of addressing implemented by the 8291A may be selected by writing one of the following bytes to the Address Mode Register.

Register Contents Mode
10000000 Enable talk only mode (ton)
01000000 Enable listen only mode (Ion)
11000000 The 8291 may talk to itself
00000001 Mode 1, (Primary-Primary)
$00000010 \quad$ 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 "Ion" flags which indicate the talk 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 use these bits when the secondary address is passed through to determine whether the 8291A is addressed to talk or listen. The LA (listener addressed) bit will be set when the 8291A 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 8291A is formed by the following sequence of writes by the microprocessor.

| Operation | $\overline{\mathbf{C S}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | Data | RS2-RS0 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1. Select addressing Mode 1 | 0 | 1 | 0 | 00000001 | 100 |
| 2. Load major address into | 0 | 1 | 0 | 001 AAAAA | 110 |
| Address 0 Register with <br> listener function disabled. |  |  |  |  |  |
| 3. Load minor address into <br> Address 1 Register with <br> talker function disabled. | 0 | 1 | 0 | 110 BBBBB | 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.

The Address 0 Register contains a copy of bit 7 of the Interrupt Status 2 Register (INT). This is to be used when polling for interrupts. Software should poll register 6 checking for INT (bit 7) to be set. When INT is set, the Interrupt Status Register should be read to determine which interrupt was received.

## Command Pass Through Register

| CPT7 | CPT6 | CPT5 | CPT4 | CPT3 | CPT2 | CPT1 | CPTO |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

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 8291A becomes an undefined command. When Mode 3 addressing is used secondary addresses are also passed through
the CPT Register. In either case, the 8291A will holdoff the handshake until the microprocessor reads this register and issues the VSCMD auxiliary command.

The CPT and APT interrupts flag the availablility 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 8291A is its ability to handle undefined secondary commands following undefined primaries. Thus, the number of available commands for future IEEE-488 definition is increased; one undefined primary command followed by a sequence of as many as 32 secondary commands can be processed. The IEEE-488 Standard does not permit users to define their own commands, but upgrades of the standard are thus provided for.

The recommended use of the 8291A'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-4: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 8291A:

1. To load "hidden" auxiliary registers on the 8291A.
2. To issue commands from the microprocessor to the 8291A.
3. To preset an internal counter used to generate T1, delay in the Source Handshake function, as defined in IEEE-488.

Table 5 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 5

| CODE |  | COMMAND |
| :---: | :---: | :---: |
| $\begin{array}{\|c\|} \hline \text { CONTROL } \\ \text { BITS } \\ \hline \end{array}$ | $\begin{gathered} \text { COMMAND } \\ \text { BITS } \\ \hline \end{gathered}$ |  |
| 000 | OCCCC | Execute auxiliary command CCCC |
| 001 | ODDDD | Preset internal counter to match external clock frequency of DDDD MHz (DDDD binary representation of 1 to 8 MHz ) |
| 100 | DDDDD | Write DDDDD into auxiliary register A |
| 101 | DDDDD | Write DDDDD into auxiliary register B |
| 011 | USP $\mathrm{P}_{3} \mathrm{P}_{2} \mathrm{P}_{1}$ | Enable/disable parallel poll either in response to remote messages (PPC followed by PPE or PPD) or as a local Ipe message. (Enable if $\mathrm{U}=0$, disable if $U=1$.) |

## AUXILIARY COMMANDS

Auxiliary commands are executed by the 8291A whenever 0000CCCC is written into the Auxiliary Mode Register, where CCCC is the 4 -bit command code.

0000-Immediate Execute pon: This command resets the 8291A to a power up state (local pon message as defined in IEEE-488).
The following conditions constitute the power up state:

1. All talkers and listeners are disabled.
2. No interrupt status bits are set.

The 8291A 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.

0010-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. (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.

0101, 1101-Clear/Set rtl: These commands correspond to the local rtl message as defined by the IEEE-488. The 8291A will go into local mode when a Set rtl Auxiliary Command is received if local lockout is not in effect. The 8291A will exit local mode after receiving a Clear rtl Auxiliary Command if the 8291 A is addressed to listen.

0110-Send EOI: The EOI line of the 8291A 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 8291A that the secondary address received by the microprocessor was valid or invalid ( 0111 = invalid, 1111 = 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 A to continue from the command-pass-through-state, or from RFD holdoff on GET, SDC or DCL.

1000-pon: This command puts the 8291A into the pon (power on) state and holds it there. It is similar to a Chip Reset except none of the Auxiliary Mode Registers are cleared. In this state, the 8291A does not participate in any bus activity. An Immediate Execute pon releases the 8291A from the pon state and permits the device to participate in the bus activity again.

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 (PRR = 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.

## INTERNAL COUNTER

The internal counter determines the delay time allowed for the setting of data on the DIO lines. This delay time is defined as $\mathrm{T}_{1}$ in IEEE-488 and appears in the Source Handshake state diagram between the

SDYS and STRS. As such, DAV is asserted $\mathrm{T}_{1}$ after the DIO lines are driven. Consequently, $T_{1}$ is a major factor in determining the data transfer rate of the 8291A over the GPIB ( $T_{1}=$ TWRDV2-TWRD15).

When open-collector transceivers are used for connection to the GPIB, $T_{1}$ is defined by IEEE-488 to be $2 \mu \mathrm{sec}$. By writing 0010DDDD into the Auxiliary Mode Register, the counter is preset to match a $\mathrm{f}_{\mathrm{c}} \mathrm{MHz}$ clock input, where DDDD is the binary representation of $N_{F}\left[1 \leqslant N_{F} \leqslant 8, N_{F}=(D D D D)_{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 N_{F}}{f_{\mathrm{C}}}+\mathrm{t}_{\mathrm{SYNC}}, 1 \leqslant \mathrm{~N}_{\mathrm{F}} \leqslant 8$
$t_{\text {sync }}$ 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, $\mathrm{t}_{\mathrm{sYNC}}$ is less than half the clock cycle).

If it is necessary that $T_{1}$ be different from $2 \mu \mathrm{sec}, \mathrm{N}_{\mathrm{F}}$ may be set to a value other than $\mathrm{f}_{\mathrm{c}}$. 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 $T_{1}$.

When tri-state transceivers are used, IEEE-488 allows a higher transfer rate (lower $T_{1}$ ). Use of the 8291A with such transceivers is enabled by setting $B_{2}$ 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 .
$\mathrm{T}_{1}($ High Speed $) \mu \mathrm{sec}=\frac{\mathrm{N}_{\mathrm{F}}}{2 \mathrm{f}_{\mathrm{C}}}+\mathrm{t}_{\mathrm{SYNC}}$
Thus, the shortest $T_{1}$ is achieved by setting $N_{F}=1$ using an 8 MHz clock with a $50 \%$ duty cycle clock ( $\mathrm{t}_{\mathrm{sYNC}}<63 \mathrm{nsec}$ ):
$T_{1(H S)}=\frac{1}{2 \times 8}+0.063=125$ nsec max.

## AUXILIARY REGISTER A

Auxiliary Register A is a "hidden" 5-bit register which is used to enable some of the 8291A 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.
$A_{0}$ - RFD Holdoff on all Data: If the 8291A is listening, RFD will not be sent true until the "finish handshake" auxiliary command is issued by the microprocessor. The holdoff will be in effect for each data byte.
$\mathbf{A}_{1}$-RFD 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.
$\mathbf{A}_{2}$-End on EOS Received: Whenever the byte in the Data In Register matches the byte in the EOS Register, the END interrupt bit will be set in the Interrupt Status 1 Register.
$\mathbf{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 $A_{0}=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 8291A 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 8291A 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 8291A should be taken out of the "continuous AH cycling" mode, the GPIB will hang up in ANRS, and a Bl interrupt will be generated to indicate that control may be taken. A simpler procedure may be used when a "tcs on end of block" is executed; the 8291A 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 8291A. Whenever a $101 B_{4} B_{3} B_{2} B_{1} B_{0}$ is written into the Auxiliary Mode Register, it is loaded with the data $B_{4} B_{3} B_{2} B_{1} B_{0}$. Setting the respective bits to " 1 " enables the following features:
$\mathbf{B}_{0}$-Enable Undefined Command Pass Through: This feature allows any commands not recognized by the 8291A to be handled in software. If enabled, this feature will cause the 8291A 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.
$\mathbf{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 $\mathrm{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 $T_{1}$ duration as a function of $B_{2}$ and of clock frequency.
$\mathbf{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 ${ }^{\circledR}$ Family. Interrupt registers are not affected by this bit.
$B_{4}$-Enable RFD Holdoff on GETor DEC: Setting this bit causes RFD to be held false until the "VSCMD" auxiliary command is written after GET, SDC, and DCL commands. This allows the device to hold off the bus until it has completed a clear or trigger similar to an unrecognized command.

## PARALLEL POLL PROTOCOL

Writing a 011USP ${ }_{3} \mathrm{P}_{2} \mathrm{P}_{1}$ into the Auxiliary Mode Register will enable $(\mathrm{U}=0)$ or disable $(\mathrm{U}=1)$ the 8291A for a parallel poll. When $\mathrm{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 8291A is enabled; only if the Parallel Poll Flag ('ist"' local message) matches this bit will the Parallel Poll Response, $\mathrm{PPR}_{\mathrm{N}}$, be sent true (Response= $\mathrm{S}+$ ist). The bits $P_{3} P_{2} P_{1}$ specify which of the eight data lines $\mathrm{PPR}_{\mathrm{N}}$ will be sent over. Thus, once the 8291A 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 $\mathrm{PPR}_{\mathrm{N}}$ true or false according to the comparison.

If a PP2* implementation is desired, the "Ipe" and "ist" local messages are all that are needed. Typically, the user will configure the 8291A 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 8291A 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 8291A must be used. In PP1, the 8291A is indirectly configured for Parallel Poll by the active controller on the GPIB. The sequence at the 8291A being enabled or disabled remotely is as follows:

1. The PPC message is received and is loaded into the Command Pass Through Register as an undefined command. 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 8291A, releasing the handshake.
3. Having received an undefined primary command, the 8291A is set up to receive an undefined secondary command (the PPE or PPD message). This message is also received into the CPT Register, the handshake is held off, and the CPT interrupt is generated.

NOTE: *As defined in IEEE Standard 488.
4. The microprocessor reads the PPE or PPD message and writes the command into the Auxiliary Mode Register (bit 7 should be cleared first). Finally, the microprocessor sends VSCMD and the handshake is released.

## End of Sequence (EOS) Register



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 8291A is a listener, and the "End on EOS Received" is enabled with bit $A_{2}$, then an END interrupt is generated in the Interrupt Status 1 Register whenever the byte in the Data-In Register matches the byte in the EOS Register.

If the 8291A is a talker, and the "Output EOI on EOS Sent" is enabled with bit $A_{3}$, then the EOI line is sent true with the next byte whenever the contents of the Data Out Register match the EOS register.

## Reset Procedure

The 8291A 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 (not Interrupt Enable Registers).
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. $\mathrm{N}_{\mathrm{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).
8. The rdy local message is sent.

The initialization state is released by an "immediate execute pon" command ( 00 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 intial conditions by writing into the Interrupt Enable, 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 PP2 Parallel Poll implementation is to be used the "Ipe" local message may be sent, enabling the 8291A for a Parallel Poll Response on an assigned line. (Refer to the section on Parallel Poll Protocol.)

## Using DMA

The 8291A may be connected to the Intel ${ }^{\circledR} 8237$ or 8257 DMA Controllers or the 8089 I/O Processor for DMA operation. The 8237 will be used to refer to any DMA controller. The DREQ pin of the 8291A requests a DMA byte transfer from the 8237. It is set by BO or BI flip flops, enabled by the DMAO and DMAI bits in the Interrupt Enable 2 Register. (After reading, the INT1 register BO and BI interrupts will be cleared but not BO and BI in DREQ equation.)

The $\overline{\text { DACK }}$ pin is driven by the 8237 in response to the DMA request. When $\overline{\text { DACK }}$ is true (active low) it sets $\overline{\mathrm{CS}}=\mathrm{RS} 0=\mathrm{RS} 1=\mathrm{RS} 2=0$ such that the $\overline{\mathrm{RD}}$ and $\overline{W R}$ signals sent by the 8237 refer to the Data In and Data Out Registers. Also, the DMA request line is reset by $\overline{\mathrm{DACK}}(\overline{\mathrm{RD}}+\overline{\mathrm{WR}})$.

DMA input sequence:

1. A data byte is accepted from the GPIB by the 8291A.
2. A BI interrupt is generated and DREQ is set.
3. $\overline{\mathrm{DACK}}$ and $\overline{\mathrm{RD}}$ are driven by the 8237 , the contents of the Data In Register are transferred to the system bus, and DREQ is reset.
4. The 8291A sends RFD true on the GPIB and proceeds with the Acceptor Handshake protocol.

DMA output sequence:

1. $\mathrm{A} B O$ interrupt is generated (indicating that a byte should be output) and DREQ is asserted.
2. $\overline{D A C K}$ and $\overline{W R}$ are driven by the 8237, a byte is transferred from the MCS bus into the Data Out Register, and DREQ is reset.
3. The 8291A sends DAV true on the GPIB and proceeds with the Source Handshake protocol.
It should be noted that each time the device is addressed (MTA + MLA + ton + lon), the Address Status Register should be read, and the 8237 should be initialized accordingly. (Refer to the 8237 or 8257 Data Sheets.)

## APPLICATION BRIEF

## System Configuration

## MICROPROCESSOR BUS CONNECTION

The 8291A is $8048 / 49,8051,8080 / 85$, and $8086 / 88$
compatible. The three address pins $\left(\mathrm{RS}_{0}, \mathrm{RS}_{1}, \mathrm{RS}_{2}\right)$ should be connected to the non-multiplexed address bus (for example: $A_{8}, A_{9}, A_{10}$ ). In case of 8080 , any address lines may be used. If the three lowest address bits are used ( $A_{0}, A_{1}, A_{2}$ ), then they must be demultiplexed first.

## EXTERNALTRANSCEIVERS CONNECTION

The 8293 GPIB Transceiver interfaces the 8291A directly to the IEEE-488 bus. The 8291A and two 8293's can be configured as a talker/listener (see Figure 6) or with the 8292 as a talker/listener/controller (see Figure 7). Absolutely no active or passive external components are required to comply with the complete IEEE-488 electrical specification.


Figure 6. 8291A and 8293 System Configuration

8291A
PRELOMONARY


Figure 7. 8291A, 8292, and 8293 System Configuration

## Start-Up Procedures

The following section describes the steps needed to initialize a typical 8291A system implementing a talker/listener interface and an $8291 \mathrm{~A} / 8292$ system implementing a talker/listener/controller interface.

## TALKER/LISTENER SYSTEM

Assume a general system configuration with the following features: (i) Polled system interface; (ii) Mode 1 addressing; (iii) same address for talker and listener; (iv) ASCII carriage return as the end-ofsequence (EOS) character; (v) EOI sent true with the last byte; and, (vi) 8 MHz clock.

Initialization. Initialization is accomplished with the following steps:

1. Pulse the RESET input or write 02 H to the Auxiliary Mode Register.
2. Write $\mathbf{0 O H}$ to the Interrupt Enable Registers 1 and 2. This disables interrupt and DMA.
3. Write 01 H to the Address Mode Register to select Mode 1 addressing.
4. Write 28 H to the Auxiliary Mode Register. This loads 8 H to the Auxiliary Register A matching the 8 MHz clock input to the internal T1 delay counter to generate the delay meeting the IEEE spec.
5. Write the talker/listener address to the Address $0 / 1$ register. The three most significant bits are zero.
6. Write an ASCII carriage return (ODH) to the EOS register.
7. Write 84 H to the Auxiliary Mode Register to allow $\overline{E O I}$ to be sent true when the EOS character is sent.
8. Write 00 H to the Auxiliary Mode Register. This writes the "Immediate Execute pon" message and takes the 8291A from the initialization state into the idle state. The 8291A will remain idle until the controller initiates some activity by driving $\overline{\text { ATN }}$ true.

Communication. The local CPU now polls the 8291A to determine which controller command has been received.

The controller addresses the 8291A by driving ATN, placing MLA (My Listen Address) on the bus and driving $\overline{\text { DAV }}$. If the lower five bits of the MLA message match the address programmed into the Address 0/1 register, the 8291A is addressed to listen. It would be addressed to talk if the controller sent the MTA message instead of MLA.

The ADSC bit in the Interrupt Status 2 Register indicates that the 8291A has been addressed or unaddressed. The TA and LA bits in the Address Status Register indicate whether the 8291A is talker ( $T A=1$ ), listener $(L A=1)$, both ( $T A=L A=1$ ) or unaddressed ( $T A=L A=0$ ).

If the 8291A is addressed to listen, the local CPU can read the Data-In Register whenever the BI (Byte In) interrupt occurs in the Interrupt Status 1 Register. If the END bit in the same register is also set, either EOI or a data byte matching the pattern in the EOS register has been received.

In the talker mode, the CPU writes data into the Byte-Out Register on BO (Byte Out) true.

## TALKER/LISTENER/CONTROLLER SYSTEM

Combined with the Intel 8292, the 8291A executes a complete IEEE-488-1978 controller function, The 8291A talks and listens via the data and handshake lines ( $\overline{\text { NRFD }}, \overline{\text { NDAC }}$ and $\overline{\mathrm{DAV}}$ ). The 8292 controls four of the five bus management lines ( $\overline{\mathrm{FFC}, \overline{S R Q}, \overline{\mathrm{ATN}} \text { and }}$ $\overline{\mathrm{REN}}$ ). $\overline{\mathrm{EO}}$, the fifth line, is shared. The 8291A drives and receives EOI when EOI is used as an end-ofblock indicator. The 8292 drives EOI along with ATN during a parallel poll command.

Once again, assume a general system configuration with the following features: (i) Polled system interface; (ii) 8292 as the system controller and controller-in-charge; (iii) ASCII carriage return (ODH) as the EOS identifier; (iv) EOI sent with the last character; and, ( $v$ ) an external buffer (8282) used to monitor the TCI line.

Initialization. In order to send a command across the GPIB, the 8292 has to drive $\overline{\text { ATN }}$, and the 8291A has to drive the data lines. Both devices therefore need initialization.

To initialize the 8292:

1. Pulse the RESET input. The 8292 will initially drive all outputs high. TCI, SPI, OBFI, IBFI and CLTH will then go low. The Interrupt Status, Interrupt Mask, Error Flag, Error Mask and Timeout registers will be cleared. The interrupt counter will be disabled and loaded with 255 . The 8292 will then monitor the status of the SYC pin. If high, the 8292 will pulse IFC true for at least $100 \mu \mathrm{~s}$ in compliance with the IEEE-488-1978 standard. It will then take control by asserting $\overline{\text { ATN }}$.
To initialize the 8291A, the following is necessary:
2. Write 00 H to Interrupt Enable registers 1 and 2. This disables interrupt and DMA.
3. With the 8292 as the controller-in-charge, it is impossible to address the 8292 via the GPIB. Therefore, the ton or lon modes of the 8291A must be used. To send comands, set the 8291A in the ton mode by writing 80 H to the Address Mode Register.
4. Write $\mathbf{2 6 H}$ to the Auxiliary Mode Register to match the T1 data settling time to the 6 MHz clock input.
5. Write an ASCII carriage return (ODH) to the EOS Register.
6. Write 84 H to the Auxiliary Mode Register in order to enable "Output EOI on EOS sent" and thus send EOI with the last character.
7. Write $\mathbf{0 O H}$-Immediate Execute pon-to the Auxiliary Mode Register to put the 8291A in the idle state.

Communication. Since the 8291A is in the ton mode, a BO interrupt is generated as soon as the immediate Execute pon command is written. The CPU writes the command into the Data Out Register, and repeats it on BO becoming true for as many commands as necessary. $\overline{\text { ATN }}$ remains continuously
true unless the GTSB (Go To Standby) command is sent to the 8292.
$\overline{\text { ATN }}$ has to be false in order to send data rather than commands from the controller. To do this, the following steps are needed:

1. Enable the TCI interrupt if not already enabled.
2. Wait for IBF (Input Buffer Full) in the 8292 Interrupt Status Register to be reset.
3. Write the GTSB (F6H) command to the 8292 Command Field Register.
4. Read the 8282 and wait for TCl to be true.
5. Write the ton $(80 \mathrm{H})$ and pon $(\mathrm{OOH})$ command to the 8291A Address Mode Register and Auxiliary Mode Registers respectively.
6. Wait for the BO interrupt to be set in the 8291A.
7. Write the data to the 8291A Data-Out Register.

Identically, the user could command the controller to listen rather than talk. To do that, write lon (40H) instead of ton into the Address Mode Register. Then wait for BI rather than BO to go true. Read the data Register.

## 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 .............................. 0.65 Watts
*NOTICE: 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[\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$ (Commercial) $]$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2 | $\mathrm{V}_{C c}+0.5$ | V |  |
| VOL | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=2 \mathrm{~mA} \mathrm{( } 4 \mathrm{~mA}$ for TR1 pin) |
| VOH | Output High Voltage | 2.4 |  | V | $1 \mathrm{OH}=-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}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{IOH}=-50 \mu \mathrm{~A} \end{aligned}$ |
| ILL | Input Leakage |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ to $\mathrm{V}_{\text {CC }}$ |
| I'OFL | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=0.45 \mathrm{~V}, \mathrm{~V}_{\text {CC }}$ |
| Icc | VCC Supply Current |  | 120 | mA | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |

## A.C. CHARACTERISTICS $\left[\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$ (Commercial)]

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AR }}$ | Address Stable Before $\overline{\text { READ }}$ | 0 |  | nsec |  |
| tra | Address Hold After $\overline{\text { READ }}$ | 0 |  | nsec |  |
| $t_{\text {RR }}$ | $\overline{\text { READ width }}$ | 140 |  | nsec |  |
| $t_{\text {AD }}$ | Address Stable to Data Valid |  | 250 | nsec |  |
| tri | $\overline{\text { READ to Data Valid }}$ |  | 100 | nsec |  |
| trdF | Data Float After $\overline{\text { READ }}$ | 0 | 60 | nsec |  |
| taw | Address Stable Before WRITE | 0 |  | nsec |  |
| twa | Address Hold After WRITE | 0 |  |  |  |
| tww | WRITE Width | 170 |  | nsec |  |
| tow | Data Set Up Time to the Trailing Edge of WRITE | 130 |  | nsec |  |
| two | Data Hold Time After WRITE | 0 |  | nsec |  |
| $t_{\text {DKDR4 }}$ | $\overline{\mathrm{RD}} \downarrow$ or $\overline{\mathrm{WR}} \downarrow$ to DREQ $\downarrow$ |  | 130 | nsec |  |
| tokdab | $R \mathrm{D} \downarrow$ to Valid Data $\left(D_{0}-D_{7}\right)$ |  | 200 | nsec | $\overline{\mathrm{DACK}} \downarrow$ to $\overline{\mathrm{RD}} \downarrow 0 \leqslant \mathrm{t} \leqslant 50 \mathrm{nsec}$ |

## WAVEFORMS

## READ



WRITE


## A.C. TIMING MEASUREMENT POINTS AND LOAD CONDITIONS



## GPIB TIMINGS ${ }^{1}$

| Symbol | Parameter | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: |
| TEOT13 ${ }^{2}$ | $\overline{\mathrm{EO}} \downarrow$ to TR1 $\uparrow$ | 135 | nsec | PPSS, ATN $=0.45 \mathrm{~V}$ |
| TEOD16 | EOI $\downarrow$ to $\overline{\text { DIO }}$ Valid | 155 | nsec | PPSS, ATN $=0.45 \mathrm{~V}$ |
| TEOT12 | $\overline{\mathrm{EOI}} \uparrow$ to TR1 $\downarrow$ | 155 | nsec | PPSS, ATN $=0.45 \mathrm{~V}$ |
| TATND4 | $\overline{\text { ATN }} \downarrow$ to $\overline{\text { NDAC }} \downarrow$ | 155 | nsec | TACS, AIDS |
| TATT14 | $\overline{\text { ATN }} \downarrow$ to TR1 $\downarrow$ | 155 | nsec | TACS, AIDS |
| TATT24 | $\overline{\text { ATN }} \downarrow$ to TR2 $\downarrow$ | 155 | nsec | TACS, AIDS |
| TDVND3-C | $\overline{\mathrm{DAV}} \downarrow$ to $\overline{\text { NDAC }} \uparrow$ | 650 | nsec | AH, CACS |
| TNDDV1 | $\overline{\text { NDAC }} \uparrow$ to $\overline{\mathrm{DAV}} \uparrow$ | 350 | nsec | SH, STRS |
| TNRDR1 | $\overline{\text { NRFD }} \uparrow$ to DREQ $\uparrow$ | 400 | nsec | SH |
| TDVDR3 | $\overline{\mathrm{DAV}} \downarrow$ to DREQ $\uparrow$ | 600 | nsec | AH, LACS, ATN $=2.4 \mathrm{~V}$ |
| TDVND2-C | $\overline{\mathrm{DAV}} \uparrow$ to $\overline{\mathrm{NDAC}} \downarrow$ | 350 | nsec | AH, LACS |
| TDVNR1-C | $\overline{\mathrm{DAV}} \uparrow$ to $\overline{\mathrm{NRFD}} \uparrow$ | 350 | nsec | AH, LACS, rdy=True |
| TRDNR3 | $\overline{\mathrm{RD}} \downarrow$ to $\overline{\mathrm{NRFD}} \uparrow$ | 500 | nsec | AH, LACS |
| TWRD15 | $\overline{\mathrm{WR}} \uparrow$ to $\overline{\mathrm{DIO}}$ Valid | 280 | nsec | SH, TACS, RS $=0.4 \mathrm{~V}$ |
| TWREO5 | $\overline{\mathrm{WR}} \uparrow$ to EOI Valid | 350 | nsec | SH, TACS |
| TWRDV2 | $\overline{\mathrm{WR}} \uparrow$ to $\overline{\mathrm{DAV}} \downarrow$ | $830+t_{\text {SYNC }}$ | nsec | High Speed Transfers Enabled, $\mathrm{N}_{\mathrm{F}}=\mathrm{f}_{\mathrm{C}}, \mathrm{t}_{\mathrm{SYNC}}=1 / 2 \cdot \mathrm{f}_{\mathrm{C}}$ |

## NOTES:

1. All GPIB timings are at the pins of the 8291A.
2. The last number in the symbol for any GPIB timing parameter is chosen according to the transition directions of the reference signals. The following table describes the numbering scheme.

| $\uparrow$ to $\uparrow$ | 1 |
| :--- | :--- |
| $\uparrow$ to $\downarrow$ | 2 |
| $\downarrow$ to $\uparrow$ | 3 |
| $\downarrow$ to $\downarrow$ | 4 |
| $\uparrow$ to VALID | 5 |
| $\downarrow$ to VALID | 6 |

## 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. The 8291A supports the complete set of IEEE-488 interface functions except for the controller. These include: SH1, AH1, T5, TE5, L3, LE3, SR1, RL1, PP1, DC1, DT1, and C0.
B. Addressing modes included in $\mathrm{T}, \mathrm{L}$ state diagrams.

Note that in Mode 3, MSA, OSA are generated only after secondary address validity check by the microprocessor (APT interrupt).
C. In these modified state diagrams, the IEEE-4881978 convention of negative (low true) logic is followed. This should not be confused with the Intel pin- and signal-naming convention based on positive logic. Thus, while the state diagrams below carry low true logic, the signals described elsewhere in this data sheet are consistent with Intel notation and are based on positive logic.

| Level | Logic | Convention |  |
| :---: | :---: | :---: | :---: |
|  |  | Intel |  |
| 0 | T | $\overline{\text { DAV }}$ | $\overline{\mathrm{DAV}}$ |
| 1 | F | $\overline{\mathrm{DAV}}$ | DAV |
| 0 | T | $\overline{\text { NDAC }}$ | $\overline{\text { NDAC }}$ |
| 1 | F | $\overline{\text { NDAC }}$ | NDAC |
| 0 | T | NRFD | $\overline{\text { NRFD }}$ |
| 1 | F | $\overline{\text { NRFD }}$ | NRFD |

Consider the condition when the Not-Ready-ForData signal (pin 37) is active. Intel indicates this active low signal with the symbol $\overline{\text { NRFD }}\left(\mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {OL }}\right.$ for $\mathrm{AH} ; \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{IL}}$ for SH ). The IEEE-488-1978 Standard, in its state diagrams, indicates the active state of this signal (True condition) with NRFD.
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 returns to state S.
2. $X$ overrides any other transition condition in the function.

Statement 2 simplifies the diagram, avoiding the explicit use of $X$ to condition all transitions from $S$ to other states.


Figure A-1. 8291A State Diagrams (Continued next page)


Figure A-1. 8291A State Diagrams (Continued next page)


Figure A-1. 8291A State Diagrams

## APPENDIX B

Table B-1. IEEE 488 Time Values

| Time Value <br> Identifier ${ }^{1}$ | Dunction (Applies to) | Description | Value |
| :---: | :---: | :--- | :--- |
| $\mathrm{T}_{1}$ | SH | Settling Time for Multiline Messages | $\geq 2 \mu \mathrm{~s}^{2}$ |
| $\mathrm{t}_{2}$ | $\mathrm{LC}, \overline{\mathrm{IC}, \mathrm{SH}, \mathrm{AH}, \mathrm{T}, \mathrm{L}}$ | Response to ATN | $\leq 200 \mathrm{~ns}$ |
| $\mathrm{~T}_{3}$ | AH | Interface Message Accept Time ${ }^{3}$ | $>0^{4}$ |
| $\mathrm{t}_{4}$ | $\mathrm{~T}, \mathrm{TE}, \mathrm{L}, \mathrm{LE}, \mathrm{C}, \mathrm{CE}$ | Response to IFC or REN False | $<100 \mu \mathrm{~s}$ |
| $\mathrm{t}_{5}$ | PP | Response to ATN+EOI | $\leq 200 \mathrm{~ns}$ |
| $\mathrm{~T}_{6}$ | C | Parallel Poll Execution Time | $\geq 2 \mu \mathrm{~s}$ |
| $\mathrm{~T}_{7}$ | C | Controller Delay to Allow Current Talker <br> to see ATN Message | $\geq 500 \mathrm{~ns}$ |
| $\mathrm{~T}_{8}$ | C | Length of IFC or REN False | $>100 \mu \mathrm{~s}$ |
| $\mathrm{~T}_{9}$ | C | Delay for EOI | $\geq 1.5 \mu \mathrm{~s}^{6}$ |

## NOTES:

${ }^{1}$ 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.
${ }^{2}$ If three-state drivers are used on the $\overline{\mathrm{DIO}}, \overline{\mathrm{DAV}}$, and $\overline{\mathrm{EOI}}$ lines, $\mathrm{T}_{1}$ may be:

1. $\geq 1100 \mathrm{~ns}$.
2. $\mathrm{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 \mathrm{~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.
${ }^{3}$ Time required for interface functions to accept, not necessarily respond to interface messages.
${ }^{4}$ Implementation dependent.
${ }^{5}$ Delay required for $\overline{\mathrm{EOI}}, \overline{\mathrm{NDAC}}$, and $\overline{\mathrm{NRFD}}$ signal lines to indicate valid states.
${ }^{6} \geq 600$ ns for three-state drivers.

## APPENDIX C THE THREE-WIRE HANDSHAKE



Figure C-1. 3-Wire Handshake Timing at 8291A

## 8292 <br> GPIB CONTROLLER

- Complete IEEE Standard 488 Controller Function
- Interface Clear (IFC) Sending Capability Allows Seizure of Bus Control and/or Initialization of the Bus
- Responds to Service Requests (SRQ)
- Sends Remote Enable (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 function with the 8291 GPIB Talker/Listener to implement the full IEEE Standard 488 controller function, including transfer control protocol. The 8292 is a preprogrammed Intel ${ }^{\circledR}$ 8041A.


Figure 1. 8291, 8292 Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{FFCL}}$ | 1 | 1 | IFC Received (Latched): The 8292 monitors the IFC Line (when not system controller) through this pin. |
| $\mathrm{X}_{1}, \mathrm{X}_{2}$ | 2, 3 | 1 | Crystal Inputs: Inputs for a crystal, LC or an external timing signal to determine the internal oscillator frequency. |
| $\overline{\text { RESET }}$ | 4 | 1 | Reset: Used to initialize the chip to a known state during power on. |
| $\overline{\mathrm{CS}}$ | 6 | 1 | Chip Select Input: Used to select the 8292 from other devices on the common data bus. |
| $\overline{\mathrm{RD}}$ | 8 | 1 | Read Enable: Allows the master CPU to read from the 8292. |
| $\mathrm{A}_{0}$ | 9 | 1 | 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{W R}$ | 10 | 1 | Write Enable: Allows the master CPU to write to the 8292 . |
| SYNC | 11 | 0 | Sync: 8041A instruction cycle synchronization signal; it is an output clock with a frequency of XTAL :15. |
| $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 12-19 | 1/0 | Data: 8 bidirectional lines used for communication between the central processor and the 8292's data bus buffers and status register. |
| $\mathrm{V}_{S S}$ | 7, 20 | P.S. | Ground: Circuit ground potential. |
| $\overline{\text { SRQ }}$ | 21 | 1 | Service Request: One of the IEEE control lines. Sampled by the 8292 when it is controller in charge. If true, SPI interrupt to the master will be generated. |
| $\overline{\text { ATNI }}$ | 22 | 1 | Attention In: Used by the 8292 to monitor the GPIB ATN control line. It is used during the transfer control procedure. |
| $\overline{\mathrm{FFC}}$ | 23 | I/O | Interface Clear: One of the GPIB management lines, as defined by IEEE Std. 488-1978, places all devices in a known quiescent state. |
| SYC | 24 | 1 | System Conroller: Monitors the system controller switch. |
| CLTH | 27 | 0 | Clear Latch: Used to clear the IFCR latch after being recognized by the 8292. Usually low (except after hardware Reset), it will be pulsed high when IFCR is recognized by the 8292. |
| $\overline{\text { ATNO }}$ | 29 | 0 | Attention Out: Controls the ATN control line of the bus through external logic for tcs and tca procedures. (ATN is a GPIB control line, as defined by IEEE Std. 488-1978.) |


| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 5,26,40 | P.S. | Voltage: +5 V supply input $\pm 10 \%$. |
| COUNT | 39 | 1 | Event Count: 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}$ sample period when using 5 MHz XTAL). It can be used for byte counting when connected to NDAC, or for block counting when connected to the EOI. |
| REN | 38 | 0 | Remote Enable: 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-1978. |
| $\overline{\text { DAV }}$ | 37 | I/O | Data Valid: Used during parallel poll to force the 8291 to accept the parallel poll status bits. It is also used during the tcs procedure. |
| $\overline{\text { IBFI }}$ | 36 | 0 | 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. |
| OBFI | 35 | 0 | 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{\mathrm{EO} 12}$ | 34 | I/O | End Or Identify: One of the GPIB management lines, as defined by IEEE Std. 488-1978. Used with ATN as Identify Message during parallel poll. |
| SPI | 33 | 0 | Special Interrupt: Used as an interrupt on events not initiated by the central processor. |
| TCI | 32 | 0 | 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 buffer. |
| CIC | 31 | 0 | Controller In Charge: Controls the S/R input of the SRQ bus transceiver. It can also be used to indicate that the 8292 is in charge of the GPIB bus. |

## FUNCTIONAL DESCRIPTION

The 8292 is an Intel 8041A which has been programmed as a GPIB Controller interface element. It is used with the 8291 GPIB Talker/Listener and two 8293 GPIB Transceivers to form a complete IEEE-488 Bus Interface for a microprocessor. The electrical interface is performed by the transceivers, data transfer is done by the talkerl listener, and control of the bus is done by the 8292. Figure 3 is a typical controller interface using Intel's GPIB peripherals.


Figure 3. Talker/Listener/Controller Configuration

The internal RAM in the 8041A is used as a special purpose register bank for the 8292 . Most of these registers (except for the interrupt flag) can be accessed through commands to the 8292. Table 2 identifies the registers used by the 8292 and how they are accessed.

Interrupt Status Register

| SYC | ERR | SRQ | EV | X | IFCR | IBF | OBF |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{7}$ | $\mathrm{D}_{0}$ |  |  |  |  |  |  |

The 8292 can be configured to interrupt the microprocessor on one of several conditions. Upon receipt of the interrupt the microprocessor must read the 8292 interrupt status register to determine which event caused the interrupt, and then the appropriate subroutine can be performed. The interrupt status register is read with $A_{0}$ high. With the exception of OBF and IBF, these interrupts are enabled or disabled by the SPI interrupt mask. OBF and IBF have their own bits in the interrupt mask (OBFI and $\overline{\mathrm{IBFI}}$ ).
OBF Output Buffer Full. A byte is waiting to be read by the microprocessor. This flag is cleared when the output data bus buffer is read.
IBF Input Buffer Full. The byte previously written by the microprocessor has not been read yet by the 8292. If another byte is written to the 8292 before this flag clears, data will be lost. IBF is cleared when the 8292 reads the data byte.
IFCR Interface Clear Received. The GPIB system controller has set IFC. The 8292 has become idle and is no longer in charge of the bus. The flag is cleared when the IACK command is issued.
EV Event Counter Interrupt. The requested number of blocks or data bytes has been transferred. The EV interrupt flag is cleared by the IACK command.
SRQ Service Request. Notifies the 8292 that a service request (SRQ) message has been received. It is cleared by the IACK command.
ERR Error occurred. The type of error can be determined by reading the error status register. This interrupt flag is cleared by the IACK command.
SYC System Controller Switch Change. Notifies the processor that the state of the system controller switch has changed. The actual state is contained in the GPIB Status Register. This flag is cleared by the IACK command.

Table 2. 8292 Registers


WRITE TO 8292


TIME OUT


Note: These registers are accessed by a special utility command, see page 6.

Interrupt Mask Register

| 1 | SPI | TCI | SYC | OBFI | $\overline{\mid B F I}$ | 0 | SRQ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{7}$ |  |  |  |  |  |  |  |

The Interrupt Mask Register is used to enable features and to mask the SPI and TCl interrupts. The flags in the Interrupt Status Register will be active even when masked out. The Interrupt Mask Register is written when $A_{0}$ is low and reset by the RINM command. When the register is read, $D_{1}$ and $D_{7}$ are undefined. An intertupt is enabled by setting the corresponding register bit.

SRQ Enable interrupts on SRQ received.
$\overline{I B F I}$ Enable interrupts on input buffer empty.
OBFI Enable interrupts on output buffer full.
SYC Enable interrupts on a change in the system controller switch.

TCI Enable interrupts on the task completed.
SPI Enable interrupts on special events.
NOTE: The event counter is enabled by the GSEC command, the error interrupt is enabled by the error mask register, and IFC cannot be masked (it will always cause an interrupt).

Controller Status Register

| CSBS | CA | X | X | SYCS | IFC | REN | SRQ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{D}_{7}$ |  |  |  |  |  |  |  |

The Controller Status Register is used to determine the status of the controller function. This register is accessed by the RCST command.
SRQ Service Request line active (CSRS).
REN Sending Remote Enable.
IFC Sending or receiving interface clear.
SYCS System Controller Switch Status (SACS).
CA Controller Active (CACS + CAWS + CSWS).
CSBS Controller Stand-by State (CSBS, CA) $=(0,0)-$ Controller Idle

GPIB Bus Status Register

| REN | DAV | EOI | $X$ | SYC | IFC | ATNI | SRQ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $D_{7}$ |  |  |  |  |  |  |  |

This register contains GPIB bus status information. It can be used by the microprocessor to monitor and manage the bus. The GPIB Bus Register can be read using the RBST command.
Each of these status bits reflect the current status of the corresponding pin on the 8292.
SRQ Service Request
ATNI Attention In
IFC Interface Clear
SYC System Controller Switch
EOI End or Identify
DAV Data Valid
REN Remote Enable

## Event Counter Register

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The Event Counter Register contains the initial value for the event counter. The counter can count pulses on pin 39 of the 8292 (COUNT). It can be connected to EOI or NDAC to count blocks or bytes respectively during standby state. A count of zero equals 256 . This register cannot be read, and is written using the WEVC command.

Event Counter Status Register

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

This register contains the current value in the event counter. The event counter counts back from the initial value stored in the Event Counter Register to zero and then generates an Event Counter Interrupt. This register cannot be written and can be read using a REVC command.

Time Out Register

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The Time Out Register is used to store the time used for the time out error function. See the individual timeouts (TOUT1, 2, 3) to determine the units of this counter. This Time Out Register cannot be read, and it is written with the WTOUT command.

## Time Out Status Register

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

This register contains the current value in the time out counter. The time out counter decrements from the original value stored in the Time Out Register. When zero is reached, the appropriate error interrupt is generated. If the register is read while none of the time out functions are active, the register will contain the last value reached the last time a function was active. The Time Out Status Register cannot be written, and it is read with the RTOUT command.

## Error Flag Register



Four errors are flagged by the 8292 with a bit in the Error Flag Register. Each of these errors can be masked by the Error Mask Register. The Error Flag Register cannot be written, and it is read by the IACK command when the error flag in the Interrupt Status Register is set.

TOUT1 Time Out Error 1 occurs when the current controller has not stopped sending ATN after receiving the TCT message for the time period specified by the Time Out Register. Each count in the Time Out Register is at least $1800 \mathrm{t}_{\mathrm{CY}}$. After flagging the error, the 8292 will remain in a loop trying to take control until the current controller stops sending ATN or a new command is written by the microprocessor. If a new command is written, the 8292 will return to the loop after executing it.

TOUT2 Time Out Error 2 occurs when the transmission between the addressed talker and listener has not started for the time period specified by the Time Out Register. Each count in the Time Out Register is at least $45 \mathrm{t}_{\mathrm{CY}}$. This feature is only enabled when the controller is in the CSBS state.

TOUT3 Time Out Error 3 occurs when the handshake signals are stuck and the 8292 is not succeeding in taking control synchronously for the time period specified by the Time Out Register. Each count in the Time Out Register is at least 1800 $t_{\mathrm{CY}}$. The 8292 will continue checking $\overline{\text { ATNI }}$ until it becomes true or a new command is received. After performing the new command, the 8292 will return to the $\overline{\mathrm{ATNI}}$ checking loop.
USER User error occurs when request to assert iFC or REN was received and the 8292 was not the system controller.

## Error Mask Register



The Error Mask Register is used to mask the interrupt from a particular type of error. Each type of error interrupt is enabled by setting the corresponding bit in the Error Mask Register. This register can be read with the RERM command and written with $\mathrm{A}_{0}$ low.

## Command Register

| 1 | 1 | 1 | $O P$ | $C$ | $C$ | $C$ | $C$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Commands are performed by the 8292 whenever a byte is written with $A_{0}$ high. There are two categories of commands distinguished by the OP bit (bit 4). The first category is the operation command ( $O P=1$ ). These commands initiate some action on the interface bus. The second category is the utility commands ( $O P=0$ ). These commands are used to aid the communication between the processor and the 8292.

## OPERATION COMMANDS

Operation commands initiate some action on the GPIB interface bus. It is using these commands that the control functions such as polling, taking and passing control, and system controller functions are performed. A TCl interrupt is generated upon successful completion of each of these functions.

## F0 - SPCNI - Stop Counter Interrupts

This command disables the internal counter interrupt so that the 8292 will stop interrupting the master on event counter underflows. However, the counter will continue counting and its contents can still be used.

## F1 - GIDL - Go To Idle

This command is used during the transfer of control procedure while transferring control to another controller. The 8292 will respond to this command only if it is in the active state. $\overline{\text { ATNO }}$ will go high, and CIC will be high so that this 8292 will no longer be driving the ATN line on the GPIB interface bus.

## F2 - RST - Reset

This command has the same effect as asserting the external reset on the 8292 . For details, refer to the reset procedure described later.

## F3 - RSTI - Reset Interrupts

This command resets any pending interrupts and clears the error flags. The 8292 will not return to any loop it was in (such as from the time out interrupts).

## F4 - GSEC - Go To Standby, Enable Counting

The function causes $\overline{\text { ATNO }}$ to go high and the counter will be enabled. If the 8292 was not the active controller, this command will exit immediately. If the 8292 is the active controller, the counter will be loaded with the value stored in the Event Counter Register, and the internal interrupt will be enabled so that when the counter reaches zero, the SPI interrupt will be generated. SPI will be generated every 256 counts thereafter until the controller exits the standby state or the SPCNI command is written. An initial count of 256 (zero in the Event Counter Register) will be used if the WEVC command is not executed. If the data transmission does not start, a TOUT2 error will be generated.

## F5 - EXPP - Execute Parallel Poll

This command initiates a parallel poll by asserting ATN and EOI (IDY message) true. The 8291 should be previously configured as a listener. Upon detection of DAV true, the 8291 enters ACDS and latches the parallel poll response (PPR) byte into its data in register. The master will be interrupted by the 8291 BI interrupt when the PPR byte is available. No interrupts except the $\overline{\mathrm{IBFI}}$ will be generated by the 8292 . The 8292 will respond to this command only when it is the active controller.

## F6 - GTSB - Go To Standby

If the 8292 is the active controller, $\overline{\text { ATNO }}$ will go high then TCl will be generated. If the data transmission does not start, a TOUT2 error will be generated.

## F7 - SLOC - Set Local Mode

If the 8292 is the system controller, then REN will be asserted false for at least $100 \mu \mathrm{sec}$. If it is not the system controller, the User Error bit will be set in the Error Flag Register.

## F8 - SREM - Set Interface To Remote Control

This command will set REN true if this 8292 is the system controller. If not, the User Error bit will be set in the Error Flag Register.

## F9 - ABORT - Abort All Operation, Clear Interface

This command will cause IFC to be asserted true for at least $100 \mu \mathrm{sec}$ if this 8292 is the system controller. If it is in CIDS, it will take control over the bus (see the TCNTR command).

## FA - TCNTR - Take Control

The transfer of control procedure is coordinated by the master with the 8291 and 8292 . When the master receives a TCT message from the 8291, it should issue the TCNTR command to the 8292. The following events occur to take control:

1. The 8292 checks to see if it is in CIDS, and if not, it exits.
2. Then $\overline{A T N}$ is checked until it becomes high. If the current controller does not release ATN for the time specified by the Time Out Register, then a TOUT1 error is generated. The 8292 will return to this loop after an error or any command except the RST and RSTI commands.
3. After the current controller releases ATN, the 8292 will assert $\overline{\mathrm{ATNO}}$ and $\overline{\mathrm{CIC}}$ low.
4. Finally, the TCI interrupt is generated to inform the master that it is in control of the bus.

## FC - TCASY - Take Control Asynchronously

TCAS transfers the 8292 from CSBS to CACS independent of the handshake lines. If a bus hangup is detected (by an error flag), this command will force the 8292 to take control (asserting ATN) even if the AH function is not in ANRS (Acceptor Not Ready State). This command should be used very carefully since it may cause the loss of a data byte. Normally, control should be taken synchronously. After checking the controller function for being in the CSBS (else it will exit immediately), $\overline{\text { ATNO }}$ will go low, and a TCI interrupt will be generated.

## FD - TCSY - Take Control Synchronously

There are two different procedures used to transfer the 8292 from CSBS to CACS depending on the state of the 8291 in the system. If the 8291 is in "continuous AH cycling" mode (Aux. Reg. $A 0=A 1=1$ ), then the following procedure should be followed:

1. The master microprocessor stops the continuous AH cycling mode in the 8291;
2. The master reads the 8291 Interrupt Status 1 Register;
3. If the END bit is set, the master sends the TCSY command to the 8292;
4. If the END bit was not set, the master reads the 8291 Data In Register and then waits for another BI interrupt from the 8291. When it occurs, the master sends the 8292 the TCSY command.
If the 8291 is not in AH cycling mode, then the master just waits for a BI interrupt and then sends the TCSY command. After the TCSY command has been issued, the 8292 checks for $\overline{\text { CSBS }}$. If $\overline{\text { CSBS, }}$, then it exits the routine. Otherwise, it then checks the DAV bit in the GPIB status. When DAV becomes false, the 8292 will
wait for at least $1.5 \mu \mathrm{sec}$. ( T 10 ) and then $\overline{\text { ATNO }}$ will go low. If DAV does not go low, a TOUT3 error will be generated.

## FE - STCNI - Start Counter Interrupts

This command enables the internal counter interrupt. The counter is enabled by the GSEC command.

## UTILITY COMMANDS

All these commands are either Read or Write to registers in the 8292. Upon completion of Read commands, the TCI (Task Completed Interrupt) will be generated. Note that writing to the Error Mask Register and the Interrupt Mask Register are done directly.

## E1 - WTOUT - Write To Time Out Register

The byte written to the data bus buffer (with $\mathrm{A}_{0}=0$ ) following this command will determine the time used for the time out function. Since this function is implemented in software, this will not be an accurate time measurement. This feature is enable or disable by the Error Mask Register. No interrupts except for the $\overline{\mid B F I}$ will be generated upon completion.

## E2 - WEVC - Write To Event Counter

The byte written to the data bus buffer (with $A_{0}=0$ ) following this command will be loaded into the Event Counter Register and the Event Counter Status for byte counting or EOI counting. Only $\overline{\mathrm{IBFI}}$ will indicate completion of this command.

## E3 - REVC - Read Event Counter Status

This command transfers the contents of the Event Counter into the data bus buffer. A TCl is generated when the data is available in the data bus buffer.

## E4 - RERF - Read Error Flag Register

This command transfers the contents of the Error Flag Register into the data bus buffer. A TCI is generated when the data is available.

## E5 - RINM - Read Interrupt Mask Register

This command transfers the contents of the Interrupt Mask Register into the data bus buffer. This register is available to the processor so that it does not need to store this information elsewhere. A TCI is generated when the data is available in the data bus buffer.

## E6 - RCST - Read Controller Status Register

This command transfers the contents of the Controller Status Register into the data bus buffer and a TCI interrupt is generated.

## E7 - RBST - Read GPIB Bus Status Register

This command transfers the contents of the GPIB Bus Status Register into the data bus buffer, and a TCI interrupt is generated when the data is available.

## E9 - RTOUT - Read Time Out Status Register

This command transfers the contents of the Time Out Status Register into the data bus buffer, and a TCl interrupt is generated when the data is available.

## EA - RERM - Read Error Mask Register

This command transfers the contents of the Error Mask Register to the data bus buffer so that the processor does not need to store this information elsewhere. A TCI interrupt is generated when the data is available.

## Interrupt Acknowledge

| SYC | ERR | SRQ | EV | 1 | IFCR | 1 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $D_{7}$ |  |  |  |  |  |  |  |

Each named bit in an Interrupt Acknowledge (IACK) corresponds to a flag in the Interrupt Status Register. When the 8292 receives this command, it will clear the SPI and the corresponding bits in the Interrupt Status Register. If not all the bits were cleared, then the SPI will be set true again. If the error flag is not acknowledged by the IACK command, then the Error Flag Register will be transferred to the data bus buffer, and a TCI will be generated.

NOTE: XXXX1X11 is an undefined operation or utility command, so no conflict exists between the IACK operation and utility commands.

## SYSTEM OPERATION

## 8292 To Master Processor Interface

Communication between the 8292 and the Master Processor can be either interrupt based communication or based upon polling the interrupt status register in predetermined intervals.

## Interrupt Based Communication

Four different interrupts are available from the 8292:
OBFI Output Buffer Full Interrupt
$\overline{\text { IBFI }}$ Input Buffer Not Full Interrupt
TCI Task Completed Interrupt
SPI Special Interrupt
Each of the interrupts is enabled or disabled by a bit in the interrupt mask register. Since OBFI and IBFI are directly connected to the OBF and IBF flags, the master can write a new command to the input data bus buffer as soon as the previous command has been read.
The TCI interrupt is useful when the master is sending commands to the 8292. The pending TCI will be cleared with each new command written to the 8292. Commands sent to the 8292 can be divided into two major groups:

1. Commands that require response back from the 8292 to the master, e.g., reading register.
2. Commands that initiate some action or enable features but do not require response back from the 8292, e.g., enable data bus buffer interrupts.

With the first group, the TCI interrupt will be used to indicate that the required response is ready in the data bus buffer and the master may continue and read it. With the second group, the interrupt will be used to indicate completion of the required task, so that the master may send new commands.

The SPI should be used when immediate information or special events is required (see the Interrupt Status Register).

## "Polling Status" Based Communication

When interrupt based communication is not desired, all interrupts can be masked by the interrupt mask register. The communication with the 8292 is based upon sequential poll of the interrupt status register. By testing the OBF and IBF flags, the data bus buffer status is determined while special events are determined by testing the other bits.

## Receiving IFC

The IFC pulse defined by the IEEE-488 standard is at least $100 \mu \mathrm{sec}$. In this time, all operation on the bus should be aborted. Most important, the current controller (the one that is in charge at that time) should stop sending ATN or EOI. Thus, IFC must externally gate CIC (controller in charge) and $\overline{\text { ATNO }}$ to ensure that this occurs.

## Reset and Power Up Procedure

After the 8292 has been reset either by the external reset pin, the device being powered on, or a RST command, the following sequential events will take place:

1. All outputs to the GPIB interface will go high (SRQ, $\overline{A T N I, ~ I F C, ~ S Y C, ~ C L T H, ~} \overline{\text { ATNO, }} \overline{C I C}, \mathrm{TCI}, \mathrm{SPI}, \overline{E O I}$, OBFI, IBFI, $\overline{D A V}, \overline{R E V})$.
2. The four interrupt outputs (TCI, SPI, OBFI, $\overline{\mathrm{BFI}}$ ) and CLTH output will go low.
3. The following registers will be cleared: Interrupt Status Interrupt Mask
Error Flag
Error Mask
Time Out
Event Counter ( $=256$ ), Counter is disabled.
4. If the 8292 is the system controller, an ABORT command will be executed, the 8292 will become the controller in charge, and it will enter the CACS state.

If it is not the system controller, it will remain in CIDS.

## System Configuratian

The 8291 and 8292 must be interfaced to an IEEE-488 bus meeting a variety of specifications including drive capability and loading characteristics. To interface the 8291 and the 8292 without the 8293's, several external gates are required, using a configuration similar to that used in Figure 5. 8292


Figure 4. 8291 and 8292 System Configuration


Figure 5. 8291, 8292, and 8293 System Configuration

## ABSOLUTE MAXIMUM RATINGS*


*NOTICE: 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 $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}: 8292, \mathrm{~V}_{\mathrm{CC}}= \pm 5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL1 }}$ | Input Low Voltage (All Except $\mathrm{X}_{1}, \mathrm{X}_{2}, \overline{\text { RESET }}$ ) | -0.5 | 0.8 | V |  |
| $\mathrm{V}_{\text {IL2 }}$ | Input Low Voltage ( $\mathrm{X}_{1}, \mathrm{X}_{2}, \overline{\mathrm{RESET}}$ ) | -0.5 | 0.6 | V |  |
| $\mathrm{V}_{\mathrm{IH} 1}$ | Input High Voltage (All Except $\mathrm{X}_{1}, \mathrm{X}_{2}, \overline{\text { RESET }}$ ) | 2.2 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 2}$ | Input High Voltage ( $\mathrm{X}_{1}, \mathrm{X}_{2}, \overline{\text { RESET }}$ ) | 3.8 | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) |  | 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}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage Current (COUNT, $\overline{\mathrm{FCCL}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}, \mathrm{A}_{0}$ ) |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{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}_{\text {SS }}+0.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathbf{L 1} 1}$ | Low Input Load Current (Pins 21-24, 27-38) |  | 0.5 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{L} 12}$ | Low Input Load Current ( $\overline{\mathrm{RESET}}$ ) |  | 0.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Total Supply Current |  | 125 | mA | Typical $=65 \mathrm{~mA}$ |
| IH | Input High Leakage Current (Pins 21-24, 27-38) |  | 100 | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{C C}$ |
| $\mathrm{CIN}^{\text {N }}$ | Input Capacitance |  | 10 | pF |  |
| $\mathrm{Cl}_{1 / \mathrm{O}}$ | I/O Capacitance |  | 20 | pF |  |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}: 8292, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$ ) DBB READ

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A R}$ | $\overline{C S}, A_{0}$ Setup to $\overline{R D} \downarrow$ | 0 |  | ns |  |
| $t_{\text {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 |  | 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{DF}}$ | $\overline{\mathrm{RD}} \uparrow$ to Data Float Delay |  | 100 | 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_{\text {WA }}$ | CS, A $A_{0}$ Hold After WR $\uparrow$ | 0 |  | ns |  |
| $t_{\text {WW }}$ | WR Pulse Width | 250 |  | ns |  |
| $t_{D W}$ | Data Setup to WR $\uparrow$ | 150 |  | ns |  |
| $t_{\text {WD }}$ | Data Hold After WR $\downarrow$ | 0 |  | ns |  |

COMMAND TIMINGS ${ }^{[1,3]}$

| Code | Name | $\begin{aligned} & \text { Execution } \\ & \text { Time } \end{aligned}$ | IBFIt | TCI ${ }^{[2]}$ | SPI | ATNO | $\overline{\text { CIC }}$ | IFC | REN | EOI | $\overline{\text { DAV }}$ | Comments |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| E1 | WTOUT | 63 | 24 |  |  |  |  |  |  |  |  |  |
| E2 | WEVC | 63 | 24 |  |  |  |  |  |  |  |  |  |
| E3 | REVC | 71 | 24 | 51 |  |  |  |  |  |  |  |  |
| E4 | RERF | 67 | 24 | 47 |  |  |  |  |  |  |  |  |
| E5 | RINM | 69 | 24 | 49 |  |  |  |  |  |  |  |  |
| E6 | RCST | 97 | 24 | 77 |  |  |  |  |  |  |  |  |
| E7 | RBST | 92 | 24 | 72 |  |  |  |  |  |  |  |  |
| E8 |  |  |  |  |  |  |  |  |  |  |  |  |
| E9 | RTOUT | 69 | 24 | 49 |  |  |  |  |  |  |  |  |
| EA | RERM | 69 | 24 | 49 |  |  |  |  |  |  |  |  |
| F0 | SPCNI | 53 | 24 |  |  |  |  |  |  |  |  | Count Stops After 39 |
| F1 | GIOL | 88 | 24 | 70 |  | $\uparrow 61$ | $\uparrow 61$ |  |  |  |  |  |
| F2 | RST | 94 | 24 |  | 152 |  |  |  |  |  |  | Not System Controller |
| F2 | RST | 214 | 24 | 192 | $\downarrow 52$ | \$179 | $\downarrow 174$ | $\downarrow 101$ |  |  |  | System Controller |
| F3 | RSTI | 61 | 24 |  |  |  |  |  |  |  |  |  |
| F4 | GSEC | 125 | 24 | 107 |  | 498 |  |  |  |  |  |  |
| F5 | EXPP | 75 | 24 |  |  |  |  |  | $\begin{aligned} & \mathbf{\downarrow 5 3} \\ & \uparrow 59 \\ & \hline \end{aligned}$ | $\begin{aligned} & \downarrow 55 \\ & \uparrow 57 \end{aligned}$ |  |  |
| F6 | GTSB | 118 | 24 | 100 |  | $\uparrow 91$ |  |  |  |  |  |  |
| F7 | SLOC | 73 | 24 | 55 |  |  |  | $\uparrow 46$ |  |  |  |  |
| F8 | SREM | 91 | 24 | 73 |  |  |  | 164 |  |  |  |  |
| F9 | ABORT | 155 | 24 | 133 |  | $\downarrow 120$ | $\downarrow 115$ | $\downarrow 42$ |  |  |  |  |
| FA | TCNTR | 108 | 24 | 86 |  | $\downarrow 71$ | 168 |  |  |  |  |  |
| FC | TCAS | 92 | 24 | 67 |  | $\downarrow 55$ |  |  |  |  |  |  |
| FD | TCSY | 115 | 24 | 91 |  | $\downarrow 80$ |  |  |  |  |  |  |
| FE | STCNI | 59 | 24 |  |  |  |  |  |  |  |  | Starts Count After 43 |
| PIN | RESET | 29 | - | $\downarrow 7$ | $\downarrow 7$ |  |  |  |  |  |  | Not System Controller |
| X | IACK | 116 | - |  | $\begin{aligned} & \downarrow 73 \\ & \uparrow 98 \\ & \hline \end{aligned}$ |  |  |  |  |  |  | If Interrupt Pending |

Notes:

1. All times are multiples of $\mathrm{t}_{\mathrm{CY}}$ from the 8041A command interrupt.
2. TCl clears after $7 \mathrm{t}_{\mathrm{CY}}$ on all commands.
3. $\uparrow$ indicates a level transition from low to high, $\downarrow$ indicates a high to low transition.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


CLOCK DRIVER CIRCUITS

## CRYSTAL OSCILLATOR MODE



CRYSTAL SERIES RESISTANCE SHOULD BE $<75 \Omega$ AT 6 MHz ; <180』 AT 3.6 MHz .

## DRIVING FROM EXTERNAL SOURCE



BOTH XTAL1 AND XTAL2 SHOULD BE DRIVEN.
RESISTORS TO $V_{C C}$ ARE NEEDED TO ENSURE $V_{I H}=3.8 \mathrm{~V}$ IF TTL CIRCUITRY IS USED.

## LC OSCILLATOR MODE



EACH C SHOULD BE APPROXIMATELY 20 PF, INCLUDING STRAY CAPACITANCE.

## WAVEFORMS

## READ OPERATION-DATA BUS BUFFER REGISTER



## WRITE OPERATION - DATA BUS BUFFER REGISTER



## APPENDIX

The following tables and state diagrams were taken from the IEEE Standard Digital Interface for Program-
mable Instrumentation, IEEE Std. 488-1978. This document is the official standard for the GPIB bus and can be purchased from IEEE, 345 East 47th St., New York, NY 10017.

C MNEMONICS

| Messages | Interface States |
| :---: | :---: |
| ```pon = power on rsc = request system control rpp = request parallel poll gts =go to standby tca = take control asynchronously tcs = take control synchronously sic = send interface clear sre = send remote enable IFC = interface clear ATN = attention TCT = take control``` | CIDS = controller idle state <br> CADS = controller addressed state <br> CTRS = controller transfer state <br> CACS = controller active state <br> CPWS = controller parallel poll wait state <br> CPPS = controller parallel poll state <br> CSBS = controller standby state <br> CSHS = controller standby hold state <br> CAWS = controller active wait state <br> CSWS = controller synchronous wait state <br> CSRS = controller service requested state <br> CSNS = controller service not requested state <br> SNAS = system control not active state <br> SACS = system control active state <br> SRIS = system control remote enable idle state <br> SRNS = system control remote enable not active state <br> SRAS = system control remote enable active state <br> SIIS = system control interface clear idle state <br> SINS = system control interface clear not active state <br> SIAS = system control interface clear active state <br> (ACDS $)=$ accept data state (AH function) <br> ANRS) = acceptor not ready state (AH function) <br> SDYS = source delay state (SH function) <br> (STRS) = source transfer state (SH function) <br> TADS) $=$ talker addressed state ( $T$ function) |



Figure A.1. C State Diagram

## REMOTE MESSAGE CODING



The $1 / 0$ coding on ATN when sent concurrent with multiline messages has been added to this revision for interpretive convenience.

## NOTES:

1. D1-D8 specify the device dependent data bits.
2. E1-E8 specify the device dependent code used to indicate the EOS message.
3. L1-L5 specify the device dependent bits of the device's listen address.
4. T1-T5 specify the device dependent bits of the device's talk address.
5. S1-S5 specify the device dependent bits of the device's secondary address.
6. S specifies the sense of the PPR.

Response $=\overline{\mathbf{S} \oplus \text { ist }}$
P1-P3 specify the PPR message to be sent when a parallel poll is executed.

| P3 | P2 | P1 | PPR Message |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | PPR1 |

- . . .
$\begin{array}{lll}\cdot & \cdot & . \\ i & .\end{array}$
$11 \begin{array}{llll}1 & 1 & \text { PPR8 }\end{array}$

7. D1-D4 specify don't-care bits that shall not be decoded by the receiving device. It is recommended that all zeroes be sent.
8. $\mathrm{S} 1-\mathrm{S} 6, \mathrm{~S} 8$ specify the device dependent status. (DIO7 is used for the RQS message.)
9. The source of the message on the ATN line is always the C function, whereas the messages on the DIO and EOI lines are enabled by the $T$ function.
10. The source of the messages on the ATN and EOI lines is always the C function, whereas the source of the messages on the DIO lines is always the PP function.
11. This code is provided for system use, see 6.3.

## 8293

GPIB TRANSCEIVER

\author{

- Nine Open-collector or Three-state Line Drivers <br> - 48 mA Sink Current Capability on Each Line Driver <br> - Nine Schmitt-type Line Receivers <br> - High Capacitance Load Drive Capability <br> - Single 5V Power Supply <br> - 28-Pin Package <br> - Low Power HMOS Design
}
- On-chip Decoder for Mode Configuration
- Power Up/Power Down Protection to
Prevent Disrupting the IEEE Bus
- Connects with the 8291A and 8292 to Form an IEEE Standard 488 Interface Talker/Listener/Controller with no Additional Components

■ Only Two 8293's Required per GPIB Interface

- On-Chip IEEE-488 Bus Terminations

The Intel ${ }^{\circledR} 8293$ GPIB Transceiver is a high-current, non-inverting buffer chip designed to interface the 8291A GPIB Talker/Listener, or the 8291A/8292 GPIBTalker/Listener/Controller combination, to the IEEE Standard 488-1978 Instrumentation Interface Bus. Each GPIB interface would contain two 8293 Bus Transceivers. In addition, the 8293 can also be used as a general-purpose bus driver.


Figure 1. 8291A, 8292, 8293 Block Diagram


Figure 2. Pin Configuration

8293
PRELINONARY

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :--- | :---: | :---: | :---: |
| BUS1- <br> BUS9 | 12,13, <br> $15-19$, <br> 21,22 | I/O | GPIB Lines, GPIB Side: These are <br> the IEEE-488 bus interface <br> driver/receivers, or TTL-compatible <br> inputs on the 8291A/8292 side, <br> depending on the mode used. Their <br> use is programmed by the two mode <br> select pins, OPTA and OPTB. |
| DATA1- <br> DATA10 | $5-11$, <br> $23-25$ | I/O | GPIB Lines, 8291A/92 Side: These <br> are the pins to be connected to the <br> 8291A and 8292 to interface with the <br> GPIB. Their use is programmed by <br> the two mode select pins, OPTA and <br> OPTB. All these pins areTTL compa- <br> tible. |
| T/ $\overline{1} 1$ | 1 | I | Transmit Receive 1: This pin con- <br> trols the direction for NDAC, NRFD, <br> DAV, and DIO1-DIO8. Input is TTL |
| $T / \bar{R} 2$ | 2 | I | Transmit Receive 2: This pin con- <br> trols the direction for EOI. Input is <br> TTL compatible. |


| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\overline{\mathrm{EOI}}$ | 3 | 1/O | End Or Identify: This pin indicates the end of a multiple byte transfer or, in conjunction with ATN, addresses the device during a polling sequence. It connects to the 8291A and is switched between transmit and receive by $T / \bar{R} 2$. This pin is TTL compatible. |
| $\overline{\text { ATN }}$ | 4 | 0 | Attention: This pin is used by the 8291A to monitor the GPIB ATN control line. It specifies how data on the DIO lines is to be interpreted. This output is TTL compatible. |
| OPTA OPTB | $\begin{aligned} & 27 \\ & 26 \end{aligned}$ | I | Mode Select: These two pins are to control the function of the 8293. A truth table of how they program the various modes is in Table 2. |
| $\mathrm{V}_{\mathrm{Cc}}$ | 28 | P.S. | Voltage: Positive power supply ( 5 V $\pm 10 \%$ ). |
| GND | 14, 20 | P.S. | Ground: Circuit ground. |

Table 2. 8293 Mode Selection Pin Mapping

| Pin Name | Pin No. | IEEE Implementation Name |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Mode 0 | Mode 1 | Mode 2 | Mode 3 |
| OPTA | 27 | 0 | 1 | 0 | 1 |
| OPTB | 26 | 0 | 0 | 1 | 1 |
| DATA1 | 5 | IFC | $\overline{\text { DIO8 }}$ | IFC | $\overline{\text { DIO8 }}$ |
| BUS1 | 12 | IFC* | DIO8* | IFC* | DIO8* |
| DATA2 | 6 | REN | DI07 | REN | DIO7 |
| BUS2 | 13 | REN* | DIO7* | REN* | DIO7* |
| DATA3 | 7 | NC | DIO6 | EOI2 | DIO6 |
| BUS3 | 15 | EOI* | DIO6* | EOI* | DIO6* |
| DATA4 | 8 | $\overline{\text { SRQ }}$ | DIO5 | SRQ | DIO5 |
| BUS4 | 16 | SRQ* | DIO5* | SRQ* | DIO5* |
| DATA5 | 9 | $\overline{\text { NRFD }}$ | $\overline{\text { DIO4 }}$ | $\overline{\text { NRFD }}$ | $\overline{\mathrm{DIO4}}$ |
| BUS5 | 17 | NRFD* | DIO4* | NRFD* | DIO4* |
| DATA6 | 10 | NDAC | $\overline{\mathrm{D}, 03}$ | NDAC | $\overline{\text { DIO3 }}$ |
| BUS6 | 18 | NDAC* | DIO3* | NDAC* | DIO3* |
| DATA7 | 11 | T/R101 | NC | ATNI | ATNO |
| DATA8 | 23 | T/R̄102 | $\overline{\mathrm{DIO}}$ | $\overline{\text { ATNO }}$ | $\overline{\text { DIO2 }}$ |
| BUS7 | 19 | ATN* | DIO2* | ATN* | DIO2* |
| DATA9 | 24 | GIO1 | $\overline{\text { DAV }}$ | CIC | $\overline{\text { DAV }}$ |
| BUS8 | 21 | GIO1* | DAV* | CLTH | DAV* |
| DATA10 | 25 | GIO2 | DIO1 | IFCL | DIO1 |
| BUS9 | 22 | GIO2* | DIO1* | SYC | DIO1* |
| T/R1 | 1 | T/R1 | T/R1 | T/R1 | T/R1 |
| T/R2 | 2 | T/R2 | NC | T/R2 | IFCL |
| EOI | 3 | EOI | EOI | EOI | EOI |
| $\overline{\text { ATN }}$ | 4 | $\overline{\text { ATN }}$ | $\overline{\text { ATN }}$ | ATN | $\overline{\text { ATN }}$ |

[^31]
## GENERAL DESCRIPTION

The 8293 is a bidirectional transceiver. It was designed to interface the Intel 8291A GPIB Talker/Listener and the Intel ${ }^{\circledR} 8292$ GPIB Controller to the IEEE Standard 488-1978 Instrumentation Bus (also referred to as the GPIB). The Intel GPIB Transceiver meets or exceeds all of the electrical specifications defined in the IEEE Standard 4881978, Section 3.3-3.5, including the bus termination specifications.

The 8293 can be hardware programmed to one of four modes of operation. These modes allow the 8293 to be configured to support both a Talker/Listener/Controller environment and a Talker/Listener environment. In addition, the 8293 can be used as a general-purpose, threestate (push-pull) or open-collector bus transceiver with nine receiver/drivers. Two modes each are used to support a Talker/Listener (see Figure 3) and a Talker/Listener/Controller environment (see Figure 4). Mode 1 is used in general-purpose environments.


Figure 3. Talker/Listener Configuration


Figure 4. Talker/Listener/Controller Configuration


Figure 5. Talker/Listener Control Configuration

Table 3. Mode 0 Pin Description

| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :--- | | T/R1 | 1 | I |
| :---: | :---: | :--- |
| Transmit Receive 1 Direction control |  |  |
| for NDAC and NRFD. If T/R1 is high, then |  |  |
| NDAC* and NRFD* are receiving. Input is |  |  |
| TTL compatible. |  |  |

Table 3. Mode 0 Pin Description (Continued)

| Symbol | Pin <br> No. | Type | Name and Function |
| :--- | :---: | :---: | :--- |\(\left|\begin{array}{|l|c|l|}\hline NRFD*^{*} \& 17 \& I/O <br>

\hline Not Ready For Data: IEEE GPIB bus <br>
handshake control line. When an input, <br>
it is a TTL compatible Schmitt-trigger. <br>
When an output, it is an open-collector <br>
driver with a 48 mA current sinking <br>
capability.\end{array}\right|\)

$\left.$| Symbol | Pin <br> No. | Type | Name and Function |
| :--- | :---: | :---: | :--- |\(\left|\begin{array}{l}IFC* <br>


\hline 12\end{array}\right| 1\)| Interface Clear: IEEE GPIB bus control |
| :--- |
| line. This input is a TTL compatible |
| Schmitt-trigger. | \right\rvert\,



Figure 6. Talker/Listener Data Configuration

Table 4. Mode 1 Pin Description

| Symbol | $\begin{aligned} & \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| T/R1 | 1 | 1 | Transmit Recelve 1: Controls the direction for DAV and the DIO lines. If $T / \bar{R} 1$ is high, then all these lines are sending information to the IEEE GPIB lines. This input is TTL compatible. |
| $\overline{\overline{\mathrm{EOI}}}$ | $\begin{aligned} & 3 \\ & 4 \end{aligned}$ | I | End Of Sequence And Attention: Processor GPIB control lines. These two control signals are ANDed together to determine whether all the transceivers in the 8293 are threestate (push-pull) or open-collector. When both signals are low (true), then the controller is performing a parallel poll and the transceivers are all open-collector. These inputs are TTL compatible. |
| $\overline{\text { DAV }}$ | 24 | 1/O | Data Valid: Processor GPIB bus handshake control line; used to indicate the condition (availability and validity) of information on the DIO lines. It is TTL compatible. |
| DAV* | 21 | I/O | Data Valid: IEEE GPIB bus handshake control line. When an input, it is a TTL compatible Schmitt-trigger. When DAV* is an output, it can sink 48 mA. |
| $\frac{\overline{\mathrm{DIO1}}}{\mathrm{DIO}}$ | $\begin{array}{rr} 25, & 23, \\ 10, & 9, \\ 8, & 7, \\ 6, & 5 \end{array}$ | 1/0 | Data Input/Output: Processor GPIB bus data lines; used to carry message and data bytes in a bit-parallel byteserial form controlled by the three handshake signals. These lines are TTL compatible. |
| $\begin{aligned} & \mathrm{DIO1}^{*}- \\ & \text { DIO8* } \end{aligned}$ | $\begin{aligned} & 22,19, \\ & 18,17, \\ & 16,15, \\ & 13,12 \end{aligned}$ | 1/0 | Data Input/Output: IEEE GPIB bus data lines. They are TTL compatible Schmitt-triggers when used for input and can sink 48 mA when used for output. See $\overline{\text { ATN }}$ and $\overline{\text { EOI }}$ description for output mode. |



Figure 7. Talker/Listener/Controller Control Configuration

Table 5. Mode 2 Pin Description

| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| T/ $\overline{\mathrm{R}} 1$ | 1 | 1 | Transmit Receive 1: Direction control for NDAC and NRFD. If $T / \bar{R} 1$ is high, then NDAC and NRFD are receiving. Input is TTL compatible. |
| $\overline{\text { NDAC }}$ | 10 | 1/0 | Not Data Accepted: Processor GPIB bus handshake control line; used to indicate the condition of acceptance of data by device(s). This pin is TTL compatible. |
| NDAC* | 18 | 1/0 | Not Data Accepted: IEEE GPIB bus handshake control line. It is a TTL compatible Schmitt-trigger when used for input and an open-collector driver with a 48 mA current sink capability when used for output. |
| $\overline{\text { NRFD }}$ | 9 | I/O | Not Ready For Data: Processor GPIB bus handshake control line; used to indicate the condition of readiness of device(s) to accept data. This pin is TTL compatible. |
| NRFD* | 17 | I/O | Not Ready For Data: IEEE GPIB bus handshake control line. It is a TTL compatible Schmitt-trigger when used for input and an open-collector driver with a 48 mA current sink capability when used for output. |
| SYC ${ }^{1}$ | 22 | 1 | System Controller: Used to monitor the system controller switch and control the direction for IFC and REN. This pin is a TTL compatible input. |
| $\overline{\text { REN }}$ | 6 | 1/0 | Remote Enable: Processor GPIB control line; used by the active controller (in conjunction with other messages) to select between two alternate sources of device programming data (remote or local control). This pin is TTL compatible. |
| REN* | 13 | 1/0 | Remote Enable: IEEE GPIB bus control line. When used as an input, this is a TTL compatible Schmitt-trigger. When an output, it is a three-state driver with a 48 mA current sinking capability. |
| $\overline{\mathrm{IFC}}$ | 5 | 1/0 | Interface Clear: Processor GPIB bus control line; used by the active controller to place the interface system into a known quiescent state. This pin is TTL compatible. |
| IFC* | 12 | 1/0 | Interface Clear: IEEE GPIB control line. This is a TTL compatible Schmitttrigger when used for input and a threestate driver capable of sinking 48 mA current when used for output. |
| $\overline{\mathrm{CIC}}$ | 24 | 1 | Controller In Charge: Used to control the direction of the SRQ and to indicate that the 8292 is in charge of the bus. $\overline{\text { CIC }}$ is a TTL compatible input. |


| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| CLTH ${ }^{1}$ | 21 | 1 | Clear Latch: Used to clear the IFC Received latch after it has been recognized by the 8292. Normally low (except after a hardware reset). It will be pulsed high when IFC Received is recognized by the 8292. This input is TTL compatible. |
| $\overline{\mathrm{IFCL}}$ | 25 | 0 | IFC Received Latch: The 8292 monitors the IFC line when it is not the active controller through this pin. |
| $\overline{S R Q}$ | 8 | 1/0 | Service Request: Processor GPIB control line; indicates the need for attention and requests the active controller to interrupt the current sequence of events on the GPIB bus. This pin is TTL compatible. |
| SRQ* | 16 | I/O | Service Request: IEEE GPIB bus control line. When used as an input, this pin is a TTL compatible Schmitt-trigger. When used as an output, it is an opencollector driver with a 48 mA current sinking capability. |
| T/R2 | 2 | 1 | Transmit Receive 2: Controls the direction for EOI. This input is TTL compatible. |
| $\overline{\text { ATNO }}$ | 23 | 1 | Attention Out: Processor GPIB bus control line; used by the 8292 for ATN control of the IEEE bus during "take control synchronously" operations. A low on this input causes ATN to be asserted if $\overline{\mathrm{CIC}}$ indicates that this 8292 is in charge. ATNO is a TTL compatible input. |
| $\overline{\text { ATN }}$ | 11 | 0 | Attention In: Processor GPIB bus control line; used by the 8292 to monitor the ATN line. This output is TTL compatible. |
| $\overline{\text { ATN }}$ | 4 | 0 | Attention: Processor GPIB bus control line; used by the 8292 to monitor the ATN line. This output is TTL compatible. |
| ATN* | 19 | 1/0 | Attention: IEEE GPIB bus control line; used by a controller to specify how data on the DIO signal lines are to be interpreted and which devices must respond to data. When used as an output, this pin is a three-state driver capable of sinking 48 mA current. As an input, it is a TTL compatible Schmitt-trigger. |
| $\overline{\mathrm{EOO}}$ | 7 | 1/0 | End Or Identify 2: Processor GPIB bus control line; used in conjunction with ATN by the active controller (the 8292) to execute a polling sequence. This pin is TTL compatible. |
| EOI | 3 | I/O | End Or Identify: Processor GPIB bus control line; used by a talker to indicate the end of a multiple byte transfer sequence. This pin is TTL compatible. |

## NOTES:

1. $\mathrm{V}_{\text {IL3 }}$ is guaranteed at 1.1 V on these inputs to accommodate the high current-sourcing capability of these pins during a low input in Mode 2.

Table 5. Mode 2 Pin Description (Continued)

| Symbol | Pin <br> No. | Type | Name and Function |
| :--- | :---: | :---: | :---: |$|$| EOI $^{*}$ | 15 | $1 / \mathrm{O}$ |
| :--- | :--- | :--- |
| End Or Identify: IEEE GPIB bus control <br> line; used by a talker to indicate the end <br> of a multiple byte transfer sequence or, <br> by a controller in conjunction with ATN, <br> to execute a polling sequence. When an <br> output, this pin can sink 48 mA current. <br> When an input, it is a TTL compatible <br> Schmitt-trigger. |  |  |



Figure 8. Talker/Listener/Controller Data Configuration

Table 6. Mode 3 Pin Description

| Symbol | Pin <br> No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| T/R1 | 1 | 1 | Transmit Receive 1: Controls the direction for DAV and the DIO lines. If $T / \bar{R} 1$ is high, then all these lines are sending information to the IEEE GPIB lines. This input is TTL compatible. |
| $\overline{\overline{\mathrm{EOI}}}$ | $\begin{aligned} & 3 \\ & 4 \end{aligned}$ | $1$ | End Of Sequence and Attention: Processor GPIB control lines. These two control lines are ANDed together to determine whether all the transceivers in the 8293 are push-pull or open-collector. When both signals are low (true), then the controller is performing a parallel poll and the transceivers are all open-collector. These inputs are TTL compatible. |
| $\overline{\text { ATNO }}$ | 11 | 1 | Attention Out: Processor GPIB control line; used by the 8292 during 'take control synchronously" operations. This pin is TTL compatible. |
| $\overline{\text { IFCL }}$ | 2 | 1 | Interface Clear Latched: Used to make DAV received after the system controller asserts IFC. This input is TTL compatible. |
| $\overline{\text { DAV }}$ | 24 | 1/O | Data Valid: Processor GPIB handshake control line; used to indicate the condition (availability and validity) of information on the DIO signals. This pin is TTL compatible. |
| DAV* | 21 | 1/0 | Data Valid: IEEE GPIB handshake control line. When an input, this pin is a TTL compatible Schmitt-trigger. When DAV* is an output, it can sink 48 mA . |
| $\frac{\overline{\mathrm{DIO1}}}{\mathrm{DIO}}$ | $\begin{array}{r} 25, \\ 10, \\ 8, \\ 8, \\ 6, \\ 6 \end{array}$ | 1/0 | Data Input/Output: Processor GPIB bus data lines; used to carry message and data bytes in a bit-parallel byteserial from controlled by the three handshake signals. These lines are TTL compatible. |
| $\begin{aligned} & \text { DIO1* }^{*} \\ & \text { DIO8 } \end{aligned}$ | $\begin{aligned} & 22,19 \\ & 18,17 \\ & 16,15 \\ & 13,12 \end{aligned}$ | 1/O | Data Input/Output: IEEE GPIB bus data lines. They are TTL compatible Schmitt-triggers when used for input and can sink 48 mA when used for output. |



Figure 9. 8291A and 8293 System Configuration


Figure 10. 8291A, 8292, and 8293 System Configuration

## 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. . . . . . . . . . . . . . . . . - 1.0V to + 7 V
Power Dissipation. . . . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*NOTICE:

1. 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. 2. All devices are guaranteed to operate within the minimum and maximum parameter limits specified below. Typical parameters however are not tested and are not guaranteed. Established statistically, they indicate the performance level expected in a typical device at room temperature $\left(T_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$ and $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$.
D.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{V}_{\text {IL1 }}$ | Input Low Voltage (GPIB Bus Pins) |  |  | 0.8 | V |  |
| $V_{\text {IL2 }}$ | Input Low Voltage (Option Pins) | -0.1 |  | 0.1 | V |  |
| $\mathrm{V}_{\mathrm{IL} 2}{ }^{1}$ | Input Low Voltage (All Others) |  |  | 0.8 | V |  |
| $\mathrm{V}_{1 \mathrm{H}_{1}}$ | Input High Voltage (GPIB Bus Pins) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {IH2 }}$ | Input High Voltage (Option Pins) | 4.5 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{1} \mathrm{H}_{3}$ | Input High voltage (All Others) | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {IH4 }}$ | Receiver Input Hysteresis | 400 |  |  | mV |  |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage (GPIB Bus Pins) |  |  | 0.5 | V | $\mathrm{l}_{\mathrm{OL}}=48 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 2}$ | Output Low Voltage (All Others) |  |  | 0.5 | V | $\mathrm{l}_{\mathrm{OL}}=16 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (GPIB Bus Pins) | 2.4 |  |  | V | $\mathrm{IOH}=-5.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Others) | 2.4 |  |  | V | $\mathrm{IOH}=-800 \mu \mathrm{~A}$ |
| $V_{I T}$ | Receiver Input Threshold $\frac{\text { High to Low }}{\text { Low to High }}$ | 0.8 |  | 2.0 | V |  |
| ${ }_{\text {L L C }}$ | Input Load Current (GPIB Pins) | See Bus Load Line Diagram |  |  |  | $V_{C C}=5.0 \mathrm{~V} \pm 5 \%$ |
| IIL | Input Leakage Current (All Others) |  |  | 10 | $\mu \mathrm{A}$ | $0.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ${ }^{\text {IPD }}$ | Bus Power Down Leakage Current |  |  | 40 | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {BUS }} \leqslant 2.7 \mathrm{~V}$ |
| ICC | Power Supply Current |  | 110 | 175 | mA |  |

NOTES:

1. $\mathrm{V}_{\mathrm{IL} 3}=1.1 \mathrm{~V}$ max on pins 21 and 22 in Mode 2 for the 8293-10.

## CAPACITANCE

| Symbol | Parameter | Min. | Typ. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IO1 }}$ | I/O Capacitance (GPIB Side) |  | 50 | 80 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\text {IO2 }}$ | I/O Capacitance (System Side) |  | 35 | 50 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\text {ITR }}$ | Input Capacitance (T/R1, T/R2) |  | 7 | 10 | pF | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{CC}}$ |

A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Max. | Units |
| :---: | :---: | :---: | :---: |
| $t_{\text {P1 }}$ | Transmitter Propagation Delay (All Lines) | 30 | ns |
| $t_{\text {P2 }}$ | Receiver Propagation Delay (EOI, ATN and Handshake Lines) | 50 | ns |
| $\mathrm{t}_{\mathrm{P} 3}$ | Receiver Propagation Delay (All Other Lines) | 60 | ns |
| ${ }_{\text {tPHZ1 }}$ | Transmitter Disable Delay (High to 3-State) | 40 | ns |
| $\mathrm{t}_{\text {PZH1 }}$ | Transmitter Enable Delay (3-state to High) | 40 | ns |
| tplZ1 | Transmitter Disable Delay (Low to 3-State) | 40 | ns |
| $\mathrm{t}_{\text {PZL1 }}$ | Transmitter Enable Delay (3-State to Low) | 40 | ns |
| $\mathrm{t}_{\text {PHZ2 }}$ | Receiver Disable Delay (High to 3-State) | 40 | ns |
| tpZH2 | Receiver Enable Delay (3-State to High) | 40 | ns |
| tplZ2 | Receiver Disable Delay (Low to 3-State) | 40 | ns |
| $\mathrm{t}_{\text {PZL2 }}$ | Receiver Enable Delay (3-State to Low) | 40 | ns |
| $\mathrm{t}_{\mathrm{MS}}$ | Mode Switch Delay | 10 | $\mu \mathrm{S}$ |

## TYPICAL OUTPUT LOADING CIRCUITS


A.C. TESTING INPUT, OUTPUT WAVEFORM

| INPUT/OUTPUT <br> A C TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC • 1 " AND 0.45 V FOR A LOGIC ' 0 ." TIMING MEASUREMENTS ARE MADE AT 2.0 V FOR A LOGIC " 1 " AND 0.8 V FOR A LOGIC $0^{\circ}$ |
| :---: |
|  |  |
|  |  |

## WAVEFORMS


*DELAYS ARE REFERENCED AGAINST PERCENTAGE OF FINAL OUTPUT WHEREVER 3-STATE OUTPUTS ARE INVOLVED BECAUSE THE RISE AND FALLTIMES DEPEND ONTHE EXTERNAL PULL-UP AND PULL-DOWN LOADS.

## BUS LOAD LINE



TYPICAL RECEIVER HYSTERESIS CHARACTERISTICS


# 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 ${ }^{\circledR} 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.


Figure 1. Block Diagram
Figure 2. Pin Configuration

## FUNCTIONAL DESCRIPTION

## General

The 8253 is a programmable interval timer/counter specifically designed for use with the Intel ${ }^{\text {Tm }}$ 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{\mathrm{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 3. 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 {rm }}$ Microcomputer Systems and interfaces in the same manner as all other peripherals of the family. It is treated by the systems software as an array of peripheral I/O ports; three are counters and the fourth is a control register for MODE programming.

Basically, the select inputs A0, A1 connect to the A0, A1 address bus signals of the CPU. The $\overline{\mathrm{CS}}$ can be derived directly from the address bus using a linear select method. Or it can be connected to the output of a decoder, such as an Intel ${ }^{\circledR} 8205$ for larger systems.


Figure 4. Block Diagram Showing Control Word Register and Counter Functions


Figure 5. 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. Prior to initialization, the MODE, count, and output of all counters is undefined. 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 probiems 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. (A0, A1 = 11)

## Control Word Format

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{\mathbf{5}}$ | $\mathrm{D}_{\mathbf{4}}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{\mathbf{2}}$ | $\mathrm{D}_{\mathbf{1}}$ | $\mathrm{D}_{\mathbf{0}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC 1 | SC 0 | RL 1 | RLO | M 2 | M 1 | M 0 | BCD |

## Definition of Control

SC - Select Counter:
SC1 SC0

| 0 | 0 | Select Counter 0 |
| :--- | :--- | :--- |
| 0 | 1 | Select Counter 1 |
| 1 | 0 | Select Counter 2 |
| 1 | 1 | Iliegal |

## RL - Read/Load:

RL1 RL0

| 0 | 0 | Counter Latching operation (see <br> READ/WR ITE 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 |
| 0 0 0 Mode 0 <br> 0 0 1 Mode 1 <br> $X$ 1 0 Mode 2 <br> $X$ 1 1 Mode 3 <br> 1 0 0 Mode 4 <br> 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 ouiput 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 $(\mathrm{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 | Low Or Going Low | Rising | High |
| :---: | :---: | :---: | :---: |
| 0 | Disables counting | -- | Enables counting |
| 1 | -- | 1) Initıates countıng <br> 2) Resets output after next clock | - |
| 2 | 1) Disables counting <br> 2) Sets output immediately high | 1) Reloads counter <br> 2) Initiates counting | Enables counting |
| 3 | 1) Disables counting <br> 2) Sets output immediately high | Initiates counting | Enables counting |
| 4 | Disables counting | -- | Enables counting |
| 5 | -- | Initiates counting | -- |

Figure 6. Gate Pin Operations Summary


MODE 1: Programmable One-Shot



MODE 2: Rate Generator


MODE 3: Square Wave Generator


MODE 4: Software Triggered Strobe



MODE 5: Hardware Triggered Strobe



Figure 7. 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 (RL0, RL1) are programmed. Then proceed with the restart operation.

|  | MODE Control Word <br> Counter $\mathbf{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 8. 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 | MSB | Count Register Byte Counter 1 | 0 | 1 |
| No. 6 | LSB | Count Register Byte Counter 2 | 1 | 0 |
| No. 7 | MSB | Count Register Byte 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 9. 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 externallogic 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 $1 / 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.


[^32]Figure 10. MCS-85 ${ }^{\text {TM }}$ Clock Interface*

## ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature Under Bias | 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 Wat |

*NOTICE: 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 $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| 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}}+.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}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0V |
| $\mathrm{I}_{\mathrm{OFL}}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to .45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 140 | mA |  |

CAPACITANCE $\quad\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| 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\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}$ )

Bus Parameters (Note 3)
READ CYCLE

| Symbol | Parameter | 8253 |  | 8253-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {AR }}$ | Address Stable Before READ | 50 |  | 30 |  | ns |
| $\mathrm{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 |
| trD | Data Delay From $\overline{\text { READ }}$ [4] |  | 300 |  | 200 | ns |
| ${ }^{\text {t }}$ DF | $\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}$ |

## A.C. CHARACTERISTICS (Continued)

WRITE CYCLE

| Symbol | Parameter | 8253 |  | 8253-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {A }}$ W | Address Stable Before WRITE | 50 |  | 30 |  | ns |
| ${ }^{\text {t }}$ WA | Address Hold Time for WRITE | 30 |  | 30 |  | ns |
| ${ }^{\text {w }}$ W | $\overline{\text { WRITE Pulse Width }}$ | 400 |  | 300 |  | ns |
| ${ }^{\text {t }}$ W | Data Set Up Time for $\overline{\text { WRITE }}$ | 300 |  | 250 |  | ns |
| ${ }^{\text {t W }}$ | Data Hold Time for $\overline{\text { WRITE }}$ | 40 |  | 30 |  | ns |
| $\mathrm{t}_{\mathrm{R} V}$ | Recovery Time Between WRITE and Any Other Control Signal | 1 |  | 1 |  | $\mu \mathrm{s}$ |

CLOCK AND GATE TIMING

| Symbol | Parameter | 8253 |  | 8253-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {t CLK }}$ | Clock Period | 380 | dc | 380 | dc | ns |
| tpWH | 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{G}} \mathrm{L}$ | Gate Width Low | 100 |  | 100 |  | ns |
| $\mathrm{t}_{\mathrm{GS}}$ | Gate Set Up Time to CLK $\uparrow$ | 100 |  | 100 |  | ns |
| $\mathrm{t}_{\mathrm{GH}}$ | Gate Hold Time After CLK $\uparrow$ | 50 |  | 50 |  | ns |
| tod | Output Delay From CLK $\downarrow$ [4] |  | 400 |  | 400 | ns |
| todg | Output Delay From Gate $\downarrow$ [4] |  | 300 |  | 300 | ns |

## NOTES:

1. $\mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$
2. $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
3. AC timings measured at $\mathrm{V}_{\mathrm{OH}} 2.2, \mathrm{~V}_{\mathrm{OL}}=0.8$.
4. $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## CLOCK AND GATE TIMING



## 8254 <br> PROGRAMMABLE INTERVALTIMER

- Compatible with Most Microprocessors Including 8080A, 8085A, iAPX 88 and IAPX 86
- Handles Inputs from DC to $8 \mathbf{M H z}$ ( 10 MHz for 8254-2)
- Six Programmable Counter Modes
- Status Read-Back Command
- Three Independent 16-bit Counters
- Binary or BCD Counting
- Single +5V Supply

■ Uses HMOS Technology

The Intel ${ }^{\circledR} 8254$ is a counter/timer device designed to solve the common timing control problems in microcomputer system design. It provides three independent 16-bit counters, each capable of handling clock inputs up to 10 MHz . All modes are software programmable. The 8254 is a superset of the 8253 .

The 8254 uses HMOS technology and comes in a 24 -pin plastic or CERDIP package.


Figure 1. 8254 Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Pin No. | Type | Name and Function |
| :--- | :---: | :---: | :--- |
| D $_{7}$ - $\mathrm{D}_{0}$ | $1-8$ | //O | Data: Bi-directional three state data bus <br> lines, connected to system data bus. |
| CLK 0 | 9 | 1 | Clock 0: Clock input of Counter 0. |
| OUT 0 | 10 | O | Output 0: Output of Counter 0. |
| GATE 0 | 11 | 1 | Gate 0: Gate input of Counter 0. |
| GND | 12 |  | Ground: Power supply connection. |
|  |  |  |  |

## FUNCTIONAL DESCRIPTION

## General

The 8254 is a programmable intervai timer/counter designed for use with Intel microcomputer systems. It is a general purpose, multi-timing element that can be treated as an array of I/O ports in the system software.

The 8254 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 software, the programmer configures the 8254 to match his requirements and programs one of the counters for the desired delay. After the desired delay, the 8254 will interrupt the CPU. Software overhead is minimal and variable length delays can easily be accommodated.

Some of the other counter/timer functions common to microcomputers which can be implemented with the 8254 are:

- Real time clock
- Event counter
- Digital one-shot
- Programmable rate generator
- Square wave generator
- Binary rate multiplier
- Complex waveform generator
- Complex motor controller

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 24 |  | Power: +5 V power supply connection. |
| $\overline{W R}$ | 23 | 1 | Write Control: This input is low during CPU write operations. |
| $\overline{\mathrm{RD}}$ | 22 | 1 | Read Control: This input is low during CPU read operations. |
| $\overline{\mathrm{CS}}$ | 21 | 1 | Chip Select: A low on this input enables the 8254 to respond to $\overline{R D}$ and $\overline{W R}$ signals. $\overline{R D}$ and $\overline{W R}$ are ignored otherwise. |
| $\mathrm{A}_{1}, \mathrm{~A}_{0}$ | 20-19 | 1 | Address: Used to select one of the three Counters or the Control Word Register for read or write operations. Normally connected to the system address bus. |
|  |  |  | $\mathrm{A}_{1} \mathrm{~A}_{0} \quad$ Selects |
|  |  |  | 0 0 Counter 0 <br> 0 1 Counter 1 <br> 1 0 Counter 2 <br> 1 1 Control Word Register |
| CLK 2 | 18 | 1 | Clock 2: Clock input of Counter 2. |
| OUT 2 | 17 | 0 | Out 2: Output of Counter 2. |
| GATE 2 | 16 | 1 | Gate 2: Gate input of Counter 2. |
| CLK 1 | 15 | 1 | Clock 1: Clock input of Counter 1. |
| GATE 1 | 14 | 1 | Gate 1: Gate input of Counter 1. |
| OUT 1 | 13 | 0 | Out 1: Output of Counter 1. |

## Block Diagram

## DATA BUS BUFFER

This 3-state, bi-directional, 8 -bit buffer is used to interface the 8254 to the system bus (see Figure 3).


Figure 3. Block Diagram Showing Data Bus Buffer and Read/Write Logic Functions

## READ/WRITE LOGIC

The Read/Write Logic accepts inputs from the system bus and generates control signals for the other functional blocks of the 8254. $A_{1}$ and $A_{0}$ select one of the three counters or the Control Word Register to be read from/written into. A "low" on the $\overline{R D}$ input tells the 8254 that the CPU is reading one of the counters. A "low" on the $\overline{W R}$ input tells the 8254 that the CPU is writing either a Control Word or an initial count. Both $\overline{R D}$ and $\overline{W R}$ are qualified by $\overline{\mathrm{CS}} ; \overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are ignored unless the 8254 has been selected by holding $\overline{\mathrm{CS}}$ low.

## CONTROL WORD REGISTER

The Control Word Register (see Figure 4) is selected by the Read/Write Logic when $A_{1}, A_{0}=11$. If the CPU then does a write operation to the 8254, the data is stored in the Control Word Register and is interpreted as a Control Word used to define the operation of the Counters.

The Control Word Register can only be written to; status information is available with the Read-Back Command.


Figure 4. Block Diagram Showing Control Word Register and Counter Functions

## COUNTER 0, COUNTER 1, COUNTER 2

These three functional blocks are identical in operation, so only a single Counter will be described. The internal block diagram of a single counter is shown in Figure 5.
The Counters are fully independent. Each Counter may operate in a different Mode.
The Control Word Register is shown in the figure; it is not part of the Counter itself, but its contents determine how the Counter operates.


Figure 5. Internal Block Diagram of a Counter

The status register, shown in the Figure, when latched, contains the current contents of the Control Word Register and status of the output and null count flag. (See detailed explanation of the Read-Back command.)
The actual counter is labelled CE (for "Counting Element"). It is a 16 -bit presettable synchronous down counter.
$\mathrm{OL}_{\mathrm{M}}$ and $\mathrm{OL}_{\mathrm{L}}$ are two 8-bit latches. OL stands for "Output Latch"; the subscripts $M$ and $L$ stand for "Most significant byte" and "Least significant byte" respectively. Both are normally referred to as one unit and called just OL. These latches normally "follow" the CE, but if a suitable Counter Latch Command is sent to the 8254, the latches "latch" the present count until read by the CPU and then return to "following" the CE. One latch at a time is enabled by the counter's Control Logic to drive the internal bus. This is how the 16 -bit Counter communicates over the 8 -bit internal bus. Note that the CE itself cannot be read; whenever you read the count, it is the OL that is being read.
Similarly, there are two 8 -bit registers called $\mathrm{CR}_{\mathrm{M}}$ and $\mathrm{CR}_{\mathrm{L}}$ (for "Count Register"). Both are normally referred to as one unit and called just CR. When a new count is written to the Counter, the count is stored in the CR and later transferred to the CE. The Control Logic allows one register at a time to be loaded from the internal bus. Both bytes are transferred to the CE simultaneously. $C R_{M}$ and $C R_{L}$ are cleared when the Counter is programmed. In this way, if the Counter has been programmed for one byte counts (either most significant byte only or least significant byte only) the other byte will be zero. Note that the CE cannot be written into; whenever a count is written, it is written into the CR.
The Control Logic is also shown in the diagram. CLK $n$, GATE $n$, and OUT $n$ are all connected to the outside world through the Control Logic.

## 8254 SYSTEM INTERFACE

The 8254 is a component of the Intel 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 $A_{0}, A_{1}$ connect to the $A_{0}, A_{1}$ address bus signals of the CPU. The CS can be derived directly from the address bus using a linear select method. Or it can be connected to the output of a decoder, such as an Intel 8205 for larger systems.


Figure 6. 8254 System Interface

## OPERATIONAL DESCRIPTION

## General

After power-up, the state of the 8254 is undefined. The Mode, count value, and output of all Counters are undefined.

How each Counter operates is determined when it is programmed. Each Counter must be programmed before it can be used. Unused counters need not be programmed.

## Programming the 8254

Counters are programmed by writing a Control Word and then an initial count.

All Control Words are written into the Control Word Register, which is selected when $A_{1}, A_{0}=11$. The Control Word itself specifies which Counter is being programmed.
By contrast, initial counts are written into the Counters, not the Control Word Register. The $\mathrm{A}_{1}, \mathrm{~A}_{0}$ inputs are used to select the Counter to be written into. The format of the initial count is determined by the Control Word used.

## Control Word Format

$$
\mathrm{A}_{1}, \mathrm{~A}_{0}=11 \quad \overline{\mathrm{CS}}=0 \quad \overline{\mathrm{RD}}=1 \quad \overline{\mathrm{WR}}=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}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SC1 | SCO | RW1 | RW0 | M2 | M1 | M0 | BCD |


| SC - Select Counter: |  |  |
| :---: | :---: | :---: |
| SC1 | SCO |  |
| 0 | 0 | Select Counter 0 |
| 0 | 1 | Select Counter 1 |
| 1 | 0 | Select Counter 2 |
| 1 | 1 | Read-Back Command (See Read Operations) |

RW - Read/Write:
RW1 RW0

| 0 | 0 | Counter Latch Command (see Read <br> Operations) |
| :---: | :---: | :--- |
| 0 | 1 | Read/Write least significant byte only. |
| 1 | 0 | Read/Write most significant byte only. |
| 1 | 1 | Read/Write 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) |

NOTE: DON'T CARE BITS ( $\mathbf{X}$ ) SHOULD BE 0 TO INSURE COMPATIBILITY WITH FUTURE INTEL PRODUCTS.

Figure 7. Control Word Format

## Write Operations

The programming procedure for the 8254 is very flexible. Only two conventions need to be remembered:

1) For each Counter, the Control Word must be written before the initial count is written.
2) The initial count must follow the count format specified in the Control Word (least significant byte only, most significant byte only, or least significant byte and then most significant byte).

Since the Control Word Register and the three Counters have separate addresses (selected by the $A_{1}, A_{0}$ inputs), and each Control Word specifies the Counter it applies to (SC0,SC1 bits), no special instruction sequence is re-
quired. Any programming sequence that follows the conventions above is acceptable.

A new initial count may be written to a Counter at any time without affecting the Counter's programmed Mode in any way. Counting will be affected as described in the Mode definitions. The new count must follow the programmed count format.

If a Counter is programmed to read/write two-byte counts, the following precaution applies: A program must not transfer control between writing the first and second byte to another routine which also writes into that same Counter. Otherwise, the Counter will be loaded with an incorrect count.

|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ |  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Control Word - Counter 0 | 1 | 1 | Control Word - Counter 2 | 1 | 1 |
| LSB of count - Counter 0 | 0 | 0 | Control Word - Counter 1 | 1 | 1 |
| MSB of count - Counter 0 | 0 | 0 | Control Word - Counter 0 | 1 | 1 |
| Control Word - Counter 1 | 1 | 1 | LSB of count - Counter 2 | 1 | 0 |
| LSB of count - Counter 1 | 0 | 1 | MSB of count - Counter 2 | 1 | 0 |
| MSB of count - Counter 1 | 0 | 1 | LSB of count - Counter 1 | 0 | 1 |
| Control Word - Counter 2 | 1 | 1 | MiSB of count - Counter 1 | 0 | 1 |
| LSB of count - Counter 2 | 1 | 0 | LSB of count - Counter 0 | 0 | 0 |
| MSB of count - Counter 2 | 1 | 0 | MSB of count - Counter 0 | 0 | 0 |
|  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ |  | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ |
| Control Word - Counter 0 | 1 | 1 | Control Word - Counter 1 | 1 | 1 |
| Control Word - Counter 1 | 1 | 1 | Control Word - Counter 0 | 1 | 1 |
| Control Word - Counter 2 | 1 | 1 | LSB of count - Counter 1 | 0 | 1 |
| LSB of count - Counter 2 | 1 | 0 | Control Word - Counter 2 | 1 | 1 |
| LSB of count - Counter 1. | 0 | 1 | LSB of count - Counter 0 | 0 | 0 |
| LSB of count - Counter 0 | 0 | 0 | MSB of count - Counter 1 | 0 | 1 |
| MSB of count - Counter 0 | 0 | 0 | LSB of count - Counter 2 | 1 | 0 |
| MSB of count - Counter 1 | 0 | 1 | MSB of count - Counter 0 | 0 | 0 |
| MSB of count - Counter 2 | 1 | 0 | MSB of count - Counter 2. | 1 | 0 |

NOTE: IN ALL FOUR EXAMPLES, ALL COUNTERS ARE PROGRAMMED TO READ/WRITE TWO-BYTE COUNTS. THESE ARE ONLY FOUR OF MANY POSSIBLE PROGRAMMING SEQUENCES.

Figure 8. A Few Possible Programming Sequences

## Read Operations

It is often desirable to read the value of a Counter without disturbing the count in progress. This is easily done in the 8254.

There are three possible methods for reading the Counters. The first is through the Read-Back command,
which is explained later. The second is a simple read operation of the Counter, which is selected with the $A_{1}, A_{0}$ inputs. The only requirement is that the CLK input of the selected Counter must be inhibited by using either the GATE input or external logic. Otherwise, the count may be in process of changing when it is read, giving an undefined result.

## COUNTER LATCH COMMAND

The other method involves a special software command called the "Counter Latch Command". Like a Control Word, this command is written to the Control Word Register, which is selected when $A_{1}, A_{0}=11$. Also like a Control Word, the SC0,SC1 bits select one of the three Counters, but two other bits, D5 and D4, distinguish this command from a Control Word.

| $A_{1}, A_{0}=11 ; C S=0 ; R D=1 ; W R=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}$ |
| SC1 | SC0 | 0 | 0 | X | X | x | x |

SC1,SC0 - specify counter to be latched

| SC1 | SCO | Counter |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 2 |
| 1 | 1 | Read-Back Command |

D5,D4 - 00 designates Counter Latch Command
X - don't care

NOTE: DON'T CARE BITS (X) SHOULD BE 0 TO INSURE COMPATIBILITY WITH FUTURE INTEL PRODUCTS.

Figure 9. Counter Latching Command Format

The selected Counter's output latch (OL) latches the count at the time the Counter Latch Command is received. This count is held in the latch until it is read by the CPU (or until the Counter is reprogrammed). The count is then unlatched automatically and the OL returns to "following" the counting element (CE). This allows reading the contents of the Counters "on the fly" without affecting counting in progress. Multiple Counter Latch Commands may be used to latch more than one Counter. Each latched Counter's OL holds its count until it is read. Counter Latch Commands do not affect the programmed Mode of the Counter in any way.

If a Counter is latched and then, some time later, latched again before the count is read, the second Counter Latch Command is ignored. The count read will be the count at the time the first Counter Latch Command was issued.

With either method, the count must be read according to the programmed format; specifically, if the Counter is programmed for two byte counts, two bytes must be read. The two bytes do not have to be read one right after the other; read or write or programming operations of other Counters may be inserted between them.

Another feature of the 8254 is that reads and writes of the same Counter may be interleaved; for example, if the Counter is programmed for two byte counts, the following sequence is valid.

1. Read least significant byte.
2. Write new least significant byte.
3. Read most significant byte.
4. Write new most significant byte.

If a Counter is programmed to read/write two-byte counts, the following precaution applies: A program must not transfer control between reading the first and second byte to another routine which also reads from that same Counter. Otherwise, an incorrect count will be read.

## READ-BACK COMMAND

The read-back command allows the user to check the count value, programmed Mode, and current state of the OUT pin and Null Count flag of the selected counter(s).
The command is written into the Control Word Register and has the format shown in Figure 10. The command applies to the counters selected by setting their corresponding bits D3,D2,D1=1.
$A 0, A 1=11 \quad \overline{\mathrm{CS}}=0 \quad \overline{\mathrm{RD}}=1 \quad \overline{\mathrm{WR}}=0$

$\mathrm{D}_{5}: 0$ = LATCH COUNT OF SELECTED COUNTER(S)
$\mathrm{D}_{4}: 0=$ LATCH STATUS OF SELECTED COUNTER(S)
$\mathrm{D}_{3}: 1$ = SELECT COUNTER 2
$\mathrm{D}_{2}: 1$ = SELECT COUNTER 1
$\mathrm{D}_{1}: 1$ = SELECT COUNTER 0
$D_{0}$ : RESERVED FOR FUTURE EXPANSION; MUST BE 0

Figure 10. Read-Back Command Format

The read-back command may be used to latch multiple counter output latches (OL) by setting the COUNT bit $\mathrm{D} 5=0$ and selecting the desired counter(s). This single command is functionally equivalent to several counter latch commands, one for each counter latched. Each counter's latched count is held until it is read (or the counter is reprogrammed). That counter is automatically unlatched when read, but other counters remain latched until they are read. If multiple count read-back commands are issued to the same counter without reading the count, all but the first are ignored; i.e., the count which will be read is the count at the time the first read-back command was issued.

The read-back command may also be used to latch status information of selected counter(s) by setting STATUS bit D4 $=0$. Status must be latched to be read; status of a counter is accessed by a read from that counter.

The counter status format is shown in Figure 11. Bits D5 through DO contain the counter's programmed Mode exactly as written in the last Mode Control Word. OUTPUT bit D7 contains the current state of the OUT pin. This allows the user to monitor the counter's output via software, possibly eliminating some hardware from a system.


Figure 11. Status Byte

NULL COUNT bit D6 indicates when the last count written to the counter register (CR) has been loaded into the counting element (CE). The exact time this happens depends on the Mode of the counter and is described in the Mode Definitions, but until the count is loaded into the counting element (CE), it can't be read from the counter. If the count is latched or read before this time, the count value will not reflect the new count just written. The operation of Null Count is shown in Figure 12.

THIS ACTION: CAUSES:
A. WRITE TO THE CONTROL WORD REGISTER: ${ }^{[1]}$ NULL COUNT $=1$
B. WRITE TO THE COUNT REGISTER (CR); ${ }^{[2]}$ NULL COUNT=1
C. NEW COUNT IS LOADED INTO CE (CR $\rightarrow C E$ ); NULL COUNT $=0$
[1]
ONLY THE COUNTER SPECIFIED BY THE CONTROL WORD WILL HAVE ITS NULL COUNT SET TO 1. NULL COUNT BITS OF OTHER COUNTERS ARE UNAFFECTED.
[2]
IF THE COUNTER IS PROGRAMMED FOR TWO-BYTE COUNTS (LEAST SIGNIFICANT BYTE THEN MOST SIGNIFICANT BYTE) NULL COUNT GOES TO I WHEN THE SECOND BYTE IS WAITTEN.

Figure 12. Null Count Operation

If multiple status latch operations of the counter(s) are performed without reading the status, all but the first are ignored; i.e., the status that will be read is the status of the counter at the time the first status read-back command was issued.

Both count and status of the selected counter(s) may be latched simultaneously by setting both COUNT and STATUS bits $D 5, D 4=0$. This is functionally the same as issuing two separate read-back commands at once, and the above discussions apply here also. Specifically, if multiple count and/or status read-back commands are issued to the same counter(s) without any intervening reads, all but the first are ignored. This is illustrated in Figure 13.

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\begin{gathered} \text { Com } \\ D_{4} \end{gathered}$ | $\begin{gathered} \text { mand } \\ D_{3} \end{gathered}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ | Description | Result |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | Read back count and status of Counter 0 | Count and status latched for Counter 0 |
| 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | Read back status of Counter 1 | Status latched for Counter 1 |
| 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 | Read back status of Counters 2, 1 | Status latched for Counter 2, but not Counter 1. |
| 1 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | Read back count of Counter 2 | Count latched for Counter 2 |
| 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | Read back count and status of Counter 1 | Count latched for Counter 1, but not status |
| 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | Read back status of Counter 1 | Command ignored, status already latched for Counter 1 |

Figure 13. Read-Back Command Example

If both count and status of a counter are latched, the first read operation of that counter will return latched status, regardless of which was latched first. The next one or two reads (depending on whether the counter is programmed for one or two type counts) return latched count. Subsequent reads return unlatched count.

| $\mathbf{C S}$ | $\overline{\text { RD }}$ | $\overline{\mathrm{WR}}$ | $\mathbf{A}_{\mathbf{1}}$ | $\mathbf{A}_{\mathbf{0}}$ |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 1 | 0 | 0 | 0 | Write into Counter 0 |
| 0 | 1 | 0 | 0 | 1 | Write into Counter 1 |
| 0 | 1 | 0 | 1 | 0 | Write into Counter 2 |
| 0 | 1 | 0 | 1 | 1 | Write Control Word |
| 0 | 0 | 1 | 0 | 0 | Read from Counter 0 |
| 0 | 0 | 1 | 0 | 1 | Read from Counter 1 |
| 0 | 0 | 1 | 1 | 0 | Read from Counter 2 |
| 0 | 0 | 1 | 1 | 1 | No-Operation (3-State) |
| 1 | X | X | X | X | No-Operation (3-State) |
| 0 | 1 | 1 | X | X | No-Operation (3-State) |

Figure 14. Read/Write Operations Summary

## Mode Definitions

The following are defined for use in describing the operation of the 8254.

CLK pulse: a rising edge, then a falling edge, in that order, of a Counter's CLK input.
trigger: a rising edge of a Counter's GATE input.
Counter loading: the transfer of a count from the CR to the CE (refer to the "Functional Description")

## MODE 0: INTERRUPT ON TERMINAL COUNT

Mode 0 is typically used for event counting. After the Control Word is written, OUT is initially low, and will remain law until the Counter reaches zero. OUT then goes high and remains high until a new count or a new Mode 0 Control Word is written into the Counter.

GATE $=1$ enables counting; GATE $=0$ disables counting. GATE has no effect on OUT.
After the Control Word and initial count are written to a Counter, the initial count will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an initial count of $N$, OUT does not go high until $N+1$ CLK pulses after the initial count is written.

If a new count is written to the Counter, it will be loaded on the next CLK pulse and counting will continue from the new count. If a two-byte count is written, the following happens:

1) Writing the first byte disables counting. OUT is set low immediately (no clock pulse required)
2) Writing the second byte allows the new count to be loaded on the next CLK pulse.

This allows the counting sequence to be synchronized by software. Again, OUT does not go high until $N+1$ CLK pulses after the new count of $N$ is written.

If an initial count is written while GATE $=0$, it will still be loaded on the next CLK pulse. When GATE goes high, OUT will go high N CLK pulses later; no CLK pulse is needed to load the Counter as this has already been done.


NOTE: THE FOLLOWING CONVENTIONS APPLY TO ALL MODE TIMING DIAGRAMS: 1. COUNTERS ARE PROGRAMMED FOR BINARY (NOT BCD) COUNTING AND FOR READING/WRITING LEAST SIGNIFICANT BYTE (LSB) ONLY.
2. THE COUNTER IS ALWAYS SELECTED (CS ALWAYS LOW).
3. CW STANDS FOR "CONTROL WORD"; CW=10 MEANS A CONTROL WORD OF 10 heX IS WRITTEN TO THE COUNTER.
LSB STANDS FOR "LEAST SIGNIFICANT BYTE" OF COUNT.
5. NUMBERS BELOW DIAGRAMS ARE COUNT VALUES.

THE LOWER NUMBER IS THE LEAST SIGNIFICANT BYTE.
THE UPPER NUMBER IS THE MOST SIGNIFICANT BYTE. SINCE THE COUNTER IS PROGRAMMED TO READ/WRITE LSB ONLY, THE MOST SIGNIFICANT BYTE CANNOT BE READ.
N STANDS FOR AN UNDEFINED COUNT.
VERTICAL LINES SHOW TRANSITIONS BETWEEN COUNT VALUES.

Figure 15. Mode 0

## MODE 1: HARDWARE RETRIGGERABLE ONE-SHOT

OUT will be initially high. OUT will go low on the CLK pulse following a trigger to begin the one-shot pulse, and will remain low until the Counter reaches zero. OUT will then go high and remain high until the CLK pulse after the next trigger.
After writing the Control Word and initial count, the Counter is armed. A trigger results in loading the Counter and setting OUT low on the next CLK pulse, thus starting the one-shot pulse. An initial count of $N$ will result in a one-shot pulse N CLK cycles in duration. The one-shot is retriggerable, hence OUT will remain low for N CLK pulses after any trigger. The one-shot pulse can be repeated without rewriting the same count into the counter. GATE has no effect on OUT.

If a new count is written to the Counter during a oneshot pulse, the current one-shot is not affected unless the Counter is retriggered. In that case, the Counter is loaded with the new count and the one-shot pulse continues until the new count expires.


Figure 16. Mode 1

## MODE 2: RATE GENERATOR

This Mode functions like a divide-by-N counter. It is typiclaly used to generate a Real Time Clock interrupt. OUT will initially be high. When the initial count has decremented to 1, OUT goes low for one CLK pulse. OUT then goes high again, the Counter reloads the initial count and the process is repeated. Mode 2 is periodic; the same sequence is repeated indefinitely. For an initial count of N , the sequence repeats every N CLK cycles.
GATE $=1$ enables counting; GATE $=0$ disables counting. If GATE goes low during an output pulse, OUT is set high immediately. A trigger reloads the Counter with the initial count on the next CLK pulse; OUT goes low $N$ CLK pulses after the trigger. Thus the GATE input can be used to synchronize the Counter.
After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. OUT goes low N CLK Pulses after the initial count is written. This allows the Counter to be synchronized by software also.


Figure 17. Mode 2

Writing a new count while counting does not affect the current counting sequence. If a trigger is received after writing a new count but before the end of the current period, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from the new count. Otherwise, the new count will be loaded at the end of the current counting cycle.

## MODE 3: SQUARE WAVE MODE

Mode 3 is typically used for Baud rate generation. Mode 3 is similar to Mode 2 except for the duty cycle of OUT. OUT will initially be high. When half the initial count has expired, OUT goes low for the remainder of the count. Mode 3 is periodic; the sequence above is repeated indefinitely. An initial count of $N$ results in a square wave with a period of N CLK cycles.

GATE $=1$ enables counting; GATE $=0$ disables counting. If GATE goes low while OUT is low, OUT is set high immediately; no CLK pulse is required. A trigger reloads the Counter with the initial count on the next CLK pulse. Thus the GATE input can be used to synchronize the Counter.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. This allows the Counter to be synchronized by software also.
Writing a new count while counting does not affect the current counting sequence. If a trigger is received after writing a new count but before the end of the current half-cycle of the square wave, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from the new count. Otherwise, the new count will be loaded at the end of the current half-cycle.
Mode 3 is implemented as follows:
Even counts: OUT is initially high. The initial count is loaded on one CLK pulse and then is decremented by two on succeeding CLK pulses. When the count expires OUT changes value and the Counter is reloaded with the initial count. The above process is repeated indefinitely.

Odd counts: OUT is initially high. The initial count minus one (an even number) is loaded on one CLK pulse and then is decremented by two on succeeding CLK pulses. One CLK pulse after the count expires, OUT goes low and the Counter is reloaded with the initial count minus one. Succeeding CLK pulses decrement the count by two. When the count expires, OUT goes high again and the Counter is reloaded with the initial count minus one. The above process is repeated indefinitely. So for odd counts, OUT will be high for $(N+1) / 2$ counts and low for ( $\mathrm{N}-1$ )/2 counts.


Figure 18. Mode 3

## MODE 4: SOFTWARE TRIGGERED STROBE

OUT will be initially high. When the initial count expires, OUT will go low for one CLK pulse and then go high again. The counting sequence is "triggered" by writing the initial count.
GATE $=1$ enables counting; GATE $=0$ disables counting. GATE has no effect on OUT.

After writing a Control Word and initial count, the Counter will be loaded on the next CLK pulse. This CLK pulse does not decrement the count, so for an initial count of N, OUT does not strobe low until $\mathrm{N}+1$ CLK pulses after the initial count is written.

If a new count is written during counting, it will be loaded on the next CLK pulse and counting will continue from the new count. If a two-byte count is written, the following happens:

1) Writing the first byte has no effect on counting.
2) Writing the second byte allows the new count to be loaded on the next CLK pulse.

This allows the sequence to be "retriggered" by software. OUT strobes low $\mathrm{N}+1$ CLK pulses after the new count of $N$ is written.


Figure 19. Mode 4

## MODE 5: HARDWARE TRIGGERED STROBE (RETRIGGERABLE)

OUT will initially be high. Counting is triggered by a rising edge of GATE. When the initial count has expired, OUT will go low for one CLK pulse and then go high again.
After writing the Control Word and initial count, the counter will not be loaded until the CLK pulse after a trigger. This CLK pulse does not decrement the count, so for an initial count of N, OUT does not strobe low until $N+1$ CLK pulses after a trigger.
A trigger results in the Counter being loaded with the initial count on the next CLK pulse. The counting sequence is retriggerable. OUT will not strobe low for $\mathrm{N}+1$ CLK pulses after any trigger. GATE has no effect on OUT.

If a new count is written during counting, the curent counting sequence will not be affected. If a trigger occurs after the new count is written but before the current count expires, the Counter will be loaded with the new count on the next CLK pulse and counting will continue from there.


Figure 20. Mode 5

| Signal <br> Status <br> Modes | Low Or Going Low | Rising | High |
| :---: | :---: | :---: | :---: |
| 0 | Disables counting | -- | Enables counting |
| 1 | - - | 1) Initiates counting <br> 2) Resets output after next clock | - - |
| 2 | 1) Disables counting <br> 2) Sets output immediately high | Initiates counting | Enables counting |
| 3 | 1) Disables counting <br> 2) Sets output immediately high | Initiates counting | Enables counting |
| 4 | Disables counting | - - | Enables counting |
| 5 | -- | Initiates counting | -- |

Figure 21. Gate Pin Operations Summary

| Mode | Min <br> Count | Max <br> Count |
| :---: | :---: | :---: |
| 0 | 1 | 0 |
| 1 | 1 | 0 |
| 2 | 2 | 0 |
| 3 | 2 | 0 |
| 4 | 1 | 0 |
| 5 | 1 | 0 |

NOTE: 0 IS EQUIVALENT TO $2^{16}$ FOR BINARY COUNTING AND $10^{4}$ FOR bCD COUNTING.

Figure 22. Minimum and Maximum Initial Counts

## Operation Common to All Modes

## PROGRAMMING

When a Control Word is written to a Counter, all Control Logic is immediately reset and OUT goes to a known initial state; no CLK pulses are required for this.

## GATE

The GATE input is always sampled on the rising edge of CLK. In Modes 0, 2, 3, and 4 the GATE input is level sensitive, and the logic level is sampled on the rising edge of CLK. In Modes 1, 2, 3, and 5 the GATE input is rising-edge sensitive. In these Modes, a rising edge of GATE (trigger) sets an edge-sensitive flip-flop in the Counter. This flip-flop is then sampled on the next rising edge of CLK; the flip-flop is reset immediately after it is sampled. In this way, a trigger will be detected no matter when it occurs - a high logic level does not have to be maintained until the next rising edge of CLK. Note that in Modes 2 and 3, the GATE input is both edge- and levelsensitive.

## COUNTER

New counts are loaded and Counters are decremented on the falling edge of CLK.

The largest possible initial count is 0 ; this is equivalent to $2^{16}$ for binary counting and $10^{4}$ for $B C D$ counting.

The Counter does not stop when it reaches zero. In Modes $0,1,4$, and 5 the Counter "wraps around" to the highest count, either FFFF hex for binary counting or 9999 for BCD counting, and continues counting. Modes 2 and 3 are periodic; the Counter reloads itself with the initial count and continues counting from there.

## 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
*NOTICE: 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 10 \%$ )

| 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.0 \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 |  | 140 | mA |  |

CAPACITANCE ( $\left.\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| 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 <br> returned to $V_{S S}$ |

A.C. CHARACTERISTICS $\left(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, $\mathrm{GND}=0 \mathrm{~V}$ )

Bus Parameters (Note 1)
READ CYCLE

| Symbol | Parameter | 8254 |  | 8254-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $t_{\text {AR }}$ | Address Stable Before $\overline{\mathrm{RD}} \downarrow$ | 45 |  | 30 |  | ns |
| ${ }_{\text {t }} \mathrm{R}$ | $\overline{\mathrm{CS}}$ Stable Before $\overline{\mathrm{RD}} \downarrow$ | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RA}}$ | Address Hold Time After $\overline{\mathrm{RD}} \uparrow$ | 0 |  | 0 |  | ns |
| $t_{\text {RR }}$ | $\overline{\mathrm{RD}}$ Puise Width | 150 |  | 95 |  | ns |
| $t_{\text {RD }}$ | Data Delay from $\overline{\mathrm{R}} \bar{\downarrow} \downarrow$ |  | 120 |  | 85 | ns |
| $t_{\text {AD }}$ | Data Delay from Address |  | 220 |  | 185 | ns |
| $t_{\text {bF }}$ | $\overline{\mathrm{RD}} \uparrow$ to Data Floating | 5 | 90 | 5 | 65 | ns |
| $\mathrm{t}_{\mathrm{RV}}$ | Command Recovery Time | 200 |  | 165 |  | ns |

Note 1: AC timings measured at $\mathrm{V}_{\mathrm{OH}}=2.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{OL}}=0.8 \mathrm{~V}$.

## A.C. CHARACTERISTICS (Continued)

## WRITE CYCLE

| Symbol | Parameter | 8254 |  | 8254-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {AW }}$ | Address Stable Before $\overline{\mathrm{WR}} \downarrow$ | 0 |  | 0 |  | ns |
| tsw | $\overline{\mathrm{CS}}$ Stable Before $\overline{\mathrm{WR}} \downarrow$ | 0 |  | 0 |  | ns |
| twA | Address Hold Time $\overline{\mathrm{WR}} \uparrow$ | 0 |  | 0 |  | ns |
| tww | $\overline{\text { WR Pulse Width }}$ | 150 |  | 95 |  | ns |
| tow | Data Setup Time Before $\overline{\mathrm{WR}} \uparrow$ | 100 |  | 95 |  | ns |
| twD | Data Hold Time After $\overline{\mathrm{WR}} \uparrow$ | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RV}}$ | Command Recovery Time | 200 |  | 165 |  | ns |

CLOCK AND GATE $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | 8254 |  | 8254-2 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }_{\text {t CLK }}$ | Clock Period | 125 | DC | 100 | DC | ns |
| tPWH | High Pulse Width | 60 |  | 30 |  | ns |
| $t_{\text {PWL }}$ | Low Pulse Width | 60 |  | 50 |  | ns |
| $t_{R}$ | Clock Rise Time |  | 100 |  | 100 | ns |
| ${ }_{\text {t }}$ | Clock Fall Time |  | 100 |  | 100 | ns |
| $\mathrm{t}_{\mathrm{GW}}$ | Gate Width High | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{GL}}$ | Gate Width Low | 50 |  | 50 |  | ns |
| $\mathrm{t}_{\mathrm{GS}}$ | Gate Setup Time to CLK $\uparrow$ | 50 |  | 40 |  | ns |
| ${ }_{\text {tGH }}$ | Gate Hold Time After CLK $\uparrow$ | $50^{[2]}$ |  | $50^{[2]}$ |  | ns |
| $\mathrm{t}_{\mathrm{OD}}$ | Output Delay from CLK $\downarrow$ |  | 150 |  | 100 | ns |
| todg | Output Delay from Gate $\downarrow$ |  | 120 |  | 100 | ns |

Note 2: In Modes 1 and 5 triggers are sampled on each rising clock edge. A second trigger within 120 ns ( 70 ns for the $8254-2$ ) of the rising clock edge may not be detected.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


WAVEFORMS
WRITE


## READ



## RECOVERY

$\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$


CLOCK AND GATE


# 8255A/8255A-5 <br> PROGRAMMABLE PERIPHERAL INTERFACE 

MCS-85 ${ }^{\text {TM }}$ Compatible 8255A.5<br>24 Programmable I/O Pins<br>- Completely TTL Cómpatible<br>Fully Compatible with Intel ${ }^{\circledR}$ Microprocessor Families<br>- 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.


Figure 1. 8255A Block Diagram


Figure 2. Pin Configuration

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

## ( $\overline{C S}$ )

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 ( $\mathrm{A}_{0}$ and $\mathrm{A}_{1}$ ).

## 8255A BASIC OPERATION

| $A_{1}$ | $A_{0}$ | $\overline{\text { RD }}$ | $\overline{\mathrm{WR}}$ | $\overline{\mathbf{C S}}$ | INPUT OPERATION (READ) |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 1 | 0 | PORT A $\Rightarrow$ DATA BUS |
| 0 | 1 | 0 | 1 | 0 | PORT B $\Rightarrow$ DATA BUS |
| 1 | 0 | 0 | 1 | 0 | PORT C $\Rightarrow$ DATA BUS |
|  |  |  |  |  | OUTPUT OPERATION <br> (WRITE) |
| 0 | 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT A |
| 0 | 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT B |
| 1 | 0 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ PORT C |
| 1 | 1 | 1 | 0 | 0 | DATA BUS $\Rightarrow$ CONTROL |
|  |  |  |  |  | DISABLE FUNCTION |
| X | X | X | X | 1 | DATA BUS $\Rightarrow 3-$ STATE |
| 1 | 1 | 0 | 1 | 0 | ILLEGAL CONDITION |
| X | X | 1 | 1 | 0 | DATA BUS $\Rightarrow 3-$ STATE |



Figure 3. 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 ( $\mathrm{A}, \mathrm{C}, \mathrm{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 8255A.

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, $\mathrm{D}_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :---: | :---: |
| RESET | RESET INPUT |
| CS | CHIP SELECT |
| RD | READ INPUT |
| WR | WRITE INPUT |
| A0, A1 | PORT ADDRESS |
| PA7PA0 | PORT A (BIT) |
| PB7 PB0 | PORT B (BIT) |
| PC7.PC0 | PORT C (BIT) |
| $\mathrm{V}_{\mathrm{CC}}$ | +5 VOLTS |
| GND | 0 VOLTS |

Figure 4. 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.

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 5. Basic Mode Definitions and Bus Interface


Figure 6. 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 7. 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 Port Definition

| A |  | B |  | GROUP A |  |  | GROUP B |  |
| :---: | :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{D}_{\mathbf{4}}$ | $\mathbf{D}_{\mathbf{3}}$ | $\mathbf{D}_{\mathbf{1}}$ | $\mathbf{D}_{\mathbf{0}}$ | PORT A | PORT C <br> (UPPER) | $\#$ | PORT B | PORT C <br> (LOWER) |
| 0 | 0 | 0 | 0 | OUTPUT | OUTPUT | 0 | OUTPUT | OUTPUT |
| 0 | 0 | 0 | 1 | OUTPUT | OUTPUT | 1 | OUTPUT | INPUT |
| 0 | 0 | 1 | 0 | OUTPUT | OUTPUT | 2 | INPUT | OUTPUT |
| 0 | 0 | 1 | 1 | OUTPUT | OUTPUT | 3 | INPUT | INPUT |
| 0 | 1 | 0 | 0 | OUTPUT | INPUT | 4 | OUTPUT | OUTPUT |
| 0 | 1 | 0 | 1 | OUTPUT | INPUT | 5 | OUTPUT | INPUT |
| 0 | 1 | 1 | 0 | OUTPUT | INPUT | 6 | INPUT | OUTPUT |
| 0 | 1 | 1 | 1 | OUTPUT | INPUT | 7 | INPUT | INPUT |
| 1 | 0 | 0 | 0 | INPUT | OUTPUT | 8 | OUTPUT | OUTPUT |
| 1 | 0 | 0 | 1 | INPUT | OUTPUT | 9 | OUTPUT | INPUT |
| 1 | 0 | 1 | 0 | INPUT | OUTPUT | 10 | INPUT | OUTPUT |
| 1 | 0 | 1 | 1 | INPUT | OUTPUT | 11 | INPUT | INPUT |
| 1 | 1 | 0 | 0 | INPUT | INPUT | 12 | OUTPUT | OUTPUT |
| 1 | 1 | 0 | 1 | INPUT | INPUT | 13 | OUTPUT | INPUT |
| $\mathbf{1}$ | 1 | 1 | 0 | INPUT | INPUT | 14 | INPUT | OUTPUT |
| $\mathbf{1}$ | 1 | 1 | 1 | INPUT | INPUT | 15 | INPUT | INPUT |

## MODE 0 Configurations

CONTROL WORD \#0

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |



CONTROL WORD \#2

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |



CONTROL WORD \#3

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |



CONTROL WORD \#1


CONTROL WORD \#4

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |



CONTROL WORD \#8

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{7}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |



CONTROL WORD \#9

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 1 |



CONTROL WORD \#6

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 0 | 1 | 0 | 1 | 0 |



CONTROL WORD \#10

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $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 \#11

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 0 | 0 | 1 | 1 |



CONTROL WORD \#12

| $D_{7}$ | $D_{6}$ | $D_{5}$ | $D_{4}$ | $D_{3}$ | $D_{2}$ | $D_{1}$ | $D_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |



CONTROL WORD \#13

| $\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 | 0 | 1 |



CONTROL WORD \#14

| $\mathrm{D}_{7}$ | $\mathrm{D}_{6}$ | $\mathrm{D}_{5}$ | $\mathrm{D}_{4}$ | $\mathrm{D}_{3}$ | $\mathrm{D}_{2}$ | $\mathrm{D}_{1}$ | $\mathrm{D}_{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 1 | 0 | 0 | 1 | 1 | 0 | 1 | 0 |



CONTROL WORD \#15

| $\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 8. MODE 1 Input


Figure 9. MODE 1 (Strobed Input)

## Output Control Signal Definition

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 10. MODE 1 Output


Figure 11. 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 12. 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}$.


Figure 13. MODE Control Word


Figure 14. MODE 2


Figure 15. MODE 2 (Bidirectional)

NOTE: Any sequence where $\overline{W R}$ occurs before $\overline{A C K}$ and $\overline{S T B}$ occurs before $\overline{\operatorname{RD}}$ is permissible. $(\operatorname{INTR}=\mathrm{IBF} \cdot \overline{\mathrm{MASK}} \cdot \overline{\mathrm{STB}} \cdot \overline{\mathrm{RD}}+\overline{\mathrm{OBF}} \cdot \overline{\mathrm{MASK}} \cdot \overline{\mathrm{ACK}} \cdot \overline{\mathrm{WR}})$


Figure 16. MODE $1 / 4$ Combinations

## Mode Definition Summary

|  | MODE O |  |
| :--- | :--- | :--- |
|  | IN | OUT |
| $\mathrm{PA}_{0}$ | IN | OUT |
| $\mathrm{PA}_{1}$ | IN | OUT |
| $\mathrm{PA}_{2}$ | IN | OUT |
| $\mathrm{PA}_{3}$ | IN | OUT |
| $\mathrm{PA}_{4}$ | IN | OUT |
| $\mathrm{PA}_{5}$ | IN | OUT |
| $\mathrm{PA}_{6}$ | IN | OUT |
| $\mathrm{PA}_{7}$ | IN | OUT |
| $\mathrm{PB}_{0}$ | IN | OUT |
| $\mathrm{PB}_{1}$ | IN | OUT |
| $\mathrm{PB}_{2}$ | IN | OUT |
| $\mathrm{PB}_{3}$ | IN | OUT |
| $\mathrm{PB}_{4}$ | IN | OUT |
| $\mathrm{PB}_{5}$ | IN | OUT |
| $\mathrm{PB}_{6}$ | IN | OUT |
| $\mathrm{PB}_{7}$ | IN | OUT |
| $\mathrm{PC}_{0}$ | IN | OUT |
| $\mathrm{PC}_{1}$ | IN | OUT |
| $\mathrm{PC}_{2}$ | IN | OUT |
| $\mathrm{PC}_{3}$ | IN | OUT |
| $\mathrm{PC}_{4}$ | IN | OUT |
| $\mathrm{PC}_{5}$ | IN | OUT |
| $\mathrm{PC}_{6}$ | IN | OUT |
| $\mathrm{PC}_{7}$ | IN | OUT |
|  |  |  |


| MODE 1 |  |
| :---: | :---: |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| IN | OUT |
| INTR $_{B}$ | $\mathrm{INTR}_{B}$ |
| $\mathrm{IBF}_{B}$ | $\overline{\mathrm{OBF}}_{\mathrm{B}}$ |
| $\overline{S T B}_{B}$ | $\overline{A C K}_{B}$ |
| $\mathrm{INTR}_{A}$ | $\mathrm{INTR}_{\text {A }}$ |
| $\overline{S T B}_{A}$ | 1/O |
| $\mathrm{IBF}_{\text {A }}$ | 1/0 |
| 1/O | $\overline{\text { ACK }}^{\text {A }}$ |
| 1/0 | $\overline{O B F}_{A}$ |

$\longrightarrow$
$\longrightarrow$

## 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 17. MODE 1 Status Word Format


Figure 18. 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 19 through 25 present a few examples of typical applications of the 8255A.


Figure 19. Printer Interface


Figure 20. Keyboard and Display Interface


Figure 21. Keyboard and Terminal Address Interface


Figure 22. Digital to Analog, Analog to Digital


Figure 24. Basic Floppy Disc Interface


Figure 23. Basic CRT Controller Interface


Figure 25. Machine Tool 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
*NOTICE: 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 $\quad\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{FH}}$ | 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}}(\mathrm{DB})$ | Output High Voltage (Data Bus) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OH}}(\mathrm{PER})$ | Output High Voltage (Peripheral Port) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{DAR}}{ }^{[1]}$ | Darlington Drive Current | -1.0 | -4.0 | mA | $\mathrm{R}_{\mathrm{EXT}}=750 \Omega ; \mathrm{V}_{\mathrm{EXT}}=1.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 120 | mA |  |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{OFL}}$ | Output Float Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to .45 V |

## NOTE:

1. Available on any 8 pins from Port $B$ and $C$.

CAPACITANCE $\quad\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol . | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to GND |

## A.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 \%$, $\mathrm{GND}=0 \mathrm{~V}$ )

## Bus Parameters

READ

| Symbol | Parameter | 8255A |  | 8255A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {AR }}$ | Address Stable Before READ | 0 |  | 0 |  | ns |
| $t_{\text {RA }}$ | - Address Stable After READ | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{RR}}$ | READ Pulse Width | 300 |  | 300 |  | ns |
| $t_{\text {RD }}$ | Data Valid From READ ${ }^{[1]}$ |  | 250 |  | 200 | ns |
| tDF | Data Float After READ | 10 | 150 | 10 | 100 | ns |
| $t_{\text {R } V}$ | Time Between READs and/or WRITEs | 850 |  | 850 |  | ns |

## A.C. CHARACTERISTICS (Continued) <br> WRITE

| Symbol | Parameter | 8255A |  | 8255A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {t }}$ AW | Address Stable Before WRITE | 0 |  | 0 |  | ns |
| twa | Address Stable After WRITE | 20 |  | 20 |  | ns |
| ${ }^{\text {tw }}$ W | WRITE Pulse Width | 400 |  | 300 |  | ns |
| ${ }^{\text {t }}$ W | Data Valid to WRITE (T.E.) | 100 |  | 100 |  | ns |
| twD | Data Valid After WRITE | 30 |  | 30 |  | ns |

OTHER TIMINGS

| Symbol | Parameter | 8255A |  | 8255A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {twB }}$ | WR = 1 to Output ${ }^{[1]}$ |  | 350 |  | 350 | ns |
| $\mathrm{t}_{\mathrm{IR}}$ | Peripheral Data Before RD | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{HR}}$ | Peripheral Data After RD | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {AK }}$ | ACK Pulse Width | 300 |  | 300 |  | ns |
| $\mathrm{t}_{\text {ST }}$ | STB Pulse Width | 500 |  | 500 |  | ns |
| $t_{\text {PS }}$ | Per. Data Before T.E. of STB | 0 |  | 0 |  | ns |
| ${ }_{\text {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 |
| $t_{\text {WOB }}$ | $W \mathrm{R}=1$ to OBF $=0^{[1]}$ |  | 650 |  | 650 | ns |
| ${ }^{\text {t }}$ AOB | $\mathrm{ACK}=0$ to $\mathrm{OBF}=1^{[1]}$ |  | 350 |  | 350 | ns |
| ${ }^{\text {S SIB }}$ | STB $=0$ to $I B F=1^{[1]}$ |  | 300 |  | 300 | ns |
| ${ }^{\text {R }}$ IB | $\mathrm{RD}=1$ to $\mathrm{IBF}=0^{[1]}$ |  | 300 |  | 300 | ns |
| $\mathrm{t}_{\text {RIT }}$ | $R D=0$ to INTR $=0{ }^{[1]}$ |  | 400 |  | 400 | ns |
| ${ }^{\text {S SIT }}$ | STB $=1$ to INTR = $1^{[1]}$ |  | 300 |  | 300 | ns |
| ${ }_{\text {t }}^{\text {AIT }}$ | ACK $=1$ to $\mathrm{INTR}=1^{[1]}$ |  | 350 |  | 350 | ns |
| ${ }^{\text {t WIT }}$ | WR $=0$ to $\mathrm{INTR}=0^{[1,3]}$ |  | 450 |  | 450 | ns |

## NOTES:

1. Test Conditions: $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
2. Period of Reset pulse must be at least $50 \mu \mathrm{~s}$ during or after power on. Subsequent Reset pulse can be 500 ns min.
3. INTR $\uparrow$ may occur as early as $\overline{\mathrm{WR}} \downarrow$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS



MODE 0 (BASIC OUTPUT)


## WAVEFORMS (Continued)



MODE 1 (STROBED OUTPUT)


## WAVEFORMS (Continued)

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. (INTR $=\mathrm{IBF} \cdot \overline{\mathrm{MASK}} \cdot \overline{\mathrm{STB}} \cdot \overline{\mathrm{RD}}+\overline{\mathrm{OBF}} \cdot \overline{\mathrm{MASK}} \cdot \overline{\mathrm{ACK}} \cdot \overline{\mathrm{WR}})$

## WRITE TIMING



READ TIMING


8275
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
- MCS-51 ${ }^{\text {TM }}$, MCS-85 ${ }^{\text {TM }}$, IAPX 86, and iAPX 88 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.


Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Descriptions

| Symbol | $\begin{aligned} & \hline \text { Pin } \\ & \text { No. } \end{aligned}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{LC}_{3}$ <br> $\mathrm{LC}_{2}$ <br> $\mathrm{LC}_{1}$ <br> $\mathrm{LC}_{0}$ | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | 0 | Line Count: Output from the line counter which is used to address the character generator for the line positions on the screen. |
| DRQ | 5 | 0 | DMA Request: Output signal to the 8257 DMA controller requesting a DMA cycle. |
| $\overline{\text { DACK }}$ | 6 | 1 | DMA Acknowledge: Input signal from the 8257 DMA controller acknowledging that the requested DMA cycle has been granted. |
| HRTC | 7 | 0 | Horizontal Retrace: Output signal which is active during the programmed horizontal retrace interval. During this period the VSP output is high and the LTEN output is low. |
| VRTC | 8 | 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. |
| $\overline{\mathrm{RD}}$ | 9 | 1 | Read Input: A control signal to read registers. |
| $\overline{\text { WR }}$ | 10 | 1 | Write Input: A control signal to write commands into the control registers or write data into the row buffers during a DMA cycle. |
| LPEN | 11 | 1 | Light Pen: Input signal from the CRT system signifying that a light pen signal has been detected. |
| $\mathrm{DB}_{0}$ <br> $\mathrm{DB}_{1}$ <br> $\mathrm{DB}_{2}$ <br> $\mathrm{DB}_{3}$ <br> $\mathrm{DB}_{4}$ <br> $\mathrm{DB}_{5}$ <br> $\mathrm{DB}_{6}$ <br> $\mathrm{DB}_{7}$ | $\begin{aligned} & 12 \\ & 13 \\ & 14 \\ & 15 \\ & 16 \\ & 17 \\ & 18 \\ & 19 \\ & \hline \end{aligned}$ | I/O | Bi-Directional Three-State Data Bus Lines: The outputs are enabled during a read of the C or P ports. |
| Ground | 20 |  | Ground. |


| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $V_{C C}$ | 40 |  | +5 V Power Supply. |
| $\begin{aligned} & \mathrm{LA}_{0} \\ & \mathrm{LA}_{1} \end{aligned}$ | $\begin{aligned} & 39 \\ & 38 \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. |
| LTEN | 37 | 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. |
| RVV | 36 | 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. |
| VSP | 35 | 0 | Video Suppression: Output signal used to blank the video signal to the CRT. This output is active: <br> -during the horizontal and vertical retrace intervals. <br> -at the top and bottom lines of rows if underline is programmed to be number 8 or greater. <br> -when an end of row or end of screen code is detected. <br> -when a DMA underrun occurs. <br> -at regular intervals ( $1 / 16$ frame frequency for cursor, $1 / 32$ frame frequency for character and field attri-butes)-to create blinking displays as specified by cursor, character attribute, or field attribute programming. |
| $\begin{aligned} & \text { GPA }_{1} \\ & \text { GPA }_{0} \end{aligned}$ | $\begin{aligned} & 34 \\ & 33 \end{aligned}$ | 0 | General Purpose Attribute Codes: Outputs which are enabled by the general purpose field attribute codes. |
| HLGT | 32 | 0 | Highlight: Output signal used to intensify the display at particular positions on the screen as specified by the character attribute codes or field attribute codes. |
| IRQ | 31 | 0 | Interrupt Request. |
| CCLK | 30 | 1 | Character Clock (from dot/timing logic). |
| $\mathrm{CC}_{6}$ <br> $\mathrm{CC}_{5}$ <br> $\mathrm{CC}_{4}$ <br> $\mathrm{CC}_{3}$ <br> $\mathrm{CC}_{2}$ <br> $\mathrm{CC}_{1}$ <br> $\mathrm{CC}_{0}$ | $\begin{aligned} & \hline 29 \\ & 28 \\ & 27 \\ & 26 \\ & 25 \\ & 24 \\ & 23 \\ & \hline \end{aligned}$ | 0 | Character Codes: Output from the row buffers used for character selection in the character generator. |
| CS | 22 | 1 | Chip Select: The read and write are enabled by CS. |
| $\mathrm{A}_{0}$ | 21 | 1 | Port Address: A high input on $\mathrm{A}_{0}$ selects the "C" port or command registers and a low input selects the "P" port or parameter registers. |

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

## CS (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 3. 8275 Block Diagram Showing Data Bus Buffer and Read/Write Functions

| $\mathbf{A}_{\mathbf{0}}$ | $\overline{\mathrm{BD}}$ | $\overline{\mathrm{WR}}$ | $\overline{\mathbf{C S}}$ |  |
| :---: | :---: | :---: | :---: | :--- |
| 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_{0-1}$ (Line Attribute), HGLT (Highlight), RVV (Reverse Video), LTEN (Light Enable), VSP (Video Suppress), and GPA 0-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 4. 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 5. 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.)


Figure 6. 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 7. 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 8. 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 9. 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 10．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 11．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 dis－ played，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$ | $\square$ | 0000 | 1111 |
| 1 | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | 0001 | 0000 |
| 2 | $\square$ | $\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$ | － | $\square$ | 0100 | 0011 |
| 5 | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | ■ | $\square$ | 0101 | 0100 |
| 6 | $\square$ | － | $\square$ | － | $\square$ | $\square$ | $\square$ | － | $\square$ | 0110 | 0101 |
| 7 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | － | 0111 | 0110 |
| 8 | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | 1000 | 0111 |
| 9 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | 1001 | 1000 |
| 10 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1010 | 1001 |
| 11 | $\square$ | $\square$ | $\square$ | $\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$ | $\square$ | 1110 | 1101 |
| 15 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1111 | 1110 |

Figure 12．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$ | 0001 | 0000 |
| 2 | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0010 | 0001 |
| 3 | 口 | － | $\square$ | $\square$ | $\square$ | － | $\square$ | 0011 | 0010 |
| 4 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | 0100 | 0011 |
| 5 | $\square$ | － | $\square$ | $\square$ | － | $\square$ | $\square$ | 0101 | 0100 |
| 6 | $\square$ | － | $\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$ | $\square$ | 1001 | 1000 |

Figure 13．Example of a 10 －Line Format

Mode 0 is useful for character generators that leave address zero blank and start at address 1 ．Mode 1 is useful for char－ acter 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$ | $\square$ | $\bigcirc$ | $\square$ | $\square$ | 0000 | 1011 |
| 1 | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | 0001 | 0000 |
| 2 | $\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$ | － | 0100 | 0011 |
| 5 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0101 | 0100 |
| 6 | $\square$ | － | － | － | － | － | － | $\cdots$ | $\square$ | 0110 | 0101 |
| 7 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0 | － | $\square$ | 0111 | 0110 |
| 8 | $\square$ | － | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | － | $\square$ | 1000 | 0111 |
| 9 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1001 | 1000 |
| 10 | － | $\cdots$ | － | － | － | $\cdots$ | － | $\square$ | － | 1010 | 1001 |
| 11 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 口 | $\square$ | $\square$ | － | 1011 | 1010 |
| Top and Bottom Lines are Blanked |  |  |  |  |  |  |  |  |  |  |  |

Figure 14．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 15．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．

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

## 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 17. 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 18. 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 19. 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.

The first DMA request for a row will start at the first character clock of the preceding row. If the burst mode is used, the first DMA request may occur a number of character clocks later. This number is equal to the programmed burst space.

If, for any reason, there is a DMA underrun, a flag in the status word will be set.


Figure 20. 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 interrupt 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 21. Beginning of Interrupt Request IRO will go inactive after the status register is read.


Figure 22. 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 ( $\mathrm{MSB}=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 ( $L A_{0-1}$ ), the Video Suppression 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
MSB LSB
 CHARACTER ATTRIBUTE CODE


Figure 23. Typical Character Attribute Logic

Table 2. Character Attributes
Character attributes were designed to produce the following graphics:

| CHARACTER ATTRIBUTE CODE "CCCC" |  | OUTPUTS |  |  |  | SYMBOL | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | LA ${ }_{1}$ | LA ${ }_{0}$ | 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 | 1-2me | 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 |  |  |  | ' |  |  |

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

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 hoids 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
$U=1$ FOR UNDERLINE
$\mathbf{G G}=\mathrm{GPA}_{1}, \mathrm{GPA}_{0}$
*More than one attribute can be enabled at the same time. If the blinking and reverse video attributes are enabled simultaneously, only the reversed characters will blink.

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 24. 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 25. Block Diagram Showing FIFO Activation

Each row buffer has a corresponding FIFO. 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 $\left(C_{0-6}\right)$. 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 26. Example of the Invisible Field Attribute Mode (Underline Attribute)

## Field and Character Attribute Interaction

Character Attribute Symbols are affected by the Reverse Video (RVV) 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_{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 $\mathbf{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 | $\mathrm{A}_{0}$ | DESCRIPTION | MSB | DAT |  |  | LS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Reset Command | $0 \quad 0$ | 0 | 0 |  | 0 | 0 |
|  | Write | 0 | Screen Comp Byte 1 | S H | H | H |  | H | H |
| Parameters | Write | 0 | Screen Comp Byte 2 | $V \vee R R R R R R$ |  |  |  |  |  |
|  | Write | 0 | Screen Comp Byte 3 | $\cup \cup$ | U | L | L | L | L |
|  | Write | 0 | Screen Comp Byte 4 | $M \mathcal{M} \subset \mathcal{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.

\section*{Parameter - S Spaced Rows <br> | $\mathbf{S}$ | FUNCTIONS |
| :---: | :---: |
| 0 | Normal Rows |
| 1 | Spaced Rows |}

Parameter - HHHHHHH Horizontal Characters/Row
HO. OF CHARACTERS
PER ROW

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 | - | RR | R | RR |  | cal 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 - LLLL Number of Lines per Character Row

| $\mathbf{L}$ | $\mathbf{L}$ | $\mathbf{L}$ | $\mathbf{L}$ | NO. OF LINES/ROW |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 1 | 2 |
| 0 | 0 | 1 | 0 | 3 |
|  |  |  |  | . |
|  |  |  |  | . |
| 1 | 1 | 1 | 1 | 16 |

Parameter - M Line Counter Mode

| $\boldsymbol{M}$ | LINE COUNTER MODE |
| :---: | :---: |
| $\mathbf{0}$ | Mode 0 (Non-Offset) |
| $\mathbf{1} \cdots$ | 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 |

Parameter - ZZZZ Horizontal Retrace Count

| $\mathbf{z}$ | $\mathbf{z}$ | $\mathbf{z}$ | $\mathbf{z}$ | NO. OF CHARACTER <br> COUNTS PER HRTC |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 2 |
| 0 | 0 | 0 | 1 | 4 |
| 0 | 0 | 1 | 0 | 6 |
|  | $\cdot$ |  | $\cdot$ |  |
|  | $\cdot$ |  | $\cdot$ |  |
| 1 | 1 | 1 | 1 | 32 |

Note: uuuu MSB determines blanking of top and bottom lines ( 1 = blanked, $0=$ not blanked) .

## 2. Start Display Command:

|  | OPERATION | A $_{\mathbf{0}}$ | DESCRIPTION | MSB |  |  |  | LSB |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Start Display | 0 | 0 | 1 | S. | S | S | B | B |
| No parameters |  |  |  |  |  |  |  |  |  |  |  |


| S S S BURST SPACE CODE |  |  |  |
| :---: | :---: | :---: | :---: |
| S | S | S | NO. OF CHARACTER CLOCKS 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 |
| B | B | NO. OF DMA CYYCLES PER <br> 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:


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


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 | DATA | BU |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Load Cursor | 10 | 00 | 0 | 0 | 0 |
| Parameters | Write Write | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | Char. Number Row Number | (Char. Position in Row) (Row Number) |  |  |  |  |

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:

|  |  |  | DATA BUS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |  |  | LSB |  |  |  |
| Command | Write | 1 | Enable Interrupt | 1 | 0 | 1 | 0 | 0 | 0 | 0 |
| No parameters |  |  |  |  |  |  |  |  |  |  |

Action - The interrupt enable status flag is set and interrupts are enabled.
7. Disable Interrupt Command:

|  |  |  |  |  | DATA BUS |  |  |  |  |
| ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |  |  |  | LSB |
| Command | Write | 1 | Disable Interrupt | 1 | 1 | 0 | 0 | 0 | 0 |

Action - Interrupts are disabled and the interrupt enable status flag is reset.

## 8. Preset Counters Command:

|  | OPERATION | $A_{0}$ | DESCRIPTION | MSB |  |  |  |  | LSB |
| ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Preset Counters | 1 | 1 | 1 | 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

|  |  |  | DATA BUS |  |  |
| :--- | :---: | :---: | :--- | :--- | ---: |
|  | OPERATION | A $_{0}$ | DESCRIPTION | MSB | LSB |
| Command | Read | 1 | Status Word | 0 IE IR LPIC 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 or 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
*NOTICE: 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 ( $\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. | 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.45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 160 | mA |  |

CAPACITANCE $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| 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 $V_{\mathrm{SS}}$. |

## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{GND}=0 \mathrm{~V}\right)$

## Bus Parameters

## READ CYCLE

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A R}$ | Address Stable Before READ | 0 |  | ns |  |
| $t_{R A}$ | Address Hold Time for READ | 0 |  | ns |  |
| $t_{R R}$ | READ Pulse Width | 250 |  | ns |  |
| $t_{R D}$ | Data Delay from READ |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | READ to Data Floating | 20 | 100 | ns | $\mathrm{C}_{\mathrm{L}}$ min. $=20 \mathrm{pF} ; \mathrm{C}_{\mathrm{L}}$ max. $=150 \mathrm{pF}$ |

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

## A.C. CHARACTERISTICS (Continued)

## CLOCK TIMING

|  |  | $\mathbf{c}$ |  |  |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test <br> Conditions |
| $t_{\text {CLK }}$ | Clock Period | 480 |  | 320 |  | ns |  |
| $\mathrm{t}_{\mathrm{KH}}$ | Clock High | 240 |  | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{KL}}$ | Clock Low | 160 |  | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{KR}}$ | Clock Rise | 5 | 30 | 5 | 30 | ns |  |
| $\mathrm{t}_{\mathrm{KF}}$ | Clock Fall | 5 | 30 | 5 | 30 | ns |  |

## OTHER TIMING


A.C. TESTING INPUT, OUTPUT WAVEFORM

A.C. TESTING LOAD CIRCUIT


WAVEFORMS

## TYPICAL DOT LEVEL TIMING


*CCLK IS A MULTIPLE OF THE DOT CLOCK AND AN INPUT TO THE 8275.

## LINE TIMING



## WAVEFORMS (Continued)

## ROW TIMING



FRAME TIMING


## INTERRUPT TIMING



## WAVEFORMS (Continued)

## DMA TIMING



LPEN


## CLOCK TIMING <br> 

## 8276 SMALL SYSTEM CRT CONTROLLER

## - Programmable Screen and Character Format

- 6 Independent Visual Field Attributes
- Cursor Control (4 Types)
- MCS-51 ${ }^{\circledR}$, MCS-85 ${ }^{\circledR}$, iAPX 86, and iAPX 88 Compatible
- Dual Row Buffers
- Single +5 V Supply
- 40-Pin Package
- 3 MHz Clock with 8276-2

The Intel 8276 Small System CRT Controller is a single chip device intended to interface CRT raster scan displays with Intel microcomputers in minimum device-count systems. Its primary function is to refresh the display by buffering character information from main memory and keeping track of the display position of the screen. The flexibility designed into the 8276 will allow simple interface to almost any raster scan CRT display. It can be used with the 8051 Single Chip Microcomputer for a minimum IC count design.


Figure 1. Block Diagram


Figure 2. Pin Configuration

Table 1. Pin Descriptions

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $L^{L} C_{3}$ <br> $\mathrm{LC}_{2}$ <br> $\mathrm{LC}_{1}$ <br> $\mathrm{LC}_{0}$ | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | 0 | Line count. Output from the line counter which is used to address the character generator for the line positions on the screen. |
| BRDY | 5 | 0 | Buffer ready. Output signal indicating that a Row Buffer is ready for loading of character data. |
| $\overline{B S}$ | 6 | 1 | Buffer select. Input signal enabling $\overline{W R}$ for character data into the Row Buffers. |
| HRTC | 7 | 0 | Horizontal retrace. Output signal which is active during the programmed horizontal retrace interval. During this period the VSP output is high and the LTEN output is low. |
| VRTC | 8 | 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. |
| $\overline{\mathrm{RD}}$ | 9 | 1 | Read input. A control signal to read registers. |
| $\overline{W R}$ | 10 | 1 | Write input. A control signal to write commands into the control registers or write data into the row buffers. |
| NC | 11 |  | No connection. |
| $\begin{aligned} & \mathrm{DB}_{0} \\ & \mathrm{DB}_{1} \\ & \mathrm{DB}_{2} \\ & \mathrm{DB}_{3} \\ & \mathrm{BB}_{4} \\ & \mathrm{BB}_{5} \\ & \mathrm{BB}_{6} \\ & \mathrm{BB}_{7} \end{aligned}$ | $\begin{aligned} & 12 \\ & 13 \\ & 14 \\ & 15 \\ & 16 \\ & 17 \\ & 18 \\ & 19 \end{aligned}$ | I/O | Bidirectional data bus. Three-state lines. The outputs are enabled during a read of the C or P ports. |
| Ground | 20 |  | Ground. |


| Symbol | $\begin{array}{\|l\|} \hline \text { Pin } \\ \text { No. } \end{array}$ | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ | 40 |  | +5 V power supply. |
| NC | 39 |  | No connection. |
| NC | 38 |  | No connection. |
| LTEN | 37 | 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. |
| RVV | 36 | 0 | Reverse video. Output signal used to activate 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. |
| VSP | 35 | 0 | Video suppression. Output signal used to blank the video signal to the CRT. This output is active: <br> - during the horizontal and vertical retrace intervals. <br> - at the top and bottom lines of rows if underline is programmed to be number 8 or greater. <br> - when an end of row or end of screen code is detected. <br> - when a Row Buffer underrun occurs. <br> - at regular intervals ( $1 / 16$ frame frequency for cursor, 1/32 frame frequency for attributes)-to create blinking displays as specified by cursor or field attribute programming. |
| GPA $_{1}$ $\mathrm{GPA}_{0}$ | $\begin{array}{\|l\|} \hline 34 \\ 33 \end{array}$ | 0 | General purpose attribute codes.Outputs which are enabled by the general purpose field attribute codes. |
| HLGT | 32 | 0 | Highlight. Output signal used to intensify the display at particular positions on the screen as specified by the field attribute codes. |
| INT | 31 | 0 | Interrupt output. |
| CCLK | 30 | 1 | Character clock (from dot/timing logic). |
| $\mathrm{CC}_{6}$ <br> $\mathrm{CC}_{5}$ <br> $\mathrm{CC}_{4}$ <br> $\mathrm{CC}_{3}$ <br> $\mathrm{CC}_{2}$ <br> $\mathrm{CC}_{1}$ <br> $\mathrm{CC}_{0}$ | $\begin{array}{\|l\|} \hline 29 \\ 28 \\ 27 \\ 26 \\ 25 \\ 24 \\ 23 \\ \hline \end{array}$ | 0 | Character codes. Output from the row buffers used for character selection in the character generator. |
| $\overline{\mathrm{CS}}$ | 22 | 1 | Chip select. Enables $\overline{\mathrm{RD}}$ of status or $\overline{\mathrm{WR}}$ of command or parameters. |
| C/ $\overline{\mathrm{P}}$ | 21 | 1 | Port address. A high input on this pin selects the " $C$ " port or command registers and a low input selects the "P" port or parameter registers. |

## FUNCTIONAL DESCRIPTION

## Data Bus Buffer

This 3-state, bidirectional, 8-bit buffer is used to interface the 8276 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.

| $\mathbf{C} / \overline{\mathbf{P}}$ | OPERATION | REGISTER |
| :---: | :---: | :---: |
| 0 | Read | RESERVED |
| 0 | Write | PARAMETER |
| 1 | Read | STATUS |
| 1 | Write | COMMAND |

## $\overline{\mathbf{R D}}$ (READ)

A "low" on this input informs the 8276 that the CPU is reading status information from the 8276.

## $\overline{\text { WR }}$ (WRITE)

A "low" on this input informs the 8276 that the CPU is writing data or control words to the 8276.

## CS (CHIP SELECT)

A "low" on this input selects the 8276 for $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ of Commands, Status, and Parameters.

## BRDY (BUFFER READY)

A "high" on this output indicates that the 8276 is ready to receive character data.

## $\overline{\mathrm{BS}}$ (BUFFER SELECT)

A "low" on this input enables $\overline{W R}$ of character data to the 8276 row buffers.

## INT (INTERRUPT)

A "high" on this output informs the CPU that the 8276 needs interrupt service.

| $\mathbf{C} / \overline{\mathbf{P}}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\overline{\mathbf{C S}}$ | $\overline{\mathbf{B S}}$ |  |
| :---: | :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | $\mathbf{1}$ | 0 | 1 | Reserved |
| 0 | 1 | 0 | 0 | 1 | Write 8276 Parameter |
| 1 | 0 | 1 | 0 | 1 | Read 8276 Status |
| 1 | 1 | 0 | 0 | 1 | Write 8276 Command |
| $\mathbf{X}$ | 1 | 0 | 1 | 0 | Write 8276 Row Buffer |
| $\mathbf{X}$ | 1 | 1 | $\mathbf{X}$ | $\mathbf{X}$ | High Impedance |
| $\mathbf{X}$ | $\mathbf{X}$ | $\mathbf{X}$ | $\mathbf{1}$ | $\mathbf{1}$ | High Impedance |

## 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 derived from the external dot clock.

## Line Counter

The Line Counter is a programmable counter that is used to determine the number of horizontal lines (Raster Scans) per character row. Its outputs are used to address the external character generator.

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

## 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 HGLT (Highlight), RVV (Reverse Video), LTEN (Light Enable), VSP (Video Suppress), and GPA ${ }_{0-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.

## Buffer Input/Output Controllers

The Buffer Input/Output Controllers decode the characters being placed in the row buffers. If the character is a field attribute or special code, they control the appropriate action. (Example: A "Highlight'" field attribute will cause the Buffer Output Controller to activate the HGLT output.)

## SYSTEM OPERATION

The 8276 is programmable to a large number of different display formats. It provides raster timing, display row buffering, visual attribute decoding and cursor timing.

It is designed to interface with standard character generators for dot matrix decoding. Dot level timing must be provided by external circuitry.

## General Systems Operational Description

Display characters are retrieved from memory and displayed on a row-by-row basis. The 8276 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 8276 uses BRDY to request character data to fill the row buffer that is not being used for display.

The 8276 displays character rows one scan line at a time. The number of scan lines per character row, the underline position, and blanking of top and bottom lines are programmable. (See Programming Section.)

The 8276 provides special Control Codes which can be used to minimize overhead. It also provides Visual Attribute Codes to cause special action on the screen without the use of the character generator. (See Visual Attributes Section.)

The 8276 also controls raster timing. This is done by generating Horizontal Retrace (HRTC) and Vertical Retrace (VRTC) signals. The timing of these signals is also programmable.

The 8276 can generate a cursor. Cursor location and format are programmable. (See Programming Section.)


Figure 3. CRT System Block Diagram


Figure 4. Display Of A Character Row

## Display Row Buffering

Before the start of a frame, the 8276 uses BRDY and $\overline{\mathrm{BS}}$ to fill one row buffer with characters.

When the first horizontal sweep is started, character codes are output to the character generator from the row buffer just filled. Simultaneously, the other row buffer is filled with the next row of characters.

After all the lines of the character row are scanned, the buffers are swapped and the same procedure is followed for the next row.

This process is repeated until all of the character rows are displayed.

Row Buffering allows the CPU access to the display memory at all times except during Buffer Loading (about $25 \%$ ). This compares favorably to alternative approaches which restrict CPU access to the display memory to occur only during horizontal and vertical retrace intervals ( $80 \%$ of the bus time is used to refresh the display.)


Figure 5. First Row Buffer Filled


Figure 6. Second Row Buffer Filled, First Row Displayed


Figure 7. First Row Buffer Filled With Third Row, Second Row Displayed

## Display Format

## SCREEN FORMAT

The 8276 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 8276 can also be programmed to blank alternate rows. In this mode, the first row is displayed, the second blanked, the third displayed, etc. Display data is not requested for the blanked rows.


Figure 9. Blank Alternate Rows Mode

## ROW FORMAT

The 8276 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 entire 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).


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$ | $\square$ | 0001 | 0000 |
| 2 | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | 0010 | 0001 |
| 3 | $\square$ | - | $\square$ | $\square$ | $\square$ | - | $\square$ | 0011 | 0010 |
| 4 | $\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$ | 0111 | 0110 |
| 8 | ㅁ. | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | 1000 | 0111 |
| 9 | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | 1.001 | 1000 |

Figure 11. Example of a 10-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 number 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 <br> Counter <br> Mode 0 | Line Counter Mode 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0000 | 1011 |
| 1 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 0001 | 0000 |
| 2 | $\square$ | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0010 | 0001 |
| 3 | $\square$ | $\square$ | - | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0011 | 0010 |
| 4 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 0100 | 0011 |
| 5 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 0101 | 0100 |
| 6 | $\square$ | - | - | $\square$ | - | - | - | $\square$ | $\square$ | 0110 | 0101 |
| 7 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 0111 | 0110 |
| 8 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | 1000 | 0111 |
| 9 | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | $\square$ | - | $\square$ | 1001 | 1000 |
| 10 | - | $\square$ | - | $\square$ | $\square$ | $\square$ | - | $\square$ | - | 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 maximum 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.

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

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

## Interrupt Timing

The 8276 can be programmed to generate an interrupt request at the end of each frame. If the 8276 interrupt enable flag is set, an interrupt request will occur at the beginning of the last display row.


Figure 18. Beginning of Interrupt

INT will go inactive after the status register is read.


Figure 19. End of Interrupt

A reset command will also cause INT to go inactive, but this is not recommended during normal service.

Note: Upon power-up, the 8276 Interrupt Enable Flag may be set. As a result, the user's cold start routine should write a reset command to the 8276 before system interrupts are enabled.

## VISUAL ATTRIBUTES AND SPECIAL CODES

The characters processed by the 8276 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 ( $\mathrm{MSB}=0$ ), or if it is a Field Attribute or Special Code (MSB = 1).

## Special Codes

Four special codes are available to help reduce bus usage.


The End of Row Code (00) activates VSP and holds it to the end of the line.

The End of Row-Stop Buffer Loading (BRDY) Code (01) causes the Buffer Loading Control Logic to stop buffer loading for the rest of the row upon being 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 Buffer Loading (BRDY) Code (11) causes the Row Buffer Control Logic to stop buffer loading for the rest of the frame upon being written. It affects the display in the same way as the End of Screen Code (10).

If the Stop Buffer Loading 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 Buffer Loading is not the last character in a row, Buffer Loading is not stopped until after the next character is read. In this situation, a dummy character must be placed in memory after the Stop Buffer Loading 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.

The 8276 can be programmed to provide visible field attribute characters; all field attribute codes will occupy a position on the screen. These codes will appear as blanks caused by activation of the Video Suppression output (VSP). The chosen visual attributes are activated after this blanked character.

## 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 8276 outputs which act as general purpose, independently programmable field attributes. GPA $_{0-1}$ are active high outputs.
```
ABCDE FGHIJKLM
```

NOPQRSTUV
$\begin{array}{llllll}12345 & 6789\end{array}$

Figure 20. Example of a Visible Field Attribute (Underline Attribute)

## FIELD ATTRIBUTE CODE



H = 1 FOR HIGHLIGHTING
B = 1 FOR BLINKING
R = 1 FOR REVERSE VIDEO
$\mathrm{U}=1$ FOR UNDERLINE
$\mathbf{G G}=\mathbf{G P A}_{1}, \mathbf{G P A}_{0}$
Note: More than one attribute can be enabled at the same time. If the blinking and reverse video attributes are enabled simultaneously, only the reversed characters will blink.

## 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 non-blinking reverse video field, the cursor will appear as a normal video block.

If a non-blinking underline cursor appears in a nonblinking underline field, the cursor will not be visible.

## Device Programming

The 8276 has two programming registers, the Command Register and the Parameter Register. It also has a Status Register. The Command Register can only be written into and the Status Register can only be read from. They are addressed as follows:

| $\mathbf{C} / \mathbf{P}$ | OPERATION | REGISTER |
| :---: | :---: | :---: |
| 0 | Read | Reserved |
| 0 | Write | Parameter |
| 1 | Read | Status |
| 1 | Write | Command |

The 8276 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 8276 instruction set consists of 7 commands.

| COMMAND | NO. OF PARAMETER BYTES |
| :--- | :---: |
| Reset | 4 |
| Start Display | 0 |
| Stop Display | 0 |
| Load Cursor | 2 |
| Enable Interrupt | 0 |
| Disable Interrupt | 0 |
| Preset Counters | 0 |

In addition, the status of the 8276 can be read by the CPU at any time.

## 1. RESET COMMAND



Action-After the reset command is written, BRDY goes inactive, 8276 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-HHHHHHH

Horizontal Characters/Row


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 | $\mathbf{R}$ | $\mathbf{R}$ | $\mathbf{R}$ | $\mathbf{R}$ | $\mathbf{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 | . |

## Parameter-UUUU Underline Placement

| $\mathbf{U}$ | $\mathbf{U}$ | $\mathbf{U}$ | $\mathbf{U}$ | LINE NUMBER OF <br> UNDERLINE |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 1 | 2 |
| 0 | 0 | 1 | 0 | 3 |
|  |  | $\cdot$ |  | $\cdot$ |
|  | $\cdot$ |  | $\cdot$ |  |
| 1 | 1 | 1 | 1 | $\cdot$ |

Parameter-LLLL Number of Lines
per Character Row
L L L L

| 0 | 0 | 0 | 0 | 1 |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 | 2 |
| 0 | 0 | 1 | 0 | 3 |
|  | . |  | $\cdot$ |  |
|  | $\cdot$ |  | $\cdot$ |  |
| 1 | 1 | 1 | 1 | 16 |

Parameter-M Line Counter Mode

| M | LINE COUNTER MODE |
| :---: | :---: |
| 0 | Mode 0 (Non-Offset) |
| 1 | Mode 1 (Offset by 1 Count) |

Parameter-CC Cursor Format

| C | C | CURSOR FORMAT |
| :--- | :--- | :--- |
| 0 | 0 | Blinking reverse video block |
| 0 | 1 | Blinking underline |
| 1 | 0 | Non-blinking reverse video block |
| 1 | 1 | Non-blinking underline |

## Parameter-ZZZZ Horizontal Retrace Count

| $\mathbf{z}$ | $\mathbf{z}$ | $\mathbf{z}$ | $\mathbf{z}$ | NO. OF CHARACTER <br> COUNTS PER HRTC |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 2 |
| 0 | 0 | 0 | 1 | 4 |
| 0 | 0 | 1 | 0 | 6 |
|  | . |  | $\cdot$ |  |
|  |  |  |  |  |
| 1 | 1 | 1 | 1 | 3 |

Note: uuuu MSB determines blanking of top and bottom lines ( 1 = blanked, $0=$ not blanked).

## 2. START DISPLAY COMMAND

|  |  |  | OPERATION | C/P | DESCRIPTION | MSB |  |  | LSB |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Start Display | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| No parameters |  |  |  |  |  |  |  |  |  |  |  |

Action-8276 interrupts are enabled, BRDY goes active, video is enabled, Interrupt Enable and Video Enable status flags are set.

## 3. STOP DISPLAY COMMAND

|  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | OPERATION | C/P | DESCRIPTION | MSB | DATA BUS |  |  |  |  |  |  |
| 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 reenable the display.

## 4. LOAD CURSOR POSITION



Action-The 8276 is conditioned to place the next two parameter bytes into the cursor position registers. Status flag not affected.

## 5. ENABLE INTERRUPT COMMAND

|  | OPERATION | C/P | DESCRIPTION | MSB |  |  |  | LSB |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Enable Interrupt | 1 | 0 | 1 | 0 | 0 | 0 | 0 |
| No parameters |  |  |  |  |  |  |  |  |  |  |

Action-The interrupt enable flag is set and interrupts are enabled.

## 6. DISABLE INTERRUPT COMMAND

|  | OPERATION | C/P | DESCRIPTION | MSB |  |  |  | LSB |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | 1 | Disable Interrupt | 1 | 1 | 0 | 0 | 0 | 0 | 0

Action-Interrupts are disabled and the interrupt enable status flag is reset.

## 7. PRESET COUNTERS COMMAND

|  |  |  |  |  | LSB |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Command | Write | $\mathbf{1}$ | Preset Counters | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 |
| No parameters |  |  |  |  |  | DATA BUS |  |  |  |  |  |

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

|  |  | DATA BUS |  |  |
| :--- | :---: | :---: | :---: | :--- |
|  | OPERATION | C/P | DESCRIPTION | MSB |
| Command | Read | 1 | Status Word | 0 IE IR $X$ IC VE BU $X$ |

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.

IC - (Improper Command) This flag is set when a command parameter string is too long or 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.

BU — (Buffer Underrun) This flag is set whenever a Row Buffer is not filled with character data in time for a buffer swap required by the display. Upon activation of this bit, buffer loading ceases, and the screen is blanked until after the vertical retrace interval.

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots . .0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ Storage Temperature $\ldots . . . . . .-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage On Any Pin
With Respect to Ground $\ldots \ldots . .-0.5 \mathrm{~V}$ to +7 V
Power Dissipation ........................... 1 Watt
*NOTICE: 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}_{\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 \mathrm{~V}$ | V |  |
| $\mathrm{~V}_{\text {OL }}$ | Output Low Voltage |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$ |
| $\mathrm{~V}_{\text {OH }}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 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 }}=\mathrm{V}_{\text {CC }}$ to 0.45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 160 | mA |  |

CAPACITANCE $\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| SYMBOL | PARAMETER | MIN. | MAX. | UNITS | TEST CONDITIONS |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {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}_{\text {SS }}$ |

## A.C. TESTING LOAD CIRCUIT



Cincludes jig capactitance

## A.C. CHARACTERISTICS $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$; $\mathrm{GND}=0 \mathrm{~V}$ )

## Bus Parameters

## 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 |  |
| $\mathrm{t}_{\text {RR }}$ | READ Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Delay from READ |  | 200 | ns | $\mathrm{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 |  |
| $\mathrm{t}_{\text {WA }}$ | Address Hold Time for WRITE | 0 |  | ns |  |
| $\mathrm{t}_{\text {WW }}$ | WRITE Pulse Width | 250 |  | ns |  |
| $\mathrm{t}_{\text {DW }}$ | Data Setup Time for WRITE | 150 |  | ns |  |
| $\mathrm{t}_{\text {WD }}$ | Data Hold Time for WRITE | 0 |  | ns |  |

## CLOCK TIMING

|  |  | 8276 |  | 8276-2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test Conditions |
| ${ }^{\text {t CLK }}$ | Clock Period | 480 |  | 320 |  | ns |  |
| $\mathrm{t}_{\mathrm{KH}}$ | Clock High | 240 |  | 120 |  | ns |  |
| $t_{\text {KL }}$ | Clock Low | 160 |  | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{KR}}$ | Clock Rise | 5 | 30 | 5 | 30 | ns |  |
| $\mathrm{t}_{\mathrm{KF}}$ | Clock Fall | 5 | 30 | 5 | 30 | ns |  |

## OTHER TIMING

| (HER TIM |  | 8276 |  | 8276-2 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Max. | Min. | Max. | Units | Test Conditions |
| ${ }^{\mathrm{t}} \mathrm{CC}$ | Character Code Output Delay |  | 150 |  | 150 | ns | $\mathrm{CL}=50 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{HR}}$ | Horizontal Retrace Output Delay |  | 200 |  | 150 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $t_{\text {LC }}$ | Line Count Output Delay |  | 400 |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| ${ }^{\text {AT }}$ | Control/Attribute Output Delay |  | 275 |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| tVR | Vertical Retrace Output Delay |  | 275 |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $t_{\text {R }}$ | INT $\downarrow$ from $\overline{\mathrm{RD}} \uparrow$ |  | 250 |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| ${ }^{\text {t }}$ WQ | BRDY $\uparrow$ from $\overline{\mathrm{WR}} \uparrow$ |  | 250 |  | 250 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| $t_{R Q}$ | BRDY $\downarrow$ from $\overline{W R} \downarrow$ | . | 200 |  | 200 | ns | $\mathrm{C}_{\mathrm{L}}=50 \mathrm{pF}$ |
| ${ }_{\text {L LR }}$ | $\overline{\mathrm{BS}} \downarrow$ to $\overline{\mathrm{WR}} \downarrow$ | 0 |  | 0 |  | ns | $\square$ |
| $\mathrm{t}_{\text {RL }}$ | $\overline{\mathrm{WR}} \uparrow$ to $\overline{\mathrm{BS}} \uparrow$ | 0 |  | 0 |  | ns |  |

## WAVEFORMS

## Typical Dot Level Timing



## Line Timing



Row Timing


Frame Timing


Interrupt Timing


## Timing for Buffer Loading



## Write Timing



Read Timing


Input and Output Waveforms for A.C. Tests


FOR A.C. TESTING, INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 ", AND 0.45V FOR A LOGIC "O." TIMING MEASUREMENTS FOR INPUT AND OUTPUT SIGNALS ARE MADE AT 2.0V FOR A LOGIC "1" AND 0.8 V FOR A LOGIC " 0

# 8279/8279-5 <br> PROGRAMMABLE KEYBOARD/DISPLAY 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 8279 is a general purpose programmable keyboard and display I/O interface device designed for use with Intel ${ }^{\oplus}$ 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.


Figure 1. Logic Symbol


Figure 2. Pin Configuration

## HARDWARE DESCRIPTION

The 8279 is packaged in a 40 pin DIP. The following is a functional description of each pin.

Table 1. Pin Descriptions

| Symbol | Pin <br> No. | Name and Function |
| :---: | :---: | :---: |
| $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ | 8 | Bi-directional data bus: All data and commands between the CPU and the 8279 are transmitted on these lines. |
| CLK | 1 | Clock: Clock from system used to generate internal timing. |
| RESET | 1 | Reset: A high signal on this pin resets the 8279. After being reset the 8279 is placed in the following mode: <br> 1) 168 -bit character display -left entry. <br> 2) Encoded scan keyboard-2 key lockout. <br> Along with this the program clock prescaler is set to 31. |
| CS | 1 | Chip Select: A low on this pin enables the interface functions to receive or transmit. |
| $\mathrm{A}_{0}$ | 1 | 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. |
| $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | 2 | 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. |
| IRQ | 1 | 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. |
| $\mathrm{V}_{\mathrm{SS}}, \mathrm{V}_{\mathrm{Cc}}$ | 2 | Ground and power supply pins. |
| $\mathrm{SL}_{0}-\mathrm{SL}_{3}$ | 4 | Scan Lines: 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). |
| $R L_{0}-\mathrm{RL}_{7}$ | 8 | Return Line: 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. |


| Symbol | Pin <br> No. | Name and Function |
| :---: | :---: | :---: |
| SHIFT | 1 | Shift: The shift input status is stored along with the key position on key closure in the Scanned Keyboard modes. It has an active internal pullup to keep it high until a switch closure pulls it low. |
| CNTL/STB | 1 | Control/Strobed Input Mode: For keyboard modes this line is used as a control input and stored like status on a key closure. The line is also the strobe line that enters the data into the FIFO in the Strobed Input mode. <br> (Rising Edge). It has an active internal pullup to keep it high until a switch closure pulls it low. |
| OUT $\mathrm{A}_{0}$-OUT $\mathrm{A}_{3}$ OUT $B_{0}$-OUT $B_{3}$ | $\begin{aligned} & 4 \\ & 4 \end{aligned}$ | Outputs: These two ports are the outputs for the $16 \times 4$ display refresh registers. The data from these outputs is synchronized to the scan lines $\left(\mathrm{SL}_{0}-\mathrm{SL}_{3}\right)$ for multi-, plexed digit displays. The two 4 bit ports may be blanked independently. These two ports may also be considered as one 8-bit port. |
| $\overline{\mathrm{BD}}$ | 1 | Blank Display: This output is used to blank the display during digit switching or by a display blanking command. |

## 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 (8x8 matrix switches) or decoded ( $4 \times 8$ matrix switches) scan lines. Key status (open or closed) stored in RAM addressable by CPU.
- Strobed Input -- Data on return lines during control line strobe is transferred to FIFO


## Output Modes

- 8 or 16 character multiplexed displays that can be organized as dual 4-bit or single 8 -bit $\left(B_{0}=D_{0}, A_{3}=D_{7}\right)$.
- 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.


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

## I/O Control and Data Buffers

The I/O 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{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ determine the direction of data flow through the Data Buffers. The Data Buffers are bi-directional buffers that connect the internal bus to the external bus. When the chip is not selected ( $\overline{C S}=1$ ), the devices are in a high impedance state. The drivers input during $\overline{\mathrm{WR}} \bullet \overline{\mathrm{CS}}$ and output during $\overline{\mathrm{RD}} \bullet \overrightarrow{\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}$.


Figure 3. Internal Block Diagram

The command is then decoded and the appropriate function is set. The timing control contains the basic timing counter chain. The first counter is a $\div \mathrm{N}$ prescaler that can be programmed to 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.

## FIFO/Sensor RAM and Status

This block is a dual function $8 \times 8$ RAM. In Keyboard or Strobed Input modes, it is a FIFO. Each new entry is written into successive RAM positions and each is then read in order of entry. FIFO status keeps track of the number of characters in the FIFO and whether it is full or empty. Too many reads or writes will be recognized as an error. The status can be read by an $\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

MSB

Code: $\quad$| 0 | 0 | 0 | $D$ | $D$ | $K$ | LSB | $K$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Where DD is the Display Mode and KKK is the Keyboard Mode.

## DD

0 0 8-bit character display - Left entry
0116 8-bit character display - Left entry*
10 8-bit character display - Right entry
116 8-bit character display - Right entry
For description of right and left entry, see Interface Considerations. Note that when decoded scan is set in keyboard mode, the display is reduced to 4 characters independent of display mode set.

## KKK

000 Encoded Scan Keyboard - 2 Key Lockout*
$\begin{array}{llll}0 & 0 & 1 & \text { Decoded Scan Keyboard - 2-Key Lockout }\end{array}$
010 Encoded Scan Keyboard - N-Key Rollover
$\begin{array}{lll}0 & 1 & 1\end{array}$ Decoded Scan Keyboard - N-Key Rollover
100 Encoded Scan Sensor Matrix
101 Decoded Scan Sensor Matrix
110 Strobed Input, Encoded Display Scan
111 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 FIFO/Sensor RAM

Code:


X = Don't Care
The CPU sets up the 8279 for a read of the FIFO/Sensor RAM by first writing this command. In the Scan Key-

[^33]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 ( $\mathrm{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}$ | $\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 ( $\mathrm{Al}=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

Code:

| 1 | 0 | 0 | AI | A | A | A | 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

Code: | $\mathbf{1}$ | $\mathbf{0}$ | $\mathbf{1}$ | X | IW | IW | BL | BL |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

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

Code:

| 1 | 1 | 0 | $C_{D}$ | $C_{D}$ | $C_{D}$ | $C_{F}$ | $C_{A}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

The $C_{D}$ bits are available in this command to clear all rows of the Display RAM to a selectable blanking code as follows:


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 $\left(C_{F}=1\right)$, 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 $\mathrm{C}_{\mathrm{F}}$; it uses the $\mathrm{C}_{\mathrm{D}}$ clearing code on the Display RAM and also clears FIFO status. Furthermore, it resynchronizes the internal timing chain.

## End Interrupt/Error Mode Set

$$
\text { Code: } \quad \begin{array}{|l|l|l|l|l|l|l|l|}
\hline 1 & 1 & 1 & E & X & X & X & X \\
\hline
\end{array}
$$

For the sensor matrix modes this command lowers the IRQ line and enables further writing into RAM. (The IRQ line would have been raised upon the detection of a change in a sensor value. This would have also inhibited further writing into the RAM until reset).

For the N -key rollover mode - if the E bit is programmed to " 1 " the chip will operate in the special Error mode. (For further details, see Interface Considerations Section.)

## Status Word

The status word contains the FIFO status, error, and display unavailable signals. This word is read by the CPU when $A_{0}$ is high and $\overline{\mathrm{CS}}$ and $\overline{\mathrm{RD}}$ are low. See Interface Considerations for more detail on status word.

## Data Read

Data is read when $A_{0}, \overline{C S}$ and $\overline{R D}$ are all low. The source of the data is specified by the Read FIFO or Read Display commands. The trailing edge of $\overline{R D}$ will cause the address of the RAM being read to be incremented if the AutoIncrement flag is set. FIFO reads always increment (if no error occurs) independent of AI.

## Data Write

Data that is written with $A_{0}, \overline{C S}$ and $\overline{W R}$ low is always written to the Display RAM. The address is specified by the latest Read Display or Write Display command. AutoIncrementing on the rising edge of $\overline{W R}$ 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 Interrupt command if the Auto-Increment flag is set to one.
Note: Multiple changes in the matrix Addressed by (SLO-3 $=0$ ) may cause multiple interrupts. (SL $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.


SCANNED KEYBOARD DATA FORMAT
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.


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:


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 if the address sequence is interrupted:


Enter next at Location 5 Auto Increment


RIGHT ENTRY MODE (AUTO INCREMENT)
Starting at an arbitrary location operates as shown below:


Entry appears to be from the initial entry point.

## 8/16 Character Display Formats

If the display mode is set to an 8 character display, the on duty-cycle is double what it would be for a 16 character display (e.g., 5.1 ms scan time for 8 characters vs. 10.3 ms for 16 characters with 100 kHz internal frequency).

## G. FIFO Status

FIFO status is used in the Keyboard and Strobed Input modes to indicate the number of characters in the FIFO and to indicate whether an error has occurred. There are two types of errors possible: overrun and underrun. Overrun occurs when the entry of another character into a full FIFO is attempted. Underrun occurs when the CPU tries to read an empty FIFO.

The FIFO status word also has a bit to indicate that the Display RAM was unavailable because a Clear Display or Clear All command had not completed its clearing operation.

In a Sensor Matrix mode, a bit is set in the FIFO status word to indicate that at least one sensor closure indication is contained in the Sensor RAM.

In Special Error Mode the S/E bit is showing the error flag and serves as an indication to whether a simultaneous multiple closure error has occurred.


*Do not drive the keyboard decoder with the MSB of the scan lines.
Figure 4. System Block Diagram

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature . . . . . . . . . . . . $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Voltage on any Pin with
Respect to Ground . . . . . . . . . . . . . . -0.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*NOTICE: 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 $\left.70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%(8279-5)\right]$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL} 1}$ | Input Low Voltage for <br> Return Lines | -0.5 | 1.4 | V |  |
| $\mathrm{~V}_{\mathrm{IL} 2}$ | Input Low Voltage for All Others | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH} 1}$ | Input High Voltage for <br> Return Lines | 2.2 |  | V |  |
| $\mathrm{~V}_{\mathrm{IH} 2}$ | Input High Voltage for All Others | 2.0 |  | V |  |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | V | Note 1 |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage on Interrupt <br> Line | 3.5 | V | Note 2 |  |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Other Outputs | 2.4 |  |  | $\mathrm{~F}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL} 1}$ | Input Current on Shift, Control and <br> Return Lines |  | +10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{IL} 2}$ | Input Leakage Current on All Others |  | $\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}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ to 0.45V |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current | mA |  |  |  |

## CAPACITÁNCE

| Symbol | Parameter | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 5 | 10 | pF | $\mathrm{f}_{\mathrm{C}}=1 \mathrm{MHz}$ Unmeasured |
| C OUT $^{\text {pins returned to } V_{S S}}$ |  |  |  |  |  |

A.C. CHARACTERISTICS $\left[T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$, $($ Note 3$\left.)\right]$

Bus Parameters
READ CYCLE

| Symbol | Parameter | 8279 |  | 8279-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {AR }}$ | Address Stable Before $\overline{\text { READ }}$ | 50 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{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}}{ }^{[4]}$ | Data Delay from $\overline{\text { READ }}$ |  | 300 |  | 150 | ns |
| $t_{A D}{ }^{[4]}$ | Address to Data Valid |  | 450 |  | 250 | ns |
| ${ }_{\text {t }}$ F | $\overline{\text { READ to Data Floating }}$ | 10 | 100 | 10 | 100 | ns |
| $\mathrm{t}_{\text {RCY }}$ | Read Cycle Time | 1 |  | 1 |  | $\mu \mathrm{s}$ |

## A.C. CHARACTERISTICS (Continued)

WRITE CYCLE

| Symbol | Parameter | 8279 |  | 8279-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {taw }}$ | Address Stable Before $\overline{\text { WRITE }}$ | 50 |  | 0 |  | ns |
| twa | Address Hold Time for WRITE | 20 |  | 0 |  | ns |
| ${ }^{\text {tww }}$ | $\overline{\text { WRITE Pulse Width }}$ | 400 |  | 250 |  | ns |
| ${ }^{\text {D W }}$ | Data Set Up Time for WRITE | 300 |  | 150 |  | ns |
| ${ }^{\text {twD }}$ | Data Hold Time for WRITE | 40 |  | 0 |  | ns |
| ${ }^{\text {twCy }}$ | Write Cycle Time | 1 |  | 1 |  | $\mu \mathrm{S}$ |

OTHER TIMINGS

| Symbol | 8279 |  | $8279-5$ |  |  |  |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
|  | Parameter | Min. | Max. | Min. | Max. | Unit |
| $\mathrm{t}_{\phi \mathrm{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 ${ }^{[5]}$ | $10 \mu \mathrm{sec}$ |

NOTES:

1. $8279, \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} ; 8279-5, \mathrm{I}_{\mathrm{OL}}=2.2 \mathrm{~mA}$.
2. $8279, \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} ; 8279-5, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$.
3. $8279, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \% ; 8279-5, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$.
4. $8279, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF} ; 8279-5, \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
5. The Prescaler should be programmed to provide a $10 \mu$ s internal clock cycle.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS

READ OPERATION


## WRITE OPERATION



## CLOCK INPUT



WAVEFORMS (Continued)


PRELCONONARY

## iAPX 43201/43202/43203 <br> VLSI MICROMAINFRAME ${ }^{\text {T }}$ SYSTEM

## - Multiprocessor Computer System provides a range of performance

Object Based Architecture Meets Operating System and High Level Language Needs
$2^{40}$ Bytes of Virtual Address Space
Protected Addressing increases reliability and fits High Level Language Needs

- Multiple I/O Subsystems provide I/O Extensibility

■ Silicon O.S. Provides:

- Transparent Multiprocessor Support
— Multitasking
- Dynamic Storage Allocation/Deallocation
- Interprocess Communication


Figure 1: General 432 System Organization

## APPLICATIONS

The 432 is a VLSI computer system aimed at a distinctive class of applications. Products wellsuited to the 432 exhibit some or all of the following attributes (as seen by the OEM, not the end user):

- a range of performance (potentially extending up to the level of a midrange mainframe) is required to span a family of related products or to provide headroom for future growth;
- maximum dependability (data integrity and uptime) of both hardware and software is critical;
- software dominates development cost and time to market;
- concurrent execution of many independent and cooperative activities characterizes the runtime environment;
- growth and evolution of services over time make software revision as important as initial development.

Compared to "traditional" microcomputer applications, these applications are larger (as measured by consumption of computer as well as staff and financial resources) and are far more complex. These factors place demanding requirements on the computer system selected to support the application.

The goal of the 432 is to significantly reduce the lifecycle costs of complex applications. Toward this end, the 432 introduces a new computer technology, an integrated system of hardware, software and methodology.

## SYSTEM ORGANIZATION

All 432-based systems share the overall organization depicted in figure 1. The boundary between the central system and the peripheral subsystems essentially divides responsibility for data processing from input/output processing. It also serves as a protective barrier: all information in central system memory is shielded (by 432 hardware) against unauthorized access; peripheral subsystems may or may not provide any sort of protection. Finally, processing required to satisfy a critical real-time constraint (usually related to an I/O device) is generally performed in a peripheral subsystem, close to the source of the constraint.

The central system is organized as a set of 432 processors that share access to a common pool of memory and to each other. General data processors (GDPs) perform computational work, while interface processors (IPs) provide pathways for input/output to and from the central memory. The number and type of processors configured in a given system is a function of performance requirements, and can be varied independently of software. All 432 processors have built-in facilities for communicating with each other, both automatically and under software control. Additional communication facilities permit programs running on the same or different processors to exchange messages through memory.

The central system supports up to $2^{24}$ bytes (16 megabytes) of real memory, and a virtual memory space of $2^{40}$ (over a trillion) bytes. Enforced automatically by the processors, every data structure in the central memory is individually protected. It is important to note here that "data structure" means any organized collection of information, including such logical entities as operand stacks and sequences of code, as well as what are ordinarily considered data structures.

A multiprocessor design like the 432 permits widely differing systems to be built from a small collection of parts. No bus design could possibly satisfy the cost, size, flexibility and performance requirements of all possible system configurations. Therefore, the 432 defines a standard processor/memory communications protocol rather than a standard bus. Designed to minimize bus occupancy and exploit available bus width, the protocol is based on a variable-length ( 1 to 16 byte) packet of information. Processors transmit request packets to memory, and receive reply packets in response to read operations. The protocol defines interprocessor communication as well. Each application is free to design an interconnect structure that implements the protocol in conformance with local needs.

Independent decentralized I/O, along the lines of the mainframe channel concept, is inherent in the 432. Input/output operations - including all device control, interrupt handling and data buffering - are delegated to peripheral subsystems. These are autonomous satellite computers attached to the central system by means of 432 interface processors. The number and configuration of peripheral subsystems is a function of application needs and can evolve over time. Any computer that can communicate over a standard 8 - or 16 -bit bus, such as Intel's Multibus design (IEEE standard 769), can serve as a peripheral subsystem. iAPX 43201 iAPX 43202

PRELOMONARY VLSI GENERAL DATA PROCESSOR

## Self-Dispatching Processors for Software-Transparent Multiprocessing

- Hardware Implemented Inter-Process Communication and Dynamic Storage Allocation


## - High-Level Language Directed

 Instruction Set with 0-3 Operand References
## Functional Redundancy Checking Mode for Hardware Error Detection

## - Capability-Based Addressing and Protection

$2^{40}$ Bytes of Virtual Address Space

- Object-Based Architecture for Improved Programmer Productivity

■ Symmetrical Support of All 8-, 16-, and 32-Bit Scalar Data Types and Proposed IEEE Standard 32-, 64-, and 80-Bit Floating Point

The Intel iAPX 432 General Data Processor (GDP) consists of two VLSI devices, the 43201 and the 43202. These companion devices (shown in Figures 1 and 2) provide the general data processing facility of the IAPX 432 Micromainframe ${ }^{T M}$ system. The combination of VLSI technology and advanced architecture in the iAPX 432 system results in mainframe functionality with a microcomputer form factor. The new objectbased architecture significantly reduces the cost of large software systems and enhances their reliability and security.

Software-transparent multiprocessing allows the user to configure systems matched to the required performance and provides an easy growth path. Hardware support for operating systems and high-level languages eases their implementation.

The GDP provides $2^{40}$ bytes of virtual address space with capability-based addressing and protection. In addition, a hardware-implemented functional redundancy checking mode is provided for the detection of hardware errors.

The iAPX 43201 and iAPX 43202 are fabricated with Intel's highly reliable +5 -volt, depletion load, N -channel, silicon gate HMOS technology and each is packaged in a 64-pin Quad In-Line Package (QUIP).


Figure 1. 43201 Pin Assignment Instruction Decoder/Microinstruction Sequencer


Figure 2. 43202 Pin Assignment Execution Unit

## iAPX 432 GDP FUNCTIONAL DESCRIPTION

The general data processor is organized internally as a three-stage microprogram-controlled pipeline. The first stage is the instruction decoder (ID); the second stage is the microinstruction sequencer (MS); and the third stage is the execution unit (EU).

The first two stages of the pipeline are physically located on the 43201 (Figure 3). Each stage of the pipeline can be considered an independent subprocessor which operates until the pipeline is full and then halts and waits for more work to do.

## Instruction Decoder

The first subprocessor of the pipeline is the ID, which performs the following functions:

- Receives macroinstructions
- Processes variable-length fields


## - Extracts logical addresses

- Generates starting addresses for the microinstruction procedures
- Generates microinstructions for simple operations

The general task facing the Instruction Decoder is to interpret the macro-instruction stream to determine which micro-instruction sequence should be initiated next and to extract logical address data. The major sub-tasks involved in accomplishing the larger goal are:

- IAPX 432 instructions contain a variable number of bits, depending upon the complexity of the instruction. Instructions may range from a few bits long to several hundred bits long. Instructions may extend over many words in memory. The Instruction Decoder requests words from memory as they are needed.
- A GDP instruction is composed of a variable number of fields and each field may contain a variable number of bits. In most cases, the


Figure 3. 43201 Block Diagram
171873-3
encoding of a field specifies its length. The Instruction Decoder interprets a field to find its length.

- The Instruction Decoder determines when an instruction boundary has been reached so that it may properly begin decoding the next instruction.
- In some cases, the interpretation of one field may depend upon the value of some previous field. In particular, the interpretation of the opcode (the last field of an instruction) depends on the value of the class field of that instruction (the first field). The Instruction Decoder saves enough information about the instruction to properly interpret every field in the instruction.
- A GDP instruction may contain an explicit reference to some location in memory. This logical address information must be transferred to the Reference Generation Unit so that the correct physical address of the operand may be generated. As with all fields of a GDP instruction, the logical address fields are also variable length fields. The Instruction Decoder has provisions for formatting the logical address information and storing it until needed by the Reference Generation Unit.
- The iAPX 432 instruction set contains several branch instructions. Since IAPX 432 instructions may start at any bit in the segment, the Instruction Decoder is able to start decoding at any point in the segment. Since branches occur fairly often in a typical instruction stream, it is also desirable to minimize the start-up time of the GDP after a branch has occurred.
- The Instruction Decoder provides a mechanism to recover from an instruction that faults. The information necessary for fault recovery will be retained by the Instruction Decoder until the instruction is successfully completed.


## Microinstruction Sequencer

The second subprocessor in the pipeline is the Microinstruction Sequencer (MS) which performs the following functions:

- Issues microinstructions to the Execution Unit (EU) (43202)
- Executes microcode sequences out of an on-chip, $4.0 \mathrm{~K} \times 16$-bit microcode ROM
- Responds to the bus control signals
- Invokes macroinṣtruction fetches
- Initiates interprocessor communication and fault handling sequences

The role of the Microinstruction Sequencer is to decide which microinstruction should be sent to the Execution Unit for each cycle. The Microinstruction Sequencer must consider each of the following when generating microinstructions:

- There are two sources of microinstructions. They may come from either the Instruction Decoder or from a ROM contained in the Microinstruction Sequencer (MS). The MS must choose the appropriate source.
- The Microinstruction Sequencer must compute the address in ROM (if any) of the next microinstruction.
- The Execution Unit may require variable lengths of time to complete some microinstructions. The Microinstruction Sequencer waits for the Execution Unit to finish the requested operation.


## Execution Unit

The 43202 contains the third stage of the GDP pipeline-the Execution Unit (EU). (Refer to Figure 4.) This unit receives microinstructions from the 43201 and routes them to one of the two independent subprocessors that make up the EU. These two are the Data Manipulation Unit (DMU) and the Reference Generation Unit (RGU).

The EU executes most microinstructions in one clock cycle. However, each of the subprocessors has an associated sequencer that may run for many cycles in response to certain microinstructions. Those sequencers are invoked for complicated arithmetic operations (in the Data Manipulation Unit) and Processor Packet bus transactions (in the Reference Generation Unit).

The Data Manipulation Unit contains the registers and arithmetic capabilities to perform the following functions:

- Hardware recognition of nine (9) data types
- Built-in state machine for 16 - and 32 -bit multiply, divide, and remainder
- Control functions for 32-, 64-, and 80-bit floating point arithmetic


Figure 4. 43202 Block Diagram
171873-4

The Reference Generation Unit performs the following functions:

- Provides the translation of a 40 -bit virtual address into a 24 -bit physical address
- Provides for a hardware-enforced domain protection system (read, write, alter, accessed)
- Handles sequencing for 8 -, 16-, 32 -, 64 -, and 80-bit memory accesses
- Controls on-chip top-of-stack register

The Execution Unit manipulates data and translates the logical addresses into physical addresses. The efficient performance of these tasks requires:

- While most microinstructions require only a single cycle to complete, there are some that require multiple and even variable numbers of cycles. As a result there are two sequences in the Execution Unit. One sequence is associated with the Data Manipulation Unit and is responsible for controlling multiple-cycle .arithmetic operations. The other sequencer works in conjunction with the Reference Generation Unit and is responsible for running cycles on the Processor Packet bus.
- When a reference to a given memory segment has been translated from its logical representation to a physical address, there is a cache in the Reference Generation Unit that maintains the physical base address as well as the length of the segment. Future references to the same segment can use this cached information as the basis for logical to physical address translation.
- There is a hardware-implemented feature which uses least-recently-used algorithms for deciding which cached segment base-length pair to replace when a new segment is referenced.
- The top 16 -bit element of the operand stack can be stored in a register in the Data Manipulation Unit.
- A circuit in the Reference Generation Unit checks every memory reference to see if it is within the length of its segment. Since the IAPX 432 architecture controls the type of access (read, write) as well, whether or not the access is allowed at all, this hardware also verifies that the reference is of the proper type.

The 43201 and 43202 components, described above, together form the GDP. Figure 5 is a block diagram that shows both units interfacing to the Packet bus as a single processor.


Figure 5. GDP Block Diagram


Figure 6. GDP Layout

## iAPX 43201/43202 <br> PHYSICAL INTERCONNECT

Figure 6 illustrates how the 43201 and 43202 are layed-out to form a GDP.

## 432 INSTRUCTIONS

Intel iAPX 432 instruction codes have been designed to minimize the space the instructions occupy in memory and still allow for efficient encoding. In order to achieve the ultimate in efficiency of storage, the instructions are encoded without regard for byte, word, or other artificial boundaries. The instructions may be viewed as a
linear sequence of bits in memory, with each instruction occupying exactly the number of bits required for its complete specification.
iAPX 432 processors view these instructions as composed of fields of varying numbers of bits that are organized to present information to the Instruction Decoder in the sequence required for decoding. A unified form for all instructions allows instruction decoding of all instructions to proceed in the same fashion.

In general, GDP instructions consist of four main fields. These fields are called the class field, the format field, the reference field, and the opcode field. The reference field, in turn, may contain
several other fields, depending upon the number and complexity of the operand references in the instruction. The fields of a GDP instruction are stored in memory in the following format.

The class field is either 4 - or 6 -bits long, depending on its encoding. The class field specifies the number of operands required by the instruction and the primitive types of the operands. The class field may indicate $0,1,2$ or 3 references.

If the class field indicates one or more references, a format field is required to specify whether the references are implicit or explicit and their uses.

In the case of explicit references the format field can indicate whether or not the reference is direct or indirect. Further, the format field may indicate that a single operand plays more than one role in the execution of the instruction. As an example, consider an instruction to increment the value of an integer in memory. This instruction contains a class field, which specifies that the operator is of order two and that the two operands both occupy a word of storage, followed by a format field, whose value indicates that a single reference specifies a logical address to be used both for fetching the source operand and for storing the result, followed by an explicit data reference to the integer to be incremented, and finally followed by an opcode field for the order-two operator INCREMENT INTEGER. It is possible for a format field to indicate that an instruction contains fewer explicit data references than are indicated by the instruction's class field. In such a case the other required data references are implicit references, and the corresponding source or result operands are obtained from or returned to the top of the operand stack. The use of implicit references is illustrated in the following example, which considers the high-level language statement

$$
A=A+B^{*} C
$$

The instruction stream fragment for this statement consists of two instructions and has the following form:

$\leftarrow$ Increasing address

Assume that $A, B$, and $C$ are integer operands. The first class field (the rightmost field above) specifies that the operator requires three references and that all three references are to word operands.

The first format field contains a code specifying two explicit data references. These references are to supply only the two source operands. The destination is referenced implicitly so that the result of the multiplication is to be pushed onto the operand stack. The second class field is identical to the first and specifies three required references by the operator. In addition, all three references are to word operands. The second format field specifies one explicit data reference to be used for both the first source operand and the destination. The second source operand is referenced implicitly and is to be popped from the operand stack when the instruction is executed.

The reference fields themselves can be of various lengths and can appear in various numbers, consistent with their specification in the class and format fields. If implicit references are specified, reference fields for them will not appear. Direct references will require more bits to specify than indirect references.

Following the class, format, and reference fields, the opcode field appears. The opcode field specifies the operator to be applied to the operands specified in the preceding fields.

## Modes of Generation

Figures 7 and 8 illustrate the two iAPX 432 system modes of generation: Selector Generation and Displacement Generation.

The modes of Selector Generation are concerned with the object structure and how they are accessed by the operands. The four modes of Selector Generation shown are:

## - Short Direct

- Long Direct
- Stack Indirect
- General Indirect

The modes of Displacement Generation specify the physical location and displacement of objects within a given segment or segment. The four modes of Displacement Generation are:

- Scalar Data Reference Mode
- Record Item Reference Mode
- Static Vector Element Reference Mode
- Dynamic Vector Element Reference Mode



Figure 8. Modes of Displacement Generation

C. STATIC VECTOR ELEMENT REFERENCE MODE

171873-10

D. DYNAMIC VECTOR ELEMENT REFERENCE MODE

Figure 8. Modes of Displacement Generation (Cont'd.)

## HARDWARE ERROR DETECTION FOR iAPX 432 PROCESSORS

iAPX 432 processors include a facility to support the hardware detection of errors by functional redundancy checking (FRC). At initialization time, each IAPX 432 processor is configured to operate as either a master or a checker processor. A master operates in the normal manner. A checker places all output pins that are being checked in the high-impedance state. Thus, those pins which are to be checked on a master and checker are parallel-connected, pin for pin, so the checker can compare its master's output values with its own. Any comparison error causes the checker to assert HERR/ (refer to Figure 9).


Figure 9. Hardware Error Detection 171873-12

## iAPX 432 INFORMATION STRUCTURE

The following section presents the information structure for an iAPX 432 system and includes a discussion of memory system requirements, physical addressing, data formats, and data representation. Any 432 processor in the system can access all the contents of physical memory. This section describes how information is represented and accessed.

## Memory

The iAPX 432 implements a two-level memory structure. The software system exists in a segmented environment in which a logical address specifies the location of a data item. The processor automatically translates this logical address into a physical address for accessing the value in physical memory.

## Physical Addressing

Logical addresses are translated by the processor into physical addresses. Physical addresses are transmitted to memory by a processor to select the beginning byte of a memory value to be referenced. A physical address is 24 binary bits in length. This results in a maximum physical memory of 16 megabytes.

## Data Formats

When a processor executes the instructions of an operation within a context, operands found in the logical address space of the context may be manipulated. An individual operand may occupy one, two, four, eight, or ten bytes of memory (byte, double byte, word, double word, or extended word, respectively). All operands are referenced by a logical address as described above. The displacement in such an address is the displacement in bytes from the base address of the data segment to the first byte of the operand. For operands consisting of multiple bytes, the address locates the low-order byte while the higher-order bytes are found at the next higher consecutive addresses.

## Data Representation

An iAPX 432 convention has been adopted for representing data operands stored in memory. The bits in a field are numbered by increasing numeric significance, with the least-significant bit shown on the right. Increasing byte addresses are shown from right to left. Examples of the five basic data lengths used in the iAPX 432 system are shown in Figure 10.

## Data Positioning

The data operand types shown in Figure 10 may be aligned on an arbitrary byte boundary within a data segment. Note that more efficient system operation may be obtained when multi-byte data structures are aligned on double-byte boundaries (if the memory system is organized in units of double bytes).

## Requirements of an IAPX 432 Memory System

The multiprocessor architecture of the IAPX 432 places certain requirements on the operation of the memory system to ensure the integrity of data


Figure 10. Basic iAPX 432 Data Lengths
items that can potentially be accessed simultaneously. Indivisible read-modify-write (RMW) operations to both double-byte and word operands in memory are necessary for manipulating system objects. When an RMW-read is processed for a location in memory, any other RMWreads from that location must be held off by the memory system until an RMW-write to that location is received (or until an RMW timeout occurs). Note that while the memory system is awaiting the RMW-write, any other types of reads and writes are allowed. Also, for ordinary reads and writes of double-byte or longer operands, the memory system must ensure the entire operand has been either read or written before beginning to process another access to the same location; e.g., if two simultaneous writes to the same location occur, the memory system must ensure that the set of locations used to store the operand does not get changed to some interleaved combination. of the two written values.

## PROCESSOR PACKET BUS DEFINITION

This section describes and defines the significance of the 19 signal lines that make up the Processor Packet bus, and the general scheme by which timing relationships on these lines are derived. Although this section defines all legal bus activities, the processors do not necessarily perform all allowed activities. Slaves to the Pro-
cessor Packet bus must support all state transitions to ensure compatibility (refer to Figure 11 for Packet bus states).

The Processor Packet bus consists of 3 control lines:

- Processor Packet bus Request (PRQ),
- Enable Buffers for Output (BOUT),
- Interconnect Status (ICS).

This bus also includes sixteen 3-state Address-Control-Data lines (ACD15 through ACD0). PRQ has two functions whose use depends upon the application; i.e., PRQ either indicates the first cycle of a transaction on the Processor Packet bus or the cancellation of a transaction initiated in the previous cycle. Of the three control lines, BOUT has the simplest function, serving as a direction control for buffers in large systems requiring more electrical drive than the processor components can provide. The ICS signal has significance pertaining to one of three different system conditions and depends on the state of the Processor Packet bus transaction. The processor interprets the ICS input as an indication of one of the following:

- Whether or not an interprocessor communication (IPC) is waiting,
- Whether or not the slave requires more time to service the processor's request,
- Whether or not a bus ERROR has occurred.


| Initial State | Next State | Trigger |
| :---: | :---: | :---: |
| Ti | $\begin{aligned} & \mathrm{Ti} \\ & \mathrm{Ti} \end{aligned}$ | Bus cycle desired <br> No bus cycle desired |
| TI | T2 | Unconditional |
| T2 | $\begin{aligned} & \mathrm{T} 3 \\ & \mathrm{Tw} \\ & \mathrm{TI} \\ & \mathrm{Ti} \end{aligned}$ | ICS high <br> ICS low <br> Cancelled, Access Pending <br> Cancelled, No Access Pending |
| T3 | $\begin{aligned} & \text { T3 } \\ & \text { Tw } \\ & \text { Tv } \\ & \text { Tvo } \end{aligned}$ | Additional transfer required, ICS high <br> Additional transfer required, ICS low <br> All transfers completed, no overlapped access <br> Current write with overlapped access |
| Tv | $\begin{aligned} & \mathrm{Ti} \\ & \mathrm{Ti} \end{aligned}$ | No access pending Access pending |
| Tvo | T2 | Unconditional |
| Tw | $\begin{aligned} & \text { Tw } \\ & \text { T3 } \end{aligned}$ | ICS Iow ICS high |

Figure 11. Processor Packet Bus State Diagram

The Address/Control/Data lines emit output specification information to indicate the type of cycle being initiated, e.g., addresses, data to be written, or control information. They also receive data returned to the processor during reads. Details of the ACD line operation and the associated control lines are summarized below.

## ACD15-ACD0 (Address/Control/Data)

During the first cycle, (T1 or Tvo) of a Processor Packet bus transaction (indicated by the rising edge of PRQ), the high-order 8 ACD bits (ACD15...ACD8) specify the type of the current transaction. In this first cycle, the low-order ACD bits (ACD7...ACDO) contain the least significant eight bits of the 24-bit physical address.

During the subsequent cycle (T2), the remainder of the address is present on the ACD pins (aligned such that the most significant byte of the address is on ACD15 through ACD8, the mid-significant byte on ACD7 through ACDO). If PRQ is asserted during T2, the access is cancelled and the ACD lines are not defined.

During the third cycle (T3 or Tw) of a Processor Packet bus transaction the processor presents a high impedance to the ACD lines for read transactions and asserts write data for write transactions.

Once the bus has entered T3 or Tv, the sequence of state transactions depends on the type of cycle requested during the preceding T 1 or Tvo. Accesses ranging in length from 1 to 32 bytes may be requested (see Table 1). If a transfer of more than one double-byte has been requested, it is necessary to enter T3 for every double-byte that is transferred. The processor may simply enter T3 or it may first enter Tw for any number of cycles (as dictated by ICS).

After all data is transferred, the processor enters either Tv or Tvo. Tvo can be entered only when the internal state of execution is such that the processor is prepared to accomplish an immediate write transfer (overlapped access). During Tvo, the ACD lines contain address and specification information aligned in the same fashion as in T1. If the processor does not require an overlapped access, the bus state moves to Tv (the ACD lines will be high impedance). After Tv, a new bus cycle can be started with T1, or the processor may enter the idle state(Ti).

## ICS (Interconnect Status)

ICS has three possible interpretations depending on the state of the bus transaction (see Table 2). Notice that under most conditions ICS has IPC significance for more than one cycle. It is important to note that a valid low during any cycle with IPC significance will signal the processor that an

Table 1. ACD Specification Encoding

| $\begin{gathered} \text { ACD } \\ 15 \end{gathered}$ | $\begin{gathered} \text { ACD } \\ 14 \end{gathered}$ | $\begin{gathered} \text { ACD } \\ 13 \end{gathered}$ | $\begin{array}{cc} \text { ACD } & \text { ACD } \\ 12 & 11 \end{array}$ | $\begin{gathered} \text { ACD } \\ 10 \end{gathered}$ | $A C D$ $A C D$ <br> 9 8 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Access | Op | RMW | Length |  | Modifiers |
| 0 - <br> Memory $1 \text { - }$ <br> Other | 0 Read <br> 1Write | 0 - <br> Nominal <br> 1 RMW | $\begin{aligned} & 000-1 \text { Byte } \\ & 001-2 \text { Bytes } \\ & 010-4 \text { Bytes } \\ & 011-6 \text { Bytes } \\ & 100-8 \text { Bytes } \\ & 101-10 \text { Bytes } \\ & 110-16 \text { Bytes }^{*} \\ & 111-32 \text { Bytes }^{*} \end{aligned}$ <br> * Not implemented |  | ACD $15=0$ : <br> 00-Inst Seg <br> Access <br> 01-Stack Seg <br> Access <br> 10-Context Ctl <br> Seg Access <br> 11-Other <br> ACD 15 = 1 : <br> 00-Reserved <br> 01-Reserved <br> 10-Reserved <br> 11-Interconn <br> Register |

IPC or reconfiguration request has been received. An iAPX 432 processor is required to record and service only one IPC or reconfiguration request at a time. Logic in the interconnect system must record and sequence multiple (possibly simultaneous) IPC occurrences and reconfiguration requests to the processor. Thus the logic that forms ICS must accomodate global and local IPC arrivals and requests for reconfiguration as individual events:

- Assert IPC significance on ICS for the arrival of an IPC or reconfiguration request.
- When the iAPX 432 processor reads interconnect address register 2 , it will respond to one of the status bits for the IPC or reconfiguration request signalled on ICS in the following order:

Bit 2 ( $1=$ reconfigure, $0=$ Do not reconfigure)
Bit 1 ( $1=$ global IPC arrived, $0=$ no global IPC)
Bit 0 ( $1=$ Local IPC arrived, $0=$ no local IPC)

- The logic in the interconnect system must clear the highest order status bit that was serviced by the IAPX 432 processor, and if additional IPC information has arrived, the interconnect system logic must signal an additional IPC indication to the IAPX 432 processor. The interconnect system must signal the second IPC by raising ICS high for at least one cycle and then setting ICS low for at least one cycle during IPC significance time.

Table 2. ICS Interpretation

|  | Level |  | State |
| :--- | :--- | :--- | :--- |
|  | High | Low |  |
| IPC | None | Waiting |  |
| $\mathrm{Ti}, \mathrm{T} 1, \mathrm{~T} 2^{\star}$ |  |  |  |
| Stretch | Don't | Stretch | $\mathrm{T} 3, \mathrm{Tw}$ <br> Err |
|  | Bus Error | No Error | $\mathrm{Tv}, \mathrm{Tvo}$ |

*ICS has no significance in a cycle following a T2 where PRQ is asserted (cancelled access) or in any cycle during which CLR/ is asserted.

## PRQ (Processor Packet Bus Request)

PRQ is normally low and can go high only during T1, T2 and Tvo. High levels during Tvo and T1 indicate the first cycle of an access. A high level during T2 indicate that the current cycle is to be cancelled. (See Table 3.)

Table 3. PRQ Interpretation

| State | PRQ | Condition |
| :--- | :---: | :--- |
| Ti | 0 | Always |
| T 1 | 1 | Initiate access |
| T 2 | 0 | Continue access |
|  | 1 | Cancel access |
| T 3 | 0 | Always |
| Tw | 0 | Always |
| Tv | 0 | Always |
| Tvo | 1 | Initiate overlapped access |

## BOUT (Enable Buffers for Output)

BOUT is provided to control external buffers when they are present. Table 4 and Figures 12 through 16 show its state under various conditions.

## PROCESSOR PACKET BUS TIMING RELATIONSHIPS

All timing relationships on the Processor Packet bus are derived from a simple scheme and related to Table 5. Each timing diagram shown in the following pages (Figures 12 through 17) provides a separate table illustrating the various system states during the cycle. This approach to transfer timing was designed to allow maximum time for the transfer to occur and yet guarantee hold time. The solid lines in Figure 18 show the state transitions initiated by the GDP.

Any agent connected to the Processor Packet bus is recognized as either a processor or a slave. Examples of processors are the GDP and the IP. A memory system provides an example of a slave.

In all tranfers between a processor and a slave, the data to be driven are clocked three-quarters of a cycle before they are to be sampled. This allows adequate time for the transfer and ensures sufficient hold time after sampling. The BOUT timing is unique because BOUT is intended as a direction control for external buffers.

Detailed set-up and hold times depend on the processor implementation and can be found in the AC characteristics section.

Table 4. BOUT Interpretation

| BOUT | Always High | Low-to-High <br> Transition <br> or Low | High-to-Low <br> Transition <br> or Low | High-to-Low <br> Transition <br> or High |
| :---: | :---: | :---: | :---: | :---: |
| Write | $\mathrm{T} 1, \mathrm{~T} 2, \mathrm{~T} 3, \mathrm{Tw}$, Tvo | Ti | None | Tv |
| Read | $\mathrm{T} 1, \mathrm{~T} 2$ | $\mathrm{Ti}, \mathrm{Tv}$ | $\mathrm{T} 3, \mathrm{Tw}$ | None |



Figure 12. Nominal Write Cycle Timing

Table 5. iAPX 432 Component Signaling Scheme

|  | Processor |  | Slave |  |
| :---: | :---: | :---: | :---: | :---: |
| Inputs Sampled | ACD: <br> Others: | $\begin{aligned} & \text { lCLKA } \\ & \uparrow C L K A \end{aligned}$ | All: | $\uparrow$ CLKB |
| Outputs Driven | All (except BOUT): BOUT: | $\downarrow$ CLKA $\uparrow C L K A$ | ACD: <br> Others: | $\begin{aligned} & \text { lCLKB } \\ & \uparrow C L K B \end{aligned}$ |



Figure 13. Minimum Write Cycle Timing



Figure 15. Minimum Read Cycle (Not Buffered)


Figure 16. Minimum Read Cycle (Buffered System)


Figure 17. Minimum Faulted Access Cycle


Figure 18. GDP State Diagram

## 43201 PIN DESCRIPTION

Processor Packet Bus Group

## ACD ${ }_{15}-$ ACD $_{0}$ (Address/Control/

 Data lines, Inputs, high asserted)The Processor Packet bus Address/Control/Data lines are the basic communication path between the GDP and its environment. These lines are always inputs to the 43201 and are driven by either the 43202 or the external environment. Note that the 43201 must receive the specification byte from the 43202 during T 1 of a bus transaction (Figure 11). As a result, the ACD receivers must be capable of slave timing as well as processor timing. (See Processor Packet bus timing relationships for definition of processor and slave timing).

## PRQ (Processor Packet bus <br> Request, Input, high asserted)

The PRQ input is used to initiate a transaction between the GDP and the bus interface. PRQ is normally held low by the 43202 whenever there is
no transaction. PRQ is asserted high during the first cycle of a bus transaction and returns low during the second cycle if the transaction is to be completed. The GDP may cancel a bus transaction by asserting PRQ high (instead of returning it low) during the second cycle of the transaction. The GDP will cancel a transaction if a bounds or access rights violation for the transaction has been detected. PRQ is sampled on the rising edge of CLKA.

## ICS (Interconnect Status,

 Input, high asserted)The ICS input is continually monitored by the 43201 to determine the state of bus transactions. The interpretation of ICS depends on the present cycle of a bus transaction and will indicate one of the following states:

1. Interprocessor communication (IPC) message waiting.
2. Input data invalid, a stretched access.
3. Output data not taken, a stretched access.
4. Bus error in external environment.

## Intra-GDP Bus Group

$\mathrm{Ul}_{15} \ldots \mathrm{Ul}_{0}$ (Microinstruction<br>Bus lines, Outputs, high asserted)

These lines are used to transmit microinstructions from the 43201 to the 43202. These pins are high impedance in the checker state (Refer to Hardware Error Detection Group). They are monitored by the hardware error checking logic.

## $\mathbf{I S}_{6} \ldots$ IS $_{0}$ (Interchip Status lines, Inputs, high asserted)

The 43201 receives information pertaining to interchip microprogram status from the 43202 over these lines.

## System Group

## FATAL/ (Fatal, Output, low asserted)

FATAL/ is asserted by the 43201 under microcode control and is used by the GDP microcode to indicate to the system that the GDP cannot continue due to grossly incorrect information structures in memory. FATAL/ is synchronously asserted low and remains low until the processor is initialized. FATAL/ is not affected by the hardware checking logic.

## ALARM/ (Alarm signal, Input, low asserted)

The ALARM/ input signals the occurrence of an unusual system-wide condition (such as power fail). The 43201 does not respond to ALARM/ until it has completed execution of the current 432 instruction, i.e., if any instruction is currently under execution. ALARM/ is active Iow and is sampled on the rising edge of CLKA.

## INIT/ (Initialization, Input, low asserted)

The INIT/ pin is used to establish initialization. INIT/ must be asserted low for at least 10 CLKA cycles before the initial state is reached to allow time for the 43201 to begin execution of a microcode sequence that initializes all of the 43201 and 43202 internal registers. Once this initialization sequence has been completed, normal operation begins.

## CLR/ (Clear, Input, low asserted)

Assertion of CLR/ results in a microprogram trap which causes the GDP to immediately terminate any bus transactions or internal operations which may be in progress at the time, reset to a known state, assert FATAL/, and await an IPC (which resets the GDP to the same state as INIT/ assertion does). The IPC will not be serviced for at least five clock cycles following CLR/ assertion.

If CLR/ is continuously asserted low for more than one clock cycle, it is ignored during alternate clock cycles (beginning with the second clock cycle) of continuous CLR/ low assertion.

## Hardware Error Detection Group

## MASTER (Master, Input, high asserted)

The MASTER pin is used to place the processor in either master or checker mode. MASTER is sampled during initialization (INIT/ asserted). If MASTER is asserted throughout initialization, the 43201 functions normally and drives the microinstruction bus. If MASTER is low throughout initialization, microinstruction bus signals $\mathrm{ul}_{15}-\mathrm{ul}_{0} \mathrm{go}$ to their high-impedance state. A 43201 checker does not drive the microinstruction bus; rather, it monitors the bus and compares the data on the bus to its internally generated result, signalling disagreement on its HERR/ line. This hardware error detection capability on the 43201 is provided mainly for test purposes. MASTER should be tied to $V_{\text {cc }}$ for normal operation and tied low to enable hardware error detection and disable the bus ( $\mathrm{ul}_{15}-\mathrm{ul}_{0}$ ) outputs.

HERR/ (Hardware Error, Output, low asserted)

HERR/ is a signal produced by the 43201 to indicate disagreement between the data appearing on the micro-instruction bus ( $\mathrm{ul}_{15}-\mathrm{ul}_{0}$ ) and the internally generated result of the 43201. HERR/ is asserted low when disagreement occurs and is valid during CLKA. HERR/ can drive one low power Schottky load.

## Clock Group

## CLKA, CLKB (Clock A, Clock B, Inputs)

Clock A (CLKA) provides the basic timing reference for the 43201. CLKB overlaps CLKA by nominally $1 / 4$ cycle ( 90 degrees phase shift). All
external signals are referenced to CLKA. Refer to the AC Electrical Characteristics for exact statement of timing relationships.

## Testing Input

## RDROM/ (Read ROM,

 Input, low asserted)The RDROM / input line is used to force a sequential read of Read-Only-Memory. If RDROM/ is low when INIT/ goes high, the 43201 goes into a special diagnostic mode. In this mode, with RDROM/ held low, the 43201 microinstruction sequencer steps through the 43201 microprogram ROM, sequentially displaying (but not executing) the 43201 microprogram on the $\mathrm{ul}_{15}$ - $\mathrm{ul}_{0}$ lines. The RDROM/ feature is useful for testing. RDROM/ should be tied to $V_{C C}$ for normal operation and tied low for testing.

## Power and Ground Connections

## $V_{C c}$ (4 pins)

These pins supply $+5 \mathrm{~V} \pm 10$ \% referenced to GND pins.

## GND (5 pins)

These pins supply ground reference for the 43201.

## $\mathrm{V}_{\mathrm{BB}}$ (Internally Generated)

This pin is connected to the substrate bias voltage of the 43201. An external low leakage 1 microfarad capacitor rated at 5 volts or greater should be used to bypass $\mathrm{V}_{\mathrm{BB}} . \mathrm{V}_{\mathrm{BB}}$ is a negative voltage.

## N.C. (No Connection, 4 pins)

## 43202 PIN DESCRIPTION

## Processor Packet Bus Group

$\mathrm{ACD}_{15}-\mathrm{ACD}_{0}$ (Address/Control/
Data lines, Inputs or Three-state Outputs, high asserted)

The Processor Packet bus Address/Control/Data lines are the basic communication path between the GDP and its environment. These pins are used three ways:

- They may indicate control information for bus transactions,
- They may issue physical addresses generated by the GDP for an access, or
- They may transfer data (either direction).

When the 43202 is in checker mode, the ACD pins are monitored by the hardware error checking logic and are in the high impedance mode.

## PRQ (Processor Packet bus Request, Three-state Output, high asserted)

PRQ is used to indicate the presence of a transaction between the GDP and its external environment. Normally low, the PRQ pin is brought high during the same cycle as the first double-byte of address information is being driven onto the ACD pins. PRQ remains high for only one cycle during the access, unless an address development fault occurs. The 43202 will leave PRQ high for a second cycle to indicate the GDP has detected an addressing or segment rights fault in completing address generation. PRQ is checked by the hardware error logic. PRQ is in a high impedance state when the 43202 is in checker mode (see MASTER description).

## ICS (Interconnect Status, Input, high asserted)

ICS is an indication to the 43202 from the bus interface circuitry concerning the status of a bus transaction. The interpretation of the ICS state is dependent upon the present cycle of a bus transaction and may indicate:

- Interprocessor communication (IPC) message waiting,
- Input data invalid,
- Output data not taken,
- Bus error in external environment.


## BOUT (Enable Buffers for Output, Output, high asserted)

BOUT is used to control external bus transceivers to buffer the 43201, 43202 from the Processor Packet bus load. Though not required, the use of buffers may be desired in systems with heavy loading. BOUT is asserted when information is to leave the 43202 on the ACD lines. BOUT is not checked by the hardware error detection logic.

## Intra-GDP Bus Group

## $\mathrm{ul}_{15}-\mathrm{ul}_{0}$ (Microinstruction Bus <br> lines, Inputs, high asserted)

The $\mathrm{ul}_{15}-\mathrm{ul}_{0}$ input lines provide the 43202 with microinstruction information sent from the 43201.
$\mathbf{I S}_{6}-\mathbf{I S}_{0}$ (Interchip Status lines, Outputs, high asserted)

The $\mathrm{IS}_{6}-\mathrm{IS}_{0}$ lines drive interchip microprogram status information from the 43202 to the 43201. $\mathrm{IS}_{6}-\mathrm{IS} \mathrm{S}_{0}$ are not checked by the hardware error detection logic.

## System Group

PCLK/ (Processor Clock, Input, low asserted)

PCLK/ is asserted to change the state of two processor timers. The affected timers are called the system timer and the service timer. Assertion of PCLK/ for one cycle causes the system timer to increment and the service timer to decrement. Assertion of PCLK/ for more than one cycle causes the system timer to be cleared and decrements the service timer. For proper operation PCLK/ must be unasserted for at least four clock cycles before being asserted. PCLK/ is synchronous with respect to CLKA, but is generally unrelated to other interface timings.

## CLR/ (Clear, Input, low asserted)

Assertion of CLR/ results in a microprogram trap which causes the GDP to immediately terminate any bus transactions or internal operations which may be in progress at the time, reset to a known
state, assert FATAL/, and await an IPC (which resets the GDP to the same state as INIT/ assertion does). The IPC will not be serviced for at least five clock cycles following CLR/ assertion.

If CLR/ is continuously asserted low for more than one clock cycle, it is ignored during alternate clock cycles (beginning with the second clock cycle) of continuous CLR/ low assertion.

## Hardware Error Detection Group

MASTER (Master, Input, high asserted; 25 k nominal pullup on-chip)

The MASTER input determines whether the 43202 is to function as a master or a checker. In master mode, the 43202 functions normally and drives all of its outputs. In checker mode, $A C D_{15}-A C D_{0}$ and PRQ enter the high impedance state and BOUT is unconditionally low. A 43202, whether master or checker, monitors the $A C D_{15}-A C D_{0}$ and $P R Q$ lines and compares the data on them to its internally generated result, signalling disagreement on its HERR/ line. For normal operation, MASTER may be either left alone or tied high. MASTER must be tied low to disable the $A C D_{15}-A C D_{0}$ and PRQ outputs.

## HERR/ (Hardware Error, Open Drain Output, low asserted)

HERR/ is asserted low by the 43202 to indicate disagreement between the data appearing on the $A C D_{15}-A C D_{0}$ and PRQ pins and the internally generated result of the 43202. HERR/ is valid during CLKA and can normally be asserted by a 43202 every clock cycle. HERR/ is prevented from being asserted low during any clock cycle following a clock cycle in which a CLR/ low assertion is recognized by the 43202 . HERR/ requires an external 2.2 k ohm nominal pullup resistor.

## Clock Group

## CLKA, CLKB (Clock A, Clock B, Inputs)

Clock A (CLKA) provides the basic timing reference for the 43202. Clock B (CLKB) overlaps CLKA by nominally $1 / 4$ cycle ( 90 degrees phase shift). Refer to the ac electrical characteristics for exact statement of timing relationships. All external signals are referenced to CLKA.

## Power and Ground Connections

Vcc (Power Supply, 4 pins)
These pins supply $+5 \mathrm{~V} \pm 10 \%$, referenced to GND pins.

## GND (Ground, 5 pins)

These pins supply ground reference for the 43202.
N.C. (No Connection, 7 pins)

## INSTRUCTION SET SUMMARY

Refer to Table 14 for the iAPX 432 General Data Processor operator set summary.

## 43201/43202 ELECTRICAL SPECIFICATIONS

Tables 6 through 13 and Figures 19 through 27 provide appropriate timing diagrams and tables to represent the complete electrical specifications for both the 43201 and 43202 components.

Table 6. iAPX 43201 Electrical Specification

| 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 GND** | -1 V to +7 V |
| Power Dissipation | 2.5 Watts |
| *43201 $\mathrm{V}_{\mathrm{BB}}$ Pin with respect to GND | -5 V to 0 V |

Table 7. iAPX 43201 Electrical Specification

| DC Characteristics |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| VSS $=0$ Volts, VCC $=5$ Volts $\pm 10 \%$ |  |  | $\mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| Symbol | Description | Min | Max | Units |
| Vili | Input Low Voltage IS6...IS0 | -0.3 | +0.7 | V |
| Vihi | Input High Voltage IS6...IS0 | 3.0 | VCC +0.5 | V |
| Vilc | Clock Input Low Voltage | -0.3 | +0.5 | V |
| Vihc* | Clock Input High Voltage | 3.5 | VCC +0.5 | V |
| Vil | Input Low Voltage | -0.3 | 0.8 | V |
| Vih | Input High Voltage | 2 | $V C C+0.5$ | V |
| Vol | Output Low Voltage (Microinstruction Lines) ( $\mathrm{Iol}=-0.1 \mathrm{~mA}$ ) | 0 | 0.35 V |  |
| Voh | Output High Voltage (Microinstruction Lines) ( $\mathrm{loh}=0.1 \mathrm{~mA}$ ) | 3.25 | VCC | V |
| Vol | Output Low Voltage $(101=2.0 \mathrm{~mA})$ | - | 0.45 | V |
| Voh | Output High Voltage ( $10 h=-400 u A$ ) | 2.4 | VCC | V |
| Icc | Power Supply Current (Sum of all VCC Pins) | - | 400 | mA |
| lil | Input Leakage Current | - | $\pm 10$ | uA |

Table 7. iAPX 43201 Electrical Specification (Cont'd.)

| DC Characteristics |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| VSS $=0$ Volts, VCC $=5$ Volts $\pm 10 \%$ |  |  | $\mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| Symbol | Description | Min | Max | Units |
| 10 | Output Leakage Current | - | $\pm 10$ | uA |
| \|ol | $@ 0.45 \text { Vol }$ HERR/ | - | . 4 | mA |
|  | FATAL/ | - | 4 | mA |
|  | OTHER | - | 2 | mA |
| loh | @ 2.4 Voh | - | -0.1 | mA |

* For operation at 5 MHz or slower, the 43201 may be operated with Vihc minimum of 2.7 Volts.

Table 8. iAPX 43201 AC Characteristics

| VCC $=5 \pm 10 \%$ |  |  |  | $\mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Description |  | $\begin{aligned} & \mathrm{Hz} \\ & \text { Max } \end{aligned}$ |  | $\begin{aligned} & \mathrm{Hz} \\ & \mathrm{Max} \end{aligned}$ | Unit |
| tcy | Clock Cycle Time | 125 | 1000 | 200 | 1000 | nsec. |
| tr, tf | Clock Rise and Fall Time | 0 | 10 | 0 | 10 | nsec. |
| $\begin{aligned} & \mathrm{t} 1, \mathrm{t2}, \\ & \mathrm{t} 3, \mathrm{t} 4 \end{aligned}$ | Clock Pulse Widths | 26 | 250 | 45 | 250 | nsec. |
| tdc | Signal to Clock Set-up Time | 5 | - | 5 | - | nsec. |
| tod | Clock to Signal Delay Time | - | 55 | - | 85 | nsec. |
| tis | Init to Signal Hold Time | 15 | - | 20 | - | nsec. |
| tie | Init enable Time | 10 | - | 10 | - | tcy |
| tdh | Clock to Signal Hold Time | 25 | - | 35 | - | nsec. |
| $\mathrm{t}_{\mathrm{OH}}$ | Clock to Signal Output Hold Time | 15 | - | 20 | - | nsec. |
| tsi | Signal to INIT/ Set-up Time | 10 | - | 10 | - | nsec |
| tuif | Microinstruction Bus Float Time | 0 | - | 0 | - | nsec. |

The above specifications are subject to the following definitions and test conditions:

1. Note that tcy $=\mathrm{t} 1+\mathrm{t} 2+\mathrm{t} 3+\mathrm{t} 4+2^{\star} \mathrm{tr}+2^{\star} \mathrm{tf}$.
2. Pins under consideration were subjected to the following purely capacitive loading:

$$
\begin{aligned}
& \mathrm{C} 1=25 \mathrm{pF} \text { on HERR } / \\
& \mathrm{C} 1=50 \mathrm{pF} \text { on ul15 ..ul0, IS6..IS0 } \\
& \mathrm{C} 1=70 \mathrm{pF} \text { on all remaining pins. }
\end{aligned}
$$

3. All timings are measured with respect to the switching level of 1.5 Volts. The switching point of CLKA and CLKB is referenced to the 1.8 Volt level.
4. CLKA and CLKB must be continuously applied for the 43201 to retain its state.

Table 9. iAPX 43201 Capacitance

| Symbol | Parameter | Typical | Unit |
| :---: | :---: | :---: | :---: |
| Cin Cout | Input Capacitance Output Capacitance | $\begin{array}{r} 6 \\ 12 \end{array}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ |
| Conditions: $\mathrm{fc}=1 \mathrm{MHz}, \mathrm{Vin}=0 \mathrm{~V}, \mathrm{VCC}=5 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}$ Outputs in High Impedance state |  |  |  |

Table 10. iAPX 43202 Electrical Specification

| 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 GND | -1 V to +7 V |
| Power Dissipation | 2.5 Watts |

Table 11. iAPX 43202 Electrical Specification

| DC Characteristics |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| VSS $=0$ Volts, VCC $=5$ Volts $\pm 10 \%$ |  |  | $\mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| Symbol | Description | Min | Max | Units |
| Vilc | Clock Input Low Voltage | -0.3 | +0.5 | V |
| Vihc* | Clock Input High Voltage | 3.5 | VCC +0.5 | V |
| Vil | Input Low Voltage | -0.3 | +0.8 | V |
| Vih | Input High Voltage | 2 | $\mathrm{VCC}+0.5$ | V |
| Vili | Input Low Voltage ul15...ul0 | -0.3 | +0.7 | V |
| Vihi | Input High Voltage ul15...u10 | 3.0 | $\mathrm{VCC}+0.5$ | V |
| Vol | Output Low Voltage <br> (lol $=4.0 \mathrm{~mA}$ ) ACD15...ACD0, PRQ ( $\mathrm{lol}=8.0 \mathrm{~mA}$ ) BOUT, HERR $/$ | - | 0.45 | V |
| Voh | Output High Voltage ( $\mathrm{loh}=-800 \mathrm{uA}$ ) | 2.4 | VCC | V |
| Voli | Output Low Voltage IS6...IS0 loli $=0.1 \mathrm{~mA}$ | - | 0.35 | V |
| Vohi | Output High Voltage IS6...ISO lohi $=0.1 \mathrm{~mA}$ | 3.25 | - | V |
| Icc | Power Supply Current (Sum of all VCC Pins) | - | 455 | mA |
| III | Input Leakage Current except MASTER | - | $\pm 10$ | uA |
| llim | Input Leakage on MASTER | - | -400 | uA |
| 110 | Output Leakage Current $\mathrm{Vo}=0.45 \mathrm{~V}$.. VCC | - | $\pm 10$ | uA |

* For operation at 5 MHz or slower, the 43202 may be operated with $\mathrm{V}_{\mathrm{inc}}$ minimum of 2.7 Volts.

Table 12. iAPX 43202 AC Characteristics

| $V C C=5 \pm 10 \%$ |  | $\mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Description | $\begin{aligned} & 8 \mathrm{~N} \\ & \mathrm{Min} \end{aligned}$ | Hz <br> Max | 5 Min | Hz <br> Max | Unit |
| tr, tf | Clock Rise and Fall Time | 0 | 10 | 0 | 10 | nsec. |
| $\begin{aligned} & \mathrm{t} 1, \mathrm{t} 2, \\ & \mathrm{t} 3, \mathrm{t} 4 \end{aligned}$ | Clock Pulse Widths | 26 | 250 | 45 | 250 | nsec. |
| tcy | Clock Cycle Time $\left(t \mathrm{c} y=\mathrm{t} 1+\mathrm{t} 2+\mathrm{t} 3+\mathrm{t} 4+2^{*} \mathrm{tr}+2^{\star} \mathrm{tf}\right)$ | 125 | 1000 | 200 | 1000 | nsec. |
| tdc | Signal to Clock Set-up Time | 5 | - | 5 | - | nsec. |
| tcd | Clock to Signal Delay Time | - | 55 | - | 85 | nsec. |
| tdh | Clock to Signal Hold Time | 25 | - | 35 | - | nsec. |
| toh | Clock to Signal Output Hold Time . | 15 | - | 20 | - | nsec. |
| ten | Clock to Signal Output Enable Time | 15 | - | 20 | - | nsec. |
| tdf | Clock to Signal Data Float Time | - | 55 | - | 75 | nsec. |

The timing characteristics given below assume the following loading on output pins. Loading is given in terms of a fixed capacitance plus a DC current load.

| Pins | Loading |
| :--- | :--- |
| HERR/ | $90 \mathrm{pF} \mathrm{Iol}=8 \mathrm{mA} .,$. Open Drain |
| BOUT | $70 \mathrm{pF} \mathrm{Iol}=8 \mathrm{~mA} .$, Ioh $=-800 \mathrm{uA}$ |
| PRQ | $70 \mathrm{pF} \mathrm{Iol}=4 \mathrm{~mA} .$, loh $=-800 \mathrm{uA}$ |
| IS6...IS0 | 50 pF MOS only |
| ACD15...ACD0 | $70 \mathrm{pF} \mathrm{lol}=4 \mathrm{~mA} .$, loh $=-800 \mathrm{uA}$ |

All output delays are measured with respect to the falling edge of CLKA except for BOUT. BOUT output delays are measured with respect to the rising edge of CLKA.

All timings are measured with respect to the switching level of 1.5 Volts. The switching point of CLKA and CLKB is referenced to the 1.8 V level.

The 43202 is not capable of DC operation. For continuous data and logic state retention the CLKA and CLKB signals must be present.

Table 13. iAPX 43202 Capacitance

| Symbol | Parameter | Typical | Unit |
| :---: | :---: | :---: | :---: |
| Cin | Input Capacitance <br> Output Capacitance | 6 | pF |
| Cout |  | 12 |  |
| Conditions:$\mathrm{fc}=1 \mathrm{MHz}, \mathrm{Vin}=0$, Vout $=0, \mathrm{VCC}=5.0 \mathrm{~V}, \mathrm{Ta}=25^{\circ} \mathrm{C}$. <br> Outputs in High Impedance state |  |  |  |



Figure 19. 43201 Clock Input Specification


Figure 20. 43201 Output Timing Specification


Figure 21. 43201 Input Timing Specification


Figure 22. 43201 Hardware Error Detection Timing


Figure 23. 43201 Initialization Timing 171873-26


Figure 24. 43201 Microcode Interrogate Timing


Figure 25. 43202 Clock Input Specification


Figure 26. 43202 Output Timing Specification 171873-28


Figure 27. 43202 Input Timing Specification 171873-29

Table 14. General Data Processor Operator Set Summary

| Character Operators | Short-Integer Operators | Integer Operators |
| :---: | :---: | :---: |
| Move Character <br> Zero Character <br> One Character <br> Save Character <br> AND Character <br> OR Character <br> XOR Character <br> XNOR Character <br> Complement Character <br> Add Character <br> Substract Character <br> Increment Character <br> Decrement Character <br> Equal Character <br> Not Equal Character <br> Equal Zero Character <br> Not Equal Zero Character <br> Greater Than Character <br> Greater Than or Equal Character <br> Convert Character to Short Ordinal | Move Short Integer <br> Zero Short Integer <br> One Short Integer <br> Save Short Integer <br> Add Short Integer <br> Subtract Short Integer <br> Increment Short Integer <br> Decrement Short Integer <br> Negate Short Integer <br> Multiply Short Integer <br> Divide Short Integer <br> Remainder Short Integer <br> Equal Short Integer <br> Not Equal Short Integer <br> Equal Zero Short Integer <br> Not Equal Zero Short Integer <br> Greater Than Short integer <br> Greater Than or Equal Short Integer <br> Positive Short Integer <br> Negative Short Integer <br> Convert Short Integer to Integer <br> Convert Short Integer to Temporary Real | Move Integer <br> Zero Integer <br> One Integer <br> Save Integer <br> Add Integer <br> Subtract Integer <br> Increment Integer <br> Decrement Integer <br> Negate Integer <br> Multiply Integer <br> Divide Integer <br> Remainder Integer <br> Equal Integer <br> Not Equal Integer <br> Equal Zero Integer <br> Not Equal Zero Integer <br> Greater Than Integer <br> Greater Than or Equal Integer <br> Positive Integer <br> Negative Integer <br> Convert Integer to Short Integer <br> Convert Integer to Ordinal <br> Convert Integer to Temporary Real |
| Short-Ordinal Operators | Ordinal Operators | Short-Real Operators |
| Move Short Ordinal <br> Zero Short Ordinal <br> One Short Ordinal <br> Save Short Ordinal <br> AND Short Ordinal <br> OR Short Ordinal <br> XOR Short Ordinal <br> XNOR Short Ordinal <br> Complement Short Ordinal <br> Extract Short Ordinal <br> Insert Short Ordinal <br> Significant Bit Short Ordinal <br> Add Short Ordinal <br> Subtract Short Ordinal <br> Increment Short Ordinal <br> Decrement Short Ordinal <br> Multiply Short Ordinal <br> Divide Short Ordinal <br> Remainder Short Ordinal <br> Equal Short Ordinal <br> Not Equal Short Ordinal <br> Equal Zero Short Ordinal <br> Not Equal Zero Short Ordinal <br> Greater Than Short Ordinal <br> Greater Than or Equal Short Ordinal <br> Convert Short Ordinal to Character <br> Convert Short Ordinal to Ordinal <br> Convert Short Ordinal to Temporary Real | Move Ordinal <br> Zero Ordinal <br> One Ordinal <br> Save Ordinal <br> AND Ordinal <br> OR Ordinal <br> XOR Ordinal <br> XNOR Ordinal <br> Complement Ordinal <br> Extract Ordinal <br> Insert Ordinal <br> Significant Bit Ordinal <br> Add Ordinal <br> Subtract Ordinal <br> Increment Ordinal <br> Decrement Ordinal <br> Multiply Ordinal <br> Divide Ordinal <br> Remainder Ordinal <br> Equal Ordinal <br> Not Equal Ordinal <br> Equal Zero Ordinal <br> Not Equal Zero Ordinal <br> Greater Than Ordinal <br> Greater Than or Equal Ordinal <br> Convert Ordinal to Short Ordinal <br> Convert Ordinal to Integer <br> Convert Ordinal to Temporary Real | Move Short Real <br> Zero Short Real <br> Save Short Real <br> Add Short Real-Short Real <br> Add Short Real-Temporary Real <br> Add Temporary Real-Short Real <br> Subtract Short Real-Short Real <br> Subtract Short Real-Temporary Real <br> Subtract Temporary Real-Short Real <br> Multiply Short Real-Short Real <br> Multiply Short Real-Temporary Real <br> Multiply Temporary Real-Short Real <br> Divide Short Real-Short Real <br> Divide Short Real-Temporary Real <br> Divide Temporary Real-Short Real <br> Negate Short Real <br> Absolute Value Short Real |

Table 14. General Data Processor Operator Set Summary (Cont'd.)

| Short-Real Operators | Real Operators | Temporary-Real Operators |
| :---: | :---: | :---: |
| Equal Short Real <br> Equal Zero Short Real Greater Than Short Real Greater Than or Equal Short Real Positive Short Real Negative Short Real <br> Convert Short Real to Temporary Real | Move Real <br> Zero Real <br> Save Real <br> Add Real-Real <br> Add Real-Temporary Real <br> Add Temporary Real-Real <br> Subtract Real-Real <br> Subtract Real-Temporary Real <br> Subtract Temporary Real-Real <br> Multiply Real-Real <br> Multiply Real-Temporary Real <br> Multiply Temporary Real-Real <br> Divide Real-Real <br> Divide Real-Temporary Real <br> Divide Temporary Real-Real <br> Negate Real <br> Absolute Value Real <br> Equal Real <br> Equal Zero Real <br> Greater Than Real <br> Greater Than or Equal Real <br> Positive Real <br> Negative Real <br> Convert Real to Temporary Real | Move Temporary Real <br> Zero Temporary Real <br> Save Temporary Real <br> Add Temporary Real <br> Subtract Temporary Real <br> Multiply Temporary Real <br> Divide Temporary Real <br> Remainder Temporary Real <br> Negate Temporary Real <br> Square Root Temporary Real <br> Absolute Value Temporary Real <br> Equal Temporary Real <br> Equal Zero Temporary Real <br> Greater Than Temporary Real <br> Greater Than or Equal Temporary Real <br> Positive Temporary Real <br> Negative Temporary Real <br> Convert Temporary Real to Ordinal <br> Convert Temporary Real to Integer <br> Convert Temporary Real to Short Real <br> Convert Temporary Real to Real |
| Access Descriptor Movement Operators | Rights Manipulation Operators | Type Definition Manipulation Operators |
| Copy Access Descriptor Null Access Descriptor | Amplify Rights Restrict Rights | Create Public Type <br> Create Private Type <br> Retrieve Public Type Representation <br> Retrieve Type Representation <br> Retrieve Type Definition |
| Refinement Operators | Segment Creation Operators | Access Path Inspection Operators |
| Create Generic Refinement Create Typed Refinement Retrieve Refined Object | Create Data Segment Create Access Segment Create Typed Segment Create Access Descriptor | Inspect Access Descriptor Inspect Access |
| Object Interlock Operators | Branch Operators | Interconnect Operators |
| Lock Object Unlock Object Indivisibly Add Short Ordinal Indivisibly Add Ordinal Indivisibly Insert Short Ordinal Indivisibly Insert Ordinal | Branch <br> Branch True <br> Branch False <br> Branch Indirect <br> Branch Intersegment <br> Branch Intersegment without Trace <br> Branch Intersegment and Link | Move to Interconnect Move from Interconnect |
| Process Communication Operators | Processor Communication Operators | Context Communication Operators |
| Send <br> Receive <br> Conditional Send <br> Conditional Receive <br> Surrogate Send <br> Surrogate Receive <br> Delay <br> Read Process Clock | Send to Processor <br> Broadcast to Processors <br> Read Processor Status and Clock | Enter Access Segment <br> Enter Global Access Segment <br> Set Context Mode <br> Call Context <br> Call Context with Message <br> Return from Context |

- Fully Independent and Decentralized I/O


## Buffered Data Path for High-Speed Burst-Mode Transfers

- Initialization/Diagnostic Interface to 432 Systems
- Multiple 43203's per System Provide Incremental I/O Capacity
- Protected I/O Interface to 432 Memory
- Silicon Operating System Instruction Set Extensions for Attached iAPX Processors
- Multibus ${ }^{\text {TM }}$ System Compatible Interface
- Functional Redundancy Checking
Mode for Hardware Error Detection

The Intel 43203 Interface Processor (IP) provides I/O facilities in iAPX 432 micromainframe systems employing peripheral subsystems. An IP maps a portion of the peripheral subsystem address space into iAPX 432 system memory. As any IAPX 432 processor, the IP operates in an object-oriented, capabilitybased, multiprocessing environment.

The 43203 is a VLSI device, fabricated with Intel's highly reliable +5 volt, depletion load, $N$-channel, silicon gate HMOS technology, and is packaged in a 64-pin Quad In-Line Package (QUIP). Refer to Figure 1 for the QUIP representation of the 43203 pin configuration.


Figure 1. iAPX 43203 Interface Processor Pin Configuration

## FUNCTIONAL DESCRIPTION

The block diagram shown in Figure 2 illustrates the internal architecture of the Interface Processor. Figure 3 represents the Interface Processor as a logical device and illustrates the signal interface to the Processor Packet bus (left side) and the peripheral subsystem (right side). The Interface Processor (IP) operates in conjunction with an Attached Processor (AP) to form the logical I/O processor of an IAPX 432 system.

The IP acts as a slave to the AP, and maps a portion of the AP's peripheral subsystem address space into IAPX 432 system memory with the same protection mechanisms as any IAPX 432 processor. Five peripheral subsystem (PS) memory subranges may be mapped into iAPX 432 memory segments. These five windows (labeled 0 through
4) allow the AP to reference IAPX 432 memory with logical addresses or, in special circumstances, with direct, 24-bit physical addresses.

## A BASIC I/O MODEL

A typical application based on the iAPX 432 microprocessor family consists of a main system and one or more peripheral subsystems. Figure 4 illustrates a hypothetical configuration that employs two peripheral subsystems. The main system hardware is composed of one or more iAPX 432 general data processors (GDPs) and a common memory that is shared by these processors. The main system software is a collection of one or more processes that execute on the GDP(s).


Figure 2. iAPX 43203 IP Functional Block Diagram


Figure 3. iAPX 43203 IP Logic Symbol


Figure 4. Main System and Peripheral Subsystem

A fundamental principle of the iAPX 432 architecture is that the main system environment is selfcontained; neither processors nor processes have any direct contact with the "outside world." Conceptually, the main system is enclosed by a wall that protects objects in memory from possible damage by uncontrolled I/O operations.

In an iAPX 432-based system, the bulk of processing required to support input/output operations is delegated to peripheral subsystems; this includes device control, timing, interrupt handling and buffering. A peripheral subsystem is an autonomous computer system with its own local memory, I/O devices and controllers, at least one processor, and software. The number of peripheral subsystems employed in any given application depends on the I/O-intensiveness of the application, and may be varied with changing needs, independent of the number of GDPs in the system.

A peripheral subsystem resembles a mainframe channel in that it assumes responsibility for lowlevel I/O device support, executing in parallel with main system processor(s). Unlike a simple channel, however, each peripheral subsystem can be configured with a complement of hardware and software resources that precisely fits application cost and performance requirements. In general, any system that can communicate over a standard 8- or 16-bit microcomputer bus such as Intel's Multibus design may serve as an iAPX 432 peripheral subsystem.

A peripheral subsystem is attached to the main system by means of an IP. At the hardware level, the IP presents two separate bus interfaces. One of these is the standard IAPX 432 Processor Packet bus and the other is a very general interface.

To support the transfer of data through the wall that separates a peripheral subsystem from the main system, the IP provides a set of softwarecontrolled windows. A window is used to expose a single object in main system memory so that its contents may be transferred to or from the peripheral subsystem.

The IP also provides a set of functions that are invoked by software. While the operation of these functions varies considerably, they generally permit objects in main system memory to be manipulated as entities, and enable communication between main system processes and software executing in a peripheral subsystem.

It is important to note that both the window and function facilities utilize and strictly enforce the standard iAPX 432 addressing and protection systems. Thus, a window provides protected access to an object, and a function provides a protected way to operate in the main system. The IP permits data to flow across the peripheral subsystem boundary while preserving the integrity of the main system.

As Figure 5 illustrates, input/output operations in an IAPX 432 system are based on the notion of passing messages between main system processes and device interfaces located in a peripheral subsystem. A device interface is considered to be the hardware and software in the peripheral subsystem that is responsible for managing an $1 / O$ device. An $1 / O$ device is considered to be a "data repository," which may be a real device (e.g., a terminal), a file, or a pseudodevice (e.g., a spooler).

A message sent from a process that needs an I/O service contains information that describes the requested operation (e.g., "read file XYZ'). The device interface interprets the message and carries out the operation. If an operation requests input data, the device interface returns the data as a message to the originating process. The device interface may also return a message to positively acknowledge completion of a request.

A very general and very powerful mechanism for passing messages between processes is inherent in the iAPX 432 architecture. A given peripheral subsystem may, or may not, have its own message facility, but in any case, such a facility will not be directly compatible with the iAPX 432's. By interposing a peripheral subsystem interface at the subsystem boundary, the standard IP communication system can be made compatible with any device interface (see Figure 6).

## iAPX 432 SYSTEM INTERFACE

The IP exists in both the protected environment of the iAPX 432, and the conventional environment of the peripheral subsystem. Because of this, an IP is able to provide a pathway over which data may flow between the iAPX 432 system and the external subsystem. The IP operates at the boundary between the systems, providing compatibility and protection. In this position, the Interface Processor presents two different views of itself, one to software and processors in the iAPX 432 environment and another to its attached processor.


Figure 5. Basic IO Service Cycle

From the iAPX 432 side, an IP looks and behaves very much like any other processor. It attaches to the Processor Packet bus in the same way as a GDP. Within the iAPX 432 memory, the IP supports an execution environment that is compatible with, and largely identical to, the GDP. Thus, the IP recognizes and manipulates system objects representing processors, processes, ports, etc. It supports and enforces the iAPX 432's access control mechanisms, and provides full interprocess and interprocessor communication facilities.

The principal difference between the two processors is that the GDP manipulates its environment in response to the instruction it fetches, while the IP operates under the direction of its attached processor. Indeed, the IP may be said to extend the instruction set of the Attached Processor (AP) so that it may function in the environment of the iAPX 432 system.

## PERIPHERAL SUBSYSTEM INTERFACE

A peripheral subsystem interface ( PSI ) is a collection of hardware and software that acts as an adapter that enables message-based communication between a process in the main system and a device interface in a peripheral subsystem (see Figure 6). Viewed from the iAPX 432 side, the
peripheral subsystem interface appears to be a process. The peripheral subsystem interface may be designed to present any desired appearance to a device interface. For example, it may look like a collection of tasks, or like a collection of subroutines.

## Hardware

The PSI hardware consists of an IP, an AP, and local memory (see Figure 7). To improve performance, these may be augmented by a DMA controller. The AP and the IP work together as a team, each providing complementary facilities. Considered as a whole, the AP/IP pair may be thought of as a logical I/O processor that supports software operations in both the main system and the peripheral subsystem.

## ATTACHED PROCESSOR

Almost any general-purpose CPU, such as an 8085 , an iAPX 86 or an iAPX 88 can be used as an $A P$. The AP need not be dedicated exclusively to working with the IP.

It may, for example, also execute device interface software. Thus, the AP may be the only CPU in the peripheral subsystem, or it may be one of several.


Figure 6. Peripheral Subsystem Interface


Figure 7. Peripheral Subsystem Interface Hardware

As Figure 7 shows, the AP is "attached" to the interface processor in a logical sense only. The physical connections are standard bus signals and one interrupt line (which would typically be routed to the AP via an interrupt controller).

Continuing the notion of the logical I/O processor, the AP fetches instructions, and provides the instructions needed to alter the flow of execution, and to perform arithmetic, logic and data transfer operations within the peripheral subsystem.

## INTERFACE PROCESSOR

The IP completes the logical I/O processor by providing data paths between the peripheral subsystem and the main system, and by providing functions that effectively extend the AP's instruction set so that software running on the logical $1 / 0$ processor can operate in the main system. Since these facilities are software-controlled, they are discussed in the next section.

As Figure 7 shows, the IP presents both a peripheral subsystem bus interface and a standard IAPX 432 Processor Packet bus interface. By bridging the two buses, the IP provides the hardware link that permits data to flow under software control between the main system and the peripheral subsystem.

The IP connects to the main system in exactly the same way as a GDP. Thus, in addition to being able to access main memory, the IP supports other IAPX 432 hardware-based facilities, including processor communication, the alarm signal and functional redundancy checking.

The IP is connected to the peripheral subsystem bus as if it were a memory component; it occupies a block of memory addresses up to 64 K bytes long. Like a memory, the IP behaves passively within the peripheral subsystem (except as noted below). It is driven by peripheral subsystem memory references that fall within its address range.

While the IP generally responds like a memory component, it also provides an interrupt request signal. The interface processor uses this line to notify its AP that an event has occurred which requires its attention.

To summarize, the AP and the IP interact with each other by means of address references generated by the AP and interrùpt requests generated by the IP. Since the IP responds to
memory references, other active peripheral subsystem agents (bus masters), such as DMA controllers, may obtain access to main system memory via the IP.

## Software

## IP CONTROLLER

The peripheral subsystem interface is managed by software, referred to as the IP controller. The IP controller executes on the AP and uses the facilities provided by the AP and the IP to control the flow of data between the main system and the peripheral subsystem.

While there are no actual constraints on the structure of the IP controller, organizing it as a collection of tasks running under the control of a multitasking operating system (such as an RMX-80 or iRMX-86 operating system) can simplify software development and modification. This type of organization supports asynchronous messagebased communication within the IP controller, similar to the iAPX 432's intrinsic interprocessor communication facility. Extending this approach to the device interface as well results in a consistent, system-wide communication model. However, communication within the IP controller and between the IP controller and device interfaces, is completely application-defined. It may also be implemented via synchronous procedure calls, with "messages" being passed in the form of parameters.

However it is structured, the IP controller interacts with the main system through facilities provided by the interface processor. There are three of these facilities: execution environments, windows, and functions.

## EXECUTION ENVIRONMENTS

The IP provides an environment within the main system that supports the operation of the IP controller in that system. This environment is embodied in a set of system objects that are used and manipulated by the IP. At any given time, the IP controller is represented in main memory by a process object and a context object. Like a GDP, the IP itself is represented by a processor object. Representing the IP and its controlling software like this creates an execution environment that is analogous to the environment of a process running on a GDP. This environment provides a standard framework for addressing, protection and communication within the main system.

Like a GDP, an IP actually supports multiple process environments. The IP controller selects the environment in which a function is to be executed. This permits, for example, the establishment of separate environments corresponding to individual device interface tasks in the peripheral subsystem. If an error occurs while the IP controller is executing a function on behalf of one device interface, that error is confined to the associated process, and processes associated with other device interfaces are not affected.

## WINDOWS

Every transfer of data between the main system and a peripheral subsystem is performed with the aid of an IP window. A window defines a correspondence, or mapping, between a subrange of
peripheral subsystem memory addresses (within the range of addresses occupied by the IP) and an object in main system memory (see Figure 8). When an agent in the peripheral subsystem (e.g., the IP controller) reads a local windowed address, it obtains data from the associated object; writing into a windowed address transfers data from the peripheral subsystem to the windowed object.

The action of the IP, in mapping the peripheral subsystem address to the main system object, is transparent to the agent making the reference; as far as it is concerned, it is simply reading or writing local memory.

Since a window is referenced like local memory, any individual transfer may be between an object and local memory, an object and a processor register, or an object and an I/O device. The


Figure 8. Interface Processor Window
iAPX 43203
latter may be appealing from the standpoint of "efficiency," but it should be considered with caution. Using a window to directly "connect" an I/O device and an object in main memory has thẹ undesirable effect of propagating the real-time constraints imposed by the device beyond the subsystem boundary into the main system. It may seriously complicate error recovery as well. Finally, since there is a finite number of windows, most applications will need to manage them as scarce resources that will not always be instantly available. This means that at least some I/O device transfers will have to be buffered in local memory until a window becomes available. It may be simplest to buffer all I/O device transfers and use the windows to transfer data between local memory and main system memory.

There are four IP windows that may be mapped onto four different objects. The IP controller may alter the windows during execution to map different subranges and objects. References to windowed subranges may be interleaved and may be driven by different processors in the peripheral subsystem. For example, the AP and a DMA controller may be driving transfers concurrently, subject to the same bus arbitration constraints that would apply if they were accessing local memory.

## FUNCTIONS

A fifth window provides the IP controller with access to the IP's function facility. By writing operands and an opcode into predefined locations in this window's subrange, the IP controller requests the IP to execute a function on its behalf. This procedure is very similar to writing commands and data to a memory-mapped peripheral controller (e.g., a floppy disk controller). Upon completion of the function, the IP provides status information that the IP controller can read through the window. The IP can perform transfer requests through the other four windows while it is executing a function.

The IP's function set permits the IP controller to:

- alter windows;
- exchange messages with GDP processes via the standard 432 communication facility;
- manipulate objects.

These functions may be viewed as instruction set extensions to the AP, which permit the IP controller to operate in the main system. The combination of the IP's function set and windows, the

AP's instruction set, and possibly additional facilities provided by a peripheral subsystem operating system, permits the construction of powerful IP controllers that can relieve the main system of much I/O-related processing. At the same time, by utilizing only a subset of the available IP functions, relatively simple IP controllers can also be built (in cases where this approach is more appropriate).

## SUPPLEMENTARY INTERFACE PROCESSOR FACILITIES

The preceding sections describe the IP as it is used most of the time. The IP provides two additional capabilities that are typically used less frequently, and only in exceptional circumstances. These are physical reference mode and interconnect access.

## Physical Reference Mode

The IP normally operates in logical reference mode; this mode is characterized by its objectoriented addressing and protection system. There are times when logical referencing is impossible because the objects used by the hardware to perform logical-to-physical address development are absent (or, less likely, are damaged). In these situations, the IP can be used in physical reference mode.

In physical reference mode, the IP provides a reduced set of functions. Its windows operate as in logical reference mode, except that they are mapped onto memory segments (rather than objects) that are specified directly with 24 -bit addresses. In this respect, physical reference mode is similar to traditional computer addressing techniques.

Physical reference mode is most often employed during system initialization to load binary images of objects from a peripheral subsystem into main memory. Once the required object images are available, processors can begin normal logical reference mode operations.

## Interconnect Access

In addition to memory, the iAPX 432 architecture defines a second address space called the processor-memory interconnect address space. One of the IP windows is software-switchable to
either space. In logical reference mode, the interconnect space is addressed in the same objectoriented manner as the memory space, with the IP automatically performing the logical-to-physical address development. In physical reference mode, the interconnect space is addressed as an array of 16 -bit registers, with a register selected by a 24 -bit physical address.

## iAPX 432 INFORMATION STRUCTURE

The following information describes the requirements placed on the logical structure of the iAPX 432 hardware environment. These requirements are concerned directly with the constraints of physical memory, the type of data transferred, and the structure of the data types. These requirements are common to the iAPX 432 family of processors. (Any pin notations called out in this information are described in the 43203 Pin Description section of this data sheet).

Any 432 processor in the system can access all the contents of physical memory. This section describes how information is represented and accessed.

## Memory

The iAPX 432 implements a two-level memory structure. The software system exists in a segmented environment in which a logical address specifies the location of a data item. The processor automatically translates this logical address into a physical address for accessing the value in physical memory.

## Physical Addressing

Logical addresses are translated by the processor into physical addresses. Physical addresses are transmitted to memory by a processor to select the beginning byte of a memory value to be referenced. A physical address is 24 binary bits in length. This results in a maximum physical memory of 16 Megabytes.

## Data Formats

When a processor executes the instructions of an operation within a context, operands found in the logical address space of the context may be
manipulated. An individual operand may occupy one, two, four, eight, or ten bytes of memory (byte, double byte, word, double word, or extended word, respectively). All operands are referenced by a logical address as described above. The displacement in such an address is the displacement in bytes from the base address of the data segment to the first byte of the operand. For operands consisting of multiple bytes, the address locates the low-order byte while the higher-order bytes are found at the next higher consecutive addresses.

## DATA REPRESENTATION

An iAPX 432 convention has been adopted for representing data operands stored in memory. The bits in a field are numbered by increasing numeric significance, with the least-significant bit shown on the right. Increasing byte addresses are shown from right to left. Examples of the five basic data lengths used in the iAPX 432 system are shown in Figure 9.

## DATA POSITIONING

The data operand types shown in Figure 9 may be aligned on an arbitrary byte boundary within a data segment. Note that more efficient system operation may be obtained when multi-byte data structures are aligned on double-byte boundaries (if the memory system is organized in units of double bytes).

## Requirements of an iAPX 432 Memory System

The multiprocessor architecture of the IAPX 432 places certain requirements on the operation of the memory system to ensure the integrity of data items that can potentially be accessed simultaneously. Indivisible read-modify-write (RMW) operations to both double-byte and word operands in memory are necessary for manipulating system objects. When an RMW-read is processed for a location in memory, any other RMW-reads from that location must be held off by the memory system until an RMW-write to that location is received (or until an RMW timeout occurs). Note that while the memory system is awaiting the RMW-write, any other types of reads and writes are allowed. Also, for ordinary reads and writes of double-byte or longer operands, the memory system must ensure the entire operand


171873-13
Figure 9. Basic iAPX 432 Data Lengths
has been either read or written before beginning to process another access to the same location; e.g., if two simultaneous writes to the same location occur, the memory system must ensure that the set of locations used to store the operand does not get changed to some interleaved combination of the two written values.

## iAPX 432 HARDWARE ERROR DETECTION

iAPX 432 processors include a facility to support the hardware detection of errors by functional redundancy checking (FRC). At initialization time, each iAPX 432 processor is configured to operate as either a master or a checker processor (Figure 10). A master operates in the normal manner. A checker places all output pins that are being checked into a high-impedance state. Thus, those pins which are to be checked on a master and checker are parallel-connected, pin for pin, such that the checker is able to compare its master's output pin values with its own. Any comparison error causes the checker to assert HERR.


Figure 10. Hardware Error Detection

## PROCESSOR PACKET BUS DEFINITION

This section describes and defines the significance of the 19 signal lines that make up the Processor Packet bus, and the general scheme by which timing relationships on these lines are derived. Although this section defines all legal bus activities, the processors do not necessarily perform all allowed activities. Slaves to the Processor Packet bus must support all state transitions to ensure compatibility.

The Processor Packet bus consists of 3 control lines:

- Processor Packet bus Request (PRQ),
- Enable Buffers for Output (BOUT),
- Interconnect Status (ICS).

This bus also includes sixteen 3-state Address-Control-Data lines (ACD15 through ACD0). PRQ has two functions whose use depends upon the application; i.e., PRQ either indicates the first cycle of a transaction on the Processor Packet bus or the cancellation of a transaction initiated in the previous cycle. Of the three control lines;, BOUT has the simplest function, serving as a direction control for buffers in large systems requiring more electrical drive than the processor components can provide. The ICS signal has significance pertaining to one of three different system conditions and depends on the state of the Processor Packet bus transaction. The processor interprets the ICS input as an indication of one of the following:

- Whether or not an interprocessor communication (IPC) is waiting,
- Whether or not the slave requires more time to service the processor's request,
- Whether or not a bus ERROR has occurred.

The Address/Control/Data lines emit output specification information to indicate the type of cycle being initiated, e.g., addresses, data to be written, or control information. They also receive data returned to the processor during reads. Details of the ACD line operation and the associated control lines are summarized below.

## ACD15-ACD0 (Address/Control/Data)

As shown in Figure 11, the first cycle, (T1 or Tvo) of a Processor Packet bus transaction (indicated by the rising edge of PRQ), the high-order 8 ACD bits (ACD15...ACD8) specify the type of the current transaction. In this first cycle; the low-order ACD bits (ACD7...ACD0) contain the least-significant eight bits of the 24-bit physical address.
During the subsequent cycle (T2), the remainder of the address is present on the ACD pins (aligned such that the most significant byte of the address is on ACD15 through ACD8, the mid-significant byte on ACD7 through ACD0). If PRQ is asserted during T2, the access is cancelled and the ACD lines are not defined.

During the third cycle (T3 or Tw) of a Processor Packet bus transaction the processor presents a high impedance to the ACD lines for read transactions and asserts write data for write transactions.

Once the bus has entered T3 or Tv, the sequence of state transactions depends on the type of cycle requested during the preceding T 1 or Tvo. Accesses ranging in length from 1 to 32 bytes may be requested (see Table 1). If a transfer of more than one double byte has been requested, it is necessary to enter T3 for every double-byte that is transferred. The processor may simply enter T3 or it may first enter Tw for any number of cycles (as dictated by ICS).

After all data is transferred, the processor enters either Tv or Tvo. Tvo can be entered only when the internal state of execution is such that the processor is prepared to accomplish an immediate write transfer (overlapped access). During Tvo, the ACD lines contain address and specification information aligned in the same fashion as in T1. If the processor does not require an overlapped access, the bus state moves to Tv (the ACD lines will be high impedance). After Tv, a new bus cycle can be started with T1, or the processor may enter the idle state(Ti).

## ICS (Interconnect Status)

ICS has three possible interpretations depending on the state of the bus transaction (see Table 2). Notice that under most conditions ICS has IPC significance for more than one cycle. It is important to note that a valid low during any cycle with IPC significance will signal the processor that an IPC or reconfiguration request has been received. An iAPX 432 processor is required to record and service only one IPC or reconfiguration request at a time. Logic in the interconnect system must record and sequence multiple (possibly simultaneous) IPC occurrences and reconfiguration requests to the processor. Thus the logic that forms ICS must accomodate global and local IPC arrivals and requests for reconfiguration as individual events:

1. Assert IPC significance on ICS for the arrival of an IPC or reconfiguration request.
2. When the iAPX 432 processor reads interconnect address register 2 , it will respond to one of the status bits for the IPC or reconfiguration request signalled on ICS in the following order:

Bit 2 (1=reconfigure, $0=$ do not reconfigure)
Bit 1 ( $1=$ global IPC arrived, $0=$ no global IPC)
Bit 0 ( $1=$ local IPC arrived, $0=$ no local IPC)


Figure 11. Processor Packet Bus State Diagram

Table 1. ACD Specification Encoding

| $\begin{gathered} \text { ACD } \\ 15 \end{gathered}$ | $\begin{gathered} \text { ACD } \\ 14 \end{gathered}$ | $\begin{gathered} \text { ACD } \\ 13 \end{gathered}$ | ACD ACD ACD <br> 12 11 10 | $A C D$ $A C D$ <br> 9 8 |
| :---: | :---: | :---: | :---: | :---: |
| Access | Op | RMW | Length | Modifiers |
| 0 - <br> Memory <br> 1- <br> Other | 0 - <br> Read <br> 1- <br> Write | 0 - <br> Nominal <br> 1- <br> RMW | 000-1 Byte <br> 001-2 Bytes <br> 010-4 Bytes <br> 011-6 Bytes <br> 100-8 Bytes <br> 101-10 Bytes <br> 110-16 Bytes* <br> 111-32 Bytes* <br> * Not implemented | ACD $1.5=0$ : <br> 00-Inst Seg <br> Access <br> 01-Stack Seg <br> Access <br> 10-Context Ctl <br> Seg Access <br> 11-Other <br> ACD $15=1$ : <br> 00-Reserved <br> 01-Reserved <br> 10-Reserved <br> 11-Interconn <br> Register |

3. The logic in the interconnect system must clear the highest order status bit that was serviced by the IAPX 432 processor, and if additional IPC information has arrived, the interconnect system logic must signal an additional IPC indication to the iAPX 432 processor.

The interconnect system must signal the second IPC by raising ICS high for at least one cycle and then setting ICS low for at least one cycle during IPC significance time.

Table 2. ICS Interpretation

|  | Level |  | State |
| :--- | :--- | :--- | :--- |
|  | High | Low |  |
| IPC | None | Waiting | Ti, T1, T2* |
| Stretch | Don't | Stretch | T3, Tw |
| Err | Bus Error | No Error | Tv, Tvo |

*ICS has no significance in a cycle following a T2 where PRQ is asserted (cancelled access) or in any cycle during which CLR/ is asserted.

## PRQ (Processor Packet Bus Request)

PRQ is normally low and can go high only during T1, T2 and Tvo. High levels during Tvo and T1 indicate the first cycle of an access. A high level during T2 indicates that the current cycle is to be cancelled. See Table 3.

Table 3. PRQ Interpretation

| State | PRQ | Condition |
| :--- | :---: | :--- |
| Ti | 0 | Always |
| T 1 | 1 | Initiate access |
| T 2 | 0 | Continue access |
|  | 1 | Cancel access |
| T 3 | 0 | Always |
| Tw | 0 | Always |
| TV | 0 | Always |
| Tvo | 1 | Initiate overlapped access |

## BOUT (Enable Buffers for Output)

BOUT is provided to control external buffers when they are present. Table 4 and Figures 12 through 16 show its state under various conditions.

## Processor Packet Bus Timing Relationships

All timing relationships on the processor packet bus are derived from a simple scheme and related to Table 5. Each timing diagram shown in the following pages (Figures 12 through 17) provides a separate table illustrating the various system states during the cycle. This approach to transfer timing was designed to allow maximum time for the transfer to occur and yet guarantee hold time. The solid lines in Figure 18 show the state transitions initiated by the IP.
iAPX 43203

Any agent connected to the processor packet bus is recognized as either a processor or a slave. Examples of processors are the GDP and the IP. A memory system provides an example of a slave.

In all tranfers between a processor and a slave, the data to be driven are clocked three-quarters of a cycle before they are to be sampled. This allows
adequate time for the transfer and ensures sufficient hold time after sampling. The BOUT timing is unique because BOUT is intended as a direction control for external buffers.

Detailed set-up and hold times depend on the processor implementation and can be found in the ac characteristics section.

Table 4. BOUT Interpretation

| BOUT | Always High | Low-to-High <br> Transition <br> or Low | High-to-Low <br> Transition <br> or Low | High-to-Low <br> Transition <br> or High |
| :---: | :--- | :---: | :--- | :--- |
| Write <br> Read | $\mathrm{T} 1, \mathrm{~T} 2, \mathrm{~T} 3, \mathrm{Tw}, \mathrm{Tvo}$ <br> $\mathrm{T} 1, \mathrm{~T} 2$ | Ti | None | Tv <br> Ti, Tv |
| T3, Tw | None |  |  |  |

Table 5. iAPX 432 Component Signaling Scheme

|  | Processor |  | Slave |  |
| :---: | :---: | :---: | :---: | :---: |
| Inputs Sampled | ACD: Others: | $\begin{aligned} & \text { ICLKA } \\ & \text { †CLKA } \end{aligned}$ | All: | $\uparrow$ ¢LKB |
| Outputs Driven | All (except BOUT): BOUT: | \CLKA †CLKA | ACD: Others: | $\begin{aligned} & \text { ICLKB } \\ & \text { †CLKB } \end{aligned}$ |



Figure 12. Nominal Write Cycle Timing


Figure 13. Minimum Write Cycle Timing


Figure 14. Stretched Write Cycle Timing


Figure 15. Minimum Read Cycle (Not Buffered)


Figure 16. Minimum Read Cycle (Buffered System)


Figure 17. Minimum Faulted Access Cycle


Figure 18. IP State Diagram

Table 6. iAPX 43203 Interface Processor Pin Summary

| 432 System Side |  |  |  |
| :---: | :---: | :---: | :---: |
| Pin Group | Pin Name | Direction | Hardware Error Detection |
| PROCESSOR PACKET BUS GROUP <br> SYSTEM GROUP DETECTION GROUP | ACD15...ACD0 <br> PRQ <br> ICS <br> BOUT <br> ALARM / <br> FATAL/ <br> CLR/ <br> PCLK/ <br> INIT/ <br> CLKA <br> CLKB <br> HERR |  | $\begin{aligned} & x \\ & x \end{aligned}$ |
| Peripheral Subsystem Side |  |  |  |
| Pin Group | Pin Name | Direction | Hardware Error Detection |
| PERIPHERAL SUBSYSTEM BUS GROUP <br> PS TIMING GROUP | AD15... AD0 <br> BHEN/ <br> CSI <br> WR/ <br> ALE <br> OE <br> SYNC | $\begin{aligned} & 1 / 0 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | x |
| PS BUFFER CONTROL GROUP | DEN/ | 0 | x |
| PS INTERLOCK GROUP | $\begin{aligned} & \text { HLD } \\ & \text { HDA } \end{aligned}$ | $0$ | x |
| PS SYNCHRONIZATION GROUP | XACK। <br> NAKI <br> INH1 | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \\ & x \end{aligned}$ |
| PS INTERRUPT GROUP | INT | 0 | $x$ |
| PS RESET GROUP | PSR | 0 | x |

iAPX 43203

## 43203 PIN DESCRIPTION

The following section provides detailed information concerning the 43203 pin description. Table 6 lists a summary of all signal groups, signal names and their active states, and whether or not they are monitored by the Hardware Error Detection circuitry.

## Processor Packet Bus Group

ACD ${ }_{15}$-ACD 0 (Address/Control/
Data lines, Inputs or Three-state Outputs, high asserted)

The Processor Packet bus Address/Control/Data lines are the basic communication path between the IP and its environment. These pins are used three ways:

- They may indicate control information for bus transactions,
- They may issue physical addresses generated by the IP for an access, or
- They may transfer data (either direction).

When the 43203 is in checker mode, the ACD pins are monitored by the hardware error detection logic and are in the high impedance mode.

## PRQ (Processor Packet bus Request, Three-state Output, high asserted)

PRQ is used to indicate the presence of a transaction between the IP and its external environment. Normally low, the PRQ pin is brought high during the same cycle as the first double-byte of address information is being driven onto the ACD pins. PRQ remains high for only one cycle during the access, unless an address development fault occurs. The 43203 will leave PRQ high for a second cycle to indicate the GDP has detected an addressing or segment rights fault in completing address generation. PRQ is checked by the hardware error detection logic. PRQ is in a high impedance state when the 43203 is in checker mode.

## ICS (Interconnect Status, Input, high asserted)

ICS is an indication to the 43203 from the bus interface circuitry concerning the status of a bus transaction. The interpretation of the ICS state is dependent upon the present cycle of a bus transaction and may indicate:

- Interprocessor communication (IPC) message waiting,
- Input data invalid,
- Output data not taken,
- Bus error in external environment.


## System Group

## ALARM/ (Alarm, Input, low asserted)

The ALARM/ input monitors the occurrence of an unusual, system-wide condition such as power failure. ALARM/ is sampled on the rising edge of CLKA.

FATAL/ (Fatal, Output, low asserted) (Master, Input, low asserted)

FATAL/ is asserted by the IP under microcode control when the processor is unable to continue due to various error or fault conditions. Once FATAL/ is asserted, it can only be reset by assertion of INIT/. FATAL/ is not checked by the hardware error detection logic.

When INIT/ is asserted, the FATAL/ pin assumes an input role. Please refer to the INIT/ pin description for a discussion of this function.

## Hardware Error Detection Group

## HERR (Hardware Error Output, Open Drain Output, high asserted) (Master, Input, low asserted)

HERR is used to signal a discrepancy between a master and a checker (difference between the value internally computed in the checker and that output by the master). The sampling of errors occurs at the most appropriate time for the pin(s) being checked.

HERR is an open drain output which requires an external pullup resistor. Nominally the output is held low. HERR is released upon the detection of discrepancy. The timing of HERR depends on the source of the error. Once HERR is high it will remain high until external logic forces it to go low again. When HERR goes low again, the present HERR error condition is cleared and HERR is immediately capable of detecting and signaling another error.

When INIT/ is asserted, the HERR pin assumes an input role. Please refer to the INIT/ pin description for a discussion of this function.

PCLK/ (Processor Clock, Input, low asserted)

Assertion of PCLK/ for one clock cycle causes the system timer in the IP to decrement. Assertion of PCLK/ for two or more cycles causes the system timer to be reset. PCLK/ must be unasserted for at least 10 clock cycles before being asserted again.

## CLR/ (Clear, Input, low asserted)

Assertion of CLR/ results in a microprogram trap which causes the IP to immediately terminate any bus transactions or internal operations which may be in progress at the time, reset to a known state, assert FATALI, and await an IPC (which resets the IP to the same state as INIT/ assertion does). The IPC will not be serviced for at least four clock cycles following CLR/ assertion.

Response to CLR/ is disabled by the first CLR/ assertion and is reenabled when the IP receives the first IPC (or INIT/ assertion).

CLR/ is sampled by the IP on the rising edge of CLKA.

## INIT/ (Initialize, Input, low asserted)

Assertion of INIT/ causes the internal state of the IP to be reset and starts execution of the initialization microcode. INIT/ must be asserted for a minimum of 10 clock cycles. After the INIT/ pin is returned to its nonasserted state, IP microcode will initialize all of the internal registers and windows and will wait for a local IPC.

During INIT/ assertion, the FATAL/ and HERR pins are sampled by the IP to establish the mode in which the two bus interfaces of the IP are to par-
ticipate in hardware error detection. Table 7 specifies the encoding of the master/checker modes.

Table 7. Representation of MASTER/CHECKER Modes at Initialization

| FATAL/ | HERR | iAPX 432 <br> Side | Peripheral <br> Subsystem Side |
| :---: | :---: | :---: | :--- |
| 0 | 0 | MASTER | MASTER |
| 0 | 1 | MASTER | CHECKER |
| 1 | 0 | CHECKER | MASTER |
| 1 | 1 | CHECKER | CHECKER |

## Clock Group

CLKA, CLKB (Clock A, Clock B, Inputs)
CLKA provides the basic timing reference for the IP. CLKB follows CLKA by one-quarter cycle and is used to assist internal timings.

## Peripheral Subsystem Bus Group

## $A D_{15}-A D_{0}$ (Address/Data, Input/Output)

These pins constitute a multiplexed address and data input/output bus. When the attached processor bus is idle or during the first part of an access, these pins normally view the bus as an address. The address is asynchronously checked to see if it falls within (matches) any one of the five window address ranges. The address is latched on the falling edge of ALE thereby maintaining the state of a match or no match for the remainder of the access cycle. The addresses are then unlatched on the falling edge of $O E$.

Once SYNC has pulsed high, the $A D_{15}-A D_{0}$ pins become data input and output pins. When WR/ is high (read mode), data is now accessed in the IP and the output buffers are enabled onto the AD pins if the OE is asserted. When WR/ is low (write mode), data is sampled by the IP after the rising edge of SYNC during the CLKA high time.

The address is always a 16-bit, unsigned number. Data may be either 8 bits or 16 bits as defined by $B H E N /$ and $A D_{0}$. The 8-bit data may be transferred on either the high $\left(A D_{15}-A D_{8}\right)$ or the low $\left(A D_{7}-A D_{0}\right)$ byte. When 8 -bit data is transferred on the high or low byte, the opposite byte is 3 -stated.
iAPX 43203

Twenty-bit addresses are accommodated by the external decoding of the additional address bits and are incorporated in the external CS/ logic.

During the clock in which write data is sampled, data must be set up before the rising edge of CLKA and must be held until the falling edge of that CLKA. Read data is driven out from a CLKA high and should be sampled on the next rising edge of CLKA.

Hardware error detection sampling is not done synchronously to CLKA. It is sampled by the falling edge of the OE pin. The internal AD pin hardware error detection signal is then clocked and output on the HERR pin. At this point it may still not be synchronous with CLKA and should be externally synchronized.

## BHEN/ (Byte High Enable, Input, low asserted)

This pin, together with $A D_{0}$, determines whether 8 or 16 bits of data are to be accessed, and if it is 8 bits, whether it is to be accessed on the upper or lower byte position. This pin is latched by the falling edge of ALE and unlatched by the falling edge of OE. BHEN/ and $A D_{0}$ decode as shown in Table 8.

Table 8. Bus Data Controls

| BHEN/ | AD $D_{0}$ | Description |
| :---: | :---: | :--- |
| 0 | 0 | 16 -bit access |
| 0 | 1 | 8 bits on upper byte, <br> lower byte tristated |
| 1 | 0 | 8 bits on lower byte, <br> upper byte tristated |
| 1 | 1 | 8 bits on lower byte, <br> upper byte tristated |

## CS/ (Chip Select, Input, low asserted)

Chip Select specifies that this IP is selected and that a read or write cycle is requested. This pin is latched by the falling edge of ALE and unlatched by the falling edge of $O E$.

## WR/ (Write, Input, low asserted)

This pin specifies whether the access is to be a read or a write. WR/ is asserted high for a read and asserted low for a write. This pin is latched by the falling edge of ALE and unlatched by the falling edge of $O E$.

## PS Timing Group

ALE (Address Latch Enable, Input,
Rising- and Falling-Edge-Triggered)
The rising edge of ALE sets a flip-flop which enables Transfer Acknowledge (XACK/) to become active. The falling edge of ALE latches the address on the $A D_{15}-A D_{0}$ pins and latches WRI, BHEN/ and CS/. Figure 19 shows two styles of ALE.

## OE (Data Output Enable, Input, high asserted)

During a read cycle the OE pin enables read data on to the $A D_{15}-A D_{0}$ pins when it is asserted. During a read or write cycle the falling edge of OE signifies the end of the access cycle. Specifically, the falling edge of OE does three things:

1. Resets the XACK/ enable flip-flop, thereby terminating XACK/.
2. Terminates DEN / (if read cycle).
3. Opens address latches WR/, BHEN /, and CS/.


171874-10
Figure 19. Two styles of ALE

## SYNC (Synchronized Qualifier Signal, Input, high asserted)

A rising edge on this signal must be synchronized to the IP CLKA falling edge. This signal qualifies the address, BHEN/, CS/ and WR/, indicating a valid condition. SYNC also initiates any internal action on the IP's part to process an access. It starts the request for data to the IP in a read access. In a write access, data is expected one or two CLKA's after SYNC pulses high. At initialization time, IP microcode sets the write sample delay to the slowest operation (two CLKA's after SYNC). However, this can be modified to one clock cycle by making a function request to the IP to change the write sample delay.

When the hold/hold-acknowledge mechanism of the IP is used, and once HDA has pulsed high, a SYNC pulse is required to qualify the hold acknowledge since the HDA pin can be asynchronous.

## PS Buffer Control Group

## DEN/ (Data Enable, Output, Iow asserted)

This pin enables external data buffers which would be used in systems where the address and data are not multiplexed (e.g., a Multibus system). DEN/ assertion begins no sooner than the CLKA high time of the first clock of SYNC assertion if a valid, mappable address range is detected. It is terminated with the falling edge of OE. In a write access, it is also terminated after XACK/ assertion.

Hardware error detection occurs during the first clock of SYNC assertion.

## PS Interlock Group

## HLD (Hold Request, Output, high asserted)

The hold/hold-acknowledge mechanism is an interlocking mechanism between the peripheral subsystem and the IP. Hold is used by the IP to gain control of the subsystem bus to ensure that no subsystem processors will make an access to the IP while it alters internal registers.

This signal is put out synchronously with the rising edge of CLKA. Hardware error detection sampling occurs during CLKA low time.

In special cases it may not be necessary to use the HLD function interlocking. In this case HDA can be tied high and no SYNC pulse will be required for HDA qualification. The hardware detects this condition by noting that the HDA pin was high a half clock before HLD requests a hold. In this mode the HLD output still functions and can be monitored if desired.

## HDA (Hold Acknowledge, Input, high asserted)

HDA is asserted by the peripheral subsystem when the IP's request for a hold has been granted. This pin need only be a high pulse and can be asynchronous to CLKA. This pin must be followed by a SYNC pulse in order to synchronously qualify it.

## PS Synchronization Group

## XACK/ (Transfer Acknowledge, Output, low asserted)

XACK/ is used to acknowledge that a data transfer has taken place.

For random or local accesses, XACK/ indicates that a transfer to or from iAPX 432. memory has been completed.

For buffered accesses where the XACK-Delay is not in the advanced mode, XACK/ signifies that the transfer from/to the prefetch/postwrite buffer in the IP has been completed.

For buffered accesses which use advanced acknowledge mode ( $X D=0$ ) the formation of an advanced XACK/ signal is requested. This allows the possibility of interfacing to the peripheral subsystem without wait states. The acknowledge will be advanced if the access is a read operation and the buffer contains the required data or the access is a write operation and the buffer contains sufficient space to accept the write data. In addition, the access must be valid.

If XACK/ is preceded by a low pulse on NAK/, then XACK/ signifies that the access encountered a fault. If the access was a random access, other than window \#4, the window will be placed in the faulted state and any further accesses to this window will be ignored by the IP.

If the IP is programmed to be in advanced acknowledge mode ( $\mathrm{XD}=0$ ) and $\mathrm{XACK} /$ is not returned before the peripheral subsystem issued SYNC, then XACK/ will be postponed until valid data has been established on the $A D_{15}-A D_{0}$ bus.

## Five conditions affecting XACK/ behavior are:

- XACK-Delay, user programmable through an IP function request. This parameter establishes the minimum operating XACK-delay with respect to the SYNC signal. Table 9 displays the representation of the XACK-delay codes.
- XACK-enable-flip-flop, set by the rising edge of the ALE signal and reset by the falling edge of the $O E$ signal.
- Internal IP Registers. These are used to determine validity of the peripheral subsystem access and establish access modes.
- Type of access behavior: Random or Buffered, Memory or Interconnect.
- Bus Faults, nonexistent memory, etc.

Hardware error detection occurs during the first clock of SYNC assertion.

## NAK/ (Negative Acknowledge, Output, low asserted)

This signal precedes XACK/ by one-half clock cycle in order to qualify it as a negative acknowledge. This pin pulses low for only one clock period.

When the IP is in physical mode and making an interconnect access, negative acknowledge may be used to indicate that the access was made to a nonexistent interconnect address space. This will
allow determination of the system configuration by a subsystem processor at system initialization time.

This pin could be used to set a status bit and cause a special interrupt to transmit the information back to the subsystem.

This signal is synchronously driven from the falling edge of CLKA. Hardware error detection occurs during CLKA high time.

## INH1 (Inhibit, Output, high asserted)

This pin is asynchronously asserted by nonclocked logic when a valid mappable address range is detected. It can be used to override other memories in the peripheral subsystem whose address space is overlapped by an IP window. After initialization, the microcode sets the INH1 mode for each window by loading registers in the IP for each window. Once the subsystem is allowed to make a function request, it can selectively disable or enable the inhibit mode on each window. This pin is gated off by CS/.

The selection of the inhibit mode for window 0 , when in buffered mode, causes a corresponding built-in XACK-delay which delays the acknowledge from going active until two clock periods after the rising edge of SYNC. This was done to facilitate most Multibus systems using INH1, as they require that the acknowledge be delayed. When the Advanced XACK/ mode is programmed, the inhibit mode should not be used on window 0 when in buffered mode, since the acknowledge will not be effectively delayed.

Hardware error detection occurs during the first clock of SYNC assertion.

Table 9. XACK/ Timing Parameters

| Inhibit <br> Mode | WR/ | XD1 | XD | XACK/Formation |
| :---: | :---: | :---: | :---: | :--- |
| 0 | X | 0 | 0 | Advanced Acknowledge <br> (XACK/ can occur before SYNC) |
| 0 | 1 | 0 | 1 | Rising edge of SYNC |
| 0 | 0 | 0 | 1 | Rising edge of SYNC plus 1 Clock |
| 0 | 1 | 1 | 0 | Rising edge of SYNC plus 1 Clock |
| 0 | 0 | 1 | 0 | Rising edge of SYNC plus 2 Clocks |
| 1 | $X$ | 1 | 0 | Rising edge of SYNC plus 2 Clocks |
| 1 | X | 0 | 1 | Rising edge of SYNC plus 2 Clocks |
| X | 1 | 1 | Illegal condition |  |

Note: $X=$ don't care condition

## PS Interrupt Group

## INT (Interrupt, Output, high asserted)

This output is a pulse 2 CLKA's wide, and is synchronously driven from the rising edge of CLKA. Hardware error detection occurs during CLKA low time.

## PS Reset Group

PSR (Peripheral Subsystem Reset, Output, high asserted)

PSR is asserted by the IP under microprogram control. When asserted, the peripheral subsystem should be reset. In a debug type of control, it may be desirable to use this pin to set a status bit in an external register or possibly cause a special inter-
rupt. This pin is normally asserted by the IP when the peripheral subsystem is believed to be faulty and would not respond to other means of control.

This signal is put out synchronously with the rising edge of CLKA. Hardware error detection sampling occurs during CLKA low time.

## 43203 ELECTRICAL CHARACTERISTICS

Tables 10 through 12 and Figures 20 through 25 provide electrical specification information and include input/output timing, read and write timing, and component maximum ratings.

## Instruction Set Comparison

Refer to Table 13 for a GDP/IP operator comparison.

Table 10. 43203 Absolute Maximum Ratings

| 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 GND | -1 V to +7 V |
| Power Dissipation | 2.5 Watts |

Table 11. iAPX 43203 DC Characteristics

| $V C C=5 V \pm 10 \%$ |  |  | $\mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| :---: | :---: | :---: | :---: | :---: |
| Spec | Description | Min | Max | Units |
| Vilc | Clock input Low Voltage | -0.3 | +0.5 | V |
| Vihc* | Clock Input High Voltage | 3.5 | $\mathrm{VCC}+0.5$ | V |
| Vil | Input Low Voltage | -0.3 | 0.8 | V |
| Vih | Input High Voltage | 2 | VCC +0.5 | V |
| Icc | Power Supply Current | - | 450 | mA |
| lii | Input Leakage Current | - | $\pm 10$ | uA |
| 10 | Output Leakage Current | - | $\pm 10$ | uA |
| lol | @ 0.45 Vol HERR | -- | 8 | mA |
|  | FATAL/ | - | 4 | mA |
|  | AD15...AD0 | - | 4 | mA |
|  | OTHER | - | 2 | mA |
| Ioh | @ 2.4 Voh | - | -0.1 | mA |

[^34]Table 12. iAPX 43203 AC Characteristics

| $\mathrm{VCC}=5 \pm 10 \% \quad \mathrm{Ta}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  | Loading: AD15...AD0 OTHER |  |  | 020 to 100pf 20 to 70pf |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Description | 8 MHz . |  | 5 MHz . |  | Unit |
|  |  | Min | Max | Min | Max |  |
| GLOBAL TIMING REQUIREMENTS |  |  |  |  |  |  |
| tcy tr,tf t1,t2 t3, t4 tis tsi tie | Clock Cycle Time <br> Clock Rise and Fall Time <br> Clock Pulse Widths INIT / to Signal Hold Time Signal to INIT/ Setup Time INIT/ Enable Time | $\begin{gathered} 125 \\ - \\ 26 \\ 15 \\ 10 \\ 10 \end{gathered}$ | $\begin{array}{r} 1000 \\ 10 \\ 250 \\ - \\ - \\ - \end{array}$ | $\begin{gathered} 200 \\ - \\ 45 \\ 20 \\ 10 \\ 10 \end{gathered}$ | $\begin{array}{r} 1000 \\ 10 \\ \\ 250 \\ - \\ - \\ - \end{array}$ | nsec. nsec. <br> nsec. nsec. nsec. tcy |
| SYSTEM SIDE TIMING REQUIREMENTS |  |  |  |  |  |  |
| tdc <br> tcd <br> tdh <br> toh <br> ten <br> tdf | Signal to CLOCK Setup Time Clock to Signal Delay Time Clock to Signal Hold Time Clock to Signal Output Hold Time Clock to Signal Output Enable Time Clock to Signal Data Float Time | $\begin{aligned} & 5 \\ & - \\ & 25 \\ & 15 \\ & 15 \\ & - \end{aligned}$ | - 55 - - - 55 | 5 - 35 20 20 - | - 85 - - - 75 | nsec. <br> nsec. <br> nsec. <br> nsec. <br> nsec. <br> nsec. |
| PERIPHERAL SUBSYSTEM SIDE TIMING REQUIREMENTS |  |  |  |  |  |  |
| tas <br> tah <br> tss <br> tsh <br> tsw <br> tds <br> tdx* <br> $\operatorname{tdh} x$ <br> tasy | AD15...AD0,CS/,WR/,BHEN/ <br> Setup Time to ALE Low <br> AD15...AD0,CS/,WR/,BHEN/ <br> Hold Time to ALE Low <br> SYNC High Setup Time to <br> CLKA High <br> SYNC Low Hold Time to <br> CLKA High <br> SYNC High Pulse Width <br> Write Data Setup to <br> Sampling CLKA High <br> Write Data Hold to Sampling <br> CLKA Low (Advanced XACK/) <br> Write Data Hold to XACK/ <br> AD15...AD0,CS/,WR/,BHEN/ <br> Setup to SYNC | $\begin{array}{r} 0 \\ 32 \\ 50 \\ 30 \\ 50 \\ \\ 10 \\ 10 \\ 5 \end{array}$ | tss + $1.5 \mathrm{tcy}$ | $\begin{array}{r} 0 \\ 35 \\ 60 \\ 40 \\ 60 \\ \\ 20 \\ 20 \\ 5 \end{array}$ | - - - - tss + 1.5 tcy - | nsec. <br> nsec. <br> nsec. <br> nsec. <br> nsec. <br> nsec. <br> nsec. <br> nsec. <br> nsec. |
| PERIPHERAL SUBSYSTEM TIMING RESPONSES |  |  |  |  |  |  |
| tsdh taih <br> tede tead <br> tdad <br> tced <br> tcvd tox <br> tdds <br> txde <br> tcde | CLKA High to HLD,INT,PSR <br> Valid AD15...AD0,CS/ <br> to Chip INH1 Valid Delay <br> OE to DEN / Delay <br> OE to Enable AD15...AD0 Buffers <br> Delay (Read Cycle) <br> OE to Disable AD15...AD0 Buffers <br> Delay (Read Cycle) <br> CLKA High to Enable AD15..AD0 <br> Buffers Delay <br> CLKA High to Valid Read Data Delay <br> OE Inactive to XACK/ Inactive Delay <br> AD15...AD0 Disable Setup to DEN / High <br> XACK/Low to DEN/ High (Write Cycle) <br> CLKA High to DEN / Low | 0 | $\begin{aligned} & \hline 75 \\ & 80 \\ & 65 \\ & 70 \\ & 52 \\ & 70 \\ & 80 \\ & 80 \\ & \hline- \\ & 35 \\ & 70 \end{aligned}$ | 0 | 90 <br> 85 <br> 70 <br> 75 <br> 52 <br> 75 <br> 90 <br> 90 <br> 90 <br> - <br> 40 <br> 75 | nsec. <br> nsec. nsec. <br> nsec. <br> nsec. <br> nsec. nsec. <br> nsec. <br> nsec. <br> nsec. nsec. |

Table 12. iAPX 43203 AC Characteristics (Cont'd.)

| Symbol | Description | 8 MHz . |  | 5 MHz . |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| XACK/ TIMING CHARACTERISTICS |  |  |  |  |  |  |
| $\begin{aligned} & \operatorname{tax} \\ & \operatorname{tds} x \end{aligned}$ | Buffered Accesses with XD=0 ALE High to XACK / Valid AD15...AD0 Read Data Valid Setup to XACK/ Valid | 0 | 65 | 0 | 70 | nsec. |
| $\operatorname{tadx}$ | (When internal state does not allow XACK/ before SYNC) Valid AD15...AD0 to XACK / Valid | 20 | - | 20 | - | nsec. |
|  | (When internal state allows <br> XACK/ before SYNC) | - | 120 | - | 140 | nsec. |
| tdsx | Buffered Accesses (With XD=1 or XD=2) or Random Accesses AD15...AD0 Read Data Valid Setup to XACK/ | 20 | - | 20 | - | nsec. |
| tsdl tsnx | Faulted Accesses CLKA Low to NAK/ Setup of NAK/ to XACK/ | - | 75 | 50 | 90 | nsec. nsec. |

Note: All timing parameters are measured at the 1.5 Volt level except for CLKA and CLKB which are measured at the 1.8 Volt level.

* Write data is sampled for only one clock cycle. The PS must meet the $t_{D H X}$ specification thereby guaranteeing $t_{D X}$.


Figure 20. 43203 Clock Input Specification


Figure 22. 43203 Input Timing Specification

Figure 21. 43203 Output Timing Specification



Figure 23. 43203 Initialization Timing


171874-14
Figure 24. Local Processor Bus Timing


Figure 25. Multibus ${ }^{\text {TM }}$ Interface Timing

Table 13. GDP/IP Operator Comparison

| OPERATOR | IP IMPLEMENTATION |
| :---: | :---: |
| Window Definition Operator Update Window | + |
| Access Descriptor Movement Operators Copy Access Descriptor Null Access Descriptor |  |
| Rights Manipulation Operators Amplify Rights Restrict Rights | $=$ $=$ |
| Type Definition Manipulation Operators Create Public Type Create Private Type Retrieve Public Type Retrieve Type Retrieve Type Definition |  |
| Refinement Operators Create Generic Refinement Create Typed Refinement Retrieve Refinement | $=$ |
| Segment Creation Operators Create Data Segment Create Access Segment Create Typed Segment Create Access Descriptor |  |
| Access Path Inspection Operators Inspect Access Descriptor Inspect Access Path | $=$ |
| Object Interlock Operators <br> Lock Object <br> Unlock Object <br> Indivisibly Add Short Ordinal <br> Indivisibly Add Ordinial <br> Indivisibly Insert Short Ordinal Indivisibly Insert Ordinal | $\begin{aligned} & = \\ & = \\ & - \\ & - \\ & - \\ & - \end{aligned}$ |
| Context Communication Operators <br> Enter Access Segment <br> Enter Process Globals Access Segment <br> Set Context Mode <br> Call <br> Call Context with Message <br> Return | $=$ |

Table 13. GDP/IP Operator Comparison (Cont'd.)

| OPERATOR | IP IMPLEMENTATION |
| :--- | :--- |
|  |  |
| Process Communication Operators | $=$ |
| Send | $=$ |
| Receive | $=$ |
| Conditional Send | $=$ |
| Conditional Receive | $=$ |
| Surrogate Send | $=$ |
| Surrogate Receive | $=$ |
| Delay | $=$ |
| Read Process Clock | $=$ |
| Processor Communication Operators | $=$ |
| Send to Processor | $=$ |
| Broadcast to Processors | $=$ |
| Read Processor Status and Clock | - |
| Move to Interconnect | - |
| Move from Interconnect | - |
| Branch Operators | - |
| Character Operators | - |
| Short-Ordinal Operators | - |
| Short-Integer Operators | - |
| Ordinal Operators | - |
| Integer Operators | - |
| Short-Real Operators | - |
| Real Operators |  |
| Temporary-Real Operators |  |

Legend:
$=I P$ and GDP identical implementation

+ GDP does not implement operator
- IP does not implement operator

I While conceptually similar, IP implements operator differently than GDP

## Industrial Grade <br> Products

## I2114A <br> $1024 \times 4$-BIT STATIC RAM

INDUSTRIAL

|  | I2114AL-3 | I2114AL-4 | I2114A-4 | I2114A-5 |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 150 | 200 | 200 | 250 |
| Max. Current (mA) | 50 | 50 | 70 | 70 |

- HMOS Technology
- Low Power, High Speed
- Identical Cycle and Access Times
- Single +5 V Supply $\pm 10 \%$
- High Density 18 Pin Package
- Completely Static Memory - No Clock or Timing Strobe Required
- Directly TTL Compatible: All Inputs and Outputs
- Common Data Input and Output Using Three-State Outputs
- Industrial Grade Temperature Range $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ I2114A is a 4096-bit static Random Access Memory organized as 1024 words by 4 bits using HMOS, a high performance MOS technology. It uses fully DC stable (static) circuitry throughout, in both the array and the decoding, therefore it requires no clocks or refreshing to operate. Data access is particularly simple since address setup times are not required. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided.
The I2114A is designed for memory applications where the high performance and high reliability of HMOS, low cost, large bit storage, and simple interfacing are important design objectives. The 12114A 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.


Figure 1. I2114A Block Diagram


| $\mathrm{A}_{0}-\mathrm{A}_{\mathbf{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}_{\mathbf{1}} / \mathrm{O}_{\mathbf{4}}$ | DATA INPUT/OUTPUT |  |

Figure 2. I2114A Pin Diagram

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under | Co $+95^{\circ} \mathrm{C}$ |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on any Pin |  |
| With Respect to Ground | -3.5 V to +7 V |
| Power Dissipation | 1.0W |
| 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 ${ }^{[3]}$

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

| Symbol | Parameter | 12114AL-3/L-4 |  |  | 12114A-4/-5 |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ."' | Max. | Min. | Typ. ${ }^{1 \prime}$ | Max. |  |  |
| $1 / 1$ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.5 V |
| Lo | I/O Leakage Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=V_{1 H} \\ & V_{1 / O}=G N D \text { to } V_{C C} \end{aligned}$ |
| Icc | Power Supply Current |  | 25 | 50 |  | 50 | 70 | mA | $\begin{aligned} & V_{C C}=\max , I_{1 / O}=0 \mathrm{~mA}, \\ & T_{A}=-40^{\circ} C \end{aligned}$ |
| VIL | Input Low Voltage | -3.0 |  | 0.8 | -3.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | 6.0 | 2.0 |  | 6.0 | V |  |
| lot | Output Low Current | 2.1 | 9.0 |  | 21 | 9.0 |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| IOH | Output High Current | -1.0 | -2.5 |  | -1.0 | -2.5 |  | mA | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| los ${ }^{(21}$ | Output Short Circuit Current |  |  | 40 |  |  | 40 | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ |

## NOTES:

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.
3. 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_{J A}\left(@ 400 \mathrm{f}_{\mathrm{PM}}\right.$ air flow $)=40^{\circ} \mathrm{C} / \mathrm{W}$
$\theta_{\text {JA }}($ still air $)=70^{\circ} \mathrm{C} / \mathrm{W}$
$\theta_{\mathrm{JC}}=25^{\circ} \mathrm{C} / \mathrm{W}$

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

| Symbol | Test | Max | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{1 / \mathrm{O}}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{1 / \mathrm{O}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V}$ |

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

## A.C. CONDITIONS OF TEST

Input Pulse Levels10 nsOutput Load1 TTL Gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$

I2114A FAMILY
A.C. CHARACTERISTICS $T_{A}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.

READ CYCLE ${ }^{[1]}$

| Symbol | Parameter | 12114AL-3 | 12114A-4/L-4 | 12114A-5 | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Max. | Min. Max. | Min. Max. |  |
| $\mathrm{t}_{\mathrm{RC}}$ | Read Cycle Time | 150 | 200 | 250 | ns |
| $t_{A}$ | Access Time | 150 | 200 | 250 | ns |
| $\mathrm{t}_{\mathrm{co}}$ | Chip Selection to Output Valıd | 70 | 70 | 85 | ns |
| tcx | Chip Selection to Output Active | 10 | 10 | 10 | ns |
| toto | Output 3-state from Deselection | 40 | 50 | 60 | ns |
| toha | Output Hold from Address Change | 15 | 15 | 15 | ns |

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

|  | Parameter | 12114AL-3 |  | I2114A-4/L.4 |  | 12114A-5 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| twc | Write Cycle Time | 150 |  | 200 |  | 250 |  | ns |
| tw | Write Time | 90 |  | 120 |  | 135 |  | ns |
| $t_{\text {WR }}$ | Write Release Time | 0 |  | 0 |  | 0 |  | ns |
| torw | Output 3-state from Write |  | 40 |  | 50 |  | 60 | ns |
| $t_{\text {DW }}$ | Data to Write Time Overlap | 90 |  | 120 |  | 135 |  | ns |
| $\mathrm{t}_{\mathrm{DH}}$ | Data Hold from Write Time | 0 |  | 0 |  | 0 |  | ns |

## NOTES:

1. A Read occurs during the overlap of a low $\overline{C S}$ and a high $\overline{W E}$.
2. A Write occurs during the overlap of a low $\overline{C S}$ and a low $\overline{W E} . t_{w}$ is measured from the latter of $\overline{C S}$ or $\overline{W E}$ going low to the earlier of $\overline{\mathrm{CS}}$ or $\overline{\mathrm{WE}}$ going high.


## 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{\mathrm{WE}}$ must be high during all address transitions.

## 12118 FAMILY 16,384 $\times 1$-BIT DYNAMIC RAM

INDUSTRIAL

|  | $12118-12$ | $12118-15$ |
| :--- | :---: | :---: |
| Maximum Access Time (ns) | 120 | 150 |
| Read, Write Cycle (ns) | 270 | 320 |
| Read-Modify Cycle (ns) | 320 | 410 |

■ Single + 5V Supply, $\pm 10 \%$ Tolerance

- HMOS Technology


## ■ Low Power: 138 mW Max. Operating 11 mW Max. Standby

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


## ■ CAS Controlled Output is Three-State,

 TTL Compatible- $\overline{R A S}$-Only Refresh
- 128 Refresh Cycles Required Every 2 ms
- Allows Negative Overshoot $\mathrm{V}_{\text {IL }}$ min $=-2 \mathrm{~V}$
- Industrial Grade Temperature Range $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$


#### Abstract

The Intel ${ }^{\circledR} 12118$ is a 16,384 word by 1 -bit Dynamic MOS RAM designed to operate from a single +5 V power supply. The 12118 is fabricated using HMOS-a production proven process for high performance, high reliability, and high storage density.

The 12118 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 12118 in a system environment. Multiplexing the 14 address bits into 7 address input pins allows the 12118 to be packaged in the industry standard 16-pin DIP. The two 7 -bit address words are latched into the 12118 by the two TTL clocks, Row Address Strobe ( $\overline{\text { 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 12118 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 CAS to a high state. The single transistor storage cell requires refreshing for data retention. Refreshing is accomplished by performing RASonly 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.




Figure 1. Block Diagram

| $A_{0} A_{6}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{C A} \bar{S}$ | COLUMN ADDRESS STROBE |
| $D_{\text {IN }}$ | DATA IN |
| $D_{\text {OUT }}$ | DATA OUT |
| WE | WRITE ENABLE |
| $\overline{\text { RA }} \bar{S}$ | ROW ADDRESS STROBE |
| $V_{\text {DD }}$ | POWER +5 V I |
| $V_{S S}$ | GROUND |

Figure 2. Pin Diagram

12118 FAMILY

| ABSOLUTE MAXIMUM RATINGS* |  |
| :---: | :---: |
| Ambient Temperature Under Bias | - $10+$ |
| Storage Temperature | ${ }^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on any Pin Relative to $\mathrm{V}_{\mathrm{SS}}$ | 7.5 |
| Data Out Curr |  |
| Power Dissipation |  |

Ambient Temperature Under Bias .... $-50^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Voltage on any Pin Relative to $\mathrm{V}_{\text {SS }} \ldots . . . . .$.
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 $a b$ solute maximum rating conditions for extended periods may affect device reliability.

## D.C. AND OPERATING CHARACTERISTICS ${ }^{[1,4}$

$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{(2)}$ | Max. |  |  |  |
| \|lıI| | Input Load Current (any input) |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{1 N}=\mathrm{V}_{\text {SS }}$ to $\mathrm{V}_{\text {DD }}$ |  |
| \|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}}$. $V_{\text {OUT }}=0$ to 5.5 V |  |
| IDD1 | VDD Supply Current, Standby |  | 1.2 | 2 | mA | $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{\text {IH }}$ |  |
| IDD2 | VDD Supply Current, Operating |  | 21 | 25 | mA | $12118-4, \mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\mathrm{RC}} \mathrm{MIN}$ | 3 |
|  |  |  | 19 | 23 | mA | 12118-7, $\mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\mathrm{RC}} \mathrm{MIN}$ | 3 |
| IDD3 | VDD Supply Current; $\overline{\text { RAS }}$-Only Cycle |  | 14 | 16 | mA | $12118-4, \mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\mathrm{RC}}$ MIN | 3 |
|  |  |  | 12 | 14 | mA | 12118-7, $\mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\mathrm{RC}}$ MIN | 3 |
| IDD5 | VDD Supply Current, Standby, Output Enabled |  | 2 | 4 | mA | $\overline{\mathrm{CAS}}$ at $\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{RAS}}$ at $\mathrm{V}_{\text {IH }}$ | 3 |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (all inputs) | -2.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (all inputs) | 2.4 |  | 7.0 | V |  |  |
| Vol | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ |  |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-5 \mathrm{~mA}$ |  |

NOTES:

1. All voltages referenced to $\mathrm{V}_{\mathrm{SS}}$
2. Typical values are for $T A=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. $I_{D D}$ is dependent on output loading when the device output is selected. Specified $I_{D D}$ MAX is measured with the output open.
4. 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}}$ (@ $400 \mathrm{f}_{\mathrm{PM}}$ air flow) $=45^{\circ} \mathrm{C} / \mathrm{W}$
$\theta_{\mathrm{JA}}\left(\right.$ still air) $=60^{\circ} \mathrm{C} / \mathrm{W}$
$\theta_{\mathrm{JC}}=25^{\circ} \mathrm{C} / \mathrm{W}$

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

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

| Symbol | Parameter | Typ. | Max. | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Address, Data In | 3 | 5 | pF |
| $\mathrm{C}_{12}$ | $\overline{\text { RAS, }} \overline{\mathrm{CAS}}, \overline{\mathrm{WE}}$, Data Out | 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}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.
READ, WRITE, READ-MODIFY-WRITE AND REFRESH CYCLES

|  | Parameter | 12118.12 |  | 12118-15 |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. |  |  |
| trac | Access Time From $\overline{\text { RAS }}$ |  | 120 |  | 150 | ns | 4.5 |
| tcac | Access Time From $\overline{\mathrm{CAS}}$ |  | 65 |  | 80 | ns | 4,5,6 |
| tref | Time Between Refresh |  | 2 |  | 2 | ms |  |
| trp | $\overline{\text { RAS Precharge Time }}$ | 120 |  | 135 |  | ns |  |
| tCPN | $\overline{\text { CAS Precharge Time'non-page cycles' }}$ | 55 |  | 70 |  | ns |  |
| tcrp | $\overline{\overline{C A S}}$ to $\overline{\mathrm{RAS}}$ Precharge Time | 0 |  | 0 |  | ns |  |
| trci | $\overline{\text { RAS }}$ to $\overline{\mathrm{CAS}}$ Delay Time | 25 | 55 | 25 | 70 | ns | 7 |
| trsh | $\overline{\text { RAS }}$ Hold Tıme | 85 |  | 105 |  | ns |  |
| tcsh | $\overline{\mathrm{CAS}}$ Hold Time | 120 |  | 165 |  | ns |  |
| tasR | Row Address Set-Up Time | 0 |  | 0 |  | ns |  |
| trah | Row Address Hold Time | 15 |  | 15 |  | ns |  |
| tasc | Column Address Set-Up Time | 0 |  | 0 |  | ns |  |
| tCAH | Column Address Hold Time | 15 |  | 20 |  | ns |  |
| tar | Column Address Hold Time, to $\overline{\mathrm{RAS}}$ | 70 |  | 90 |  | ns |  |
| tT | Transition Time (Rise and Fall) | 3 | 50 | 3 | 50 | ns | 8 |
| toff | Output Buffer Turn Off Delay | 0 | 50 | 0 | 60 | ns |  |

READ AND REFRESH CYCLES

| tRC | Random Read Cycle Time | 270 | 320 |  | ns |
| :---: | :--- | :--- | :--- | :---: | :---: |
| tRAS | $\overline{\text { RAS Pulse Width }}$ | $140 \quad 10000$ | 175 | 10000 | ns |
| tCAS | $\overline{\text { CAS Pulse Width }}$ | 65 | 10000 | 95 | 10000 |
| ns |  |  |  |  |  |
| tRCS | Read Command Set-Up Time | 0 | 0 |  |  |
| tRCH | Read Command Hold Time | 0 | ns |  |  |

## WRITE CYCLE



READ-MODIFY-WRITE CYCLE

| trwc | Read-Modify-Write Cycle Time | 320 |  | 410 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| traw | RMW Cycle $\overline{\mathrm{RAS}}$ Pulse Width | 190 | 10000 | 265 | 10000 | ns |  |
| tcrw | RMW Cycle $\overline{\text { CAS }}$ Pulse Width | 120 | 10000 | 185 | 10000 | ns |  |
| trwo | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{WE}}$ Delay | 120 |  | 150 |  | ns | 9 |
| towo | $\overline{\mathrm{CAS}}$ to. $\overline{\mathrm{WE}}$ Delay | 65 |  | 80 |  | ns | 9 |

NOTES:

1. All voltages referenced to $\mathrm{V}_{\mathrm{SS}}$.
2. Eight cycles are required after power up or prolonged periods (greater than 2 ms ) of 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} 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 tRCD (max.).
5. $\quad$ Load $=2$ TTL loads and 100 pF
6. Assumes $t_{R C D} \geq \operatorname{tRCD}^{(m a x .)}$.
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 $t_{R C D}$ is greater than tRCD (max.) access time is trCD + tcac.
8. $\quad t_{T}$ is measured between $\mathrm{V}_{\mathrm{IH}}$ (min.) and $\mathrm{V}_{\mathrm{IL}}$ (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 tcw $\geq$ tcwo (min.) and trWD $\geq \mathrm{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



D OUT $\quad \mathrm{V}_{\text {OH }} \quad \begin{aligned} & \text { HIGH } \\ & \mathrm{V}_{\text {OL }}\end{aligned}$

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 DOUT
5. toff IS MEASURED TO IOUT $\leqslant \|_{\text {LO }}$.

6 t $_{\text {DS }}$ AND TDH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. tRCH 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 $\overline{C A S}$ HAS NOT BEEN DECODED WITH $\overline{R A S}$ )

## WAVEFORMS

READ-MODIFY-WRITE CYCLE

$\overline{R A S}$-ONLY REFRESH 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_{O H}$ MIN AND $V_{\text {OL MAX }}$ ARE REFERENCE LEVELS FOR MEASURING TIMING OF DOUT.
5. tof $\operatorname{IS}$ MEASURED TO IOUT $\leqslant \|_{\text {LOI }}$.
6. IDS AND $\mathrm{t}_{\mathrm{DH}}$ ARE REFERENCED TO $\overline{\mathrm{CAS}}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. ${ }^{\text {t }}$ CRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{\text { RAS }} / \overline{\mathrm{CAS}}$ CYCLES PRECEEDED BY A $\overline{\text { CAS }}-$ ONLY CYCLE (i.e., FOR SYSTEMS WHERE $\overline{C A S}$ HAS NOT BEEN DECODED WITH $\overline{R A S})$.

# 12716 <br> 16K $(2 \mathrm{~K} \times 8)$ UV ERASABLE PROM <br> indUSTRIAL 

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
- 525 mW Max. Active Power
- 132 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

\author{

- Completely Static
}

The Intel ${ }^{\circledR}$ Industrial Grade I2716 is a 16,384-bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 12716 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 8085 . 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 12716 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}$ | OUTPT ENABLE |
| $O_{0}-O_{7}$ | OUTPUTS |

## PROGRAMMING

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

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . . . . $-50^{\circ} \mathrm{C}$ to $+95^{\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 V to -0.3 V
$V_{\text {Pp }}$ Supply Voltage with Respect
to Ground During Program . . . . . . . . . . . . . +26.5 V to -0.3 V
*NOTICE: 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}}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{VCC}^{|1,2|}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{PP}}{ }^{|2|}=\mathrm{V}_{\mathrm{CC}}$
READ OPERATION

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ[ 3 ] | Max. |  |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=5.25 \mathrm{~V}$ |
| LLO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.25 \mathrm{~V}$ |
| $\mathrm{IPP}^{12]}$ | $V_{P P}$ 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}_{1 \mathrm{H}}, \overline{\mathrm{OE}}=\mathrm{V}_{1 L}$ |
| $\mathrm{ICC2}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Active) |  | 57 | 100 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $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. $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{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 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.

## TYPICAL CHARACTERISTICS

ICC CURRENT vs. TEMPERATURE


ACCESS TIME vs. CAPACITANCE


ACCESS TIME vs. TEMPERATURE


## A.C. CHARACTERISTICS

$\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ to $+85^{\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 | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| ${ }^{t} \mathrm{ACC}$ | Address to Output Delay |  |  | 450 | ns | $\overline{C E}=\overline{O E}=V_{\text {IL }}$ |
| ${ }^{t} \mathrm{CE}$ | $\overline{\mathrm{CE}}$ to Output Delay |  |  | 450 | ns | $\overline{O E}=V_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{OE}$ | Output Enable to Output Delay |  |  | 150 | ns | $\overline{C E}=V_{\text {IL }}$ |
| ${ }^{t}$ DF | Output Enable High to Output Float | 0 |  | 130 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{OH}$ | Output Hold From Addresses, $\overline{C E}$ or $\overline{O E}$ Whichever Occurred First | 0 |  |  | ns | $\overline{C E}=\overline{O E}=V_{\text {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 }}=\mathrm{VV}$ |
| $\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 $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ Input Rise and Fall Times: $\leqslant 20$ 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 |

## WAVEFORMS



NOTES: 1. $V_{C C}$ must be applied simultaneously or before $V_{P p}$ and removed simultane ously or after $\mathrm{V}_{\mathrm{pp}}$.
2. $V_{P P}$ may be connected directly to $V_{C C}$ except during programming. The supply current would then be the sum of Icc 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}}-\mathrm{t}_{\mathrm{OE}}$ after the falling edge of $\overline{\mathrm{CE}}$ without impact on tacc.
7. tor is specified from $\overline{\mathrm{OE}}$ or $\overline{\mathrm{CE}}$, whichever occurs first.

## DEVICE OPERATION

The five modes of operation of the 2716 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

| $\qquad$ | $\overline{C E} / P G M$ (18) | $\begin{gathered} \overline{O E} \\ (20) \end{gathered}$ | $V_{\text {pp }}$ <br> (21) | $\begin{aligned} & v_{C C} \\ & (24) \end{aligned}$ | OUTPUTS (9.11. 13.17) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | +5 | DOUT |
| Standby | $V_{1 H}$ | Don't Care | +5 | +5 | High 2 |
| Program | Pulsed $\mathrm{V}_{\text {IL }}$ to $\mathrm{V}_{\text {IH }}$ | $\mathrm{V}_{\mathrm{IH}}$ | +25 | +5 | DIN |
| Program Verify | $V_{\text {IL }}$ | $V_{1 L}$ | +25 | +5 | Dour |
| Program Inhibit | $V_{1 L}$ | $\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 dat at the outputs. Chip Enable ( $\overline{\mathrm{CE}}$ ) is the power control and should be used for device selection. Output Enable ( $\overline{O E}$ ) 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}_{C E}$ ). Data is available at the outputs 150 ns ( $\mathrm{t}_{\mathrm{OE}}$ ) after the falling edge of $\overline{O E}$, assuming that $C E$ 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 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 .2716's are usually used in larger memory arrays, Intel has provided a 2 line control function that accommodates this use of multiple memory connections. The two line control function allows for
a) the lowest possible memory power dissipation, and, b) complete assurance that output bus contention will not occur.
To most efficiently use these two control lines, it is recommended that CE (pin 18) be decoded and used as the primary device selecting function, while $\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 2716 are in the " 1 " state. Data is introduced by selectively programming " 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 2716 is in the programming mode when the VPP 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 2716 must not be programmed with a DC signal applied to the $\overline{C E}$ input.

Programming of multiple 2716's in parallel with the same data can be easily accomplished due to the simplicity of the programming requirements. Like inputs of the paralleled 2716'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 2716's.

## PROGRAM INHIBIT

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

## PROGRAM VERIFY

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

# SINGLE COMPONENT 8-BIT MICROCOMPUTER WITH ON-CHIP A/D CONVERTER 

\author{

- 8-Bit CPU, ROM, RAM, I/O in Single 40-Pin Package <br> - 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

■ $10 \mu \mathrm{sec}$ Cycle; All Instructions 1 or 2 Cycles

- $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ Operation

■ Interval Timer/Event Counter
■ Instructions-8048 Subset

- Clock Generated with Single Inductor or Crystal
- Easily Expanded I/O

The Intel I8022 is the newest member of the MCS-48® 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 I8022 addresses these applications by integrating many new functions on-chip, such as A/D conversion, comparator inputs and zero-cross detection.

The features of the I8022 includes 2 K bytes of program memory (ROM), 64 bytes of data memory (RAM), 28 I/O lines, an on-chip 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 I8022 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 I8022's hardware implementation of the A/D converter which simplifies interfacing to analog signals.


Figure 1. I8022 Block Diagram


Figure 2. 18022 Pin Configuration


Figure 3. I8022 Logic Symbol

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias ...... $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$
Storage Temperature $\qquad$ $-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 1 Watt
*NOTICE: 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 (TA $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C} ; \mathrm{VCC}=5.5 \mathrm{~V} \pm 1 \mathrm{~V} ; \mathrm{VSS}=0 \mathrm{~V}$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |  |
| VIL | Input Low Voltage | -0.5 |  | 0.5 | V | VTH Floating |
| VIL1 | Input Low Voltage (Port 0) | -0.5 |  | VTH -0.2 | V |  |
| VIH | Input High Voltage <br> (All except XTAL 1, RESET) | 2.3 |  | VCC | V | $V C C=5.0 \mathrm{~V} \pm 10 \%$ <br> VTH Floating |
| VIH1 | input High Voltage (All except XTAL 1, RESET) | 3.8 |  | VCC | V | $V C C=5.5 \mathrm{~V} \pm 1 \mathrm{~V}$ <br> VTH Floating |
| VIH2 | Input High Voltage (Port 0) | VTH + 0.2 |  | VCC | V |  |
| VIH3 | Input High Voltage (RESET, XTAL 1) | 3.8 |  | VCC | V |  |
| VTH | Port 0 Threshold Reference Voltage | 0 |  | . 4 VCC | V |  |
| VOL | Output Low Voltage |  |  | 0.45 | V | $1 \mathrm{OL}=0.8 \mathrm{~mA}$ |
| VOL1 | Output Low Voltage (P10, P11) |  |  | 2.5 | V | $1 \mathrm{OL}=3 \mathrm{~mA}$ |
| VOH | Output High Voltage (All unless Open Drain Option-Port 0) | 2.4 |  |  | V | $\mathrm{IOH}=30 \mu \mathrm{~A}$ |
| ILI | Input Current (T1) |  |  | $\pm 700$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC} \geqslant \mathrm{VIN} \geqslant \mathrm{VSS}+ \\ & 0.45 \mathrm{~V} \end{aligned}$ |
| ILO | Output Leakage Current (Open Drain Option-Port 0) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{VCC} \geqslant \mathrm{VIN} \geqslant \mathrm{VSS}+ \\ & 0.45 \mathrm{~V} \end{aligned}$ |
| ICC | VCC Supply Current | - |  | 120 | mA |  |
| ILI | Input Current to Ports |  |  | 500 | $\mu \mathrm{A}$ | $\mathrm{VIN}=0.45 \mathrm{~V}$ |

A.C. CHARACTERISTICS (TA $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C} ; \mathrm{VCC}=5.5 \mathrm{~V} \pm 1 \mathrm{~V} ; \mathrm{VSS}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| tCY | Cycle Time | 10.0 | 50.0 | $\mu \mathrm{~s}$ | 3 MHz XTAL $=10 \mu \mathrm{~s} \mathrm{tCY}$ |
| VT1 | Zero-Cross Detection Input (T1) | 1 | 3 | VACpp | AC Coupled |
| AZC | Zero-Cross Accuracy |  | $\pm 200$ | mV | 60 Hz Sine Wave |
| FT1 | Zero-Cross Detection Input Frequency (T1) | 0.05 | 1 | kHz |  |

A.C. CHARACTERISTICS (TA $=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C} ; \mathrm{VCC}=5.5 \mathrm{~V} \pm 1 \mathrm{~V} ; \mathrm{VSS}=0 \mathrm{~V}$ )

Test Conditions: $\mathrm{CL}=80 \mathrm{pF} ; \mathrm{tCY}=8.38 \mu \mathrm{~s}$

| Expander <br> Operation | Symbol | Parameter | Min | Max | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | tCP | Port Control Setup Before Falling Edge of PROG | 0.5 |  | $\mu \mathrm{s}$ |  |
|  | tPC | Port Control Hold After Falling Edge of PROG | 0.8 |  | $\mu \mathrm{s}$ |  |
|  | tPR | PROG to Time P2 Input Must Be Valid |  | 1.0 | $\mu \mathrm{s}$ |  |
|  | tDP | Output Data Setup Time | 7.0 |  | $\mu \mathrm{S}$ |  |
|  | tPD | Output Data Hold Time | 8.3 |  | $\mu \mathrm{s}$ |  |
| Normal Operation | tPF | Input Data Hold Time | 0 | 150 | ns |  |
|  | tPP | PROG Pulse Width | 8.3 |  | $\mu \mathrm{s}$ |  |
|  | tPRL | ALE to Time P2 Input Must Be Valid |  | 3.6 | $\mu \mathrm{S}$ |  |
|  | tPL | Output Data Setup Time | 0.8 |  | $\mu \mathrm{s}$ |  |
|  | tLP | Output Data Hold Time | 1.6 |  | $\mu \mathrm{S}$ |  |
|  | tPFL | Input Data Hold Time | 0 |  | $\mu \mathrm{S}$ |  |
|  | tLL | ALE Pulse Width | 3.9 | 23.0 | $\mu \mathrm{s}$ | tCY $=10.0 \mu \mathrm{~s}$ for min |

PORT 2 TIMING


# SINGLE-COMPONENT 8-BIT MICROCOMPUTER 

8031 - Control Oriented CPU With RAM and I/O

- 8051 - An 8031 With Factory Mask-Programmable ROM

\author{

- 4K x 8 ROM <br> - $128 \times 8$ RAM <br> - Four 8-Bit Ports, 32 I/O Lines <br> - Two 16-Bit Timer/Event Counters <br> - High-Performance Full-Duplex Serial Channel <br> - External Memory Expandable to 128K <br> - Compatible with MCS-80 ${ }^{(\pi)} /$ MCS $^{(85}$ Peripherals
}

Boolean Processor<br>- MCS-48 ${ }^{\circledR}$ Architecture Enhanced with:<br>- Non-Paged Jumps<br>- Direct Addressing<br>- Four 8-Register Banks<br>- Stack Depth Up to 128-Bytes<br>- Multiply, Divide, Subtract, Compare<br>- Most Instructions Execute in $1 \mu \mathrm{~s}$<br>$4 \mu \mathrm{~s}$ Multiply and Divide

The Intel ${ }^{\circledR} 8031 / 8051$ is a stand-alone, high-performance single-chip computer fabricated with Intel's highly-reliable +5 Volt, depletion-load, N-Channel, silicon-gate HMOS technology and packaged in a 40-pin DIP. It provides the hardware features, architectural enhancements and new instructions that are necessary to make it a powerful and cost effective controller for applications requiring up to 64 K bytes of program memory and/or up to 64 K bytes of data storage.
The 8051 contains a non-volatile 4K $\times 8$ read only program memory; a volatile $128 \times 8$ read/write data memory, 32 I/O lines; two 16-bit timer/counters; a five-source, two-priority-level, nested interrupt structure; a serial I/O port for either multi-processor communications, I/O expansion, or full duplex UART; and on-chip oscillator and clock circuits. The 8031 is identical, except that it lacks the program memory. For systems that require extra capability, the 8051 can be expanded using standard TTL compatible memories and the byte oriented MCS-80 and MCS-85 peripherals.
The 8051 microcomputer, like its 8048 predecessor, is efficient both as a controller and as an arithmetic processor. The 8051 has extensive facilities for binary and BCD arithmetic and excels in bit-handling capabilities. Efficient use of program memory results from an instruction set consisting of $44 \%$ one-byte, $41 \%$ two-byte, and $15 \%$ three-byte instructions. $58 \%$ of the instructions execute in $1 \mu \mathrm{~s}$, $40 \%$ in $2 \mu \mathrm{~s}$, and multiply and divide require only $4 \mu \mathrm{~s}$. Among the many instructions added to the standard 8048 instruction set are multiply, divide, subtract and compare.


18048H/I8035HL NEW HIGH PERFORMANCE HMOS SINGLE COMPONENT 8-BIT MICROCOMPUTER

## INDUSTRIAL

- 18048H Mask Programmable ROM
- 18035HL External ROM or EPROM
- RAM Power Down Mode
- Interchangeable with 8748
- 8 MHz Operation
- 8-Bit CPU, ROM, RAM, I/O in Single Package
- High Performance HMOS
- Reduced Power Consumption
- $1.88 \mu \mathrm{sec}$ Cycle

All instructions 1 or 2 Cycles

- Over 90 Instructions: 70\% Single Byte
- $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ Operation
- $1 \mathrm{~K} \times 8 \mathrm{ROM}$
$64 \times 8$ RAM
27 I/O Lines
- Interval Timer/Event Counter
- Easily Expandable Memory and I/O
- Compatible with 8080/8085 Series Peripherals
- Two Single Level Interrupts

The Intel 18048 H is a totally self-sufficient, 8-bit parallel computer fabricated on a single silicon chip using Intel's advanced N -channel silicon gate HMOS process.
The 18048 H contains a $1 \mathrm{~K} \times 8$ program memory, a $64 \times 8$ RAM data memory, $27 \mathrm{I} / \mathrm{O}$ lines, and an 8 -bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability the 18048 H can be expanded using standard memories and MCS $-80^{\circledR} / \mathrm{MCS}-85^{\circledR}$ peripherals. The 18035 HL is the equivalent of the I8048H without program memory and can be used with external ROM and RAM.
To reduce development problems to a minimum and provide maximum flexibility, a logically and functionally pin-compatible version of the I8048H with UV-erasable user-programmable EPROM program memory is available. The 18748 will emulate the 18048 H up to 6 MHz clock frequency with minor differences.
I8048H is fully compatible with the 18048 when operated at 6 MHz .
These microcomputers are designed to be efficient controllers as well as arithmetic processors. They have 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.


Figure 1.
Block Diagram

Figure 2.
Logic Symbol


Figure 3.
Pin Configuration

## 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.5 Watt
*NOTICE: 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 device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $85^{\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 RESET, X1, X2) | -. 5 |  | . 8 | V |  |
| $V_{\text {ILI }}$ | Input Low Voltage (RESET, X1, X2) | -. 5 |  | 6 | V |  |
| $V_{1 H}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{R E S E T}$ ) | 2.2 |  | $\mathrm{v}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H}_{1}}$ | Input High Voltage ( $\mathrm{X} 1, \mathrm{X} 2, \overline{\mathrm{RESET}}$ ) | 3.8 |  | VCC | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage (BUS) |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE}$ ) |  |  | . 45 | v | $\mathrm{I}_{\mathrm{OL}}=1.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage (PROG) |  |  | 45 | V | $\mathrm{I}_{\mathrm{OL}}=0.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 3}$ | Output Low Voltage <br> (All Other Outputs) |  |  | . 45 | v | $\mathrm{I}_{\mathrm{OL}}=1.2 \mathrm{~mA}$ |
| VOH | Output High Voltage (BUS) | 2.4 |  |  | v | $\mathrm{I}^{\prime} \mathrm{OH}=-280 \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 | ${ }^{\prime} \mathrm{OH}=-80 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | v | $\mathrm{I}^{\text {OH }}=-30 \mu \mathrm{~A}$ |
| ${ }_{\text {LL1 }}$ | Input Leakage Current ( $\mathrm{T} 1, \overline{\mathrm{INT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $V_{S S} \leqslant V_{I N} \leqslant V_{C C}$ |
| 'LII | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{S S}$ ) |  |  | -600 | $\mu \mathrm{A}$ | $\mathrm{V}_{S S}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| 'LO | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{S S}+.45 \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| IDD | $\vee_{\text {DD }}$ Supply Current |  | 6 | 12 | mA |  |
| $\begin{aligned} & \text { IOD } \\ & \text { ICC } \end{aligned}$ | Total Supply Current |  | 5 | 95 | mA |  |
| $V_{\text {DD }}$ | RAM Standby Pin Voltage | 3.0 |  |  | V | Reset $\leqslant 0.6 \mathrm{~V}$ |

( 50 mA
A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $85^{\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 | $f(t c y)$ <br> (Note 3) | 8 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| $\mathrm{t}_{\mathrm{LL}}$ | ALE Pulse Width | 7/30 ${ }^{\text {t }} \mathrm{CY}-170$ | 270 |  | ns |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | 1/5 t $\mathrm{CY}-110$ | 270 |  | ns |  |
| ${ }^{\text {L L }}$ A | Addr Hold from ALE | ${ }^{1 / 15}{ }^{\text {t }} \mathrm{CY}-40$ | 90 |  | ns |  |
| ${ }^{t} \mathrm{CC} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 ${ }^{\mathrm{t}} \mathrm{CY}-200$ | 740 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\mathrm{PSEN}}$ ) | 2/5 ${ }^{\text {t }} \mathrm{CY}$-200 | 550 |  | ns |  |
| tow | Data Setup before $\overline{W R}$ | 13/30 t CY -200 | 620 |  | ns |  |
| twD | Data Hold after $\overline{W R}$ | 1/15 tcy -50 | 80 |  | ns | (Note 2) |
| ${ }^{t} \mathrm{DR}$ | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-30}$ | 0 | 160 | ns |  |
| $t_{\text {RD1 }}$ | $\overline{\mathrm{RD}}$ to Data in | $2 / 5{ }^{\text {t }} \mathrm{CY}-200$ |  | 550 | ns |  |
| $\mathrm{t}_{\text {RD2 }}$ | $\overline{\text { PSEN }}$ to Data in | $3 / 10{ }^{\text {t }} \mathrm{CY}-200$ |  | 360 | ns |  |
| ${ }^{\text {t }}$ AW | Addr Setup to $\overline{W R}$ | ${ }^{2 / 5}{ }^{\text {t }} \mathrm{CY}^{-150}$ | 600 |  | ns |  |
| ${ }^{\text {t }}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | 23/30 t ${ }_{\text {CY }}-250$ |  | 1190 | ns |  |
| ${ }^{t}$ AD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5 \mathrm{t}^{\text {CY }}{ }^{-250}$ |  | 870 | ns |  |
| ${ }^{\text {t } A F C 1}$ | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | ${ }^{2 / 15}{ }^{\text {t }} \mathrm{CY}^{-40}$ | 210 |  | ns |  |
| ${ }^{t} A F C 2$ | Addr Float to PSEN | $1 / 30{ }^{\text {t }} \mathrm{CY}^{-40}$ | 20 |  | ns |  |
| ${ }^{\text {L LAFC1 }}$ | ALE to Control, ( $\overline{\mathrm{RD}} ; \overline{\mathrm{WR}}$ ) | $1 / 5 \mathrm{t}^{\text {CY }}{ }^{-75}$ | 300 |  | ns |  |
| ${ }^{\text {L LAFC2 }}$ | ALE to Control ( $\overline{\text { PSEN }}$ ) | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-75}$ | 120 |  | ns |  |
| ${ }^{\text {t }}$ CA1 | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15{ }^{\text {t }} \mathrm{CY}^{-40}$ | 90 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CA} 2$ | Control to ALE ( $\overline{\mathrm{PSEN}}$ ) | ${ }^{4 / 15}{ }^{\text {t }} \mathrm{CY}^{-40}$ | 460 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CP}$ | Port Control Setup to $\overline{\text { PROG }}$ | 2/15 tcy -80 | 170 |  | ns |  |
| ${ }^{\text {t PC }}$ | Port Control Hold to $\overline{\text { PROG }}$ | $4 / 15 \mathrm{t}^{\text {CY }}{ }^{-200}$ | 300 |  | ns |  |
| ${ }^{\text {t PR }}$. | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy -120 |  | 1010 | ns |  |
| ${ }^{\text {t PF }}$ | Input Data Hold from $\overline{\text { PROG }}$ | $1 / 10{ }^{\text {t }} \mathrm{CY}$ | 0 | 190 | ns |  |
| ${ }^{\text {t }} \mathrm{DP}$ | Output Data Setup | ${ }^{2 / 5}{ }^{\text {t }} \mathrm{CY}^{-150}$ | 600 |  | ns |  |
| ${ }^{\text {t PD }}$ | Output Data Hold | ${ }^{1 / 10}{ }^{\text {t }} \mathrm{CY}^{-50}$ | 140 |  | ns |  |
| ${ }^{\text {t PPP }}$ | PROG Pulse Width | ${ }^{7 / 10}{ }^{\text {t }} \mathrm{CY}^{-250}$ | 1070 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | ${ }^{4 / 15}{ }^{\text {t }} \mathrm{CY}^{-200}$ | 300 |  | ns |  |
| ${ }^{\text {L }}$ LP | Port $2 \mathrm{I} / \mathrm{O}$ Hold to ALE | $1 / 10{ }^{\text {t }} \mathrm{CY}^{-100}$ | 90 |  | ns |  |
| ${ }^{\text {t PV }}$ | Port Output from ALE | $3 / 10 \mathrm{t}_{\mathrm{CY}}+100$ | 670 |  | ns |  |
| ${ }^{t} \mathrm{C} Y$ | Cycle Time | 1/( $\mathrm{fXTAL} \times 15$ ) | 1.88 | 15 | $\mu \mathrm{s}$ | (Note 4) |
| toprR | T0 Rep Rate | $3 / 15{ }^{\mathrm{t}} \mathrm{CY}$ | 380 |  | ns |  |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF}$ BUS Outputs CL $=150 \mathrm{pF}$
2. BUS High Impedance Load 20pf
3. Interrupt pin must remain low for at least $3 \mathrm{t}_{\mathrm{cy}}$ to ensure proper operation.
4. Calculated values will be equal to or better than published 18048 H values. $f\left(\mathrm{t}_{\mathrm{cy}}\right)$ assumes $50 \%$ duty cycle on $\mathrm{X} 1, \mathrm{X} 2$.

# 18049H/I8039HL NEW HIGH PERFORMANCE SINGLE COMPONENT 8-BIT MICROCOMPUTER 

INDUSTRIAL

- I8049H Mask Programmable ROM
- I8039H Requires External ROM or EPROM
- 11 MHz Operation

\author{

- 8-Bit CPU, ROM, RAM, I/O in Single Package <br> Single 5V $\pm$ 10\% Supply <br> $1.36 \mu \mathrm{sec}$ Cycle; All instructions 1 or 2 Cycles <br> Over 90 Instructions: 70\% Single Byte <br> ■ Pin Compatible with 8048/8748 <br> - $2 \mathrm{~K} \times 8$ ROM <br> $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 <br> - $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ Operation
}


#### Abstract

The Intel 18049 H is a totally self-sufficient 8 -bit parallel computer fabricated on a single silicon chip using Intel's advanced N -channel silicon gate HMOS process. The 18049 H contains a $2 \mathrm{~K} \times 8$ program memory, a $128 \times 8$ RAM data memory, $27 \mathrm{I} / \mathrm{O}$ lines, and an 8-bit timer/counter in addition to on-board oscillator and clock circuits. For systems that require extra capability, the I8049H can be expanded using standard memories and MCS-80®/MCS-85® peripherals. The 18039 HL is the equivalent to an 18049 H without program memory. To reduce development problems to a minimum and provide maximum flexibility, two interchangeable pincompatible versions of this single component microcomputer exist: the 18049 H with factory-programmed mask ROM program memory for low-cost high volume production, and the 18039 HL 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 18049 H 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.




[^35]
## 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.5 Watt
*NOTICE: 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 device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## D.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $85^{\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 <br> (All Except RESET, X1, X2) | -. 5 |  | . 8 | v |  |
| VIL1 | Input Low Voltage ( $\overline{\text { RESET }}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 6 | V |  |
| $V_{1 H}$ | Input High Voltage <br> (All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.2 |  | $\mathrm{v}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage ( $\mathrm{X} 1, \mathrm{X} 2, \overline{\mathrm{RESET}}$ ) | 3.8 |  | $\mathrm{v}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage (BUS) |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OL} 1}$ | Output Low Voltage ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PSEN}}, \mathrm{ALE})$ |  |  | . 45 | V | $\mathrm{I}^{\mathrm{OL}}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage (PROG) |  |  | . 45 | V | ${ }^{\mathrm{O}} \mathrm{OL}=.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL3 }}$ | Output Low Voltage <br> (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=1.2 \mathrm{~mA}$ |
| VOH | Output High Voltage (BUS) | 2.4 |  |  | V | $\mathrm{I}^{\mathrm{OH}}=-280 \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}}=-80 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage <br> (All Other Outputs) | 2.4 |  |  | V | ${ }^{\mathrm{O}} \mathrm{OH}=-30 \mu \mathrm{~A}$ |
| ${ }^{\text {LL1 }}$ | Input Leakage Current (T1, $\overline{\mathrm{INT}}$ ) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ${ }^{\text {L LII }}$ | Input Leakage Current (P10-P17, P20-P27, EA, $\overline{S S}$ ) |  |  | -600 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| ${ }^{\text {L }}$ O | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}}+.45 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IDD | $V_{\text {DD }}$ Supply Current |  | 10 | 20 | mA |  |
| $\left\lvert\, \begin{aligned} & 1 \mathrm{DD}+ \\ & \mathrm{I} \mathrm{CD} \end{aligned}\right.$ | Total Supply Current |  | 75 | 145 | mA |  |





I8049H/I8039HL
A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{C C}=\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{S S}=0 \mathrm{~V}$ )

| Symbol | Parameter | f(tcy) <br> (Note 3) | 11 MHz |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max |  |  |
| $t_{\text {LL }}$ | ALE Pulse Width | 7/30 t CY -170 | 150 |  | ns |  |
| ${ }^{\text {t }}$ AL | Addr Setup to ALE | $1 / 5 \mathrm{t}_{\mathrm{C}} \mathrm{C}-110$ | 160 |  | ns |  |
| ${ }^{\text {L LA }}$ | Addr Hold from ALE | $1 / 15 \mathrm{t}^{\text {CY }}-40$ | 50 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CC} 1$ | Control Pulse Width ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | 1/2 t ${ }^{\text {c }}$ CY-200 | 480 |  | ns |  |
| ${ }^{\mathrm{t}} \mathrm{CC} 2$ | Control Pulse Width ( $\overline{\text { PSEN }}$ ) | 2/5 ${ }^{\text {t }}$ CY ${ }^{-200}$ | 350 |  | ns |  |
| ${ }^{\text {t }}$ DW | Data Setup before $\overline{W R}$ | $13 / 30 \mathrm{t}_{\text {CY }}-200$ | 390 |  | ns |  |
| ${ }^{\text {t }}$ WD | Data Hold after $\overline{W R}$ | 1/15 ter -50 | 40 |  | ns | (Note 2) |
| ${ }^{t}$ DR | Data Hold ( $\overline{\mathrm{RD}}, \overline{\mathrm{PSEN}}$ ) | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-30}$ | 0 | 110 | ns |  |
| ${ }^{\text {t RD1 }}$ | $\overline{R D}$ to Data in | $2 / 5 \mathrm{t}^{\text {CY }}$-200 |  | 350 | ns |  |
| $\mathrm{t}_{\text {RD2 }}$ | $\overline{\text { PSEN }}$ to Data in | $3 / 10 \mathrm{t}_{\mathrm{CY}}-200$ |  | 210 | ns |  |
| ${ }^{t}$ AW | Addr Setup to $\overline{W R}$ | $2 / 5 \mathrm{t}^{\text {CY }}{ }^{-150}$ | 400 |  | ns |  |
| ${ }^{t}$ AD1 | Addr Setup to Data ( $\overline{\mathrm{RD}}$ ) | $23 / 30{ }^{\text {t }}$ CY -250 |  | 800 | ns |  |
| ${ }^{\text {t }}$ AD2 | Addr Setup to Data ( $\overline{\text { PSEN }}$ ) | $3 / 5{ }^{\text {t }} \mathrm{CY}^{-250}$ |  | 570 | ns |  |
| ${ }^{\text {t }}{ }^{\text {AFC1 }}$ | Addr Float to $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ | $2 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 140 |  | ns |  |
| ${ }^{t} A F C 2$ | Addr Float to $\overline{\text { PSEN }}$ | $1 / 30 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 10 |  | ns |  |
| ${ }^{\text {L LAFC1 }}$ | ALE to Control, ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ ) | $1 / 5 \mathrm{t}^{\text {C }}{ }^{-75}$ | 200 |  | ns |  |
| ${ }^{\text {L LAFC2 }}$ | ALE to Control ( $\overline{\mathrm{PSEN}}$ ) | $1 / 10 \mathrm{t}_{\mathrm{CY}}{ }^{-75}$ | 60 |  | ns |  |
| ${ }^{\text {t }}$ CA1 | Control to ALE ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PROG}}$ ) | $1 / 15 \mathrm{t}_{\mathrm{CY}}{ }^{-40}$ | 50 |  | ns |  |
| ${ }^{\text {t }}$ CA2 | Control to ALE ( $\overline{\mathrm{PSEN}}$ ) | $4 / 15 \mathrm{t}^{\text {CY }}{ }^{-40}$ | 320 |  | ns |  |
| ${ }^{t} \mathrm{CP}$ | Port Control Setup to $\overline{\mathrm{PROG}}$ | 2/15 ter -80 | 100 |  | ns |  |
| ${ }^{\text {P PC }}$ | Port Control Hold to $\overline{\text { PROG }}$ | $4 / 15 \mathrm{t}^{\text {CY }}{ }^{-200}$ | 160 |  | ns |  |
| ${ }^{\text {P PR }}$ | $\overline{\text { PROG }}$ to P2 Input Valid | 6/10 tcy -120 |  | 700 | ns |  |
| ${ }^{\text {t PF }}$ | Input Data Hold from $\overline{\text { PROG }}$ | ${ }^{1 / 10}{ }^{\text {t }} \mathrm{CY}$ | 0 | 140 | ns |  |
| ${ }^{t} \mathrm{DP}$ | Output Data Setup | ${ }^{2 / 5}{ }^{\text {t }} \mathrm{CY}^{-150}$ | 400 |  | ns |  |
| ${ }^{\text {t PD }}$ | Output Data Hold | ${ }^{1 / 10}{ }^{\text {t }} \mathrm{CY}^{-50}$ | 90 |  | ns |  |
| ${ }^{t} \mathrm{PP}$ | PROG Pulse Width | $7 / 10 \mathrm{t}^{\mathrm{CY}}$-250 | 700 |  | ns |  |
| tPL | Port 2 I/O Setup to ALE | $4 / 15 \mathrm{t}^{\text {CY }}{ }^{-200}$ | 160 |  | ns |  |
| $t_{L P}$ | Port $2 \mathrm{I} / \mathrm{O}$ Hold to ALE | ${ }^{1 / 10} \mathrm{t}_{\mathrm{CY}}{ }^{-100}$ | 40 |  | ns |  |
| ${ }^{\text {t PV }}$ | Port Output from ALE | ${ }^{3 / 10}{ }^{\text {t }} \mathrm{CY}^{+100}$ |  | 510 | ns |  |
| ${ }^{t} \mathrm{CY}$ | Cycle Time | ${ }^{1 /(f}$ XTAL $\left.\times 15\right)$ | 1.36 |  | $\mu \mathrm{s}$ | (Note 4) |
| topRR | TO Rep Rate | ${ }^{3 / 15}{ }^{\mathrm{t}} \mathrm{CY}$ | 270 |  | ns |  |

## Notes:

1. Control Outputs $\mathrm{CL}=80 \mathrm{pF}$
2. BUS High Impedance Load 20 pF BUS Outputs CL $=150 \mathrm{pF}$
3. Ċalculated values will be equal to or better than published 18049 H values. $\mathrm{f}\left(\mathrm{t}_{\mathrm{cy}}\right)$ assumes $50 \%$ duty cycle on X1, X2.
4. Interrupt pin must remain low for at least $3 \mathrm{t}_{\mathrm{cy}}$ to ensure proper operation.

## I8085AH <br> SINGLE CHIP 8-BIT HMOS MICROPROCESSOR

INDUSTRIAL

- Industrial Temperature Range: -40 to $+85^{\circ} \mathrm{C}$
- Single +5 V Power Supply with $\mathbf{1 0 \%}$ Voltage Margins
- 100\% Software Compatible with 8080A
- $1.3 \mu$ 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 ${ }^{\circledR}$ I8085AH 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 ICs [8085AH (CPU), 8156H (RAM I/O), and 8355/8755A (ROM/PROM/I/O)] while maintaining total system expandability.
The I8085AH 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 I8085AH 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 \mathrm{H} / 8156 \mathrm{H} / 8355 / 8755 \mathrm{~A}$ memory products allow a direct interface with the I8085AH.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots . . .-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.3 to +7 V
Power Dissipation .................................. 1.5 Watt
*NOTICE: 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 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}=-40^{\circ} \mathrm{C}\right.$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$; unless otherwise specified)

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.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}_{\text {in }}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\text {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}_{\text {IHR }}$ | Input High Level, RESET | 2.4 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{HY}}$ | Hysteresis, RESET | 0.25 |  | V |  |

## NOTE:

1. The I8085AH will operate as a $8085 \mathrm{AH}-2$ from $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$.

Table 2. Bus Timing Specification as a $\mathbf{T}_{\mathrm{CYC}}$ Dependent

| $t_{\text {AL }}$ | - | $(1 / 2) \mathrm{T}-50$ | MIN |
| :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{LA}}$ | - | $(1 / 2) \mathrm{T}-60$ | MIN |
| $\mathrm{t}_{\mathrm{LL}}$ | - | $(1 / 2) \mathrm{T}-40$ | MIN |
| $\mathrm{t}_{\mathrm{LCK}}$ | - | $(1 / 2) \mathrm{T}-60$ | MIN |
| $\mathrm{t}_{\mathrm{LC}}$ | - | $(1 / 2) \mathrm{T}-30$ | MIN |
| $\mathrm{t}_{\mathrm{AD}}$ | - | $(5 / 2+\mathrm{N}) \mathrm{T}-225$ | MAX |
| $\mathrm{t}_{\mathrm{RD}}$ | - | $(3 / 2+\mathrm{N}) \mathrm{T}-200$ | MAX |
| $\mathrm{t}_{\mathrm{RAE}}$ | - | $(1 / 2) \mathrm{T}-60$ | MIN |
| $\mathrm{t}_{\mathrm{CA}}$ | - | $(1 / 2) \mathrm{T}-40$ | MIN |
| $\mathrm{t}_{\mathrm{DW}}$ | - | $(3 / 2+\mathrm{N}) \mathrm{T}-60$ | MIN |

NOTE:
N is equal to the total WAIT states.
$T=\mathrm{t}_{\mathrm{Cr}}$.

| ${ }^{\text {two }}$ | - | (1/2) T-80 | MIN |
| :---: | :---: | :---: | :---: |
| ${ }^{\text {t }} \mathrm{CC}$ | - | $(3 / 2+N) T-80$ | MIN |
| ${ }^{\mathrm{t}} \mathrm{CL}$ | - | (1/2) T-110 | MIN |
| $\mathrm{t}_{\text {ARY }}$ | - | (3/2) T-260 | MAX |
| ${ }^{\text {t }}$ HACK | - | (1/2) T-50 | MIN |
| ${ }^{\text {t }}$ HABF | - | $(1 / 2) T+30$ | MAX |
| ${ }^{\text {thabe }}$ | - | (1/2) T+30 | MAX |
| ${ }^{t} A C$ | - | (2/2) T-50 | MIN |
| $\mathrm{t}_{1}$ | - | (1/2) T-80 | MIN |
| $\mathrm{t}_{2}$ | - | (1/2) T-40 | MIN |
| ${ }^{\text {t }}$ RV | - | (3/2) T-80 | MIN |
| ${ }^{\text {t }}$ INS | - | (1/2) T + 200 | MIN |

A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{CYC}}$ | CLK Cycle Period | 320 | 2000 | ns | See Notes 1, 2, 3, 4, 5 |
| $\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 |  |
| ${ }^{t}{ }_{\text {AL }}$ | Address (A8-A15) Valid Before Trailing Edge of ALE ${ }^{(1)}$ | 110 |  | ns |  |
| $t_{\text {ALL }}$ | Address (A0-A7) Valid Before Trailing Edge of ALE | 90 |  | ns |  |
| ${ }^{\text {t }}$ LA | Address Hold Time After ALE | 100 |  | ns |  |
| $\mathrm{t}_{\text {LL }}$ | ALE Width | 140 |  | ns |  |
| $\mathrm{t}_{\text {LCK }}$ | ALE Low During CLK High | 100 |  | ns |  |
| ${ }^{\text {L }}$ LC | Trailing Edge of ALE to Leading Edge of Control | 130 |  | ns |  |
| ${ }^{\text {t }}$ AFR | Address Float After Leading Edge of $\overline{\text { READ }}$ (INTA) |  | 0 | ns |  |
| ${ }^{\text {t }}$ AD | Valid Address to Valid Data In |  | 575 | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | $\overline{\text { READ }}$ (or $\overline{\text { INTA }}$ ) to Valid Data |  | 300 | ns |  |
| $\mathrm{t}_{\text {RDH }}$ | Data Hold Time After $\overline{\text { READ ( }} \overline{\text { INTA }}$ ) | 0 |  | ns |  |
| $t_{\text {RAE }}$ | Trailing Edge of $\overline{\text { READ }}$ to Re-Enabling of Address | 150 |  | ns | $\begin{aligned} & T_{\mathrm{CYC}}=320 \mathrm{~ns} ; \\ & \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF} \end{aligned}$ |
| ${ }^{t} \mathrm{CA}$ | Address (A8-A15) Valid After Control | 120 |  | ns |  |
| ${ }^{\text {d }}$ D ${ }_{\text {W }}$ | Data Valid to Trailing Edge of WRITE | 420 |  | ns |  |
| ${ }_{\text {tw }}$ | Data Valid After Trailing Edge of WRITE | 100 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CC}$ | Width of Control Low ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { INTA }}$ ) | 400 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CL}$ | Trailing Edge of Control to Leading Edge of ALE | 50 |  | ns |  |
| ${ }^{t}$ ARY | READY Valid From Address Valid |  | 220 | ns |  |
| $\mathrm{t}_{\text {RYS }}$ | READY Setup Time to Leading Edge of CLK | 110 |  | ns |  |
| $t_{\text {RYH }}$ | READY Hold Time | 0 |  | ns |  |
| ${ }^{\text {H HACK }}$ | HLDA Valid to Trailing Edge of CLK | 110 |  | ns |  |
| ${ }^{t_{\text {HABF }}}$ | Bus Float After HLDA |  | 210 | ns |  |
| $\mathrm{t}_{\text {RV }}$ | Control Trailing Edge to Leading Edge of Next Control | 400 |  | ns |  |
| ${ }^{t}{ }_{\text {AC }}$ | Address Valid to Leading Edge of Control | 270 |  | ns |  |
| ${ }^{\text {t }}$ HDS | HOLD Setup Time to Trailing Edge of CLK | 170 |  | ns |  |
| $\mathrm{t}_{\mathrm{HDH}}$ | HOLD Hold Time | 0 |  | ns |  |
| $\mathrm{t}_{\text {INS }}$ | INTR Setup Time to Leading Edge of CLK (M1, T1 only). Also RST and TRAP | 360 |  | ns |  |
| ${ }^{\text {t }}$ INH | INTR Hold Time | 0 |  | ns |  |

## NOTES:

1. A8-15 address specs apply to $1 O / M$, SO and $S 1$. A8-15 are undefined during $t_{4}-t_{6}$ of $O F$ cycle whereas $1 O / \bar{M} S_{0}$ and $S_{1}$ are stable.
2. For all output timing where $C_{L}=150$ pf use the following correction factors:25pf $\leqslant C_{L}<150 \mathrm{pf}:-.10 \mathrm{~ns} / \mathrm{pf} ; 150 \mathrm{pf}<\mathrm{C}_{\mathrm{L}} \leqslant 300 \mathrm{pf}$ : $+.30 \mathrm{~ns} / \mathrm{pf}$.
3. Output timings are measured with purely capacitive load.
4. All timings are measured at output voltage $\mathrm{V}_{\mathrm{L}}=.8 \mathrm{~V}, \mathrm{~V}_{\mathrm{H}}=2.0 \mathrm{~V}$, and 1.5 V with 20 ns rise and fall time on inputs.
5. All timings are measured at input voltage $\mathrm{V}_{1 \mathrm{~L}}=.45 \mathrm{~V}, \mathrm{~V}_{1 \mathrm{H}}=2.4 \mathrm{~V}$.
6. To calculate timing specifications at other values of $T_{C Y C}$ use the table in Table 2.
7. L.E. = leading edge; T.E. = trailing edge.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT

$C_{L}=150 \mathrm{pF}$
$\mathrm{C}_{\mathrm{L}}$ INCLUDES JIG CAPACITANCE

# INDUSTRIAL iAPX 86/10 16-BIT HMOS MICROPROCESSOR <br> INDUSTRIAL 

- Direct Addressing Capability to 1 MByte of Memory
- Assembly Language Compatible with 8080/8085
- 14 Word, by 16-Bit Register Set with Symmetrical Operations
- 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

- MULTIBUS ${ }^{\text {TM }}$ System Compatible Interface
- Industrial Temperature Range: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ Industrial iAPX 86/10 is a new generation, high performance 16-bit 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.



Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias $\ldots-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
$\quad$ Respect to Ground......................... 1.0 to +7 V
Power Dissipation .......................... Watt
*NOTICE: 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 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(\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {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}$ |
| $\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 iAPX 86 |  | 340 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $I_{L I}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV}<\mathrm{V}_{\text {IN }}<\mathrm{V}_{\mathrm{CC}}$ |
| Lo | 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}, \overline{\operatorname{RQ}} / \overline{G T}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{10}$ | Capacitance of I/O Buffer $\left(A D_{0}-A D_{15}, \overline{R Q} / \overline{G T}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

INDUSTRIAL iAPX 86

## A.C. CHARACTERISTICS $\quad\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

## MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| Symbol | Parameter | IAPX 86 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period - 8086 | 200 | 500 | ns |  |
| TCLCH | CLK Low Time | (2/3 TCLCL)-15 |  | ns |  |
| TCHCL | CLK High Time | (1/3 TCLCL) +2 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 | ns | From 1.0V to 35.V |
| TCL2CL1 | CLK Fall Time |  | 10 | ns | From 3.5 V to 1.0 V |
| TDVCL | Data in Setup Time | 30 |  | ns |  |
| TCLDX | 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/3 TCLCL)-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, TEST Setup Time (See Note 2) | 30 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time (Except CLK) |  | 12 | ns | From 2.0 V to 0.8 V |

TIMING RESPONSES

| Symbol | Parameter | IAPX 86 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| TCLAV | Address Vaiid Delay | 10 | 110 | ns | $C_{L}=20-100 \mathrm{pF}$ for all 8086 Outputs (In addition to 8086 self-load) |
| 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 |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | ns |  |
| TCHDX | Data Hold Time | 10 |  | ns |  |
| TWHDX | Data Hold Time After WR | TCLCH-30 |  | ns |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 110 | ns |  |
| TCVCTX | Control Inactive Delay | 10 | 110 | ns |  |
| TAZRL | Address Float to READ Active | 0 |  | ns |  |
| TCLRL | $\overline{\mathrm{R}}$ Active Delay | 10 | 165 | ns |  |
| TCLRH | $\overline{\mathrm{RD}}$ Inactive Delay | 10 | 150 | ns |  |
| TRHAV | $\overline{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-45 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | ns |  |
| TRLRH | $\overline{\text { RD }}$ Width | 2TCLCL-75 |  | ns |  |
| TWLWH | $\overline{\text { WR Width }}$ | 2TCLCL-60 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-60 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## 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 ( 8 ns into T 3 ).

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS

## BUS TIMING - MINIMUM MODE SYSTEM



WAVEFORMS (Continued)
bUS TIMING - MINIMUM MODE SYSTEM (Continued)


## NOTES:

1. All signals switch between $V_{O H}$ and $V_{O L}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Two INTA cycles run back-to-back. The 8086 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control signals shown for second INTA cycle.
4. Signals at 8284A are shown for reference only.
5. All timing measurements are made at 1.5 V unless otherwise noted.

## A.C. CHARACTERISTICS

MAX MODE SYSTEM (USING 8288 BUS CONTROLLER) TIMING REQUIREMENTS

| Symbol | Parameter | $\mathbf{8 0 8 6 / 8 0 8 6 - 4}$ |  | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| TCLCL | CLK Cycle Period -8086 | 200 | 500 | ns |  |
| TCLCH | CLK Low Time | 118 |  | ns |  |
| TCHCL | CLK High Time | 69 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 | ns | From 1.0V to 3.5V |
| TCL2CL1 | CLK Fall Time |  | 10 | ns | From 3.5V to 1.0V |
| TDVCL | Data in Setup Time | 30 |  | ns |  |
| TCLDX | Data in Hoid 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 | 118 |  | ns |  |
| TCHRYX | Ready Hold Time into 8086 | 30 |  | ns |  |
| TRYLCL | READY Inactive to CLK (See Note 4) | -8 |  | ns |  |
| TINVCH | Setup Time for Recognition <br> (INTR, NMI, TEST) (See Note 2) | 30 |  | ns |  |
| TGVCH | RQ/GT Setup Time | 30 |  | ns |  |
| TCHGX | RQ Hold Time into 8086 | 40 |  | ns |  |

TIMING RESPONSES

| Symbol | Parameter | 8086/8086-4 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | ns | $C_{L}=20-100 \mathrm{pF}$ for all 8086 Outputs (In addition to 8086 self-load) |
| 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 | 10 | 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 | 10 | 110 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 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 |  |

INDUSTRIAL iAPX 86

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | $\mathbf{8 0 8 6 / 8 0 8 6 - 4}$ |  | Units | rest Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| 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 | GT Active Delay | 0 | 85 | ns |  |
| TCLGH | GT Inactive Delay | 0 | 85 | ns |  |
| TRLRH | RD Width | $2 T C L C L-75$ |  | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8V to 2.0V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0V to 0.8V |

## 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 T 2 state ( 8 ns into T 3 ).

WAVEFORMS


WAVEFORMS (Continued)


## NOTES:

1. All signals switch between $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Cascade address is valid between first and second INTA cycle.
4. Two INTA cycles run back-to-back. The 8086 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control for pointer address is shown for second INTA cycle.
5. Signals at 8284 A or 8288 are shown for reference only.
6. The issuance of the 8288 command and control signals ( $\overline{M R D C}, \overline{M W T C}, \overline{A M W C}, \overline{I O R C}, \overline{I O W C}, \overline{A I O W C}, \overline{I N T A}$ and DEN) lags the active high 8288 CEN.
7. All timing measurements are made at 1.5 V unless otherwise noted.
8. Status inactive in state just prior to $\mathrm{T}_{4}$.

WAVEFORMS (Continued)

## ASYNCHRONOUS SIGNAL RECOGNITION



NOTE: 1 SETUP REQUIREMENTS FOR ASYNCHRONOUS SIGNALS ONLY TO GUARANTEE RECOGNITION AT NEXT CLK

BUS LOCK SIGNAL TIMING (MAXIMUM MODE ONLY)


RESET TIMING


## REQUEST/GRANT SEQUENCE TIMING (MAXIMUM MODE ONLY)



NOTES: 1. THE COPROCESSOR MAY NOT DRIVE THE BUSES OUTSIDE THE REGION SHOWN WITHOUT RISKING CONTENTION.

HOLD/HOLD ACKNOWLEDGE TIMING (MINIMUM MODE ONLY)


# 18155H/8156H <br> 2048-BIT STATIC HMOS RAM WITH I/O PORTS AND TIMER INDUSTRIAL 

- Industrial Temperature Range:
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
- 256 Word x 8 Bits
- Single +5 V Power Supply with $10 \%$ Voltage Margins
- 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 18155 H and 18156 H are RAM and $\mathrm{I} / \mathrm{O}$ chips to be used in the MCS $-85^{\circledR}$ 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 8085AH 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.

*: $8155=\overline{C E}, 8156=C E$

Figure 1. Block Diagram

Figure 2. Pin Configuration


## ABSOLUTE MAXIMUM RATINGS*

| 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 +7V |
| Power Dissipation | 1.5 |

*NOTICE: 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}=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Min. | Max | Units | Test Condtions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $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}_{\text {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{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| Icc | VCC Supply Current |  | 180 | mA |  |
| IIL (CE) | Chip Enable Leakage $\begin{aligned} & 8155 \\ & 8156 \end{aligned}$ |  | $\begin{aligned} & +100 \\ & -100 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\mathrm{OV} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |

## A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | 8155/8156 |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{AL}}$ | Address to Latch Set Up Time | 50 |  | ns |
| $\mathrm{t}_{\text {LA }}$ | Address Hold Time after Latch | 80 |  | ns |
| ${ }_{t} \mathrm{LC}$ | Latch to READ/WRITE Control | 100 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}$ | Valid Data Out Delay from READ Control |  | 170 | ns |
| ${ }^{\text {t }}$ AD | Address Stable to Data Out Valid |  | 400 | ns |
| $\mathrm{t}_{\text {LL }}$ | Latch Enable Width | 100 |  | ns |
| $\mathrm{t}_{\text {RDF }}$ | Data Bus Float after READ | 0 | 100 | ns |
| ${ }^{\text {t }}$ L | READ/WRITE Control to Latch Eanble | 20 |  | ns |
| ${ }^{\text {t }} \mathrm{CC}$ | READ/WRITE Control Width | 250 |  | ns |
| ${ }^{\text {t }}$ W | Data In to WRITE Set Up Time | 150 |  | ns |
| $t_{\text {WD }}$ | Data In Hold Time after WRITE | 25 |  | ns |
| $t_{\text {RV }}$ | Recovery Time Between Controls | 300 |  | ns |
| $t_{\text {WP }}$ | WRITE to Port Output |  | 400 | ns |
| $t_{\text {PR }}$ | Port Input Set Up Time |  |  | ns |
| $\mathrm{t}_{\mathrm{RP}}$ | Port Input Hold Time | 50 |  | ns |
| ${ }_{\text {t }}^{\text {SBF }}$ | Strobe to Buffer Full |  | 400 | ns |
| $\mathrm{t}_{\text {SS }}$ | Strobe Width | 200 |  | ns |
| $t_{\text {RBE }}$ | READ to Buffer Empty |  | 400 | ns |

A.C. CHARACTERISTICS (Continued) $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | 8155/8156 |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| ${ }^{\text {t }}$ S | Strobe to INTR On |  | 400 | ns |
| $t_{\text {RDI }}$ | READ to INTR Off |  | 400 | ns |
| $\mathrm{t}_{\text {PSS }}$ | Port Set Up Time to Strobe | 50 |  | ns |
| $t_{\text {PHS }}$ | Port Hold Time after Strobe | 120 |  | ns |
| ${ }^{\text {t }}$ SBE | Strobe to Buffer Empty |  | 400 | ns |
| $t_{\text {WBF }}$ | WRITE to Buffer Full |  | 400 | ns |
| ${ }^{t}$ WI | WRITE to INTR Off |  | 400 | ns |
| ${ }_{\text {t }}{ }_{\text {L }}$ | TIMER-IN to TIMER-OUT Low |  | 400 | ns |
| ${ }_{\text {t }}^{\text {TH }}$ | TIMER-IN to TIMER-OUT High |  | 400 | ns |
| $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 |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT

## 18185* $1024 \times 8$-BIT STATIC RAM FOR MCS-85 ${ }^{\circledR}$ <br> *Compatible with 8085A. INDUSTRIAL

## Multiplexed Address and Data Bus

- Directly Compatible with 8085A and 8088 Microprocessors

Low Operating Power Dissipation

■ Low Standby Power Dissipation

■ Single +5V Supply

■ High Density 18-Pin Package
© Industrial Temperature Range: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ I8185 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 and 8088 microprocessors to provide a maximum level of system integration.

The low standby power dissipation minimizes system power requirements when the 8185 is disabled.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## FUNCTIONAL 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 8 bit address on $A D_{0-7}, A_{8}$ and $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{\mathrm{WR}}$ 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{\mathrm{CE}}_{1}$ and $\mathrm{CE}_{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 IO/M line to the 8185's $\overline{C 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{\mathbf{C E}}_{\mathbf{1}}$ | $\mathbf{C E}_{\mathbf{2}}$ | $\overline{\mathbf{C S}}$ | $\left.\mathbf{( C S}^{\star}\right)^{[2]}$ | $\mathbf{8 1 8 5 \text { Status }}$ |
| :---: | :---: | :---: | :---: | :--- |
| 1 | X | X | 0 | Power Down and <br> Function Disable $[1]$ |
| X | 0 | X | 0 | Power Down and <br> Function Disable $[1]$ |
| 0 | 1 | 1 | 0 | Powered Up and <br> Function Disable $[1]$ |
| 0 | 1 | 0 | 1 | Powered Up and <br> 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(\mathrm{CE}_{2}=1\right) \cdot(\overline{\mathrm{CS}}=0)$
CS* $=1$ signifies all chip enables and chip select active

Table 2. Truth Table for Control and Data Bus Pin Status

| $\left.\mathbf{( C S}^{\star}\right)$ | $\overline{\mathbf{R D}}$ | $\overline{\mathbf{W R}}$ | $\mathbf{A D}_{\mathbf{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 3. 18185 in an MCS-85 ${ }^{\circledR}$ System

## 8088 FIVE CHIP SYSTEM

Figure 4 shows a five chip system containing:

- 1.25 K Bytes RAM
- 2 K Bytes ROM
- 38 I/O Pins
- 1 Interval Time
- 2 Interrupt Levels


Figure 4. 8088 Five Chip System Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias | +8 |
| :---: | :---: |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Voltage on Any Pin with Respect to Ground | $-0.5 \mathrm{~V} \text { to }+7 \mathrm{~V}$ |
| ower Dissipation | . 5 W |

*NOTICE: 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 condtions for extended periods may affect device reliability.

## D.C. CHARACTERISTICS <br> $\left(T_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}, V_{C C}=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}_{\text {IH }}$ | Input High Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\text {OL }}$ | Output Low Voltage | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA}$ |  |
| $\mathrm{~V}_{\text {OH }}$ | Output High Voltage | 2.4 |  |  | $\mathrm{IOH}_{\mathrm{OH}}=400 \mu \mathrm{~A}$ |
| $\mathrm{IIL}^{\text {ILO }}$ | Input Leakage | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ |
| $\mathrm{~V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ to 0 V |  |  |  |  |  |
| ILO |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leq \mathrm{V}_{\text {OUT }} \leq \mathrm{V}_{\text {CC }}$ |  |
| ICC | VCC Supply Current <br> Powered Up <br> Powered Down | 125 | mA |  |  |

## A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ )

| Symbol | Parameter ${ }^{[1]}$ | 8185Preliminary |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | ns |
| $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 |
| ${ }_{\text {LD }}$ | ALE to Data Out Valid |  | 300 | ns |
| $t_{\text {LL }}$ | Latch Enable Width | 100 |  | ns |
| $\mathrm{t}_{\text {RDF }}$ | Data Bus Float after READ | 0 | 100 | ns |
| ${ }_{t}{ }_{\text {cL }}$ | READ/WRITE Control to Latch Enable | 20 |  | ns |
| $\mathrm{t}_{\mathrm{CC}}$ | READ/WRITE Control Width | 250 |  | ns |
| $\mathrm{t}_{\text {DW }}$ | Data In to Write Set Up Time | 150 |  | ns |
| $t_{\text {WD }}$ | Data In Hold Time after WRITE | 20 |  | ns |
| $t_{\text {SC }}$ | Chip Select Set Up to Control Line | 10 |  | ns |
| $t_{\text {cs }}$ | Chip Select Hold Time after Control | 10 |  | ns |
| $t_{\text {ALCE }}$ | Chip Enable Set Up to ALE Falling | 30 |  | ns |
| $t_{\text {LACE }}$ | Chip Enable Hold Time after ALE | 50 |  | ns |

NOTES:

1. All A.C. parameters are referenced at
a) 2.4 V and .45 V for inputs
b) 2.0 V and .8 V for outputs.

## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT

## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS



18212
8-BIT INPUT/OUTPUT PORT
INDUSTRIAL

- Fully Parallel 8-Bit Data Register and Buffer
- Service Request Flip-Flop for Interrupt Generation

■ Low Input Load Current - .25mA Max

- Three State Outputs
- Outputs Sink 15 mA
3.65V Output High Voltage for Direct Interface to ID8085A CPU

Asynchronous Register Clear
Replaces Buffers, Latches and Multiplexers in Microcomputer Systems

Industrial Temperature Range:
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

The 18212 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.


Figure 1. Logic Diagram


| $D I_{1} \cdot D I_{8}$ | DATA IN |
| :--- | :--- |
| $D O_{1} \cdot D O_{8}$ | DATA OUY |
| $\overline{D S_{1}} \cdot D S_{2}$ | DEVICE SELECT |
| $M D$ | MODE |
| $S T B$ | STROBE |
| $\overline{I N T}$ | INTERRUPT (ACTIVE LOW) |
| $\overline{C L A}$ | CLEAR (ACTIVE LOW) |

Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

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

*NOTICE: 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}}=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$ )

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| IF | Input Load Current, ACK, DS2, CR, $\mathrm{Dl}_{1}$ - $\mathrm{Dl}_{8}$ Inputs |  |  | -. 25 | mA | $V_{F}=.45 \mathrm{~V}$ |
| $I_{\text {F }}$ | Input Load Current MD Input |  |  | -. 75 | mA | $V_{F}=.45 \mathrm{~V}$ |
| IF | Input Load Current DS 1 Input |  |  | -1.0 | mA | $V_{F}=.45 \mathrm{~V}$ |
| IR | Input Leakage Current, ACK, DS, CR, $\mathrm{Dl}_{1}$-DI $\mathrm{DI}_{8}$ Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IR | Input Leakage Current MO Input |  |  | 30 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| IR | Input Leakage Current DS 1 Input |  |  | 40 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Voltage Clamp |  |  | -1 | V | IC $=-5 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | 0.85 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| Vol | Output "Low" Voltage |  |  | 0.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}$ |
| \|lol | Output Leakage Current High Impedance State |  |  | $\begin{gathered} -20 \\ 20 \\ \hline \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{O}}=5.25 \mathrm{~V} \\ & \hline \end{aligned}$ |
| ICC | Power Supply Current |  | 90 | 130 | mA |  |

CAPACITANCE* ( $\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}$ )

| Symbol | Test | Limits |  |
| :---: | :---: | :---: | :---: |
|  |  | Typ. | Max. |
| CIn | DS1 MD Input Capacitance | 9pF | 15 pF |
| CIN | DS $2, \mathrm{CK}, \mathrm{ACK}, \mathrm{Dl}_{1}-\mathrm{Dl}_{8}$ Input Capacitance | 5pF | 10 pF |
| Cout | $\mathrm{DO}_{1}-\mathrm{DO}_{8}$ Output Capacitance | 8pF | 15 pF |

[^36]
## A.C. CHARACTERISTICS ( $T_{A}=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+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 |  |
| th | Data Hold Time | 20 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{R}}$ | Reset to Output Delay |  |  | 40 | ns | Note 1 |
| ts | Set to Output Delay |  |  | 30 | ns | Note 1 |
| $\mathrm{t}_{\mathrm{E}}$ | Output Enable/Disable Time |  |  | 45 | ns | Note 1 |
| tc | Clear to Output Delay |  |  | 55 | ns | Note 1 |

## SWITCHING CHARACTERISTICS

## Conditions of Test

Input Pulse Amplitude $=2.5 \mathrm{~V}$
Input Rise and Fall Times 5ns
Between 1V and 2V Measurements made at 1.5 V with 15 mA and 30 pF Test Load

Note 1:

| Test | $\mathbf{C L}^{*}$ | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :--- | :---: | :---: | :---: |
| tpd, twe, tr, ts, tc | 30 pF | $300 \Omega$ | $600 \Omega$ |
| te, ENABLE $\dagger$ | 30 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| te, ENABLE $!$ | 30 pF | $300 \Omega$ | $600 \Omega$ |
| te, DISABLE 1 | 5 pF | $300 \Omega$ | $600 \Omega$ |
| te, DISABLE | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

*Includes probe and jig capacitance.
A.C. TESTING LOAD CIRCUIT


## I8216/I8226 4-BIT PARALLEL BIDIRECTIONAL BUS DRIVER

indUSTRIAL

## - Data Bus Buffer Driver <br> - Low Input Load Current - . 25 mA Maximum <br> - High Output Drive Capability for Driving System Data Bus

- 3.65V Output High Voltage
- Three State Outputs
- Reduces System Package Count
- Industrial Temperature Range:
$-40^{\circ}$ to $+85^{\circ} \mathrm{C}$

The I8216/18226 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 (18216) and an inverting (18226) are available to meet a wide variety of applications for buffering in microcomputer systems.



Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$ . $-40^{\circ} \mathrm{C}$ to $85^{\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
*NOTICE: 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}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $I_{F 1}$ | Input Load Current $\overline{\text { DIEN, }} \overline{\text { CS }}$ |  | -0.15 | -. 5 | mA | $V_{F}=0.45$ |
| $I_{\text {F } 2}$ | Input Load Current All Other Inputs |  | -0.08 | -. 25 | mA | $V_{F}=0.45$ |
| $\mathrm{I}_{\mathrm{R} 1}$ | Input Leakage Current $\overline{\text { DIEN, }}$, $\overline{C S}$ |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R} 2}$ | Input Leakage Current DI Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Voltage Clamp |  |  | -1 | V | $I_{C}=-5 \mathrm{~mA}$ |
| $V_{\text {IL }}$ | Input "Low" Voltage |  |  | . 95 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| 1101 | Output Leakage Current DO <br> (3-State) DB |  |  | $\begin{gathered} 20 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=0.45 \mathrm{~V} / 5.25 \mathrm{~V}$ |
| ${ }^{\text {c }} \mathrm{C}$ | Power Supply Current |  | 95 | 130 | mA |  |
|  |  |  | 85 | 120 | mA |  |
| $\mathrm{V}_{\text {OL1 }}$ | Output "Low" Voltage DO, DB Outputs |  | 0.3 | . 45 | V | DO Outputs $\mathrm{I}_{\mathrm{OL}}=15 \mathrm{~mA}$ DB Outputs $\mathrm{I}_{\mathrm{OL}}=25 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output "Low" Voltage DB Outputs Only |  | 0.5 | . 6 | V | DB Outputs $\mathrm{I}_{\mathrm{OL}}=50 \mathrm{~mA}$ |
|  |  |  | 0.5 | . 6 | V | DB Outputs $\mathrm{I}_{\mathrm{OL}}=45 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output "High" Voltage DO Outputs | 3.65 | 4.0 |  | V | DO Outputs $\mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output "High" Voltage DB Outputs | 2.4 | 3.0 |  | V | DB Outputs $\mathrm{IOH}^{\text {a }}=-10 \mathrm{~mA}$ |
| los | Output Short Circuit Current | $\begin{aligned} & -15 \\ & -30 \end{aligned}$ | $\begin{aligned} & -35 \\ & -75 \end{aligned}$ | $\begin{gathered} -65 \\ -120 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | DO Outputs $\mathrm{V}_{\mathrm{O}} \cong 0 \mathrm{~V}$, <br> DB Outputs $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |

NOTE: $T_{y p i c a l}$ values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5.0 \mathrm{~V}$.

CAPACITANCE ( $\left.\mathrm{V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. [1] | Max. |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 4 | 8 | pF |
| Couti | Output Capacitance |  | 6 | 10 | pF |
| Cout2 | Output Capacitance |  | 13 | 20 | pF |

A.C. CHARACTERISTICS $\quad\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{11]}$ | 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}$ |
| $\mathrm{T}_{\text {PD2 }}$ | Input to Output Delay DB Outputs 8216 |  | 20 | 30 | ns | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}, \mathrm{R}_{1}=90 \Omega \\ & \mathrm{R}_{2}=180 \Omega \end{aligned}$ |
|  | 8226 |  | 16 | 25 | ns |  |
| $\mathrm{T}_{\mathrm{E}}$ | Output Enable Time $\begin{array}{r} \\ \\ \\ \\ \hline 8216 \\ \hline 8226\end{array}$ |  | 45 | 65 | ns | (Note 2) |
|  |  |  | 36 | 54 | ns | (Note 2) |
| TD | Output Disable Time |  | 20 | 35 | ns | (Note 2) |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
2. 

| TEST | $C_{L}$ | $\mathrm{R}_{1}$ | $\mathrm{R}_{2}$ |
| :---: | :---: | :---: | :---: |
| $T_{\text {PD1 }}$ | 30 pF | 300s: | $600!$ ! |
| $T^{\text {PD } 2}$ | 300 pF | 90\% | 180! |
| $\mathrm{T}_{\mathrm{E}}$, (DO. ENABLE') | 30 pF | $10 \mathrm{~K}!$ ! | 1 K ! |
| $\mathrm{T}_{\mathrm{E}}$ ( DO, ENABLEI) | 30 pF | 3009 ? | 600:! |
| $T_{E}$, (DB, ENABLE') | 300 pF | 10K! | 1K!! |
| $\mathrm{T}_{\mathrm{E}}$ ( (DB, ENABLE!) | 300 pF | 909 | 180!! |
| To. (DO. DISABLE') | 5 pF | 30082 | $600!$ ? |
| ${ }^{T} \mathrm{D}$. (DO. DISABLE ${ }^{\text {( }}$ ) | 5 pF | $10 \mathrm{~K}!$ | $1 \mathrm{~K}!$ ! |
| ${ }^{T} \mathrm{D}$. (DB. DISABLE ${ }^{\text {( }}$ ) | 5 pF | $90 \Omega 2$ | 180ヶ! |
|  | 5 pF | 10K\% | $1 \mathrm{~K}!$ |

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

## A.C. TESTING LOAD CIRCUIT



# I8259A PROGRAMMABLE INTERRUPT CONTROLLER 

INDUSTRIAL

- iAPX 86 Compatible
- MCS-80 ${ }^{\circledR}$, $85^{\circledR}$ Compatible
- Eight-Level Priority Controller
- Expandable to 64 Levels
- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single +5V Supply (No Clocks)
- Industrial Temperature Range:
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

The Intel ${ }^{*}$ 18259A 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 I8259A 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.


Figure 1. Block Diagram
Figure 2. Pin Configuration

Table 1. Pin Descriptions

| Symbol | Pin No. | Type | Name and Function |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{C C}$ | 28 |  | Voltage: +5 V supply. |
| GND | 14 |  | Ground: Ground. |
| $\mathrm{D}_{0-7}$ | 11-4 | 1/0 | Data Bus: 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. |
| $1 \mathrm{R}_{0-7}$ | 18-25 | 1 | Interrupt Requests: These are asynchronous inputs. A positive-going 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{\mathrm{RD}}$ | 3 | 1 | Read: (generally from 8228 in MCS-80 system or from 8086 in MCS-86 system). |
| $\overline{\text { WR }}$ | 2 | 1 | Write: (generally from 8288 in MCS-80 system or from 8086 in MCS-86 system). |
| INTA | 26 | 1 | Interrupt Acknowledge: (generally from 8228 in MCS-80 system, 8086 in MCS-86 system). The 8288 generates three distinct INTA pulses whan a CALL is inserted, the 8086 produces two distinct INTA pulses during an interrupt cycle. |
| $\overline{\mathrm{CS}}$ | 1 | 1 | Chip Select: $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ are enabled by Chip Select, whereas Interrupt Acknowledge is independent of Chip Select. |
| A0 | 27 | 1 | Address: Usually the least significant bit of the microprocessor address output. 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 | 17 | 0 | Interrupt: Goes directly to the microprocessor interrupt 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 | 12 | $\begin{aligned} & 1 / \mathrm{O} \\ & 13 \\ & 15 \end{aligned}$ | Cascade Lines: Three cascade lines, outputs in master mode and inputs in slave. Mode The master issues the binary code of the acknowledged interrupt level on these lines. Each slave compares this code with its own. |
| $\overline{\mathrm{SP}} / \mathrm{EN}$ | 16 | 1/0 | $\overline{\mathbf{S P}} / \overline{\mathbf{E N}}$ : A dual function pin. In the buffered mode $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ is used to enable bus transceivers ( $\overline{E N}$ ). In the non-buffered mode $\overline{\mathrm{SP}} / \overline{\mathrm{EN}}$ determines if this 8259 A 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 . . . . $\quad-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
*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -.5 | .8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High VoItage | 2.3 | $\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 |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current | -10 | +10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{LOL}}$ | Output Leakage Current | -10 | +10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{LOH}}$ | Output Leakage Current |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | mA |  |  |

CAPACITANCE $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{/ / O}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $\mathrm{V}_{\mathrm{SS}}$ |

A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAHRL | A0/ $\overline{\mathrm{CS}}$ Setup to $\overline{\mathrm{RD}} / \overline{\mathrm{INTA}} \downarrow$ | 0 |  | ns |  |
| TRHAX | AO/ $\overline{\mathrm{CS}}$ Hold after $\overline{\mathrm{RD}} / / \overline{\mathrm{NTA}} \uparrow$ | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | 235 |  | ns |  |
| TAHWL | A0/ $\overline{\mathrm{CS}}$ Setup to $\overline{W R} \downarrow$ | 0 |  | ns |  |
| TWHAX | A0/ $\overline{\mathrm{CS}}$ Hold after $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| TWLWH | $\overline{\text { WR Pulse Width }}$ | 290 |  | ns |  |
| TDVWH | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 240 |  | ns |  |
| TWHDX | Data Hold after $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| TJLJH | Interrupt Request Width (Low) | 100 |  | ns | See Note 1 |
| TCVIAL | Cascade Setup to Second or Third INTA $\downarrow$ (Slave Only) | 55 |  | ns |  |
| TRHRL | End of $\overline{\mathrm{RD}}$ to next $\overline{\mathrm{RD}}$ End of $\overline{\text { INTA }}$ to next INTA within an INTA sequence only | 160 |  | ns |  |
| TWHWL | End of $\overline{W R}$ to next $\overline{W R}$ | 190 |  | ns |  |

## A.C. CHARACTERISTICS (Continued)

## TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| TCHCL | End of Command to next Command <br> (Not same command type) | 500 |  | ns |  |
|  | End of INTA sequence to next <br> INTA sequence. |  |  |  |  |

*Worst case timing for TCHCL in an actual microprocessor system is typically much greater than 500 ns (i.e. $8085 \mathrm{~A}=1.6 \mu \mathrm{~s}$, $8085 \mathrm{~A}-2=1 \mu \mathrm{~s}, 8086=1 \mu \mathrm{~s}, 8086-2=625 \mathrm{~ns}$ )

TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TRLDV | Data Valid from $\overline{\mathrm{RD}} / \overline{\mathrm{NNTA}} \downarrow$ |  | 200 | ns | $\begin{aligned} & \text { C of Data Bus } \\ & \text { Max. test } C=100 \mathrm{pF} \\ & \text { Min. test } C=15 \mathrm{pF} \\ & \mathrm{C}_{\text {INT }}=100 \mathrm{pF} \\ & \mathrm{C}_{\text {ENABLE }}=15 \mathrm{pF} \end{aligned}$ |
| TRHDZ | Data Float after $\overline{\mathrm{RD}} / \overline{\mathrm{NT} T A} \uparrow$ | 10 | 100 | ns |  |
| TJHIH | Interrupt Output Delay |  | 350 | ns |  |
| TIALCV | Cascade Valid from First $\overline{\text { INTA }} \downarrow$ (Master Only) |  | 565 | ns |  |
| TRLEL | Enable Active from $\overline{\mathrm{RD}} \downarrow$ or $\overline{\text { NTA }} \downarrow$ |  | 125 | ns |  |
| TRHEH | Enable Inactive from $\overline{\mathrm{RD}} \uparrow$ or $\overline{\text { INTA } \uparrow}$ |  | 150 | ns |  |
| TAHDV | Data Valid from Stable Address |  | 200 | ns |  |
| TCVDV | Cascade Valid to Valid Data |  | 300 | ns |  |

NOTE:

1. This is the low time required to clear the input latch in the edge triggered mode.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS

## WRITE



WAVEFORMS (Continued)

## READ/INTA MODE



INTA SEQUENCE


NOTES: Interrupt output must remain HIGH at least until leading edge of first INTA.

1. Cycle 1 in iAPX 86, IAPX 88 systems, the Data Bus is not active.

WAVEFORMS (Continued)
OTHER TIMING


# I8282/8283 <br> OCTAL LATCH <br> INDUSTRIAL 

## - Fully Parallel 8-Bit Data Register and Buffer

- Transparent during Active Strobe
- Address Latch for iAPX 86, 88, MCS-80 ${ }^{\circledR}$, MCS-85 ${ }^{\circledR}$, MCS-48 ${ }^{\circledR}$ Families


## - 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
- Industrial Temperature Range: $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$

The I8282 and I8283 are 8-bit bipolar latches with 3 -state output buffers. They can be used to implement latches, buffers, or multiplexers. The 18283 inverts the input data at its outputs while the 18282 does not. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with these devices.


Figure 1. Logic Diagrams



Figure 2. Pin Configurations

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| STB | 1 | Strobe: STB is an input control pulse used to strobe data at the input pins $\left(A_{0}-A_{7}\right)$ into the data latches. This signal is active HIGH to admit input data. The data is latched at the HIGH to LOW transition of STB. |
| $\overline{\mathrm{OE}}$ | 1 | Output Enable: $\overline{\mathrm{OE}}$ is an input control signal which when active LOW enables the contents of the data latches onto the data output pin $\left(\mathrm{B}_{0}-\mathrm{B}_{7}\right)$. $\overline{\mathrm{OE}}$ being inactive HIGH forces the output buffers to their high impedance state. |
| $\mathrm{DI}_{0}-\mathrm{Dl}_{7}$ | 1 | Data Input Pins: Data presented at these pins satisfying setup time requirements when STB is strobed is latched into the data input latches. |
| $\begin{aligned} & \mathrm{DO}_{0}-\mathrm{DO}_{7} \\ & (\mathrm{IB282)} \\ & \mathrm{DO}_{0}-\overline{\mathrm{DO}} \\ & (1828) \\ & (1823) \end{aligned}$ | 0 | Data Output Pins: When $\overline{\mathrm{OE}}$ is true, the data in the data latches is presented as inverted (18283) or noninverted (I8282) data onto the data output pins. |

## FUNCTIONAL DESCRIPTION

The I8282 and I8283 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{\mathrm{OE}}$ input line. When $\overline{\mathrm{OE}}$ 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.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $\qquad$ $-40^{\circ} \mathrm{C}$ to $+85^{\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
*NOTICE: 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(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

| 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 |  | .45 | V | $\mathrm{I}_{\mathrm{OL}}=20 \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.25 V |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage |  | 0.8 | V | $\mathrm{~V}_{\mathrm{CC}}=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}_{\mathrm{IN}}$ | Input Capacitance |  | 12 | pF | $\mathrm{F}=1 \mathrm{MHz}$ <br> $\mathrm{V}_{\mathrm{BIAS}}=2.5 \mathrm{~V}, \mathrm{~V}$ <br> V |

## A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

(Loading: Outputs $-\mathrm{I}_{\mathrm{OL}}=20 \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 2) |
| TSHOV | STB to Output Delay <br> -Inverting <br> -Non-Inverting |  | 45 | ns |  |
| TEHOZ | Output Disable Time |  | 25 | ns |  |
| TELOV | Output Enable Time | 10 | 50 | ns |  |
| TIVSL | Input to STB Setup Time | 0 |  | ns |  |
| TSLIX | Input to STB Hold Time | 25 |  | ns |  |
| TSHSL | STB High Time | 15 |  | ns |  |
| TILIH, <br> TOLOH | Input, Output Rise Time | 20 | ns | From 0.8V to 2.0V |  |
| TIHIL, <br> TOHOL | Input, Output Fall Time | 12 | ns | From 2.0V to 0.8V |  |

## NOTES:

1. Output Loading $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$.
2. See waveforms and test load circuit on following page.

## A.C. TESTING INPUT, OUTPUT WAVEFORM

input/OUTPUT


A C. TESTING. INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45V FOR A LOGIC " 0 ." TIMING MEASUREMENTS ARE MADE AT 1.5 V FOR BOTH A
LOGIC • 1" AND "0

## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS



NOTE: 1. I8283 ONLY - OUTPUT MAY BE MOMENTARILY INVALID FOLLOWING THE HIGH GOING STB TRANSITION.
2. ALL TIMING MEASUREMENTS ARE MADE AT 1.5 V UNLESS OTHERWISE NOTEDs

18284
CLOCK GENERATOR AND DRIVER FOR iAPX 86, 88 PROCESSORS

INDUSTRIAL

Industrial Temperature Range:
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Generates the System Clock for the Industrial iAPX 86/10

Uses a Crystal or a TTL Signal for Frequency Source

Single +5V Power Supply

- 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 I8284 is a bipolar clock generator/driver designed to provide clock signals for the iAPX 86, 88 and peripherals. It also contains READY logic for operation with two MULTIBUS ${ }^{\text {TM }}$ systems and provides the processors required READY synchronization and timing. Reset logic with hysteresis and synchronization is also provided.


Figure 1. Block Diagram


Figure 2. Pin Configuration

| X1 $\times 21$ | CONNECTIONS FOR CRYSTAL | $\overline{\text { RES }}$ | RESET INPUT |
| :---: | :---: | :---: | :---: |
| F/IC | Clock source select | RESET | SYNCHRONIZED RESET OUTPUT |
| EFI | EXTERNAL CLOCK INPUT | OSC | OSCILLATOR OUTPUT |
| CSYNC | CLOCK SYNCHRONIZATION INPUT | CLK | MOS CLOCK ID8086 |
| RDY1 | READY SIGNAL FROM TWO MULTIBUS ${ }^{\text {TM }}$ SYSTEMS | PCLK | TTL CLOCK FOR PERIPHERALS |
| RDY2 | READY SIGNAL FROM TWO MULTIBUS SYSTEMS | REAOY | SYNCHRONIZED READY OUTPUT |
| $\frac{\overline{A E N} 1}{\overline{A E N} 2}$ | ADDRESS ENABLED QUALIFIERS FOR RDY1.2 | VCC GND | +5 VOLTS <br> 0 VOLTS |
| I8284 Pin Names |  |  |  |

18284

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $85^{\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
*NOTICE: 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 operation 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}}=-40^{\circ} \mathrm{C}$ to $85^{\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 VoItage |  | 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}_{\mathrm{R}}}$ | 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 |  |  |  |  |  |

A.C. CHARACTERISTICS ( $T_{A}=-40^{\circ} \mathrm{C}$ to $85^{\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 | 13 |  | ns | 90\% - 90\% VIN |
| TELEH | External Frequency Low Time | 13 |  | ns | 10\% - 10\% VIN |
| TELEL | EFI Period | TEHEL + TELEH + $\delta$ |  | ns | (Note 1) |
|  | XTAL Frequency | 12 | 25 | MHz |  |
| TRIVCL | RDY1, RDY2 Set-Up to CLK | 35 |  | ns |  |
| TCLR1X | RDY1, RDY2 Hold to CLK | 0 |  | ns |  |
| TA1VR1V | AEN1, $\overline{\text { AEN2 }}$ Set-Up to RDY1, RDY2 | 15 |  | ns |  |
| TCLA1X | $\overline{\text { AEN1 }}$, $\overline{\text { 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 |  |
| TIIHCL | $\overline{\text { RES }}$ Set-Up to CLK | 65 |  | ns | (Note 2) |
| TCLITH | $\overline{\text { RES }}$ Hold to CLK | 20 |  | ns | (Note 2) |
| TILIH | Input Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. CHARACTERISTICS (Continued)

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 |  |
| TCLCH | CLK Low Time | $(2 / 3 \mathrm{TCLCL})-15.0$ |  | ns |  |
| TCH1CH2 <br> TCL2CL1 | CLK Rise or Fall Time |  | 10 | ns | 1.0 V to 3.5V |
| TPHPL | PCLK High Time | TCLCL-20 |  | ns |  |
| TPLPH | PCLK Low Time | TCLCL-20 |  | ns |  |
| TRYLCL | Ready Inactive to CLK (See Note 4) | -8 |  | ns |  |
| TRYHCH | Ready Active to CLK (See Note 3) | $(2 / 3$ TCLCL)-15.0 |  | ns |  |
| TCLIL | CLK to Reset Delay |  | 40 | ns |  |
| TCLPH | CLK to PCLK High Delay |  | 22 | ns |  |
| TCLPL | CLK to PCLK Low Delay |  | 22 | ns |  |
| TOLCH | OSC to CLK High Delay | -5 | 12 | ns |  |
| TOLCL | OSC to CLK Low Delay | 2 | 25 | ns |  |
| TOLOH | Output Rise Time (Except CLK) |  | 20 | ns | From 0.8V to 2.0V |
| TOHOL | Output Fall Time (Except CLK) |  | 12 | ns | From 2.0V to 0.8V |

NOTES:

1. $\delta=\mathrm{EFI}$ rise ( 5 ns max) +EFI fall ( 5 ns max).
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. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT

$C_{L}=$ SEE NOTES 1 AND 2.

## WAVEFORMS



NOTE: ALL TIMING MEASUREMENTS ARE MADE AT 1.5 VOLTS, UNLESS OTHERWISE NOTED


Clock High and Low Time


Ready to Clock (using $\mathrm{X}_{1}, \mathrm{X}_{2}$ )


Clock High and Low Time


Ready to Clock (using EFI)

NOTES:

1. $C_{L}=100 \mathrm{pF}$.
2. $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$.

# I8286/8287 <br> OCTAL BUS TRANSCEIVER 

## INDUSTRIAL

- Data Bus Buffer Driver for iAPX 86,88, MCS-80 ${ }^{\circledR}$, MCS-85 ${ }^{\circledR}$, and MCS-48 ${ }^{\circledR}$
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

Industrial Temperature Range: $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

The 18286 and 18287 are 8 -bit bipolar transceivers with 3 -state outputs. The 18287 inverts the input data at its outputs while the 18286 does not. Thus, a wide variety of applications for buffering in microcomputer systems can be met.


Figure 1. Logic Diagrams


Figure 2. Pin Configuration

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :--- | :---: | :--- |
| $T$ | $I$ | Transmit: $T$ is an input control signal used to control the direction of the transceivers. When HIGH, it <br> configures the transceiver's $\mathrm{B}_{0}-\mathrm{B}_{7}$ as outputs with $\mathrm{A}_{0}-\mathrm{A}_{7}$ as inputs. $T$ LOW configures $\mathrm{A}_{0}-\mathrm{A}_{7}$ as the <br> outputs with $\mathrm{B}_{0}-\mathrm{B}_{7}$ serving as the inputs. |
| $\overline{\mathrm{OE}}$ | 1 | Output Enable: $\overline{\mathrm{OE}}$ is an input control signal used to enable the appropriate output driver (as selected by <br> T ) onto its respective bus. This signal is active LOW. |
| $\mathrm{A}_{0}-\mathrm{A}_{7}$ | $1 / \mathrm{O}$ | Local Bus Data Pins: These pins serve to either present data to or accept data from the processor's local <br> bus depending upon the state of the $T$ pin. |
| $\mathrm{B}_{0}-\mathrm{B}_{7}$ <br> $(\mathrm{I} 8286)$ <br> $\overline{\mathrm{B}_{0}}-\overline{B_{7}}$ <br> $(\mathrm{I} 8287)$ | $\mathrm{I} / \mathrm{O}$ | System Bus Data Pins: These pins serve to either present data to or accept data from the system bus <br> depending upon the state of the $T$ pin. |

## FUNCTIONAL DESCRIPTION

The I8286 and I8287 transceivers are 8-bit transceivers with high impedance outputs. With T active HIGH and $\overline{\mathrm{OE}}$ active LOW, data at the $\mathrm{A}_{0}-\mathrm{A}_{7}$ pins is driven onto the
$\mathrm{B}_{0}-\mathrm{B}_{7}$ pins. With T inactive LOW and $\overline{\mathrm{OE}}$ active LOW data at the $\mathrm{B}_{0}-\mathrm{B}_{7}$ pins is driven onto the $\mathrm{A}_{0}-\mathrm{A}_{7}$ pins. No output low glitching will occur whenever the transceivers are entering or leaving the high impedance state.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias. . . . . . . . . . . . $-40^{\circ} \mathrm{C}$ to $+85^{\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
*NOTICE: 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(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| ${ }^{\text {cc }}$ | $\begin{array}{r} \text { Power Supply Current }-8287 \\ -8286 \end{array}$ |  | $\begin{aligned} & 130 \\ & 160 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ |  |
| $I_{\text {F }}$ | Forward Input Current |  | -0.2 | mA | $V_{F}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {OL }}$ | $\begin{aligned} \text { Output Low Voltage } & \text { - B Outputs } \\ & - \text { A Outputs } \end{aligned}$ |  | $\begin{aligned} & .45 \\ & .45 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=10 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} \text { Output High Voltage } & - \text { B Outputs } \\ & - \text { A Outputs } \end{aligned}$ | $\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}$ |
| $\begin{aligned} & I_{\text {OFF }} \\ & I_{\text {OFF }} \end{aligned}$ | Output Off Current Output Off Current |  | $\begin{aligned} & I_{F} \\ & I_{R} \end{aligned}$ |  | $\begin{aligned} & V_{\text {OFF }}=0.45 \mathrm{~V} \\ & V_{\text {OFF }}=5.25 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage - A Side <br>  - B Side |  | $\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> $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, See Note 1 |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | V | $\mathrm{V}_{C C}=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}$ |

A.C. CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
(Loading: B Outputs- $\mathrm{l}_{\mathrm{OL}}=20 \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 2) |
| 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 |  |
| TILIH, <br> TOLOH | Input, Output Rise Time |  | 20 | ns | From 0.8V to 2.0V |
| TIHIL, <br> TOHOL | Input, Output Fall Time |  | 12 | ns | From 2.0V to 0.8V |

## NOTES:

1. B Outputs- $\mathrm{l}_{\mathrm{OL}}=20 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF} ; \mathrm{A}$ Outputs- $\mathrm{l}_{\mathrm{OL}}=10 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$.
2. See waveforms and test load circuit following.
A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT


A C TESTING. INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45 V FOR
A LOGIC "0 TIMING MEASUREMENTS ARE MADE AT 15 V FOR BOTH A
LOGIC 1 AND "0.

## TEST LOAD CIRCUITS



## WAVEFORMS



Output Delay vs. Capacitance

# 18288 <br> BUS CONTROLLER FOR IAPX 86, 88 PROCESSORS <br> INDUSTRIAL 

## 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
- Industrial Temperature Range: $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ I8288 Bus Controller is a 20-pin bipolar component for use with medium-to-large iAPX 86 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.


Figure 1. Block Diagram


Figure 2. Pin Configuration


Figure 3. Functional Pin-Out

| ABSOLUTE MAXIMUM | GS* |
| :---: | :---: |
| Temperature Under Bias | $-40^{\circ} \mathrm{C}$ to $85^{\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.5 Wat |

## D.C. CHARACTERISTICS $\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 230 | mA |  |
| $l_{\text {F }}$ | 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 \end{aligned}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{O}}=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{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V |  |
| $V_{\text {IH }}$ | 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 $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.85^{\circ} \mathrm{C}\right)$ TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 |  | ns |  |
| TCLCH | CLK Low Time | 66 |  | ns |  |
| TCHCL | CLK High Time | 40 |  | ns |  |
| TSVCH | Status Active Setup Time | 35 |  | ns |  |
| TCHSV | Status Active Hold Time | 10 |  | ns |  |
| TSHCL | Status Inactive Setup Time | 35 |  | ns |  |
| TCLSH | Status Inactive Hold Time | 10 |  | ns |  |
| TILIH | Input Rise Time |  | 20 | ns | From 0.8V to 2.0V |
| TIHIL | Input Fall Time |  | 12 | ns | From 2.0V to 0.8V |

## A.C. CHARACTERISTICS (Continued)

TIMING RESPONSES


## A.C. TESTING INPUT, OUTPUT WAVEFORM

InPUT/OUTPUT

A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0 45V FOR A LOGIC "0." TIMING MEASUREMENTS ARE MADE AT 1.5 V FOR BOTH A LOGIC "1" AND "0

## TEST LOAD CIRCUITS-3-STATE COMMAND OUTPUT TEST LOAD



## WAVEFORMS



## WAVEFORMS (Continued)

DEN, PDEN QUALIFICATION TIMING


ADDRESS ENABLE (AEN) TIMING (3-STATE ENABLE/DISABLE)


NOTE: CEN must be low or valid prior to T 2 to prevent the command from being generated.

## I8289 <br> BUS ARBITER

## INDUSTRIAL

- Provides Multi-Master System Bus Protocol
- Synchronizes iAPX 86, 88 Processors with Multi-Master Bus
- Provides Simple Interface with 8288 Bus Controller
- Compatible with Intel Bus Standard MULTIBUS ${ }^{\text {TM }}$
- Provides System Bus Arbitration for 8089 IOP in Remote Mode
- Full Industrial Temperature Range $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$


## - Four Operating Modes for Flexible System Configuration

The Intel 18289 Bus Arbiter is a 20 -pin, 5 -volt-only bipolar component for use with medium to large iAPX 86,88 multimaster/multiprocessing systems. The 18289 provides system bus arbitration for systems with multiple bus masters, such as an I8086 CPU with I8089 IOP in its REMOTE mode, while providing bipolar buffering and drive capability.


Figure 1. Block Diagram


Figure 2. Pin Diagram


Figure 3. Functional Pinout

## 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.
D.C. CHARACTERISTICS $\left(T_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | - 1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.50 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Forward Current |  | -0.5 | mA | $\mathrm{V}_{C C}=5.50 \mathrm{~V}, \mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Leakage Current |  | 60 | $\mu \mathrm{A}$ | $\mathrm{V}_{C C}=5.50, \mathrm{~V}_{\mathrm{R}}=5.50$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage $\overline{B U S Y}, \overline{\mathrm{CBRQ}}$ $\overline{\mathrm{AEN}}$ $\overline{\mathrm{BPRO}}, \overline{\mathrm{BREQ}}$ |  | $\begin{aligned} & 0.45 \\ & 0.45 \\ & 0.45 \\ & \hline \end{aligned}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=16 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage $\overline{B U S Y}, \overline{\mathrm{CBRQ}}$ | Open Collector |  |  |  |
|  | All Other Outputs | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=400 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 165 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | . 8 | V |  |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input High Voltage | 2.0 |  | V |  |
| Cin Status | Input Capacitance |  | 25 | pF |  |
| Cin (Others) | Input Capacitance |  | 12 | pF |  |

A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$ TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 |  | ns |  |
| TCLCH | CLK Low Time | 65 |  | ns |  |
| TCHCL | CLK High Time | 35 |  | ns |  |
| TSVCH | Status Active Setup | 65 | TCLCL-10 | ns |  |
| TSHCL | Status Inactive Setup | 50 | TCLCL-10 | ns |  |
| THVCH | Status Active Hold | 10 |  | ns |  |
| THVCL | Status Inactive Hold | 10 |  | ns |  |
| TBYSBL | BUSY $\uparrow \downarrow$ Setup to BCLK $\downarrow$ | 20 |  | ns |  |
| TCBSBL | CBRQ $\uparrow \downarrow$ Setup to BCLK $\downarrow$ | 20 |  | ns |  |
| TBLBL | BCLK Cycle Time | 100 |  | ns |  |
| TBHCL | BCLK High Time | 30 | .65[TBLBL] | ns |  |
| TCLLL1 | LOCK Inactive Hold | 10 |  | ns |  |
| TCLLL2 | LOCK Active Setup | 40 |  | ns |  |
| TPNBL | BPRN $\downarrow \uparrow$ to BCLK Setup Time | 15 |  | ns |  |
| TCLSR1 | SYSB/RESB Setup | 0 |  | ns |  |
| TCLSR2 | SYSB/RESB Hold | 20 |  | ns |  |
| TIVIH | Initialization Pulse Width | $\begin{gathered} 3 \text { TBLBL+ } \\ 3 \text { TCLCL } \end{gathered}$ |  | ns |  |
| TILIH | Input Rise Time |  | 20 | ns | From 0.8 to 2.0 V |
| TIHIL | Input Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. CHARACTERISTICS (Continued)

TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Unit | Test Condition |
| :--- | :--- | :--- | :--- | :--- | :--- |
| TBLBRL | BCLK to BREQ Delay $\downarrow \uparrow$ | 35 | ns |  |  |
| TBLPOH | BCLK to BPRO $\downarrow \uparrow$ (See Note 1) |  | 40 | ns |  |
| TPNPO | BPRN $\downarrow \uparrow$ to BPRO $\downarrow \uparrow$ Delay <br> (See Note 1) |  | 25 | ns |  |
| TBLBYL | BCLK to BUSY Low |  | 60 | ns |  |
| TBLBYH | BCLK to BUSY Float (See Note 2) |  | 35 | ns |  |
| TCLAEH | CLK to AEN High |  | 65 | ns |  |
| TBLAEL | BCLK to AEN Low |  | 60 | ns |  |
| TBLCBL | BCLK to CBRQ Low |  | 35 | ns |  |
| TRLCRH | BCLK to CBRQ Float (See Note 2) |  | 20 | ns |  |
| TOLOH | Output Rise Time |  | 12 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | ns | From 2.0 V to 0.8 V |  |

$\downarrow \uparrow$ Denotes that spec applies to both transitions of the signal.

## NOTES:

1. BCLK generates the first BPRO wherein subsequent BPRO changes lower in the chain are generated through BPRON.
2. Measured at .5 V above GND.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## ADDITIONAL NOTES:

The signals related to CLK are typical processor signals, and do not relate to the depicted sequence of events of the signals referenced to $\overline{B C L K}$. The signals shown related to the $\overline{B C L K}$ represent a hypothetical sequence of events for illustration. Assume 3 bus arbiters of priorities 1, 2 and 3 configured in serial priority resolving scheme as shown in Figure 6. Assume arbiter 1 has the bus and is holding busy low. Arbiter \#2 detects its processor wants the bus and pulls low $\overline{\mathrm{BREQ} 2}$. If $\overline{\mathrm{BPRN} \mathrm{\# 2}}$ is high (as shown), arbiter \#2 will pull low $\overline{\mathrm{CBRQ}}$ line. $\overline{\mathrm{CBRQ}}$ signals to the higher priority arbiter \#1 that a lower priority arbiter wants the bus. [A higher priority arbiter would be granted BPRN when it makes the bus request rather than having to wait for another arbiter to release the bus through CBRQ]. ** Arbiter \#1 will relinquish the multi-master system bus when it enters a state not requiring it (see Table 1), by lowering its BPRO\#1 (tied to $\overline{\text { BPRN\# }}$ ) and releasing BUSY. Arbiter \#2 now sees that it has priority from BPRN\#2 being low and releases $\overline{\mathrm{CBRQ}}$. As soon as BUSY signifies the bus is available (high), arbiter \#2 pulls BUSY low on next falling edge of BCLK. Note that if arbiter \#2 didn't want the bus at the time it received priority, it would pass priority to the next lower priority arbiter by lowering its $\overline{\mathrm{BPRO} \# 2}$ [TPNPO].

* Note that even a higher prionty arbiter which is acquiring the bus through $\overline{\mathrm{BPRN}}$ will momentarily drop $\overline{\mathrm{CBRQ}}$ until it has acquired the bus

18355*
16,384-BIT ROM WITH I/O
*Directly Compatible with I8085A CPU. INDUSTRIAL

## - Industrial Temperature Range:

$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

## - 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 ${ }^{\circledR}$ I8355 is a ROM and I/O chip to be used in the MCS $85{ }^{\circledR}$ 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 individually programmable as input or output.


Figure 1. Block Diagram
Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| 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 |
| ower Dissipation | 1.5W |

*NOTICE: 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}=-40^{\circ} \mathrm{C}\right.$ to $85^{\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{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}}=1.6 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| IILL | Input Leakage |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\text {LO }}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{OUT}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 180 | mA |  |

## A.C. CHARACTERISTICS $\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $85^{\circ} \mathrm{C}$; $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| tcre | Clock Cycle Time | 320 |  | ns |  |
| T1 | CLK Pulse Width | 80 |  | ns |  |
| $\mathrm{T}_{2}$ | CLK Pulse Width | 120 |  | ns |  |
| $\mathrm{t}_{\mathrm{f}, \mathrm{tr}_{\mathrm{r}}}$ | CLK Rise and Fall Time |  | 30 | ns |  |
| $\mathrm{taL}_{\text {c }}$ | Address to Latch Set Up Time | 50 |  | ns |  |
| tLA | Address Hold Time after Latch | 80 |  | ns |  |
| tıc | Latch to READ/WRITE Control | 100 |  | ns |  |
| trd | Valid Data Out Delay from READ Control |  | 170 | ns |  |
| $t_{\text {AD }}$ | Address Stable to Data Out Valid |  | 400 | ns |  |
| tLL | Latch Enable Width | 100 |  | ns |  |
| trif | Data Bus Float after READ | 0 | 100 | ns |  |
| tcl | READ/WRITE Control to Latch Enable | 20 |  | ns |  |
| tcc | READ/WRITE Control Width | 250 |  | ns |  |
| tow | Data In to Write Set Up Time | 150 |  | ns | ; |
| two | Data In Hold Time After WRITE | 10 |  | ns |  |
| twp | WRITE to Port Output |  | 400 | ns |  |
| tPR | Port Input Set Up Time | 50 |  | ns |  |
| trp | Port Input Hold Time | 50 |  | ns |  |
| $t_{\text {RYH }}$ | READY HOLD Time | 0 | 160 | ns |  |
| tary | ADDRESS (CE) to READY |  | 160 | ns | - |
| trv | Recovery Time Between Controls | 300 |  | ns |  |
| trie | READ Control to Data Bus Enable | 10 |  | ns |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT
A.C. TESTING. INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "1" AND 0.45V FOR A LOGIC ' 0 " TIMING MEASUREMENTS ARE MADE AT 2.0 V FOR A LOGIC • 1 ' AND 0.8V FOR A LOGIC " 0
A.C. TESTING LOAD CIRCUIT


18755A<br>16,384-BIT EPROM WITH I/O<br>*Directly Compatible with I8085A CPU.<br>INDUSTRIAL

- Industrial Temperature Range $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$
- 2048 Words $\times 8$ Bits
- Single +5 V Power Supply (Vcc)
- U.V. Erasable and Electrically Reprogrammable
- Internal Address Latch
- 2 General Purpose 8-Bit I/O Ports
- Each I/O Port Line Individually Programmable as Input or Output
- Multiplexed Address and Data Bus
- 40-Pin DIP

The Intel ${ }^{\circledR}$ I8755A is an erasable and electrically reprogrammable ROM (EPROM) and I/O chip to be used in the MCS-85 ${ }^{\circledR}$ 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 I8085A 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.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

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.5 W
*Except for programming voltage
*NOTICE: 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 $\quad\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}= \pm 10 \%$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | 0.7 | 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{IL}}$ | Input Leakage |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\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 |  |
| $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}$ Supply Current |  | 30 | mA | $\mathrm{~V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{f}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | Input/Output Capacitance |  | 15 | pF | $\mathrm{f}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS $\quad\left(T_{A}=-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}= \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CYC}}$ | Clock Cycle Time | 320 |  | ns | $C_{\text {LOAD }}=150 \mathrm{pF}$ |
| T ${ }_{1}$ | CLK Pulse Width | 80 |  | ns |  |
| $\mathrm{T}_{2}$ | CLK Pulse Width | 120 |  | ns |  |
| $t_{f}, t_{r}$ | CLK Rise and Fall Time |  | 30 | ns |  |
| $\mathrm{t}_{\mathrm{AL}}$ | Address to Latch Set Up Time | 60 |  | ns | 150 pF Load |
| $t_{\text {LA }}$ | Address Hold Time after Latch | 90 |  | ns |  |
| $t_{\text {LC }}$ | Latch to READ/WRITE Control | 110 |  | ns |  |
| $t_{\text {RD }}$ | Valid Data Out Delay from READ Control* |  | 180 | ns |  |
| $t_{A D}$ | Address Stable to Data Out Valid** |  | 470 | ns |  |
| $\mathrm{t}_{\mathrm{LL}}$ | Latch Enable Width | 120 |  | ns |  |
| $\mathrm{t}_{\text {RDF }}$ | Data Bus Float after READ | 0 | 100 | ns |  |
| $\mathrm{t}_{\mathrm{CL}}$ | READ/WRITE Control to Latch Enable | 40 |  | ns |  |
| $\mathrm{t}_{\mathrm{CC}}$ | READ/WRITE Control Width | 270 |  | ns |  |
| $t_{\text {DW }}$ | Data In to WRITE Set Up Time | 170 |  | ns |  |
| $t_{\text {WD }}$ | Data In Hold Time After WRITE | 30 |  | ns |  |
| $t_{\text {WP }}$ | WRITE to Port Output |  | 400 | ns |  |
| $t_{\text {PR }}$ | Port Input Set Up Time | 60 |  | ns |  |
| $t_{\text {RP }}$ | Port Input Hold Time | 60 |  | ns |  |
| $\mathrm{t}_{\text {RYM }}$ | READY HOLD TIME | 10 | 160 | ns |  |
| $\mathrm{t}_{\text {ARY }}$ | ADDRESS (CE) to READY) |  | 220 | ns |  |
| $t_{\text {RV }}$ | Recovery Time Between Controls | 350 |  | ns |  |
| $t_{\text {RDE }}$ | Data Out Delay from READ Control | 20 |  | ns |  |

${ }^{*} T_{A D}-\left(T_{A L}+T_{L C}\right)$, whichever is greater.
**Defines ALE to Data Out Valid in conjunction with $\mathrm{T}_{\mathrm{AL}}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## FOREWORD

A rapidly increasing number of military and hi-rel applications are turning toward microprocessor based architectures and high density memory components, taking advantage of the benefits of size, economy, performance and reliability. This demand for high technology LSI products with proven reliability is a natural extension of Intel's historic capabilities.

Intel offers a broad line of LSI components processed and tested to military standards. All standard products are screened to full Class B requirements of MIL-STD-883B, Method 5004. Additionally, complete quality conformance testing is available as a customer option in accordance with MIL-STD-883B, Method 5005.

Intel will continue to demonstrate its commitment to the military/hi-rel market by upgrading the latest breakthroughs in high performance LSI/VLSI technology to military standards. Also, as slash sheets are issued, Intel plans to support additional JAN qualifications.

In 1977, Intel qualified the first military microprocessor under MIL-M-38510. The JAN version of the industry standard 8080A is listed in Part I of the Qualified Products List (QPL-38510) as M38510/42001BQB. See Table I for other JAN qualified products.

Every effort is made to adopt the processing and performance standards set by official military specifications. Table I lists the available versions of each product:

MIL-M-38510: Products qualified to MIL-M-38510 and listed in QPL-38510.
Example: Part number Marking M38510/42001BQB JM38510/42001BQB

883/CLASS B: Intel's standard military product with full Class B processing per MIL-STD-883B, Methods 5004 and 5005.

Example: Part number Marking
MD2716/B MD2716/B
DESC SPEC: Class B products screened to DESC Selected Item Drawing (issued by Defense Electronics Supply Center). DESC specs become obsolete when QPL source for JAN product becomes available.

Example:

| Part number | Marking |
| :--- | :--- |
| 7802201JB | 7802201JB |
|  | MD2716/B |

MIL TEMP ONLY (MTO): Standard commercial processing, guaranteed to meet Intel military data sheet electrical specifications across the rated temperature range. Must be special ordered.

Example:
Part number
Marking
MD2716
S8311

## TABLE I

MILITARY PRODUCTS

| Product | Mil Temp Only (S-spec No.) | $\begin{gathered} 883 / \\ \text { Class B } \end{gathered}$ | Desc Selected Item Drawing | $\begin{gathered} \text { JAN } \\ \text { (MIL-M-38510/XXX) } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| M2114A-4 | S8399 | X |  |  |
| M2114A-5 | S8400 | X |  |  |
| M2114AL-3 | S8401 | X |  |  |
| M2114AL-4 | S8402 | X |  |  |
| M2118-4 | S8403 | X |  |  |
| M2118-7 | S8379 | $x$ |  |  |
| M2147H | S8404 | X |  | 238 |
| M2147H-3 | S8405 | X |  | 238 |
| M2148H | S8406 | X |  | 238* |
| M2167-10 | S8510* | $X$ |  |  |
| M2716 | S8311 | X | 78022 |  |
| M2732 | S8376 | $X$ | 80012 |  |
| M2732A* | S8511** | $X$ |  |  |
| M2764 | S8513* | $X$ |  |  |
| M2816 | S8440 | $X$ |  |  |
| M3632 | S8512* | $X$ |  |  |
| M3636* | S8375 | X |  | 210 |
| M8048 |  | X |  | 490* |
| M8748 | S8502 | X |  | 400 |
| M8035L | S8503 | X |  |  |
| M8080A | S8027 | X |  | 420 |
| M8212 | S8035 | X |  |  |
| M8214 | S8036 | X |  |  |
| M8216 | S8037 | $x$ |  |  |
| M8224 | S8028 | X |  |  |
| M8226 | S8038 | $x$ |  |  |
| M8228 | S8029 | $x$ |  |  |
| M8231A | S8509 | $x$ |  |  |
| M8243 | S8508 | $X$ |  |  |
| M8085A | S8370 | X | 79010 |  |
| M8155 | S8374 | X | 79010 |  |
| M8755A |  | X |  |  |
| M8086 | S8368 | $x$ |  | 530 |
| M8282 | S8375 | $X$ |  |  |
| M8283 |  | $X$ |  |  |
| M8284 | S8372 | X |  |  |
| M8286 | S8373 | $X$ |  |  |
| M8287 |  | X |  |  |
| M8288 | S8371 | X |  |  |
| M8251A | S8504 | $X$ |  |  |
| M8253 | S8505 | X |  |  |
| M8255A | S8032 | $x$ |  |  |
| M8257 |  | X |  |  |
| M8259A | S8506 | X |  |  |
| M8741A | S8507 | X |  |  |

[^37]MILITARY PRODUCT REQUIREMENTS

| General Requirements | MIL-M-38510 <br> Requirements | JAN (Class B) | 883 (Class B) |
| :---: | :---: | :---: | :---: |
| CERTIFICATION <br> A. Product Assurance Program Plan <br> B. Manufacturer's Certification <br> DEVICE QUALIFICATION <br> TRACEABILITY <br> COUNTRY OF MANUFACTURE | Para. 3.4.1.2 <br> Para. 3.4.1.2.1 <br> Para. 4.4 <br> Para. 3.4.6 <br> Para. 3.2.1 | $x$ $x$ $x$ $x$ $x$ $x$ | MIL-STD-883 <br> Requirements <br> Apply |
| Screening Test Requirements | Screening Per Method 5004 of MIL-STD-883 |  |  |
| INTERNAL VISUAL STABILIZATION BAKE | $\begin{aligned} & \text { 2010, Cond. B } \\ & 1008 \text {, Cond. C } \\ & \left(24 \text { Hrs. @ } 150^{\circ} \mathrm{C}\right) \end{aligned}$ | $\begin{aligned} & 100 \% \\ & 100 \% \end{aligned}$ | $\begin{aligned} & 100 \% \\ & 100 \% \end{aligned}$ |
| 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 | $\begin{aligned} & 1014 \text {, Cond. B } \\ & \left(5 \times 10^{-8} \mathrm{~atm}-\mathrm{cc} / \mathrm{sec}\right) \\ & \text { Cond. C } \end{aligned}$ | 100\% | 100\% |
| PRE BURN-IN ELECTRICAL | Per Applicable Device Specification | 100\% | 100\% |
| BURN-IN | 1015, Cond. C or D <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. Functional and Switching (@ $25^{\circ} \mathrm{C}$, Min and Max Rated Temp) | Per Applicable Device Specification Per Applicable Device Specification | $\begin{aligned} & 100 \% \\ & 100 \% \end{aligned}$ | $\begin{aligned} & 100 \% \\ & 100 \% \end{aligned}$ |
| EXTERNAL VISUAL | 2009 | 100\% | 100\% |
| Quality Conformance Inspection Tests | Per MIL-STD-883, Method 5005 | JAN <br> (Level B) | $\begin{gathered} 883 \\ \text { (Level B) } \end{gathered}$ |
| GROUP A Electrical Tests | Per Applicable Device Specification. Table I, Subgroups as Required | Every <br> Inspection <br> Lot | Every Inspection Lot |
| GROUP B Package Function and Mechanical Tests | Per Table IIb, Subgroups $1-3$ | Every 6 <br> Weeks | Available Option |
| GROUP C Die Related Tests | Per Table III, Subgroups 1 and 2 | Every 12 Weeks | Available Option |
| GROUP D <br> Package Related Tests | Per Table IV, Subgroups 1.5 | Every 6 Months | Available Option |

## M2114A <br> 1024 X 4 BIT STATIC RAM

MILITARY

|  | M2114AL-3 | M2114AL-4 | M2114A-4 | M2114A-5 |
| :--- | :---: | :---: | :---: | :---: |
| Max. Access Time (ns) | 150 | 200 | 200 | 250 |
| Max. Current (mA) | 50 | 50 | 70 | 70 |

## - HMOS Technology

- Low Power, High Speed
- Identical Cycle and Access Times
- Single +5 V Supply $\pm 10 \%$
- High Density 18 Pin Package
- Completely Static Memory - No Clock or Timing Strobe Required
- Directly TTL Compatible: All Inputs and Outputs
- Common Data Input and Output Using Three-State Outputs
- M2114 Upgrade
- Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel M2114A is a 4096-bit static Random Access Memory organized as 1024 words by 4 -bits using HMOS, a high performance MOS technology. It uses fully DC stable (static) circuitry throughout, in both the array and the decoding, therefore it requires no clocks or refreshing to operate. Data access is particularly simple since address setup times are not required. The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided.

The M2114A is designed for memory applications where the high performance and high reliability of HMOS, low cost, large bit storage, and simple interfacing are important design objectives. The M2114A 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.


## 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 | -3.5 V to +7 V |
| Power Dissipation | 1.0W |
| D.C. Output Current |  |

*COMMENT: Stresses above those listed under "Absolute Maxı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 sectıons of this specificatıon is not implied. Exposure 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 \%$, unless otherwise noted.

| SYMBOL | PARAMETER | M2114AL-3/L-4 |  |  | M2114A-4/-5 |  |  | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{\text {" }}$ | Max. | Min. | Typ. ${ }^{\text {'1 }}$ | Max. |  |  |
| ᄂ | Input Load Current (All Input Pins) |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $V_{\text {IN }}=0$ to 5.5 V |
| ILO | I/O Leakage Current |  |  | 10 |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{1 H} \\ & \mathrm{~V}_{1 / O}=G N D \text { to } V_{C C} \end{aligned}$ |
| Icc | Power Supply Current |  | 25 | 50 |  | 50 | 70 | mA | $\begin{aligned} & V_{C C}=\max , I_{I / O}=0 \mathrm{~mA}, \\ & T_{A}=-55^{\circ} \mathrm{C} \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage | -3.0 |  | 0.8 | -3.0 |  | 0.8 | V |  |
| $V_{1 H}$ | Input High Voltage | 2.0 |  | 6.0 | 2.0 |  | 6.0 | $\checkmark$ |  |
| los | Output Low Current | 2.1 | 9.0 |  | 2.1 | 9.0 |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| 1 OH | Output High Current | -1.0 | -2.5 |  | -1.0 | -2.5 |  | mA | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| los ${ }^{2}$ ) | Output Short Circuit Current |  |  | 40 |  |  | 40 | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ |

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 |
| :--- | :--- | :---: | :---: | :--- |
| $\mathrm{C}_{1 / O}$ | Input/Output Capacitance | 5 | pF | $\mathrm{V}_{1 / O}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V}$ |

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

Output Load................................................ 1 TTL Gate and $C_{L}=100 \mathrm{pF}$

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

NORMALIZED ACCESS TIME VS.
SUPPLY VOLTAGE


NORMALIZED ACCESS TIME VS. AMBIENT TEMPERATURE


NORMALIZED POWER SUPPLY CURRENT VS. AMBIENT TEMPERATURE

$\mathrm{T}_{\mathrm{A}}\left({ }^{\circ} \mathrm{C}\right)$

OUTPUT SINK CURRENT VS. OUTPUT VOLTAGE

$\mathrm{V}_{\mathrm{OL}}(\mathrm{V})$

## M2114A FAMILY

A.C. CHARACTERISTICS $\quad 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]}$

|  | PARAMETER | M2114AL-3 |  | M2114A-4/L-4 |  | M2114A-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{BC}}$ | Read Cycle Time | 150 |  | 200 |  | 250 |  | ns |
| $t_{A}$ | Access Time |  | 150 |  | 200 |  | 250 | ns |
| $t_{\text {co }}$ | Chip Selection to Output Valid |  | 70 |  | 70 |  | 85 | ns |
| $\mathrm{t}_{\mathrm{cx}}$ | Chip Selection to Output Active | 10 |  | 10 |  | 10 |  | ns |
| toto | Output 3-state from Deselection |  | 40 |  | 50 |  | 60 | ns |
| toha | Output Hold from Address Change | 15 |  | 15 |  | 15 |  | ns |

WRITE CYCLE ${ }^{[2]}$

|  | PARAMETER | M2114AL-3 |  | M2114A-4/L-4 |  | M2114A-5 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYMBOL |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| twc | Write Cycle Time | 150 |  | 200 |  | 250 |  | ns |
| $\mathrm{t}_{\mathrm{w}}$ | Write Time | 90 |  | 120 |  | 135 |  | ns |
| twr | Write Release Time | 0 |  | 0 |  | 0 |  | ns |
| torw | Output 3-state from Write |  | 40 |  | 50 |  | 60 | ns |
| tow | Data to Write Time Overlap | 90 |  | 120 |  | 135 |  | ns |
| tor | Data Hold from Write Time | 0 |  | 0 |  | 0 |  | ns |

## NOTES:

1. A Read occurs during the overlap of a low $\overline{C S}$ and a high $\overline{W E}$.
2. A Write occurs during the overlap of a low $\overline{C S}$ and a low $\overline{W E} . t_{W}$ is measured from the latter of $\overline{C S}$ or $\overline{W E}$ going low to the earlier of $\overline{C S}$ or $\overline{W E}$ going high.

## WAVEFORMS

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


## NOTES:

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

## WRITE CYCLE


intel
PRRELDNONARY

# M2118 FAMILY <br> 16,384 x 1 BIT DYNAMIC RAM 

MILITARY

|  | M2118-4 | M2118.7 |
| :--- | :---: | :---: |
| Maximum Access Time (ns) | 120 | 150 |
| Read, Write Cycle $(\mathbf{n s})$ | 270 | 320 |
| Read-Modify Cycle $(\mathbf{n s})$ | 320 | 410 |

Single +5V Supply, $\pm 10 \%$ Tolerance<br>- HMOS Technology<br>- Low Power: 150 mW Max. Operating 11 mW Max. Standby<br>- Low VDD Current Transients<br>- All Inputs, Including Clocks, TTL Compatible

## $\overline{\text { CAS }}$ Controlled Output is Three-State, TTL Compatible <br> RAS Only Refresh <br> - 128 Refresh Cycles Required Every 2 ms <br> - Allows Negative Overshoot $\mathrm{V}_{\mathrm{IL}} \min =-2 \mathrm{~V}$ <br> Military Temperature Range $-55^{\circ}$ to $+85^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ M2118 is a 16,384 word by 1 -bit Dynamic MOS RAM designed to operate from a single +5 V power supply. The M2118 is fabricated using HMOS-a production proven process for high performance, high reliability, and high storage density.

The M2118 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 M2118 in a system environment.
Multiplexing the 14 address bits into the 7 address input pins allows the M2118 to be packaged in the industry standard 16-pin DIP. The two 7-bit address words are latched into the M2118 by the two TTL clocks, Row Address Strobe (RAS) and Column Address Strobe (CAS). Non-critical timing requirements for RAS and $\overline{\mathrm{CAS}}$ allow use of the address multiplexing technique while maintaining high performance.
The M2118 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 single transistor storage cell requires refreshing for data retention. Refreshing is accomplished by performing $\overline{\text { RAS }}$ only 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 .... $-65^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ Storage Temperature . . . . . . . . . . . . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Voltage on any Pin Relative to $\mathrm{V}_{\text {SS }} \ldots . . .$.
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]}$

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

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{(2)}$ | Max |  |  |  |
| \|lil| | Input Load Current (any input) |  | 0.1 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {SS }}$ to $\mathrm{V}_{\text {DD }}$ |  |
| \|lol | 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.2 | 2 | mA | $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{RAS}}$ at $\mathrm{V}_{1 H}$ |  |
| IDD2 | VDD Supply Current, Operating |  | 21 | 25 | mA | M2118-4, $\mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\mathrm{RCMIN}}$ | 3 |
|  |  |  | 19 | 23 | mA | M2118-7, $\mathrm{t}_{\text {RC }}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
| IDD3 | VDD Supply Current; $\overline{\text { RAS }}$-Only Cycle |  | 14 | 16 | mA | M2118-4, $\mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\text {RCMIN }}$ | 3 |
|  |  |  | 12 | 14 | mA | M2118-7, $\mathrm{t}_{\mathrm{RC}}=\mathrm{t}_{\mathrm{RCMIN}}$ | 3 |
| IDD5 | VDD Supply Current, Standby, Output Enabled |  | 2 | 4 | mA | $\overline{\text { CAS }}$ at $V_{\text {IL }}, \overline{\text { RAS }}$ at $V_{\text {IH }}$ | 3 |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage (all inputs) | -2.0 |  | 0.8 | V |  |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (all inputs) | 2.4 |  | 7.0 | V |  |  |
| VOL | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=4.2 \mathrm{~mA}$ |  |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-5 \mathrm{~mA}$ |  |

## NOTES:

1. All voltages referenced to $V_{\text {SS }}$
2. Typical values are for $T A=25^{\circ} \mathrm{C}$ and nominal supply voltages.
3. $I_{D D}$ is dependent on output loading when the device output is selected. Specified $I_{D D}$ MAX is measured with the output open.

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

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

| Symbol | Parameter | Typ | Max | Unit |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{11}$ | Address, Data In | 3 | 5 | pF |
| $\mathrm{C}_{12}$ | $\overline{\text { RAS, } \overline{\mathrm{CAS}}, \overline{\mathrm{WE}}, \text { Data Out }}$ | 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 ${ }^{[1,2,3]}$

$\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V} \pm 10 \%$, $\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}$, unless otherwise noted.
READ, WRITE, READ-MODIFY-WRITE AND REFRESH CYCLES

| Symbol | Parameter | M2118-4 |  | M2118.7 |  | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| trac | Access Time From $\overline{\mathrm{RAS}}$ |  | 120 |  | 150 | ns | 4.5 |
| tcac | Access Time From $\overline{\text { CAS }}$ |  | 65 |  | 80 | ns | 4,5,6 |
| tref | Time Between Refresh |  | 2 |  | 2 | ms |  |
| tRP | $\overline{\text { RAS }}$ Precharge Time | 120 |  | 135 |  | ns |  |
| tCPN | $\overline{\mathrm{CAS}}$ Precharge Time (non-page cycles) | 55 |  | 70 |  | ns |  |
| tCRP | $\overline{\text { CAS }}$ to $\overline{\mathrm{RAS}}$ Precharge Time | 0 |  | 0 |  | ns |  |
| trco | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{CAS}}$ Delay Tıme | 25 | 55 | 25 | 70 | ns | 7 |
| trsh | $\overline{\text { RAS }}$ Hold Time | 85 |  | 105 |  | ns |  |
| tcsh | $\overline{\text { CAS }}$ Hold Time | 120 |  | 165 |  | ns |  |
| task | Row Address Set-Up Time | 0 |  | 0 |  | ns |  |
| $t_{\text {RAH }}$ | Row Address Hold Time | 15 |  | 15 |  | ns |  |
| tasc | Column Address Set-Up Time | 0 |  | 0 |  | ns |  |
| tcan | Column Address Hold Time | 15 |  | 20 |  | ns |  |
| $t_{A R}$ | Column Address Hold Time, to $\overline{\text { RAS }}$ | 70 |  | 90 |  | ns |  |
| $t$ | Transition Time (Rise and Fall) | 3 | 50 | 3 | 50 | ns | 8 |
| toff | Output Buffer Turn Off Delay | 0 | 50 | 0 | 60 | ns |  |

READ AND REFRESH CYCLES

| tre | Random Read Cycle Time | 270 |  | 320 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tras | $\overline{\text { RAS Pulse Width }}$ | 140 | 10000 | 175 | 10000 | ns |  |
| tcas | $\overline{\text { CAS Pulse Width }}$ | 65 | 10000 | 95 | 10000 | ns |  |
| trcs | Read Command Set-Up Time | 0 |  | 0 |  | ns |  |
| $\mathrm{trch}^{\text {r }}$ | Read Command Hold Time | 0 |  | 0 |  | ns |  |

## WRITE CYCLE

| $t_{\text {PC }}$ | Random Write Cycle Time | 270 |  | 320 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tras | $\overline{\text { RAS Pulse Width }}$ | 140 | 10000 | 175 | 10000 | ns |  |
| tcas | $\overline{\text { CAS Pulse Width }}$ | 65 | 10000 | 95 | 10000 | ns |  |
| twCs | Write Command Set-Up Time | 0 |  | 0 |  | ns | 9 |
| twCH | Write Command Hold Time | 30 |  | 45 |  | ns |  |
| tWCR | Write Command Hold Time, to $\overline{\text { RAS }}$ | 85 |  | 115 |  | ns |  |
| twp | Write Command Pulse Width | 30 |  | 50 |  | ns |  |
| trwL | Write Command to $\overline{\text { RAS }}$ Lead Time | 65 |  | 110 |  | ns |  |
| tcwl | Write Command to $\overline{C A S}$ Lead Time | 50 |  | 100 |  | ns |  |
| tos | Data-In Set-Up Time | 0 |  | 0 |  | ns |  |
| toh | Data-In Hold Time | 30 |  | 45 |  | ns |  |
| tDHR | Data-In Hold Time, to $\overline{\mathrm{RAS}}$ | 85 |  | 115 |  | ns |  |

READ-MODIFY-WRITE CYCLE

| trwe | Read-Modify-Write Cycle Time | 320 |  | 410 |  | ns |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| traw | RMW Cycle $\overline{\mathrm{RAS}}$ Pulse Width | 190 | 10000 | 265 | 10000 | ns |  |
| tcrw | RMW Cycle $\overline{\text { CAS }}$ Pulse Width | 120 | 10000 | 185 | 10000 | ns |  |
| trwo | $\overline{\mathrm{RAS}}$ to $\overline{\mathrm{WE}}$ Delay | 120 |  | 150 |  | ns | 9 |
| tcwo | $\overline{\mathrm{CAS}}$ to $\overline{\mathrm{WE}}$ Delay | 65 |  | 80 |  | ns | 9 |

NOTES:

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{\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 tRCD (max.).
5. Load $=2 \mathrm{~T}$ L 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 tRCD is less than $t_{R C D}$ (max.) access time is tRAC. If tRCD is greater than tRCD (max.) access time is trCD + tcAC .
8. $\quad t_{T}$ is measured between $\mathrm{V}_{\mathrm{IH}}$ (min.) and $\mathrm{V}_{\mathrm{IL}}$ (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 tcwo $\geq$ tCWD (min.) and tRWD $\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


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 \|_{\text {Lo }} \mid$.
6. TOS AND tDH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.

8 tcRP REQUIREMENT IS ONLY APPLICABLE FOR $\overline{R A S} / \overline{C A S} C Y C L E S ~ P R E C E E D E D ~ B Y ~ A ~ \overline{C A S}-$ ONLY CYCLE (I, e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

## WAVEFORMS

READ-MODIFY-WRITE CYCLE


RAS-ONLY REFRESH CYCLE


NOTES: 1,2. $V_{I H \text { 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 DOUT.
5. toff is Measured to lout $\leqslant \|$ lol.
6. tDS AND tDH ARE REFERENCED TO $\overline{C A S}$ OR $\overline{W E}$, WHICHEVER OCCURS LAST.
7. ${ }^{\text {TCRP REQUIREMENT IS ONLY APPLICABLE FOR } \overline{R A S} / \overline{C A S}}$ CYCLES PRECEEDED BY A $\overline{C A S}-$ ONLY CYCLE (i.e., FOR SYSTEMS WHERE CAS HAS NOT BEEN DECODED WITH RAS).

|  | M2147H-3 | M2147H |
| :--- | :---: | :---: |
| Max. Access Time (ns) | 55 | 70 |
| Max. Active Current (mA) | 180 | 180 |
| Max. Standby Current (mA) | 30 | 30 |

- Pinout, Function, and Power Compatible to Industry Standard M2147
- HMOS II Technology
- Completely Static Memory-No Clock or Timing Strobe Required
- Equal Access and Cycle Times
- Single +5V Supply
- Direct Performance Upgrade for M2147
- Automatic Power-Down
- High Density 18-Pin Package
- Separate Data Input and Output
- Three-State Output
- Full Military Temperature Range
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR} \mathrm{M} 2147 \mathrm{H}$ is a 4096 -bit static Random Access Memory organized as 4096 words by 1 -bit using HMOS II, Intel's next generation 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 M 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 M 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 | $V_{C C}$ | POWER $(+5 V)$ |
| :--- | :--- | :--- | :--- |
| $\overline{W E}$ | WRITE ENABLE | GND | GROUND |
| $\overline{C S}$ | CHIP SELECT |  |  |
| $D_{\text {IN }}$ | DATA $\operatorname{INPUT}$ |  |  |
| $D_{\text {OUT }}$ | DATA OUTPUT |  |  |

TRUTH TABLE

| $\overline{C S}$ | $\overline{W E}$ | MODE | OUTPUT | POWER |
| :---: | :---: | :---: | :---: | :---: |
| $H$ | $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 . . . . . . . . . . $-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 ..... -3.5 V to +7 V
Power Dissipation ..... 1.2 W
D.C. Output Current ..... 20 mA
*COMMENT: Stresses above those listed under "Abso lute 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}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.)

| Symbol | Parameter | M2147H-3, M2147H |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{[2]}$ | Max |  |  |
| $\mathrm{I}_{\text {LI }}$ | Input Load Current (All Input Pins) |  | 0.01 | 10 | $\mu \mathrm{A}$ | $V_{C C}=$ Max., $V_{\text {IN }}=G N D$ to $V_{C C}$ |
| $\mid \mathrm{L}$ LO | Output Leakage Current |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{C S}=V_{I H}, V_{C C}=\text { Max., } \\ & V_{\text {OUT }}=G N D \text { to } 4.5 \mathrm{~V} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Operating Current |  | 120 | 170 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \quad \mathrm{V}_{\mathrm{CC}}=$ Max., $\overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}}$, |
|  |  |  |  | 180 | mA | $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ Outputs Open |
| $\mathrm{I}_{\text {SB }}$ | Standby Current |  | 18 | 30 | mA | $V_{C C}=$ Min. to Max., $\overline{C S}=V_{I H}$ |
| $\mathrm{IPO}^{[3]}$ | Peak Power-On Current |  | 35 | 70 | mA | $\begin{aligned} & V_{\mathrm{CC}}=\mathrm{GND} \text { to } \mathrm{V}_{\mathrm{CC}} \mathrm{Min} . \\ & \mathrm{CS}=\text { Lower of } \mathrm{V}_{\mathrm{CC}} \text { or } \mathrm{V}_{\mathrm{IH}} \text { Min. } \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $-3.0$ |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | 6.0 | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-4.0 \mathrm{~mA}$ |
| Ios | Output Short Circuit Current | -200 |  | $+200$ | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}, \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ |

## 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 Load A .
3. A pull-up resistor to $\mathrm{V}_{\mathrm{CC}}$ on the $\overline{\mathrm{CS}}$ input is required to keep the device deselected; otherwise, power-on current approaches $\mathrm{I}_{\mathrm{CC}}$ active.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.0V |
| :--- | ---: |
| Input Rise and Fall Times | 5 ns |
| Input Timing Reference Levels | 1.5 V |
| Output Timing Reference Levels | $0.8-2.0 \mathrm{~V}$ |
| Output Load | See Load A |

CAPACITANCE ${ }^{[4]}\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| 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:
4. This parameter is sampled and not $100 \%$ tested.


Load A


Load B
A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.)

Read Cycle

| Symbol | Parameter | $\begin{aligned} & \text { M2147H-3 } \\ & \text { Min } \quad \operatorname{Max} \end{aligned}$ | $\begin{aligned} & \text { M2147H } \\ & \text { Min Max } \end{aligned}$ | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{RC}}{ }^{[1]}$ | Read Cycle Time | 55 | 70 | ns |  |
| $t_{\text {AA }}$ | Address Access Time | 55 | 70 | ns |  |
| $t_{\text {ACS } 1}$ | Chip Select Access Time | 55 | 70 | ns | Note 8 |
| $\mathrm{t}_{\text {ACS2 }}$ | Chip Select Access Time | 65 | 80 | ns | Note 9 |
| ${ }^{\text {toh }}$ | Output Hold from Address Change | 5 | 5 | ns |  |
| $\mathrm{t}_{\mathrm{Lz}}{ }^{[2,7]}$ | Chip Selection to Output in Low Z | 10 | 10 | ns | Note 3 |
| $\mathrm{t}_{\mathrm{HZ}}{ }^{[2,7]}$ | Chip Deselection to Output in High Z | 030 | $0 \quad 40$ | ns | Note 3 |
| $t_{\text {PU }}$ | Chip Selection to Power Up Time | 0 | 0 | ns |  |
| ${ }_{\text {tPD }}$ | Chip Deselection to Power Down Time | 20 | 30 | ns |  |

## WAVEFORMS

Read Cycle No. $1^{[4,5]}$


Read Cycle No. $2^{[4,6]}$


## NOTES:

1. All Read Cycle timings are referenced from the last valid address to the first transitioning address.
2. 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.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with Load B.
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.
7. This parameter is sampled and not $100 \%$ tested.
8. Chip deselected for greater than 55 ns prior to selection.
9. Chip deselected for a finite time that is less than 55 ns prior to selection. (If the deselect time is 0 ns , the chip is by definition selected and access occurs according to Read Cycle No. 1)

## A.C. CHARACTERISTICS (Continued)

## Write Cycle

| Symbol | Parameter | M2147H-3 <br> Min Max | $\begin{aligned} & \text { M2147H } \\ & \text { Min } \quad \text { Max } \end{aligned}$ | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{w c}{ }^{[2]}$ | Write Cycle Time | 55 | 70 | ns |  |
| ${ }_{\text {t }}$ W | 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 |  |
| $t_{\text {WP }}$ | Write Pulse Width | 25 | 40 | ns |  |
| $t_{\text {WR }}$ | Write Recovery Time | 10 | 15 | ns |  |
| $t_{\text {DW }}$ | Data Valid to End of Write | 25 | 30 | ns |  |
| ${ }^{\text {t }}$ DH | Data Hold Time | 10 | 10 | ns |  |
| $t_{\text {Wz }}$ | Write Enabled to Output in High Z | $0 \quad 25$ | $0 \quad 35$ | ns | Note 3 |
| tow | Output Active from End of Write | 0 | 0 | ns | Note 3 |

## WAVEFORMS

Write Cycle No. 1 ( $\overline{W E}$ CONTROLLED) ${ }^{[4]}$


Write Cycle No. 2 ( $\overline{C S}$ CONTROLLED) ${ }^{[4]}$

## NOTES:



1. If $\overline{\mathrm{CS}}$ goes high simultaneously with $\overline{\mathrm{WE}}$ high, the output remains in a high impedance state.
2. All Write Cycle timings are referenced from the last valid address to the first transitioning address.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with Load B.
4. $\overline{\mathrm{CS}}$ or $\overline{\mathrm{WE}}$ must be high during address transitions.

# MILITARY 

|  | M2148H |
| :--- | ---: |
| Max. Access Time (ns) | 70 |
| Max. Active Current (mA) | 180 |
| Max. Standby Current (mA) | 30 |

## - HMOS II 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
- Industry Standard M2114A Pinout
- Common Data Input and Output
- Three-State Output
- Full Military Temperature Range $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ M2148H is a 4096 -bit static Random Access Memory organized as 1024 words by 4 bits using HMOS II, a 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-disabling the M 2148 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 disabled.
The M 2148 H 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.


PIN NAMES

| $A_{0}-A_{9}$ | ADDRESS INPUTS |
| :--- | :--- |
| $\overline{W E}$ | WRITE ENABLE |
| $\overline{C S}$ | CHIP SELECT |
| $/ / O_{1}-I / O_{4}$ | DATA INPUT/OUTPUT |
| $V_{C C}$ | POWER ( +5 V ) |
| GND | GROUND |

TRUTH TABLE

| $\overline{\text { CS }}$ | WE | MODE | I/O | POWER |
| :---: | :---: | :---: | :---: | :---: |
| H | X | NOT SELECTED | HIGH-Z | STANDBY |
| L | L | WRITE | $\mathrm{D}_{\text {IN }}$ | ACTIVE |
| L | H | READ | Dout | ACTIVE |

BLOCK DIAGRAM


## 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 | 3.5 V to +7 V |
| Power Dissipation | 1.2W |
| .C. Output Curren | 20 m |

*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]}$

( $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted.)

| Symbol | Parameter | M2148H |  |  | Unit | Test Conditions |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{[2]}$ | Max |  |  |  |
| $I_{L I}$ | Input Load Current (All Input Pins) |  | 0.01 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=$ Max., $\mathrm{V}_{\text {IN }}=\mathrm{GND}$ to $\mathrm{V}_{\mathrm{CC}}$ |  |
| $\mid \mathrm{l}$ Lo ${ }^{\text {l }}$ | Output Leakage Current |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{H}}, \mathrm{~V}_{\mathrm{CC}}=\text { Max., } \\ & \mathrm{V}_{\text {OUT }}=\mathrm{GND} \text { to } 4.5 \mathrm{~V} \end{aligned}$ |  |
| ICC | Operating Current |  | 120 | 180 | mA | $\mathrm{T}_{\text {A }}=-55^{\circ} \mathrm{C}$ | $V_{\mathrm{CC}}=\text { Max. }, \overline{\mathrm{CS}}=\mathrm{V}_{\mathrm{IL}},$ <br> Outputs Open |
| $\mathrm{I}_{\text {SB }}$ | Standby Current |  | 15 | 30 | mA | $\mathrm{V}_{\mathrm{CC}}=$ Min. to Max., $\overline{\mathrm{CS}}=\mathrm{V}_{1 H}$ |  |
| $\mathrm{IPO}^{[3]}$ | Peak Power-On Current |  | 25 | 50 | mA | $\begin{aligned} & V_{C C}=G N D \text { to } V_{C C} M i n . \\ & C S=\text { Lower of } V_{C C} \text { or } V_{I H} \text { Min. } \end{aligned}$ |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | $-3.0$ |  | 0.8 | V |  |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.1 |  | 6.0 | V |  |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=8 \mathrm{~mA}$ |  |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-4.0 \mathrm{~mA}$ |  |
| $\mathrm{los}^{\text {[4] }}$ | Output Short Circuit Current |  | $\pm 200$ |  | mA | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ | o $\mathrm{V}_{\mathrm{CC}}$ |

## 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 Load A .
3. A pull-up resistor to $\mathrm{V}_{C C}$ on the $\overline{\mathrm{CS}}$ input is required to keep the device deselected; otherwise, power-on current approaches $I_{C C}$ active.
4. Duration not to exceed one second.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | ---: |
| Input Rise and Fall Times <br> Input and Output Timing Reference <br> Levels | 5 ns |
| Output Load | 1.5 V |
|  | See Load A |

CAPACITANCE ${ }^{[4]}\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$

| Symbol | Parameter | Max. | Unit | Conditions |
| :---: | :--- | :---: | :---: | :---: |
| $\mathrm{C}_{I N}$ | Input Capacitance | 5 | pF | $\mathrm{V}_{I N}=0 \mathrm{~V}$ |
| $\mathrm{C}_{/ / O}$ | Input/Output <br> Capacitance | 7 | pF | $\mathrm{V}_{I / O}=0 \mathrm{~V}$ |

## NOTE:

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


Load A


Load B
A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$ unless otherwise noted.)

Read Cycle

| Symbol | Parameter | M2148H |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| $t_{\text {RC }}$ | Read Cycle Time | 70 |  | ns |  |
| $t_{\text {AA }}$ | Address Access Time |  | 70 | ns |  |
| $t_{\text {ACS } 1}$ | Chip Select Access Time |  | 70 | ns | Note 1 |
| $\mathrm{t}_{\text {ACS2 }}$ | Chip Select Access Time |  | 80 | ns | Note 2 |
| $\mathrm{t}_{\mathrm{OH}}$ | Output Hold from Address Change | 5 |  | ns |  |
| $\mathrm{t}_{\text {LZ }}$ | Chip Selection Output in Low Z | 20 |  | ns | Note 6 |
| $t_{H Z}$ | Chip Deselection to Output in High Z | 0 | 20 | ns | Note 6 |
| $t_{\text {PU }}$ | Chip Selection to Power Up Time | 0 |  | ns |  |
| $t_{\text {PD }}$ | 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 $\overline{\mathrm{CS}}$ transition low.
2. Chip deselected for a finite time that is less than 55 ns prior to $\overline{\mathrm{CS}}$ transition low. (If the deselect time is 0 ns , the chip is by definition selected and access occurs according 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. Address valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
6. Transition is measured $\pm 500 \mathrm{mV}$ from high impedance voltage with Load $B$. This parameter is sampled and not $100 \%$ tested.

## A.C. CHARACTERISTICS (Continued)

## Write Cycle

| Symbol |  | M2148H |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Parameter | Min | Max |  |  |
| $t_{\text {wc }}$ | Write Cycle Time | 70 |  | ns |  |
| $\mathrm{t}_{\mathrm{CW}}$ | Chip Selection to End of Write | 65 |  | ns |  |
| $t_{\text {AW }}$ | Address Valid to End of Write | 65 |  | ns |  |
| $t_{\text {AS }}$ | Address Setup Time | 0 |  | ns |  |
| $t_{\text {WP }}$ | Write Pulse Width | 50 |  | ns |  |
| $t_{\text {WR }}$ | Write Recovery Time | 5 |  | ns |  |
| $t_{\text {DW }}$ | Data Valid to End of Write | 25 |  | ns |  |
| $t_{\text {DH }}$ | Data Hold Time | 0 |  | ns |  |
| $t_{\text {wz }}$ | Write Enabled to Output in High Z | 0 | 25 | ns | Note 2 |
| tow | Output Active from End of Write | 0 |  | ns | Note 2 |

## WAVEFORMS

## Write Cycle No. 1

( $\overline{W E}$ CONTROLLED)


## Write Cycle No. 2

(CS CONTROLLED)


NOTES:

1. If $\overline{C S}$ goes high simultaneously with $\overline{W E}$ high, the output remains in a high impedance state.
2. Transition is measured $\pm 500 \mathrm{mV}$ from high impedance voltage with Load B . This parameter is sampled and not $100 \%$ tested.

# M2167-10 HIGH SPEED 16,384 x 1 BIT STATIC RAM 

MILITARY

| Max Access Time (ns) | 100 |
| :--- | :---: |
| Max Active Current (mA) | 150 |
| Max Standby Current (mA) | 75 |

■ M2147H Upgrade<br>- Double Poly HMOS II Technology<br>- Equal Access and Cycle Times<br>- Single +5V Supply<br>- Automatic Power Down<br>- Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

■ 0.8-2.0V Output Timing Reference Levels<br>- High Density 20-Pin Package<br>- Completely Static Memory-No Clock or Timing Strobe Required<br>- Separate Data Input and Output<br>- Three-State Output

The Intel M2167 is a 16,384-bit static Random Access Memory organized as 16,384 words by 1 bit. This memory is fabricated using Intel's high-density, high-performance technology-Double Poly HMOS II. This state of the art technology brings high-density to high-performance static RAMs. The design of the M2167 offers a $4 x$ density improvement over the industry standard M2147H with compatible performance. The M2167 offers the automatic power-down feature pioneered by the Intel M2147H.
$\overline{\mathrm{CS}}$ controls the power-down feature. In less than a cycle time after $\overline{\mathrm{CS}}$ goes high (deselecting the M2167), 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 $50 \%$ in larger systems where the majority of devices are deselected.
The M2167 is placed in a 20-pin package configured with the industry standard $16 \mathrm{~K} \times 1$ pinout, offering the industry's highest density 16K static RAM. 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.


Figure 1. M2167-10 Block Diagram

PIN NAMES


$$
\begin{array}{cc}
A_{0}\left[\begin{array}{ll}
1 & 20 \\
A_{1} & V_{C C} \\
A_{2} & 19
\end{array} A_{13}\right. \\
A_{3} & 18 \\
A_{3} & 17 \\
A_{4} & A_{12} \\
A_{11} & 16
\end{array} A_{10}
$$

Figure 2. M2167-10 Pin Configuration

| PIN | ADDRESS | FUNCTION |
| :---: | :---: | :---: |
| 17 | $A_{11}$ | $X_{0}$ |
| 18 | $A_{12}$ | $X_{1}$ |
| 19 | $A_{13}$ | $X_{2}$ |
| 1 | $A_{0}$ | $X_{3}$ |
| 2 | $A_{1}$ | $X_{4}$ |
| 3 | $A_{2}$ | $X_{5}$ |
| 4 | $A_{3}$ | $X_{6}$ |
| 13 | $A_{7}$ | $Y_{0}$ |
| 7 | $A_{6}$ | $Y_{1}$ |
| 15 | $A_{9}$ | $Y_{2}$ |
| 6 | $A_{5}$ | $Y_{3}$ |
| 16 | $A_{10}$ | $Y_{4}$ |
| 5 | $A_{4}$ | $Y_{5}$ |
| 14 | $A_{8}$ | $Y_{6}$ |



Figure 3. M2167-10 Logic Symbol

## ABSOLUTE MAXIMUM RATINGS*

*NOTICE: 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 ${ }^{(1)}\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%$, unless otherwise noted)

| Symbol | Parameter | M2167-10 |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{(2)}$ | Max |  |  |
| ILI | Input Load Current (All Input Pins) |  | 0.01 | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=\mathrm{Max}, \mathrm{V}_{\text {IN }}=\mathrm{GND}$ to $\mathrm{V}_{\text {CC }}$ |
| $\mid \mathrm{L}$ LO\| | Output Leakage Current |  | 0.1 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \overline{\mathrm{CS}}=\mathrm{V}_{I H}, V_{C C}=\operatorname{Max}, \\ & \mathrm{V}_{\mathrm{OUT}}=\mathrm{GND} \text { to } 4.5 \mathrm{~V} \end{aligned}$ |
| ${ }^{\prime} \mathrm{CC}$ | Operating Current |  |  | 150 | mA | $\begin{aligned} & \mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Max}, \\ & \mathrm{CS}=\mathrm{V}_{\mathrm{IL}}, \text { Outputs Open } \end{aligned}$ |
| ISB | Standby Current |  | 60 | 75 | mA | $\mathrm{V}_{\mathrm{CC}}=$ Min. to Max, $\overline{\mathrm{CS}}=\mathrm{V}_{\text {IH }}$ |
| $1 \mathrm{PO}{ }^{(3)}$ | Peak Power-On Current |  | 70 | 90 | mA | $V_{C C}=G N D$ to $V_{C C}$ Min., $\overline{\mathrm{CS}}=$ Lower of $\mathrm{V}_{\mathrm{CC}}$ or $V_{\text {IH }}$ Min. |
| $V_{\text {IL }}$ | Input Low Voltage | -3.0 |  | 0.8 | V |  |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | 6.0 | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{IOL}=8 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-4.0 \mathrm{~mA}$ |

Notes:

1. The operating ambient temperature is guaranteed with transverse air flow exceeding 400 linear feet per minute.
2. Typical limits are at $V_{C C}=5 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$, and specified loading.
3. 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.

## A.C. TEST CONDITIONS

| Input Pulse Levels | GND to 3.0 V |
| :--- | ---: |
| Input Rise and Fall Times | 5 ns |
| Input Timing Reference Level | 1.5 V |
| Output Timing Reference Levels | $0.8-2.0 \mathrm{~V}$ |
| Output Load | See Figure 4 |

## CAPACITANCE*

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

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

[^38]

Figure 4. Output Load


Figure 5. Output Load for $\mathrm{t}_{\mathrm{HZ}}$, tLZ, twz, tow
A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$, unless otherwise noted)

READ CYCLE

| Symbol | Parameter | M2167-10 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $t_{R} C^{(1)}$ | Read Cycle Time | 100 |  | ns |
| $\mathrm{t}_{\text {AA }}$ | Address Access Time |  | 100 | ns |
| ${ }^{\text {taCS }}$ | Chip Select Access Time |  | 100 | ns |
| ${ }^{\text {toh }}$ | Output Hoid from Access Change | 5 |  | ns |
| $\mathrm{t}_{\mathrm{L}} \mathrm{Z}^{(2,3)}$ | Chip Selection to Output in Low Z | 10 |  | ns |
| $\mathrm{t}_{\mathrm{H}} \mathrm{Z}^{(2,3)}$ | Chip Deselection to Output in High Z | 0 | 40 | ns |
| tPU | Chip Selection to Power-Up Time | 55 |  | ns |
| tPD | Chip Deselection to Power-Down Time |  | 80 | ns |

## WAvEFORMS

## READ CYCLE NO. $1^{(4,5)}$



READ CYCLE NO. $\mathbf{2}^{(4,6)}$


## Notes:

1. All Read Cycle timings are referenced from the last valid address to the first transitioning address.
2. 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.
3. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 5. This parameter is sampled and not $100 \%$ tested.
4. $\overline{W E}$ is high for Read Cycles.
5. Device is continuously selected, $\overline{C S}=V_{I L}$.
6. Addresses valid prior to or coincident with $\overline{\mathrm{CS}}$ transition low.
A.C. CHARACTERISTICS (Continued)

WRITE CYCLE


## WAVEFORMS

WRITE CYCLE \#1 (WE CONTROLLED) ${ }^{(3)}$


WRITE CYCLE \#2 (CS CONTROLLED) ${ }^{(3)}$


## Notes:

1. All Write Cycle timings are referenced from the last valid address to the first transitioning address.
2. Transition is measured $\pm 500 \mathrm{mV}$ from steady state voltage with specified loading in Figure 5 . This parameter is sampled and not $100 \%$ tested.
3. $\overline{\mathrm{CS}}$ or $\overline{\mathrm{WE}}$ must be high during address transitions.
4. If $\overline{C S}$ goes high simultaneously with $\overline{W E}$ high, the output remains in a high impedance state.

M2716/M2716M

## 16K (2K x 8) UV ERASABLE PROM

## MILITARY

\author{

- Military Temperature Range <br> M2716M: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ <br> M2716: $-55^{\circ} \mathrm{C}$ to $100^{\circ} \mathrm{C}$ <br> - $5 \mathrm{~V} \pm 10 \% \mathrm{~V}_{\mathrm{cc}}$
}
a Pin Compatible to Intel's M2732 32K EPROM
- Fast Access Time; 450 ns maximum
- Static Standby Mode
- Low Power Dissipation of 165 mW maximum standby power
- Inputs and Outputs TTL Compatible during Read and Program

The Intel ${ }^{\circledR}$ M2716M and M2716 are 16 384-bit ultraviolet erasable and electrically programmable read only memories (EPROMs) specified over the military and extended temperature range respectively. They operate from a single +5 V power supply, have a static power-down mode, and feature fast, single-address location programming. It makes designing with EPROMs faster, easier and more economical. Both products are manufactured from the same dice. Except for the operating temperature range, both products have the same electrical and programming specifications.

The M2716/M2716M 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. Both are pin compatible to Intel's 32K military EPROM, the M2732.

The M2716/M2716M 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 CONFIGURATIONS



MODE SELECTION

| $\qquad$ | $\overline{\mathrm{CE}} / \mathrm{PGM}$ <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}$ | OUTPUTS <br> (9.11, 13.17) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $V_{\text {IL }}$ | $V_{\text {IL }}$ | +5 | +5 | Dout |
| Standby | $\mathrm{V}_{\text {IH }}$ | Don't Care | +5 | +5 | High Z |
| Program | Pulsed $\mathrm{V}_{\text {IL }}$ to $\mathrm{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 }}$ | $\mathrm{V}_{1} \mathrm{H}$ | +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 | $-65^{\circ} \mathrm{C}$ to $+135^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| All Input or Output Voltages with Respect to Ground .. | $+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 }$ |

*Notice:
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 A.C. READ OPERATING CONDITIONS

|  | Temperature Range | $\mathbf{V}_{\mathrm{cC}}$ | $\mathbf{V}_{\mathrm{PP}}$ |
| :--- | :---: | :---: | :---: |
| M2716M | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ | $\mathrm{~V}_{\mathrm{cC}}$ |
| M2716 | $-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ | $5 \mathrm{~V} \pm 10 \%$ | $\mathrm{~V}_{\mathrm{cc}}$ |

## D.C. Characteristics

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ [3] | Max. |  |  |
| $I_{L I}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |
| 1 LO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ |
| $\mathrm{IPP}^{1 / 2]}$ | $V_{\text {PP }}$ Current |  |  | 5 | mA | $\mathrm{V}_{\mathrm{PP}}=5.5 \mathrm{~V}$ |
| $\mathrm{ICCl}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Standby) |  | 10 | 30 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{\text {IL }}, \overline{\mathrm{OE}}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{ICC2}^{[2]}$ | $\mathrm{V}_{\text {CC }}$ Current (Active) |  | 57 | 115 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{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. $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{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 of $\mathrm{I}_{\mathrm{CC}}$ and $\mathrm{I}_{\mathrm{PP} 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.

## Typical Characteristics




A.C. Characteristics

| 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}}$ |
| ${ }^{\text {t }}$ CE | $\overline{\mathrm{CE}}$ to Output Delay |  |  | 450 | ns | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{\text {t }} \mathrm{OE}$ | Output Enable to Output Delay |  |  | 150 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{\text {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{\mathrm{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 simultane. ously 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 $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{O E}$ may be delayed up to $t_{A C C}-t_{O E}$ after the falling edge of $\overline{C E}$ without impact on $t_{\text {Acc }}$.
7. $t_{D F}$ is specified from $\overline{O E}$ or $\overline{C E}$, whichever occurs first.

# M2732A <br> 32K (4K x 8) UV ERASABLE PROM 

MILITARY

450 ns Maximum Access Time...HMOS* -E Technology<br>- Compatible to High Speed 5MHz MiAPX 86/10 MPU ... Zero WAIT State<br>- Two Line Control<br>- Military Temperature Range:<br>$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

- Pin Compatible to M2764 EPROM

■ Industry Standard Pinout...JEDEC Approved

The Intel M2732A is a 5 V only, 32,768 bit ultraviolet erasable and electrically programmable read-only memory (EPROM). It is pin compatible to Intel's 450 ns M2732. The standard M2732A's access time is 450 ns . The access time is compatible to high performance microprocessors, such as the $5 \mathrm{MHz} \mathrm{MiAPX} 86 / 10$. In these systems, the M2732A allows the microprocessor to operate without the addition of WAIT states.
An important M2732A feature is the separate output control, Output Enable ( $\overline{O E}$ ), 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-72 describes the microprocessor system implementation of the $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}}$ controls on Intel's EPROMs. AP-72 is available from Intel's Literature Department.
The M2732A 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 45 mA , a $70 \%$ saving. The standby mode is achieved by applying a TTL-high signal to the $\overline{C E}$ input.
The M2732A is fabricated with HMOS -E technology, Intel's high speed N-channel MOS Silicon Gate Technology.


Figure 1. Block Diagram

Mode Selection

| PINS | CE <br> $(\mathbf{1 8})$ | $\overline{\mathrm{OE} / \mathrm{VPP}}$ <br> $(\mathbf{2 0})$ | VCC <br> $(\mathbf{2 4 )}$ | OUTPUTS <br> $(9-11,13-17)$ |
| :--- | :---: | :---: | :---: | :---: |
| Read | $V_{I L}$ | $V_{I L}$ | +5 | DOUT |
| Standby | $V_{I H}$ | Don't Care | +5 | High $Z$ |
| Program | $V_{I L}$ | $V_{P P}$ | +5 | DIN |
| Program Verify | $V_{I L}$ | $V_{I L}$ | +5 | DOUT |
| Program Inhibit | $V_{I H}$ | VPP | +5 | High $Z$ |


(1)For total compatibility from M2732A provide a trace to pin 26

Figure 2. Pin Configurations

Pin Names

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

M2764
64K (8K x 8) UV ERASABLE PROM
military

- Military Temperature Range...
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- 250 ns (M2764/S8462) Maximum Access Time...HMOS*-E Technology
- Compatible with 5 MHz MiAPX 86/10 MPU...Zero WAIT State
- Two Line Control
- Pin Compatible with M2732 EPROM
- Industry Standard Pinout...JEDEC Approved
- Low Active Current... 100mA Max.
- $\pm 10 \% V_{\text {CC }}$ Tolerance

The intel ${ }^{\circledR} \mathrm{M} 2764$ is a 5 V only, 65,536 -bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The M2764/S8463 access time is 450 ns with speed selection available at 250 ns for the $\mathrm{M} 2764 / \mathrm{S} 8462$. The access time is compatible to high performance microprocessors, such as Intel's 5 MHz MiAPX 86/10. In these systems, the M2764/S8462 allows the microprocessor to operate without the addition of WAIT states.
An important M2764 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-72 describes the microprocessor system implementation of the $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}}$ controls on Intel's EPROMs. AP-72 is available from Intel's Literature Department. M2764/S8462 and M2764/S8463 require that activation of $\overline{\mathrm{OE}}$ be delayed at least 100 ns from the activation of $\overline{\mathrm{CE}}$ or stable addresses, whichever occurs last, to permit operation over the entire Military temperature range.

The M2764 has a standby mode which reduces the power dissipation without increasing access time. The active current is 100 mA , while the standby current is only 50 mA . The standby mode is achieved by applying a TTL-high signal to the $\overline{C E}$ input.
The M2764 is fabricated with HMOS*-E technology, Intel's high-speed N-channel MOS Silicon Gate Technology.


Figure 1. Block Diagram

MODE SELECTION

| Pins <br> Mode | $\begin{gathered} \text { CE } \\ (20) \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{OE} \\ \mathbf{( 2 2 )} \\ \hline \end{gathered}$ | $\begin{aligned} & \text { PGM } \\ & (27) \\ & \hline \end{aligned}$ | VpP <br> (1) | $\begin{aligned} & \mathrm{V}_{\mathrm{C}} \mathrm{C} \\ & (28) \end{aligned}$ | Outputs (11-13, 15-19) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | VIL | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | DOUT |
| Standby | $\mathrm{V}_{\text {IH }}$ | X | X | $\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ | High Z |
| Program | VIL | X | $\mathrm{V}_{\text {IL }}$ | VPP | $\mathrm{V}_{\mathrm{CC}}$ | DIN |
| Program Verify | $V_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{1 \mathrm{H}}$ | $V_{P P}$ | $\mathrm{V}_{\mathrm{CC}}$ | DOUT |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\times$ | X | VPP | $\mathrm{V}_{\mathrm{CC}}$ | High Z |

$x$ can be either $V_{I L}$ or $V_{I H}$

[1] For upgradability to JEDEC approved 128 K EPROMs. provide an address line to pin 26. For compatability with the M2732 and 32K ROMs, provide a trace from VCC to pin 26.
Figure 2. M2732 and M2764 Pin Configuration

| $\mathrm{A}_{0}-\mathrm{A}_{12}$ | Addresses |
| :--- | :--- |
| $\overline{\mathrm{CE}}$ | Chip Enable |
| $\overline{\overline{O E}}$ | Output Enable |
| $\mathrm{O}_{0}-\mathrm{O}_{7}$ | Outputs |
| $\overline{\mathrm{PGM}}$ | Program |
| N.C. | No Connect |

[^39][^40]The programming specifications are described in the Intel Component Data Catalog in the PROM/ROM programming instruction section.

## 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 Input or Output Voltages with
Respect to Ground $\qquad$ +6 V to -0.6 V
VPP Supply Voltage With Respect to Ground
During Programming
+22 V to -0.6 V
*NOTICE: 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 A.C. OPERATING CONDITIONS DURING READ

|  | $\mathbf{M 2 7 6 4 / S 8 4 6 2}$ | M2764/S8463 |
| :--- | :---: | :---: |
| Operating Temperature <br> Range | $-55^{\circ} \mathrm{C}$ to <br> $+125^{\circ} \mathrm{C}$ | $-55^{\circ} \mathrm{C}$ to <br> $+125^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{CC}}$ Power Supply ${ }^{1,2}$ | $5 \mathrm{~V} \pm 10 \%$ | $5 \mathrm{~V} \pm 10 \%$ |
| $\mathrm{~V}_{\mathrm{PP}}$ Voltage $^{2}$ | $\mathrm{~V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ |

## Read Operation

## D.C. CHARACTERISTICS

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{3}$ | Max |  |  |
| ILI | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=5.5 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ |
| $1 \mathrm{PP1}^{2}$ | VPP Current Read |  |  | 5 | mA | $\mathrm{V} P \mathrm{P}=5.5 \mathrm{~V}$ |
| $\mathrm{CCO}^{2}$ | $\mathrm{V}_{\text {CC }}$ Current Standby |  |  | 50 | mA | $\mathrm{CE}=\mathrm{V}_{\text {IH }}$ |
| $\mathrm{ICCl}^{2}$ | $V_{C C}$ Current Active |  | 70 | 100 | $\mathrm{m} A$ | $C E=O E=V_{\text {IL }}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -. 1 |  | +. 6 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | . 45 | V | $1 \mathrm{OL}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |

## A.C. CHARACTERISTICS

| Symbol | Parameter | $\begin{aligned} & \text { M2764/S8462 } \\ & \text { Limits } \end{aligned}$ |  | M2764/S8463 Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| $\mathrm{t}_{\mathrm{ACC}}$ | Address to Output Deiay |  | 250 |  | 450 | ns | $C E=O E=V_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{CE}$ | CE to Output Delay |  | 250 |  | 450 | ns | $\mathrm{OE}=\mathrm{V}_{\text {IL }}$ |
| toe | OE to Output Delay |  | 100 |  | 150 | ns | $C E=V_{\text {IL }}$ |
| ${ }^{\text {t } \mathrm{DF}^{4}}$ | OE High to Output Float | 0 | 85 | 0 | 130 | ns | $C E=V_{I L}$ |
| ${ }^{\mathrm{t}} \mathrm{OH}$ | Output Hold from Addresses, CE or OE Whichever Occurred First | 0 |  | 0 |  | ns | $C E=O E=V_{I L}$ |

See Notes on Page 4.

## SYSTEM TIMING REQUIREMENTS

| Symbol | Parameter | M2764/S8462 |  | M2764/S8463 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |  |
| ${ }^{\text {t }} \mathrm{AO}$ | Address to OE | 100 |  | 100 |  | ns | $C E=V_{\text {IL }}$ |
| ${ }^{\text {t }} \mathrm{CO}$ | CE to OE | 100 |  | 100 |  | ns |  |

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

| Symbol | Parameter | Typ $^{\mathbf{3}}$ | Max. | Unit | Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\text {IN }^{4}}$ | 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}$ |



Figure 3. A.C. Testing Input, Output Waveform


Figure 4. A.C. Testing Load Circuit

See Notes on Page 4.

## A.C. WAVEFORMS



## NOTES:

1. $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before $\mathrm{V}_{\mathrm{PP}}$ and removed simultaneously or after $\mathrm{V}_{\mathrm{PP}}$.
2. $V_{P P}$ may be connected directly to $\mathrm{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 not $100 \%$ tested.
5. IDF $^{\text {is specified from } \overline{O E} \text {. }}$

## ERASURE CHARACTERISTICS

The erasure characteristics of the M2764 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 M2764 in approximately 3 years, while it would take approximately 1 week to cause erasure when exposed to direct sunlight. If the M2764 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 M2764 window to prevent unintentional erasure.

The recommended erasure procedure for the M2764 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 12000 $\mu \mathrm{W} / \mathrm{cm} \mathrm{m}^{2}$ power rating. The M2764 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 M2764 are listed in Table 1. A single 5 V power supply is required in the read mode. All inputs are TTL levels except for Vpp.

Table 1. Mode Selection

| Pins <br> Mode | $\begin{aligned} & \overline{C E} \\ & \text { (20) } \\ & \hline \end{aligned}$ | $\begin{aligned} & \overline{\mathrm{OE}} \\ & \text { (22) } \\ & \hline \end{aligned}$ | $\overline{\text { PGM }}$ (27) | Vpp <br> (1) | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}} \mathrm{C} \\ & (28) \end{aligned}$ | $\begin{aligned} & \text { Outputs } \\ & \text { (11-13, } \\ & 15-19 \text { ) } \\ & \hline \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\mathrm{IL}}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{CC}}$ | $V_{C C}$ | DOUT |
| Standby | $\mathrm{V}_{\text {IH }}$ | X | X | $v_{\text {CC }}$ | $\mathrm{V}_{\mathrm{CC}}$ | High 2 |
| Program | $V_{\text {IL }}$ | X | $\mathrm{V}_{\text {IL }}$ | $V_{P P}$ | $\mathrm{V}_{\mathrm{CC}}$ | DIN |
| Program Verify | $\mathrm{V}_{\text {IL }}$ | $V_{\text {IL }}$ | $\mathrm{V}_{1 \mathrm{H}}$ | VPP | $V_{\text {CC }}$ | DOUT |
| Program Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | X | X | $V_{\text {PP }}$ | $\mathrm{V}_{\mathrm{CC}}$ | High Z |

$x$ can be either $V_{I L}$ or $V_{I H}$

# M2816 <br> 16K (2K x 8) ELECTRICALLY ERASABLE PROM 

MILITARY

- Full Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- HMOS*-E FLOTOX Cell Design
- Reliable Floating Gate Technology
- Very Fast Access Time
-M2816, 350 ns Max.
—M2816-4, 450 ns Max.
- Single Byte Erase/Write Capability
- Fast Byte Erase/Write Time
-M2816, 50 ms Minimum
- Conforms to JEDEC Byte-Wide Family Standard
- Microprocessor Compatible Architecture
- Low Current
-Active Current, 140 mA Max.
-Standby Current, 60 mA Max.
- Erase/Write Specifications

Guaranteed $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ M2816 is a 16,384 bit electrically eraseable programmable read-only memory ( $E^{2}$ PROM). The M2816 can be easily erased and reprogrammed on a byte basis. A chip erase function is also provided. The device operates from a 5-volt power supply in the read mode; writing and erasing are accomplished by providing a single 21-volt pulse.

The M2816, with its very fast read access speed, is compatible with high performance microprocessors such as the MiAPX 86/10. Using the fast access speed allows zero wait operation in large system configurations.

The electrical erase/write capability of the M2816 makes it ideal for a wide variety of applications requiring in-system, non-volatile erase and write. Never before has in-system alterability been possible with this combination of density, performance and flexibility. Any byte can be erased or written in 50 ms without affecting the data in any other byte. Alternatively, the entire memory can be erased in 50 ms allowing the total time to rewrite all 2 K bytes to be cut by $50 \%$. The M2816 provides a significant increase in flexibility allowing new applications (dynamic reconfiguration, continuous calibration) never before possible.

The M2816 E ${ }^{2}$ PROM possesses Intel's 2-line control architecture to eliminate bus contention in a system environment. A power down mode is also featured; in the standby mode power consumption is reduced by over $55 \%$ without increasing access time. The standby mode is achieved by applying a TTL-high signal to the CE input.

Byte erase and write are controlled entirely by TTL signal levels, yet require no control signals beyond CE and OE. For byte write a selected chip ( $C E=T T L$ low) senses the 21 V Vpp pulse and automatically goes into write mode. Byte erase mode is identical to byte write except that data-in must be all logic ones (TTL-high). Never before has an in-system alteration of non-volatile information been implemented with such simple control.
*HMOS-E is a patented process of Intel Corporation.


| PIN NAMES |  |
| :--- | :--- |
| $A_{0} \cdot A_{10}$ | ADDRESSES |
| $\overline{\mathrm{CE}}$ | CHIP ENABLE |
| $\overline{\mathrm{OE}}$ | OUTPUT ENABLE |
| $\mathrm{O}_{0} \cdot \mathrm{O}_{7}$ | DATA OUTPUTS |
| $\mathrm{I}_{0} \cdot 17$ | DATA INPUTS |
| $\mathrm{V}_{\mathrm{PP}}$ | PROGRAM VOLTAGE |

Figure 1. M2816 Functional Block Diagram
Figure 2. Pin Configurations

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias ............. - $65^{\circ} \mathrm{C}$ to $+135^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| tor |  |
| All Input or Output Voltages with |  |
| Respect to Ground |  |
| $V_{\text {PP }}$ Supply Voltage with Respect to |  |
| Maximum Duration of VPP Supply at 22V |  |
| aximum Duration During Write/Erase |  |

*NOTICE: 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 A.C. OPERATING CONDITIONS DURING READ AND WRITE

|  | M2816/S8442 | M2816-4/S8442 |
| :---: | :---: | :---: |
| Temperature Range | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ | $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\text {CC }}$ Power Supply $^{[9]}$ | $5 \mathrm{~V} \pm 10 \%$ | $5 \mathrm{~V} \pm 10 \%$ |

## D.C. CHARACTERISTICS

## READ

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{[1]}$ | Max |  |  |
| $\mathrm{I}_{1}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |
| lo | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{V}_{\text {CC }}$ Current (Active) |  | 90 | 140 | mA | $\overline{\mathrm{OE}}=\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ICCl | $\mathrm{V}_{\mathrm{CC}}$ Current (Standby) |  | 35 | 60 | mA | $\overline{C E}=V_{I H}$ |
| $\left.\mathrm{IPP}_{\text {P }} \mathrm{R}\right)$ | $V_{\text {pp }}$ Current (Read) |  |  | 5 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{PP}}=4$ to 6 |
| $V_{\text {IL }}$ | Input Low Voltage | -0.1 |  | . 8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.2 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | . 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}$ |
| $V_{P P}$ | Read Voltage | 4 |  | 6 | V |  |

## WRITE

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{[1]}$ | Max |  |  |
| VPP | Write/Erase Voltage | 21 |  | 22 | V |  |
| ${ }^{\text {IPP(W) }}$ | VPP Current (Byte Erase/Write) |  |  | 15 | mA | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{V}_{\text {OE }}$ | $\overline{\mathrm{OE}}$ Voltage (Chip Erase) | 9 |  | 15 | V | $\mathrm{I}_{\overline{O E}}=10 \mu \mathrm{~A}$ |
| IPP(1) | VPP Current Inhibit |  |  | 5 | mA | $\mathrm{V}_{\mathrm{PP}}=22, \mathrm{CE}=\mathrm{VIH}$ |
| IPP(C) | VPP Current (Chip Erase) |  | 3 | 5 | mA | $\overline{C E}=V_{I L}$ |

For footnotes see page 13.

CAPACITANCE ${ }^{[1]} \quad\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$

| Symbol | Parameter | Typ | Max | Unit | Conditions |
| :--- | :--- | :---: | :---: | :---: | :--- |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance | 5 | 10 | pF | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance |  | 10 | pF | $\mathrm{V}_{\mathrm{OUT}}=0 \mathrm{~V}$ |
| $\mathrm{C}_{\mathrm{VCC}}$ | $\mathrm{V}_{\text {CC }}$ Capacitance |  | 500 | pF | $\mathrm{CE}=\mathrm{OE}=\mathrm{V}_{\mathrm{IH}}$ |
| $\mathrm{C}_{\mathrm{VPP}}$ | $\mathrm{V}_{\text {PP }}$ Capacitance |  | 50 | pF | $\mathrm{CE}=\mathrm{OE}=\mathrm{V}_{\mathrm{IH}}$ |

## A.C. TEST CONDITIONS

Output Load: 1 TTL gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ Input Pulse Levels: 0.45 to 2.4 V
Timing Measurement Reference Level:
Input 1 V and 2 V
Output . 8 V and 2 V

## A.C. CHARACTERISTICS

READ

| Symbol | Parameter | M2816 |  |  | M2816-4 |  |  |  | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{[1]}$ | Max | Min | Typ ${ }^{[1]}$ | Max | Unit |  |
| ${ }^{\text {t }}$ ACC | Address to Output Delay |  | 250 | 350 |  | 350 | 450 | ns | $\overline{\mathrm{CE}}=\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{\text {t }}$ CE | $\overline{\mathrm{CE}}$ to Output Delay |  | 250 | 350 |  | 350 | 450 | ns | $\overline{\mathrm{OE}}=\mathrm{V}_{\mathrm{IL}}$ |
| toe | Output Enable to Output Delay | 10 |  | 120 | 10 |  | 140 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| $t_{\text {DF }}$ | Output Enable High to Output Float | 0 |  | 100 | 0 |  | 100 | ns | $\overline{\mathrm{CE}}=\mathrm{V}_{\mathrm{IL}}$ |
| ${ }^{\text {toH }}$ | Output Hold from $\qquad$ <br> Addresses, $\overline{\mathrm{CE}}$ or $\overline{\mathrm{OE}}$ <br> Whichever Occurred First | 0 |  |  | 0 |  |  | ns |  |

## WRITE

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ ${ }^{[1]}$ | Max |  |  |
| $t_{\text {AS }}$ | Add to VPP Set-Up Time | 150 |  |  | ns |  |
| $\mathrm{t}_{\mathrm{CS}}$ | CE to VPP Set-Up Time | 150 |  |  | ns |  |
| $t_{\text {DS }}{ }^{[10]}$ | Data to VPP Set-Up Time | 0 |  |  | ns |  |
| ${ }_{\text {t }}{ }^{\text {[10] }}$ | Data Hold Time | 50 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| $t_{W P}{ }^{\text {[9] }}$ | Write Pulse Width/M2816 | 50 |  | 70 | ms |  |
| $t_{\text {WR }}$ | Write Recovery Time | 50 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| tos | Chip Erase Set-Up Time | 0 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V} \quad \mathrm{~V}_{\text {OE }}=9 \mathrm{~V}$ |
| ${ }^{\text {toH }}$ | Chip Erase Hold Time | 0 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V} \quad \mathrm{~V}_{\mathrm{OE}}=9 \mathrm{~V}$ |
| ${ }^{\text {tBOS }}$ | Byte Erase/Write Set-Up Time | 0 |  |  | ns | $V_{P P}=6 \mathrm{~V}$ |
| ${ }^{\text {t }} \mathrm{BOH}$ | Byte Erase/Write Set-Up Time | 0 |  |  | ns | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |
| tPRC | VPP RC Time Constant | 450 | 600 | 750 | $\mu \mathrm{s}$ |  |
| ${ }_{\text {tPFT }}{ }^{\text {[7] }}$ | $V_{\text {PP }}$ Fall Time |  |  | 100 | $\mu \mathrm{S}$ | $\mathrm{V}_{\mathrm{PP}}=6 \mathrm{~V}$ |

## WAVEFORMS

READ


BYTE ERASE ${ }^{[5]}$ OR WRITE


## WAVEFORMS (Continued)

## CHIP ERASE ${ }^{[6]}$



## NOTES

1. This parameter is only sampled and not $100 \%$ tested.
2. OE may be delayed up to 230 ns after falling edge of CE without impact on $\mathrm{T}_{\mathrm{ACC}}$ for M2816.
3. $t_{D F}$ is specified from OE or CE whichever occurs first.
4. The rising edge of $V_{P P}$ must follow an exponential waveform. That waveform's time constarit is specified as $t_{\text {PRC }}$. See Intel's AP-102 for details.
5. Prior to a data write, an erase operation must be performed. For erase, data in $=V_{I H}$.
6. In the chip erase mode $D_{I N}=V_{I H}$.
7. To allow immediate read verify capability, $\mathrm{V}_{\mathrm{PP}}$ can be driven low in less than 50 ns. See AP-101 for more information.
8. Adherence to $t_{W P}$ specification is important to device reliability.
9. To prevent spurious device erasure or write, $\mathrm{V}_{\mathrm{CC}}$ must be applied simultaneously or before 21 volt application of $V_{P p}$. $V_{\text {PP }}$ cannot be driven to 21 volts without previously applying $V_{\text {CC }}$.
10. The data in set up and hold times for chip erase are identical to those specified for byte erase.
11. This switch includes automatic voltage shutdown on power fail.

M3632
32K (4K x 8) BIPOLAR PROM
MILITARY

## 35 ns Typical Access

- Low Power Dissipation: 0.02 mW/Bit Typically
Two Chip Select Inputs for Easy
Memory Expansion
$\pm 10 \%$ Power Supply Tolerance
- Three-State Outputs
- Hermetic 24-Pin DIP
- Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability
- Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel M3632 is a high performance 32,768-bit PROM organized as 4096 words by 8 bits. The worst case access time of 50 ns is specified over the $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ temperature range and $10 \% \mathrm{~V}_{\mathrm{CC}}$ power supply tolerances. There are two 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.

The M3632 allows present $4 \mathrm{~K}, 8 \mathrm{~K}$ and 16K PROM users to significantly increase density without sacrificing performance. The M3632 is packaged in a hermetic 24 pin dual in-line package. The 32,768-bit PROM uses the most advanced technology available. As a result, the M3632 combines high performance, high density and lower power per bit than previous Bipolar PROM designs.


Figure 1. M3632 Block Diagram

(1) To select the PROM $\overline{C S}_{1}=V_{I L}$ and $\mathrm{CS}_{2}=\mathrm{V}_{\mathrm{IH}}$

Figure 2. M3632 Pin Configuration


Figure 3. M3632 Logic Symbol

## M3636 <br> $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ BIPOLAR PROM

$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Operation<br>■ Fast Access Time: 80ns Maximum<br>■ Low Power Dissipation: $0.05 \mathrm{~mW} /$ Bit Typically<br>- Three Chip Select Inputs for Easy Memory Expansion

## - Pin Compatible to 8 K PROMs <br> - Three-State Outputs <br> - Hermetic 24-Pin DIP <br> - Polycrystalline Silicon Fuses for Higher Fuse Reliability/Higher Programmability

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 8K PROMs. The M3636 is packaged in a hermetic 24 -pin dual in-line package.

PIN CONFIGURATION


BLOCK DIAGRAM

$\begin{array}{ll}C l_{1} & O_{1} \\ C S_{2} & O_{2} \\ C S_{3} & O_{3} \\ A_{0} & O_{4} \\ A_{1} & O_{5} \\ A_{2} & O_{6} \\ A_{3} & O_{7} \\ A_{4} & O_{8} \\ A_{5} & \\ A_{6} & \\ A_{7} & \\ A_{8} & \\ A_{9} & \\ A_{10} & \end{array}$
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}_{\text {IL }}$ and $\mathrm{CS}_{2}=\mathrm{CS}_{3}=\mathrm{V}_{1} \mathrm{H}$

## PROGRAMMING

The programming specifications are described in the PROM/ROM 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.5 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. 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 |  |
| $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}_{\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}$ |
| $\|10\|$ | Output Leakage for High Impedance State |  |  | 60 | $\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}^{[2]}$ | Output Short Circuit Current | -20 | -35 | -100 | 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.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}_{C C}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{S}}=-10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | 3.2 V |  | V | $\mathrm{I}_{\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}$ |
| $I_{\text {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 | $V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Iriput "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{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 $V_{C C}=+5 \mathrm{~V} \pm 5 \%, T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$

| SYMBOL | PARAMETER | MAX. LIMITS | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{A}}$ | Address to Output Delay | 80 | ns | $\overline{\mathrm{CS}}_{1}=\mathrm{V}_{1 \mathrm{~L}}$ <br> and $\mathrm{CS}_{2}=\mathrm{CS}_{3}=\mathrm{V}_{1 H}$ <br> to select the PROM. |
| $\mathrm{t}_{\mathrm{EN}}$ | Output Enable Time | 50 | ns | ns |
| $\mathrm{t}_{\text {DIS }}$ | Output Disable Time | 50 |  |  |

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}$ | $V_{\text {IN }}=2.5 \mathrm{~V}$ |
| $C_{\text {INS }}$ | Chip-Select Input Capacitance | 6 | 10 | pF | $V_{C C}=5 \mathrm{~V}$ | $V_{\text {IN }}=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


# M8048/M8748/M8035L SINGLE COMPONENT 8-BIT MICROCOMPUTER 

MILITARY

## - 8048 Mask Programmable ROM - 8748 User Programmable/Erasable EPROM 8035L Requires External ROM or EPROM

- $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C} 6 \mathrm{MHz}$ Operation (M8048/M8035L)
- $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ 3.6 MHz Operation (M8748)
- 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
- Screened to MIL-STD-883B

The Intel M8048/M8748/M8035L are totally self-sufficient 8-bit parallel computers fabricated on single silicon chips using Intel's N -Channel silicon gate MOS process.

The M8048 contains an 8-bit CPU, 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®/MCS-85® peripherals. The M8035L is the equivalent of an M8048 without program memory, and has the RAM power down mode of the M8048. To reduce development problems to a minimum and provide maximum flexibility, three interchangeable pin-compatible* versions of this single component micro-computer 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 M8035L 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.
${ }^{*} V_{D D}$ is used to program the M8748 and used for low power standby on the M8048/8035L.


Figure 1. Block Diagram


Figure 2. Logic Symbol


Figure 3. Pin Configuration

WAVEFORMS

COMBINATION PROGRAM/VERIFY MODE (EPROM'S ONLY)


VERIFY MODE (ROM/EPROM)

TO, $\overline{\text { RESET }}$


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}}$. 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 ${ }^{\circledR}$ Development System with a UPP-848 Personality Card

## Table 1. Instruction Set Summary

|  | Mnemonic | Description | Bytes | Cycle |
| :---: | :---: | :---: | :---: | :---: |
|  | ADO 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 $\mathrm{A}_{\text {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{ }^{\prime}$ |
|  | 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 |
|  | 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 |
| $\begin{aligned} & \stackrel{5}{0} \\ & \stackrel{5}{c} \\ & \text { Nim } \end{aligned}$ | 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 |
|  | JT0 addr | Jump on T0 = 1 | 2 | 2 |
|  | JNTO addr | Jump on T0 $=0$ | 2 | 2 |
|  | JT1 addr | Jump on $\mathrm{T} 1=1$ | 2 | 2 |
|  | JNT1 addr | Jump on $\mathrm{T} 1=0$ | 2 | 2 |
|  | JF0 addr | Jump on F0 $=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 addr <br> RET <br> RETR | Jump to subroutine <br> Return <br> Return and restore status | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ |
| $\left\lvert\, \begin{aligned} & \text { 朐 } \\ & \frac{\pi}{4} \end{aligned}\right.$ | CLR C <br> CPL C <br> CLR FO <br> CPL FO <br> CLR F1 <br> CPL F1 | Clear carry <br> Complement carry <br> Clear flag 0 . <br> Complement flag 0 <br> Clear flag 1 <br> Complement flag 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $1$ |
|  | MOV A, R MOV A, @R MOV A, \#data MOV R, A MOV @R, A MOV R, \#data MOV @R, \#data MOV A, PSW MOV PSW, A XCH A, R . XCHA, @R XCHD A, @R MOVX A, @R MOVX @R, A MOVP A, @A MOVP3 A, @A | Move register to $A$ <br> Move data memory to a <br> Move immediate to $A$ <br> Move A to register <br> Move A to data memory <br> Move immediate to register <br> Move immediate to data memory <br> Move PSW to A <br> Move A to PSW <br> Exchange $A$ and register <br> Exchange $A$ and data memory <br> Exchange nibble of $A$ and register <br> Move external data memory to A <br> Move A to external data memory <br> Move to A from current page <br> Move to A from page 3 | $\begin{aligned} & 1 \\ & 1 \\ & 2 \\ & 1 \\ & 1 \\ & 2 \\ & 2 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 2 \\ & 1 \\ & 1 \\ & 2 \\ & 2 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 2 \end{aligned}$ |
| Timer/Counter | MOV A, T <br> MOV T, A <br> STRT T <br> STRT CNT <br> STOP TCNT <br> EN TCNTI <br> DIS TCNTI | Read timer/counter <br> Load timer/counter <br> Start timer <br> Start counter <br> Stop timer/counter <br> Enable timer/counter interrupt <br> Disable timer/counter interrupt | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |
| \| | EN I <br> DIS I <br> SEL RBo <br> SEL RB1 <br> SEL MBO <br> SEL MB1 <br> ENTO CLK | Enable external interrupt <br> Disable external interrupt <br> Select register bank 0 <br> Select register bank 1 <br> Select memory bank 0 <br> Select memory bank 1 <br> Enable clock output on TO | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |
|  | NOP | No operation | 1 | 1 |

M8048/M8748/M8035L

Table 2. Pin Description

| Symbol | Pin No. | Function | Symbol | Pin No. | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{S S}$ | 20 | Circuit GND potential | INT | 6 | Interrupt input. Initiates an interrupt |
| $V_{D D}$ | 26 | Programming power supply; +25 V during program, +5 V during operation for both ROM and PROM. Low power standby pin in 8048 and 8035L. |  |  | 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 |
| $V_{C C}$ | 40 | Main power supply; +5 V during operation and programming. |  |  | onto the bus from an external device. |
| PROG | 25 | Program pulse $(+23 \mathrm{~V})$ input pin during 8748 programming. |  |  | Used as a read strobe to external data memory. (Active low) |
|  | 27-34 | Output strobe for 8243 I/O expander. <br> 8 -bit quasi-bidirectional port. | $\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 $\mathrm{V}_{\mathrm{IH}}$ ) |
| P20-P27 | 21-24 | 8 -bit quasi-bidirectional port. | $\overline{W R}$ | 10 | Output strobe during a bus write. (Active low) |
| Port 2 | 35-38 | P20-P23 contain the four high order program counter bits during an external program memory fetch and serve |  |  | Used as write strobe to external data memory. |
|  |  | as a 4-bit I/O expander bus for 8243 . | ALE | 11 | Address latch enable. This signal occurs once during each cycle and |
| $\begin{aligned} & \mathrm{DB}_{0}-\mathrm{DB}_{7} \\ & \mathrm{BUS} \end{aligned}$ | 12-19 | True bidirectional port which can be written or read synchronously using the RD, WR strobes. The port can also be statically latched: |  |  | 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. |
|  |  | counter bits during an external program memory fetch, and receives the addressed instruction under the | $\overline{\text { PSEN }}$ | 9 | Program store enable. This output occurs only during a fetch to external program memory. (Active low) |
|  |  | control of PSEN. Also contains the address and data during an external RAM data store instruction, under control of ALE, RD, and WR. | $\overline{\text { SS }}$ | 5 | Single step input can be used in junction 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. TO is also used during programming. | 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) |
| T1 | 39 | Input pin testable using the JT1, and JNT1 instructions. Can be designated the timer/counter input using the | XTAL1 | 2 | One side of crystal input for internal oscillator. Also input for external source. (Non TTL $V_{1 H}$ ) |
|  |  | STRT CNT instruction. | XTAL2 | 3 | Other side of crystal input. |

## WAVEFORMS


A.C. CHARACTERISTICS $T_{A}=-55^{\circ} \mathrm{C}$ to $125^{\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{aligned} & \text { M8048 } \\ & \text { M8035L } \end{aligned}$ |  | M8748 |  | Unit | Conditions (Note 1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |  |
| $t_{L L}$ | ALE Pulse Width | 200 |  | 300 |  | ns |  |
| $t_{\text {AL }}$ | Address Setup to ALE | 120 |  | 120 |  | ns |  |
| $t_{\text {LA }}$ | Address Hold from ALE | 80 |  | 80 |  | ns |  |
| $\mathrm{t}_{\mathrm{CC}}$ | Control Pulse Width ( $\overline{\text { PSEN }}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}})$ | 400 |  | 600 |  | ns |  |
| $t_{\text {DW }}$ | Data Setup before $\overline{W R}$ | 420 |  | 600 |  | ns |  |
| $t_{\text {wo }}$ | Data Hold After WR | 80 |  | 120 |  | ns | $\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{Cr}}$ | Cycle Time | 2.5 | 15.0 | 4.17 | 15.0 | $\mu \mathrm{S}$ | $\begin{aligned} & (3.6 \mathrm{MHz} \\ & \text { XTAL 8748) } \\ & \hline \end{aligned}$ |
| $t_{\text {DR }}$ | Data Hold | 0 | 200 | 0 | 200 | ns |  |
| $\mathrm{t}_{\text {RD }}$ | $\overline{\text { PSEN, }} \overline{\mathrm{RD}}$ to Data In |  | 400 |  | 600 | ns |  |
| $t_{\text {AW }}$ | Address Setup to $\overline{W R}$ | 230 |  | 260 |  | ns |  |
| $t_{\text {AD }}$ | Address Setup to Data In |  | 600 |  | 900 | ns |  |
| $t_{\text {AFC }}$ | Address Float to $\overline{\mathrm{RD}}, \overline{\text { PSEN }}$ | -40 |  | -60 |  | ns |  |
| $t_{\text {ca }}$ | Control Pulse to ALE | 10 |  | 10 |  | ns |  |

Note 1: Control outputs: $C_{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 \mathrm{~s}$ for 8748

ABSOLUTE MAXIMUM RATINGS*
Ambient Temperature Under Bias

| 8748 | .$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| :---: | :---: |
| 8048/8035L | . $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Storage Temperature | - $65^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |
| Voltage On Any Pin With Respect to Ground | -0.5 to +7 V |
| Power Dissipation | 1.5 Watt |

*NOTICE: 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}}=\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 <br> (All Except $\overline{\mathrm{RESET}}, \mathrm{X} 1, \mathrm{X} 2$ ) | -. 5 |  | . 7 | V |  |
| $\mathrm{V}_{\text {LL1 }}$ | Input Low Voltage (RESET, X1, X2) | -. 5 |  | . 5 | V |  |
| $\mathrm{V}_{1 H}$ | Input High Voltage (All Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.3 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{1 \mathrm{H} 1}$ | Input High Voltage (RESET, X1, X2) | 3.8 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage <br> (BUS, $\overline{R D}, \overline{W R}, \overline{P S E N}, ~ A L E)$ |  |  | . 45 | V | $\mathrm{I}_{\mathrm{OL}}=1.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage (All Other Outputs) |  |  | . 45 | V | $\mathrm{I}_{\mathrm{oL}}=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 <br> (RD, WR, $\overline{\text { PSEN }}, \mathrm{ALE})$ | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-50 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 2}$ | Output High Voltage (All Other Outputs) | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-30 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Leakage Current (T1, /ָNT) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{SS}} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\text {LI1 }}$ | Input Leakage Current (P10-P17, P20-P27, EA, S̄) |  |  | -700 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| Lo | Output Leakage Current (BUS, TO) (High Impedance State) |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+.45 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\text {DD }}$ Supply Current |  | 10 | 25 | mA |  |
| $\mathrm{I}_{\mathrm{DD}}+\mathrm{I}_{\mathrm{CC}}$ | Total Supply Current |  | 80 | 155 | mA |  |



- Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
$\pm 10 \%$ Power Supply Tolerance
- $2 \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 64K Bytes of Memory

\author{
16-Bit Stack Pointer and Stack Manipulation Instructions for Rapid Switching of the Program Environment <br> - Decimal, Binary, and Double Precision Arithmetic <br> \title{

- Ability to Provide Priority Vectored Interrupts
} <br> 512 Directly Addressed I/O Ports
}

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-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 single and double precision operators. Arithmetic and logical instructions set or reset 4 testable flags. A fifth flag provides decimal arithmetic operation.
The M8080A features an external stack. 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 6 general-purpose registers. The 16 -bit stack pointer controls addressing of this external stack. This stack enables the M8080A to handle multiple-level priority interrupts by rapidly storing and restoring processor status. It also provides almost unlimited subroutine nesting.
This microprocessor simplifies systems design. Separate 16 -line address and 8 -line bidirectional data busses facilitate 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, which can suspend processor operation and force the address and data busses into a high impedance state. This permits OR-typing these busses with other controlling devices for (DMA) direct memory access or multiprocessor operation.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## 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}_{S S}$ With Respect to $\mathrm{V}_{\mathrm{BB}}$ | -0.3V to +20V |
| Power Dissipation |  |

*NOTICE: 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 $\quad T_{A}=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%$,

$$
\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \text {; unless otherwise noted) }
$$

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

CAPACITANCE $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V}\right)$

| 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 |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance | 10 | 20 | pf | Returned to $\mathrm{V}_{\mathrm{SS}}$ |

## A.C. CHARACTERISTICS

$\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%$, $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{BB}}=-5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$; unless otherwise noted)


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

## A.C. TESTING LOAD CIRCUIT



WAVEFORMS
NOTE:
Timing measurements are made at the following reference voltages: CLOCK " 1 " $=7.0 \mathrm{~V}$, " 0 " $=1.0 \mathrm{~V}$; INPUTS $" 1 "=3.0 \mathrm{~V}$, $" 0$ " $=0.8 \mathrm{~V}$; OUTPUTS " 1 " $=2.0 \mathrm{~V}$, " 0 " $=0.8 \mathrm{~V}$.


INTE

THIS TIMING DIAGRAM SHOWS TIMING RELATIONSHIPS ONLY; IT DOES NOT REPRESENT ANY SPECIFIC MACHINE CYCLE.

## WAVEFORMS (Continued)




Typical Supply Current versus Temperature, Normalized

## NOTES:

1. Data input should be enabled with DBIN status. No bus conflict can then occur and data hold time is assured. $t_{\mathrm{DH}}=50 \mathrm{~ns}$ or t $t_{D F}$, whichever is less.
2. $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

3. The following are relevant when interfacing the M8080A to devices having $\mathrm{V}_{\mathbb{I}}=3.3 \mathrm{~V}$ :
a) Maximum output rise time from .8 V to $3.3 \mathrm{~V}=100 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}$ = SPEC.
b) Output delay when measured to $3.0 \mathrm{~V}=\mathrm{SPEC}+60 \mathrm{~ns} @ \mathrm{C}_{\mathrm{L}}$ = SPEC.
c) If $C_{L}=$ SPEC, add $.6 \mathrm{~ns} / \mathrm{pF}$ if $\mathrm{C}_{\mathrm{L}}>$ C $_{\text {SPEC }}$, subtract $.3 \mathrm{~ns} / \mathrm{pF}$ (from modified delay) if $C_{L}<C_{S P E C}$.
4. $t_{A W}=2 t_{C Y}-t_{D 3}-t_{r \phi 2}-140 n s e c$.
5. $t_{D W}=t_{C Y}-t_{D 3}-t_{r \phi 2}-170 \mathrm{nsec}$.
6. If not HLDA, $t_{W D}=t_{W A}=t_{D 3}+t_{r \phi 2}+10 \mathrm{~ns}$. If HLDA, $t_{W D}=$ $t_{W A}=t_{W F}$.
7. $t_{H F}=t_{\mathrm{D} 3}+t_{\mathrm{r} \phi 2}-50 \mathrm{~ns}$.
8. $t_{W F}=t_{D 3}+t_{r \phi 2}-10 \mathrm{~ns}$.
9. Data in must be stable for this period during DBIN $\cdot T_{3}$. Both $t_{D S 1}$ and $t_{D S 2}$ must be satisfied.
10. Ready signal must be stable for this period during $T_{2}$ or $T_{W}$. (Must be externally synchronized.)
11. Hold signal must be stable for this period during $T_{2}$ or $T_{W}$ when entering hold mode, and during $T_{3}, T_{4}, T_{5}$ and $T_{W H}$ when in hold mode. (External synchronization is not required.)
12. Interrupt signal must be stable during this period of the last clock cycle of any instruction in order to be recogized on the following instruction. (External synchronization is not required.)


Data Bus Characteristics During DBIN

# M8085AH 8-BIT HMOS MICROPROCESSOR 

MILITARY

■ Single +5V Power Supply with 10\% Voltage Margins

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

- $1.3 \mu$ s Instruction Cycle (8085AH)
- 100\% Compatible with M8085A
- 100\% Software Compatible with M8080A

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 M8080A-Compatible Interrupt

- Serial In/Serial Out Port
- Decimal, Binary and Double Precision Arithmetic
- Direct Addressing Capability to 64 K Bytes of Memory

The Intel M8085AH is a complete 8 bit parallel Central Processing Unit (CPU) implemented in N-channel, depletion load, silicon gate technology (HMOS). Its instruction set is $100 \%$ software compatible with the M8080A microprocessor, and it is designed to improve the present M8080A's performance by higher system speed. Its high level of system integration allows a minimum system of three IC's [M8085AH (CPU), M8185H (RAM/IO) and M8755A (PROM/IO)] while maintaining total system expandability.
The M8085AH incorporates all of the features that the M8224 (clock generator) and M8228 (system controller) provided for the M8080A, thereby offering a high level of system integration.

The M8085AH 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 M8155H/M8755A memory products allow a direct interface with the M8085AH.


Figure 2. M8085AH Pin Configuration

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
*NOTICE: 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{~V}_{\mathrm{SS}}=0 \mathrm{~V}$; unless otherwise specified)

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.2 | $\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 |  | 200 | mA |  |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Leakage |  | $\pm 10$ | $\mu \mathrm{~A}$ | $0 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage | $\pm 10$ | $\mu \mathrm{~A}$ | $0.45 \leq \mathrm{V}_{\mathrm{OUT}} \leq \mathrm{V}_{\mathrm{CC}}$ |  |
| $\mathrm{V}_{\mathrm{ILR}}$ | Input Low Level, RESET | -0.5 | +0.8 | V |  |
| $\mathrm{~V}_{\mathrm{IHR}}$ | Input High Level, RESET | 2.4 | $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |
| $\mathrm{~V}_{\mathrm{HY}}$ | Hysteresis, RESET | 0.25 |  | V |  |

A.C. CHARACTERISTICS $\quad\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ )

| Symbol | Parameter | M8085AH ${ }^{[2]}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| ${ }^{\text {t }}$ CYC | CLK Cycle Period | 320 | 2000 | ns |
| $\mathrm{t}_{1}$ | CLK Low Time (Standard CLK Loading) | 80 |  | ns |
| $\mathrm{t}_{2}$ | CLK High Time (Standard CLK Loading) | 120 |  | ns |
| $t_{r}, t_{f}$ | CLK Rise and Fall Time |  | 30 | ns |
| tXKR | $\mathrm{X}_{1}$ Rising to CLK Rising | 20 | 120 | ns |
| tXKF | $\mathrm{X}_{1}$ Rising to CLK Falling | 20 | 150 | ns |
| ${ }^{t} A C$ | $\mathrm{A}_{8-15}$ Valid to Leading Edge of Control ${ }^{[1]}$ | 270 |  | ns |
| ${ }^{t} \mathrm{ACL}$ | $\mathrm{A}_{0-7}$ Valid to Leading. Edge of Control | 240 |  | ns |
| ${ }^{\text {A }}$ AD | $\mathrm{A}_{0-15}$ Valid to Valid Data In |  | 575 | ns |
| ${ }^{t}$ AFR | Address Float After Leading Edge of $\overline{\text { READ }}$ ( $\overline{\text { INTA }}$ ) |  | 0 | ns |
| ${ }^{\text {taL }}$ | $A_{8-15}$ Valid Before Trailing Edge of ALE ${ }^{[1]}$ | 90 |  | ns |
| ${ }^{\text {t }}$ LLL | $\mathrm{A}_{0-7}$ Valid Before Trailing Edge of ALE | 70 |  | ns |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | M8085AH ${ }^{[2]}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |
| $t_{\text {ARY }}$ | READY Valid from Address Valid |  | 220 | ns |
| ${ }^{\text {t }}$ CA | Address ( $\mathrm{A}_{8-15}$ ) Valid After Control | 120 |  | ns |
| ${ }^{\text {t }} \mathrm{C}$ | Width of Control Low ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\text { INTA }}$ ) Edge of ALE | 400 |  | ns |
| ${ }^{\text {t }}$ CL | 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 |
| ${ }^{\text {thDH }}$ | HOLD Hold Time | 0 |  | ns |
| ${ }^{\text {thDS }}$ | HOLD Setup Time to Trailing Edge of CLK | 170 |  | ns |
| $\mathrm{t}_{\mathrm{N} \mathrm{NH}}$ | 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 |
| tic | Trailing Edge of ALE to Leading Edge of Control | 130 |  | ns |
| tLCK | ALELow During CLK High | 100 |  | ns |
| t LDR | ALE to Valid Data During Read |  | 460 | ns ${ }^{\circ}$ |
| tLDW | ALE to Valid Data During Write |  | 200 | ns |
| tLL | ALE Width | 140 |  | ns |
| tLRY | ALE to READY Stable |  | 110 | ns |
| $t_{\text {RAE }}$ | Trailing Edge of $\overline{\text { READ }}$ to Re-Enabling of Address | 150 |  | ns |
| $t_{\text {RD }}$ | $\overline{\text { READ ( }}$ (or INTA) to Valid Data |  | 300 | ns |
| tr V | Control Trailing Edge to Leading Edge of Next Control | 400 |  | ns |
| $t_{\text {RDH }}$ | Data Hold Time After $\overline{\text { READ INTA }}$ | 0 |  | ns |
| $t_{\text {RYM }}$ | READY Hold Time | 0 |  | ns |
| $t_{\text {RYS }}$ | READY Setup Time to Leading Edge of CLK | 110 |  | ns |
| two | Data Valid After Trailing Edge of WRITE | 100 |  | ns |
| ${ }^{\text {tw }}$ WL | LEADING Edge of WRITE to Data Valid |  | 40 | ns |

## NOTES:

1. $A_{8}-A_{15}$ address Specs apply $1 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 $S_{1}$ are stable.
2. Test Conditions: $\mathrm{t}_{\mathrm{CYC}}=320 \mathrm{~ns}(\mathrm{M} 8085 \mathrm{AH}) ; \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.
3. For all output timing where $C_{L} \neq 150 \mathrm{pF}$ use the following correction factors:

$$
\begin{aligned}
& 25 \mathrm{pF} \leq \mathrm{C}_{\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}
\end{aligned}
$$

4. Output timings are measured with purely capacitive load.
5. To calculate timing specifications at other values of $t_{\mathrm{CYC}}$ use Table 5.

WAVEFORMS


## WAVEFORMS (Continued)

READ OPERATION WITH WAIT CYCLE (TYPICAL) - SAME READY TIMING APPLIES TO WRITE


INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, CA 95051 (408) 987-8080

## MILITARY iAPX 86/10 16-BIT HMOS MICROPROCESSOR

(M8086)
MILITARY

## - Direct Addressing Capability to 1 MByte of Memory <br> - Assembly Language Compatible with 8080/8085

- 14 Word, By 16-Bit Register Set with Symmetrical Operations


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

- MULTIBUS ${ }^{\text {TM }}$ System Compatible Interface


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

The Intel ${ }^{(8)}$ Military iAPX $86 / 10$ is a new generation, high performance 16 -bit 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.


Figure 1. Functional Block Diagram


Figure 2. Pin Configuration

## 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 . . . . . . . . . . . . . . . . . . - 1.0 to + 7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 2.5 Watt
*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage | -0.5 | + 0.8 | V |  |
| $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.0 \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 |  | 340 | mA | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $I_{L I}$ | Input Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{OV}<\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 }}$ |
| $V_{C L}$ | 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}, \overline{R Q} / \overline{G T}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $C_{10}$ | Capacitance of I/O Buffer $\left(A D_{0}-A D_{15}, \overline{R Q} / \overline{G T}\right)$ |  | 15 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |

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

## MINIMUM COMPLEXITY SYSTEM TIMING REQUIREMENTS

| Symbol | Parameter | IAPX 86 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| TCLCL | CLK Cycle Period - 8086 | 200 | 500 | ns | From 1.0V to 35.V |
| TCLCH | CLK Low Time | (2/3 TCLCL)-15 |  | ns |  |
| TCHCL | CLK High Time | $(113$ TCLCL) +2 |  | ns |  |
| TCH1CH2 | CLK Rise Time |  | 10 | ns |  |
| TCL2CL1 | CLK Fall Time |  | 10 | ns | From 3.5 V to 1.0 V |
| TDVCL | Data in Setup Time | 30 |  | ns | dor |
| TCLDX | 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/3 TCLCL)-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, TEST Setup Time (See Note 2) | 30 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time (Except CLK) |  | 12 | ns | From 2.0 V to 0.8 V |

TIMING RESPONSES

| Symbol | Parameter | IAPX 86 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| TCLAV | Address Valid Delay | 10 | 110 | ns | $C_{L}=20-100 \mathrm{pF}$ for all 8086 Outputs (In addition to 8086 self-load) |
| 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 |  |
| TLLAX | Address Hold Time to ALE Inactive | TCHCL-10 |  | ns |  |
| TCLDV | Data Valid Delay | 10 | 110 | ns |  |
| TCHDX | Data Hold Time | 10 |  | ns |  |
| TWHDX | Data Hold Time After WR | TCLCH-30 |  | n's |  |
| TCVCTV | Control Active Delay 1 | 10 | 110 | ns |  |
| TCHCTV | Control Active Delay 2 | 10 | 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{\mathrm{RD}}$ Inactive to Next Address Active | TCLCL-45 |  | ns |  |
| TCLHAV | HLDA Valid Delay | 10 | 160 | ns |  |
| TRLRH | $\overline{\text { RD Width }}$ | 2TCLCL-75 |  | ns |  |
| TWLWH | WR Width | 2TCLCL-60 |  | ns |  |
| TAVAL | Address Valid to ALE Low | TCLCH-60 |  | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## 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 ( 8 ns into T3).

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



## WAVEFORMS (Continued)

## BUS TIMING-MINIMUM MODE SYSTEM (Continued)



## NOTES:

1. All signals switch between $V_{O H}$ and $V_{O L}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Two INTA cycles run back-to-back. The 8086 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control signals shown for second INTA cycle.
4. Signals at 8284A are shown for reference only.
5. All timing measurements are made at 1.5 V unless otherwise noted.

MILITARY IAPX 86

## A.C. CHARACTERISTICS

MAX MODE SYSTEM (USING 8288 BUS CONTROLLER)
TIMING REQUIREMENTS

| Symbol | Parameter | 8086 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| TCLCL | CLK Cycle Period - 8086 | 200 | 500 | ns |  |
| TCLCH | CLK Low Time | (2/3 TCLCL) - 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 |  |
| TCLDX | 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/3 TCLCL) - 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, TEST) (See Note 2) | 30 |  | ns |  |
| TGVCH | RQ/GT Setup Time | 30 |  | ns |  |
| TCHGX | RQ Hold Time into 8086 | 40 |  | ns |  |
| TILIH | Input Rise Time (Except CLK) |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time (Except CLK) |  | 12 | ns | From 2.0 V to 0.8 V |

## TIMING RESPONSES

| Symbol | Parameter | 8086 |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| TCLML | Command Active Delay (See Note 1) | 10 | 35 | ns | $C_{L}=20-100 \mathrm{pF} \text { for }$ <br> all 8086 Outputs <br> (In addition to 8086 self-load) |
| 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 | 10 | 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 | 10 | 110 | ns |  |
| TCHDX | Data Hold Time | 10 |  | 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 |  |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | $\mathbf{8 0 8 6 / 8 0 8 6 - 4}$ |  | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| 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 | GT Active Detay | 0 | 85 | ns |  |
| TCLGH | GT Inactive Delay | 0 | 85 | ns |  |
| TRLRH | RD Width | $2 T C L C L-75$ |  | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From Q.8V to 2.0V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0V to 0.8V |

## 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 T 3 and wait states.
4. Applies only to T 2 state ( 8 ns into T 3 ).

MILITARY iAPX 86

## WAVEFORMS

BUS TIMING-MAXIMUM MODE SYSTEM (USING 8288)


WAVEFORMS (Continued)


## NOTES:

1. All signals switch between $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ unless otherwise specified.
2. RDY is sampled near the end of $T_{2}, T_{3}, T_{W}$ to determine if $T_{W}$ machines states are to be inserted.
3. Cascade address is valid between first and second INTA cycle.
4. Two INTA cycles run back-to-back. The 8086 LOCAL ADDR/DATA BUS is floating during both INTA cycles. Control for pointer address is shown for second INTA cycle.
5. Signals at 8284A or 8288 are shown for reference only.
6. The issuance of the 8288 command and control signals ( $\overline{M R D C}, \overline{M W T C}, \overline{A M W C}, \overline{I O R C}, \overline{I O W C}, \overline{A I O W C}, \overline{I N T A}$ and DEN) lags the active high 8288 CEN.
7. All timing measurements are made at 1.5 V unless otherwise noted.
8. Status inactive in state just prior to $\mathrm{T}_{4}$.

## M8155H <br> 2048-BIT STATIC HMOS RAM WITH I/O PORTS AND TIMER

MILITARY

Full Military Temperature Range: $-55^{\circ} \mathrm{C} \quad 2$ Programmable 8-Bit I/O Ports to $+125^{\circ} \mathrm{C}$<br>- 1 Programmable 6-Bit I/O Port<br>- 30\% Lower Power Consumption than the M8155<br>100\% Compatible with M8155<br>256 Word x 8 Bits<br>Completely Static Operation<br>Internal Address Latch<br>- Programmable 14-Bit Binary Counter/ Timer<br>- Compatible with M8085AH<br>Multiplexed Address and Data Bus<br>Single +5V Power Supply with 10\% Voltage Margins

The Intel M8155H is a RAM and I/O chip implemented in N-Channel, depletion load, silicon gate technology (HMOS) to be used in the M8085AH microprocessor 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 an M8085AH 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.


Figure 1. M8155H Block Diagram


Figure 2. M8155H Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under B | $-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 |

*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | 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{IOL}=2 \mathrm{~mA}$ |
| V OH | Output High Voltage | 2.4 | $\because$ | V | $\mathrm{IOH}^{\prime}=-400 \mu \mathrm{~A}$ |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ILO | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{A}$ | $0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ICC | VCC Supply Current |  | 125 | mA |  |
| IIL ( $\overline{\mathrm{CE}})$ | Chip Enable Leakage M8155H | - ${ }^{\text {c }}$ | + 100 | $\mu \mathrm{A}$ | $\mathrm{OV} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |

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

|  |  | M8155H |  |  |
| :---: | :--- | :---: | :---: | :---: |
| Symbol |  | Min | Max | Units |
| taL | Address to Latch Set Up Time | 50 |  | ns |
| tLA | Address Hold Time after Latch | 80 |  | ns |
| tLC | Latch to READ/WRITE Control | 100 |  | ns |
| tRD | Valid Data Out Delay from READ Control |  | 170 | ns |
| taD | Address Stable to Data Out Valid |  | 400 | ns |
| tLL | Latch Enable Width | 100 |  | ns |
| tRDF | Data Bus Float After READ | 0 | 100 | ns |
| tCL | READ/WRITE Control to Latch Enable | 20 |  | ns |
| tCC | READ/WRITE Control Width | 250 |  | ns |
| tDW | Data In to WRITE Set Up Time | 150 |  | ns |
| tWD | Data In Hold Time After WRITE | 0 |  | ns |
| tRV | Recovery Time Between Controls | 300 |  | ns |
| tWP | WRITE to Port Output |  | 400 | ns |
| tPR | Port Input Setup Time | 70 |  | ns |
| tRP | Port Input Hold Time | 50 |  | ns |
| tSBF | Strobe to Buffer Full |  | 400 | ns |
| tSS | Strobe Width | 200 |  | ns |
| tRBE | READ to Buffer Empty |  | 400 | ns |
| tSI | Strobe to INTR On |  | 400 | ns |

M8155H
A.C. CHARACTERISTICS (Continued) $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

|  |  | M8155H |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min | Max | Units |
| tr ${ }_{\text {R }}$ | READ to INTR Off |  | 400 | ns |
| tPSS | Port Setup Time to Strobe Strobe | 50 |  | ns |
| tpHS | Port Hold Time After Strobe | 120 |  | ns |
| tSBE | Strobe to Buffer Empty |  | 400 | ns |
| tWBF | WRITE to Buffer Full |  | 400 | ns |
| tWI | WRITE to INTR Off |  | 400 | ns |
| ${ }_{\text {t }}$ TL | TIMER-IN to TIMER-OUT Low |  | 400 | ns |
| tTH | TIMER-IN to TIMER-OUT High |  | 400 | ns |
| trde | 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 |

## InPUT/OUTPUT



A C TESTING INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "1" AND 0.45 V FOR A LOGIC "0". TIMING MEASUREMENTS ARE MADE AT 2.0 V FOR A LOGIC "1" AND $0.8 V$ FOR A LOGIC " 0 ".

Figure 4. A.C. Testing Input, Output Waveform

$C_{L}=150 \mathrm{pF}$
$C_{L}$ INCLUDES JIG CAPACITANCE
Figure 5. A.C. Testing Load Circuit

## WAVEFORMS



## M8185* <br> $1024 \times 8$-BIT STATIC RAM FOR MCS-85 ${ }^{\circledR}$ <br> *Compatible with 8085A. <br> MILITARY

- Multiplexed Address and Data Bus
- Directly Compatible with 8085A and 8088 Microprocessors
- Low Operating Power Dissipation
- Low Standby Power Dissipation
- Single +5 V Supply
- High Density 18-Pin Package
- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel ${ }^{\circledR}$ M8185 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 and 8088 microprocessors to provide a maximum level of system integration.

The low standby power dissipation minimizes system power requirements when the 8185 is disabled.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| as | $-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 W |

Storage Temperature $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Voltage on Any Pin
with Respect to Ground ............... -0.5 V to +7 V

NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| 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}_{\text {cc }}+0.5$ | V |  |
| VOL | Output Low Voltage |  | 0.45 | V | $\mathrm{IOL}=1.6 \mathrm{~mA}$ |
| VOH | Output High Voltage | 2.4 |  |  | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| ILL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {cC }}$ |
| 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 |  | 150 | mA |  |
|  | Powered Down |  | 50 | mA |  |

A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter ${ }^{[1]}$ | 8185Preliminary |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $t_{\text {AL }}$ | Address to Latch Set Up Time | 50 |  | ns |
| $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 {LD }}$ | ALE to Data Out Valid |  | 300 | ns |
| $t_{\text {LL }}$ | Latch Enable Width | 100 |  | ns |
| $t_{\text {RDF }}$ | Data Bus Float after READ | 0 | 100 | ns |
| ${ }^{\text {cta }}$ | READ/WRITE Control to Latch Enable | 20 |  | ns |
| ${ }_{\text {tcc }}$ | READ/WRITE Control Width | 250 |  | ns |
| $t_{\text {DW }}$ | Data In to Write Set Up Time | 150 |  | ns |
| $t_{\text {WD }}$ | Data In Hold Time after WRITE | 20 |  | ns |
| $t_{\text {sc }}$ | Chip Select Set Up to Control Line | 10 |  | ns |
| $\mathrm{t}_{\mathrm{CS}}$ | Chip Select Hold Time after Control | 10 |  | ns |
| $t_{\text {ALCE }}$ | Chip Enable Set Up to ALE Falling | 30 |  | ns |
| t LACE | Chip Enable Hold Time after ALE | 50 |  | ns |

## NOTES:

1. All A.C. parameters are referenced at
a) 2.4 V and .45 V for inputs
b) 2.0 V and .8 V for outputs.

## M8212 <br> 8-BIT INPUT/OUTPUT PORT <br> MILITARY

\author{

- Fully Parallel 8-Bit Data Register and Buffer <br> ■ Service Request Flip-Flop for Interrupt Generation <br> ■ Low Input Load Current 0.25mA Max <br> - 3-State Outputs <br> - 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.


Figure 1. 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 or Supply Voltages . . . . -0.5 to +7 Volts All Input Voltages . . . . . . . . . . . . -1.0 to 5.5 Volts Output Currents . . . . . . . . . . . . . . . . . . . . . . . 100 mA
*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stess 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_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Limits |  |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| If | Input Load Current <br> STB, $\mathrm{DS}_{2}, \mathrm{CR}, \mathrm{Dl}_{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}$ |
| $I_{\text {R }}$ | Input Leakage Current STB, DS, CR, $\mathrm{DI}_{1}-\mathrm{DI}_{8}$ Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{Cc}}$ |
| $I_{\text {R }}$ | Input Leakage Current MD Input |  |  | 30 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{CC}}$ |
| $I_{\text {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 |  |
| $V_{\text {IH }}$ | Input "High" Voltage | 2.0 |  |  | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output "Low" Voltage |  |  | . 45 | V | $1 \mathrm{la}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | 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 |  |

CAPACITANCE ( $\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}$ )

| Symbol | Test | LIMITS |  |
| :--- | :--- | :---: | :---: |
|  |  | Typ. | Max. |
| $\mathrm{C}_{\text {IN }}$ | $\overline{\mathrm{DS}}, \mathrm{MD}$ Input Capacitance | 9 pF | 15 pF |
| $\mathrm{C}_{\mathrm{IN}}$ | $\mathrm{DS}_{2}, \overline{\mathrm{CLR}}, \mathrm{STB}, \mathrm{DI}_{1},-\mathrm{DI}_{8}$ <br> Input Capacitance | 5 pF | 10 pF |
| $\mathrm{C}_{\text {OUT }}$ | $\mathrm{DO}^{2}-\mathrm{DO}_{8}$ Output Capacitance | 8 pF | 15 pF |

## Conditions of Test

Input Pulse Amplitude $=2.5 \mathrm{~V}$
Input Rise and Fall Times: 5 ns between 1 V and 2V
Measurements made at 1.5 V
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)$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tPW | Pulse Width | 40 |  | ns |  |
| $t_{\text {PD }}$ | Data To Output Delay |  | 30 | ns | NOTE 1 |
| $t_{\text {WE }}$ | 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_{\text {R }}$ | Reset To Output Delay |  | 55 | ns | NOTE 1 |
| ts | Set To Output Delay |  | 35 | ns | NOTE 1 |
| $\mathrm{t}_{\mathrm{E}}$ | Output Enable/Disable Time |  | 50 | ns | NOTE $1 \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ |
| ${ }^{\text {t }}$ | Clear To Output Delay |  | 55 | ns | NOTE 1 |

NOTE 1:

| TEST | $\mathbf{C}_{\mathbf{L}}$ | $\mathbf{R}_{\mathbf{1}}$ | $\mathbf{R}_{\mathbf{2}}$ |
| :--- | :---: | :---: | :---: |
| $\mathrm{t}_{\text {PD }}, \mathrm{t}_{\text {WE }}, \mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{s}}, \mathrm{t}_{\mathrm{C}}$ | 30 pF | $300 \Omega$ | $600 \Omega$ |
| $\mathrm{t}_{\mathrm{E}}$, ENABLE $\uparrow$ | 30 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| $\mathrm{t}_{\mathrm{E}}$, ENABLE $\downarrow$ | 30 pF | $300 \Omega$ | $600 \Omega$ |
| $\mathrm{t}_{\mathrm{E}}$, DISABLE $\uparrow$ | 5 pF | $300 \Omega$ | $600 \Omega$ |
| $\mathrm{t}_{\mathrm{E}}$, DISABLE $\downarrow$ | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

A.C. TESTING LOAD CIRCUIT


WAVEFORMS


# M8214 <br> PRIORITY INTERRUPT CONTROL UNIT <br> MILITARY 

## - 8 Priority Levels

- Fully Expandable
- Current Status Register


## - Priority Comparator

24-Pin Dual In-Line Package

- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- +10\% Power Supply Tolerance

The Intel ${ }^{*}$ 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.


Figure 1. Logic Diagram


M8214

## 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
*NOTICE: 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}=55^{\circ} \mathrm{C}\right.$ 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 | $I_{C}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Forward Current: | ETLG input all other inputs |  | $\begin{aligned} & -.15 \\ & -.08 \end{aligned}$ | $\begin{aligned} & -0.5 \\ & -0.25 \end{aligned}$ | $\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}$ |
| VIL | Input LOW Voltage: | all inputs |  |  | 0.8 | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input HIGH Voltage: | all inputs | 2.0 |  |  | V | $V_{C C}=5.0 \mathrm{~V}$ |
| ICC | Power Supply Current |  |  | 90 | 130 | mA | See Note 2. |
| $\mathrm{V}_{\text {OL }}$ | Output LOW Voltage: | all outputs |  | . 3 | . 45 | $V$ | $1 \mathrm{OL}=10 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage: | ENLG output | 2.4 | 3.0 |  | V | $\mathrm{IOH}=-1 \mathrm{~mA}$ |
| los. | Short Circuit Output Current: ENLG output |  | -15 | -35 | -55 | mA | $\mathrm{V}_{C C}=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}$ |

CAPACITANCE ( $\mathrm{V}_{\text {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}$ )

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{[1]}$ | Max |  |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 5 | 10 | pF |
| Cout | Output Capacitance Except ENLG (Pin 14) |  | 7 | 12 | pF |

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)$

| Symbol | Parameter | Limits |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. ${ }^{\text {[1] }}$ | Max. |  |
| ${ }^{\text {t }} \mathrm{CY}$ | CLK Cycle Time | 85 |  |  | ns |
| ${ }_{\text {t PW }}$ | $\overline{C L K}, \overline{\text { ECS }}$, 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 CLK | 20 | 10 |  | ns |
| $\mathrm{t}_{\text {ETCS }}{ }^{[2]}$ | ETLG Setup Time to $\overline{\text { CLK }}$ | 25 | 12 |  | ns |
| $\mathrm{t}_{\mathrm{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{\text { CLK }}$ | 85 | 25 |  | ns |
| $\mathrm{t}_{\mathrm{ECCH}}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{C L K}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {ECRS }}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{\text { CLK }}$ | 110 | 70 |  | ns |
| ${ }^{\text {t }}$ ECRH | ECS Hold Time After $\overline{\text { CLK }}$ | 0 |  |  |  |
| $\mathrm{t}_{\mathrm{ECSS}}{ }^{[2]}$ | $\overline{\text { ECS }}$ Setup Time to $\overline{\text { CLK }}$ | $\therefore 85$ | 70 |  | ns |
| $\mathrm{t}_{\mathrm{ECSH}}{ }^{[2]}$ | $\overline{\text { ECS }}$ Hold Time After $\overline{\text { CLK }}$ | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{DCS}}{ }^{[2]}$ | $\overline{\mathrm{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{B_{0}} \cdot \overline{B_{2}}$ Hold Time After $\overline{\text { CLK }}$ | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{RCS}}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to $\overline{\mathrm{CLK}}$ | 100 | 55 |  | ns |
| $\mathrm{t}_{\mathrm{RCH}}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ Hold Time After $\overline{C L K}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {cs }}$ | INT Setup Time to $\overline{\text { CLK }}$ | 55 | 35 |  | ns |
| ${ }^{\text {t }}$ CI | $\overline{\mathrm{CLK}}$ to INT Propagation Delay |  | 15 | 30 | ns |
| $\mathrm{t}_{\text {RIS }}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ Setup Time to INT | 10 | 0 |  | ns |
| $\mathrm{t}_{\text {RIH }}$ | $\overline{R_{0}} \cdot \overline{R_{7}}$ Hold Time After $\overline{\mathrm{NTT}}$ | 35 | 20 |  | ns |
| $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 |
| $\mathrm{t}_{\text {ELA }}$ | $\overline{\mathrm{ELR}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 40 | 55 | ns |
| $\mathrm{t}_{\mathrm{ECA}}$ | $\overline{\mathrm{ECS}}$ to $\overline{\mathrm{A}_{0}} \cdot \overline{\mathrm{~A}_{2}}$ Propagation Delay |  | 100 | 130 | 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 }}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Setup Time to $\overline{\mathrm{ECS}}$ | 20 | 10 |  | ns |
| $\mathrm{t}_{\text {DECH }}$ | $\overline{\text { SGS }}$ and $\overline{\mathrm{B}_{0}} \cdot \overline{\mathrm{~B}_{2}}$ Hold Time After ECS | 20 | 10 |  | ns |
| $\mathrm{t}_{\text {REN }}$ | $\overline{\mathrm{R}_{0}} \cdot \overline{\mathrm{R}_{7}}$ to ENLG Propagation Delay |  | 45 | 70 | ns |
| $\mathrm{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 }}$ | $\overline{\text { ECS }}$ to ENLG Propagation Delay |  | 35 | 55 | ns |

NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, V_{C C}=5.0 \mathrm{~V}$.
2. $B_{0}-B_{2}, \overline{S G S}, C L K, \overline{R_{0}}-\overline{R_{4}}$ grounded, all other inputs and all outputs open.

## intel

# M8216/M8226 <br> 4-BIT PARALLEL BIDIRECTIONAL BUS DRIVER 

MILITARY

Data Bus Buffer Driver for 8080 CPU
■ Low Input Load Current: 0.25mA Maximum

■ High Output Drive Capability for Driving System Data Bus

## 16-Pin Dual In-Line Package

- 3.40V Output High Voltage for Direct
Interface to 8080 CPU
- 3-State Outputs

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



| $\mathrm{DB}_{0} \cdot \mathrm{DB}_{3}$ | DATA BUS <br> BI-DIRECTIONAL |
| :--- | :--- |
| $\mathrm{DI}_{0} \cdot \mathrm{DI}_{3}$ | DATA INPUT |
| $\mathrm{DO} 0_{0} \cdot \mathrm{DO}_{3}$ | DATA OUTPUT |
| $\overline{\text { DIEN }}$ | DATA IN ENABLE <br> DIRECTION CONTROL |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |

Figure 2. Pin Configuration

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

*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Limits |  |  | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| If1 | Input Load Current $\overline{\text { DIEN }}$, $\overline{\mathrm{CS}}$ |  | -0.15 | -. 5 | mA | $\mathrm{V}_{\mathrm{F}}=0.45$ |
| $\mathrm{I}_{\text {F2 }}$ | Input Load Current All Other Inputs |  | -0.08 | -. 25 | mA | $V_{F}=0.45$ |
| IR1 | Input Leakage Current $\overline{\text { DIEN, }}$ CS |  |  | 20 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| $I_{\text {R } 2}$ | Input Leakage Current DI Inputs |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| VC | Input Forward Voltage Clamp |  |  | -1.2 | V | $\mathrm{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{V}_{C C}=5 \mathrm{~V}$ |
| VIH | Input "High" Voltage | 2.0 |  |  | V | $\mathrm{V}_{\text {cc }}=5 \mathrm{~V}$ |
| \|lo| | Output Leakage Current DO <br> (3-State) DB <br> Por |  |  | $\begin{gathered} 20 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ |
| ICC | Power Supply Current 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}$ |
| V OH | Output "High" Voltage | 3.4 | 3.8 |  | V | DO Outputs $1 \mathrm{IOH}=-.5 \mathrm{~mA}$ |
| VOH2 | Output "High" Voltage | 2.4 | 3.0 |  | V | DO Outputs $I_{\mathrm{OH}}=-2 \mathrm{~mA}$ <br> DB Outputs $\mathrm{IOH}=-5.0 \mathrm{~mA}$ |
| Ios | Output Short Circuit Current | $\begin{aligned} & -15 \\ & -30 \end{aligned}$ | $\begin{aligned} & \hline-35 \\ & -75 \end{aligned}$ | $\begin{gathered} \hline-65 \\ -120 \end{gathered}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | DO Outputs $\mathrm{VCC}=5.0 \mathrm{~V}$ <br> DB Outputs $V_{C C}=5.0 \mathrm{~V}$ |

NOTE: Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
CAPACITANCE ( $\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}$ )

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

## Conditions of Test

Input Pulse Amplitude $=2.5 \mathrm{~V}$
Input Rise and Fall Times: 5 ns between 1V and 2V
Measurements made at 1.5 V

## A.C. CHARACTERISTICS $\left(T_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%\right)$

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

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
2. 

| TEST | $\mathrm{C}_{\mathrm{L}}$ | R1 | $\mathrm{R}_{2}$ |
| :---: | :---: | :---: | :---: |
| $T_{\text {PD1 }}$ | 30 pF | 300:2 | 60082 |
| TPD2 | 300 pF | 9032 | 180S2 |
| $T_{E},(D 0, E N A B L E T)$ | 30 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| TE, (DO, ENABLEV) | 30 pF | 30082 | 60082 |
| $\mathrm{T}_{\mathrm{E}}$, (DB, ENABLE $\dagger$ ) | 300 pF | 10KS | $1 \mathrm{~K} \Omega 2$ |
| $T_{E},(D B, E N A B L E \downarrow$; | 300 pF | 9032 | 18082 |
| $T_{\text {D }}$, (DO, DISABLE $)$ | 5 pF | $300 \Omega$ | $600 \Omega$ |
| T ${ }_{\text {d }}$ ( $D$ O, DISABLE $\downarrow$ ) | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |
| TD, (DB, DISABLE $\dagger$ ) | 5 pF | $90 \Omega$ | $180 \Omega$ |
| T , (DB, DISABLE $\downarrow$ ) | 5 pF | $10 \mathrm{~K} \Omega$ | $1 \mathrm{~K} \Omega$ |

## A.C. TESTING LOAD CIRCUIT



WAVEFORMS


M8224
CLOCK GENERATOR AND DRIVER
For 8080A CPU
MILITARY

## Single Chip Clock Generator/Driver for M8080A CPU <br> - Power-Up Reset for CPU <br> - Ready Synchronizing Flip-Flop <br> Advanced Status Strobe <br> - Military Temperature Range:

$-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C} \quad \pm 10 \%$ Power Supply Tolerance

- Oscillator Output for External System Timing
- Crystal Controlled for Stable System Operation
- Reduces System Package Count

The Intel ${ }^{(1)}$ 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.


Figure 1. Block Diagram



| XTAL 1 | CONNECTIONS <br> FOR CRYSTAL |
| :--- | :--- |
| XTAL 2 |  |
| TANK | USED WITHOVERTONE XTAL |
| OSC | OSCILLATOR OUTPUT |
| $\phi_{2}$ (TTL) | $\phi_{2}$ CLK (TTL LEVEL) |
| $V_{\text {CC }}$ | +5 V |
| $V_{\text {DD }}$ | +12 V |
| GND | OV |

Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

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

*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $\left.125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5.0 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{I}_{\mathrm{F}}$ | Input Current Loading |  |  | -. 25 | mA | $\mathrm{V}_{\mathrm{F}}=.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=5.5 \mathrm{~V}$ |
| $V_{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}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input "High" Voltage $\overline{\text { RESIN }}$ <br> All Other Inputs | $\begin{aligned} & 2.6 \\ & 2.0 \end{aligned}$ |  |  | V |  |
| $\mathrm{V}_{\text {IH }}-\mathrm{V}_{\text {IL }}$ | $\overline{\text { RESIN }}$ Input Hysteresis | . 25 |  |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | $\begin{array}{r} \text { Output "Low" Voltage OSC, } \\ \phi 2 \text { (TTL) } \\ \text { All Other Outputs } \end{array}$ |  |  | $\begin{gathered} .45 \\ .45 \end{gathered}$ | $\mathrm{V}$ V | $\begin{aligned} & \mathrm{IOL}=10 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OL}}=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 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| bos ${ }^{[1]}$ | Output Short Circuit Current (All Low Voltage Outputs Only) | -10 |  | -60 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{O}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{Cc}}$ | Power Supply Current |  |  | 115 | mA |  |
| $\mathrm{I}_{\mathrm{DD}}$ | 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-35$ pF
Equivalent Resistance: 75-20 ohms
Power Dissipation (Min): 4mW
*With tank circuit use 3rd overtone mode.
A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=+5.0 \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Limits |  |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |  |
| $\mathrm{t}_{\phi 1}$ | $\phi_{1}$ Pulse Width | $\frac{2 \text { 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 \mathrm{~ns}$ |  |  |  |  |
| ${ }^{t}{ }_{\text {1 }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | 0 |  |  |  |  |
| $t_{\text {D } 2}$ | $\phi_{2}$ to $\phi_{1}$ Delay | $\frac{2 \mathrm{tcy}}{9}-25 \mathrm{~ns}$ |  |  |  |  |
| $t_{\text {t }}$ | $\phi_{1}$ to $\phi_{2}$ Delay | $\frac{2 \mathrm{tcy}}{9}$ |  | $\frac{2 \mathrm{tcy}}{9}+40 \mathrm{~ns}$ |  |  |
| $\mathrm{t}_{\mathrm{R}}$ | $\phi_{1}$ and $\phi_{2}$ Rise Time |  |  | 25 |  |  |
| $t_{\text {F }}$ | $\phi_{1}$ and $\phi_{2}$ Fall Time |  |  | 25 |  |  |
| $t_{\text {D } \phi 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}$ |
| toss | $\phi_{2}$ to STSTB Delay | $\frac{6 \mathrm{tcy}}{9}-30 \mathrm{~ns}$ |  | $\frac{6 \text { tcy }}{9}$ | : | '. |
| ${ }_{\text {tPW }}$ | STSTB Pulse Width | $\frac{\text { tcy }}{9}-23 \mathrm{~ns}$ |  |  |  | $\overline{\text { STSTB }}, C L=15 \mathrm{pF}$ $R_{1}=2 K$ |
| ${ }^{\text {t }}$ DRS | RDYIN Setup Time to Status Strobe | $50 \mathrm{~ns}-\frac{4 \mathrm{tcy}}{9}$ |  |  |  | $\mathrm{R}_{2}=4 \mathrm{~K}$ |
| ${ }^{\text {t }}$ DRH | RDYIN Hold Time After STSTB | $\frac{4 \mathrm{tcy}}{9}$ |  |  |  |  |
| $t_{\text {DR }}$ | READY or RESET to $\phi_{2}$ Delay | $\frac{4 t c y}{9}-25 n s$ |  | $\cdots$ |  | $\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}$ |

## Example:

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


## A.C. TESTING LOAD CIRCUIT



C L includes Jig capacitance

## WAVEFORMS



# M8228 <br> SYSTEM CONTROLLER AND BUS DRIVER FOR M8080A CPU 

MILITARY

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

- Built-In Bidirectional Bus Driver for Data Bus Isolation

\author{

- 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
- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- $\pm 10 \%$ Power Supply Tolerance

The Intel ${ }^{\circledR}$ M8228 is a single chip system controller and bus driver for MCS-80 ${ }^{\circledR}$. 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.


Figure 1. Block Diagram

| 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 | STSTB | STATUS STROBE (FROM 8224) |
| MEMW | MEMORY WRITE | $\mathrm{V}_{\mathrm{cc}}$ | $+5 \mathrm{~V}$ |
| DBIN | DBIN (FROM 8080) | GND | 0 VOLTS |

Figure 2. Pin Configuration


Figure 3. M8080A CPU Interface


Figure 4. Status Word Chart

## 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 | -1.0 V to +7V |
| Output Current | 100 mA |


#### Abstract

*NOTICE: 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(\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)^{[1]}$

| Symbol | Parameter | Limits |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage, All Inputs |  | -1.2 | V | $I_{C}=-5 \mathrm{~mA}$ |
| $\mathrm{I}_{\mathrm{F}}$ | Input Load Current, $\overline{\text { STSTB }}$ |  | 500 | $\mu \mathrm{A}$ | $V_{F}=0.4 V$ |
|  | $\mathrm{D}_{2}, \mathrm{D}_{6}$ |  | 750 | $\mu \mathrm{A}$ |  |
|  | $\mathrm{D}_{0}, \mathrm{D}_{1}, \mathrm{D}_{4}, \mathrm{D}_{5}, \mathrm{D}_{7}$ |  | 250 | $\mu \mathrm{A}$ |  |
|  | All Other Inputs |  | 250 | $\mu \mathrm{A}$ |  |
| $I_{\text {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{IOL}=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}_{C C}=5 \mathrm{~V}$ |
| 10 (Off) | Off State Output Current, All Controls Outputs |  | 100 | $\mu \mathrm{A}$ | $\mathrm{V}_{0}=5.5 \mathrm{~V}$ |
|  |  |  | -100 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{O}}=.45 \mathrm{~V}$ |
| IINT | INTA Current |  | 5 | mA | (See Figure) |

CAPACITANCE ( $\left.\mathrm{V}_{\text {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}\right)$

|  |  | Limits |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Symbol | Parameter | Min. | Typ. ${ }^{11]}$ | Max. | Unit |
| 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 |

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

## A.C. CHARACTERISTICS $\quad\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Limits |  | Units | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |  |
| tpW | Width of Status Strobe | 25 |  | ns |  |
| ${ }_{\text {tss }}$ | Setup Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 8 |  | ns |  |
| ${ }_{\text {tS }}$ | Hold Time, Status Inputs $\mathrm{D}_{0}-\mathrm{D}_{7}$ | 5 |  | ns |  |
| $\mathrm{t}_{\mathrm{DC}}$ | Delay from STSTB to any Control Signal | 20 | 75 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RR}}$ | Delay from DBIN to Control Outputs |  | 30 | ns | $\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 |  | 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}$ |
| $t_{\text {WE }}$ | Delay to Enable System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ after STSTB |  | 30 | ns | $C_{L}=100 \mathrm{pF}$ |
| ${ }_{\text {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}$ |
| $\mathrm{t}_{\mathrm{E}}$ | Delay from System Bus Enable to System Bus $\mathrm{DB}_{0}-\mathrm{DB}_{7}$ |  | 30 | ns | $C_{L}=100 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{HD}}$ | HLDA to Read Status Outputs |  | 25 | ns | $C_{L}=100 \mathrm{pF}$ |
| ${ }^{\text {t }}$ D | Setup Time, System Bus Inputs to HLDA | 10 |  | ns |  |
| ${ }^{\text {t }}$ H | Hold Time, System Bus Inputs to HLDA | 20 |  | ns |  |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages.
2. For $D_{0}-D_{7}: R_{1}=4 K \Omega, R_{2}=\infty \Omega, C_{L}=25 \mathrm{pF}$. For all other outputs: $R_{1}=500 \Omega, R_{2}=1 \mathrm{~K} \Omega, C_{L}=100 \mathrm{pF}$.

## A.C. TESTING LOAD CIRCUIT




INTA Test Circuit (for RST 7)

## WAVEFORMS



VOLTAGE MEASUREMENT POINTS: $\mathrm{D}_{0}-\mathrm{D}_{7}$ (when outputs) Logic " 0 " $=0.8 \mathrm{~V}$, Logic " 1 " $=3.0 \mathrm{~V}$. All other signals measured at 1.5 V .

# M8231A <br> ARITHMETIC PROCESSING UNIT 

## Military

- Fixed Point Single and Double Precision (16/32 Bit)
- Floating Point Single Precision (32 Bit)
- Binary Data Formats

Add, Subtract, Multiply and Divide

- Trigonometric and Inverse Trigonometric Functions
- Square Roots, Logarithms, Exponentiation
- Float to Fixed and Fixed to Float Conversions


## - Stack Oriented Operand Storage

- Compatible with MCS-80®, MCS-85® ${ }^{\text {® }}$ and IAPX 86 Microprocessor Families
- Direct Memory Access or Programmed I/O Data Transfers
- End of Execution Signal
- 4 MHz Clock Rate
- Standard 24 Pin Package
- +12 Volt and +5 Volt Power Supplies
- Advanced N-Channel Silicon Gate HMOS Technology
- Full Military Temperature

Range $-\mathbf{- 5 5 ^ { \circ }} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The Intel M8231A Arithmetic Processing Unit (APU) is a monolithic HMOS LSI device that provides high performance fixed and floating point arithmetic and floating point trigonometric operations. It may be used to enhance the mathematical capability of a wide variety of processor-oriented systems. Chebyshev polynomials are used in the implementation of the APU algorithms.

All transfers, including operand, result, status and command information, take place over an 8-bit bidirectional data bus. Operands are pushed onto an internal stack and commands are issued to perform operations on the data in the stack. Results are then available to be retrieved from the stack.

Transfers to and from the APU may be handled by the associated processor using conventional programmed I/O, or may be handled by a direct memory access controller for improved performance. Upon completion of each command, the APU issues an end of execution signal that may be used as an interrupt by the CPU to help coordinate program execution.


Figure 1. M8231A Block Diagram


Figure 2. M8231A Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ Ambient Temperature Under Bias . . . . $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ VDD with Respect to VSS . . . . . . . . . . . -0.5 V to +15.0 V
 All Signal Voltages with Respect
to VSS . . . . . . . . . . . . . . . . . . . . . . . -0.5 V to +7.0 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 2.0W
*NOTICE: 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 effect device reliability.
D.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}, \mathrm{V}_{S S}=\mathrm{OV}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| V OH | Output HIGH Voltage | 3.7 |  |  | Volts | $\mathrm{I}^{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  |  | 0.4 | Volts | $1 \mathrm{OL}=3.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | Volts |  |
| VIL | Input LOW Voltage | -0.5 |  | 0.8 | Volts |  |
| IIL | Input Load Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| Ioz | Data Bus Leakage |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.4 \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| ICC | $\mathrm{V}_{\text {CC }}$ Supply Current |  | 50 | 95 | mA |  |
| IDD | VDD Supply Current |  | 50 | 95 | mA |  |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance |  | 8 |  | pF |  |
| $\mathrm{C}_{1}$ | Input Capacitance |  | 5 |  | pF | $\mathrm{fc}=1.0 \mathrm{MHz}$, Inputs $=0 \mathrm{~V}$ |
| $\mathrm{CIO}^{\text {a }}$ | 1/O Capacitance |  | 10 |  | pF |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C TESTING. INPUTS ARE DRIVEN AT 3.7V FOR A LOGIC "1" AND 0.4 V FOR A LOGIC " 0 ." TIMING MEASUREMENTS ARE MADE AT 2.0 V FOR A LOGIC " 1 " AND 0.8 V FOR A LOGIC " 0 ."
A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}, \mathrm{V}_{S S}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{DD}}=+12 \mathrm{~V} \pm 10 \%\right)$ READ OPERATION

| Symbol | Parameter |  | $\begin{gathered} 2 \mathrm{MHz} \text { Operation } \\ \hline \text { M8231A-8 } \end{gathered}$ |  | 4 MHz Operation M8231A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| ${ }^{\text {t }}$ AR | $\mathrm{A}_{0}, \overline{\mathrm{CS}}$ Setup to $\overline{\mathrm{RD}}$ |  | 0 |  | 0 |  | ns |
| tra | $A_{0}, \overline{C S}$ Hold from $\overline{\mathrm{RD}}$ |  | 0 |  | 0 |  | ns |
| try | READY ! from $\overline{\mathrm{RD}}$ ! Delay ( Note 2) |  |  | 150 |  | 100 | ns |
| tYR | READY 1 to $\overline{\mathrm{RD}}$ i |  | 0 |  | 0 |  | ns |
| trRR | READY Pulse Width (Note 3) | Data | $\begin{gathered} 3.5 \mathrm{t} \mathrm{CY} \\ +50 \end{gathered}$ |  | $\begin{gathered} 3.5 \mathrm{t} \mathrm{CY} \\ +50 \end{gathered}$ |  | ns |
|  |  | Status | $\begin{gathered} 1.5 \mathrm{t} \mathrm{CY} \\ +50 \end{gathered}$ |  | $\begin{aligned} & 1.5 \mathrm{t} \mathrm{CY} \\ & +50 \end{aligned}$ |  | ns |
| trde | Data Bus Enable from $\overline{\mathrm{RD}}$ ! |  | 50 |  | 50 |  | ns |
| tDRY | Data Valid to READY $\dagger$ |  | 0 |  | 0 |  | ns |
| tDF | Data Float after $\overline{\mathrm{RD}}$ † |  | 50 | 200 | 50 | 100 | ns |

WRITE OPERATION

| Symbol | Parameter |  | $\frac{2 \mathrm{MHz} \text { Operation }}{\text { M8231A-8 }}$ |  | $\frac{4 \mathrm{MHz} \text { Operation }}{\text { M8231A }}$ |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max |  |
| ${ }^{\text {t }}$ AW | $\mathrm{A}_{0}, \overline{\mathrm{CS}}$ Setup to $\overline{\mathrm{WR}}$ |  | 0 |  | 0 |  | ns |
| tWA | $A_{0}, \overline{C S}$ Hold after $\overline{W R}$ |  | 60 |  | 25 |  | ns |
| tWY | READY ! from $\bar{W} R$ ! Delay (Note 2) |  |  | 150 |  | 100 | ns |
| tYW | READY 1 to $\overline{\mathrm{WR}}$ ! |  | 0 |  | 0 |  | ns |
| trRW | READY Pulse Width (Note 4) |  |  | 50 |  | 50 | ns |
| twi | Write Inactive Time (Note 4) | Command | 4 t CY |  | 4 t CY |  | ns |
|  |  | Data | 5 tcy |  | 5 t CY |  | ns |
| tDW | Data Setup to $\overline{\mathrm{WR}}$ |  | 150 |  | 100 |  | ns |
| tWD | Data Hold after $\overline{W R}$ |  | 20 |  | 20 |  | ns |

OTHER TIMINGS

| Symbol | Parameter | $\frac{2 \mathrm{MHz} \text { Operation }}{\text { M8231A-8 }}$ |  | 4 MHz Operation M8231A |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |
|  |  | Min | Max | Min | Max |  |
| ${ }^{\text {t }} \mathrm{CY}$ | Clock Period | 480 | 5000 | 250 | 2500 | ns |
| ${ }^{\text {t }}$ CPH | Clock Pulse High Width | 200 |  | 100 |  | ns |
| ${ }^{t} \mathrm{CPL}$ | Clock Pulse Low Width | 240 |  | 120 |  | ns |
| ${ }^{\text {t E E }}$ | END Pulse Width (Note 5) | 400 |  | 200 |  | ns |
| teat | $\overline{\mathrm{EACK}}$ + to END $\dagger$ Delay |  | 200 |  | 150 | ns |
| ${ }^{\text {t }}$ AA | EACK Pulse Width | 100 |  | 50 |  | ns |
| tSA | SVACK \\| to SVREQ | Delay |  | 300 |  | 150 | ns |
| tSS | $\overline{\text { SVACK Puise Width }}$ | 100 |  | 50 |  | ns |

## NOTES:

1. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$, nominal supply voltages and nominal processing parameters.
2. READY is pulled low for both command and data operations.
3. Minimum values shown assume no previously entered command is being executed for the data access. If a previously entered command is being executed, READY low pulse width is the time to complete execution plus the time shown. Status may be read at any time without exceeding the time shown.
4. READY low pulse width is less than 50 ns when writing into the data port or the control port as long as the duty cycle requirement ( $\mathrm{t}_{\mathrm{W} I}$ ) is observed and no previous command is being executed. tWI may be safely violated as long as the extended trRW that results is observed. If a previously entered command is being executed, READY low pulse width is the time to complete execution plus the time shown. These timings refer specifically to the M8231A
5. $\overline{E N D}$ low pulse width is specified for $\overline{E A C K}$ tied to VSS. Otherwise $t_{E A E}$ applies.

# M8243 <br> MCS-48® INPUT/OUTPUT EXPANDER <br> MILITARY 

- $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ Military Temp.
- Simple Interface to M8748/8048/ 8035L Microcomputers
- Four 4-Bit I/O Ports
- AND and OR Directly to Ports


## 24-Pin DIP <br> Single 5V Supply <br> - High Output Drive <br> - Direct Extension of Resident 8048 I/O Ports

The Intel M8243 is an input/output expander designed specifically to provide a low cost means of I/O expansion for the MCS $-48^{\circledR}$ family of single chip microcomputers. Fabricated in 5 volts NMOS, the M8243 combines low cost, single supply voltage and high drive current capability.
The M8243 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 M8048 be used for I/O expansion, and also allows multiple M8243's to be added to the same bus.
The I/O ports of the M8243 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.



Figure 2. M8243 Pin Configuration

Figure 1. M8243
Block Diagram

[^41]Table 1. Pin Description

| Symbol | Pin No. | Function |
| :---: | :---: | :---: |
| PROG | 7 | Clock Input. A high to low transition on PROG signifies that address and control are available on P20-P23, and a low to high transition signifies that data is available on P20-P23. |
| $\overline{\mathrm{CS}}$ | 6 | Chip Select Input. A high on CS inhibits any change of output or internal status. |
| P20-P23 | 11-8 | Four (4) bit bi-directional port contains the address and control 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. |
| GND | 12 | 0 volt supply. |
| P40-P43 | 2-5 | Four (4) bit bi-directional I/O ports. |
| P50-P53 | 1, 23-21 | May be programmed to be input |
| P60-P63 | 20-17 | (during read), low impedance |
| P70-P73 | 13-16 | latched output (after write), or a tristate (after read). Data on pins P20-P23 may be directly written, ANDed or ORed with previous data. |
| $\mathrm{v}_{\mathrm{CC}}$ | 24 | +5 volt supply. |

## FUNCTIONAL DESCRIPTION

## General Operation

The M8243 contains four 4-bit I/O ports which serve as an extension of the on-chip I/O and are addressed as ports 4-7. 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 M8048 and the M8243 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 M8243's may be added to the 4-bit bus and chip selected using additional output lines from the M8048/8748/ 8035L.

## 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 VCC drops below 1 V .

| P21 | P20 | Address <br> Code | P23 | P22 | Instruction <br> 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 M8243 output. A read of any port will leave that port in a high impedance state.

## 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
*NOTICE: 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 device at these or any other conditions above those indicated in the operational sections of this specification is not implied.
D.C. CHARACTERISTICS
$\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{C C}=5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VIL | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| VIH | Input High Voltage | 2.0 |  | VCC+0.5 | V |  |
| VOL1 | Output Low Voltage Ports 4-7 |  |  | 0.45 | V | $\mathrm{IOL}=4.5 \mathrm{~mA}{ }^{*}$ |
| VOL2 | Output Low Voltage Port 7 |  |  | 1 | V | $1 \mathrm{OL}=20 \mathrm{~mA}$ |
| VOH1 | Output High Voltage Ports 4-7 | 2.4 |  |  | V | $1 \mathrm{OH}=240 \mu \mathrm{~A}$ |
| IIL1 | Input Leakage Ports 4-7 | -10 |  | 20 | $\mu \mathrm{A}$ | $V_{\text {in }}=\mathrm{VCC}$ to $O V$ |
| IIL2 | Input Leakage Port 2, CS, PROG | -10 |  | 10 | $\mu \mathrm{A}$ | $V_{\text {in }}=\mathrm{VCC}$ to OV |
| VOL3 | Output Low Voltage Port 2 |  |  | 45 | $\checkmark$ | $1 \mathrm{OL}=0.6 \mathrm{~mA}$ |
| ICC | VCC Supply Current |  | 10 | 20 | mA |  |
| VOH2 | Output Voltage Port 2 | 2.4 |  |  |  | $1 \mathrm{OH}=100 \mu \mathrm{~A}$ |
| IOL | Sum of all IOL from 16 Outputs |  |  | 72 | mA | 4.5 mA Each Pin |

*See following graph for additional sink current capability

## A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| tA | Code Valid Before PROG | 100 |  | ns | 80 pF Load |
| tB | Code Valid After PROG | 60 |  | ns | 20 pF Load |
| tC | Data Valid Before PROG | 200 |  | ns | 80 pF Load |
| tD | Data Valid After PROG | 20 |  | ns | 20 pF Load |
| tH | Floating After PROG | 0 | 150 | ns | 20 pF Load |
| tK | PROG Negative Pulse Width | 920 |  | ns |  |
| tCS | CS Valid Before/After PROG | 50 |  | ns |  |
| tPO | Ports 4-7 Valid After PROG |  | 700 | ns | 100 pF Load |
| tLP1 | Ports 4-7 Valid Before/After PROG | 120 |  | ns |  |
| tACC | Port 2 Valid After PROG |  | 700 | ns | 80 pF Load |

 M8251A
PROGRAMMABLE COMMUNICATION INTERFACE

## MILITARY

## - Asynchronous Baud Rate - DC to 19.2K Baud

- Full Duplex, Double Buffered, Transmitter and Receiver


## ■ Error Detection - Parity, Overrun and Framing

- Fully Compatible with M8080/M8085 CPU
- 28-Pin DIP Package
- All Inputs and Outputs are TTL Compatible
- Single + 5V Supply
- Single TTL Clock

The Intel ${ }^{\circledR}$ M8251A 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 M8085. The M8251A 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.


Figure 1. Block Diagram


Figure 2. Pin Configuration

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


#### Abstract

*NOTICE: 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 $\quad\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $125^{\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}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ TO 0.45 V |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current |  | 150 | mA | All Outputs $=$ High |

CAPACITANCE $\quad\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | I/O Capacitance |  | 20 | pF | Unmeasured pins returned to GND |

A.C. CHARACTERISTICS $\quad\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$, $\mathrm{GND}=0 \mathrm{~V}$ )

## Bus Parameters ${ }^{[1]}$

READ CYCLE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A R}$ | Address Stable Before $\overline{R E A D}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | -75 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RA}}$ | Address Hold Time for $\overline{\mathrm{READ}}(\overline{\mathrm{CS}}, \mathrm{C} / \overline{\mathrm{D}})$ | 75 |  | ns | Note 2 |
| $\mathrm{t}_{\mathrm{RR}}$ | $\overline{\mathrm{READ}}$ Pulse Width | 300 |  | ns |  |
| $\mathrm{t}_{\mathrm{RD}}$ | Data Delay from $\overline{\mathrm{READ}}$ |  | 280 | ns | $3, C_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{DF}}$ | $\overline{\text { READ }}$ to Data Floating | 5 | 120 | ns |  |

## A.C. CHARACTERISTICS (Continued)

## WRITE CYCLE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | Address Stable Before $\overline{\text { WRITE }}$ | 75 |  | ns |  |
| $\mathrm{t}_{\text {WA }}$ | Address Hold Time for $\overline{\text { WRITE }}$ | 75 |  | ns |  |
| $\mathrm{t}_{W} W$ | WRITE Pulse Width | 300 |  | ns |  |
| $\mathrm{t}_{\mathrm{DW}}$ | Datà Set Up Time for $\overline{\text { WRITE }}$ | 200 |  | ns |  |
| $\mathrm{t}_{\text {WD }}$ | Data Hold Time for $\overline{\text { WRITE }}$ | 80 |  | ns |  |
| $\mathrm{t}_{\text {RV }}$ | Recovery Time Between WRITES | 6 |  | $\mathrm{t}_{\mathrm{CY}}$ | Note 4 |

OTHER TIMINGS

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ CY | Clock Period | 320 | 1350 | ns | Notes 5, 6 |
| ${ }_{\text {t }}$ | Clock High Pulse Width | 150 | $\mathrm{t}_{\mathrm{CY}}$-100 | ns |  |
| ¢ $\overline{\text { ¢ }}$ | Clock Low Pulse Width | 100 |  | ns |  |
| $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}$ | Clock Rise and Fall Time |  | 20 | ns |  |
| $\mathrm{t}_{\text {DTX }}$ | TxD Delay from Falling Edge of $\overline{\mathrm{T} \times \mathrm{C}}$ |  | 1 | $\mu \mathrm{s}$ |  |
| ${ }^{\text {T }} \times$ | Transmitter Input Clock Frequency <br> 1x Baud Rate <br> 16x Baud Rate <br> 64x Baud Rate | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \hline \end{aligned}$ | $\begin{array}{r} 64 \\ 310 \\ 615 \end{array}$ | kHz <br> kHz <br> kHz |  |
| ${ }^{\text {t TPW }}$ | Transmitter Input Clock Pulse Width <br> 1x Baud Rate <br> 16x and 64x Baud Rate | $\begin{array}{r} 12 \\ 1 \\ \hline \end{array}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| ${ }_{\text {t TPD }}$ | Transmitter Input Clock Pulse Delay <br> 1x Baud Rate <br> 16x and 64x Baud Rate | $\begin{array}{r} 15 \\ 3 \end{array}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| $\mathrm{f}_{\mathrm{R} \times}$ | Receiver Input Clock Frequency <br> 1x Baud Rate <br> 16x Baud Rate <br> 64x Baud Rate | $\begin{aligned} & \mathrm{DC} \\ & \mathrm{DC} \\ & \mathrm{DC} \\ & \hline \end{aligned}$ | $\begin{array}{r} 64 \\ 310 \\ 615 \\ \hline \end{array}$ | kHz <br> kHz <br> kHz |  |
| $t_{\text {RPW }}$ | Receiver Input Clock Pulse Width <br> 1x Baud Rate <br> $16 x$ and $64 x$ Baud Rate | $\begin{array}{r} 12 \\ 1 \\ \hline \end{array}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \end{aligned}$ |  |
| trPD | Receiver Input Clock Pulse Delay <br> 1x Baud Rate <br> 16x and 64x Baud Rate | $\begin{array}{r} 15 \\ 3 \end{array}$ |  | $\begin{aligned} & \mathrm{t}_{\mathrm{CY}} \\ & \mathrm{t}_{\mathrm{CY}} \\ & \hline \end{aligned}$ |  |
| $\mathrm{t}_{\text {T } \times \text { R }}{ }^{\text {r }}$ | TxRDY Pin Delay from Center of last Bit |  | 8 | ${ }^{\text {t }} \mathrm{CY}$ | Note 7 |
| t $\times$ XRDY CLEAR | TxRDY $\downarrow$ from Leading Edge of $\overline{W R}$ |  | 6 | ${ }^{t_{C Y}}$ | Note 7 |
| $t_{\text {RXRD }}$ | RxRDY Pin Delay from Center of last Bit |  | 24 | ${ }^{\text {t }} \mathrm{C}$ | Note 7 |
| $t_{\text {RX }}$ R ${ }_{\text {DY CLEAR }}$ | R×RDVY $\downarrow$ from Leading Edge of $\overline{\mathrm{RD}}$ |  | 6 | ${ }^{t_{C Y}}$ | Note 7 |
| $\mathrm{t}_{\text {IS }}$ | Internal SYNDET Delay from Rising Edge of $\overline{\mathrm{RxC}}$ |  | 24 | ${ }^{\mathrm{t}} \mathrm{CY}$ | Note 7 |
| $\mathrm{t}_{\mathrm{ES}}$ | External SYNDET Set-Up Time Before <br> Falling Edge of $\overline{\mathrm{R} \times \mathrm{C}}$ | 16 |  | ${ }^{t} \mathrm{CY}$ | Note 7 |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{T} \times \mathrm{XEMPTY}}$ | TxEMPTY Delay from Center of Last Bit | 20 |  | $\mathrm{t}_{\mathrm{CY}}$ | Note 7 |
| $\mathrm{t}_{\mathrm{WC}}$ | Control Delay from Rising Edge of <br> WRITE (TxEn, $\overline{\mathrm{DTR}}, \overline{\mathrm{RTS}})$ | 8 |  | $\mathrm{t}_{\mathrm{CY}}$ | Note 7 |
| $\mathrm{t}_{\mathrm{CR}}$ | Control to READ Set-Up Time ( $\overline{\mathrm{DSR}}, \overline{\mathrm{CTS}})$ | 20 |  | $\mathrm{t}_{\mathrm{CY}}$ | Note 7 |

NOTES:

1. AC timings measured $\mathrm{V}_{\mathrm{OH}}=2.0, \mathrm{~V}_{\mathrm{OL}}=0.8$, and with load circuit of Figure 1.
2. Chip Select (CS) and Command/Data (C/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{C}} \mathrm{CY}$ and for Synchronous Mode is $16 \mathrm{t}_{\mathrm{C}} \mathrm{C}$.
5. The $T \times C$ and $R \times C$ frequencies have the following limitations with respect to CLK.

For $1 \times$ Baud Rate, $\mathrm{f}_{\mathrm{T}}$ or $\mathrm{f}_{\mathrm{R}_{\mathrm{x}}} \leqslant 1 /\left(30 \mathrm{t}_{\mathrm{C}} \mathrm{Y}\right)$
For $16 x$ and $64 x$ Baud Rate, ${ }^{f} T_{x}$ or $f_{R x} \leqslant 1 /\left(4.5{ }^{t} \mathrm{CY}\right)$
6. Reset Pulse Width $=6{ }^{t} \mathrm{CY}$ minimum; System Clock must be running during Reset.
7. Status update can have a maximum delay of 28 clock periods from the event affecting the status.

TYPICAL $\Delta$ OUTPUT DELAY VERSUS $\Delta$ CAPACITANCE (pF)


## A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT

## A.C. TESTING LOAD CIRCUIT


$R_{L}=420 \Omega$
$\mathrm{V}_{\mathrm{L}}=2 \mathrm{~V}$
$C_{L}=150 \mathrm{pF}$
C INCLUDES Jig CAPACITANCE

## M8253 <br> PROGRAMMABLE INTERVAL TIMER

MILITARY

- 3 Independent 16-Bit Counters
- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- Programmable Counter Modes
- Count Binary or BCD
- Single + 5V Supply
- 24-Pin Dual In-Line Package

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


Figure 1. Block Diagram


| $D_{1} D_{0}$ | DATA BUS I8 BIT |
| :--- | :--- |
| CLKN | COUNTER CLOCK INPUTS |
| GATEN | COUNTER GATE INPUTS |
| OUT N | COUNTER OUTPUTS |
| $\overline{R D}$ | READ COUNTER |
| WR | WRITE COMMAND OR DATA |
| $C S$ | CHIP SELECT |
| $A_{0} A_{1}$ | COUNTER SLLECT |
| $V_{G C}$ | +5VOLTS |
| GND | GROUND |

Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Ambient Temperature Under Bias | $-55^{\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 |


#### Abstract

*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ )

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{I L}$ | Input Low Voltage | -0.5 | 0.8 | V |  |
| $\mathrm{~V}_{\text {IH }}$ | Input High Voltage | 2.4 |  | 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}}=-150 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{IL}}$ | Input Load Current |  | $\pm 20$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {IN }}=V_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\text {OFL }}$ | Output Float Leakage |  | $\pm 20$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\text {OUT }}=V_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 160 | mA |  |

CAPACITANCE $\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $C_{I N}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / \mathrm{O}}$ | I/O Capacitance |  |  | 20 | pF | Unmeasured pins returned to $V_{S S}$ |

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 \%, \mathrm{GND}=\mathrm{OV}\right)$

Bus Parameters ${ }^{[1]}$
READ CYCLE

| Symbol | Parameter | M8253 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| ${ }^{\text {A }}$ AR | Address Stable Before $\overline{\text { READ }}$ | 50 |  | ns |
| $\mathrm{t}_{\text {RA }}$ | Address Hold Time for $\overline{\text { READ }}$ | 10 |  | ns |
| $\mathrm{t}_{\text {RR }}$ | $\overline{\text { READ Pulse Width }}$ | 400 |  | ns |
| $\mathrm{t}_{\mathrm{RD}}$ | DATA Delay from $\overline{\operatorname{READ}}{ }^{(2)}$ |  | 300 | ns |
| $t_{\text {DF }}$ | $\overline{\text { READ }}$ to Data Floating | 25 | 175 | ns |
| $\mathrm{t}_{\mathrm{RV}}$ | Recovery Time Between $\overline{\text { READ }}$ and Any Other Control Signal | 1 |  | $\mu \mathrm{s}$ |

## A.C. CHARACTERISTICS (Continued)

WRITE CYCLE

| Symbol | Parameter | M8253 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $\mathrm{t}_{\text {AW }}$ | Address Stable Before WRITE | 50 |  | ns |
| twa | Address Hold Time for WRITE | 30 |  | ns |
| ${ }^{\text {tw }}$ w | WRITE Pulse Width | 400 |  | ns |
| ${ }_{\text {t }}$ W | Data Set Up Time for WRITE | 300 |  | ns |
| twD | Data Hold Time for WRITE | 40 |  | ns |
| $\mathrm{t}_{\mathrm{RV}}$ | Recovery Time Between WRITE and Any Other Control Signal | 1 |  | $\mu \mathrm{s}$ |

## NOTES:

1. AC timings measured at $\mathrm{V}_{\mathrm{OH}}=2.2, \mathrm{~V}_{\mathrm{OL}}=0.8$.

## CLOCK AND GATE TIMING

| Symbol | Parameter | M8253 |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| tCLK | Clock Period | 400 | dc | ns |
| tPWH | High Pulse Width | 250 |  | ns |
| tpWL | Low Pulse Width | 150 |  | ns |
| $\mathrm{t}_{\mathrm{G} W}$ | Gate Width High | 150 |  | ns |
| $\mathrm{t}_{\mathrm{GL}}$ | Gate Width Low | 100 |  | ns |
| $\mathrm{t}_{\mathrm{GS}}$ | Gate Set Up Time to CLK $\uparrow$ | 100 |  | ns |
| $\mathrm{t}_{\mathrm{GH}}$ | Gate Hold Time After CLK $\uparrow$ | 100 |  | ns |
| tod | Output Delay From CLK $\downarrow^{[1]}$ |  | 400 | ns |
| todg | Output Delay From Gate $\downarrow$ [1] |  | 300 | ns |

NOTE 1:
Test Conditions: $C_{L}=100 \mathrm{pF}$.

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT



## WAVEFORMS



## CLOCK AND GATE



# M8255A <br> PROGRAMMABLE PERIPHERAL INTERFACE <br> MILITARY 

- 24 Programmable I/O PIns
- Completely TTL Compatible
- Fully Compatible with MCS-80 ${ }^{\circledR}$ Microprocessor Family
- 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 10 \%$ 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.


Figure 1. Block Diagram


| $\mathrm{D}_{7}-\mathrm{D}_{0}$ | DATA BUS (BI-DIRECTIONAL) |
| :--- | :--- |
| RESET | RESET INPUT |
| $\overline{\mathrm{CS}}$ | CHIP SELECT |
| $\overline{\mathrm{RD}}$ | READ INPUT |
| $\overline{\text { WR }}$ | WRITE INPUT |
| AO, A1 | PORT ADDRESS |
| PA7-PAO | PORT A (BIT) |
| PB7-PB0 | PORT B (BIT) |
| PC7-PC0 | PORT C (BIT) |
| $\mathrm{V}_{\text {CC }}$ | +5 VOLTS |
| GND | $\square$ VOLTS |

Figure 2. Pin Configuration

M8255A

## 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.5 V to +7 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*NOTICE: 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 $\quad\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ 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 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\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}}(\mathrm{DB})$ | Output Low Voltage (Data Bus) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.5 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OL}}(\mathrm{PER})$ | Output Low Voltage (Peripheral Port) |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=1.7 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{OH}}$ (DB) | Output High Voltage (Data Bus) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OH}}(\mathrm{PER})$ | Output High Voltage (Peripheral Port) | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\mathrm{DAR}}[1]$ | Darlington Drive Current | -1.0 | -4.0 | mA |  |
| $\mathrm{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 $\quad\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=5.0 \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 |
| $t_{\text {RR }}$ | READ Pulse Width | 300 |  | ns |
| $\mathrm{t}_{\text {R }}$ | Data Valid From READ ${ }^{[1]}$ |  | 250 | ns |
| $t_{\text {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 |
| twb | WR = 1 to Output ${ }^{11 \mid}$ |  | 350 | ns |
| $\mathrm{t}_{\text {IR }}$ | Peripheral Data Before RD | 0 |  | ns |
| $\mathrm{t}_{\text {HR }}$ | Peripheral Data After RD | 0 |  | ns |
| $\mathrm{t}_{\text {AK }}$ | ACK Pulse Width | 300 |  | ns |
| ${ }^{\text {t }}$ T | STB Pulse Width | 500 |  | ns |
| tps | Per. Data Before T.E. of STB | 0 |  | ns |

## A.C. CHARACTERISTICS (Continued)

| Symbol | Parameter | 8255A |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $t_{\text {PH }}$ | Per. Data After T.E. of STB | 180 |  | ns |
| tad | ACK $=0$ to Output ${ }^{111}$ |  | 300 | ns |
| $\mathrm{t}_{\text {KD }}$ | ACK $=1$ to Output Float | 20 | 250 | ns |
| $t_{\text {WOB }}$ | $W R=1$ to $O B F=0^{[1]}$ |  | 650 | ns |
| $\mathrm{t}_{\mathrm{AOB}}$ | $A C K=0$ to $O B F=1 / 1 \mid$ |  | 350 | ns |
| ${ }^{\text {t }}$ IIB | STB $=0$ to $\|B F=1\| 1 \mid$ |  | 300 | ns |
| $\mathrm{t}_{\text {RIB }}$ | $R D=1$ to $\left\langle B F=0^{\|1\|}\right.$ |  | 300 | ns |
| $t_{\text {RIT }}$ | $R D=0$ to $I N T R=0^{11 \mid}$ |  | 400 | ns |
| ${ }_{\text {t }}^{\text {S }}$ T | STB $=1$ to INTR $=1\|1\|$ |  | 300 | ns |
| ${ }_{\text {t }}$ IT | $A C K=1$ to $\mid$ NTR $=1^{\|1\|}$ |  | 350 | ns |
| ${ }^{\text {t WIT }}$ | $W R=0$ to $I N T R=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 $\quad\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

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

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## A.C. TESTING LOAD CIRCUIT


${ }^{-} \mathrm{V}_{\mathrm{EXt}}$ IS SET AT VAR1OUS VOLTAGES DURING TESTING TO GUARANTEE THE SPECIFICATION.

## WAVEFORMS

MODE 0 (INPUT)


MODE 0 (OUTPUT)


## WAVEFORMS (Continued)

MODE 1 (STROBED INPUT)


MODE 1 (STROBED OUTPUT)


## WAVEFORMS (Continued)

## MODE 2 (BIDIRECTIONAL)



# M8257 <br> PROGRAMMABLE DMA CONTROLLER 

## MILITARY

## - Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$

- 4-Channel DMA Controller
- Priority DMA Request Logic
- Channel Inhibit Logic

Terminal Count and Modulo 128 Outputs<br>- Single TTL Clock<br>- Single +5V Supply<br>- Auto Load Mode


#### Abstract

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.




Figure 1. Block Diagram


| AEN | ADDRESS ENABLE |
| :--- | :--- |
| ADSTB | ADDRESS STROBE |
| TC | TERMINAL COUNT |
| MARK $^{\text {MODULO 128 MARK }}$ |  |
| DRQ $_{3} \cdot$ DRO $_{0}$ | DMA REQUEST <br> INPUT |
| DACK $_{3} \cdot$ DACK $_{0}$ | DMA ACKNOWLEDGE <br> OUT |
| CS | CHIP SELECT |
| VCC | +5 VOLTS |
| GND | GROUND |

Figure 2. Pin Configuration

## 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
*NOTICE: 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 |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  | 0.45 | Volts | $\mathrm{lOL}=1.6 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | Volts | $I_{O H}=-150 \mu A$ for $A B$, DB and AEN $\mathrm{IOH}_{\mathrm{O}}=-80 \mu \mathrm{~A}$ for others |
| $\mathrm{V}_{\mathrm{HH}}$ | HRQ Output High Voltage | 3.3 | $\mathrm{V}_{\mathrm{Cc}}$ | Volts | $\mathrm{l}_{\mathrm{OH}}=-80 \mu \mathrm{~A}$ |
| ICC | $V_{\text {cc }}$ Current Drain |  | 150 | mA |  |
| IIL | Input Leakage |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leqslant \mathrm{V}_{\text {IN }} \leqslant \mathrm{V}_{\text {CC }}$ |
| IOFL | Output Leakage During Float |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{SS}}+0.45 \\ & \leqslant \mathrm{~V}_{\mathrm{OUT}} \leqslant \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ |

CAPACITANCE $\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  |  | 10 | pF | $\mathrm{fc}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{1 / O}$ | I/O Capacitance |  |  | 20. | pF | Unmeasured pins <br> returned to GND |

## A.C. CHARACTERISTICS—DMA (MASTER) MODE ( $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$, 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}_{\mathrm{CY}}$ | ns |
| $\mathrm{T}_{\mathrm{QS}}$ | DRQ $\uparrow$ Setup to $\theta \downarrow(\mathrm{SI}, \mathrm{S4})$ | 120 |  | ns |
| $\mathrm{~T}_{\mathrm{QH}}$ | DRQ $\downarrow$ Hold from HLDA $\uparrow^{[4]}$ | 0 |  | ns |
| $\mathrm{~T}_{\mathrm{HS}}$ | HLDA $\uparrow$ or $\downarrow$ Setup to $\theta \downarrow(\mathrm{SI}, \mathrm{S} 4)$ | 100 |  | ns |
| $\mathrm{~T}_{\mathrm{RS}}$ | READY Setup Time to $\theta \uparrow(\mathrm{S} 3, \mathrm{Sw})$ | 30 |  | ns |
| $\mathrm{~T}_{\mathrm{RH}}$ | READY Hold Time from $\theta \uparrow(\mathrm{S} 3, \mathrm{Sw})$ | 20 |  | ns |

## A.C. CHARACTERISTICS—DMA (MASTER) MODE ( $\mathrm{T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$, <br> $$
\left.\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}\right)
$$

## TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| TDQ | HRQ^ or $\downarrow$ Delay from $\theta \uparrow(S I, S 4)$ (measured at 2.0V) ${ }^{[1]}$ |  | 180 | ns |
| $\mathrm{T}_{\text {DQ1 }}$ | HRQ介 or $\downarrow$ Delay from $\theta \uparrow(S I, 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 }}$ | Adr(AB)(Active) Delay from AEN $\uparrow(\text { 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 }}$ | Adr(AB)(Stable) Hold from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ | $\mathrm{T}_{\text {ASM }}-50$ |  | ns |
| $\mathrm{T}_{\text {AHR }}$ | $\operatorname{Adr}(\mathrm{AB})\left(\right.$ Valid) Hold from $\overline{\operatorname{Rd} \uparrow \uparrow(S 1, ~ S I) ~}{ }^{[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 }}$ | $\operatorname{Adr}(\mathrm{DB})\left(\right.$ Active) Delay from $\theta \uparrow(\mathrm{S} 1)^{[2]}$ |  | 300 | ns |
| $\mathrm{T}_{\text {AFDB }}$ | $\operatorname{Adr}(\mathrm{DB})\left(\right.$ 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 AdrStb $\downarrow$ (S2) ${ }^{[4]}$ | 50 |  | ns |
| $\mathrm{T}_{\text {STL }}$ | AdrStb $\uparrow$ Delay from $\theta \uparrow(S 1)^{[1]}$ |  | 200 | ns |
| $\mathrm{T}_{\text {STI }}$ | 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{R}} \downarrow \downarrow$ or $\bar{W} \mathrm{r}\left(\right.$ Ext) $\downarrow$ Delay from AdrStb $\downarrow\left(\right.$ 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(\mathrm{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}}(\mathrm{Ext}) \downarrow$ Delay from $\theta \uparrow(\mathrm{S} 2)$ and $\overline{\text { Wr }} \downarrow$ Delay from $\theta \uparrow(S 3)^{[2,6]}$ |  | 250 | ns |
| $\mathrm{T}_{\mathrm{DCT}}$ | $\overline{\text { 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}_{C Y}+\mathrm{T}_{\theta}-50$ |  | ns |
| T WWM | $\overline{\text { Wr Width (S3-S4) }}{ }^{[4]}$ | $\mathrm{T}_{C Y}-50$ |  | ns |
| TWWME | $\overline{\mathrm{Wr}}$ (Ext) Width (S2-S4) ${ }^{[4]}$. | $2 \mathrm{~T}_{C Y}-50$ |  | ns |

NOTES:

[^42]
## A.C. CHARACTERISTICS—PERIPHERAL (SLAVE) MODE $\left[T_{A}=-55^{\circ} \mathrm{C}\right.$ to $125^{\circ} \mathrm{C}$,

$$
\left.\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{GND}=0 \mathrm{~V}(\text { Note } 1)\right]
$$

## 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}_{\mathrm{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 |  |
| $\mathrm{~T}_{\text {WA }}$ | Adr Hold from $\overline{\mathrm{WR}} \uparrow$ | 35 |  | ns |  |
| $\mathrm{~T}_{\text {DW }}$ | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 200 |  | ns |  |
| $\mathrm{~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 |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\text {RSTW }}$ | Reset Pulse Width | 300 |  | ns |  |
| $\mathrm{~T}_{\text {RSTD }}$ | Power Supply $\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 $\overline{/ / O W R}$ | 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. $\mathrm{M} 8257: \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}, 8257-5: \mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$.

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

$$
\mathrm{T}_{\mathrm{A}(\mathrm{MIN})}+\left(\mathrm{T}_{\mathrm{B}(\mathrm{MIN})}{ }^{*}+50 \mathrm{~ns}\right) \leq 150 \mathrm{~ns}
$$

*if $T_{A}$ and $T_{B}$ are tracking parameters

# M8259A PROGRAMMABLE INTERRUPT CONTROLLER 

MILITARY

- iAPX 86, 88 Compatible
- MCS-80 ${ }^{\circledR}$, MCS-85 ${ }^{\circledR}$ Compatible
- Eight-Level Priority Controller
- Expandable to 64 Levels
- Programmable Interrupt Modes
- Individual Request Mask Capability
- Single + 5V Supply (No Clocks)
- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

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


Figure 1. Block Diagram
Figure 2. Pin Configuration

## 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
*NOTICE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

## D.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ 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 | -.5 | .8 | V |  |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.3 | $\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 |  | V | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}$ |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current | -10 | +10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ to 0 V |
| $\mathrm{I}_{\mathrm{LOL}}$ | Output Leakage Current | -10 | +10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0.45 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LOH}}$ | Output Leakage Current |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | mA |  |  |

CAPACITANCE $\left(T_{A}=25^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{GND}=0 \mathrm{~V}\right)$

| 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 $\mathrm{V}_{\mathrm{SS}}$ |

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

TIMING REQUIREMENTS

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TAHRL | A0/CS Setup to $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \downarrow$ | 0 |  | ns |  |
| TRHAX | A0/CS Hold after $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \uparrow$ | 0 |  | ns |  |
| TRLRH | $\overline{\mathrm{RD}}$ Pulse Width | 235 |  | ns |  |
| TAHWL | A0/ $\overline{\mathrm{S}}$ Setup to $\overline{W R} \downarrow$ | 0 |  | ns |  |
| TWHAX | A0/ $\overline{\mathrm{CS}}$ Hold after $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| TWLWH | $\overline{\text { WR Pulse Width }}$ | 290 |  | ns |  |
| TDVWH | Data Setup to $\overline{\mathrm{WR}} \uparrow$ | 240 |  | ns |  |
| TWHDX | Data Hold after $\overline{\mathrm{WR}} \uparrow$ | 0 |  | ns |  |
| TJLJH | Interrupt Request Width (Low) | 100 |  | ns | See Note 1 |
| TCVIAL | Cascade Setup to Second or Third $\overline{\text { NTA }} \downarrow$ (Slave Only) | 55 |  | ns |  |
| TRHRL | End of $\overline{R D}$ to Next Command | 300 |  | ns |  |
| TWHRL | End of $\overline{W R}$ to Next Command | 370 |  | ns |  |

## A.C. CHARACTERISTICS (Continued)

## TIMING RESPONSES

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TRLDV | Data Valid from $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \downarrow$ |  | 200 | ns | $\begin{aligned} & \text { C of Data Bus } \\ & \text { Max. test } C=100 \mathrm{pF} \\ & \text { Min. test } \mathrm{C}=15 \mathrm{pF} \\ & \mathrm{C}_{\text {INT }}=100 \mathrm{pF} \\ & \mathrm{C}_{\text {ENABLE }}=15 \mathrm{pF} \end{aligned}$ |
| TRHDZ | Data Float after $\overline{\mathrm{RD}} / \overline{\mathrm{NTA}} \uparrow$ | 10 | 100 | ns |  |
| TJHIH | Interrupt Output Delay |  | 350 | ns |  |
| TIALCV | Cascade Valid from First $\overline{\text { INTA }} \downarrow$ (Master Only) |  | 565 | ns |  |
| TRLEL | Enable Active from $\overline{\mathrm{RD}} \downarrow$ or $\overline{\text { NTA }} \downarrow$ |  | 125 | ns |  |
| TRHEH | Enable Inactive from $\overline{\mathrm{RD}} \uparrow$ or $\overline{\mathrm{NTTA}} \uparrow$ |  | 150 | ns |  |
| TAHDV | Data Valid from Stable Address |  | 200 | ns |  |
| TCVDV | Cascade Valid to Valid Data |  | 300 | ns |  |

NOTE:

1. This is the low time required to clear the input latch in the edge triggered mode.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## WAVEFORMS



# M8282/8283 <br> OCTAL LATCH 

MILITARY

## - Fully Parallel 8-Bit Data Register and Buffer

- Transparent during Active Strobe
- Supports M8080, M8085A, M8048, and Military IAPX 86 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
- Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The M8282 and M8283 are 8-bit bipolar latches with 3-state output buffers. They can be used to implement latches, buffers, or multiplexers. The M8283 inverts the input data at its outputs while the M8282 does not. Thus, all of the principal peripheral and input/output functions of a microcomputer system can be implemented with these devices.


Figure 1. Logic Diagrams


Figure 2. Pin Configurations

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| STB | 1 | Strobe: STB is an input control pulse used to strobe data at the data input pins ( $\mathrm{A}_{0}-\mathrm{A}_{7}$ ) into the data latches. This signal is active HIGH to admit input data. The data is latched at the HIGH to LOW transition of STB. |
| $\overline{O E}$ | 1 | Output Enable: $\overline{O E}$ is an input control signal which when active LOW enables the contents of the data latches onto the data output pin ( $\mathrm{B}_{0}-\mathrm{B}_{7}$ ). $\overline{\mathrm{OE}}$ being inactive HIGH forces the output buffers to their high impedance state. |
| $\mathrm{Dl}_{0}-\mathrm{Dl}_{7}$ | 1 | Data Input Pins: Data presented at these pins satisfying setup time requirements when STB is strobed is latched into the data input latches. |
| $\begin{aligned} & \mathrm{DO}_{0}-\mathrm{DO}_{7} \\ & \mathrm{MB282}_{7} \\ & \mathrm{DO}_{0}-\overline{\mathrm{DO}}_{7} \\ & (\mathrm{M} 8283) \end{aligned}$ | 0 | Data Output Pins: When $\overline{O E}$ is true, the data in the data latches is presented as inverted (M8283) or non-inverted (M8282) data onto the data output pins. |

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to + Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to + All Output and Supply Voltages . . . . . . . . -0.5 V to All Input Voltages . . . . . . . . . . . . . . . . . . . -1.0 V to |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |

*NOTICE: 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(V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

| 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 |  | .45 | V | $\mathrm{I}_{\mathrm{OL}}=20 \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.25 V |
| $\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}}=20 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$.
A.C. CHARACTERISTICS
$\left(V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
(Loading: Outputs-loL $=20 \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 |  | $\begin{aligned} & 25 \\ & 35 \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ | (See Note 1) |
| TSHOV | STB to Output Delay <br> -Inverting <br> -Non-Inverting |  | $\begin{aligned} & 45 \\ & 55 \end{aligned}$ | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |  |
| TEHOZ | Output Disable Time |  | 25 | ns |  |
| TELOV | Output Enable Time ... | 10 | 50 | ns |  |
| TIVSL | Input to STB Setup Time | 0 |  | ns |  |
| TSLIX | Input to STB Hold Time | 25 |  | ns |  |
| TSHSL | STB High Time | 15 |  | ns |  |
| TILIH, TOLOH | Input, Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL, TOHOL | Input, Output Fall Time |  | 12 | ns | From 2.0V to 0.8' |

## NOTE:

1. See waveforms and test load circuit on following page.

## M8284A <br> CLOCK GENERATOR AND DRIVER FOR MILITARY iAPX 86 MICROPROCESSOR

- Full Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- Generates the System clock for the Military iAPX 86 Microprocessor
Uses a Crystal or a TTL Signal for Frequency Source
- Provides Local READY and MULTIBUS® ${ }^{\circledR}$ READY Synchronization
- 18-Pin Package

■ Single $+5 \mathrm{~V} \pm 10 \%$ Power Supply

- Generates System Reset Output from Schmitt Trigger Input
- Capable of Clock Synchronization with Other M8284As


Figure 2. M8284A Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature $\ldots \ldots \ldots \ldots \ldots . . . .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
*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IF | Forward Input Current ( $\overline{\mathrm{ASYNC}}$ ) Other Inputs |  | $\begin{aligned} & -1.3 \\ & -0.5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & V_{F}=0.45 \mathrm{~V} \\ & V_{F}=0.45 \mathrm{~V} \end{aligned}$ |
| $I_{\text {R }}$ | Reverse Input Current ( $\overline{\mathrm{ASYNC}}$ ) Other Inputs |  | $\begin{aligned} & 50 \\ & 50 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{R}=V_{C C} \\ & V_{R}=5.25 \mathrm{~V} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{C}}$ | Input Forward Clamp Voltage |  | -1.0 | V | $1 \mathrm{C}=-5 \mathrm{~mA}$ |
| ICC | Power Supply Current |  | 162 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Voltage | 2.0 |  | V |  |
| $\mathrm{V}_{1} \mathrm{HR}^{\text {a }}$ | Reset Input HIGH Voltage | 2.6 |  | V |  |
| VOL | Output LOW Voltage |  | 0.45 | V | 5 mA |
| VOH | Output HIGH Voltage CLK Other Outputs | $\begin{gathered} 4 \\ 2.4 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & -1 \mathrm{~mA} \\ & -1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\text {IHR }}{ }^{-\mathrm{V}_{\text {ILR }}}$ | $\overline{\mathrm{RES}}$ Input Hysteresis | 0.25 |  | V |  |

A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $+125^{\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 | 13 |  | ns | 90\% - 90\% VIN |
| teLEH | External Frequency LOW Time | 13 |  | ns | $10 \%-10 \% \mathrm{~V}_{\text {IN }}$ |
| teLEL | EFI Period | tEHEL + tELEH + $\delta$ |  | ns | (Note 1) |
|  | XTAL Frequency | 12 | 25 | MHz |  |
| tr1VCL | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=\mathrm{HIGH}$ |
| tr1VCH | RDY1, RDY2 Active Setup to CLK | 35 |  | ns | $\overline{\text { ASYNC }}=$ LOW |
| trivCL | RDY1, RDY2 Inactive Setup to CLK | 35 |  | ns |  |
| tCLR1X | RDY1, RDY2 Hold to CLK | 0 |  | ns |  |
| ${ }^{\text {t }}$ AYVCL | $\overline{\text { ASYNC Setup to CLK }}$ | 50 |  | ns |  |
| ${ }^{\text {t CLAMYX }}$ | $\overline{\text { ASYNC Hold to CLK }}$ | 0 |  | ns |  |
| ta1VR1V | $\overline{\text { AEN } 1, ~ \overline{A E N 2 ~}}$ Setup to RDY1, RDY2 | 15 |  | ns |  |
| ${ }^{\text {t CLA }}$ ( ${ }^{\text {P }}$ | $\overline{\text { AEN } 1, ~ \overline{A E N 2 ~}}$ Hold to CLK | 0 |  | ns |  |
| tYHEH | CSYNC Setup to EFI | 20 |  | ns |  |
| tEHYL | CSYNC Hold to EFI | 20 |  | ns |  |
| tYHYL | CSYNC Width | 2.tELEL |  | ns |  |
| $\mathrm{t}_{11 \mathrm{HCL}}$ | $\overline{\text { RES }}$ Setup to CLK | 65 |  | ns | (Note 2) |
| ${ }^{\text {t CLIIH }}$ | $\overline{\text { RES Hold to CLK }}$ | 20 |  | ns | (Note 2) |

M8284A
PRRLOMONARY
A.C. CHARACTERISTICS (cont.) $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C} ; \mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%\right)$ TIMING RESPONSES $\dagger$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t CLCL }}$ | CLK Cycle Period | 125 |  | ns |  |
| ${ }^{\text {t }} \mathrm{CHCL}$ | CLK HIGH Time | $(1 / 3 \mathrm{t}$ CLCL) +2.0 |  | ns | Fig. 6 and Fig. 7 |
| ${ }^{\text {t }} \mathrm{CLCH}$ | CLK LOW Time | (2/3 tCLCL) - 15.0 |  | ns | Fig. 6 and Fig. 7 |
| $\begin{aligned} & \hline{ }^{\mathrm{t}} \mathrm{CH} 1 \mathrm{CH} 2 \\ & \mathrm{t} \mathrm{CL} 2 \mathrm{CL} 1 \\ & \hline \end{aligned}$ | CLK Rise or Fall Time |  | 10 | ns | 1.0 V to 3.5 V |
| tPHPL | PCLK HIGH Time | ${ }^{\text {t CLCL }}$ - 20 |  | ns |  |
| tPLPH | PCLK LOW Time | ${ }^{\text {t CLCL }}$ - 20 |  | ns |  |
| tryLCL | Ready Inactive to CLK (See Note 4) | -8 |  | ns | Fig. 8 and Fig. 9 |
| tryHCH | Ready Active to CLK (See Note 3) | (2/3 tCLCL) - 15.0 |  | ns | Fig. 8 and Fig. 9 |
| ${ }^{\text {t }}$ CLIL | CLK to Reset Delay |  | 40 | ns |  |
| ${ }^{\text {t }} \mathrm{CLPH}$ | CLK to PCLK HIGH Delay |  | 22 | ns |  |
| ${ }^{\text {t CLPL }}$ | CLK to PCLK LOW Delay |  | 22 | ns |  |
| ${ }^{\text {t }} \mathrm{OLCH}$ | OSC to CLK HIGH Delay | -5 | 22 | ns |  |
| tolcl | OSC to CLK LOW Delay | 2 | 35 | ns |  |

## Notes:

1. $\delta=\mathrm{EFI}$ rise ( $5 \mathrm{~ns} \max$ ) +EFI fall ( 5 ns max).
2. Setup and hold necessary only to guarantee recognition at next clock.
3. Applies only to T3 and TW states.
4. Applies only to T2 states.
†Figure 10 illustrates test load measurement condition.


Figure 3. Waveforms for Clocks and Reset Signals

## M8286/8287 <br> OCTAL BUS TRANSCEIVER

MILITARY

- Data Bus Buffer Driver for Military iAPX 86, M8080A, M8085A, and M8048 Processors
- 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
- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$

The M8286 and M8287 are 8-bit bipolar transceivers with 3-state outputs. The M8287 inverts the input data at is outputs while the M8286 does not. Thus, a wide variety of applications for buffering in microcomputer systems can be met.


Figure 1. Logic Diagrams


Figure 2. Pin Configurations

Table 1. Pin Description

| Symbol | Type | Name and Function |
| :---: | :---: | :---: |
| T | 1 | Transmit: $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}$ | 1 | Output Enable: $\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. |
| $\mathrm{A}_{0}-\mathrm{A}_{7}$ | I/O | Local Bus Data Pins: 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. |
| $\begin{aligned} & \mathrm{B}_{0}-\mathrm{B}_{7} \\ & (\mathrm{M} 8286) \\ & \overline{\mathrm{B}_{0}}-\overline{\mathrm{B}_{7}} \\ & (\mathrm{M} 287) \end{aligned}$ | 1/0 | System Bus Data Pins: These pins serve to either present data to or accept data from the system bus depending upon the state of the Tpin. |

## FUNCTIONAL DESCRIPTION

The M8286 and M8287 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.

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias .......... $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature ........... $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages . . . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Watt
*NOTICE: 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(V_{C C}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| $I_{\text {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}}$ | Output Low Voltage -B Outputs -A Outputs |  | $\begin{aligned} & .45 \\ & .45 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOL}=20 \mathrm{~mA} \\ & \mathrm{IOL}=10 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} \text { Output High Voltage } & - \text { B Outputs } \\ & - \text { A Outputs } \end{aligned}$ | $\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} & V_{\text {OFF }}=0.45 \mathrm{~V} \\ & 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 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, See Note 1 <br> $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, See Note 1 |
| $\mathrm{V}_{1}$ | Input High Voltage | 2.0 |  | V | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, See Note 1 |
| $\mathrm{CIN}_{\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}$ |

NOTE:

1. B outputs- $\mathrm{l}_{\mathrm{OL}}=20 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$

A Outputs-I $\mathrm{I}_{\mathrm{OL}}=10 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$
A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$
(Loading: B Outputs- $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{~mA}, \mathrm{I}_{\mathrm{OH}}=-5 \mathrm{~mA}, \mathrm{C}_{\mathrm{L}}=300 \mathrm{pF}$
A Outputs- $\mathrm{l}_{\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 |  | 22 | ns | (See Note 1) |
| TEHTV | Transmit/Receive Hold Time | TEHOZ |  | ns |  |
| TTVEL | Transmit/Receive Setup | 30 |  | ns |  |
| TEHOZ | Output Disable Time |  | 18 | ns |  |
| TELOV | Output Enable Time | 10 | 30 | ns |  |
| TILIH, <br> TOLOH | Input, Output Rise Time |  | 20 | ns | From 0.8V to 2.0V |
| TIHIL, <br> TOHOL | Input, Output Fall Time |  | 12 | ns | From 2.0V to 0.8V |

## NOTE:

1. See waveforms and test load circuit on following pages.

M8288
BUS CONTROLLER
FOR MILITARY IAPX 86
MILITARY

## Bipolar Drive Capability

- Provides Advanced Commands
- Provides Wide Flexibility in System Configurations
- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- 3-State Command Output Drivers
- Configurable for Use with an I/O Bus
- Facilitates Interface to One or Two Multi-Master Busses

The Intel ${ }^{\circledR}$ M8288 Controller is a 20-pin bipolar component for use with medium-to-large iAPX 86, 88 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 $1 / O$ bus.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias . . . . . . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
Storage Temperature . . . . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages . . . . . . . . -0.5 V to +7 V
All Input Voltages . . . . . . . . . . . . . . . . . . . . . -1.0 V to +5.5 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.5 Watt
*NOTICE: 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(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.125^{\circ} \mathrm{C}\right)$

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1 | V | $\mathrm{I}^{\prime} \mathrm{C}=-5 \mathrm{~mA}$ |
| $I_{\text {cc }}$ | Power Supply Current |  | 230 | mA |  |
| $\mathrm{I}_{\mathrm{F}}$ | Forward Input Current |  | -0.7 | mA | $\mathrm{V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{R}}$ | Reverse Input Current |  | 50 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{R}}=\mathrm{V}_{\mathrm{C}}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low VoltageCommand Outputs Control Outputs |  | $\begin{aligned} & 0.5 \\ & 0.5 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOL}=20 \mathrm{~mA} \\ & \mathrm{I}^{\mathrm{OL}}=16 \mathrm{~mA} \\ & \hline \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High VoltageCommand Outputs Control Outputs | $\begin{array}{r} 2.4 \\ 2.4 \\ \hline \end{array}$ |  | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{IOH}_{\mathrm{OH}}=-5 \mathrm{~mA} \\ & \mathrm{I}_{\mathrm{OH}}=-1 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | 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 $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.125^{\circ} \mathrm{C}\right)$

TIMING REQUIREMENTS

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 |  | ns |  |
| TCLCH | CLK Low Time | 66 |  | ns |  |
| TCHCL | CLK High Time | 40 |  | ns |  |
| TSVCH | Status Active Setup Time | 35 |  | ns |  |
| TCHSV | Status Active Hold Time | 10 |  | ns |  |
| TSHCL | Status Inactive Setup Time | 35 |  | ns |  |
| TCLSH | Status Inactive Hold Time | 10 |  | ns |  |
| TILIH | Input Rise Time |  | 20 | ns | From 0.8V to 2.0V |
| TIHIL | Input Fall Time |  | 12 | ns | From 2.0V to 0.8V |

## A.C. CHARACTERISTICS (Continued)

## TIMING RESPONSES

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCVNV | Control Active Delay | 5 | 45 | ns |  |
| TCVNX | Control Inactive Delay | 10 | 50 | ns |  |
| TCLLH,TCLMCH | ALE MCE Active Delay (from CLK) |  | 25 | ns |  |
| TSVLH, TSVMCH | ALE MCE Active Delay (from Status) |  | 25 | ns | $\overline{\text { MRDC }}$ |
| TCHLL | ALE Inactive Delay | 4 | 15 | ns | $\overline{\text { ORC }}$ |
| TCLML | Command Active Delay | 10 | 35 | ns | $\overline{\text { MWTC }}$ I $\mathrm{OLL}=20 \mathrm{~mA}$ |
| TCLMH | Command Inactive Delay | 10 | 35 | ns | $\overline{\text { IOWC }}\}{ }^{\circ} \mathrm{OH}=-5 \mathrm{~mA}$ |
| TCHDTL | Direction Control Active Delay |  | 50 | ns | INTA |
| TCHDTH | Direction Control Inactive Delay |  | 30 | ns | $\overline{\text { AMWC }}$ |
| TAELCH | Command Enable Time |  | 40 | ns | AIOWC |
| TAEHCZ | Command Disable Time |  | 40 | ns | $(\mathrm{IOL}=16 \mathrm{~mA}$ |
| TAELCV | Enable Delay Time | 115 | 200 | ns | Other $\left\{\begin{array}{l}\text { l } \\ \mathrm{OL} \\ \mathrm{OL}\end{array}=-1 \mathrm{~mA}\right.$ |
| TAEVNV | $\overline{\text { AEN }}$ to DEN |  | 20 | ns |  |
| TCEVNV | CEN to DEN, PDEN |  | 30 | ns |  |
| TCELRH | CEN to Command |  | TCLML | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

A.C. TESTING INPUT, OUTPUT WAVEFORM

INPUT/OUTPUT

A.C. TESTING: INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "1" AND 0.45V FOR A LOGIC "O." TIMING MEASUREMENTS ARE MADE AT 15 V FOR BOTH A
LOGIC " 1 " AND -0 ."

TEST LOAD CIRCUITS—3-STATE COMMAND OUTPUT TEST LOAD


## WAVEFORMS

DEN, PDEN QUALIFICATION TIMING


ADDRESS ENABLE (AEN) TIMING (3-STATE ENABLE/DISABLE)


NOTE: CEN must be low or valid prior to T 2 to prevent the command from being generated.

WAVEFORMS (Continued)


NOTES:

1. ADDRESSIDATA BUS IS SHOWN ONLY FOR REFERENCE PURPOSES

2 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 1 SV UNLESS SPECIFIED OTHERWISE

M8289
BUS ARBITER
MILITARY

- Provides Multi-Master System Bus Protocol
- Synchronizes iAPX 86, 88 Processors with Multi-Master Bus
- Provides Simple Interface with 8288 Bus Controller
- Four Operating Modes for Flexible System Configuration
- Military Temperature Range: $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
- Provides System Bus Arbitration for M8089 IOP in Remote Mode

The Intel ${ }^{\circledR} 8289$ Bus Arbiter is a 20 -pin, 5 -volt-only bipolar component for use with medium to large iAPX 86,88 multimaster/multiprocessing systems. The 8289 provides system bus arbitration for systems with multiple bus masters, such as an M8086 CPU with M8089 IOP in its REMOTE mode, while providng bipolar buffering and drive capability.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Temperature Under Bias .............. $-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
Storage Temperature .................. $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
All Output and Supply Voltages ......... -0.5 V to +7 V
All Input Voltages ......................... . 1.0 V to +5.5 V
Power Dissipation . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1.5 Watt
*NOTICE: 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 \%$ )

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{C}}$ | Input Clamp Voltage |  | -1.0 | V | $\mathrm{V}_{\mathrm{CC}}=4.50 \mathrm{~V}, \mathrm{I}_{\mathrm{C}}=-5 \mathrm{~mA}$ |
| ${ }^{\prime}$ F | Input Forward Current |  | -0.5 | mA | $\mathrm{V}_{\mathrm{CC}}=5.50 \mathrm{~V}, \mathrm{~V}_{\mathrm{F}}=0.45 \mathrm{~V}$ |
| $I_{R}$ | Reverse Input Leakage Current |  | 60 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.50, \mathrm{~V}_{\mathrm{R}}=5.50$ |
| VOL | ```Output Low Voltage BUSY, CBRQ AEN BPRO, \overline{BREQ}``` |  | $\begin{array}{r} 0.50 \\ 0.50 \\ 0.50 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{IOL}=18 \mathrm{~mA} \\ & \mathrm{OL}=14 \mathrm{~mA} \\ & \mathrm{IOL}=9 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage BUSY, CBRQ | Open Collector |  |  |  |
|  | All Other Outputs | 2.4 |  | V | $\mathrm{I}_{\mathrm{OH}}=350 \mu \mathrm{~A}$ |
| ICC | Power Supply Current |  | 165 | mA |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage |  | . 8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | V |  |
| Cin Status | Input Capacitance |  | 25 | pF |  |
| Cin (Others) | Input Capacitance |  | 12 | pF |  |

A.C. CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=-55^{\circ} \mathrm{C}\right.$ to $\left.+125^{\circ} \mathrm{C}\right)$.

## TIMING REQUIREMENTS

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TCLCL | CLK Cycle Period | 125 |  | ns |  |
| TCLCH | CLK Low Time | 65 |  | ns |  |
| TCHCL | CLK High Time | 35 |  | ns |  |
| TSVCH | Status Active Setup | 65 | TCLCL-10 | ns |  |
| TSHCL | Status Inactive Setup | 50 | TCLCL-10 | ns |  |
| THVCH | Status Active Hold | 10 |  | ns |  |
| THVCL | Status Inactive Hold | 10 |  | ns |  |
| TBYSBL | $\overline{\text { BUSY }} \uparrow \downarrow$ Setup to $\overline{\text { BCLK }} \downarrow$ | 20 |  | ns |  |
| TCBSBL | $\overline{\mathrm{CBRQ}} \uparrow \downarrow$ Setup to $\overline{\mathrm{BCLK}} \downarrow$ | 20 |  | ns |  |
| TBLBL | $\overline{\text { BCLK }}$ Cycle Time | 100 |  | ns |  |
| TBHCL | $\overline{\text { BCLK }}$ High Time | 30 | 65[TBLBL] | ns |  |
| TCLLL1 | LOCK Inactive Hold | 20 |  | ns |  |
| TCLLL2 | LOCK Active Setup | 40 |  | ns |  |
| TPNBL | $\overline{\text { BPRN }} \uparrow \downarrow$ to $\overline{\text { BCLK }} \downarrow$ Setup Time | 15 |  | ns |  |
| TCLSR1 | SYSB/RESB Setup | 0 |  | ns |  |
| TCLSR2 | SYSB/ $\overline{\text { RES }}$ Hold | 20 |  | ns |  |
| TIVIH | Initialization Pulse Width | $\begin{gathered} 3 \text { TBLBL + } \\ 3 \mathrm{TCLCL} \end{gathered}$ |  | ns |  |
| TILIH | Input Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TIHIL | Input Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## A.C. CHARACTERISTICS (Continued)

## TIMING RESPONSES

| Symbol | Parameter | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TBLBRL | $\overline{\text { BCLK }}$ to BREQ Delay $\uparrow \downarrow$ |  | 35 | ns |  |
| TBLPOH | $\overline{B C L K}$ to $\overline{B P R O} \uparrow \downarrow$ (See Note 1) |  | 40 | ns |  |
| TPNPO | $\overline{B P R N} \uparrow \downarrow$ to $\overline{B P R O} \uparrow \downarrow$ Delay (See Note 1) |  | 25 | ns |  |
| TBLBYL | $\overline{\text { BCLK }}$ to $\overline{\text { BUSY }}$ Low |  | 60 | ns |  |
| TBLBYH | $\overline{\text { BCLK }}$ to $\overline{\text { BUSY Float (See Note 2) }}$ |  | 35 | ns |  |
| TCLAEH | CLK to $\overline{\text { AEN }}$ High |  | 65 | ns |  |
| TBLAEL | $\overline{\text { BCLK }}$ to $\overline{\text { AEN }}$ Low |  | 40 | ns |  |
| TBLCBL | $\overline{\text { BCLK }}$ to CBRQ Low |  | 60 | ns |  |
| TBLCBH | $\overline{\overline{B C L K}}$ to CBRQ Float (See Note 2) |  | 35 | ns |  |
| TOLOH | Output Rise Time |  | 20 | ns | From 0.8 V to 2.0 V |
| TOHOL | Output Fall Time |  | 12 | ns | From 2.0 V to 0.8 V |

## NOTES:

1. BCLK generates the first BPRO wherein subsequent BPRO changes lower in the chain are generated through BPRN.
2. Measured at .5 V above GND.
3. Denotes that spec applies to both transitions of the signal.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## A.C. TEST CIRCUITS

1) $\overline{\mathrm{BUSY}, \overline{C B R Q}}$
2) $\overline{A E N}$
3) $\overline{B P R O}, \overline{B R E Q}$




## UNIVERSAL PERIPHERAL INTERFACE

 8-BIT MICROCOMPUTERMILITARY

## - 8-Bit CPU plus EPROM, 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$ EPROM, $64 \times 8$ RAM, 8 -Bit

Timer/Counter, 18 Programmable I/O Pins

- Fully Compatible with MCS-48, MCS-80, MCS-85, and IAPX 86, 88 Families
- Expandable I/O
- Over 90 Instructions: 70\% Single Byte
- Military Temperature Range:
$-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$

The Intel® M8741A 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, MCS-80, MCS-85, ${ }^{\circledR}$, $\mathrm{APX} 86,88$ systems.
The M8741A has 1 K words of program memory and 64 words of data memory on-chip. 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 M8243 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, single-step mode for debug and dual working register banks.
Because it's a complete microcomputer, the UPI provides more flexibility for the designer than conventional LSI inter-: face 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.


Figure 1. Block Diagram
Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

Ambient Temperature Under Bias . . . . . $-65^{\circ} \mathrm{C}$ to $100^{\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
*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $\left.100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {IL }}$ | Input Low Voltage (Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | -0.5 | 0.7 | V |  |
| $V_{1 L 1}$ | Input Low Voltage (XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | -0.5 | 0.5 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage (Except XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 2.3 | $\mathrm{V}_{\mathrm{CC}}$ |  |  |
| $\mathrm{V}_{1+1}$ | Input High Voltage (XTAL1, XTAL2, $\overline{\text { RESET }}$ ) | 3.8 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) |  | 0.45 | V | $\mathrm{IOL}=1.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL1 }}$ | Output Low Voltage ( $\mathrm{P}_{10} \mathrm{P}_{17}, \mathrm{P}_{20} \mathrm{P}_{27}$, Sync) |  | 0.45 | V | $\mathrm{IOL}=0.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {OL2 }}$ | Output Low Voltage (Prog) |  | 0.45 | $V$ | IOL $=0.8 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( $\mathrm{D}_{0}-\mathrm{D}_{7}$ ) | 2.4 |  | V | $\mathrm{IOH}=-240 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OH} 1}$ | Output High Voltage (All Other Outputs) | 2.4 |  | V | IOH $=-30 \mu \mathrm{~A}$ |
| $\mathrm{I}_{\text {IL }}$ | Input Leakage Current ( $\left.\mathrm{T}_{0}, \mathrm{~T}_{1}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{CS}}, \mathrm{A}_{0}, \mathrm{EA}\right)$ |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }} \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{Oz}}$ | Output Leakage Current ( $\mathrm{D}_{0}-\mathrm{D}_{7}$, High $Z$ State) |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {SS }}+0.45 \leqslant \mathrm{~V}_{\text {OUT }} \leqslant \mathrm{V}_{\text {CC }}$ |
| $\mathrm{I}_{\mathrm{LI}}$ | Low Input Load Current ( $\mathrm{P}_{10} \mathrm{P}_{17}, \mathrm{P}_{20} \mathrm{P}_{27}$ ) |  | 0.7 | mA | $\mathrm{V}_{\text {IL }}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\text {LII }}$ | Low Input Load Current ( $\overline{\mathrm{RESET}}$, $\overline{\mathrm{SS}}$ ) |  | 0.3 | mA | $\mathrm{V}_{\text {IL }}=0.8 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | $V_{\text {DD }}$ Supply Current |  | 25 | mA | Typical $=10 \mathrm{~mA}$ |
| $I_{C C}+I_{\text {DD }}$ | Total Supply Current |  | 155 | mA | Typical $=80 \mathrm{~mA}$ |

A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $\left.100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 10 \%\right)$
dbb READ

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AR }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{RD}}$ l | 0 |  | ns |  |
| $\mathrm{t}_{\mathrm{RA}}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After $\overline{\mathrm{RD}}$ t | 0 |  | ns |  |
| $t_{\text {RR }}$ | $\overline{\mathrm{RD}}$ Pulse Width | 350 |  | ns |  |
| $t_{A D}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ to Data Out Delay |  | 300 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{RD}}$ | $\overline{\mathrm{RD}}$ ! to Data Out Delay |  | 300 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $t_{\text {DF }}$ | $\overline{\mathrm{RD}}+$ to Data Float Delay |  | 100 | ns |  |
| $t_{\text {CY }}$ | Cycle Time | 4.17 | 15 | $\mu \mathrm{S}$ | 3.6 MHz XTAL |

DBB WRITE

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AW }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Setup to $\overline{\mathrm{WR}}$ I | 0 |  | ns |  |
| $t_{\text {WA }}$ | $\overline{\mathrm{CS}}, \mathrm{A}_{0}$ Hold After $\overline{\mathrm{WR}}$ ! | 0 |  | ns |  |
| ${ }^{\text {w }}$ w | $\overline{\text { WR Pulse Width }}$ | 350 |  | ns |  |
| $t_{\text {DW }}$ | Data Setup to $\overline{W R} \uparrow$ | 200 |  | ns |  |
| $t_{\text {WD }}$ | Data Hold After $\overline{\text { WR }}$ I | 0 |  | ns |  |

## A.C. CHARACTERISTICS (Continued)

## PORT 2

| 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 PROG | 65 |  | ns |  |
| tpR | PROG to Time P2 Input Must Be Valid |  | 860 | ns |  |
| tpF | Input Data Hold Time | 0 | 160 | ns |  |
| tpP | Output Data Setup Time | 230 |  | ns |  |
| tpD | Output Data Hold Time | 25 |  | ns |  |
| tpp | PROG Pulse Width | 920 |  | ns |  |

## DMA

| Symbol | Parameter | Min. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $t_{A C C}$ | $\overline{\mathrm{DACK}}$ to $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ | 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 |  | 300 | ns | $\mathrm{C}_{\mathrm{L}}=150 \mathrm{pF}$ |
| $\mathrm{t}_{\mathrm{CRQ}}$ | $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ to DRQ Cleared |  | 250 | ns |  |

## A.C. TESTING INPUT, OUTPUT WAVEFORM



## WAVEFORMS



# M8755A <br> 16,384-BIT EPROM WITH I/O <br> *Directly Compatible with M8085A CPU. MILITARY 

## - Military Temperature Range:

$-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$

## 2048 Words $\times 8$ Bits

- Single +5 V Power Supply (VCC)


## - U.V. Erasable and Electrically Reprogrammable

Internal Address Latch

- 2 General Purpose 8-Bit I/O Ports
- Each I/O Port Line Individually Programmable as Input or Output
- Multiplexed Address and Data Bus
- 40-Pin DIP

The Intel ${ }^{\circledR 1}$ M8755A is an erasable and electrically reprogrammable ROM (EPROM) and I/O chip to be used in the MCS-85 ${ }^{\text {m }}$. microcomputer system. The EPROM portion is organized as 2048 words by 8 bits.

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.


Figure 1. Block Diagram


Figure 2. Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Temperature Under Bias . . . . . . . . . $-55^{\circ} \mathrm{C}$ to $+100^{\circ} \mathrm{C}$ |  |
| :---: | :---: |
| Storage Temperature . . . . . . . . . . . . . $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |  |
| Voltage on Any Pin |  |
| With Respect to Grou | o +7 V |
|  | 1.5 W |

*Except for programming voltage
*NOTICE: 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}=-55^{\circ} \mathrm{C}\right.$ to $\left.+100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}= \pm 10 \%\right)$

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{I L}$ | Input Low Voltage | -0.5 | 0.7 | 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{IL}}$ | Input Leakage |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{SS}} \leqslant \mathrm{V}_{\mathrm{IN}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{SS}}+0.45 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{OUT}} \leqslant \mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Supply Current |  | 220 | mA |  |
| $\mathrm{I}_{\mathrm{DD}}$ | $\mathrm{V}_{\mathrm{DD}}$ Supply Current |  | 30 | mA | $\mathrm{~V}_{\mathrm{DD}}=\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\mathrm{IN}}$ | Input Capacitance |  | 10 | pF | $\mathrm{f}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{I} / \mathrm{O}}$ | Input/Output Capacitance |  | 15 | pF | $\mathrm{f}=1 \mathrm{MHz}$ |

A.C. CHARACTERISTICS $\left(T_{A}=-55^{\circ} \mathrm{C}\right.$ to $100^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=\mathrm{V}_{\mathrm{DD}}= \pm 10 \%$ )

| Symbol | Parameter | Min. | Max. | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {cYC }}$ | Clock Cycle Time | 320 |  | ns | $C_{\text {LOAD }}=150 \mathrm{pF}$ |
| 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 |  |
| $\mathrm{t}_{\mathrm{AL}}$ | Address to Latch Set Up Time | 70 |  | ns |  |
| $t_{\text {LA }}$ | Address Hold Time after Latch | 100 |  | ns |  |
| $t_{\text {LC }}$ | Latch to READ/WRITE Control | 130 |  | ns |  |
| $t_{\text {RD }}$ | Valid Data Out Delay from READ Control |  | 200* | ns |  |
| $t_{\text {AD }}$ | Address Stable to Data Out Valid |  | 500 | ns |  |
| $t_{\text {LL }}$ | Latch Enable Width | 140 |  | ns |  |
| $t_{\text {RDF }}$ | Data Bus Float after READ | 0 | 100 | ns |  |
| $\mathrm{t}_{\mathrm{CL}}$ | READ/WRITE Control to Latch Enable | 50 |  | ns |  |
| $\mathrm{t}_{\mathrm{CC}}$ | READ/WRITE Control Width | 300 |  | ns |  |
| $t_{\text {DW }}$ | Data In to WRITE Set Up Time | 200 |  | ns |  |
| $t_{\text {wo }}$ | Data In Hold Time After WRITE | 100 |  | ns |  |
| $t_{\text {WP }}$ | WRITE to Port Output |  | 400 | ns |  |
| $t_{\text {PR }}$ | Port Input Set Up Time | 70 |  | ns |  |
| $t_{\text {RP }}$ | Port Input Hold Time | 70 |  | ns |  |
| $t_{\text {RYH }}$ | READY HOLD TIME | 10 | 160 | ns |  |
| $t_{\text {ARY }}$ | ADDRESS (CE) to READY |  | 220 | ns |  |
| $t_{\text {RV }}$ | Recovery Time Between Controls | 400 |  | ns |  |
| $t_{\text {RDE }}$ | Data Out Delay from READ Control | 20 |  | ns |  |
| $\mathrm{t}_{\text {LD }}$ | ALE to Data Out Valid |  | 400 | ns | Preliminary |

${ }^{*} T_{A D}-\left(T_{A L}+T_{L C}\right)$, whichever is greater.

## A.C. TESTING INPUT, OUTPUT WAVEFORM


A.C. TESTING LOAD CIRCUIT


## QUALITY ASSURANCE OPERATIONS

## QUALITY ASSURANCE OPERATIONS, CORPORATE POLICY

"It is the policy of Intel Corporation to design, manufacture, and deliver products that not only meet our specified standards, but also satisfy our customer standards, and perform reliably in their applications. To this end, Quality Assurance at Intel has the authority to exercise control of quality over every phase of the design and manufacturing process."

## Intel Quality Program Policy,

 Intel (Corporate) Policies and Procedures.
## QUALITY ASSURANCE,

## THE SCOPE OF THE OPERATION

By definition, quality is conformance to specification . . . process or procedure, mechanical or electrical, customer or Intel. The operation chartered to maintain that conformance is "Quality Assurance." Within this operation, departmental activities include the day-today surveillance of manufacturing and testing of product, and the longer-range considerations of process, package, and product reliability. Just as quality is "conformance to specification," reliability is "continual conformance to specification." The reliability departments, process, package and product, play key roles in maintaining Intel's high quality standards, by being involved from concept to on-going production monitors throughout the product life.

## ORGANIZATION, A UNIQUE MATRIX

All product-related Q .A. organizations come under a uniform policy, while still maintaining the flexibility to service the specific needs of a product area. To perform in this manner, a unique matrix organization was developed. All quality and reliability functions report directly through Q.A. operations or site managers to the Director of Quality Assurance. The flexibility is obtained by the Q.A. managers associated with product areas (such as E-PROMs, memories, microcontrollers, microprocessors and peripheral circuits) also reporting indirectly to (i.e., matrixing to) the operation or division general manager.
Additionally, each product area has both a quality and reliability group under a single Q.A. manager. This involvement on a product-specific level provides both the customer and Intel with the timely response necessary to maintain a problem-free product flow. And when there are problems, they are handled quickly on a local level. This results in a "team" approach, quality, reliability, development, manufacturing-making state-of-the-art technology available in a usable form for our customers.

## RELIABILITY, DESIGNED-IN AND BUILT ON EXPERIENCE

Intel's extensive reliability program forms the basis of the quality program. Whether process, package or product, the appropriate reliability department is part of the development cycle from concept. In this way, the finished product is based on the reliability history of millions of devices-built on experience. To illustrate this philosophy, since 1970, the first application of a new technology has always been on a memory chip. This type of chip provides a large-volume basis to establish a reliability data base for the technology. As part of the data base, the memory device is extensively analyzed for failure mechanisms and the process technology altered to eliminate them. From this data base, under the guidance of process reliability, design rules, test patterns, and process limits evolve. Only after completing qualification will the technology be utilized in another type of device; such as a microprocessor. And so the data base grows, with more complex devices advancing the technology, each succeeding device being potentially more reliable than the last, because the devices are built on experience, and the reliability is designed-in.

The key to establishing a new product, process or package, or to changing an existing one, is the rigid qualification requirements which must be met. Qualification must be run and approved by the appropriate reliability department before any revenue shipment may be made. The reliability goals have been set during the concept stage in keeping with corporate objectives and must be demonstrated by the qualification. Consider one example, the qualification of a new wafer fab technology for E-PROMs. Below is a list of tests the first 5 wafer lots see during qualification:

| $125^{\circ} \mathrm{C}$ burn-in | 168 hours |
| :--- | :--- |
| $125^{\circ} \mathrm{C}$ lifetest | 2000 hours |
| $150^{\circ} \mathrm{C}$ HTRB | 1000 hours |
| Low-temperature lifetest | 1000 hours |
| $250^{\circ} \mathrm{C}$ storage | 1000 hours |

Temperature cycle
Thermal shock
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
$-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$

It is from this type of sequence that infant mortality, random failure rates, and associated failure mechanisms are determined. Also from this data, reliability reports are written and made available to our customers.

While successful completion of qualification is the key to product introduction, it would be meaningless if the device was not sampled throughout its product life. As has been shown, the use of generic technology families evaluates the process each time a new product is qualified. More than that, on a rotating product basis, $125^{\circ} \mathrm{C}$ dynamic burn-in and lifetests are performed to continuously monitor all technologies. Fifty thousand devices each month are allocated for the Reliability Monitor Program by the Components Division. In this manner, all generic technology families are continuously scrutinized to assure that reliability goals are met.

In the same manner, Intel Package Reliability performs an extensive package monitor program to assure the mechanical integrity of every package type produced by every assembly facility.

## QUALITY, THE DEVICE MEETS SPECIFICATION

The reliability program has been shown to support components quality through design-in, qualification, and on-going monitors. This forms the basis of the quality philosophy of looking at product from its concept, and requiring succeeding and more complex technologies/products to perform at levels better than those previous. The quality operations supporting this philosophy start, as reliability does, by working with the design team in the product concept stage.
Quality must approve the Target Specification for any new device. Later, before qualification, test programs are validated as meeting the required limits and conditions to guarantee operation of the product to specification.

The checks and balances implemented during the process flow start with incoming inspection of piece parts, wafers, chemicals and masks. All must meet the standards determined to be commensurate with Intel's product quality and reliability goals. The Materials Technology Laboratory plays a large support role in determining these standards, in some instances developing test methods where none exist to meet the complex control needs.
Throughout the entire process, an independent manufacturing group, Manufacturing Process Control, continuously monitors processes in wafer fabrication, assembly, die sort, burn-in and test areas. The group provides trend data and process auditing control on a day-to-day basis, involving quality and reliability groups when control problems are evident. In the case of wafer fabrication, the test methods and patterns used for process control by MPC have been designed by

Process Reliability. In all areas, controls must be approved by Quality and Reliability.

Assembly Quality Assurance operates at all assembly sites instituting controls that guarantee product integrity irrespective of plant location. Consolidated trend data is published weekly, heading off potential problems by allowing effective concentration of engineering resources in a timely manner.
Final Quality Assurance (FQA) operates in each Test and Finish area to verify that Intel and customer requirements are met. Independent electrical sampling, external visual examination, and checking data requirements are some of the functions of this group.
Overlaying all areas is a network of calibration laboratories. Operating to Mil-Std-45662, the laboratory supports all operations by maintaining test and process equipment within their required tolerances. The group provides the baseline for all Intel measurements by both systems and bench-top equipment, assuring the validity of product shipments at the customer's location.

## MAJOR PROGRAMS, CUSTOMER-ORIENTED TO PROVE AND IMPROVE QUALITY

Every area of quality and reliability at Intel häs major programs which are customer-oriented. Several are detailed here to illustrate the manner in which Intel services the customer in the quality and reliability areas after the sale.

The Reliability Monitor Program, referred to in the "Reliability" section, is a burn-in and lifetest program which verifies that all of Intel's technologies are being controlled within specified reliability target goals. By utilizing a dynamic $125^{\circ} \mathrm{C}$, 48 -hour burn-in, "infant mortality" failure rates may be determined. A portion of these devices are continued to 1000 hours to determine random failure rates. This process technologyoriented data is now available to customers biannually to use instead of requiring product burn-in on a lot-bylot basis.
There has been a need, that has grown with device complexity, for an Intel-customer correlation effort. This effort has resulted in the FACR (Failure Analysis Correlation Request) system within each division or operation. Operating through the Field Sales Engineers, the object of the program is to eliminate electrical test discrepancies between Intel and its customers in a timely manner. The system provides direct contact with a product-oriented Quality Engineer to eliminate test program or equipment discrepancies between the
customer and Intel without returning all product shipped. The success of the program may be measured by the numbers of lots that have been shipped to customers and been questioned and accepted after utilizing the FACR system. The obvious by-product of this system is to build customer confidence to the point where Intel's final test and FQA data becomes the customer's incoming inspection data.

The Military Quality Assurance program, operated out of the Phoenix site, attends to customers within the aerospace or military industry, or in some cases, to customers that have special documentation requirements. To perform in this product area, the Military Q.A. acts as an overlay on all sites and operations, defining the Q.A. program requirements in that particular area. The success of this program may be gauged by the acceptance of selected high-technology products by the Federal Government under Mil-M-38510, and the product processing areas certified by an agency of the

Federal Government (see "Military Grade Products" for details). This department also performs process audits on a regular basis of applicable Intel manufacturing facilities to assure compliance to rigid military traceability and process requirements.

## QUALITY ASSURANCE OPERATIONS FLOWCHART

The Quality Assurance Operations are involved in every phase of the Components Divisions. Activities vary from generating and validating design rules for a process technology to assuring the device count agrees with the Intel invoice in Plant Clearance. The following flowchart documents some of the major interactions of Quality and Reliability through the product lifecycle. Step-by-step inspection is not shown, but rather an overview of the entire cycle to illustrate the extent of Intel's commitment to provide the quality and reliability our customers have utilized since 1969.

## QUALITYASSURANCE OPERATIONS

## PROCESS TECHNOLOGY



Reliability: Generate Design Rules Generate Test Pattern Process Qualification Stress Testing Failure Mode Analysis

PACKAGE TECHNOLOGY

Reliability: Process Qualification Materials Test Methods Materials Characterization

## WAFER FABRICAT



Quality: Incoming Inspectior High Magnification

Reliability: Process Qualificatio Process Control, Mc Analytical Test Labo

Quality: Parameter Limits, Testability
Test Program Control
Target Specification


PRODUCT VALIDATION/QUALIFICATION


Design Engineering:
Design Engineering: Applications Engineering: Quality/Reliability:

Design Verification
Performance Verification
System Verification Qualification


## General Information

## Status Notices:

PRELCOMONARY - Indicates some electrical parameters are subject to change.
ADVANCE $\operatorname{ANPOROATOON~-~Indicates~some~functional~characteristics~are~subject~to~change.~}$

Semiconductor components are identified as follows:

## Example:



## Examples:

D2147H-1 High-speed 2147, $4096 \times 1$ RAM with 35 ns access time, hermetic package Type D, commercial temperature range.
P8085A-2 8085A 8-bit microprocessor with 5 MHz clock, plastic package, commercial temperature range.
MD3636/B $\quad 2 \mathrm{~K} \times 8$ PROM, hermetic package Type D, military temperature range, MIL-STD-883 Level B processing.*
MD8080A/B 8080A microprocessor, hermetic package Type D, 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 InteI 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.
*For Military products, MIL-STD-883 Level B processing is indicated by a /B suffix; all others should be specified by the " $s$ " number suffix.

NOTES:

1. All packages drawings not to scale.
2. All packages seating plane defined by .0415 to .0430 PCB holes.
3. Type $P$ packages only. Package length does not include end flash burr. Burr is .005 nominal, can be .010 max. at one end.
4. All package drawings end view dimensions are to outside of leads.

## PLASTIC DUAL IN-LINE PACKAGE TYPE P

## 16-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P



18-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P


## 20-LEAD PLASTIC DUAL IN-LINE PACKAGE TYPE P



## PLASTIC DUAL IN-LINE PACKAGE TYPE P

22-LEAD 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


PACKAGING INFORMATION All dimensions in inches and (millimeters)
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


22-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE D


PACKAGING INFORMATION All dimensions in inches and (millimeters)
CERAMIC DUAL IN-LINE PACKAGE TYPE D
24-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPED


24-LEAD HERMETIC 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


CERAMIC DUAL IN-LINE PACKAGE TYPE C
16-LEAD CERAMIC DUAL IN-LINE PACKAGE TYPE C


18-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


20-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


PACKAGING INFORMATION All dimensions in inches and (millimeters)
CERAMIC DUAL IN-LINE PACKAGE TYPE C
24-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


28-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


40-LEAD HERMETIC DUAL IN-LINE PACKAGE TYPE C


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


CERAMIC LEADLESS QUAD IN-LINE HERMETIC TYPE C 64 PINS-REOUIRES A SOCKET


BOTTOM VIEW


DUAL IN-LINE LEADLESS PACKAGE AND SOCKET 20 PINS


WEIGHT: 74 GRAMS NOMINAL, 80 GRAMS MAXIMUM


# intel Microcomputer Workshops 

## 1982

The best microcomputer training
you can get your hands on.

## Which Workshop Should You Attend?

If you have sufficient working experience with microcomputer hardware and software you might attend any of the Intel Workshops without first attending a prerequisite workshop; however, since microcomputers are new to many people, we recommend the sequence indicated in the chart for those who want to advance their microcomputer education. Also note that the iAPX 432 related workshops are in a sequence of their own because the iAPX 432 is a completely new product. We do, however, recommend attending the Operating System Fundamentals Workshop prior to any of the iAPX 432 workshops.
As a DESIGN ENGINEER or SYSTEM ENGINEER with $\alpha$ good understanding of digital electronics, you might start with the MCS-48/49, MCS-51, MCS-80/85 or iAPX 86,88 System Design Workshops. If you lack the digital electronics background, $s^{\prime}$ art with the Introduction to Microcomputers Workshop.
As a PROGRAMMER, you may be ready to start with the PASCAL, or PL/M Workshops; however, if you intend to use assembly language the MCS48/49, MCS-51, MCS-80/85, or iAPX 86,88 Workshops should be attended first. We suggest that you also consider the Introduction to Microcomputers Workshop to gain basic knowledge of digital electronics and machine language, since these topics are usually much more important to the microcomputer programmer.

## Recommended Sequence of Workshops



## Where is Intel Training?

Intel Customer Training is a worldwide organization with workshops scheduled nearly every week of the year in our training centers:

```
BOSTON AREA
(617) 256-1374
CHICAGO AREA
(312) 981-7250
DALLAS AREA
(312) 981-7250
SAN FRANCISCO BAY AREA
(408) 734-8395
TOKYO AREA
03-437-66l1
LONDON AREA
(0793)26101
PARIS AREA
6872221
MUNICH AREA
(089)53891
STOCKHOLM AREA
08985390
```


## CUSTOMER-SITE WORKSHOPS

All workshops detailed in the following pages can, by special arrangements, be presented by Intel instructors at your facility. We have outfitted vans with Intellec Development Systems and ICE In-Circuit Emulators so we can easily bring our extensive workshop lab equipment to your facility. Considering the transportation and lodging savings, the breakeven point is typically 5-7 attendees. For further information about on-site training contact your nearest training center.


## Training in Microcomputers

Whether your present involvement with microcomputers is a result of long-term planning or simply an exploratory project undertaken by your company in response to external circumstances, there exists an obvious and urgent need for you to familiarize yourself with this exciting new technology. If the microcomputer is, or is destined to become, a part of your working scene then the importance of carefully planned training
cannot be over-emphasized. A modest outlay in time and money now can save many weeks of self-study and could well prevent some very expensive mistakes during the initial development of your systems.

For further information and reservations call one of the numbers above or write to:

Intel Corporation
Customer Training Group
MS: SV 3-1
3065 Bowers Ave
Santa Clara, CA 95051

## INTEL PRODUCT SERVICE

Today, it's essential to have dependable data processing and information storage equipment.

To insure trouble-free performance, every Intel product is engineered and manufactured to exacting standards. But sometimes, even the finest components may malfunction.

It's then that Intel Product Service delivers fast, economical, quality maintenance and service support to keep vital projects on schedule.

Intel is committed to providing a total service support package through a wide variety of service offerings available from Intel Product Service.

Intel Product Service takes pride in its capabilities and in the entire Intel systems product line, and is dedicated to total customer satisfaction.


## Customer Is Assured Maximum Equipment Performance

The Intel Product Service team is a skilled group capable of solving any problem, either by phone or on-site. All service needs (including emergency service and preventive maintenance) are handled quickly and efficiently by Intel's Customer Engineers, supported by district, regional and factory specialists.

This assures the customer of minimum downtime and maximum equipment performance.

## Immediate Availability of Service and Parts

Working from field service offices throughout the United States, Canada and abroad, Intel's Customer Engineers provide maintenance agreement customers with equipment installation and regularly scheduled preventive maintenance, including automatic installation of engineering changes as they occur.

If there should be an equipment problem, customers contact the nearest Intel service location. If the customer location is within Intel's service area, an Intel Customer Engineer is dispatched to the site as quickly as possible. Once there, using advanced diagnostic tools and sophisticated test equipment, the Customer Engineer will determine the trouble and the replacement parts needed. With Intel's vast inventory of replacement parts, the right part is always available on the shortest notice, and the Customer Engineer is able to make repairs quickly and verify performance.


## Product Service Alternatives

Intel offers customers a number of service alternatives . . . all at reasonable prices and featuring the quality expected of the industry leader.

First, there's the Maintenance Agreement, which guarantees maintenance at the customer's site plus parts replacement and labor at no extra charge beyond an easy-to-budget, fixed monthly rate -- all billed against one purchase order. The Maintenance Agreement features preventive maintenance which helps keep emergencies at a minimum. But should an emergency arise, a Customer Engineer is sent to the site immediately.


Of course Intel provides service for every system it sells. Thus, site service, parts replacement and repair are also available without a Maintenance Agreement. However, the site must be within a reasonable distance of an Intel field service location, and all charges are paid as they are incurred.

For customers not located in an Intel service area, or for those who prefer direct factory service, an Intel Direct Return Authorization "DRA" enables the customer to return parts direct to Intel for repair, refurbishing and upgrade services by its factory experts.


When distance from an Intel field location is too great, the Return Replacement Authorization "RRA"' or the Before Return Replacement "BRR" services are the logical solutions for customers. (These services are not available on field-supported products in serviceable areas.)


The 'RRA'" service is the most cost-effective service. The customer calls the Hotline and obtains an RRA number and sends the boards in identified with this number. Replacement boards are shipped within 24 hours of receipt of the customer's boards. Replacement boards are in standard factory configuration and at the latest engineering level. Exchanged boards are not necessarily new but are functionally equivalent to new boards.

Where response is the primary concern and cost the secondary concern, the customer will find the "BRR"' service to be the best answer. A call to the Intel Hotline puts the customer in direct contact with support specialists who can determine which part is needed to repair the system. The part is then sent immediately - before the return of the old part to Intel. Boards sent to the customer are not necessarily new but are functionally equivalent to new boards.

## Toll-Free Service Hotline

In the United States, Intel's toll-free service Hotline is a direct connection to service support specialists who can help immediately.

If on-site service is available, they direct the customer to the nearest Intel field service location. If not, Hotline specialists can usually help locate the trouble . . . and indicate how to make the necessary repairs.

Whichever service alternative is chosen, the customer is assured fast, affordable service. Intel offers customers the total service they need -- that is one of the most important benefits of buying Intel products.


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

## PRODUCT SERVICE OFFICES

 ONLY, CALL INTEL'S TOLL-FREE HOT-LINE NUMBER 800-528-0595| UNITED STATES | CENTRAL CONTACT: PHOENIX, AZ 602-869-4525 |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| ALABAMA Huntsville | $\begin{aligned} & \text { GEORGIA } \\ & \text { Atlanta } \end{aligned}$ | Minvesota | $\begin{gathered} \text { OKLAHOMA } \\ \text { Oklahoma City } \\ \text { Tulsa } \end{gathered}$ | washlugaon, ..c. |
| $\xrightarrow{\text { Afizoona }}$ | $\begin{aligned} & \text { ILLINOIS } \\ & \text { Rockford } \\ & \text { Rolling Meadows } \\ & \text { (Chicago) } \end{aligned}$ | $\begin{aligned} & \text { MISSOURI } \\ & \text { Kansas City } \\ & \text { St. Louis } \end{aligned}$ | OREGON | WISCONSIN Madison Milwaukee |
|  |  | $\begin{gathered} \text { NEW JERSEY } \\ \text { Fort Lee } \end{gathered}$ |  |  |
| $\begin{gathered} \text { COLORADO } \\ \text { Denver } \end{gathered}$ | MARYLAND Hanover <br> (Baltimore) | $\begin{aligned} & \text { NEW YORK } \\ & \text { New York City } \\ & \text { Rochester } \\ & \text { Syracuse } \end{aligned}$ | $\begin{aligned} & \text { TEXAS } \\ & \text { Austin } \\ & \text { Dallas } \\ & \text { Houston } \\ & \text { San Antonio } \end{aligned}$ |  |
| CONNECTICUT Danbury Hartford | MASSACHUSETTS Chelmsford (Boston) | NORTH CAROLINA Greensboro | VIRGINIA Roanoke |  |
|  | $\begin{aligned} & \text { MICHIGAN } \\ & \text { Southfield } \\ & \text { (Detroit) } \end{aligned}$ |  | $\begin{aligned} & \text { WASHINGTON } \\ & \text { Seattle } \end{aligned}$ |  |

EUROPE
CENTRAL CONTACT: SWINDON 011-44-793-26101

FRANCE
Paris

GERMANY
Munich Hanover
Dusseldorf

HOLLAND
Rotterdam:

| SCANDANAVIA | U.K. |
| :---: | :---: |
| Copenhagen | London |
| Oslo | Swindon |
| Stockholm | Ipswich |

CENTRAL CONTACT: TOKYO 011-81-3-427-756

CHOFU
MISHIMA
NAGOYA
OSAKA
SETAGOYA (Tokyo)

Intel Corporation
3065 Bowers Avenue
Santa Clara, CA 95051
Intel International
Rue du Moulin à Papier 51, Boite 1, B-1160 Brussels, Belgium
Intel Japan K.K.
Flower Hill-Shinmachi East Bldg.
1-23-9, Shinmachi, Setagayu-ku
Tokyo 154, Japan


[^0]:    INTEL CORPORATION ASSUMES NO RESPONSIBILITY FOR THE USE OF ANY CIRCUITRY OTHER THAN CIRCUITRY EMBODIED IN AN INTEL PRODUCT. NO OTHER CIRCUIT PATENT LICENSES ARE IMPLIED. ©INTEL CORPORATION, 1977, 1979

[^1]:    *This parameter is periodically sampled and is not $100 \%$ tested.

[^2]:    Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in an Intel product. No other circuit patent licenses are implied. © INTEL CORPORATION, 1980

[^3]:    Intel Corporation Assumes No Responsibilty for the Use of Any Circuitry Other Than Circuitry Embodied in an Intel Product. No Other Circuit Patent Licenses are Implied.

[^4]:    Intel Corporation Assumes No Responsibilty for the Use of Any Circuitry Other Than Circuitry Embodied in an Intel Product. No Other Circuit Patent Licenses are Implied. 'INTEL CORPORATION, 1980

[^5]:    For footnotes see page 13.

[^6]:    Intel Corporation Assumes No Responsibilty for the Use of Any Circuitry Other Than Circuitry Embodied in an Intel Product. No Other Circuit Patent Licenses are Implied. ミ INTEL CORPORATION, 1980

[^7]:    *Not used in minimum (128K byte) system.

[^8]:    *Final test conditions: TBD.

[^9]:    *See "Error-Correcting Codes" by W.W. Peterson and E. J. Weldon, Jr., pp. 366-370, M.I.T. Press, 1972.

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

[^11]:    IEXTERNAL COMPONENTS (2921 has on-chip S\&H capacitor)

[^12]:    *See text for explanation.

[^13]:    *Typical = typical unit with $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}=+5.0 \mathrm{~V}$

[^14]:    *Typical $=$ typical unit with $V_{C C}, V_{D D}=+5.0 \mathrm{~V}, T_{A}=+25^{\circ} \mathrm{C}$

[^15]:    *Typical $=$ typical unit with $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{DD}}=+5.0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}$

[^16]:    Intel Corporation Assumes No Responsibility for the Use of Any Circuitry Other Than Circuitry Embodied in an Intel Product. No Other Circuit Patent Licenses Are Implied. © INTEL CORPORATION, 1981

[^17]:    Intel Corporation Assumes No Responsibility for the Use of any Circuitry Other Than Circuitry Embodied in an Intel Product. No Other Circuit Patent Licenses are Implied. ©INTELCORPORATION, 1980

[^18]:     Insite, iRMX, System 2000, CREDIT, iRMX/80, MULTIBUS, PROMPT, Promware, Megachassis, Library Manager, MAIN MULTIMODULE, and the combination of MCS, ICE, ISBC, IRMX or iCS and a numerical suffix. © INTEL CORPORATION, 1981.

[^19]:    - Note: Master/Slave in ICW4 is only used in the buffered mode.

[^20]:    NOTE: 1. THE COPROCESSOR MAY NOT DRIVE THE BUSSES OUTSIDE THE REGION SHOWN WITHOUT RISKING CONTENTION.

[^21]:    Intel Corporation Assumes No Responsibilty for the Use of Any Circuitry Other Than Circuitry Embodied in an Intel Product. No Other Circuit Patent Licenses are Implied © INTEL CORPORATION, 1980

[^22]:    *CPU provides active pull-up.

[^23]:    Intel Corporation Assumes No Responsibilty for the Use of Any Circuitry Other Than Circuitry Embodied in an Intel Product. No Other Circuit Patent Licenses ave Implied. © © INTEL CORPORATION, 1981.

[^24]:    1. See waveforms and test load circuit on following page.
[^25]:    *In some system configurations it is possible for a non-I/O Processor to have access to more than one Multi-Master System Bus, see 8289 Application Note.

[^26]:    *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.

[^27]:    Pointer $=$ sector length $-\left((\text { Register } 14 \mathrm{H})^{*} 128+(\right.$ Register 13 H$\left.)\right)$

[^28]:    $C_{L}$ INCLUDES JIG CAPACITANCE

[^29]:    Note: 1. Symbols used in this table are described at the end of this section.

[^30]:    ${ }^{1}$ Special Receive Condition

[^31]:    *Note: These pins are the IEEE-488 bus non-inverting driver/receivers. They include all the bus terminations required by the Standard and may be connected directly to the GPIB bus connector.

[^32]:    *If an 8085 clock output is to drive an $8253-5$ clock input, it must be reduced to 2 MHz or less.

[^33]:    *Default after reset.

[^34]:    * For operation at 5 MHz or slower, the 43203 may be operated with a Vihc minimum of 2.7 volts.

[^35]:    The following are trademarks of Intel Corporation and its affiliates and may be used only to identify Intel products: $i$, Int e I, INTEL, INTELLEC, MCS, Im, iCS, ICE, UPI, BXP, iSBC, iSBX Insite, iRMX, System 2000, CREDIT, iRMX/80, MULTIBUS, PROMPT, Promware, Megachassis, Librarv Manager, MAIN MULTIMODULE, and the combination of MCS, ICE, iSBC, iRMX or

[^36]:    *This parameter is sampled and not $100 \%$ tested

[^37]:    *Pending-Call nearest Intel sales office for information.

[^38]:    *This parameter is sampled and not 100\% tested

[^39]:    *HMOS is a patented process of Intel Corporation.

[^40]:    The following are trademarks of Intel Corporation and its affiliates and may be used only to identify Intel products: i, Intel, INTEL, INTELLEC, MCS, Im, iCS, ICE, UPI, BXP, iSBC, iSBX, Insite, iRMX, System 2000, CREDIT, iRMX/B0, MULTIBUS, PROMPT, Promware, Megachassis, Library Manager, MAIN MULTIMODULE, and the combination of MCS, ICE, iSBC, iRMX or iCS and a numerical suffix. (C) INTEL CORPORATION, 1981.

[^41]:    The following are trademarks of Intel Corporation and its affiliates and may be used only to identify Intel products: i, Intel, INTEL, INTELLEC, MCS, ${ }^{\text {I }} \mathrm{m}$, iCS, ICE, UPI, BXP, iSBC, iSBX, Insite, iRMX, System 2000, CREDIT, iRMX/80, MULTIBUS, PROMPT, Promware, Megachassis, Library Manager, MAIN MULTIMODULE, ahd the combination of MCS, ICE, iSBC, iRMX or iCS and a numerical suffix. (C) INTEL. CORPORATION, 1981.

[^42]:    1. Load $=1 \mathrm{TTL}$. 2. Load $=1 \mathrm{TTL}+50 \mathrm{pF}$. 3. $\mathrm{Load}=1 \mathrm{TTL}+\left(\mathrm{R}_{\mathrm{L}}=3.3 \mathrm{~K}\right), \mathrm{V}_{\mathrm{OH}}=3.3 \mathrm{~V}$. 4. Tracking Parameter
    2. $\Delta \mathrm{T}_{\mathrm{AK}}<50 \mathrm{~ns}$. 6. $\Delta \mathrm{T}_{\mathrm{DCL}}<50 \mathrm{~ns}$. 7. $\Delta \mathrm{T}_{\mathrm{DCT}}<50 \mathrm{~ns}$.
