Jump to content

Intel 8086

From Wikipedia, the free encyclopedia
(Redirected from8086)
Intel 8086
A rare Intel C8086 processor in purple ceramic DIP package with side-brazed pins
General information
Launched1978
Discontinued1998[1]
Common manufacturer
Performance
Max.CPUclock rate5 MHz to 10 MHz
Data width16 bits
Address width20 bits
Architecture and classification
Technology node3 μm
Instruction setx86-16
Physical specifications
Transistors
Co-processorIntel 8087,Intel 8089
Package
Socket
Products, models, variants
Variant
History
PredecessorIntel 8085
Successors80186and80286(both of which were introduced in early 1982)
Support status
Unsupported

The8086[3](also callediAPX 86)[4]is a16-bitmicroprocessorchip designed byIntelbetween early 1976 and June 8, 1978, when it was released. TheIntel 8088,released July 1, 1979,[5]is a slightly modified chip with an external 8-bitdata bus(allowing the use of cheaper and fewer supportingICs),[note 1]and is notable as the processor used in the originalIBM PCdesign.

The 8086 gave rise to thex86architecture, 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 theIntel Core i7-8086K.[5]

History

[edit]

Background

[edit]

In 1972, Intel launched the8008,Intel's first 8-bit microprocessor.[note 2]It implemented aninstruction setdesigned byDatapoint Corporationwith programmableCRT terminalsin mind, which also proved to be fairly general-purpose. The device needed several additionalICsto 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 aDRAMmanufacturer at the time).

Two years later, Intel launched the8080,[note 3]employing the new 40-pinDIL packagesoriginally developed forcalculatorICs to enable a separate address bus. It has an extended instruction set that issource-compatible(notbinary compatible) with the 8008[6]and also includes some16-bitinstructions to make programming easier. The 8080 device was eventually replaced by thedepletion-load-based8085(1977), which sufficed with a single +5 V power supply instead of the three different operating voltages of earlier chips.[note 4]Other well known 8-bit microprocessors that emerged during these years areMotorola 6800(1974),General Instrument PIC16X(1975),MOS Technology 6502(1975),Zilog Z80(1976), andMotorola 6809(1978).

The first x86 design

[edit]
Intel 8086 CPU die image

The 8086 project started in May 1976 and was originally intended as a temporary substitute for the ambitious and delayediAPX 432project. It was an attempt to draw attention from the less-delayed 16-bit and32-bitprocessors of other manufacturers —Motorola,Zilog,andNational Semiconductor.

Whereas the 8086 was a 16-bit microprocessor, it used the samemicroarchitectureas Intel's 8-bit microprocessors (8008, 8080, and 8085). This allowedassembly languageprograms written in 8-bit toseamlessly migrate.[7]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 ofnested functionsin theALGOL-family of languages, includingPascalandPL/M.According to principal architectStephen P. Morse,this was a result of a more software-centric approach. Other enhancements includedmicrocodeinstructions for the multiply and divide assembly language instructions. Designers also anticipatedcoprocessors,such as8087and8089,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,[note 5]and as almost no CAD tools were used, four engineers and 12 layout people were simultaneously working on the chip.[note 6]The 8086 took a little more than two years from idea to working product, which was considered rather fast for a complex design in the 1970s

The 8086 was sequenced[note 7]using a mixture ofrandom logic[8]andmicrocodeand was implemented using depletion-load nMOS circuitry with approximately 20,000 activetransistors(29,000 counting allROMandPLAsites). It was soon moved to a new refined nMOS manufacturing process calledHMOS(for High performance MOS) that Intel originally developed for manufacturing of faststatic RAMproducts.[note 8]This was followed by HMOS-II, HMOS-III versions, and, eventually, a fully staticCMOSversion for battery powered devices, manufactured using Intel'sCHMOSprocesses.[note 9]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 microcodedso x86 programmers usually just used the bit shift instructions for multiplying and dividing instead.[citation needed]

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 byStephen P. Morsewith 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[note 10]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 theIntel 286and theIntel 386,all of which eventually became known as thex86family. (Another reference is that thePCI Vendor IDfor Intel devices is 8086h.)

Details

[edit]
The 8086 pin assignments in min and max mode

Buses and operation

[edit]

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 1MiBphysical address space (220= 1,048,576 x 1byte). This address space is addressed by means of internal memory "segmentation". The data bus ismultiplexedwith the address bus in order to fit all of the control lines into a standard 40-pindual in-line package.It provides a 16-bit I/O address bus, supporting 64KBof 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 the80386architecture introduced wider (32-bit) registers (the memory management hardware in the80286did not help in this regard, as its registers are still only 16 bits wide).

