MIPS (arkitektur)

Den aktuella versionen av sidan har ännu inte granskats av erfarna bidragsgivare och kan skilja sig väsentligt från versionen som granskades den 2 januari 2022; kontroller kräver 5 redigeringar .
MIPS
Utvecklaren MIPS Technologies Inc.
Lite djup 64 (32→64)
Presenteras 1985
Arkitektur RISC
Sorts register-register
SK-kodning fast
Övergångsimplementering jämfört med två register
Byte-ordning Bi-endian (big→bi)
Tillägg MDMX, MIPS-3D, MIPS16e, MIPS MT
Register
generell mening 31 (R0=0)
Verklig 32 (för dubbelt används registerpar i 32-bitarsversioner av processorn)
 Mediafiler på Wikimedia Commons

MIPS (förkortning av namnet på motsvarande Stanford University- projekt .  Microprocessor without Interlocked Pipeline Stages [1] ) är ett system med instruktioner och mikroprocessorarkitekturer utvecklat av MIPS Computer Systems (för närvarande Wave Computing [2] ) i enlighet med RISC- processordesignen koncept (det vill säga för processorer med en förenklad instruktionsuppsättning). Tidiga processormodeller hade ett 32-bitars maskinord , senare 64-bitarsversioner dök upp. Det finns många processormodifieringar, inklusive MIPS I, MIPS II, MIPS III, MIPS IV, MIPS V, MIPS32 och MIPS64, varav MIPS32 (för 32-bitars implementering) och MIPS64 (för 64-bitars implementering) är giltiga. MIPS32 och MIPS64 definierar både en uppsättning kontrollregister och en uppsättning instruktioner.

Det finns flera instruktionsuppsättningar: MIPS32, MIPS64, microMIPS och nanoMIPS. Dessutom finns ytterligare instruktionsuppsättningar och processormodeller tillgängliga, till exempel MIPS-3D, som inkluderar en uppsättning SIMD -instruktioner för bearbetning av flyttal, designade för att lösa enkla 3D- problem, MDMX (MaDMaX) - med ännu bredare möjligheter - en SIMD-instruktionsuppsättning och användande av 64-bitars flyttalsregister för att arbeta med heltal, MIPS16e, som komprimerar instruktionsströmmen för att minska mängden minne som upptas av program, och MIPS MT, som ger ett flertrådigt bearbetningsläge.

MIPS-arkitektur studeras ofta i kursprogrammet "Datorarkitektur" vid universitet och tekniska lyceum. Dessa processorer påverkade avsevärt senare RISC-arkitekturer, särskilt Alpha .

För närvarande används olika implementeringar av MIPS främst i inbyggda system, såsom smartphones , routrar , gateways , och fram till 2010-talet i spelkonsoler som Sony PlayStation 2 och Sony PlayStation Portable . Fram till slutet av 2006 användes de även i SGI -datorer . I slutet av 1980- och 1990-talen användes denna arkitektur i stor utsträckning av många företag, bland dem Digital Equipment Corporation , NEC , Pyramid Technology, Siemens Nixdorf och Tandem Computers . Från mitten till slutet av 1990-talet var en av tre mikroprocessorer på marknaden en MIPS-processor.

Historik

Grundare av RISC

1981 började ett team ledd av John L. Hennessy från Stanford University arbetet med ett projekt som heter MIPS. Huvudtanken var att öka processorprestanda genom att använda en utökad pipeline . Konceptet med att använda pipeline som en kärnteknik var känt långt tidigare (till exempel i IBM 801 ), men det utnyttjade inte sin fulla potential. CPU :n innehåller flera speciella underenheter såsom instruktionsavkodare, heltals ALU (arithmetic logic unit), laddnings-/lagringsenheter (minneshantering), etc. I en traditionell icke-optimerad implementering bör en enstaka instruktion i ett program vara (nästan alltid) slutförd innan en annan startar; medan i en pipelined arkitektur kan sekventiella instruktioner exekveras parallellt. Till exempel, när en matematisk instruktion läggs in i ett flyttalsblock, kan minnesladdnings-/lagringsblocket anropa nästa instruktion samtidigt.

Ett av de största hindren för att använda pipeline var det faktum att vissa instruktioner, såsom division, tar mycket längre tid att utföra, och som ett resultat måste CPU:n vänta innan nästa instruktion skickas till pipeline. Den enda lösningen på detta problem är att använda en serie lås för att tillåta vissa stadier av rörledningen att visa att de är upptagna och, i det här fallet, avbryta kommandon uppströms i tråden. Hennessy-gruppen såg dessa lås som en enorm prestandabarriär, eftersom det var nödvändigt att komma åt alla CPU-moduler, vilket tar extra tid och begränsar klockhastigheten. Huvudaspekten av MIPS-designen var att passa in varje underfas av varje instruktion, inklusive cachning, i en cykel, och på så sätt undvika behovet av lås och tillåta endast en cykel att passera till pipelinen.

Även om en sådan implementering skulle eliminera några mycket användbara operationer som multiplikation och division, är det tydligt att systemets övergripande prestanda skulle förbättras avsevärt eftersom chipsen skulle kunna köras med högre klockhastigheter. Att uppnå hög hastighet med lås skulle vara svårt, eftersom tiden som krävs för att sätta låsen är proportionell mot klockfrekvensen, som i sin tur beror på kristallens storlek. Det är därför uteslutningen av ovannämnda verksamhet har blivit en omtvistad fråga.

En annan skillnad mellan MIPS-arkitekturen och konkurrerande Berkeley-arkitekturer är Berkeley - RISC :s förmåga att hantera subrutinsamtal. För att öka prestandan för en sådan allmän uppgift använde Berkeley-RISC en teknik som kallas ett registerfönster , som ändå begränsade det maximala djupet för flernivåsamtal. Varje subrutinsamtal krävde sin egen uppsättning register, vilket gjorde det nödvändigt att utöka antalet. Medan hårdvaruimplementeringen av denna mekanism upptog ytterligare utrymme i CPU-chippet. Men Hennessy trodde att en mer "grundlig" kompilator kunde hitta gratis register för att skicka parametrar till funktionen, och att bara en ökning av antalet register inte bara kunde förenkla denna uppgift, utan också öka prestandan för alla operationer. Därför beslutades det att överge denna teknik i MIPS.

