The 8086 (also called iAPX 86)
is a
16-bit
16-bit microcomputers are microcomputers that use 16-bit microprocessors.
A 16-bit register can store 216 different values. The range of integer values that can be stored in 16 bits depends on the integer representation used. With the two ...
microprocessor
A microprocessor is a computer processor (computing), processor for which the data processing logic and control is included on a single integrated circuit (IC), or a small number of ICs. The microprocessor contains the arithmetic, logic, a ...
chip designed by
Intel
Intel Corporation is an American multinational corporation and technology company headquartered in Santa Clara, California, and Delaware General Corporation Law, incorporated in Delaware. Intel designs, manufactures, and sells computer compo ...
between early 1976 and June 8, 1978, when it was released.
The
Intel 8088
The Intel 8088 ("''eighty-eighty-eight''", also called iAPX 88) microprocessor is a variant of the Intel 8086. Introduced on June 1, 1979, the 8088 has an eight-bit external data bus instead of the 16-bit bus of the 8086. The 16-bit registers ...
, released July 1, 1979, is a slightly modified chip with an external 8-bit
data bus (allowing the use of cheaper and fewer supporting
ICs),
[Fewer TTL buffers, latches, multiplexers (although the amount of TTL logic was not drastically reduced). It also permits the use of cheap 8080-family ICs, where the 8254 CTC, 8255 PIO, and 8259 PIC were used in the IBM PC design. In addition, it makes PCB layout simpler and boards cheaper, as well as demanding fewer (1- or 4-bit wide) DRAM chips.] and is notable as the processor used in the original
IBM PC
The IBM Personal Computer (model 5150, commonly known as the IBM PC) is the first microcomputer released in the List of IBM Personal Computer models, IBM PC model line and the basis for the IBM PC compatible ''de facto'' standard. Released on ...
design.
The 8086 gave rise to the
x86
x86 (also known as 80x86 or the 8086 family) is a family of complex instruction set computer (CISC) instruction set architectures initially developed by Intel, based on the 8086 microprocessor and its 8-bit-external-bus variant, the 8088. Th ...
architecture, which eventually became Intel's most successful line of processors. On June 5, 2018, Intel released a limited-edition CPU celebrating the 40th anniversary of the Intel 8086, called the
Intel Core i7-8086K.
History
Background
In 1972, Intel launched the
8008, Intel's first 8-bit microprocessor.
[using enhancement load PMOS logic (requiring 14 V, achieving TTL compatibility by having VCC at +5 V and VDD at −9 V).] It implemented an
instruction set
In computer science, an instruction set architecture (ISA) is an abstract model that generally defines how software controls the CPU in a computer or a family of computers. A device or program that executes instructions described by that ISA, s ...
designed by
Datapoint Corporation
Datapoint Corporation, originally known as Computer Terminal Corporation (CTC), was a computer company based in San Antonio, Texas, United States. Founded in July 1968 by Phil Ray and Gus Roche, its first products were, as the company's initial ...
with programmable
CRT terminals in mind, which also proved to be fairly general-purpose. The device needed several additional
ICs to produce a functional computer, in part due to it being packaged in a small 18-pin "memory package", which ruled out the use of a separate address bus (Intel was primarily a
DRAM manufacturer at the time).
Two years later, Intel launched the
8080, employing the new 40-pin
DIL packages originally developed for
calculator
An electronic calculator is typically a portable electronic device used to perform calculations, ranging from basic arithmetic to complex mathematics.
The first solid-state electronic calculator was created in the early 1960s. Pocket-si ...
ICs to enable a separate address bus. It had an extended instruction set that is
source-compatible (not
binary compatible) with the 8008 and also included some
16-bit
16-bit microcomputers are microcomputers that use 16-bit microprocessors.
A 16-bit register can store 216 different values. The range of integer values that can be stored in 16 bits depends on the integer representation used. With the two ...
instructions to make programming easier. The 8080 device was eventually replaced by the
depletion-load-based
8085 (1977), which used a single +5 V power supply instead of the three different operating voltages of earlier chips.
[Made possible with depletion-load nMOS logic (the 8085 was later made using HMOS processing, just like the 8086).] Other well known 8-bit microprocessors that emerged during these years are
Motorola 6800 (1974),
General Instrument PIC16X (1975),
MOS Technology 6502
The MOS Technology 6502 (typically pronounced "sixty-five-oh-two" or "six-five-oh-two") William Mensch and the moderator both pronounce the 6502 microprocessor as ''"sixty-five-oh-two"''. is an 8-bit computing, 8-bit microprocessor that was desi ...
(1975),
Zilog Z80
The Zilog Z80 is an 8-bit computing, 8-bit microprocessor designed by Zilog that played an important role in the evolution of early personal computing. Launched in 1976, it was designed to be Backward compatibility, software-compatible with the ...
(1976), and
Motorola 6809 (1978).
The first x86 design