Hardware modes of 8086

[edit]

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 inminormaxmode. 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/MX) 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.[note 11]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

[edit]
Intel 8086 registers
19 18 17 16 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 (bit position)
Main registers
AH AL AX(primary accumulator)
0 0 0 0 BH BL BX(base, accumulator)
CH CL CX(counter, accumulator)
DH DL DX(accumulator, extended acc)
Index registers
0 0 0 0 SI SourceIndex
0 0 0 0 DI DestinationIndex
0 0 0 0 BP BasePointer
0 0 0 0 SP StackPointer
Program counter
0 0 0 0 IP InstructionPointer
Segment registers
CS 0 0 0 0 CodeSegment
DS 0 0 0 0 DataSegment
ES 0 0 0 0 ExtraSegment
SS 0 0 0 0 StackSegment
Status register
- - - - O D I T S Z - A - P - C Flags

The 8086 has eight more-or-less general 16-bitregisters(including thestack pointerbut 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 thedestination,while the other operand, thesource,can be eitherregisterorimmediate.A single memory location can also often be used as bothsourceanddestinationwhich, among other factors, further contributes to acode densitycomparable 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 contemporaryminicomputersand 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 thePDP-11,VAX,68000,32016,etc. On the other hand, being more regular than the rather minimalistic but ubiquitous 8-bit microprocessors such as the6502,6800,6809,8085,MCS-48,8051,and other contemporary accumulator-based machines, it is significantly easier to construct an efficientcode generatorfor 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 andPL/M;some of the more useful instructions arepushmem-op,andretsize,supporting the "Pascalcalling convention"directly. (Several others, such aspushimmedandenter,were added in the subsequent 80186, 80286, and 80386 processors.)

A 64 KB (one segment)stackgrowing towards lower addresses is supported inhardware;16-bit words are pushed onto the stack, and the top of the stack is pointed to by SS:SP. There are 256interrupts,which can be invoked by both hardware and software. The interrupts can cascade, using the stack to store thereturn addresses.

The 8086 has 64 K of 8-bit (or alternatively 32 K of 16-bit word)I/O portspace.

Flags

[edit]

The 8086 has a 16-bitflags 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), andOverflow flag(OF). Also referred to as the status word, the layout of the flags register is as follows:[9]

Bit 15-12 11 10 9 8 7 6 5 4 3 2 1 0
Flag OF DF IF TF SF ZF AF PF CF

Segmentation

[edit]

There are also four 16-bitsegmentregisters (see figure) that allow the 8086CPUto access onemegabyteof 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 only 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, each external address can be referred to by 212= 4096 different segment:offset pairs.

0110 1000 1000 01110000 Segment, 16 bits, shifted 4 bits left (or multiplied by 0x10)
+1011 0100 1010 1001 Offset, 16 bits
0111 0011 1101 0001 1001 Address, 20 bits

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 forrelocation,with at most 15 bytes of alignment waste.

Compilers for the 8086 family commonly support two types ofpointer,nearandfar.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 supporthugepointers, which are like far pointers except thatpointer arithmeticon a huge pointer treats it as a linear 20-bit pointer, while pointer arithmetic on a far pointerwraps aroundwithin its 16-bit offset without touching the segment part of the address.

To avoid the need to specifynearandfaron numerous pointers, data structures, and functions, compilers also support "memory models" which specify default pointer sizes. Thetiny(max 64K),small(max 128K),compact(data > 64K),medium(code > 64K),large(code,data > 64K), andhuge(individual arrays > 64K) models cover practical combinations of near, far, and huge pointers for code and data. Thetinymodel 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.comfiles for instance. Precompiled libraries often come in several versions compiled for different memory models.

According to Morse et al.,.[10]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 seriescouldhave 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.[note 12]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.[11]

Porting older software

[edit]

Small programs could ignore the segmentation and just use plain 16-bit addressing. This allows8-bitsoftware to be quite easily ported to the 8086. The authors of mostDOSimplementations took advantage of this by providing anApplication Programming Interfacevery similar toCP/Mas well as including the simple.comexecutable 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

[edit]

The following 8086assemblysource code is for a subroutine named_strtolowerthat copies a null-terminatedASCIIZcharacter 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.










0000
0000 55
0001 89 E5
0003 56
0004 57
0005 8B 75 06
0008 8B 7D 04
000B FC

000C AC
000D 3C 41
000F 7C 06
0011 3C 5A
0013 7F 02
0015 04 20
0017 AA
0018 08 C0
001A 75 F0