MIPS-arkitekturen var i vissa avseenden den mest typiska för RISC . För att spara bitar i instruktionskoden har RISC minskat antalet instruktioner att koda. I MIPS, av 32 bitar av ett ord, används endast 6 för huvudkoden, och resten kan innehålla antingen en enda 26-bitars hoppadress eller upp till 5 fält som ställer in från 1 till 3 register + registerskiftlängd . Det finns ett antal andra format, till exempel när 2 register ställs in direkt av ett dedikerat 16-bitars fält, etc. Denna distribution gjorde det möjligt för processorn att ladda instruktionen och den data den behövde i en maskincykel, medan den var i äldre arkitekturer (som inte var RISC ), till exempel, såsom MOS Technology 6502, krävde separata cykler för att ladda huvudkoden och data.

Detta var en av de stora prestandaförbättringarna som erbjuds av RISC. Andra arkitekturer har dock uppnått liknande hastigheter på andra sätt (som CPU-köer).

Första hårdvaruimplementeringen

1984, övertygad om den kommersiella efterfrågan på hans design, lämnade Hennessy Stanford och grundade MIPS Computer Systems. 1985 släpptes den första kommersiella implementeringen av MIPS-mikroprocessorn, R2000, slutförd 1988 och kallades R3000. Dessa 32-bitars processorer utgjorde grunden för företagets produktlinje på 1980-talet och användes främst i SG-serien av arbetsstationer. Nya kommersiella projekt var inte i linje med Stanfords forskning, eftersom nästan alla lås utfördes i hårdvara, och multiplikations- och divisionsoperationerna var fullt implementerade.

1991 introducerades den först som en 64-bitars MIPS-mikroprocessor - modell R4000. R4000 har en utökad TLB där posten inte bara innehåller den virtuella adressen utan även den virtuella adressutrymmesidentifieraren. En sådan buffert eliminerar de huvudsakliga prestandaproblemen för mikrokärnan, som är ganska långsam i konkurrerande arkitekturer ( Pentium , PowerPC , Alpha ) på grund av behovet av att spola TLB under frekventa kontextväxlingar.

MIPS hade dock ekonomiska svårigheter med att få ut processorer på marknaden. Projektet var så viktigt för SGI (en av dåtidens få stora köpare av MIPS) att SGI 1992 köpte rättigheterna till företaget med en garanti för att designen av mikroprocessorer inte skulle förändras. Efter att ha blivit ett dotterbolag fick MIPS Computer Systems namnet MIPS Technologies.

Licensierad arkitektur

I början av 1990 började MIPS licensiera sina konstruktioner till tredje part. Idén var lycklig på grund av kärnans enkelhet, som hittade många applikationer där mycket mindre effektiva CISC- arkitekturer tidigare användes , med samma antal och samma pris på kretsar (dessa två kriterier är nära besläktade: priset på en CPU, som regel beror på antalet kretsar och kontakter). Sun Microsystems gjorde ett liknande försök att licensiera SPARC - kärnor, men Sun hade inte så stor tur. I slutet av 1990-talet hade MIPS blivit det viktigaste företaget inom inbyggda processorer, och 1997 gjorde 48 miljoner försändelser av MIPS-baserade processorer det möjligt för RISC-arkitekturer att ersätta den populära 68k-processorfamiljen. MIPS var så populärt att SGI 1998 överförde en del av tillgångarna till MIPS Technologies. Hittills kommer hälften av MIPS intäkter från utvecklingslicenser, och merparten av den andra hälften kommer från kontrakt för att utveckla kärnor för produktion av tredje part.

1999 formaliserade MIPS sina licenssystem kring två huvuddesigner - 32-bitars MIPS32 (baserat på MIPS II med några ytterligare funktioner för MIPS III, MIPS IV och MIPS V) och 64-bitars MIPS64 (baserat på MIPS V). MIPS64 licensierades av var och en av NEC , Toshiba och SiByte (sedan förvärvad av Broadcom) omedelbart efter lanseringen. De fick snart sällskap av Philips , LSI Logic och IDT. Framgång följde på framgång, och idag är MIPS-processorer en av de mest eftertraktade produkterna på marknaden för enheter av datortyp (PDA:er, set-top-boxar, etc.), tillsammans med andra utvecklare som förgäves försöker ersätta dem.

Några år efter att MIPS-arkitekturen blev licensierad började den attrahera fler och fler nya processorutvecklingsföretag. Det första sådana företaget var Quantum Effect Devices (se nästa avsnitt). Utvecklingsteamet som satte ihop MIPS R4300i grundade SandCraft, som försåg NEC med den nya R5432-processorn och, lite senare, modellerade R71000, en av de första anpassade processorerna för den inbyggda marknaden. Grundarteamet på DEC StrongARM delades så småningom upp i två nya MIPS-baserade processorföretag: SiByte, som gjorde SB-1250, ett av de första högpresterande chipsystemen baserade på MIPS ( SOC ) och Alchemy Semiconductor (senare förvärvad av AMD) , som producerade Au-1000 SOC för lågeffektapplikationer. Lexra använde en MIPS-liknande arkitektur och lade till DSP för ljudchipmarknaden och stöd för multistreaming för nätverksmarknaden. Eftersom Lexra inte köpte en licens för MIPS bröt det snart ut stämningar mellan de två företagen. Den första löstes snabbt in efter att Lexra lovade att inte marknadsföra sina processorer som liknar MIPS. Den andra processen (om MIPS-patentet 4814976 för bearbetning av den ojusterade minnesåtkomstinstruktionen) var mer utdragen och påverkade båda företagens verksamhet negativt, och efter att den slutförts utfärdade MIPS Technologies en gratis licens till Lexra och betalade en stor monetär kompensation.

Efter denna utveckling gick två företag in på marknaden som specialiserade sig på att skapa flerkärniga enheter med MIPS-arkitekturen. Raza Microelectronics Corporation köpte ut produktionslinjen från det mindre framgångsrika SandCraft och började sedan producera åttakärniga enheter för telekommunikations- och nätverksmarknaden. Cavium Networks, ursprungligen en leverantör av processorskydd, började också producera åtta- och senare 32-kärniga arkitekturer för samma marknader. Båda företagen designade själva kärnorna och licensierade bara designen istället för att köpa färdiga MIPS-processordesigner.