The 8086 project started in May 1976 and was originally intended as a temporary substitute for the ambitious and delayed
iAPX 432 project. It was an attempt to draw attention from the less-delayed 16-bit and
32-bit
In computer architecture, 32-bit computing refers to computer systems with a processor, memory, and other major system components that operate on data in a maximum of 32- bit units. Compared to smaller bit widths, 32-bit computers can perform la ...
processors of other manufacturers —
Motorola
Motorola, Inc. () was an American multinational telecommunications company based in Schaumburg, Illinois. It was founded by brothers Paul and Joseph Galvin in 1928 and had been named Motorola since 1947. Many of Motorola's products had been ...
,
Zilog, and
National Semiconductor.
Whereas the 8086 was a 16-bit microprocessor, it used the same
microarchitecture as Intel's 8-bit microprocessors (8008, 8080, and 8085). This allowed
assembly language
In computing, assembly language (alternatively assembler language or symbolic machine code), often referred to simply as assembly and commonly abbreviated as ASM or asm, is any low-level programming language with a very strong correspondence bet ...
programs written in 8-bit to
seamlessly migrate.
New instructions and features — such as signed integers, base+offset addressing, and self-repeating operations — were added. Instructions were added to assist source code compilation of
nested function
In computer programming, a nested function (or nested procedure or subroutine) is a named function that is defined within another, enclosing, block and is lexically scoped within the enclosing block meaning it is only callable by name within t ...
s in the
ALGOL
ALGOL (; short for "Algorithmic Language") is a family of imperative computer programming languages originally developed in 1958. ALGOL heavily influenced many other languages and was the standard method for algorithm description used by the ...
-family of languages, including
Pascal and
PL/M. According to principal architect
Stephen P. Morse, this was a result of a more software-centric approach. Other enhancements included
microcode
In processor design, microcode serves as an intermediary layer situated between the central processing unit (CPU) hardware and the programmer-visible instruction set architecture of a computer. It consists of a set of hardware-level instructions ...
instructions for the multiply and divide assembly language instructions. Designers also anticipated
coprocessors, such as
8087
The Intel 8087, announced in 1980, was the first floating-point coprocessor for the 8086 line of microprocessors. The purpose of the chip was to speed up floating-point arithmetic operations, such as addition, subtraction, multiplication, di ...
and
8089, so the bus structure was designed to be flexible.
The first revision of the instruction set and high level architecture was ready after about three months,
[Rev.0 of the instruction set and architecture was ready in about three months, according to Morse.] and as almost no CAD tools were used, four engineers and 12 layout people were simultaneously working on the chip.
[Using rubylith, light boards, rulers, electric erasers, and a digitizer (according to Jenny Hernandez, member of the 8086 design team, in a statement made on Intel's webpage for its 25th birthday).] The 8086 took a little more than two years from idea to working product, which was considered fast for a complex design in the 1970s.
The 8086 was sequenced
[8086 used less microcode than many competitors' designs, such as the MC68000 and others] using a mixture of
random logic and
microcode
In processor design, microcode serves as an intermediary layer situated between the central processing unit (CPU) hardware and the programmer-visible instruction set architecture of a computer. It consists of a set of hardware-level instructions ...
and was implemented using depletion-load nMOS circuitry with approximately 20,000 active
transistor
A transistor is a semiconductor device used to Electronic amplifier, amplify or electronic switch, switch electrical signals and electric power, power. It is one of the basic building blocks of modern electronics. It is composed of semicondu ...
s (29,000 counting all
ROM and
PLA sites). It was soon moved to a new refined nMOS manufacturing process called
HMOS (for High performance MOS) that Intel originally developed for manufacturing of fast
static RAM products.
[Fast static RAMs in MOS technology (as fast as bipolar RAMs) was an important product for Intel during this period.] This was followed by HMOS-II, HMOS-III versions, and, eventually, a fully static
CMOS version for battery powered devices, manufactured using Intel's
CHMOS
CHMOS refers to one of a series of Intel CMOS processes developed from their Depletion-load NMOS logic#The HMOS processes, HMOS process. CHMOS stands for "complementary high-performance metal-oxide-silicon. It was first developed in 1981.
CHMOS ...
processes.
[CHMOS is Intel's name for CMOS circuits manufactured using processing steps very similar to HMOS.] The original chip measured 33 mm² and minimum feature size was 3.2 μm. The MUL and DIV instructions were very slow due to being microcoded so x86 programmers usually just used the bit shift instructions for multiplying and dividing instead.
The 8086 was die-shrunk to 2 μm in 1981; this version also corrected a stack register bug in the original 3.5 μm chips. Later 1.5 μm and CMOS variants were outsourced to other manufacturers and not developed in-house.
The architecture was defined by
Stephen P. Morse with some help from Bruce Ravenel (the architect of the 8087) in refining the final revisions. Logic designer Jim McKevitt and John Bayliss were the lead engineers of the hardware-level development team
[Other members of the design team were Peter A.Stoll and Jenny Hernandez.] and Bill Pohlman the manager for the project. The legacy of the 8086 is enduring in the basic instruction set of today's personal computers and servers; the 8086 also lent its last two digits to later extended versions of the design, such as the
Intel 286 and the
Intel 386, all of which eventually became known as the
x86
x86 (also known as 80x86 or the 8086 family) is a family of complex instruction set computer (CISC) instruction set architectures initially developed by Intel, based on the 8086 microprocessor and its 8-bit-external-bus variant, the 8088. Th ...
family. (Another reference is that the
PCI Vendor ID for Intel devices is 8086
h.)
Details
Buses and operation
All internal registers, as well as internal and external data buses, are 16 bits wide, which firmly established the "16-bit microprocessor" identity of the 8086. A 20-bit external address bus provides a 1
MiB physical address space (2
20 = 1,048,576 x 1
byte
The byte is a unit of digital information that most commonly consists of eight bits. Historically, the byte was the number of bits used to encode a single character of text in a computer and for this reason it is the smallest addressable un ...
). This address space is addressed by means of internal memory "segmentation". The data bus is
multiplexed with the address bus in order to fit all of the control lines into a standard 40-pin
dual in-line package. It provides a 16-bit I/O address bus, supporting 64
KB of separate I/O space. The maximum linear address space is limited to 64 KB, simply because internal address/index registers are only 16 bits wide. Programming over 64 KB memory boundaries involves adjusting the segment registers (see below); this difficulty existed until the
80386 architecture introduced wider (32-bit) registers (the memory management hardware in the
80286 did not help in this regard, as its registers are still only 16 bits wide).
Hardware modes of 8086
Some of the control pins, which carry essential signals for all external operations, have more than one function depending upon whether the device is operated in ''min'' or ''max'' mode. The former mode is intended for small single-processor systems, while the latter is for medium or large systems using more than one processor (a kind of multiprocessor mode). Maximum mode is required when using an 8087 or 8089 coprocessor. The voltage on pin 33 (MN/) determines the mode. Changing the state of pin 33 changes the function of certain other pins, most of which have to do with how the CPU handles the (local) bus.
[The IBM PC and PC/XT use an Intel 8088 running in maximum mode, which allows the CPU to work with an optional 8087 coprocessor installed in the math coprocessor socket on the PC or PC/XT mainboard. (The PC and PC/XT may require maximum mode for other reasons, such as perhaps to support the DMA controller.)] The mode is usually hardwired into the circuit and therefore cannot be changed by software. The workings of these modes are described in terms of timing diagrams in Intel datasheets and manuals. In minimum mode, all control signals are generated by the 8086 itself.
Registers and instruction
The 8086 has eight more-or-less general 16-bit
registers (including the
stack pointer but excluding the instruction pointer, flag register and segment registers). Four of them, AX, BX, CX, DX, can also be accessed as 8-bit register pairs (see figure) while the other four, SI, DI, BP, SP, are 16-bit only.
Due to a compact encoding inspired by 8-bit processors, most instructions are one-address or two-address operations, which means that the result is stored in one of the operands. At most one of the operands can be in memory, but this memory operand can also be the ''destination'', while the other operand, the ''source'', can be either ''register'' or ''immediate''. A single memory location can also often be used as both ''source'' and ''destination'' which, among other factors, further contributes to a
code density comparable to (and often better than) most eight-bit machines at the time.
The degree of generality of most registers is much greater than in the 8080 or 8085. However, 8086 registers were more specialized than in most contemporary
minicomputers and are also used implicitly by some instructions. While perfectly sensible for the assembly programmer, this makes register allocation for compilers more complicated compared to more orthogonal 16-bit and 32-bit processors of the time such as the
PDP-11,
VAX,
68000,
32016, etc. On the other hand, being more regular than the rather minimalistic but ubiquitous 8-bit microprocessors such as the
6502,
6800,
6809,
8085,
MCS-48,
8051, and other contemporary accumulator-based machines, it is significantly easier to construct an efficient
code generator for the 8086 architecture.
Another factor for this is that the 8086 also introduced some new instructions (not present in the 8080 and 8085) to better support stack-based high-level programming languages such as Pascal and
PL/M; some of the more useful instructions are
push ''mem-op''
, and ret ''size'', supporting the "Pascal
calling convention" directly. (Several others, such as
push ''immed''
and
enter
, were added in the subsequent 80186, 80286, and 80386 processors.)
A 64 KB (one segment)
stack growing towards lower addresses is supported in
hardware; 16-bit words are pushed onto the stack, and the top of the stack is pointed to by SS:SP. There are 256
interrupt
In digital computers, an interrupt (sometimes referred to as a trap) is a request for the processor to ''interrupt'' currently executing code (when permitted), so that the event can be processed in a timely manner. If the request is accepted ...
s, which can be invoked by both hardware and software. The interrupts can cascade, using the stack to store the
return address
In postal mail, a return address is an explicit inclusion of the address of the person sending the message. It provides the recipient (and sometimes authorized intermediaries) with a means to determine how to respond to the sender of the message ...
es.
The 8086 has 64 K of 8-bit (or alternatively 32 K of 16-bit word)
I/O port space.
Flags
The 8086 has a 16-bit
flags register. Nine of these condition code flags are active, and indicate the current state of the processor:
Carry flag (CF),
Parity flag (PF),
Auxiliary carry flag (AF),
Zero flag (ZF),
Sign flag (SF),
Trap flag (TF),
Interrupt flag (IF),
Direction flag (DF), and
Overflow flag (OF).
Also referred to as the status word, the layout of the flags register is as follows:
Segmentation
There are also four 16-bit
segment registers (see figure) that allow the 8086
CPU to access one
megabyte
The megabyte is a multiple of the unit byte for digital information. Its recommended unit symbol is MB. The unit prefix ''mega'' is a multiplier of (106) in the International System of Units (SI). Therefore, one megabyte is one million bytes ...
of memory in an unusual way. Rather than concatenating the segment register with the address register, as in most processors whose address space exceeds their register size, the 8086 shifts the 16-bit segment four bits left before adding it to the 16-bit offset (16×segment + offset), therefore producing a 20-bit external (or effective or physical) address from the 32-bit segment:offset pair. As a result, any external address could be referred to by up to 2
12 = 4096 different segment:offset pairs.
Although considered complicated and cumbersome by many programmers, this scheme also has advantages; a small program (less than 64 KB) can be loaded starting at a fixed offset (such as 0000) in its own segment, avoiding the need for
relocation, with at most 15 bytes of alignment waste.
Compilers for the 8086 family commonly support two types of
pointer, ''near'' and ''far''. Near pointers are 16-bit offsets implicitly associated with the program's code or data segment and so can be used only within parts of a program small enough to fit in one segment. Far pointers are 32-bit segment:offset pairs resolving to 20-bit external addresses. Some compilers also support ''huge'' pointers, which are like far pointers except that
pointer arithmetic on a huge pointer treats it as a linear 20-bit pointer, while pointer arithmetic on a far pointer
wraps around within its 16-bit offset without touching the segment part of the address.
To avoid the need to specify ''near'' and ''far'' on numerous pointers, data structures, and functions, compilers also support "memory models" which specify default pointer sizes. The ''tiny'' (max 64K), ''small'' (max 128K), ''compact'' (data > 64K), ''medium'' (code > 64K), ''large'' (code,data > 64K), and ''huge'' (individual arrays > 64K) models cover practical combinations of near, far, and huge pointers for code and data. The ''tiny'' model means that code and data are shared in a single segment, just as in most 8-bit based processors, and can be used to build ''
.com'' files for instance. Precompiled libraries often come in several versions compiled for different memory models.
According to Morse et al.,. the designers actually contemplated using an 8-bit shift (instead of 4-bit), in order to create a 16 MB physical address space. However, as this would have forced segments to begin on 256-byte boundaries, and 1 MB was considered very large for a microprocessor around 1976, the idea was dismissed. Also, there were not enough pins available on a low cost 40-pin package for the additional four address bus pins.
In principle, the address space of the x86 series ''could'' have been extended in later processors by increasing the shift value, as long as applications obtained their segments from the operating system and did not make assumptions about the equivalence of different segment:offset pairs.
[Some 80186 clones did change the shift value, but were never commonly used in desktop computers.] In practice the use of "huge" pointers and similar mechanisms was widespread and the flat 32-bit addressing made possible with the 32-bit offset registers in the 80386 eventually extended the limited addressing range in a more general way.
The instruction stream is fetched from memory as words and is addressed internally by the processor to the byte level as necessary. An instruction stream queuing mechanism allows up to 6 bytes of the instruction stream to be queued while waiting for decoding and execution. The queue acts as a First-In-First-Out (FIFO) buffer, from which the Execution Unit (EU) extracts instruction bytes as required. Whenever there is space for at least two bytes in the queue, the BIU will attempt a word fetch memory cycle. If the queue is empty (following a branch instruction, for example), the first byte into the queue immediately becomes available to the EU.
Porting older software
Small programs could ignore the segmentation and just use plain 16-bit addressing. This allows
8-bit software to be quite easily ported to the 8086. The authors of most
DOS implementations took advantage of this by providing an
Application Programming Interface
An application programming interface (API) is a connection between computers or between computer programs. It is a type of software Interface (computing), interface, offering a service to other pieces of software. A document or standard that des ...
very similar to
CP/M
CP/M, originally standing for Control Program/Monitor and later Control Program for Microcomputers, is a mass-market operating system created in 1974 for Intel 8080/Intel 8085, 85-based microcomputers by Gary Kildall of Digital Research, Dig ...
as well as including the simple ''.com'' executable file format, identical to CP/M. This was important when the 8086 and MS-DOS were new, because it allowed many existing CP/M (and other) applications to be quickly made available, greatly easing acceptance of the new platform.
Example code
The following 8086
assembly source code is for a subroutine named
_strtolower
that copies a null-terminated
ASCIIZ character string from one location to another, converting all alphabetic characters to lower case. The string is copied one byte (8-bit character) at a time.
The example code uses the BP (base pointer) register to establish a
call frame, an area on the stack that contains all of the parameters and local variables for the execution of the subroutine. This kind of
calling convention supports
reentrant and
recursive code and has been used by Algol-like languages since the late 1950s. A flat memory model is assumed, specifically, that the DS and ES segments address the same region of memory.
Performance

Although partly shadowed by other design choices in this particular chip, the
multiplexed address and
data buses limit performance slightly; transfers of 16-bit or 8-bit quantities are done in a four-clock memory access cycle, which is faster on 16-bit, although slower on 8-bit quantities, compared to many contemporary 8-bit based CPUs. As instructions vary from one to six bytes, fetch and execution are made
concurrent and decoupled into separate units (as it remains in today's x86 processors): The ''bus interface unit'' feeds the instruction stream to the ''execution unit'' through a 6-byte prefetch queue (a form of loosely coupled
pipelining), speeding up operations on
registers and
immediates, while memory operations became slower (four years later, this performance problem was fixed with the
80186 and
80286). However, the full (instead of partial) 16-bit architecture with a full width
ALU meant that 16-bit arithmetic instructions could now be performed with a single ALU cycle (instead of two, via internal carry, as in the 8080 and 8085), speeding up such instructions considerably. Combined with
orthogonalizations of operations versus
operand
In mathematics, an operand is the object of a mathematical operation, i.e., it is the object or quantity that is operated on.
Unknown operands in equalities of expressions can be found by equation solving.
Example
The following arithmetic expres ...
types and
addressing modes, as well as other enhancements, this made the performance gain over the 8080 or 8085 fairly significant, despite cases where the older chips may be faster (see below).
* EA = time to compute effective address, ranging from 5 to 12 cycles.
* Timings are best case, depending on prefetch status, instruction alignment, and other factors.
As can be seen from these tables, operations on registers and immediates were fast (between 2 and 4 cycles), while memory-operand instructions and jumps were quite slow; jumps took more cycles than on the simple
8080 and
8085, and the 8088 (used in the IBM PC) was additionally hampered by its narrower bus. The reasons why most memory related instructions were slow were threefold:
* Loosely coupled fetch and execution units are efficient for instruction prefetch, but not for jumps and random data access (without special measures).
* No dedicated address calculation adder was afforded; the microcode routines had to use the main ALU for this (although there was a dedicated ''segment'' + ''offset'' adder).
* The address and data buses were
multiplex
Multiplex may refer to:
Science and technology
* Multiplex communication, combining many signals into one transmission circuit or channel
** Multiplex (television), a group of digital television or radio channels that are combined for broadcast
* ...
ed, forcing a slightly longer (33~50%) bus cycle than in typical contemporary 8-bit processors.
However, memory access performance was drastically enhanced with Intel's next generation of 8086 family CPUs. The
80186 and
80286 both had dedicated address calculation hardware, saving many cycles, and the 80286 also had separate (non-multiplexed) address and data buses.
Floating point
The 8086/8088 could be connected to a mathematical coprocessor to add hardware/microcode-based
floating-point
In computing, floating-point arithmetic (FP) is arithmetic on subsets of real numbers formed by a ''significand'' (a Sign (mathematics), signed sequence of a fixed number of digits in some Radix, base) multiplied by an integer power of that ba ...
performance. The
Intel 8087
The Intel 8087, announced in 1980, was the first floating-point coprocessor for the 8086 line of microprocessors. The purpose of the chip was to speed up floating-point arithmetic operations, such as addition, subtraction, multiplication, div ...
was the standard math coprocessor for the 8086 and 8088, operating on 80-bit numbers. Manufacturers like
Cyrix
Cyrix Corporation was a microprocessor developer that was founded in 1988 in Richardson, Texas, as a specialist supplier of floating point units for 286 and 386 microprocessors. The company was founded by Tom Brightman and Jerry Rogers. Ter ...
(8087-compatible) and
Weitek (''not'' 8087-compatible) eventually came up with high-performance floating-point coprocessors that competed with the 8087.
Chip versions
The clock frequency was originally limited to 5 MHz,
[(IBM PC used 4.77 MHz, 4/3 the standard NTSC color burst frequency)] but the last versions in
HMOS were specified for 10 MHz. HMOS-III and
CMOS versions were manufactured for a long time (at least a while into the 1990s) for
embedded system
An embedded system is a specialized computer system—a combination of a computer processor, computer memory, and input/output peripheral devices—that has a dedicated function within a larger mechanical or electronic system. It is e ...
s, although its successor, the
80186/
80188 (which includes some on-chip peripherals), has been more popular for embedded use.
The 80C86, the CMOS version of the 8086, was used in many portable computers and embedded systems, including the
GridPad,
Toshiba T1200,
HP 110, and finally the 1998–1999
Lunar Prospector.
For the packaging, the Intel 8086 was available both in ceramic and plastic DIP packages.
File:Intel D8086 CS.jpg, A ceramic D8086 variant
File:Intel P8086.jpg, A plastic P8086 variant
List of Intel 8086
Derivatives and clones
Compatible—and, in many cases, enhanced—versions were manufactured by
Fujitsu,
Harris/
Intersil,
OKI,
Siemens,
Texas Instruments
Texas Instruments Incorporated (TI) is an American multinational semiconductor company headquartered in Dallas, Texas. It is one of the top 10 semiconductor companies worldwide based on sales volume. The company's focus is on developing analog ...
,
NEC,
Mitsubishi, and
AMD. For example, the
NEC V20 and
NEC V30 pair were hardware-compatible with the 8088 and 8086 even though NEC made original Intel clones μPD8088D and μPD8086D respectively, but incorporated the instruction set of the 80186 along with some (but not all) of the 80186 speed enhancements, providing a drop-in capability to upgrade both instruction set and processing speed without manufacturers having to modify their designs. Such relatively simple and low-power 8086-compatible processors in CMOS are still used in embedded systems.
The electronics industry of the
Soviet Union
The Union of Soviet Socialist Republics. (USSR), commonly known as the Soviet Union, was a List of former transcontinental countries#Since 1700, transcontinental country that spanned much of Eurasia from 1922 until Dissolution of the Soviet ...
was able to replicate the 8086 through . The resulting chip,
K1810VM86, was binary and pin-compatible with the 8086.
i8086 and i8088 were respectively the cores of the Soviet-made PC-compatible
EC1831 and
EC1832 desktops. (EC1831 is the EC identification of IZOT 1036C and EC1832 is the EC identification of IZOT 1037C, developed and manufactured in Bulgaria. EC stands for Единая Система.) However, the EC1831 computer (IZOT 1036C) had significant hardware differences from the IBM PC prototype. The EC1831 was the first PC-compatible computer with dynamic bus sizing (US Pat. No 4,831,514). Later some of the EC1831 principles were adopted in PS/2 (US Pat. No 5,548,786) and some other machines (UK Patent Application, Publication No. GB-A-2211325, Published June 28, 1989).
Image:KL USSR KP1810BM86.jpg, Soviet clone K1810VM86
Image:Oki 80c86a.jpg, OKI M80C86A QFP-56
Image:UPD8086D-2 NEC 1984year 19week JAPAN.JPG, NEC μPD8086D-2 (8 MHz) from the year 1984, week 19 JAPAN (clone of Intel D8086-2)
Image:KL AMD D8086.jpg, The AMD D8086
Support chips
*
Intel 8237: direct memory access (DMA) controller
*
Intel 8251: universal synchronous/asynchronous receiver/transmitter at 19.2 kbit/s
*
Intel 8253: programmable interval timer, 3x 16-bit max 10 MHz
*
Intel 8255: programmable peripheral interface, 3x 8-bit I/O pins used for printer connection etc.
*
Intel 8259: programmable interrupt controller
*
Intel 8279: keyboard/display controller, scans a keyboard matrix and display matrix like
7-seg
*
Intel 8282/
8283: 8-bit latch
*
Intel 8284: clock generator
*
Intel 8286/
8287: bidirectional 8-bit driver. In 1980 both Intel I8286/I8287 (industrial grade) version were available for US$16.25 in quantities of 100.
*
Intel 8288: bus controller
*
Intel 8289: bus arbiter
*
NEC μPD765 or Intel 8272A: floppy controller
Microcomputers using the 8086
* The Intel
Multibus-compatible
single-board computer ISBC 86/12 was announced in 1978.
* The
Xerox NoteTaker was one of the earliest
portable computer designs in 1978 and used three 8086 chips (as CPU, graphics processor, and I/O processor), but never entered commercial production.
*
Seattle Computer Products shipped
S-100 bus based 8086 systems (SCP200B) as early as November 1979.
* The Norwegian
Mycron 2000, introduced in 1980.
* One of the most influential microcomputers of all, the
IBM PC
The IBM Personal Computer (model 5150, commonly known as the IBM PC) is the first microcomputer released in the List of IBM Personal Computer models, IBM PC model line and the basis for the IBM PC compatible ''de facto'' standard. Released on ...
, used the
Intel 8088
The Intel 8088 ("''eighty-eighty-eight''", also called iAPX 88) microprocessor is a variant of the Intel 8086. Introduced on June 1, 1979, the 8088 has an eight-bit external data bus instead of the 16-bit bus of the 8086. The 16-bit registers ...
, a version of the 8086 with an 8-bit
data bus (as mentioned above).
* The first
Compaq Deskpro used an 8086 running at 7.16 MHz, but was compatible with add-in cards designed for the 4.77 MHz
IBM PC XT and could switch the CPU down to the lower speed (which also switched in a memory bus buffer to simulate the 8088's slower access) to avoid software timing issues.
* An 8 MHz 8086-2 was used in the
AT&T 6300 PC (built by
Olivetti, and known globally under several brands and model numbers), an IBM PC-compatible desktop microcomputer. The M24 / PC 6300 has IBM PC/XT compatible 8-bit expansion slots, but some of them have a proprietary extension providing the full 16-bit data bus of the 8086 CPU (similar in concept to the 16-bit slots of the
IBM PC AT, but different in the design details, and physically incompatible), and all system peripherals including the onboard video system also enjoy 16-bit data transfers. The later Olivetti M24SP featured an 8086-2 running at the full maximum 10 MHz.
* The
IBM PS/2
The Personal System/2 or PS/2 is IBM's second generation of personal computers. Released in 1987, it officially replaced the IBM Personal Computer, IBM PC, IBM Personal Computer XT, XT, IBM Personal Computer/AT, AT, and IBM PC Convertible, PC Co ...
models
25 and
30 were built with an 8 MHz 8086.
* The
Amstrad PC1512,
PC1640, PC2086, PC3086 and PC5086 all used 8086 CPUs at 8 MHz.
* The
NEC PC-9801.
* The
Tandy 1000 SL-series and RL machines used 9.47 MHz 8086 CPUs.
* The
IBM Displaywriter word processing machine
and the Wang Professional Computer, manufactured by
Wang Laboratories
Wang Laboratories, Inc., was an American computer company founded in 1951 by An Wang and G. Y. Chu. The company was successively headquartered in Cambridge, Massachusetts (1954–1963), Tewksbury, Massachusetts (1963–1976), Lowell, Massachuse ...
, also used the 8086.
*
NASA
The National Aeronautics and Space Administration (NASA ) is an independent agencies of the United States government, independent agency of the federal government of the United States, US federal government responsible for the United States ...
used original 8086 CPUs on equipment for ground-based maintenance of the
Space Shuttle Discovery
Space Shuttle ''Discovery'' (Orbiter Vehicle Designation: OV-103) is a retired American Space Shuttle orbiter. The spaceplane was one of the Space Shuttle orbiter, orbiters from NASA's Space Shuttle program and the third of five fully opera ...
until the end of the space shuttle program in 2011. This decision was made to prevent
software regression that might result from upgrading or from switching to imperfect clones.
* KAMAN Process and Area Radiation Monitors
[Kaman Tech. Manual]
* The
Tektronix
Tektronix, Inc., historically widely known as Tek, is an American company best known for manufacturing test and measurement devices such as oscilloscopes, logic analyzers, and video and mobile test protocol equipment. Originally an independent c ...
4170 ran
CP/M-86 and used an 8086
See also
*
Transistor count
*
iAPX, for the iAPX name
Notes
References
External links
Intel datasheetsList of 8086 CPUs and their clones at CPUworld.comMaximum Mode InterfaceArchived
from the original on July 21, 2011. Retrieved July 10, 2022.
(PDF
Portable document format (PDF), standardized as ISO 32000, is a file format developed by Adobe Inc., Adobe in 1992 to present documents, including text formatting and images, in a manner independent of application software, computer hardware, ...
document)
8086 program codes using emu8086 (Version 4.08) Emulator
*
*
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
**
{{Authority control
80086
16-bit microprocessors
Computer-related introductions in 1978
X86 microarchitectures