001C 5F
001D 5E
001E 5D
001F C3
001F
;_strtolower:
;Copy a null-terminated ASCII string, converting
;all alphabetic characters to lower case.
;ES=DS
;Entry stack parameters
;[SP+4] = src, Address of source string
;[SP+2] = dst, Address of target string
;[SP+0] = Return address
;
_strtolowerproc
pushbp;Set up the call frame
movbp,sp
pushsi
pushdi
movsi,[bp+6];Set SI = src (+2 due to push bp)
movdi,[bp+4];Set DI = dst
cld;string direction ascending

loop:lodsb;Load AL from [si], inc si
cmpal,'A';If AL < 'A',
jlcopy;Skip conversion
cmpal,'Z';If AL > 'Z',
jgcopy;Skip conversion
addal,'a'-'A';Convert AL to lowercase
copy:stosb;Store AL to [di], inc di
oral,al;If AL <> 0,
jneloop;Repeat the loop

done:popdi;restore di and si
popsi
popbp;Restore the prev call frame
ret;Return to caller
endproc

The example code uses the BP (base pointer) register to establish acall frame,an area on the stack that contains all of the parameters and local variables for the execution of the subroutine. This kind ofcalling conventionsupportsreentrantandrecursivecode 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

[edit]
Simplified block diagram over Intel 8088 (a variant of 8086); 1=main & index registers; 2=segment registers and IP; 3=address adder; 4=internal address bus; 5=instruction queue; 6=control unit (very simplified!); 7=bus interface; 8=internal databus; 9=ALU; 10/11/12=external address/data/control bus.

Although partly shadowed by other design choices in this particular chip, themultiplexedaddress anddata buseslimit 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 madeconcurrentand decoupled into separate units (as it remains in today's x86 processors): Thebus interface unitfeeds the instruction stream to theexecution unitthrough a 6-byte prefetch queue (a form of loosely coupledpipelining), speeding up operations onregistersandimmediates,while memory operations became slower (four years later, this performance problem was fixed with the80186and80286). However, the full (instead of partial) 16-bit architecture with a full widthALUmeant 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 withorthogonalizationsof operations versusoperandtypes andaddressing 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).

Execution times for typical instructions (in clock cycles)[12]
instruction register-register register immediate register-memory memory-register memory-immediate
mov 2 4 8+EA 9+EA 10+EA
ALU 3 4 9+EA, 16+EA, 17+EA
jump register≥ 11;label≥ 15;condition,label≥ 16
integer multiply 70~160 (depending on operanddataas well as size)includingany EA
integer divide 80~190 (depending on operanddataas well as size)includingany EA
  • 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 simple8080and8085,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 dedicatedsegment+offsetadder).
  • The address and data buses weremultiplexed,forcing a slightly longer (33~50%) bus cycle than in typical contemporary 8-bit processors.[dubiousdiscuss]

However, memory access performance was drastically enhanced with Intel's next generation of 8086 family CPUs. The80186and80286both had dedicated address calculation hardware, saving many cycles, and the 80286 also had separate (non-multiplexed) address and data buses.

Floating point

[edit]

The 8086/8088 could be connected to a mathematical coprocessor to add hardware/microcode-basedfloating-pointperformance. TheIntel 8087was the standard math coprocessor for the 8086 and 8088, operating on 80-bit numbers. Manufacturers likeCyrix(8087-compatible) andWeitek(not8087-compatible) eventually came up with high-performance floating-point coprocessors that competed with the 8087.

Chip versions

[edit]

The clock frequency was originally limited to 5 MHz,[note 13]but the last versions inHMOSwere specified for 10 MHz. HMOS-III andCMOSversions were manufactured for a long time (at least a while into the 1990s) forembedded systems,although its successor, the80186/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 theGRiDPad,Toshiba T1200,HP 110,and finally the 1998–1999Lunar Prospector.

For the packaging, the Intel 8086 was available both in ceramic and plastic DIP packages.

List of Intel 8086

[edit]
Model number Frequency Technology Temperature range Package Date of release Price (USD)[list2 1]
8086 5 MHz[13] HMOS 0 °C to 70 °C[14] June 8, 1978[15] $86.65[16]
8086-1 10 MHz HMOS II Commercial
8086-2 8 MHz[13] HMOS II Commercial January/February 1980[17] $200[17][18]
8086-4 4 MHz[13] HMOS Commercial $72.50[list2 2][19]
I8086 5 MHz HMOS Industrial −40 °C to +85 °C[14] May/June 1980[14] $173.25[14]
M8086 5 MHz HMOS Military grade −55 °C to +125 °C[20]
80C86[21] CMOS 44 PinPLCC[list2 3][22]
  1. ^In quantity of 100.
  2. ^Price reduced by 21% from USD $99.00, no information in quantity value listed.
  3. ^Sampling Q4 1985