Förlust av PC-marknaden

Tillverkare som har byggt arbetsstationer med MIPS-mikroprocessorer inkluderar SGI , MIPS Computer Systems, Inc., Whitechapel Workstations, Olivetti, Siemens-Nixdorf, Acer, Digital Equipment Corporation , NEC och DeskStation. Operativsystem portade till MIPS-arkitekturen inkluderar SGI :s IRIX , Microsofts Windows NT (upp till version 4.0) , Windows CE , Linux , UNIX ( System V och BSD ), SINIX, QNX och företagets eget RISC OSoperativsystem

Det fanns spekulationer i början av 1990-talet om att MIPS, tillsammans med andra kraftfulla RISC-processorer, snart skulle gå om Intels IA32 - arkitektur . Detta underlättades av stöd för de två första versionerna av Windows NT för Alpha , MIPS och PowerPC av Microsoft , och, i mindre utsträckning, arkitekturerna Clipper och SPARC. Men så snart Intel släppte de senaste versionerna av Pentium- familjen av processorer slutade Microsoft Windows NT v4.0 att stödja allt utom Alpha och Intel. Efter SGI:s beslut att gå över till Itanium- och IA32-arkitekturerna upphörde MIPS-processorer nästan helt att användas i persondatorer.

Embedded Market

På 1990-talet användes MIPS-arkitekturen allmänt på den inbyggda marknaden : för nätverk, telekommunikation, videospel, spelkonsoler, skrivare, digitala set-top-boxar, digitala TV-apparater, xDSL- och kabelmodem och handdatorer.

Den låga strömförbrukningen och temperaturegenskaperna hos inbyggda MIPS-arkitekturer och det breda utbudet av interna funktioner gör denna mikroprocessor universell för många enheter.

Syntetiserbara kärnor för den inbäddade marknaden

Under de senaste åren har de flesta av de teknologier som används i olika generationer av MIPS föreslagits som IP-kärnor (byggstenar) för inbäddade processorimplementationer. Dessutom föreslås båda typerna av kärnor - baserade på 32 och 64 bitar, kända som 4K och 6K. Sådana kärnor kan kombineras med andra byggstenar som FPU:er , SIMD- system , olika I/O-enheter, etc.

De en gång kommersiellt framgångsrika MIPS-kärnorna har nu hittat konsument- och industriella tillämpningar. Dessa kärnor finns i de nya Cisco- , Linksys- , ZyXEL- och MikroTik -routrarna , kabel- och ADSL - modem, smartkort , laserskrivarmekanismer, digitala set-top-boxar, robotar, handdatorer, Sony PlayStation 2 och Sony PlayStation Portable. Men i mobiltelefon- och handdatorapplikationer misslyckades MIPS med att undanröja den konkurrerande ARM- arkitekturen som var fast etablerad där .

MIPS-baserade processorer inkluderar: IDT RC32438; ATI Hilleon; Alchemy Au1000, 1100, 1200 ; Broadcom Sentry5; RMI XLR7xx, Cavium Octeon CN30xx, CN31xx, CN36xx, CN38xx och CN5xxx; Infineon Technologies EasyPort, Amazon, Donau, ADM5120, WildPass, INCA-IP, INCA-IP2; Microchip Technology PIC32 ; NEC EMMA och EMMA2, NEC VR4181A, VR4121, VR4122, VR4181A, VR5432, VR5500; Oak Technologies Generation; PMC-Sierra RM11200; QuickLogic QuickMIPS ESP; Toshiba Donau, Toshiba TMPR492x, TX4925, TX9956, TX7901; KOMDIV-32 , KOMDIV-64 ; Multicore .

MIPS superdatorer

En av de mest intressanta tillämpningarna av MIPS-arkitekturen är deras användning i superdatorer med flera processorer. I början av 1990-talet fokuserade Silicon Graphics ( SGI ) sin verksamhet bort från grafikterminaler och in på marknaden för högpresterande datorer. Framgången med företagets tidiga satsningar på serversystem (nämligen Challenge-serien baserad på R4400, R8000 och R10000) motiverade SGI att skapa ett mycket kraftfullare system. Genom att använda R10000 kunde företaget designa Origin 2000-systemet, som så småningom kunde utökas till 1024 processorer med sin egen cc-NUMA-interconnect (NUMAlink). Senare skapade Origin 2000 ett nytt system - Origin 3000, som kom ut med samma maximala 1024 processorer, men som använde R14000 och R16000 chips under utveckling med en frekvens på upp till 700 MHz. Men 2005, när SGI fattade det strategiska beslutet att flytta till Intel IA-64-arkitekturen, avbröts MIPS-baserade superdatorer.

2007 introducerade SiCortex Corporation en ny personlig superdator med flera processorer baserad på MIPS-arkitekturen. Dess utveckling baserades på MIPS64 och högpresterande sammankoppling med Kautz graftopologi .  Detta system är extremt effektivt och beräkningskraftigt. Dess unika aspekt är en flerkärnig bearbetningsnod som integrerar sex MIPS64-kärnor, en minneskontrollomkopplare, DMA-intersystemkommunikation, ett 1Gb LAN och PCI Express- kontroller. Och allt detta på ett enda chip som förbrukar 10 watt effekt, men som maximalt utför 6 miljarder flyttalsoperationer per sekund. Den mest kraftfulla konfigurationen av en sådan superdator är versionen SC5832, som består av 972 noder (totalt 5832 MIPS64-kärnor) och utför 8,2 biljoner flyttalsoperationer per sekund.

Loongson återgår till anpassning

Loongson , i hopp om att kringgå MIPS-patentet, släppte sin arkitektur, som var helt lik utvecklingen av MIPS Technologies och stöddes av Linux . Eftersom produktionen av Loongson-processorer var billigare kunde MIPS återupplivas på persondatormarknaden inför Loongson. (Senare köpte Loongson en licens för MIPS - se huvudartikel)

MIPS-baserade processorer används också i netbooks från iUnika, Bestlink, Lemote och Golden Delicious Computers.

MIPS IV

