Intel i860, eller Intel 80860 (kodenavn: N10), var en superskalærRISC-prosessor som ble lansert av Intel den 27. februar 1989. Den var verdens første RISC-prosessor med mer enn 1 million transistorer. Den ble først produsert med 1.0 ɥmCHMOS-IV, og fra 6. juni 1991 med 0.8 ɥm CHMOS-V. Intel i860 ble lansert i hastigheter på 20, 33 og 40 MHz. Den 6. juni 1991 kom det også en utgave på 50 MHz.
Intel i860 ble lansert som en 64-biter mikroprosessor, men var en hybrid mellom 32-biter og 64-biter. Den var også en hybrid mellom RISC og VLIW.
Intel i860 hadde en intern 64-biter grafikkenhet som utførte SIMD-instruksjoner. Denne oppbygningen påvirket SIMD-instruksjonene MMX som ble lansert i Intel Pentium MMX i 1998 og Streaming SIMD Extensions som ble lansert i Pentium III i 1999.
Mikroprosessoren ble lansert 27. februar 1989 som en 64-biter mikroprosessor,[1][2] men var i virkeligheten en hybrid mellom en 32-biter og 64-biter mikroprosessor. Dens dataarkitektur var endog en hybrid mellom RISC og VLIW. Den var verdens første RISC-prosessor med mer enn 1 million transistorer,[3] og ble produsert med 1.0 ɥm CHMOS-IV.
Den var sammensatt av 9 komponenter, og hadde følgende karakteristika:[4]
4 Kb integrert hurtigminne for instruksjoner, med 64-biter buss (32 biter til heltallsenheten og 32 biter til flyttallsenheten)
8 Kb integrert hurtigminne for data, med 224-biter buss (32-biter til heltallsenheten, 128-biter til flyttallsenheten og 64-biter til minnekontrolleren)
Intel i860 var Intels første RISC-prosessor.[1] Den var også Intels første hyperskalære mikroprosessor. Den var treveis hyperskalær og kunne utføre en heltalls- og to flyttallsinstruksjoner samtidig.[1] Alternativt kunne den utføre en heltalls- og to SIMD-instruksjoner samtidig. Ved 40 MHz hadde den derfor en teoretisk ytelse på 40 MIPS og 80 MFLOPS.[1]
Samme år, den 12. september 1989, lanserte Intel mikroprosessoren Intel i960CA som også var en hyperskalær RISC-mikroprosessor. Den var toveis hyperskalær og kunne utføre en heltalls- og en flyttallsinstruksjon samtidig. Intel i960 ble stort sett brukt som mikrokontroller i RAIDharddisker, såvel som for laserskrivere og blekkstråleskrivere, mens Intel i860 var konstruert for bruk i superdatamaskiner og arbeidsstasjoner.
Samme år, den 10. april 1989, lanserte også Intel CISC-prosessoren Intel 80486. Mens forgjengeren Intel 80386 hadde støtte for et eksternt hurtigminne, hadde Intel 80486 et integrert hurtigminne på 8 Kb. Dette var delt mellom instruksjoner og data.
Intel i860 gikk et steg videre og hadde to adskilte hurtigminner for henholdsvis instruksjoner og data.
Intel 80860 XP
Den 6. juni 1991 ble andre generasjon lansert, under navnet Intel i860 XP (kodenavn: N11).[5] Den var produsert med 0.8 ɥm CHMOS-V,[6] og bestod av 2,55 millioner transistorer.[6] Den første generasjon av mikroprosessoren ble samtidig retrospektivt omdøpt til Intel i860 XR.
Intel i860 levde ikke opp til sin teoretiske ytelse. Mikroprosessoren var konstruert ut fra den filosofi at kompleksiteten legges i kompilatoren, ikke maskinvaren. Dette ble vanskeligere enn antatt. Selv om prosessoren teoretisk kunne yte 80 MFLOPs ved 40 MHz, hadde de fleste kompilatorer problemer med å generere kode som førte til en ytelse på 10 MFLOPs.
Liksom den første SPARC-prosessoren (1985), hadde Intel i860 og i860 XP en 4-trinns «pipe», der instruksjoner ble utført i 4 etapper:
Hent en instruksjon fra minnet
Dekod instruksjonenen
Utfør instruksjonen
Skriv resultatet i minnet
Mens én instruksjon hentes, ble en annen dekodet, en tredje utført, mens resultatet fra en fjerde ble returnert til minnet. Bearbeidelsen av 4 instruksjoner samtidig, gjorde det mulig for i860 å utføre en heltallsinstruksjon per klokkepuls. Ved desimaltallsberegninger kunne prosessoren utføre to instruksjoner per klokkepuls.
Slik kunne Intel i860 yte 40 MIPS og 80 MFLOPS ved 40 MHz.
Dette var imidlertid avhengig av at programmerere skrev god kode. Dårlig programmering kunne forsinkelse utførelsen. Assemblerkoden nedenfor, for i860, illustrerer dårlig programmering.
ld.l 0(r17), r5 ; last inn et tall fra minnet i register 5
addu r5, r6, r7 ; adder innholdet i registrene 5 og 6
; og flytt resultatet til register 7
or r8, r9, r10 ; legg resultatet av r8 OR r9 i register 10
1
2
3
4
5
6
7
HENT
DEKOD
UTFØR
SKRIV
HENT
DEKOD
UTFØR
SKRIV
HENT
DEKOD
UTFØR
SKRIV
I kolonne 4 ovenfor forsinkes utførelsen av to instruksjoner.
ld.l 0(r17), r5 ; last inn et tall fra minnet i register 5
or r8, r9, r10 ; legg resultatet av r8 OR r9 i register 10
addu r5, r6, r7 ; adder innholdet i registrene 5 og 6
; og flytt resultatet til register 7
Koden ovenfor medfører ingen forsinkelse.
1
2
3
4
5
6
HENT
DEKOD
UTFØR
LES I CACHE
SKRIV
HENT
DEKOD
UTFØR
SKRIV
HENT
DEKOD
UTFØR
SKRIV
Et annet problem med i860 var mangelen på en hurtig håndering av kontekst-skifte. Mikroprosessoren hadde flere parallelle pipes (for heltallsenheten og desimaltalls-enhetene), og et avbrudd kunne medføre at samtlige måtte lastes opp på nytt. Slike avbrudd kunne forsinke utførelsen av instruksjoner med mellom 62 og 2000 klokkepulser.
Bruksområder
I begynnelsen ble i860 brukt av et lite antall svært store datamaskiner, deriblant iPSC/860 ved Los Alamos National Laboratory. Etterhvert som kompilatorene ble forbedret, og kunne generere mer optimal kode for mikroprosessoren, var i860 utkonkurrert ytelsesmessig av andre RISC-prosessorer.
I enkelte arbeidsstasjoner ble i860 brukt som grafikk-akselrator. Et eksempel var NeXTdimension, som kjørte en nedskalert versjon av det distribuerte operativsystemet Mach. Et annet eksempel var SGI Onyx Reality Engine 2.
Microsoft hadde i 1989 som intensjon å basere operativsystemet Windows NT på i860-baserte datamaskiner. «N10-operativsystemet», «N-Ten», «NT» og «Dazzle», var interne navn på et operativsystem for i860. Planen ble senere forkastet, og forkortelsen «NT» ble omdøpt fra å bety N-Ten til å bety New Technology.[9]
I slutten av 1990-årene ble både i860 og i960 erstattet av XScale.
Custer, Helen; Cutler, David N. (1992). Inside Windows NT. Microsoft Press, 1. januar 1992. ISBN1-55615-481-X. ISBN 978-1-55615-481-2.CS1-vedlikehold: Flere navn: forfatterliste (link)
Perlmutter, David; Kagan, Michael (1991). The i860 XP - Second Generation of the i860(PDF). Intel Israel, august 1991. Arkivert fra originalen(PDF) 20. august 2018. Besøkt 14. april 2019.CS1-vedlikehold: Flere navn: forfatterliste (link)