Derivatives and clones

[edit]

Compatible—and, in many cases, enhanced—versions were manufactured byFujitsu,[23]Harris/Intersil,OKI,Siemens,Texas Instruments,NEC,Mitsubishi,andAMD.For example, theNEC V20andNEC V30pair 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 theSoviet Unionwas able to replicate the 8086 throughbothindustrial espionageand reverse engineering[citation needed].The resulting chip,K1810VM86,was binary and pin-compatible with the 8086.

i8086 and i8088 were respectively the cores of the Soviet-made PC-compatibleEC1831andEC1832desktops. (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).


Support chips

[edit]

Microcomputers using the 8086

[edit]
  • The IntelMultibus-compatiblesingle-board computerISBC 86/12 was announced in 1978.[25]
  • TheXerox NoteTakerwas one of the earliestportable computerdesigns in 1978 and used three 8086 chips (as CPU, graphics processor, and I/O processor), but never entered commercial production.
  • Seattle Computer ProductsshippedS-100 busbased 8086 systems (SCP200B) as early as November 1979.
  • The NorwegianMycron2000, introduced in 1980.
  • One of the most influential microcomputers of all, theIBM PC,used theIntel 8088,a version of the 8086 with an 8-bitdata bus(as mentioned above).
  • The firstCompaq Deskproused an 8086 running at 7.16 MHz, but was compatible with add-in cards designed for the 4.77 MHzIBM PC XTand 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 theAT&T 6300 PC(built byOlivetti,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 theIBM 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.
  • TheIBM PS/2models25and30were built with an 8 MHz 8086.
  • TheAmstrad PC1512,PC1640,PC2086, PC3086 and PC5086 all used 8086 CPUs at 8 MHz.
  • TheNEC PC-9801.
  • TheTandy 1000SL-series and RL machines used 9.47 MHz 8086 CPUs.
  • TheIBM Displaywriterword processing machine[26]and the Wang Professional Computer, manufactured byWang Laboratories,also used the 8086.
  • NASAused original 8086 CPUs on equipment for ground-based maintenance of theSpace Shuttle Discoveryuntil the end of the space shuttle program in 2011. This decision was made to preventsoftware regressionthat might result from upgrading or from switching to imperfect clones.[27]
  • KAMAN Process and Area Radiation Monitors[28]
  • TheTektronix4170 ranCP/M-86and used an 80864170 Local Graphics Processing Unit Instruction Manual(PDF)

See also

[edit]

Notes

[edit]
  1. ^Fewer TTL buffers, latches, multiplexers (although the amount of TTLlogicwas not drastically reduced). It also permits the use of cheap 8080-family ICs, where the 8254 CTC,8255PIO, 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.
  2. ^using enhancement loadPMOS logic(requiring 14V,achieving TTL compatibility by having VCCat +5 V and VDDat −9 V).
  3. ^Using non-saturated enhancement-loadNMOS logic(demanding a higher gate voltage for the load-transistor gates).
  4. ^Made possible with depletion-load nMOS logic (the 8085 was later made using HMOS processing, just like the 8086).
  5. ^Rev.0 of the instruction set and architecture was ready in about three months, according to Morse.
  6. ^Usingrubylith,light boards, rulers, electric erasers, and adigitizer(according to Jenny Hernandez, member of the 8086 design team, in a statement made on Intel's webpage for its 25th birthday).
  7. ^8086 used less microcode than many competitors' designs, such as the MC68000 and others
  8. ^Fast static RAMs in MOS technology (as fast as bipolar RAMs) was an important product for Intel during this period.
  9. ^CHMOS is Intel's name for CMOS circuits manufactured using processing steps very similar toHMOS.
  10. ^Other members of the design team were Peter A.Stoll and Jenny Hernandez.
  11. ^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.)
  12. ^Some 80186 clones did change the shift value, but were never commonly used in desktop computers.
  13. ^(IBM PC used 4.77 MHz, 4/3 the standard NTSCcolor burstfrequency)

References

[edit]
  1. ^"The Life Cycle of a CPU".www.cpushack.com.
  2. ^Lewnes, Ann, "The Intel386 Architecture Here to Stay", Intel Corporation, Microcomputer Solutions, July/August 1989, page 2
  3. ^"Microprocessor Hall of Fame".Intel. Archived fromthe originalon 2007-07-06.Retrieved2007-08-11.
  4. ^iAPX 286 Programmer's Reference(PDF).Intel. 1983. p. 1-1.
  5. ^ab"Happy Birthday, 8086: Limited-Edition 8th Gen Intel Core i7-8086K Delivers Top Gaming Experience".Intel.
  6. ^"8080 family".CPU World.
  7. ^Scanlon, Leo J. (1988).8086/8088/80286 assembly language.Brady Books. p.12.ISBN978-0-13-246919-7.[…] The8086is software-compatible with the8080at the assembly-language level. […]
  8. ^Geiger, Randall L.; Allen, Phillip E.; Strader, Noel R. (1990). "Random Logic vs. Structured Logic Forms".VLSI design techniques for analog and digital circuits.McGraw-Hill. p. 779.ISBN0-07-023253-9.— Illustration of use of "random" describing CPU control logic
  9. ^Intel Corporation (1983).IAPX 86, 88, 186, and 188 user's manual: programmer's reference.Intel. pp. 3–5.ISBN978-0835930352.OCLC11091251.
  10. ^Morse, Stephen P.; Ravenel, Bruce W; Mazor, Stanley; Pohlman, William B. (October 1980)."Intel Microprocessors: 8008 to 8086".IEEE Computer.13(10): 42–60.doi:10.1109/MC.1980.1653375.S2CID206445851.
  11. ^"8086 16-BIT HMOS Processor datasheet"(PDF).Intel.Retrieved26 November2021.
  12. ^Microsoft Macro Assembler 5.0 Reference Manual.Microsoft Corporation. 1987.Timings and encodings in this manual are used with permission of Intel and come from the following publications: Intel Corporation. iAPX 86, 88, 186 and 188 User's Manual, Programmer's Reference, Santa Clara, Calif. 1986.(Similarly for iAPX 286, 80386, 80387.)
  13. ^abcThe 8086 Family User's Manual.Intel Corporation. October 1979. p. B-1.OCLC65699372.
  14. ^abcdeIntel Corporation (May–June 1980). "8086 Available for industrial environment".Intel Preview(Special Issue: 16-Bit Solutions): 29.OCLC803251993.
  15. ^"Intel® Microprocessor Quick Reference Guide - Year".www.intel.com.
  16. ^Intel Corporation (May–June 1980). "The 8086 Family: Concepts and realities".Intel Preview(Special Issue: 16-Bit Solutions): 19.ISSN1041-8547.OCLC10331599.
  17. ^abIntel Corporation (January–February 1980). "New Products: Faster 8086 provides 60% more performance".Intel Preview:22.
  18. ^Intel Corporation (May–June 1980). "New 8086 family products boost processor performance by 50 percent".Intel Preview(Special Issue: 16-Bit Solutions): 17.
  19. ^Intel Corporation (May–June 1979). "Microcomputer Components: New price reductions and production improvements make the popular 8086 microprocessor even more attractive".Intel Preview:11.
  20. ^Intel Corporation (August 1981).Intel iAPX86, 88 User's manual.Intel Corporation. p. B-25.ISBN0835930165.OCLC8459750.
  21. ^Intel Corporation, "NewsBit: Intel Licenses Oki on CMOS Version of Several Products", Solutions, July/August 1984, Page 1.
  22. ^Ashborn, Jim; "Advanced Packaging: A Little Goes A Long Way", Intel Corporation, Solutions, January/February 1986, Page 2
  23. ^Intel Corporation, "NewsBits: Second Source News", Solutions, January/February 1985, Page 1
  24. ^"The floppy controller evolution | OS/2 Museum".2011-05-26.Retrieved2016-05-12.In the original IBM PC (1981) and PC/XT (1983), the FDC was physically located on a separate diskette adapter card. The FDC itself was a NEC μPD765A or a compatible part, such as the Intel 8272A.
  25. ^"Intel Adds 16-Bit Single Board".Computerworld.Vol. XII, no. 50. December 11, 1978. p. 86.ISSN0010-4841.
  26. ^Zachmann, Mark (August 23, 1982)."Flaws in IBM Personal Computer frustrate critic".InfoWorld.Vol. 4, no. 33. pp. 57–58.ISSN0199-6649.the IBM Displaywriter is noticeably more expensive than other industrial micros that use the 8086.
  27. ^"For Old Parts, NASA Boldly Goes... on eBay".New York Times.May 12, 2002.
  28. ^Kaman Tech. Manual
[edit]