MIPS IV  - den fjärde generationen av arkitekturen, är en utökad version av MIPS III och är kompatibel med alla befintliga MIPS-modeller. Den första implementeringen av MIPS IV introducerades 1994 under namnet R8000 . MIPS IV ingår:

MIPS V

MIPS V, den femte versionen av arkitekturen, introducerades den 21 oktober 1996 vid 1996 Microprocessor Forum . Denna modell har utformats för att förbättra prestandan för 3D-grafikapplikationer . I mitten av 1990-talet var de flesta icke-inbäddade MIPS-mikroprocessorer grafikterminaler från SGI . Utvecklingen av MIPS V kompletterades av heltals multimediatillägg MDMX (MIPS Digital Media Extensions), som introducerades samma dag som MIPS V.

Implementeringar av MIPS V implementerades aldrig. 1997 introducerade SGI mikroprocessorer kallade "H1" ("Beast") och "H2" ("Capitan"), som skulle tillverkas 1999. Men de slogs snart samman, och så småningom 1998 lades dessa projekt ner.

MIPS V lade till en ny datatyp, PS (par-singel), som är två dubbelprecisions (32-bitars) flyttalsnummer lagrade i ett 64-bitars flyttalsregister. För att arbeta med denna datatyp i SIMD -läge , tillkom olika varianter av aritmetik, jämförande operationer på flyttalsnummer, samt en villkorlig hoppinstruktion. Det finns nya instruktioner för att ladda, omkonfigurera och konvertera PS-data. Det är den första arkitekturen som kan implementera flyttalsbearbetning i SIMD -läge med tillgängliga resurser.

MIPS-processorfamilj

Den första kommersiella MIPS-mikroprocessorn var R2000, som introducerades 1985. Den implementerade operationerna multiplikation och division, som utfördes i flera cykler. Multiplikations- och divisionsenheten var inte tätt integrerad i processorkärnan, även om den var placerad på samma chip; av denna anledning utökades instruktionssystemet med instruktioner för att ladda resultaten av multiplikation och uppdelning i allmänna register, dessa instruktioner blockerade pipelinen.

R2000-mikroprocessorn kunde laddas både i big-endian-läge och i little-endian-läge, innehöll 32 32-bitars generella register. Liksom AMD 29000- och Alpha-processorerna hade R2000-mikroprocessorn inte ett separat tillståndsflaggaregister, eftersom utvecklarna ansåg att det var en potentiell flaskhals. Programräknaren är inte direkt åtkomlig.

R2000-mikroprocessorn stödde anslutning av upp till fyra samprocessorer, varav en är inbyggd och ger undantagshantering, samt minneshantering (MMU). Vid behov kan R2010-chippet, en aritmetisk samprocessor, anslutas som en annan samprocessor, som innehöll trettiotvå 32-bitarsregister som kunde användas som sexton 64-bitars dubbelprecisionsregister. Nästa i familjen var R3000 , som dök upp 1988. Den innehöll en datacache på 64 KB (R2000 - 32 KB). Dessutom gav R3000 cachekoherens när den kördes i multiprocessorkonfigurationer. Trots att stödet för R3000 multiprocessor har ett antal brister har flera fungerande multiprocessorsystem skapats baserade på R3000. När det gäller R2000 skapades för R3000 en aritmetisk samprocessor i form av en separat VLSI: R3010. R3000-mikroprocessorn var den första kommersiellt framgångsrika MIPS-processorn, med över en miljon tillverkade processorer. En accelererad version av R3000 som körde på 40 MHz, kallad R3000A, uppnådde 32 VUPs (VAX Unit of Performance). En vidareutveckling av R3000A, R3051-mikroprocessorn som arbetar på 33,8688 MHz, användes i Sony PlayStation-spelkonsolen. Andra tillverkare introducerade också processorer som är kompatibla med R3000A: Performance Semiconductor utvecklade R3400, medan IDT skapade R3500, som båda hade en integrerad R3010 matematisk coprocessor. Toshibas R3900 var det första system-on-a-chip som använde MIPS-arkitekturen; detta chip användes i en bärbar dator med Windows CE. En strålningstolerant variant av R3000 med en integrerad R3010 för rymdfarkoster utvecklades och fick namnet Mongoose-V .

R4000-serien, som släpptes 1991, utökade MIPS-processorer till 64 bitar. (MIPS Technology var det första företaget att släppa processorer med 64-bitars arkitektur) R4000 består av 1,3 miljoner transistorer, har en inbyggd datacache och instruktionscache (båda 8 KB vardera). I denna processor fördubblas den externa klockan på 50 MHz och den interna klockan 100 MHz. R4400-processorn är baserad på R4000, består av 2,2 miljoner transistorer, har en inbyggd datacache och en instruktionscache (båda 16 KB vardera) och en intern klockfrekvens på 150 MHz. Instruktionsuppsättningen för dessa processorer (MIPS II-specifikationen) har utökats med 64-bitars flyttalsladdnings- och skrivinstruktioner, enkel och dubbel precision kvadratrotsinstruktioner, villkorliga avbrottsinstruktioner och atomoperationer som är nödvändiga för att stödja multiprocessorkonfigurationer. R4000- och R4400-processorerna har 64-bitars databussar och 64-bitars register.

MIPS, nu en division av SGI som heter MTI, utvecklade de billiga R4200-processorerna som fungerade som grunden för framtida (ännu billigare) R4300i. Ett derivat av denna processor, NEC VR4300, användes i Nintendo 64-spelkonsolerna.

Quantum Effect Devices (QED), ett oberoende företag grundat av MIPS-utvecklarna, utvecklade processorerna R4600 Orion, R4700 Orion, R4650 och R5000. Om R4000 ökade klockhastigheten, men offrade mängden cacheminne, ägnade QED stor uppmärksamhet åt cacheminnets kapacitet (som kan nås på bara 2 cykler) och den effektiva användningen av kristallytan. R4600- och R4700-processorerna användes i lågkostnadsversioner av SGI Indy-arbetsstationen, såväl som i tidiga Cisco-routrar (baserade på MIPS), som 36x0- och 7x00-serien. R4650-mikroprocessorn användes i WebTV set-top-boxar (för närvarande Microsoft TV). I R5000 FPU var schemaläggning med flyttal (enkel precision) mer flexibel än i R4000, och som ett resultat hade de R5000-baserade SGI Indys-arbetsstationerna bättre grafikprestanda än en R4400 med samma klockhastighet och grafikhårdvara. För att understryka förbättringen efter att ha kombinerat R5000 och det gamla grafikkortet, gav SGI det ett nytt namn. Lite senare utvecklade QED familjen RM7000 och RM9000 processorer för nätverks- och laserskrivarmarknaden. I augusti 2000 förvärvades QED av halvledartillverkaren PMC-Sierra, och den senare fortsatte att investera i MIPS-arkitekturer. RM7000-processorn inkluderade 256 KB L2-cache på chipet och en kontroller för ytterligare L3-cache. RM9xx0-processorer skapades - en familj av SOC-enheter som inkluderar sådana perifera komponenter (på den norra bron) som: en minneskontroller, en PCI-kontroller, en Ethernet-kontroller, såväl som snabba I/O-enheter (till exempel en hög- prestationsbuss som HyperTransport).

R8000 (introducerad 1994) var den första MIPS superskalära arkitekturen som kunde ha 2 heltal (eller flyttal) och 2 minnesåtkomstinstruktioner per cykel. Denna design använde 6 scheman: en enhet för heltalsinstruktioner (16 KB för instruktioner och 16 KB för datacache), för flyttalsinstruktioner, tre sekundära RAM-cache-beskrivningar (två för sekundär cacheåtkomst + en för bussspårning ), samt en ASIC-cachekontroller. Arkitekturen har två helt pipelinerade multiplicerings-enheter (dubbel precision) som kan strömma data till 4MB off-chip sekundär cache. I mitten av 1990-talet lanserade R8000-processorerna POWER Challenge SGI-servrarna och blev senare tillgängliga på POWER Indigo2-arbetsstationerna. Även om prestandan för denna FPU var den mest lämpade för forskare, lyckades dess begränsade heltalsprestanda och höga pris inte locka de flesta användare, så R8000 fanns på marknaden i bara ett år, och till och med nu kan den knappast hittas.

1995 släpptes R10000 [3] . Denna processor erbjöds i en design med ett chip, körde med högre klockhastighet än R8000, och inkluderade även en stor (32 KB) primär data- och instruktionscache. Det var också superskalärt, men denna stora innovation var felaktig. Men även med en enklare FPU har den avsevärt förbättrade heltalsprestanda, lägre pris och högre lagringstäthet gjort R10000 till det föredragna valet för de flesta användare.

Alla senare konstruktioner var baserade på R10000- kärnan . R12000 använde en 0,25 mikron tillverkningsprocess för att göra chippet mindre och uppnå högre klockhastigheter. Den reviderade R14000 hade en högre klockhastighet förutom att stödja DDR SRAM för off-chip cache. Följande släpptes R16000 och R16000A, vars klockfrekvens också ökades; de hade ytterligare L1-cache inbyggd i sig, och deras produktion krävde mindre dies än tidigare.

Andra medlemmar i MIPS-familjen inkluderar R6000, en ESL-implementering av Bipolar Integrated Technology. R6000 tillhör MIPS II-processorgenerationen. Dess TLB och cache-enhet skiljer sig markant från andra medlemmar i den här familjen. R6000 levererade inte de utlovade fördelarna, och även om den visade sig vara något användbar för Control Data-datorer, försvann den snabbt från den vanliga marknaden.

MIPS mikroprocessorer
Modell Frekvens (MHz) År Utvecklingsteknik (µm) Transistorer (miljoner) Kristallstorlek (mm²) Antal stift Effekt, W) Spänning (V) Datacache (KB) Instruktionscache (KB) Nivå 2 cache Nivå 3 cache
R2000 8-16.67 1985 2.0 0,11 ? ? ? ? 32 64 NEJ NEJ
R3000 12-40 1988 1.2 0,11 66,12 145 fyra ? 64 64 0-256 KB Extern NEJ
R4000 100 1991 0,8 1,35 213 179 femton 5 åtta åtta 1 MB extern NEJ
R4400 100-250 1992 0,6 2.3 186 179 femton 5 16 16 1-4 MB extern NEJ
R4600 100-133 1994 0,64 2.2 77 179 4.6 5 16 16 512 KB extern NEJ
R4700 133 1996 ? ? ? 179 ? ? 16 16 Extern NEJ
R5000 150-200 1996 0,35 3.7 84 223 tio 3.3 32 32 1 MB extern NEJ
R8000 75-90 1994 0,7 2.6 299 591+591 trettio 3.3 16 16 4 MB extern NEJ
R10 000 150-250 1996 0,35, 0,25 6.7 299 599 trettio 3.3 32 32 512 KB—16 MB Externt NEJ
R12 000 270-400 1998 0,25, 0,18 6.9 204 600 tjugo fyra 32 32 512 KB—16 MB Externt NEJ
RM7000 250-600 1998 0,25, 0,18, 0,13 arton 91 304 10, 6, 3 3,3, 2,5, 1,5 16 16 256 KB internt 1 MB extern
R14 000 500-600 2001 0,13 7.2 204 527 17 ? 32 32 512 KB—16 MB Externt NEJ
R16 000 700-1000 2002 0,11 ? ? ? tjugo ? 64 64 512 KB—16 MB Externt NEJ
R24K 750+ 2003 65 nm ? 0,83 ? ? ? 64 64 4-16 MB extern NEJ

MIPS I instruktionsformat

Instruktioner är indelade i tre typer: R, I och J. Varje instruktion börjar med en 6-bitars kod. Förutom kod definierar instruktioner av R-typ tre register, ett registerskiftstorleksområde och ett funktionsområde; Instruktioner av I-typ definierar två register och ett omedelbart värde; Instruktioner av J-typ består av en opkod och en 26-bitars grenadress.

Följande är en tabell över användningen av de tre instruktionsformaten i kärnarkitekturen:

Sorts −31− format (i bitar) −0−
R kod (6) rs(5) rt(5) rd(5) skit (5) funktion (6)
jag kod (6) rs(5) rt(5) direkt (16)
J kod (6) adress (26)

Sammanställningsspråk MIPS

Dessa monteringsspråksinstruktioner har en direkt hårdvaruimplementering, i motsats till pseudo-instruktioner, som översätts till riktiga sammansatta instruktioner före montering.

Heltalsoperationer

MIPS har 32 register för heltalsoperationer. För att utföra aritmetiska beräkningar måste uppgifterna finnas i register. Register $0 lagrar alltid 0, och register $1 är reserverat för montering (för att hålla pseudo-instruktioner och stora konstanter). Tabellen nedan visar vilka bitar som motsvarar vilka delar av instruktionen. Ett bindestreck (-) indikerar ett neutralt tillstånd.

Kategori namn Instruktionssyntax Menande Format/Kod/Funktion Anteckningar/Kodning
Aritmetisk Lägg till lägg till $d,$s,$t $d = $s + $t R 0 20 16 Lägger till två register, avbryter vid spill
000000ss sssttttt ddddd --- --100000
Lägg till osignerad lägg till $d,$s,$t $d = $s + $t R 0 21 16 Som ovan, men ignorerar spill
000000ss sssttttt ddddd --- --100001
Subtrahera sub $d,$s,$t $d = $s − $t R 0 22 16 Subtraherar två register, utför ett spillavbrott
000000ss sssttttt ddddd --- --100010
subtrahera osignerad subu $d,$s,$t $d = $s − $t R 0 23 16 Som ovan, men ignorerar spill
000000ss sssttttt ddddd000 00100011
Lägg till omedelbart lägg till $t,$s,C $t = $s + C (signerad) jag 8 16 - Används för att lägga till teckenkonstanter (även för att kopiera ett register till ett annat: addi $1, $2, 0), utför ett spillavbrott
001000ss sssttttt CCCCCCCC CCCCCCCC
Lägg till omedelbart osignerad addiu $t,$s,C $t = $s + C (signerad) jag 9 16 - som ovan, men ignorerar spill, C förblir signerad
001001ss sssttttt CCCCCCCC CCCCCCCC
Multiplicera mult $s,$t LO = (($s * $t) << 32) >> 32;
HI = ($s * $t) >> 32;
R 0 18 16 Multiplicerar två register och skriver 64-bitarsresultatet till två speciella minnesfält, LO och HI. På samma sätt kan du skriva resultatet av operationen i formen: (int HI,int LO) = (64-bitar) $s * $t. Se mfhi och mflo för tillgång till LO- och HI-registren.
Dela upp div $s, $t LO = $s / $t HI = $s % $t R 0 1A16 _ Delar ett register med ett annat och skriver 32-bitarsresultatet till LO och resten till HI [4] .
Dela osignerad divu $s, $t LO = $s / $t HI = $s % $t R 0 1B 16 Delar ett register med ett annat och skriver 32-bitarsresultatet till LO och resten till HI.
Dataöverföring Ladda dubbelord ld$t,C($s) $t = Minne[$s + C] jag 23 16 - laddar ett dubbelord från: MEM[$s+C] och nästa 7 byte till $t och nästa register.
ladda ord lw $t,C($s) $t = Minne[$s + C] jag 23 16 - laddar ord från: MEM[$s+C] och nästa 3 byte.
Ladda halvord h $t,C($s) $t = Minne[$s + C] (signerat) jag 21 16 - laddar halvord från: MEM[$s+C] och nästa byte. Skylten är förlängd till fallets bredd.
Ladda halvord osignerat lhu $t,C($s) $t = Minne[$s + C] (osignerat) jag 25 16 - Som ovan, men utan skyltförlängning.
ladda byte lb $t,C($s) $t = Minne[$s + C] (signerat) jag 20 16 - laddar byte från: MEM[$s+C].
Ladda byte osignerad lbu $t,C($s) $t = Minne[$s + C] (osignerat) jag 24 16 - Som ovan, men utan skyltförlängning.
lagra dubbla ord sd $t,C($s) Minne[$s + C] = $t jag - lagrar två ordtyper från $t och nästa register i: MEM[$s+C] och nästa 7 byte. Ordningen på operanderna kan vara förvirrande.
lagra ord sw $t,C($s) Minne[$s + C] = $t jag 2B16 _ - lagrar ordet i: MEM[$s+C] och nästa 3 byte. Ordningen på operanderna kan vara förvirrande.
Förvara hälften sh $t,C($s) Minne[$s + C] = $t jag 29 16 - sparar den första halvan av registret (halvord) till: MEM[$s+C] och nästa byte.
Lagra byte sb $t,C($s) Minne[$s + C] = $t jag 28 16 - sparar den första fjärdedelen av ett register (byte) till: MEM[$s+C].
Ladda övre omedelbart lui $t,C $t = C << 16 jag F 16 - Laddar en 16-bitars operand i de högre 16 bitarna i det angivna registret. Maximalt värde för konstanten 2 16 −1
Flytta från högt mfhi$d $d = HI R 0 10 16 Placerar värdet från HI i ett register. Använd inte multiplicera och dividera instruktionerna i mfhi-instruktionen (denna åtgärd är inte definierad på grund av MIPS-pipeline).
Flytta från lågt mflo $d $d = LO R 0 12 16 Placerar värdet från LO i ett register. Använd inte multiplicera och dividera instruktioner i en mflo-instruktion (denna åtgärd är inte definierad på grund av MIPS-pipeline).
Flytta från kontrollregistret mfcZ $t, $s $t = Coprocessor[Z].ControlRegister[$s] R 0 Flyttar ett 4-byte-värde från Z-kontrollregistersamprocessorn till ett allmänt register. Skyltförlängning.
Flytta till kontrollregistret mtcZ $t, $s Coprocessor[Z].ControlRegister[$s] = $t R 0 Flyttar ett 4-byte-värde från det allmänna registret till Z-kontrollregistrets samprocessor. Skyltförlängning.
logisk Och och $d,$s,$t $d = $s & $t R 0 24 16 bitvis konjunktion
000000ss sssttttt ddddd --- --100100
Och omedelbart andi $t,$s,C $t = $s & C jag C 16 - 001100ss sssttttt CCCCCCCC CCCCCCCC
Eller eller $d,$s,$t $d = $s | $t R 0 25 16 Bitvis disjunktion
Eller omedelbart eller $t,$s,C $t = $s | C jag D16 _ -
Exklusivt eller xor $d,$s,$t $d = $s ^ $t R 0 26 16
Inte heller inte heller $d,$s,$t $d = ~ ($s | $t) R 0 27 16 Bitvis inte heller
Ställ in på mindre än slt $d,$s,$t $d = ($s < $t) R 0 2A 16 Kontrollerar om ett register är mindre än ett annat.
Ställ in på mindre än omedelbart slti $t,$s,C $t = ($s < C) jag En 16 - Kontrollerar om ett register är mindre än en konstant.
bitskifte Växla vänster logiskt sll $t,$s,C $t = $s << C R 0 0 skiftar C-bitar åt vänster (multiplicerar med två potenser )
Växla höger logiskt srl $t,$s,C $t = $s >> C R 0 2 16 skiftar C-bitar åt höger (delar med två potenser ). Observera att denna instruktion fungerar som tvås komplementdivision endast om värdet är positivt.
Skift höger aritmetik sra $t,$s,C R 0 3 16 skiftar C-bitar - (delar i två komplement binär kod)
Villkorlig förgrening Gren på lika beq $s,$t,C om ($s == $t) gå till PC+4+4 °C jag 4 16 - Hoppar till instruktionen på angiven adress om de två registren är lika.
000100ss sssttttt CCCCCCCC CCCCCCCC
Gren på inte lika bne $s,$t,C om ($s != $t) gå till PC+4+4 °C jag 5 16 - Hoppar till instruktionen på den angivna adressen om de två registren inte är lika.
Ovillkorligt hopp Hoppa j C PC = PC+4[31:28] . C*4 J 2 16 - Utför ett ovillkorligt hopp till instruktionen på den angivna adressen.
hoppa register jr$s goto adress $s R 0 8 16 Hoppar till adressen som finns i det angivna registret.
hoppa och länka jal C $31 = PC + 8; PC = PC+4[31:28] . C*4 J 3 16 - Som en procedur - används för att anropa en subrutin, register $31 tar emot och returnerar en adress; avkastningen från subrutinen kostar 31 $. Returadressen kommer att vara PC + 8, inte PC + 4, på grund av användningen av fördröjningsplatsen (fördröjningsslot): alla greninstruktioner i arkitekturen (före introduktionen av nya MIPS32 / MIPS64 instruktioner 2014) föregås alltid av exekveringen av instruktionen efter den och först därefter den faktiska övergången. Detta gjorde det möjligt att ladda pipelinen jämnare - medan övergångsinstruktionen hämtade instruktionen vid övergångsadressen, stod processorn inte i viloläge, utan utförde instruktionen efter den, vilket dock medför svårigheten att läsa och korrekt förstå assembler-kod och kräver att kompilatorer tar hänsyn till.

Obs: I MIPS assembly-språkkod kan förskjutningen för förgreningsinstruktioner representeras av markeringar någon annanstans i koden.

Obs: Det finns inget motsvarande kommando för "kopiera till register" (ladda ned omedelbart); detta kan göras med funktionerna addi (lägg till omedelbart) eller ori (eller omedelbart) med register $0. Till exempel, både addi $1, $0, 100 och ori $1, $0, 100 laddar båda $1 med värdet 100.

Operationer på flyttalsnummer

MIPS har 32 flyttalsregister. Registren är sammankopplade med 2 för dubbelprecisionsberäkningar. Udda register kan inte användas för aritmetik eller förgrening, de kan endast delvis indikera dubbel precision i ett par register.

Kategori namn Instruktionssyntax Menande Format/Kod/Funktion Anteckningar/Kodning
Aritmetisk FP lägg till singel add.s $x,$y,$z $x = $y + $z Flyttalstillägg (enkel precision)
FP subtrahera singel sub.s $x,$y,$z $x = $y - $z Flytpunktssubtraktion (enkel precision)
FP multiplicera singel mul.s $x,$y,$z $x = $y * $z Flyttalsmultiplikation (enkel precision)
FP dela singel div.s $x,$y,$z $x = $y / $z Flytpunktsdelning (enkel precision)
FP lägg till dubbelt add.d $x,$y,$z $x = $y + $z Flytpunktstillägg (dubbel precision)
FP subtrahera dubbelt sub.d $x,$y,$z $x = $y - $z Flytpunktssubtraktion (dubbel precision)
FP multiplicera dubbelt mul.d $x,$y,$z $x = $y * $z Flyttalsmultiplikation (dubbel precision)
FP dela dubbelt div.d $x,$y,$z $x = $y / $z Flytpunktsdelning (dubbel precision)
Dataöverföring Ladda ordbehandlare lwcZ $x,CONST($y) Coprocessor[Z].DataRegister[$x] = Minne[$y + CONST] jag Laddar 4 byte typord från: MEM[$2+CONST] i samprocessorns dataregister. Skyltförlängning.
Lagra ordbehandlare swcZ $x,CONST($y) Minne[$y + CONST] = Coprocessor[Z].DataRegister[$x] jag Skriver 4 byte från samprocessorns dataregister till MEM[$2+CONST]. Skyltförlängning.
hjärngymnastik FP jämför singel (eq, ne, lt, le, gt, ge) c.lt.s $f2,$f4 if ($f2 < $f4) cond=1; annat kond=0 Jämfört med instruktioner med mindre än flyttal. enda precision.
FP jämför dubbel (eq, ne, lt, le, gt, ge) c.lt.d $f2,$f4 if ($f2 < $f4) cond=1; annat kond=0 Jämfört med instruktioner med mindre än flyttal. Dubbel precision.
förgrening gren på FP sant bc1t 100 om (cond == 1) gå till PC+4+100 om formatet är FP utförs en förgrening.
gren på FP falsk bc1f 100 om (cond == 0) gå till PC+4+100 om formatet inte är FP görs en gren.

Pseudo-instruktioner

Dessa instruktioner accepteras av MIPS assemblerspråk, men de är inte verkliga. Samlaren översätter dem till faktiska instruktionssekvenser.

namn Instruktionssyntax Översättning till en vanlig instruktion menande
Ladda adress la $1, LabelAddr lui $1, LabelAddr[31:16]; eller $1,$1, LabelAddr[15:0] $1 = Adressmarkering
Ladda omedelbart li$1, IMMED[31:0] lui $1, IMMED[31:16]; eller $1, $1, IMMED[15:0] $1 = 32-bitars direktvärde
Filial om större än bgt $rs,$rt,Label slt $at,$rt,$rs; bne $at,$noll,Label if(R[rs]>R[rt]) PC=Etikett
Filial om mindre än blt $rs,$rt,Label slt $at,$rs,$rt; bne $at,$noll,Label if(R[rs]<R[rt]) PC=Etikett
Gren om större än eller lika bge etc. if(R[rs]>=R[rt]) PC=Etikett
Filial om mindre än eller lika ble if(R[rs]<=R[rt]) PC=Etikett
Filial om större än osignerad bgtu if(R[rs]=>R[rt]) PC=Etikett
Gren om större än noll bgtz if(R[rs]>0) PC=Etikett
Multiplicerar och returnerar endast de första 32 bitarna mul $1, $2, $3 mult $2, $3; $1 $1 = $2 * $3

Flera andra viktiga instruktioner

Användning av översättningsregistret

Hårdvaruarkitekturen definierar följande kriterier:

Detta är de enda begränsningarna som hårdvaruarkitekturen sätter på användningen av register för allmänna ändamål.

Olika MIPS-enheter implementerar speciella anropskonventioner som begränsar användningen av register. Samtalskonventioner stöds fullt ut av mjukvarupaketet, men krävs inte av hårdvaran.

Register
namn siffra Ansökan behöver du boka?
$noll $0 lagrar alltid 0 N/A
$at $1 tillfälligt register för monteringsspråk NEJ
$v0-$v1 $2—$3 funktions- och uttrycksvärden NEJ
$a0—$a3 $4—$7 funktionsargument NEJ
$t0—$t7 $8-$15 temporär NEJ
$s0—$s7 $16—$23 lagrade tillfälliga värden JA
$t8—$t9 $24—25 $ temporär NEJ
$k0—$k1 $26—$27 reserverad för operativsystemets kärna NEJ
$gp 28 USD global pekare JA
$sp 29 USD stackpekare JA
$fp 30 USD rampekare JA
$ra 31 USD returadress N/A

Skyddade register (enligt konvention) kan inte modifieras av system eller procedur (funktion) anrop. Till exempel måste $s-register lagras i stacken genom proceduren som kommer att använda dem; konstanterna inkrementeras till $sp- och $fp-registren, och i slutet av proceduren minskas registren igen. Det motsatta exemplet är $ra-registret, som automatiskt ändras när det anropas av någon funktion. $t-register måste sparas av programmet innan någon procedur anropas (om programmet behöver data som tas emot efter samtalet).

Emulatorer

Bland de öppna virtuella plattformarna finns en gratis OVP-sim-emulator tillgänglig för icke-kommersiellt bruk, som är ett bibliotek av processor- och plattformsmodeller, samt API:er som låter användaren designa sina egna modeller. Modellbiblioteket är en öppen resurs skriven i C och inkluderar 4K, 24K och 34K MIPS kärnor. Dessa modeller skapas och underhålls av Imperas, som har samarbetat med MIPS Technologies för att testa emulatorn och markera den som MIPS-verifierad. Exempelplattformar baserade på MIPS inkluderar både själva hårdvaran och plattformar för att ladda omodifierade binära Linux-mappningar. Dessa emulatorplattformar är effektiva för lärande och är också tillgängliga, gratis och lätta att använda. OVPsim, utvecklat och underhållet av Imperas, körs med hög hastighet (hundratals miljoner instruktioner per sekund), och är tillämpbart för att beskriva flerkärniga arkitekturer.

Det finns en gratis tillgänglig MIPS32-emulator (tidigare versioner kunde bara emulera R2000/R3000) släppt under namnet SPIM för pedagogiskt bruk. EduMIPS64 är en plattformsoberoende grafisk MIPS64-processoremulator skriven i Java /Swing. Den stöder många MIPS64 ISA och låter användaren visuellt se vad som händer i pipelinen när CPU:n kör ett assemblerprogram. Projektet har strikt pedagogiska syften och används flitigt i vissa datorarkitekturkurser runt om i världen.

En annan GUI-emulator av MIPS-processorer är MARS, även utvecklad för utbildningsändamål, och är särskilt effektiv i samband med Hennessys Computer Organization and Design -bok .

Mer avancerade versioner av gratisemulatorerna är Gxemul (tidigare känd som mips64emul-projekten), såväl som QEMU-projekten. De emulerar olika modeller av MIPS III och MIPS IV mikroprocessorer (som ett komplement till datorsystem som använder dem).

Kommersiella emulatordesigner finns främst tillgängliga för inbäddad användning av MIPS-processorer, såsom Virtutech Simics (MIPS 4Kc och 5Kc, PMC RM9000, QED RM7000), VaST Systems (R3000, R4000) och CoWare (MIPS4KE, MIPS254K och MIPS254K, MIPS254K, MIPS254K och MIPS254K).

Lista över processorer baserade på MIPS-arkitekturen per företag

Intressanta fakta

Se även

Anteckningar

  1. Evolutionen och konsten av MIPS-arkitektur - Electronics Time . Hämtad 26 mars 2019. Arkiverad från originalet 27 mars 2019.
  2. AI Pioneer Wave Computing förvärvar MIPS-teknologier . Hämtad 26 mars 2019. Arkiverad från originalet 27 mars 2019.
  3. V. Avakov, MIPS R10000 mikroprocessor Arkiverad 25 september 2018 på Wayback Machine - Öppna system. DBMS 1995 nr 06
  4. MIPS R3000 Instruktionsuppsättning Sammanfattning (inte tillgänglig länk) . Hämtad 1 juni 2010. Arkiverad från originalet 28 juni 2018. 
  5. Loongson cpu_CPU & Motherboard_江苏龙芯梦兰科技股份有限公司 Arkiverad 16 maj 2010.
  6. Digital mediaprocessor (Realtek) . Hämtad 21 december 2011. Arkiverad från originalet 1 januari 2012.
  7. Secure Media Processor™ Översikt Arkiverad 19 december 2011.
  8. Wave Computing stänger sitt MIPS Open Initiative med omedelbar effekt,  nollvarning . Hackster.io (7 november 2019). Hämtad 7 december 2019. Arkiverad från originalet 7 mars 2021.

Litteratur

Länkar